/* ═══════════════════════════════════════════════════════════
   CORETOWER DATA CENTER — Neo-Tokyo Brutalist Precision
   Palette: void-ink · electric-cobalt · ice-cyan · alert-red
   Fonts:   Syne (display) · Noto Sans JP (body) · JetBrains Mono (data)
   ═══════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=Noto+Sans+JP:wght@300;400;500;600;700&family=JetBrains+Mono:wght@300;400;600&display=swap');

:root {
  /* Palette */
  --ink:     #03060d;
  --ink2:    #080f1a;
  --ink3:    #0d1826;
  --ink4:    #122030;
  --cobalt:  #0055ff;
  --cobalt2: #0040cc;
  --cobalt3: #0030a0;
  --ice:     #00ddff;
  --ice2:    #00aacc;
  --red:     #ff3300;
  --green:   #00ff88;
  --amber:   #ffaa00;
  --silver:  #b8c8d8;
  --silver2: #607080;
  --white:   #edf2f8;
  --rule:    rgba(0,85,255,.14);
  --rule2:   rgba(255,255,255,.06);
  --glow-c:  0 0 80px rgba(0,85,255,.25);
  --glow-i:  0 0 60px rgba(0,221,255,.2);

  /* Typography */
  --ff-d:    'Syne', 'Noto Sans JP', sans-serif;
  --ff-jp:   'Noto Sans JP', sans-serif;
  --ff-mono: 'JetBrains Mono', 'Noto Sans JP', monospace;

  --max:     1340px;
  --ease:    cubic-bezier(.19,1,.22,1);
  --nav-h:   76px;
}

/* ── Reset & Base ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0 }
html { scroll-behavior:smooth; font-size:16px }
body {
  font-family: var(--ff-jp);
  background: var(--ink);
  color: var(--white);
  line-height: 1.7;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  cursor: default;
}
img { display:block; max-width:100%; }
a { color:inherit; text-decoration:none }
a:focus-visible { outline:2px solid var(--ice); outline-offset:3px }
button { font-family: inherit; cursor: pointer }
.wrap { max-width:var(--max); margin:0 auto; padding:0 56px }

/* ── Noise grain overlay ── */
body::before {
  content:''; position:fixed; inset:0; pointer-events:none; z-index:999;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E");
  opacity: .5;
}

/* ── NAV ── */
.nav {
  position: fixed; top:0; left:0; right:0; z-index:500;
  height: var(--nav-h);
  transition: background .4s var(--ease), box-shadow .4s;
}
.nav.scrolled {
  background: rgba(3,6,13,.92);
  backdrop-filter: blur(28px) saturate(1.8);
  border-bottom: 1px solid var(--rule);
  box-shadow: 0 0 60px rgba(0,55,200,.08);
}
.nav-inner {
  height: 100%;
  display: flex; align-items:center; justify-content:space-between;
  max-width: var(--max); margin: 0 auto; padding: 0 56px;
}
.logo {
  display: flex; align-items:center; gap:14px;
  font-family: var(--ff-d); font-size:18px; font-weight:800;
  letter-spacing:.06em; text-transform:uppercase;
}
.logo-box {
  width:38px; height:38px;
  background: var(--cobalt);
  display: flex; align-items:center; justify-content:center;
  position: relative;
  box-shadow: var(--glow-c);
}
.logo-box svg { width:20px; height:20px; color:#fff }
.logo-box::after {
  content:''; position:absolute; inset:-3px;
  border:1px solid rgba(0,85,255,.4);
}
.logo-txt { line-height:1.15 }
.logo-en { color:var(--white); letter-spacing:.1em }
.logo-jp {
  font-family: var(--ff-jp); font-size:10px; font-weight:400;
  color: var(--silver2); letter-spacing:.06em; display:block;
}
.nav-menu { display:flex; align-items:center; gap:4px; list-style:none }
.nav-menu a {
  font-family: var(--ff-jp); font-size:13px; font-weight:500;
  color: var(--silver2); padding:9px 16px;
  border:1px solid transparent; transition: all .2s;
}
.nav-menu a:hover,
.nav-menu a.active {
  color: var(--ice);
  border-color: rgba(0,221,255,.2);
  background: rgba(0,221,255,.04);
}
.nav-btn {
  font-family: var(--ff-d); font-size:12px; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase;
  background: var(--cobalt); color:#fff;
  padding:12px 28px; border:0;
  box-shadow: var(--glow-c);
  transition: all .25s var(--ease);
}
.nav-btn:hover {
  background: var(--ice); color: var(--ink);
  box-shadow: var(--glow-i); transform:translateY(-1px);
}
.burger {
  display:none; background:none;
  border:1px solid var(--rule2); color:var(--ice);
  font-size:20px; padding:7px 12px;
}

/* ── MOBILE MENU ── */
.mob-menu {
  display:none; position:fixed; inset:0; z-index:600;
  background: rgba(3,6,13,.98);
  backdrop-filter: blur(30px);
  flex-direction:column; align-items:center; justify-content:center; gap:28px;
}
.mob-menu.open { display:flex }
.mob-menu a {
  font-family: var(--ff-d); font-size:32px; font-weight:800;
  text-transform:uppercase; letter-spacing:.06em; color:var(--white);
  transition: color .2s;
}
.mob-menu a:hover { color: var(--ice) }
.mob-close {
  position:absolute; top:24px; right:24px;
  background:none; border:1px solid var(--rule2);
  color:var(--ice); font-size:22px; padding:6px 13px;
}

/* ── STATUS BAR ── */
.statusbar {
  background: var(--ink2);
  border-bottom: 1px solid var(--rule);
  padding: 9px 0;
  position: relative; z-index:10;
}
.statusbar-inner {
  display: flex; align-items:center; justify-content:space-between;
  flex-wrap: wrap; gap:8px;
  font-family: var(--ff-mono); font-size:11px; color:var(--silver2);
  letter-spacing:.05em;
}
.st-item { display:flex; align-items:center; gap:7px }
.st-dot {
  width:6px; height:6px; border-radius:50%;
  animation: blink 2.2s ease-in-out infinite;
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.35} }
.st-green { background:var(--green); box-shadow:0 0 8px var(--green) }
.st-cobalt { background:var(--cobalt); box-shadow:0 0 8px var(--cobalt) }
.st-amber  { background:var(--amber); box-shadow:0 0 8px var(--amber) }

/* ── HERO HOME ── */
.hero {
  position:relative; height:100vh; min-height:720px;
  display:flex; align-items:flex-end; overflow:hidden;
}
.hero-photo {
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; object-position:center 35%;
  filter: brightness(.55) saturate(.7) hue-rotate(10deg);
  transform: scale(1.04);
  animation: heroZoom 18s var(--ease) forwards;
}
@keyframes heroZoom { to { transform:scale(1) } }
.hero-grad {
  position:absolute; inset:0;
  background: linear-gradient(
    160deg,
    rgba(3,6,13,.6) 0%,
    rgba(0,30,80,.15) 40%,
    rgba(3,6,13,.9) 75%,
    var(--ink) 100%
  );
}
.hero-grad2 {
  position:absolute; inset:0;
  background: linear-gradient(to right, rgba(3,6,13,.75) 0%, transparent 55%);
}
/* Animated cobalt orb */
.hero-orb {
  position:absolute; right:8%; top:20%;
  width:480px; height:480px; border-radius:50%;
  background: radial-gradient(circle at 40% 40%,
    rgba(0,85,255,.22) 0%,
    rgba(0,221,255,.08) 40%,
    transparent 70%
  );
  animation: orbFloat 8s ease-in-out infinite;
  pointer-events:none;
}
@keyframes orbFloat {
  0%,100%{ transform:translateY(0) scale(1) }
  50%{ transform:translateY(-24px) scale(1.04) }
}
/* Bottom glow line */
.hero-line {
  position:absolute; bottom:0; left:0; right:0; height:1px;
  background: linear-gradient(to right, transparent, var(--cobalt) 35%, var(--ice) 65%, transparent);
  box-shadow: 0 0 40px var(--cobalt), 0 0 100px rgba(0,85,255,.25);
}
/* Diagonal decorative text */
.hero-bg-txt {
  position:absolute; right:-40px; top:50%;
  transform:translateY(-50%) rotate(-90deg) translateX(50%);
  font-family:var(--ff-d); font-size:clamp(60px,10vw,120px); font-weight:800;
  letter-spacing:.15em; text-transform:uppercase;
  color:rgba(0,85,255,.04); pointer-events:none; white-space:nowrap;
  user-select:none;
}

.hero-content {
  position:relative; z-index:2; width:100%;
  padding-bottom:96px;
  animation: heroUp .9s var(--ease) .15s both;
}
@keyframes heroUp { from{opacity:0;transform:translateY(36px)} to{opacity:1;transform:none} }
.hero-eyebrow {
  display:inline-flex; align-items:center; gap:14px;
  font-family:var(--ff-mono); font-size:11px; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase; color:var(--ice);
  margin-bottom:22px;
}
.hero-eyebrow::before {
  content:''; width:36px; height:1px;
  background:var(--ice); box-shadow:0 0 8px var(--ice);
}
.hero-h1 {
  font-family:var(--ff-d); font-weight:800;
  font-size: clamp(52px,9vw,120px);
  line-height:.96; letter-spacing:-.02em;
  text-transform:uppercase; color:var(--white);
  max-width:860px; margin-bottom:24px;
}
.hero-h1 .accent { color:var(--ice); text-shadow:0 0 50px rgba(0,221,255,.55) }
.hero-lead {
  font-family:var(--ff-jp); font-size:17px; font-weight:300;
  color: rgba(237,242,248,.58); max-width:480px; line-height:1.85;
  margin-bottom:44px;
}
.hero-actions { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:68px }
.btn {
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--ff-d); font-weight:700; font-size:12px;
  letter-spacing:.12em; text-transform:uppercase;
  padding:15px 36px; border:0; transition:all .25s var(--ease);
}
.btn-cobalt {
  background:var(--cobalt); color:#fff;
  box-shadow:var(--glow-c);
}
.btn-cobalt:hover { background:var(--ice); color:var(--ink); box-shadow:var(--glow-i); transform:translateY(-2px) }
.btn-outline {
  background:transparent; color:var(--white);
  border:1.5px solid rgba(237,242,248,.22);
}
.btn-outline:hover { border-color:var(--ice); color:var(--ice) }
/* Hero stats strip */
.hero-stats {
  display:flex; gap:0;
  padding-top:32px; border-top:1px solid var(--rule2);
}
.hstat {
  padding:0 44px 0 0; margin-right:44px;
  border-right:1px solid var(--rule2);
}
.hstat:last-child { border-right:0 }
.hstat-n {
  font-family:var(--ff-d); font-size:46px; font-weight:800;
  color:var(--ice); line-height:1;
  text-shadow:0 0 30px rgba(0,221,255,.45);
}
.hstat-l { font-family:var(--ff-jp); font-size:12px; color:var(--silver2); margin-top:5px }

/* ── PAGE HERO (inner pages) ── */
.page-hero {
  position:relative; overflow:hidden;
  padding: calc(var(--nav-h) + 90px) 0 88px;
}
.ph-photo {
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; object-position:center 40%;
  filter:brightness(.45) saturate(.65) hue-rotate(15deg);
}
.ph-grad {
  position:absolute; inset:0;
  background:linear-gradient(to bottom, rgba(3,6,13,.3) 0%, rgba(3,6,13,.88) 100%);
}
.ph-grad2 {
  position:absolute; inset:0;
  background:linear-gradient(to right, rgba(3,6,13,.8) 0%, transparent 60%);
}
.ph-content { position:relative; z-index:2 }
.ph-line {
  position:absolute; bottom:0; left:0; right:0; height:1px;
  background:linear-gradient(to right, transparent, var(--cobalt) 30%, var(--ice) 70%, transparent);
  box-shadow:0 0 30px var(--cobalt);
}
.ph-eyebrow {
  display:inline-flex; align-items:center; gap:12px;
  font-family:var(--ff-mono); font-size:10px; font-weight:600;
  letter-spacing:.26em; text-transform:uppercase; color:var(--ice);
  margin-bottom:18px;
}
.ph-eyebrow::before { content:''; width:28px; height:1px; background:var(--ice); box-shadow:0 0 6px var(--ice) }
.ph-h1 {
  font-family:var(--ff-d); font-weight:800;
  font-size:clamp(36px,5.5vw,72px);
  line-height:1.06; text-transform:uppercase; letter-spacing:-.01em;
}
.ph-h1 em { font-style:normal; color:var(--ice) }
.ph-sub {
  font-family:var(--ff-jp); font-size:17px; font-weight:300;
  color:rgba(237,242,248,.6); max-width:520px; line-height:1.85; margin-top:16px;
}

/* ── SECTION ── */
.sec { padding:110px 0; position:relative; z-index:1 }
.sec-dark { background:var(--ink2) }
.sec-tag {
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--ff-mono); font-size:10px; font-weight:600;
  letter-spacing:.26em; text-transform:uppercase; color:var(--ice);
  margin-bottom:14px;
}
.sec-tag::before { content:''; width:22px; height:1px; background:var(--ice); box-shadow:0 0 4px var(--ice) }
.sec-h {
  font-family:var(--ff-d); font-weight:800;
  font-size:clamp(32px,4.5vw,60px);
  line-height:1.04; text-transform:uppercase; letter-spacing:-.01em;
}
.sec-h .c { color:var(--ice) }
.sec-sub {
  font-family:var(--ff-jp); font-size:16px; font-weight:300;
  color:var(--silver2); max-width:580px; line-height:1.85; margin-top:16px;
}

/* ── TICKER ── */
.ticker {
  background:var(--ink3);
  border-top:1px solid var(--cobalt);
  border-bottom:1px solid var(--rule);
  overflow:hidden; padding:0;
  box-shadow:0 0 30px rgba(0,55,200,.1);
}
.ticker-wrap { display:flex; white-space:nowrap; animation:scrollLeft 44s linear infinite }
.tick {
  flex-shrink:0; padding:13px 48px;
  font-family:var(--ff-mono); font-size:12px; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase; color:var(--silver2);
  display:inline-flex; align-items:center; gap:18px;
}
.tick.on { color:var(--ice) }
.tick-sep { color:var(--cobalt); font-size:7px }
@keyframes scrollLeft { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ── SERVICE CARDS ── */
.svc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--rule) }
.svc-card {
  background:var(--ink2); padding:48px 36px;
  position:relative; overflow:hidden;
  transition: background .3s var(--ease), transform .3s var(--ease);
  cursor:default;
}
.svc-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background: linear-gradient(to right, var(--cobalt), var(--ice));
  transform:scaleX(0); transform-origin:left;
  transition:transform .35s var(--ease);
}
.svc-card:hover { background:var(--ink3); transform:translateY(-4px) }
.svc-card:hover::before { transform:scaleX(1) }
.svc-card:hover .svc-icon { border-color:var(--ice); box-shadow:0 0 20px rgba(0,221,255,.2) }
.svc-icon {
  width:54px; height:54px;
  border:1px solid var(--rule); color:var(--ice);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:26px; transition:all .3s;
}
.svc-icon svg { width:26px; height:26px }
.svc-num {
  font-family:var(--ff-mono); font-size:10px; font-weight:600;
  color:var(--cobalt); letter-spacing:.18em; margin-bottom:10px; display:block;
}
.svc-card h3 {
  font-family:var(--ff-d); font-size:22px; font-weight:700;
  text-transform:uppercase; letter-spacing:.04em; margin-bottom:10px;
}
.svc-card p { font-size:14px; color:var(--silver2); font-weight:300; line-height:1.85 }
.svc-more {
  display:inline-flex; align-items:center; gap:7px;
  margin-top:20px; font-family:var(--ff-mono); font-size:10px; font-weight:600;
  letter-spacing:.14em; text-transform:uppercase; color:var(--ice);
  opacity:0; transform:translateX(-10px);
  transition:opacity .3s, transform .3s;
}
.svc-card:hover .svc-more { opacity:1; transform:none }

/* ── STATS ── */
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--rule) }
.stat-block {
  background:var(--ink2); padding:44px 36px;
  border-top:2px solid transparent;
  transition:all .3s;
}
.stat-block:hover { background:var(--ink3); border-top-color:var(--cobalt) }
.stat-n {
  font-family:var(--ff-d); font-size:58px; font-weight:800;
  color:var(--ice); line-height:1;
  text-shadow:0 0 35px rgba(0,221,255,.4);
}
.stat-u { font-size:28px; color:var(--cobalt) }
.stat-l { font-family:var(--ff-jp); font-size:13px; color:var(--silver2); margin-top:8px }

/* ── GALLERY ── */
.gallery { display:grid; grid-template-columns:1.4fr 1fr 1fr; grid-template-rows:280px 280px; gap:3px }
.gal-item { position:relative; overflow:hidden; cursor:pointer }
.gal-item img {
  width:100%; height:100%; object-fit:cover;
  filter:saturate(.5) brightness(.7) hue-rotate(12deg);
  transition:transform .7s var(--ease), filter .4s;
}
.gal-item:hover img { transform:scale(1.07); filter:saturate(.9) brightness(.85) hue-rotate(0) }
.gal-tall { grid-row:span 2 }
.gal-cap {
  position:absolute; bottom:0; left:0; right:0;
  padding:18px 22px;
  background:linear-gradient(to top, rgba(3,6,13,.94), transparent);
  font-family:var(--ff-mono); font-size:11px; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase; color:var(--ice);
  transform:translateY(100%); transition:transform .3s var(--ease);
}
.gal-item:hover .gal-cap { transform:none }
.gal-cap small { display:block; font-family:var(--ff-jp); font-size:12px; color:var(--silver); letter-spacing:0; text-transform:none; margin-top:3px }

/* ── PROCESS STEPS ── */
.proc-grid {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:0; position:relative;
}
.proc-grid::before {
  content:''; position:absolute; top:40px; left:0; right:0; height:1px;
  background:linear-gradient(to right, transparent, var(--cobalt), var(--ice), var(--cobalt), transparent);
  box-shadow:0 0 10px var(--cobalt); z-index:0;
}
.proc-step {
  padding:88px 32px 52px; border-right:1px solid var(--rule);
  position:relative; z-index:1;
}
.proc-step:last-child { border-right:0 }
.proc-n {
  width:80px; height:80px; border-radius:50%;
  border:2px solid var(--cobalt); background:var(--ink2);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--ff-d); font-size:24px; font-weight:800; color:var(--ice);
  margin-bottom:28px;
  box-shadow:0 0 24px rgba(0,85,255,.25), inset 0 0 24px rgba(0,85,255,.06);
}
.proc-step h3 {
  font-family:var(--ff-d); font-size:18px; font-weight:700;
  text-transform:uppercase; letter-spacing:.04em; margin-bottom:10px;
}
.proc-step p { font-size:13px; color:var(--silver2); font-weight:300; line-height:1.85 }

/* ── FEATURE LIST ── */
.feat-list { list-style:none; display:grid; grid-template-columns:1fr 1fr; gap:10px 32px }
.feat-list li {
  display:flex; align-items:flex-start; gap:10px;
  font-size:14px; color:var(--silver); font-weight:300;
  padding:9px 0; border-bottom:1px solid var(--rule2);
}
.feat-list li::before { content:'▸'; color:var(--ice); font-size:9px; margin-top:5px; flex-shrink:0 }

/* ── SPEC TABLE ── */
.stbl { width:100%; border-collapse:collapse }
.stbl tr { border-bottom:1px solid var(--rule2); transition:background .15s }
.stbl tr:hover { background:var(--ink3) }
.stbl th, .stbl td { padding:13px 18px; font-size:14px; text-align:left }
.stbl th {
  font-family:var(--ff-mono); font-size:10px; font-weight:600;
  letter-spacing:.16em; text-transform:uppercase; color:var(--cobalt);
  background:var(--ink3); border-bottom:1px solid var(--rule);
}
.stbl td { color:var(--silver); font-weight:300 }
.stbl td:first-child { color:var(--white); font-weight:500 }
.badge-ok {
  display:inline-flex; align-items:center; gap:6px;
  font-family:var(--ff-mono); font-size:10px; color:var(--green);
  background:rgba(0,255,136,.07); border:1px solid rgba(0,255,136,.2);
  padding:4px 10px;
}
.badge-ok::before { content:''; width:5px; height:5px; border-radius:50%; background:var(--green); animation:blink 2s infinite }

/* ── CERT TAGS ── */
.certs { display:flex; flex-wrap:wrap; gap:10px; margin-top:24px }
.cert-tag {
  font-family:var(--ff-mono); font-size:10px; font-weight:600;
  letter-spacing:.1em; color:var(--cobalt);
  background:rgba(0,85,255,.08); border:1px solid rgba(0,85,255,.25);
  padding:7px 16px;
}

/* ── NEWS CARDS ── */
.news-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px }
.news-card {
  background:var(--ink2); border:1px solid var(--rule);
  padding:28px 24px;
  transition:border-color .3s, transform .3s;
}
.news-card:hover { border-color:var(--cobalt); transform:translateY(-3px) }
.news-date { font-family:var(--ff-mono); font-size:10px; color:var(--cobalt); letter-spacing:.1em; margin-bottom:10px; display:block }
.news-tag {
  display:inline-block; padding:3px 10px;
  background:rgba(0,85,255,.09); border:1px solid var(--rule);
  font-family:var(--ff-mono); font-size:9px; color:var(--cobalt);
  letter-spacing:.1em; text-transform:uppercase; margin-bottom:10px;
}
.news-card h3 { font-size:15px; font-weight:600; line-height:1.6; margin-bottom:8px }
.news-card p { font-size:13px; color:var(--silver2); font-weight:300; line-height:1.75 }

/* ── SPLIT SECTION ── */
.split { display:grid; grid-template-columns:1fr 1fr; gap:0; min-height:520px }
.split-img { position:relative; overflow:hidden }
.split-img img {
  width:100%; height:100%; object-fit:cover;
  filter:brightness(.55) saturate(.65) hue-rotate(15deg);
  transition:transform .8s var(--ease), filter .5s;
}
.split:hover .split-img img { transform:scale(1.03); filter:brightness(.65) saturate(.75) }
.split-ov {
  position:absolute; inset:0;
  background:linear-gradient(to right, transparent 60%, var(--ink) 100%);
}
.split-body {
  background:var(--ink); padding:72px 64px;
  display:flex; flex-direction:column; justify-content:center;
  border-left:1px solid var(--rule);
}
.split-body p { font-size:16px; color:var(--silver2); font-weight:300; line-height:1.9; margin-bottom:18px }

/* ── TIMELINE ── */
.tl { padding-left:28px; position:relative }
.tl::before {
  content:''; position:absolute; left:5px; top:8px; bottom:0; width:1px;
  background:linear-gradient(to bottom, var(--cobalt), var(--cobalt3), transparent);
}
.tl-item { position:relative; padding-bottom:32px }
.tl-dot {
  position:absolute; left:-24px; top:6px;
  width:12px; height:12px; border-radius:50%;
  border:2px solid var(--cobalt); background:var(--ink);
  box-shadow:0 0 12px rgba(0,85,255,.5);
}
.tl-year { font-family:var(--ff-mono); font-size:11px; color:var(--cobalt); letter-spacing:.08em; margin-bottom:4px }
.tl-item h4 { font-family:var(--ff-d); font-size:16px; font-weight:700; text-transform:uppercase; margin-bottom:5px }
.tl-item p { font-size:13px; color:var(--silver2); font-weight:300; line-height:1.75 }

/* ── CTA BAND ── */
.cta-band {
  background:var(--ink2); border-top:1px solid var(--rule);
  padding:88px 0; text-align:center; position:relative; overflow:hidden;
}
.cta-band::before {
  content:'TOKYO'; position:absolute; left:50%; top:50%;
  transform:translate(-50%,-50%);
  font-family:var(--ff-d); font-size:30vw; font-weight:800;
  color:rgba(0,85,255,.03); white-space:nowrap; pointer-events:none;
  letter-spacing:-.04em; text-transform:uppercase;
}
.cta-band h2 {
  font-family:var(--ff-d); font-size:clamp(32px,5vw,64px); font-weight:800;
  text-transform:uppercase; letter-spacing:-.01em; margin-bottom:16px;
  position:relative; z-index:1;
}
.cta-band h2 span { color:var(--ice) }
.cta-band p { font-size:17px; color:var(--silver2); margin-bottom:44px; position:relative; z-index:1 }
.cta-btns { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; position:relative; z-index:1 }

/* ── PERSON CARDS ── */
.person-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px }
.person-card {
  background:var(--ink2); border:1px solid var(--rule); padding:36px 28px;
  transition:border-color .3s, transform .3s;
}
.person-card:hover { border-color:var(--cobalt); transform:translateY(-3px) }
.person-avatar {
  width:60px; height:60px;
  border:2px solid var(--cobalt); background:var(--ink3);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--ff-d); font-size:22px; font-weight:800; color:var(--ice);
  margin-bottom:16px;
  box-shadow:0 0 20px rgba(0,85,255,.2);
}
.person-name { font-family:var(--ff-jp); font-size:18px; font-weight:700; margin-bottom:3px }
.person-role { font-family:var(--ff-mono); font-size:10px; color:var(--ice); letter-spacing:.1em; margin-bottom:12px }
.person-card p { font-size:13px; color:var(--silver2); font-weight:300; line-height:1.8 }

/* ── FAQ ── */
.faq-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px }
.faq-item { background:var(--ink2); border:1px solid var(--rule); padding:24px }
.faq-q {
  font-family:var(--ff-jp); font-size:14px; font-weight:600; margin-bottom:10px;
  display:flex; align-items:flex-start; gap:12px;
}
.faq-q::before {
  content:'Q'; font-family:var(--ff-mono); font-size:12px; font-weight:600;
  color:var(--cobalt); background:rgba(0,85,255,.1); border:1px solid var(--rule);
  padding:2px 8px; flex-shrink:0; margin-top:1px;
}
.faq-a { font-size:13px; color:var(--silver2); font-weight:300; line-height:1.8; padding-left:36px }

/* ── FOOTER ── */
footer { background:var(--ink); border-top:1px solid var(--rule) }
.foot-map-wrap { position:relative }
.foot-map-wrap::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:60px;
  background:linear-gradient(to bottom, transparent, var(--ink));
  pointer-events:none;
}
.foot-map {
  width:100%; height:340px; border:0; display:block;
  filter:invert(.88) hue-rotate(188deg) saturate(.75) brightness(.65);
}
.foot-grid {
  display:grid; grid-template-columns:1.3fr 1fr 1.5fr;
  gap:60px; padding:60px 56px;
  max-width:var(--max); margin:0 auto;
  border-bottom:1px solid var(--rule);
}
.foot-brand { font-family:var(--ff-d); font-size:24px; font-weight:800; letter-spacing:.06em; text-transform:uppercase; margin-bottom:3px }
.foot-brand span { color:var(--ice) }
.foot-brand-jp { font-family:var(--ff-jp); font-size:12px; color:var(--silver2); margin-bottom:16px }
.foot-desc { font-size:13px; color:var(--silver2); font-weight:300; line-height:1.85; margin-bottom:20px; max-width:280px }
.foot-h {
  font-family:var(--ff-mono); font-size:10px; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase; color:var(--cobalt);
  margin-bottom:20px; padding-bottom:10px; border-bottom:1px solid var(--rule);
}
.addr-blk { margin-bottom:22px }
.addr-name {
  font-family:var(--ff-jp); font-size:14px; font-weight:700; margin-bottom:6px;
  display:flex; align-items:center; gap:9px;
}
.addr-name::before {
  content:''; width:8px; height:8px; border-radius:50%;
  background:var(--ice); box-shadow:0 0 8px var(--ice);
  animation:blink 2.5s ease-in-out infinite;
}
.addr-dtl { font-family:var(--ff-jp); font-size:13px; color:var(--silver2); font-weight:300; line-height:1.9 }
.addr-dtl a { color:var(--ice); transition:opacity .2s }
.addr-dtl a:hover { opacity:.7 }
/* Footer form */
.fform { display:flex; flex-direction:column; gap:10px }
.fform input, .fform textarea, .fform select {
  background:rgba(255,255,255,.04);
  border:1px solid var(--rule); color:var(--white);
  padding:11px 14px;
  font-family:var(--ff-jp); font-size:13px;
  outline:none; transition:border-color .2s; width:100%;
}
.fform input:focus, .fform textarea:focus, .fform select:focus { border-color:var(--cobalt) }
.fform input::placeholder, .fform textarea::placeholder { color:var(--silver2) }
.fform select option { background:var(--ink2) }
.fform textarea { resize:vertical; min-height:88px }
.fform-row { display:grid; grid-template-columns:1fr 1fr; gap:10px }
.fform button {
  background:var(--cobalt); color:#fff;
  font-family:var(--ff-d); font-size:12px; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase;
  padding:13px 20px; border:0;
  display:flex; align-items:center; justify-content:center; gap:8px;
  transition:all .25s var(--ease);
  box-shadow:0 0 20px rgba(0,85,255,.3);
}
.fform button:hover { background:var(--ice); color:var(--ink); box-shadow:var(--glow-i) }
.foot-bottom {
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px;
  padding:22px 56px; max-width:var(--max); margin:0 auto;
  font-family:var(--ff-mono); font-size:11px; color:var(--silver2);
  letter-spacing:.05em;
}
.foot-bottom a { color:var(--silver2); transition:color .2s }
.foot-bottom a:hover { color:var(--ice) }
.foot-nav { display:flex; gap:12px; flex-wrap:wrap }

/* ── REVEAL ANIMATIONS ── */
.fade { opacity:0; transform:translateY(22px); transition:opacity .7s var(--ease), transform .7s var(--ease) }
.fade.vis { opacity:1; transform:none }
.d1{transition-delay:.08s} .d2{transition-delay:.16s} .d3{transition-delay:.24s} .d4{transition-delay:.32s}

/* ── COUNTER ── */
[data-count] { font-variant-numeric:tabular-nums }

/* ── CONTACT PAGE FORM ── */
.contact-form {
  display:grid; grid-template-columns:1fr 1fr; gap:16px;
}
.cf-full { grid-column:1/-1 }
.cf-group { display:flex; flex-direction:column; gap:6px }
.cf-label {
  font-family:var(--ff-mono); font-size:10px; font-weight:600;
  letter-spacing:.16em; text-transform:uppercase; color:var(--cobalt);
}
.cf-input {
  background:rgba(255,255,255,.04);
  border:1px solid var(--rule); color:var(--white);
  padding:13px 16px; font-family:var(--ff-jp); font-size:14px;
  outline:none; transition:border-color .2s, box-shadow .2s; width:100%;
}
.cf-input:focus { border-color:var(--cobalt); box-shadow:0 0 0 3px rgba(0,85,255,.12) }
.cf-input::placeholder { color:var(--silver2) }
.cf-input option { background:var(--ink2) }
.cf-submit {
  background:var(--cobalt); color:#fff;
  font-family:var(--ff-d); font-size:14px; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase;
  padding:18px 48px; border:0;
  box-shadow:var(--glow-c);
  transition:all .25s var(--ease);
  display:inline-flex; align-items:center; gap:10px;
}
.cf-submit:hover { background:var(--ice); color:var(--ink); box-shadow:var(--glow-i) }
.agree-row {
  display:flex; align-items:flex-start; gap:10px;
  padding:14px; background:rgba(255,255,255,.02);
  border:1px solid var(--rule2); font-size:13px; color:var(--silver2);
}
.agree-row input { accent-color:var(--cobalt); flex-shrink:0; margin-top:3px }
.agree-row a { color:var(--cobalt) }

/* ── RESPONSIVE ── */
@media(max-width:1080px){
  .svc-grid,.stats-grid { grid-template-columns:1fr 1fr }
  .proc-grid { grid-template-columns:1fr 1fr }
  .proc-grid::before { display:none }
  .proc-step { border-bottom:1px solid var(--rule) }
  .split { grid-template-columns:1fr }
  .split-img { min-height:340px }
  .split-ov { background:linear-gradient(to bottom, transparent 40%, var(--ink) 100%) }
  .split-body { padding:52px 40px }
  .foot-grid { grid-template-columns:1fr 1fr; gap:40px }
  .gallery { grid-template-columns:1fr 1fr; grid-template-rows:220px 220px 220px }
  .gal-tall { grid-row:span 1 }
}
@media(max-width:768px){
  .nav-menu,.nav-btn { display:none }
  .burger { display:block }
  .svc-grid,.news-grid,.stats-grid,.person-grid,.faq-grid { grid-template-columns:1fr }
  .proc-grid { grid-template-columns:1fr }
  .proc-step { border-right:0 }
  .gallery { grid-template-columns:1fr }
  .hero-stats { flex-wrap:wrap; gap:20px }
  .hstat { border-right:0; margin-right:0 }
  .feat-list { grid-template-columns:1fr }
  .split { grid-template-columns:1fr }
  .foot-grid { grid-template-columns:1fr; padding:40px 24px }
  .foot-bottom { padding:20px 24px }
  .contact-form { grid-template-columns:1fr }
  .cf-full { grid-column:1 }
  .fform-row { grid-template-columns:1fr }
  .wrap { padding:0 24px }
  .sec { padding:72px 0 }
  .nav-inner { padding:0 24px }
}
