/* ============ TOKENS ============ */
:root{
  --bg:#080a10;
  --bg-2:#0d1018;
  --bg-3:#11141d;
  --fg:#e8eef0;
  --fg-2:#a0a8b0;
  --mute:#5a6068;
  --line:#1c2028;
  --line-2:#262a34;
  --r:#ff0044;
  --g:#00ffd0;
  --b:#3060ff;
  --y:#ffd14a;
  --pad-x: clamp(20px, 4vw, 64px);
  --pad-y: clamp(80px, 9vw, 140px);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg); color:var(--fg);
  font-family:"JetBrains Mono","Noto Sans JP",monospace;
  font-weight:300; font-size:14px; line-height:1.7;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img,video{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none;cursor:pointer}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
::selection{background:var(--g);color:#000}
.nb{ display:inline-block; white-space:nowrap; }

/* ============ GLOBAL OVERLAYS ============ */
body::before{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:200;
  background:repeating-linear-gradient(0deg,rgba(255,255,255,.018) 0px,rgba(255,255,255,.018) 1px,transparent 1px,transparent 4px);
}
body::after{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:200;
  box-shadow: inset 0 0 240px rgba(0,0,0,.85); mix-blend-mode:multiply;
}
.scan{
  position:fixed; left:0; right:0; height:140px; z-index:199;
  background:linear-gradient(180deg, transparent 0%, rgba(0,255,208,.05) 50%, transparent 100%);
  pointer-events:none; animation:scan 7s linear infinite;
}
@keyframes scan{ from{ top:-140px } to{ top:100% } }

/* ============ BOOT LOADER ============ */
.boot{
  position:fixed; inset:0; z-index:1000;
  background:#000; color:var(--g);
  font-family:"JetBrains Mono",monospace; font-size:12px;
  padding:6vw; display:flex; flex-direction:column; justify-content:center; gap:8px;
  animation: bootOut 1.6s ease-in 1.2s forwards;
}
.boot-line{ opacity:0; animation: bootIn .15s linear forwards; }
.boot-line:nth-child(1){ animation-delay:.1s }
.boot-line:nth-child(2){ animation-delay:.3s }
.boot-line:nth-child(3){ animation-delay:.55s }
.boot-line:nth-child(4){ animation-delay:.8s }
.boot-line .dot{ display:inline-block; width:9px; height:9px; background:var(--r); border-radius:50%; margin-right:8px; animation:b .8s steps(2) infinite; }
.boot-line b{ color:var(--y); font-weight:500; }
.boot-bar{ margin-top:18px; height:3px; background:#0a0e08; border:1px solid var(--g); position:relative; max-width:420px; }
.boot-bar i{ position:absolute; left:0; top:0; bottom:0; width:0; background:var(--g); animation: bar 1.4s linear .4s forwards; }
@keyframes bar{ to{ width:100% } }
@keyframes bootIn{ to{ opacity:1 } }
@keyframes bootOut{ to{ opacity:0; visibility:hidden; pointer-events:none } }

/* ============ HEADER ============ */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:90;
  display:grid; grid-template-columns:auto 1fr auto; gap:24px; align-items:center;
  padding:14px var(--pad-x);
  background:rgba(8,10,16,.55); backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
  transition: padding .3s, background .3s;
}
.site-header.is-scrolled{ padding:10px var(--pad-x); background:rgba(8,10,16,.85) }
.brand{
  font-family:Anton; font-size:24px; letter-spacing:.02em;
  display:inline-block; line-height:1;
}
.brand .g{
  position:relative; color:var(--fg);
  display:inline-block;
}
.brand .g::before, .brand .g::after{
  content:attr(data-text); position:absolute; left:0; top:0; width:100%; height:100%; mix-blend-mode:screen;
}
.brand .g::before{ color:var(--r); transform:translate(-2px,0); animation:gl 4s steps(1) infinite; }
.brand .g::after{ color:var(--g); transform:translate(2px,0); animation:gl 4s steps(1) infinite reverse; }
@keyframes gl{
  0%,90%,100%{ transform:translate(0,0); }
  3%{ transform:translate(-3px,1px); }
  5%{ transform:translate(2px,-1px); }
  7%{ transform:translate(-1px,0); }
}
.nav{
  justify-self:center;
  display:flex; gap:28px;
}
.nav a{
  font-size:11px; letter-spacing:.25em; text-transform:uppercase; color:var(--fg-2);
  position:relative; padding:6px 0; transition:color .2s;
}
.nav a::before{ content:"["; color:var(--mute); margin-right:4px; opacity:0; transition:opacity .2s }
.nav a::after{ content:"]"; color:var(--mute); margin-left:4px; opacity:0; transition:opacity .2s }
.nav a:hover{ color:var(--g) }
.nav a:hover::before, .nav a:hover::after{ opacity:1 }

.header-meta{ display:flex; gap:14px; align-items:center; font-size:11px; color:var(--g); letter-spacing:.15em; }
.header-meta .rec-dot{ width:9px; height:9px; background:var(--r); border-radius:50%; animation:b 1.2s steps(2) infinite }
.lang{ display:flex; gap:6px; align-items:center; font-family:"JetBrains Mono"; font-size:11px; letter-spacing:.15em; }
.lang-btn{ padding:2px 6px; color:var(--mute); transition:color .2s; cursor:pointer; }
.lang-btn:hover{ color:var(--fg) }
.lang-btn.on{ color:var(--g); border-bottom:1px solid var(--g); }
.lang-sep{ color:var(--mute) }
@keyframes b{ 50%{ opacity:.2 } }

.nav-toggle{ display:none; width:32px; height:24px; flex-direction:column; justify-content:space-between; }
.nav-toggle span{ height:1px; background:var(--g); width:100% }

@media (max-width:920px){
  .nav-toggle{ display:flex }
  .header-meta{ gap:8px; }
  .header-meta .tc{ display:none }
}
@media (max-width:920px){
  /* full-screen drawer on mobile */
  .nav{
    position:fixed; top:0; left:0;
    width:100vw; height:100vh; height:100dvh;
    z-index:80;
    background:rgba(8,10,16,.96); backdrop-filter:blur(20px);
    flex-direction:column; gap:24px; align-items:center; justify-content:center;
    padding: 80px 24px 40px;
    transform: translateX(101vw); transition: transform .35s cubic-bezier(.6,.2,.2,1);
    pointer-events:none;
  }
  body.nav-open .nav{ transform: translateX(0); pointer-events:auto; }
  .nav a{ font-size:18px; letter-spacing:.3em; }
  body.nav-open .nav-toggle span:nth-child(1){ transform:translateY(11px) rotate(45deg); }
  body.nav-open .nav-toggle span:nth-child(2){ transform:translateY(-11px) rotate(-45deg); }
  .nav-toggle span{ transition: transform .3s; }
}

/* ============ HERO ============ */
.hero{
  min-height:100vh; position:relative; overflow:hidden;
  display:flex; align-items:center; padding: 120px var(--pad-x) 100px;
}
.hero-bg{
  position:absolute; inset:0; z-index:0; overflow:hidden;
  background:#000;
}
.hero-video{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
  filter: saturate(1.1) contrast(1.05);
}
.hero-tint{
  position:absolute; inset:0; z-index:1;
  background:
    radial-gradient(ellipse at 20% 30%, rgba(48,96,255,.18), transparent 55%),
    radial-gradient(ellipse at 80% 70%, rgba(255,0,68,.22), transparent 55%),
    radial-gradient(ellipse at 50% 100%, rgba(0,255,208,.12), transparent 60%),
    linear-gradient(180deg, rgba(8,10,16,.55) 0%, rgba(8,10,16,.35) 40%, rgba(8,10,16,.6) 75%, rgba(8,10,16,.92) 100%);
  mix-blend-mode:multiply;
}
.hero-bg::after{
  content:""; position:absolute; inset:0; z-index:2;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='.85'/%3E%3C/filter%3E%3Crect width='100' height='100' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E");
  opacity:.18; mix-blend-mode:overlay; pointer-events:none;
}
.hero-grid{
  position:absolute; inset:0; z-index:1;
  background-image:
    linear-gradient(rgba(0,255,208,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,255,208,.05) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: linear-gradient(180deg, transparent, black 30%, black 70%, transparent);
  -webkit-mask-image: linear-gradient(180deg, transparent, black 30%, black 70%, transparent);
}

.hero-marker{
  position:absolute; z-index:3;
  font-family:"JetBrains Mono"; font-size:11px; letter-spacing:.2em; color:var(--g);
  display:flex; align-items:center; gap:8px;
  text-transform:uppercase;
}
.hero-marker .bracket{
  display:inline-block; width:24px; height:18px;
  border-left:1px solid var(--g); border-top:1px solid var(--g);
}
.hero-marker .bracket.r{ border:0; border-right:1px solid var(--g); border-top:1px solid var(--g); }
.hero-marker .bracket.b{ border:0; border-left:1px solid var(--g); border-bottom:1px solid var(--g); }
.hero-marker .bracket.br{ border:0; border-right:1px solid var(--g); border-bottom:1px solid var(--g); }
.hero-marker.top-l{ top:84px; left:var(--pad-x); }
.hero-marker.top-r{ top:84px; right:var(--pad-x); }
.hero-marker.bot-l{ bottom:80px; left:var(--pad-x); }
.hero-marker.bot-r{ bottom:80px; right:var(--pad-x); }

.hero-in{ position:relative; z-index:2; max-width:1200px; }

.kicker{
  font-size:11px; letter-spacing:.4em; color:var(--g); text-transform:uppercase;
  margin-bottom:30px; display:flex; align-items:center; gap:14px; font-weight:500;
}
.kicker .rec{ width:9px; height:9px; background:var(--r); border-radius:50%; animation:b 1.2s steps(2) infinite; }
.kicker code{ color:var(--mute); font-family:"JetBrains Mono"; }

h1{
  font-family:Anton;
  font-size: clamp(54px, 11vw, 180px);
  line-height:.86; letter-spacing:-.02em;
  text-transform:uppercase;
  color:var(--fg);
  margin-bottom:32px;
}
h1 .line{ display:block; }
h1 i{ font-style:normal; color:var(--g); }

/* RGB glitch text — matches the header brand subtle effect */
.glitch{
  display:inline-block; position:relative;
}
.glitch::before, .glitch::after{
  content:attr(data-text); position:absolute; left:0; top:0; width:100%; height:100%;
  mix-blend-mode:screen;
}
.glitch::before{
  color:var(--r); transform:translate(-2px,0);
  animation: gl 4s steps(1) infinite;
}
.glitch::after{
  color:var(--g); transform:translate(2px,0);
  animation: gl 4s steps(1) infinite reverse;
}

.cli{
  font-family:"JetBrains Mono"; font-size:12px; color:var(--mute);
  margin-bottom:18px;
}
.cli b{ color:var(--g); font-weight:500; }
.cli.small{ font-size:11px; opacity:.8 }

.lead{
  font-family:"Noto Sans JP"; font-size:14px; line-height:2;
  color:var(--fg-2); max-width:640px; margin-bottom:32px;
  font-weight:300;
  border-left:2px solid var(--r); padding-left:18px;
}
.lead b{ color:var(--g); font-weight:500; }

.lead-jp{
  font-family:"Noto Sans JP"; font-size:15px; line-height:2;
  color:var(--fg-2); max-width:580px; margin-bottom:18px; font-weight:300;
}
.lead-jp b{ color:var(--g); font-weight:500; }

.hero-actions{ display:flex; gap:14px; flex-wrap:wrap; }

.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:14px 24px;
  border:1px solid var(--g); color:var(--g);
  font-size:12px; letter-spacing:.2em; text-transform:uppercase;
  background:transparent; transition:.2s;
}
.btn:hover{ background:var(--g); color:#000 }
.btn.r{ border-color:var(--r); color:var(--r) }
.btn.r:hover{ background:var(--r); color:#000 }

.hero-scroll{
  position:absolute; left:50%; bottom:30px; z-index:5;
  transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:12px;
  font-size:10px; letter-spacing:.4em; color:var(--g);
}
.hero-scroll .line{
  width:1px; height:50px;
  background:linear-gradient(180deg, transparent, var(--g), transparent);
  position:relative;
}
.hero-scroll .line::after{
  content:""; position:absolute; left:-2px; top:0; width:5px; height:5px;
  background:var(--r); border-radius:50%;
  animation:scrollDot 2.4s ease-in-out infinite;
}
@keyframes scrollDot{
  0%{ top:0; opacity:0 } 20%{opacity:1} 80%{opacity:1} 100%{ top:50px; opacity:0 }
}

/* ============ TICKER ============ */
.ticker{
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  background:#04060c;
  overflow:hidden; padding:16px 0;
}
.ticker-track{
  display:flex; gap:42px; align-items:center;
  white-space:nowrap;
  font-family:Anton; letter-spacing:.04em;
  font-size: clamp(20px, 2.5vw, 32px);
  color:var(--g);
  animation: marquee 40s linear infinite;
}
.ticker-track i{ color:var(--r); font-size:.8em; font-style:normal; }
@keyframes marquee{ from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ============ SECTION BASE ============ */
.section{
  padding: var(--pad-y) var(--pad-x);
  position:relative; border-top:1px solid var(--line);
}
.section-head{
  display:flex; align-items:center; gap:16px;
  margin-bottom:48px;
  font-family:"JetBrains Mono"; font-size:11px;
  letter-spacing:.25em; color:var(--mute); text-transform:uppercase;
}
.section-head .num{ color:var(--r); font-weight:700; }
.section-head .label{ color:var(--g) }
.section-head .meta{ margin-left:auto; opacity:.7 }

.h2{
  font-family:Anton;
  font-size: clamp(40px, 6.5vw, 96px);
  line-height: .95; letter-spacing:.02em; text-transform:uppercase;
  color:var(--fg);
  margin-bottom:36px;
}
.h2 i{ font-style:normal; color:var(--r); }
.h2.huge{ font-size: clamp(48px, 9vw, 148px); line-height:.92; }

/* ============ ABOUT ============ */
.about-grid{ display:grid; grid-template-columns: 1.4fr 1fr; gap: 64px; }
.about-l{ }
.about-r{
  border:1px solid var(--line);
  padding:24px;
  background: rgba(255,255,255,.015);
  align-self:start;
  position:relative;
}
.about-r::before{
  content:"// about us"; position:absolute; left:18px; top:-10px;
  background:var(--bg); padding:0 10px;
  font-family:"JetBrains Mono"; font-size:10px; letter-spacing:.2em; color:var(--g);
  text-transform:uppercase;
}
.data-row{
  display:flex; justify-content:space-between; gap:16px;
  padding: 10px 0; border-bottom:1px dashed var(--line-2);
  font-family:"JetBrains Mono"; font-size:13px;
}
.data-row:last-child{ border-bottom:0 }
.data-row span{ color:var(--mute); }
.data-row b{ color:var(--fg); font-weight:500; }
.data-row b.ok{ color:var(--g); }

.about-stats{
  margin-top:60px;
  display:grid; grid-template-columns: repeat(4, 1fr); gap:1px;
  background:var(--line); border:1px solid var(--line);
}
.stat{
  background:var(--bg-2);
  padding: 30px 24px;
  display:flex; flex-direction:column; gap:8px;
}
.stat b{
  font-family:Anton;
  font-size: clamp(40px, 5.5vw, 72px); line-height:1; letter-spacing:-.02em;
  color:var(--fg);
}
.stat b i{ color:var(--g); font-style:normal; font-weight:300 }
.stat span{ font-size:11px; letter-spacing:.18em; color:var(--mute); text-transform:uppercase; }

@media (max-width: 920px){
  .about-grid{ grid-template-columns:1fr }
  .about-stats{ grid-template-columns: 1fr 1fr }
}

/* ============ SERVICES ============ */
.svc-grid{
  display:grid; grid-template-columns: repeat(3, 1fr); gap:0;
  border-top:1px solid var(--line);
  border-left:1px solid var(--line);
}
.svc{
  padding: 36px 30px;
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background: rgba(255,255,255,.01);
  position:relative;
}
.svc.em{ background: rgba(0,255,208,.04); }
.svc-head{ display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:18px; }
.svc-head small{
  font-family:"JetBrains Mono"; font-size:11px;
  letter-spacing:.2em; color:var(--g); text-transform:uppercase;
}
.svc-no{
  font-family:Anton; font-size:48px; line-height:.9;
  letter-spacing:-.04em; color:rgba(0,255,208,.15);
}
.svc h3{
  font-family:Anton; font-size:32px; letter-spacing:.02em;
  text-transform:uppercase; margin-bottom:14px;
}
.svc p{
  font-family:"Noto Sans JP"; font-size:14px; color:var(--fg-2);
  line-height:1.95; margin-bottom:20px; font-weight:300;
}
.svc p b{ color:var(--g); font-weight:500; }
.svc .tags{
  list-style:none; display:flex; flex-wrap:wrap; gap:6px;
  border-top:1px dashed var(--line-2); padding-top:18px;
}
.svc .tags li{
  font-size:10px; letter-spacing:.1em; color:var(--mute);
  border:1px solid var(--line); padding:5px 10px;
  text-transform:uppercase;
}
@media (max-width:920px){ .svc-grid{ grid-template-columns:1fr } }

/* ============ FILMS ============ */
.films-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:16px; margin-bottom:48px; }
.link-arr{
  font-size:11px; letter-spacing:.25em; text-transform:uppercase;
  color:var(--g); display:inline-flex; align-items:center; gap:10px;
  border-bottom:1px solid var(--g); padding-bottom:6px;
}
.link-arr em{ font-style:normal; transition: transform .3s }
.link-arr:hover em{ transform:translateX(8px) }

.film-grid{ display:grid; grid-template-columns: repeat(3, 1fr); gap:24px; }
.film{ display:flex; flex-direction:column; gap:14px; }
.thumb{
  aspect-ratio: 16/10; position:relative; overflow:hidden;
  border:1px solid var(--line);
  background:#000;
}
.thumb::before{
  content:""; position:absolute; inset:0; z-index:1;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='.85'/%3E%3C/filter%3E%3Crect width='100' height='100' filter='url(%23n)' opacity='.4'/%3E%3C/svg%3E");
  opacity:.25; mix-blend-mode:overlay;
}
.thumb::after{
  content:""; position:absolute; inset:0; z-index:2;
  background:
    repeating-linear-gradient(0deg, transparent 0, transparent 3px, rgba(0,0,0,.18) 3px, rgba(0,0,0,.18) 4px),
    linear-gradient(180deg, transparent 60%, rgba(0,0,0,.5));
}
.thumb-tag, .thumb-tc, .thumb-no, .thumb-em{
  position:absolute; z-index:3;
  font-family:"JetBrains Mono"; font-size:10px; letter-spacing:.2em;
  color:var(--g); text-transform:uppercase;
}
.thumb-tag{ top:14px; left:14px; padding:4px 8px; border:1px solid var(--g); background:rgba(0,0,0,.55); backdrop-filter:blur(4px); }
.thumb-tc{ bottom:14px; right:14px; color:var(--y); }
.thumb-no{ top:14px; right:14px; font-size:11px; color:var(--fg-2); letter-spacing:.25em; opacity:.85; }
.thumb-em{
  left:50%; top:50%; transform:translate(-50%,-50%);
  font-family:Anton; font-size: clamp(28px, 4vw, 48px);
  letter-spacing:.04em; color:var(--fg); text-transform:uppercase;
  text-shadow: 0 0 24px rgba(0,0,0,.6);
  font-weight:400;
}
.film:hover .thumb{ filter:brightness(1.15) saturate(1.2); }
.thumb{ transition: filter .3s }
/* static (non-clickable) archive cards — used for Strategy & Others */
.film-static{ cursor: default; }
.film-static:hover .thumb{ filter: none; }

.film-meta small{
  display:block; font-family:"JetBrains Mono"; font-size:10px;
  letter-spacing:.25em; color:var(--mute); text-transform:uppercase; margin-bottom:6px;
}
.film-meta h3{
  font-family:Anton; font-size:24px; letter-spacing:.02em;
  text-transform:uppercase; line-height:1.1; margin-bottom:8px; color:var(--fg);
}
.film-meta p{
  font-family:"Noto Sans JP"; font-size:13px; color:var(--fg-2);
  line-height:1.85; font-weight:300;
}

@media (max-width: 1100px){ .film-grid{ grid-template-columns: repeat(2, 1fr) } }
@media (max-width: 720px){ .film-grid{ grid-template-columns: 1fr } }

/* ============ CREW (text-only) ============ */
.crew-grid{
  display:grid;
  grid-template-columns: repeat(8, 1fr);
  gap:1px;
  background:var(--line);
  border:1px solid var(--line);
}
.crew-card{
  background:var(--bg-2);
  position:relative; overflow:hidden;
  display:flex; flex-direction:column; justify-content:space-between;
  aspect-ratio: 1/1;
  padding: 14px 14px 14px;
  transition: background .25s;
  color:inherit; text-decoration:none;
}
.crew-card.is-linked{ cursor: pointer; }
.crew-ext{
  display:inline-block;
  font-style:normal; color:var(--g);
  margin-left:6px; font-weight:700;
  transition: transform .2s;
}
.crew-card.is-linked:hover .crew-ext{ transform: translate(2px,-2px); }
.crew-card::before{
  content:""; position:absolute; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(circle at 50% 110%, rgba(0,255,208,.05), transparent 60%),
    radial-gradient(circle at 100% 0%, rgba(255,0,68,.04), transparent 50%);
  transition: opacity .3s; opacity:.4;
}
.crew-card:hover{ background:var(--bg-3); }
.crew-card:hover::before{ opacity:1; }

.crew-id{
  position:relative; z-index:2;
  font-family:"JetBrains Mono"; font-size:9px;
  letter-spacing:.18em; color:var(--g);
}

.crew-corner{
  position:absolute; width:8px; height:8px; pointer-events:none; z-index:2;
  opacity:0; transition: opacity .25s;
}
.crew-corner.tl{ top:6px; left:6px;  border-left:1px solid var(--g); border-top:1px solid var(--g); }
.crew-corner.tr{ top:6px; right:6px; border-right:1px solid var(--g); border-top:1px solid var(--g); }
.crew-corner.bl{ bottom:6px; left:6px;  border-left:1px solid var(--g); border-bottom:1px solid var(--g); }
.crew-corner.br{ bottom:6px; right:6px; border-right:1px solid var(--g); border-bottom:1px solid var(--g); }
.crew-card:hover .crew-corner{ opacity:1; }

.crew-name{
  position:relative; z-index:2;
  font-family:Anton;
  font-size: clamp(20px, 1.8vw, 28px);
  line-height:.95; letter-spacing:.02em; text-transform:uppercase;
  color:var(--fg);
  margin: 4px 0 2px;
}
.crew-card .crew-name .glitch.glitch-soft::before,
.crew-card .crew-name .glitch.glitch-soft::after{
  /* slower / softer glitch so 16 cards aren't visually noisy */
  animation-duration: 7s;
  animation-delay: var(--d1, 0s);
  opacity:.85;
}
.crew-card .crew-name .glitch.glitch-soft::after{
  animation-delay: var(--d2, 0s);
}
.crew-card:hover .crew-name .glitch.glitch-soft::before,
.crew-card:hover .crew-name .glitch.glitch-soft::after{
  animation-duration: 1.6s;
  opacity:1;
}

.crew-role{
  position:relative; z-index:2;
  font-family:"JetBrains Mono"; font-size:9px;
  letter-spacing:.15em; color:var(--g); text-transform:uppercase;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}

.crew-scan{
  position:absolute; left:0; right:0; height:80px; z-index:1;
  background:linear-gradient(180deg, transparent, rgba(0,255,208,.08) 50%, transparent);
  pointer-events:none; opacity:0; transition: opacity .25s;
  top:-80px;
}
.crew-card:hover .crew-scan{
  opacity:1;
  animation: crewScan 1.6s linear infinite;
}
@keyframes crewScan{ from{ top:-80px } to{ top:100% } }

@media (max-width: 1100px){ .crew-grid{ grid-template-columns: repeat(4,1fr) } }
@media (max-width: 720px){ .crew-grid{ grid-template-columns: repeat(3,1fr) } }
@media (max-width: 480px){ .crew-grid{ grid-template-columns: repeat(2,1fr) } }

/* ============ SPONSOR (legacy / unused) ============ */
.sponsor-grid{ display:grid; grid-template-columns: 1.2fr 1fr; gap:64px; align-items:start; }
.sponsor-actions{ display:flex; gap:14px; flex-wrap:wrap; margin-top:32px; }
.sponsor-card{ border:1px solid var(--g); padding:28px; background:rgba(0,255,208,.05); margin-bottom:24px; position:relative; }
.sponsor-tag{ display:inline-block; font-family:"JetBrains Mono"; font-size:10px; letter-spacing:.25em; color:var(--g); text-transform:uppercase; border:1px solid var(--g); padding:3px 8px; margin-bottom:14px; }
.sponsor-card h4{ font-family:Anton; font-size:30px; letter-spacing:.04em; color:var(--fg); margin-bottom:8px; text-transform:uppercase; }
.sponsor-card .hint{ font-family:"JetBrains Mono"; font-size:11px; color:var(--mute); margin-bottom:14px; }
.sponsor-card p{ font-family:"Noto Sans JP"; font-size:13px; color:var(--fg-2); line-height:1.85; font-weight:300; }
.sponsor-list .li{
  display:grid; grid-template-columns: 36px 1fr; gap:6px 14px;
  padding:18px 0; border-bottom:1px dashed var(--line-2);
  align-items:start;
}
.sponsor-list .li:last-child{ border-bottom:0 }
.sponsor-list .li-no{
  font-family:Anton; font-size:24px; color:var(--r); letter-spacing:-.02em;
  grid-row:1 / span 2;
}
.sponsor-list .li b{
  grid-column:2; grid-row:1;
  font-family:"JetBrains Mono"; font-size:13px;
  color:var(--fg); letter-spacing:.05em;
  text-transform:uppercase;
}
.sponsor-list .li small{
  grid-column:2; grid-row:2;
  font-family:"Noto Sans JP"; font-size:12px;
  color:var(--fg-2); line-height:1.85; font-weight:300;
}

@media (max-width: 920px){ .sponsor-grid{ grid-template-columns:1fr } }

/* ============ PHOTOS ============ */
.photos-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:16px; margin-bottom:48px; }
.photo-grid{
  display:grid; grid-template-columns: repeat(4, 1fr); gap:1px;
  background:var(--line); border:1px solid var(--line);
}
.ph{
  aspect-ratio: 1/1; position:relative; overflow:hidden; background:#000;
}
.ph::before{
  content:""; position:absolute; inset:0; z-index:1;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='.95'/%3E%3C/filter%3E%3Crect width='100' height='100' filter='url(%23n)' opacity='.45'/%3E%3C/svg%3E");
  opacity:.3; mix-blend-mode:overlay;
}
.ph::after{
  content:""; position:absolute; inset:0; z-index:2;
  background:linear-gradient(180deg, transparent 60%, rgba(0,0,0,.6));
}
.ph span{
  position:absolute; left:12px; bottom:12px; z-index:3;
  font-family:"JetBrains Mono"; font-size:10px; letter-spacing:.25em;
  color:var(--g); text-transform:uppercase;
}
.ph-a{ background:radial-gradient(ellipse at 30% 30%,#28486c,#0a0e18 70%) }
.ph-b{ background:radial-gradient(ellipse at 70% 50%,#5a3848,#0a0e18 70%) }
.ph-c{ background:radial-gradient(ellipse at 40% 60%,#3a5040,#0a0e18 70%) }
.ph-d{ background:radial-gradient(ellipse at 60% 30%,#6c4830,#0a0e18 70%) }
.ph-e{ background:radial-gradient(ellipse at 50% 50%,#48286c,#0a0e18 70%) }
.ph-f{ background:radial-gradient(ellipse at 30% 70%,#6c2840,#0a0e18 70%) }
.ph-g{ background:radial-gradient(ellipse at 70% 70%,#3a4860,#0a0e18 70%) }
.ph-h{ background:radial-gradient(ellipse at 50% 30%,#284c5a,#0a0e18 70%) }
.ph:hover{ filter:brightness(1.2) saturate(1.2) }
.ph{ transition: filter .3s }

@media (max-width: 920px){ .photo-grid{ grid-template-columns: repeat(2,1fr) } }

/* ============ CONTACT ============ */
.contact-grid{
  display:grid; grid-template-columns: 1fr 1fr; gap:64px; align-items:start;
}
.contact-l{ position:sticky; top:120px; }
.contact-form{
  display:grid; grid-template-columns: 1fr 1fr; gap:18px 18px;
  border:1px solid var(--line); padding:28px;
  background:rgba(255,255,255,.012);
  position:relative;
}
.contact-form::before{
  content:"// secure-channel"; position:absolute; left:18px; top:-10px;
  background:var(--bg); padding:0 10px;
  font-family:"JetBrains Mono"; font-size:10px; letter-spacing:.2em; color:var(--g);
  text-transform:uppercase;
}
.form-row{ display:flex; flex-direction:column; gap:8px; }
.form-row-full{ grid-column:1/-1; }
.form-row label{
  font-family:"JetBrains Mono"; font-size:11px;
  letter-spacing:.18em; color:var(--g); text-transform:uppercase;
}
.form-row input, .form-row select, .form-row textarea{
  font:inherit; font-size:14px; color:var(--fg);
  background:rgba(0,0,0,.35); border:1px solid var(--line-2);
  padding:12px 14px; transition: border-color .2s, background .2s;
  font-family:"JetBrains Mono","Noto Sans JP",monospace;
}
.form-row textarea{ font-family:"Noto Sans JP"; line-height:1.7; resize:vertical; }
.form-row input:focus, .form-row select:focus, .form-row textarea:focus{
  outline:none; border-color:var(--g); background:rgba(0,255,208,.04);
}
.form-row select{ appearance:none; -webkit-appearance:none; background-image:linear-gradient(45deg,transparent 50%,var(--g) 50%),linear-gradient(135deg,var(--g) 50%,transparent 50%); background-position:calc(100% - 18px) 50%, calc(100% - 12px) 50%; background-size:6px 6px, 6px 6px; background-repeat:no-repeat; padding-right:32px; }
.form-actions{
  grid-column:1/-1;
  display:flex; flex-direction:column; gap:14px; align-items:stretch;
  border-top:1px dashed var(--line-2); padding-top:20px; margin-top:6px;
}
.form-actions .btn{ cursor:pointer; align-self:flex-start; }
.form-note{
  font-family:"JetBrains Mono"; font-size:11px; color:var(--mute);
  line-height:1.7; overflow-wrap:anywhere; word-break:normal;
  width:100%;
}
.form-status{
  font-family:"JetBrains Mono"; font-size:12px; line-height:1.6;
  width:100%; min-height:1.2em; letter-spacing:.02em;
  overflow-wrap:anywhere;
}
.form-status.is-sending{ color:var(--y); }
.form-status.is-done{ color:var(--g); }
.form-status.is-error{ color:var(--r); }
@media (max-width: 920px){
  .contact-grid{ grid-template-columns:1fr; gap:32px }
  .contact-l{ position:static; }
  .contact-form{ grid-template-columns:1fr }
}

/* ============ COMPANY ============ */
.company-grid{
  display:grid; grid-template-columns: minmax(0, max-content) minmax(0, 1fr); gap:56px; align-items:start;
}
.company-l p.lead-jp{ margin-top:12px; max-width:320px; }

.company-logo{
  width: 100%; max-width: 320px;
  margin: 28px 0 32px;
  display:flex; align-items:center; justify-content:flex-start;
  position:relative;
}
.company-logo img{
  width:100%; height:auto; display:block;
  /* black background on the artwork is removed by SCREEN blend over dark page */
  mix-blend-mode: screen;
  filter: drop-shadow(0 4px 24px rgba(0,255,208,.08)) contrast(1.05);
}
.company-logo .logo-fallback{
  display:none;
  font-family:Anton; font-size:64px; letter-spacing:.02em;
  color:var(--fg); text-transform:uppercase;
  align-items:center; gap:6px;
}
.company-logo .logo-fallback i{
  font-style:normal; color:var(--r); font-size:.5em;
}

/* ============ ACHIEVEMENTS ============ */
.achievements{
  margin-top: 80px; padding-top: 48px;
  border-top:1px solid var(--line);
}
.ach-head{
  display:flex; align-items:flex-end; gap:18px; margin-bottom:32px;
  flex-wrap:wrap;
}
.ach-head .num{
  font-family:"JetBrains Mono"; font-size:11px; letter-spacing:.3em;
  color:var(--g); text-transform:uppercase;
}
.ach-head h3{
  font-family:Anton; font-size: clamp(28px, 3.4vw, 44px);
  letter-spacing:.02em; text-transform:uppercase; color:var(--fg);
  line-height:1;
}
.ach-list{
  list-style:none; counter-reset: ach;
  display:grid; grid-template-columns: repeat(2, 1fr); gap:0;
  border-top:1px solid var(--line);
}
.ach-list li{
  counter-increment: ach;
  display:grid; grid-template-columns: 50px 130px 1fr;
  align-items:start; gap:16px;
  padding: 18px 16px;
  border-bottom:1px solid var(--line);
  border-right:1px solid var(--line);
  position:relative;
  font-family:"Noto Sans JP"; font-size:13px; line-height:1.7;
}
.ach-list li:nth-child(2n){ border-right:0 }
.ach-list li::before{
  content: "[" counter(ach, decimal-leading-zero) "]";
  font-family:"JetBrains Mono"; font-size:11px; letter-spacing:.2em;
  color:var(--r); padding-top:2px;
}
.ach-list .ach-yr{
  font-family:"JetBrains Mono"; font-size:11px; letter-spacing:.2em;
  color:var(--g); text-transform:uppercase; padding-top:2px;
}
.ach-list b{
  display:block; font-family:"Noto Sans JP"; font-size:14px;
  color:var(--fg); font-weight:500; letter-spacing:.02em; margin-bottom:4px;
}
.ach-list span:not(.ach-yr){
  display:block; font-size:12px; color:var(--fg-2); font-weight:300;
}
@media (max-width: 920px){
  .ach-list{ grid-template-columns: 1fr }
  .ach-list li{ border-right:0 }
}

/* ============ 3D DIVIDERS (dynamic, no borders) ============ */
.divider-3d{
  position:relative;
  height: clamp(380px, 42vw, 520px);
  perspective: 1400px;
  overflow:visible;
  display:block;
  margin: -40px 0 -40px;     /* slight negative margin so it bleeds into adjacent sections */
  pointer-events:none;
  z-index:5;
}
.divider-3d::after{
  content: attr(data-tag); position:absolute;
  left:var(--pad-x); top: 50%;
  font-family:"JetBrains Mono"; font-size:10px; letter-spacing:.3em;
  color:var(--mute); text-transform:uppercase;
  transform: translateY(-50%);
  opacity:.6;
}
.obj-3d{
  position:absolute;
  width: 120px; height: 120px;
  /* keep inner geometry constant; outer size controlled via --scale */
  transform-style:preserve-3d;
  top:50%; left:50%;
  margin-top: -60px; margin-left: -60px;
  transform:
    translateY(var(--ty, 0))
    scale(var(--scale, 1.6))
    rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) rotateZ(var(--rz,0deg));
  will-change: transform;
}
.divider-3d .obj-3d.pos-l{ left: 22%; }
.divider-3d .obj-3d.pos-c{ left: 50%; }
.divider-3d .obj-3d.pos-r{ left: 78%; }
.divider-3d .obj-3d.size-s{ --scale: 1.0; }
.divider-3d .obj-3d.size-m{ --scale: 1.4; }
.divider-3d .obj-3d.size-l{ --scale: 2.0; }
.divider-3d .obj-3d.size-xl{ --scale: 2.6; }
@media (max-width: 720px){
  .divider-3d{ height: clamp(280px, 80vw, 380px) }
  .divider-3d .obj-3d{ --scale: 1.1 !important }
  .divider-3d .obj-3d.size-xl{ --scale: 1.5 !important }
}
.face{
  position:absolute; inset:0;
  border:1px solid var(--g);
  background:rgba(0,255,208,.04);
  display:flex; align-items:center; justify-content:center;
  font-family:"JetBrains Mono"; font-size:11px; letter-spacing:.2em;
  color:var(--g); text-transform:uppercase;
}
.face.shadow{ background:rgba(255,0,68,.04); border-color:var(--r); color:var(--r); }
/* Cube */
.cube .f-front  { transform: translateZ(60px); }
.cube .f-back   { transform: rotateY(180deg) translateZ(60px); }
.cube .f-right  { transform: rotateY( 90deg) translateZ(60px); }
.cube .f-left   { transform: rotateY(-90deg) translateZ(60px); }
.cube .f-top    { transform: rotateX( 90deg) translateZ(60px); }
.cube .f-bottom { transform: rotateX(-90deg) translateZ(60px); }
/* Pyramid (4 triangular faces using clip-path) */
.pyramid{ width:140px; height:140px; }
.pyramid .face{
  border:0; background:transparent;
  width:140px; height:140px;
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
  background:linear-gradient(180deg, transparent, rgba(0,255,208,.18) 80%);
  outline:1px solid var(--g);
}
.pyramid .pf-1{ transform: rotateY(  0deg) translateZ(60px); }
.pyramid .pf-2{ transform: rotateY( 90deg) translateZ(60px); }
.pyramid .pf-3{ transform: rotateY(180deg) translateZ(60px); }
.pyramid .pf-4{ transform: rotateY(270deg) translateZ(60px); }
/* Hex frame: 6 vertical strips arranged as hex */
.hex{ width:160px; height:160px; }
.hex .strip{
  position:absolute; left:50%; top:50%;
  width:140px; height:8px;
  margin-left:-70px; margin-top:-4px;
  border-top:1px solid var(--g); border-bottom:1px solid var(--g);
  background: rgba(0,255,208,.06);
}
.hex .strip:nth-child(1){ transform: rotateZ(  0deg) translateZ(60px); }
.hex .strip:nth-child(2){ transform: rotateZ( 30deg) translateZ(40px); }
.hex .strip:nth-child(3){ transform: rotateZ( 60deg) translateZ(20px); }
.hex .strip:nth-child(4){ transform: rotateZ( 90deg) translateZ(-20px); }
.hex .strip:nth-child(5){ transform: rotateZ(120deg) translateZ(-40px); }
.hex .strip:nth-child(6){ transform: rotateZ(150deg) translateZ(-60px); }

/* ============ ADVANCED 3D OBJECTS ============ */
/* Gyroscope: 3 mutually perpendicular wireframe rings, each spinning independently */
.gyro{ width:160px; height:160px; }
.gyro .ring{
  position:absolute; inset:0;
  border:1px solid var(--g); border-radius:50%;
  background: transparent;
}
.gyro .ring::before{
  content:""; position:absolute; inset:-1px;
  border:1px dashed rgba(0,255,208,.35); border-radius:50%;
  transform: scale(.86);
}
.gyro .ring.r1{
  transform-style:preserve-3d;
  animation: gyroSpin 22s linear infinite;
}
.gyro .ring.r2{
  border-color:var(--r); transform-style:preserve-3d;
  transform: rotateY(60deg);
  animation: gyroSpin2 28s linear infinite;
}
.gyro .ring.r3{
  border-color:var(--y); transform-style:preserve-3d;
  transform: rotateX(60deg);
  animation: gyroSpin3 34s linear infinite;
}
.gyro .core{
  position:absolute; left:50%; top:50%; width:10px; height:10px;
  margin:-5px 0 0 -5px; background:var(--g); border-radius:50%;
  box-shadow:0 0 14px var(--g);
  transform-style:preserve-3d;
}
@keyframes gyroSpin{
  from{ transform: rotateZ(0deg) rotateX(20deg); }
  to{ transform: rotateZ(360deg) rotateX(20deg); }
}
@keyframes gyroSpin2{
  from{ transform: rotateY(60deg) rotateZ(0deg); }
  to{ transform: rotateY(60deg) rotateZ(-360deg); }
}
@keyframes gyroSpin3{
  from{ transform: rotateX(60deg) rotateY(0deg); }
  to{ transform: rotateX(60deg) rotateY(360deg); }
}

/* Wireframe sphere: 7 horizontal slice rings at varying Y positions, plus 3 longitudinal rings */
.sphere{ width:180px; height:180px; }
.sphere .lat{
  position:absolute; left:50%; top:50%;
  border:1px solid var(--g); border-radius:50%;
  background: transparent;
  transform-style:preserve-3d;
}
.sphere .lat:nth-child(1){ width:60px;  height:60px;  margin:-30px 0 0 -30px; transform: translateZ(85px); }
.sphere .lat:nth-child(2){ width:120px; height:120px; margin:-60px 0 0 -60px; transform: translateZ(60px); border-color:rgba(0,255,208,.7); }
.sphere .lat:nth-child(3){ width:160px; height:160px; margin:-80px 0 0 -80px; transform: translateZ(30px); border-color:rgba(0,255,208,.4); }
.sphere .lat:nth-child(4){ width:178px; height:178px; margin:-89px 0 0 -89px; transform: translateZ(0); }
.sphere .lat:nth-child(5){ width:160px; height:160px; margin:-80px 0 0 -80px; transform: translateZ(-30px); border-color:rgba(0,255,208,.4); }
.sphere .lat:nth-child(6){ width:120px; height:120px; margin:-60px 0 0 -60px; transform: translateZ(-60px); border-color:rgba(0,255,208,.7); }
.sphere .lat:nth-child(7){ width:60px;  height:60px;  margin:-30px 0 0 -30px; transform: translateZ(-85px); }
.sphere .lng{
  position:absolute; left:50%; top:50%;
  width:178px; height:178px; margin:-89px 0 0 -89px;
  border:1px solid rgba(255,0,68,.5); border-radius:50%;
  background:transparent;
}
.sphere .lng.l1{ transform: rotateY(  0deg); border-color:rgba(255,0,68,.7) }
.sphere .lng.l2{ transform: rotateY( 60deg); border-color:rgba(255,0,68,.45) }
.sphere .lng.l3{ transform: rotateY(120deg); border-color:rgba(255,0,68,.3) }

/* Octahedron: 8 triangular faces forming a bipyramid (top half + bottom half) */
.octa{ width:160px; height:160px; }
.octa .tri{
  position:absolute; left:50%; top:50%;
  width:0; height:0;
  border-left:80px solid transparent;
  border-right:80px solid transparent;
  margin-left:-80px;
  transform-style:preserve-3d;
  opacity:.85;
}
.octa .tri.up{
  border-bottom:120px solid rgba(0,255,208,.18);
  margin-top:-120px;
  filter: drop-shadow(0 0 1px var(--g));
}
.octa .tri.dn{
  border-top:120px solid rgba(255,0,68,.18);
  margin-top:0;
  filter: drop-shadow(0 0 1px var(--r));
}
.octa .tri.up.t1{ transform: rotateY(  0deg) translateZ(0); }
.octa .tri.up.t2{ transform: rotateY( 90deg) translateZ(0); }
.octa .tri.up.t3{ transform: rotateY(180deg) translateZ(0); }
.octa .tri.up.t4{ transform: rotateY(270deg) translateZ(0); }
.octa .tri.dn.t1{ transform: rotateY(  0deg) translateZ(0); }
.octa .tri.dn.t2{ transform: rotateY( 90deg) translateZ(0); }
.octa .tri.dn.t3{ transform: rotateY(180deg) translateZ(0); }
.octa .tri.dn.t4{ transform: rotateY(270deg) translateZ(0); }
.octa .edge{
  /* outline strokes for clarity — vertical edges */
  position:absolute; left:50%; top:50%;
  width:1px; height:120px;
  background: linear-gradient(180deg, transparent, var(--g) 50%, transparent);
  margin-left:0; margin-top:-60px;
  transform-style:preserve-3d;
}
.octa .edge:nth-child(9) { transform: rotateY(  0deg) translate3d(80px, 0, 0); }
.octa .edge:nth-child(10){ transform: rotateY( 90deg) translate3d(80px, 0, 0); }
.octa .edge:nth-child(11){ transform: rotateY(180deg) translate3d(80px, 0, 0); }
.octa .edge:nth-child(12){ transform: rotateY(270deg) translate3d(80px, 0, 0); }

/* Nested cube stack: outer wireframe + inner solid + tiny core */
.nested{ width:160px; height:160px; }
.nested .layer{
  position:absolute; inset:0;
  transform-style:preserve-3d;
  animation: layerSpin 36s linear infinite;
}
.nested .layer.l-outer{ animation-duration: 44s; }
.nested .layer.l-mid  { animation-duration: 30s; animation-direction:reverse; transform: scale(.65) }
.nested .layer.l-inner{ animation-duration: 22s; transform: scale(.32) }
.nested .layer .face{
  position:absolute; inset:0;
  border:1px solid var(--g);
  background: rgba(0,255,208,.025);
}
.nested .layer.l-mid .face{ border-color:var(--r); background:rgba(255,0,68,.04) }
.nested .layer.l-inner .face{ border-color:var(--y); background:rgba(255,209,74,.08) }
.nested .layer .f-front  { transform: translateZ(80px); }
.nested .layer .f-back   { transform: rotateY(180deg) translateZ(80px); }
.nested .layer .f-right  { transform: rotateY( 90deg) translateZ(80px); }
.nested .layer .f-left   { transform: rotateY(-90deg) translateZ(80px); }
.nested .layer .f-top    { transform: rotateX( 90deg) translateZ(80px); }
.nested .layer .f-bottom { transform: rotateX(-90deg) translateZ(80px); }
@keyframes layerSpin{
  from{ transform: rotateY(0deg) rotateX(0deg); }
  to{ transform: rotateY(360deg) rotateX(360deg); }
}
.nested .layer.l-mid{ animation-name: layerSpinB }
.nested .layer.l-inner{ animation-name: layerSpinC }
@keyframes layerSpinB{
  from{ transform: scale(.65) rotateX(0deg) rotateZ(0deg); }
  to{ transform: scale(.65) rotateX(-360deg) rotateZ(360deg); }
}
@keyframes layerSpinC{
  from{ transform: scale(.32) rotateY(0deg) rotateZ(0deg); }
  to{ transform: scale(.32) rotateY(360deg) rotateZ(-360deg); }
}

@media (prefers-reduced-motion: reduce){
  .gyro .ring, .nested .layer{ animation: none !important }
}

@media (prefers-reduced-motion: reduce){
  .obj-3d{ transform:none !important; }
}
.company-table{
  border-top:1px solid var(--line);
}
.company-table > div{
  display:grid; grid-template-columns: 200px 1fr; gap:24px;
  padding:18px 0; border-bottom:1px solid var(--line);
  align-items:start;
}
.company-table dt{
  font-family:"JetBrains Mono"; font-size:11px;
  letter-spacing:.25em; color:var(--g); text-transform:uppercase;
  padding-top:2px;
}
.company-table dd{
  font-family:"Noto Sans JP"; font-size:14px; color:var(--fg);
  font-weight:400; letter-spacing:.02em;
}
.company-table dd b{
  display:block; font-weight:500; font-size:14px; color:var(--fg);
  margin-bottom:2px;
}
.company-table dd small{
  display:block; font-size:12px; color:var(--fg-2); font-weight:300;
  line-height:1.7;
}
.company-table > .row-divider{
  /* same shape as a normal data-row, just header-styled label */
  margin-top: 14px;
}
.company-table > .row-divider dt{
  /* keep same font/letter-spacing as other dt's (KEY PARTNERS style) */
  color: var(--g);
}
.company-table > .row-divider dd{ display:none }
@media (max-width: 920px){
  .company-grid{ grid-template-columns:1fr; gap:32px }
  .company-table > div{ grid-template-columns:1fr; gap:6px; padding:14px 0 }
  .company-l p.lead-jp{ max-width:none }
}

/* ============ FOOTER ============ */
.site-footer{
  padding: 60px var(--pad-x) 30px;
  border-top:1px solid var(--line);
  background:#04060c;
}
.foot-top{
  display:flex; justify-content:space-between; align-items:flex-end; gap:24px;
  padding-bottom: 36px; border-bottom:1px solid var(--line);
}
.foot-tag{ font-size:12px; color:var(--mute); letter-spacing:.1em; }
.foot-grid{
  display:grid; grid-template-columns: repeat(4, 1fr); gap:32px;
  padding: 36px 0; border-bottom:1px solid var(--line);
}
.foot-grid.foot-grid-2col{ grid-template-columns: 1fr 1fr; }
.foot-grid > div{ display:flex; flex-direction:column; gap:8px; }
.foot-grid small{
  font-family:"JetBrains Mono"; font-size:10px; letter-spacing:.3em;
  color:var(--g); text-transform:uppercase; margin-bottom:8px;
}
.foot-grid a, .foot-grid span{
  font-size:13px; color:var(--fg-2); transition: color .2s;
}
.foot-grid a:hover{ color:var(--g) }
.foot-bot{
  padding-top: 24px;
  display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap;
  font-family:"JetBrains Mono"; font-size:10px;
  letter-spacing:.2em; color:var(--mute); text-transform:uppercase;
}

@media (max-width:920px){
  .foot-top{ flex-direction:column; align-items:flex-start; gap:14px }
  .foot-grid{ grid-template-columns: repeat(2, 1fr) }
}

/* ============ REDUCED MOTION ============ */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{ animation-duration:.01ms !important; }
  .glitch::before, .glitch::after, .scan, .ticker-track{ animation:none !important }
  .boot{ animation: bootOut .1s linear forwards }
}

/* ============ MOBILE OPTIMIZATIONS ============ */
@media (max-width: 920px){
  :root{ --pad-y: clamp(56px, 12vw, 90px); }
  /* Hero markers — hide bottom-right and shrink */
  .hero-marker{ font-size:9px; letter-spacing:.18em; }
  .hero-marker.bot-r{ display:none }
  .hero-marker.top-r{ display:none }
  .hero-marker.top-l{ top:74px; }
  .hero-marker.bot-l{ bottom:80px; max-width:80vw; }
  .hero{ padding:130px var(--pad-x) 100px; min-height:90vh }
  /* Hero buttons stack */
  .hero-actions{ flex-direction:column; align-items:flex-start; gap:10px; }
  .hero-actions .btn{ width:100%; max-width:340px; justify-content:center; padding:14px; font-size:11px }
  h1{ font-size: clamp(48px, 13vw, 96px) }
  /* Section heads */
  .section-head{ flex-wrap:wrap; gap:8px; margin-bottom:28px }
  .section-head .meta{ display:none }
  /* Form */
  .form-row input, .form-row select, .form-row textarea{ font-size:16px }
  /* Lang button */
  .lang{ gap:4px; }
  .lang-btn{ padding:2px 4px; font-size:10px }
  /* Logo */
  .company-logo{ max-width:220px; margin: 16px 0 20px }
}

/* Mobile: place logo on the right of "COMPANY OVERVIEW." title — logo takes majority of width */
@media (max-width: 720px){
  .company-l{
    display:grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.5fr);
    gap: 10px 14px;
    align-items: center;
  }
  .company-l .h2{
    grid-column: 1; grid-row: 1; margin: 0;
    font-size: clamp(28px, 7.5vw, 44px); line-height:.9;
  }
  .company-l .company-logo{
    grid-column: 2; grid-row: 1;
    width: 100%; max-width: none;
    margin: 0;
  }
  .company-l .lead-jp{
    grid-column: 1 / -1; grid-row: 2;
    margin-top: 4px;
  }
}

@media (max-width: 720px){
  :root{ --pad-x: clamp(16px, 4vw, 24px); }

  /* ---- Reduce body Japanese text size everywhere ---- */
  .lead, .lead-jp{ font-size: 11.5px; line-height: 1.8; letter-spacing:0 }
  .hero .lead{ padding-left:10px; font-size:10px; line-height:1.85; letter-spacing:0 }
  /* CLI text must fit on a single line on mobile */
  .hero .cli{
    font-size: clamp(8px, 2.3vw, 11px);
    white-space: nowrap; letter-spacing: 0;
  }
  .crew-lead{ font-size: 11px; line-height:1.75 }
  .kicker, .ach-head .num, .section-head{ font-size:10px }

  /* ---- Hero ---- */
  .hero h1{ font-size: clamp(46px, 14vw, 84px); line-height:.92 }
  .hero-marker.top-l{ top:68px; font-size:8px; letter-spacing:.15em }
  .h2{ font-size: clamp(32px, 8vw, 56px); }
  .h2.huge{ font-size: clamp(40px, 10vw, 80px); }
  .ticker-track{ font-size: clamp(16px, 5vw, 24px); gap:24px; }

  /* ---- About Us info table — stack label/value to give value full width ---- */
  .about-r{ padding:16px 14px; }
  .data-row{
    flex-direction:column; gap:3px;
    font-size:11px; padding:8px 0;
  }
  .data-row span{ font-size:9.5px; letter-spacing:.18em }
  .data-row b{
    font-size:12px; font-weight:500;
    text-align:left; white-space:nowrap;
    overflow:hidden; text-overflow:clip;
    word-break:keep-all; line-break:strict;
  }
  /* Make the value font auto-shrink if it would overflow */
  .data-row b{ font-size: clamp(10px, 3.1vw, 12px) }

  /* ---- Services ---- */
  .svc{ padding:24px 18px }
  .svc-no{ font-size:32px }
  .svc h3{ font-size:20px; margin-bottom:10px }
  .svc p{ font-size:12.5px; line-height:1.85; margin-bottom:14px }
  .svc-head small{ font-size:10px }

  /* ---- Films & Photo / Strategy & Others — TWO COLUMNS on mobile ---- */
  .films-head{ flex-direction:column; align-items:flex-start; gap:18px; margin-bottom:28px }
  .film-grid{ grid-template-columns: repeat(2, 1fr); gap:14px }
  .film{ gap:10px }
  .thumb-tag{ font-size:8px; padding:3px 6px; letter-spacing:.15em; top:8px; left:8px }
  .thumb-tc{ font-size:8px; bottom:8px; right:8px; letter-spacing:.15em }
  .thumb-no{ font-size:9px; top:8px; right:8px }
  .thumb-em{ font-size: clamp(16px, 4vw, 22px) }
  .film-meta small{ font-size:9px }
  .film-meta h3{ font-size:14px; line-height:1.18; letter-spacing:0; margin-bottom:6px }
  .film-meta p{ font-size:11.5px; line-height:1.7 }

  /* ---- Crew — extra compact (4 cols, short cards) ---- */
  .crew-grid{ grid-template-columns: repeat(4, 1fr) }
  .crew-card{ aspect-ratio: auto; min-height: 0; padding: 8px 6px 9px; }
  .crew-id{ font-size:7.5px; letter-spacing:.12em; line-height:1 }
  .crew-name{
    font-size: clamp(12px, 3.6vw, 16px);
    margin: 4px 0 2px; line-height:.95;
    word-break:keep-all;
  }
  .crew-role{
    font-size: 7.5px; letter-spacing:.06em; line-height:1.2;
    white-space:normal;
  }
  .crew-corner{ width:5px; height:5px }

  /* ---- Company table rows ---- */
  .company-table > div{ grid-template-columns:1fr; gap:4px; padding:11px 0 }
  .company-table > .row-divider{ padding: 22px 0 8px; }
  .company-table dt{ font-size:9.5px; letter-spacing:.2em }
  .company-table dd{ font-size:12.5px; line-height:1.65 }
  .company-table dd b{ font-size:12.5px; margin-bottom:1px }
  .company-table dd small{ font-size:10.5px; line-height:1.55 }
  .company-table > .row-divider dt{ font-size:18px }
  /* Achievements body inherits same look as KEY PARTNERS row — multi-line text */
  .company-table dd[data-i18n="company.ach.body"]{
    font-size: 11.5px; line-height: 1.85;
  }

  /* ---- Contact form ---- */
  .contact-form{ padding:18px; gap:14px; }
  .form-row label{ font-size:10px }

  /* ---- Footer ---- */
  .foot-grid{ grid-template-columns:1fr 1fr; gap:18px }
  .foot-grid small{ font-size:9px }
  .foot-grid a, .foot-grid span{ font-size:12px }
  .foot-bot{ flex-direction:column; gap:6px }
  .foot-bot small{ font-size:9px }
  .boot{ font-size:11px; padding:6vw 5vw }

  /* Tighten 3D dividers */
  .divider-3d{ margin: -20px 0; height: clamp(240px, 60vw, 320px) }
}

@media (max-width: 480px){
  .ach-head{ flex-direction:column; align-items:flex-start; gap:10px }
  .lang-sep{ display:none }
  .header-meta{ gap:6px }
  .header-meta .rec-dot{ width:7px; height:7px }
  .nav-toggle{ width:28px; height:20px }
  /* Crew stays 4 cols even on smallest — name fits because we shrunk it */
  .crew-grid{ grid-template-columns: repeat(4, 1fr) }
  .crew-name{ font-size: clamp(11px, 3.4vw, 14px) }
  .crew-role{ font-size: 7px; letter-spacing:.04em }
  /* Archives stays 2 cols — never collapse to 1 */
  .film-grid{ grid-template-columns: repeat(2, 1fr) !important; gap:10px }
  .film-meta h3{ font-size:12.5px; line-height:1.18 }
  .film-meta p{ font-size:10.5px; line-height:1.6 }
  .film-meta small{ font-size:8px }
  .thumb-tag{ font-size:7px; padding:2px 5px; top:6px; left:6px }
  .thumb-tc, .thumb-no{ font-size:7px; bottom:6px; right:6px }
}

