/* ============================================================
   BADINORIS: BEYOND THE GATES — promo site (DARK)
   Spirit-realm dark theme · static HTML/CSS/JS
   ============================================================ */

:root{
  /* dark surfaces */
  --bg:#160E10;
  --bg-2:#1E1316;
  --surface:#26171B;
  --surface-2:#2F1D21;
  --maroon:#4A1721;
  --oxblood:#2A1418;
  --ink-deep:#0D0708;

  /* warm light tones (text + accents) */
  --cream:#F2E7CE;
  --cream-2:#E6D4AC;
  --muted:#B3A489;
  --vermillion:#C43923;
  --vermillion-glow:#E8814A;
  --gold:#C9A24B;
  --gold-light:#E7BE63;
  --jade:#5CA98A;
  --portal-cream:#BFD8C9;
  --portal-pink:#C98BA8;

  /* semantic */
  --text:var(--cream);

  --serif:"Cormorant Garamond","Iowan Old Style",Georgia,serif;
  --sans:"Zen Kaku Gothic New","Helvetica Neue",system-ui,sans-serif;

  --ease:cubic-bezier(.22,.61,.36,1);
  --maxw:1180px;
  --pad:clamp(1.25rem,5vw,4rem);
  --line:color-mix(in srgb,var(--gold) 28%,transparent);

  --grain:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  color:var(--text);
  background:var(--bg);
  line-height:1.7;
  font-size:clamp(1rem,.95rem + .25vw,1.0625rem);
  overflow-x:hidden;
  position:relative;
}
body::before{ /* faint grain */
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:var(--grain);background-size:200px;
  opacity:.05;mix-blend-mode:overlay;
}
body::after{ /* warm top glow */
  content:"";position:fixed;top:-10%;left:50%;transform:translateX(-50%);
  width:120vw;height:60vh;z-index:0;pointer-events:none;
  background:radial-gradient(ellipse at center,rgba(196,57,35,.12),transparent 60%);
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.08;letter-spacing:-.01em;color:var(--cream)}
::selection{background:var(--vermillion);color:var(--cream)}

/* ---------- a11y helpers ---------- */
.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.skip-link{position:fixed;top:.5rem;left:.5rem;z-index:200;background:var(--vermillion);color:var(--cream);padding:.6rem 1rem;border-radius:6px;transform:translateY(-150%);transition:transform .2s}
.skip-link:focus{transform:translateY(0)}
:focus-visible{outline:2px solid var(--gold-light);outline-offset:3px;border-radius:3px}

/* ---------- shared ---------- */
.eyebrow{
  font-family:var(--serif);font-weight:600;font-size:.95rem;
  letter-spacing:.22em;text-transform:uppercase;
  background:linear-gradient(120deg,var(--gold-light),var(--gold));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  margin-bottom:.7rem;
}
@supports not ((-webkit-background-clip:text) or (background-clip:text)){.eyebrow{color:var(--gold)}}
.eyebrow .kanji{font-family:var(--sans);font-weight:700;-webkit-text-fill-color:var(--vermillion-glow);color:var(--vermillion-glow);margin-right:.35em}
.section-title{font-size:clamp(2rem,1.4rem + 2.4vw,3.25rem);margin-bottom:1rem;color:var(--cream)}
.lede{font-size:clamp(1.1rem,1rem + .6vw,1.4rem);font-family:var(--serif);font-weight:500;color:var(--cream)}
.kanji{font-family:var(--sans)}
.panel{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:4px;box-shadow:0 18px 50px -20px rgba(0,0,0,.7)}

/* filigree corners (gold) */
.filigree{position:absolute;width:30px;height:30px;pointer-events:none;opacity:.85;background:no-repeat center/contain;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3E%3Cg fill='none' stroke='%23C9A24B' stroke-width='1.4'%3E%3Cpath d='M2 2 V12 M2 2 H12'/%3E%3Cpath d='M2 2 Q14 6 8 16'/%3E%3Cpath d='M2 2 Q6 14 16 8'/%3E%3C/g%3E%3Cpath fill='%23C43923' d='M2 2 l4 0 0 4 -4 0z'/%3E%3C/svg%3E");}
.filigree--tl{top:8px;left:8px}
.filigree--tr{top:8px;right:8px;transform:scaleX(-1)}
.filigree--bl{bottom:8px;left:8px;transform:scaleY(-1)}
.filigree--br{bottom:8px;right:8px;transform:scale(-1)}

/* torii divider */
.divider{display:flex;align-items:center;justify-content:center;gap:1.2rem;color:var(--gold);padding:2.4rem var(--pad);background:var(--bg)}
.divider--dark{background:var(--bg-2)}
.divider__line{height:1px;flex:1;max-width:340px;background:linear-gradient(90deg,transparent,currentColor)}
.divider__line:last-child{background:linear-gradient(90deg,currentColor,transparent)}
.divider__torii{width:64px;height:auto;filter:drop-shadow(0 2px 8px rgba(0,0,0,.5))}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;font-family:var(--sans);font-weight:700;
  font-size:.98rem;letter-spacing:.01em;padding:.85rem 1.6rem;border-radius:999px;
  transition:transform .22s var(--ease),box-shadow .22s var(--ease),background .22s,color .22s;will-change:transform}
.btn__ico{width:1.15em;height:1.15em;flex:none}
.btn--primary{background:var(--vermillion);color:#fff;box-shadow:0 10px 26px -8px rgba(196,57,35,.7),inset 0 0 0 1px rgba(231,190,99,.5)}
.btn--primary:hover{background:var(--vermillion-glow);transform:translateY(-2px);box-shadow:0 16px 34px -8px rgba(232,129,74,.8),inset 0 0 0 1px rgba(231,190,99,.8)}
.btn--steam{background:rgba(242,231,206,.06);color:var(--cream);box-shadow:inset 0 0 0 1px var(--line)}
.btn--steam:hover{background:rgba(242,231,206,.12);color:var(--gold-light);transform:translateY(-2px);box-shadow:inset 0 0 0 1px var(--gold)}
.btn--ghost{color:var(--cream);box-shadow:inset 0 0 0 1.5px var(--jade)}
.btn--ghost:hover{background:color-mix(in srgb,var(--jade) 22%,transparent);transform:translateY(-2px)}
.dot-live{width:.6rem;height:.6rem;border-radius:50%;background:#5fd39a;box-shadow:0 0 0 0 rgba(95,211,154,.7);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(95,211,154,.6)}70%{box-shadow:0 0 0 8px rgba(95,211,154,0)}100%{box-shadow:0 0 0 0 rgba(95,211,154,0)}}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ============================================================
   AMBIENT canvas
   ============================================================ */
.ambient{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.7}

/* ============================================================
   NAV
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .35s,box-shadow .35s,backdrop-filter .35s}
.nav__inner{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;gap:1.2rem;padding:.85rem var(--pad)}
.nav__brand{display:flex;align-items:center;gap:.55rem;color:var(--cream)}
.nav__torii{width:30px;height:26px;color:var(--vermillion-glow)}
.nav__name{font-family:var(--serif);font-weight:700;font-size:1.35rem;letter-spacing:.16em;color:var(--cream)}
.nav__links{display:flex;gap:1.5rem;margin-left:auto}
.nav__links a{color:var(--cream);font-size:.95rem;letter-spacing:.04em;position:relative;padding:.2rem 0;opacity:.85;transition:opacity .2s}
.nav__links a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;background:var(--vermillion);transition:right .25s var(--ease)}
.nav__links a:hover{opacity:1}
.nav__links a:hover::after{right:0}
.nav__cta{padding:.55rem 1.2rem;font-size:.9rem}
.nav__toggle{display:none;flex-direction:column;gap:5px;padding:.4rem;margin-left:auto}
.nav__toggle span{width:24px;height:2px;background:var(--cream);transition:.3s}
.nav__mobile{display:none}
.nav.scrolled{background:color-mix(in srgb,var(--ink-deep) 88%,transparent);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--line),0 8px 30px -12px rgba(0,0,0,.7)}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100svh;display:grid;place-items:center;text-align:center;overflow:hidden;isolation:isolate;padding:7rem var(--pad) 5rem}
.hero__bg{position:absolute;inset:-8% 0;z-index:-3;will-change:transform}
.hero__bg img{width:100%;height:100%;object-fit:cover;object-position:center 55%;filter:brightness(.42) saturate(.92) contrast(1.02)}
.hero__sun{position:absolute;inset:0;z-index:-2;background:radial-gradient(ellipse 55% 45% at 50% 30%,rgba(232,129,74,.28),transparent 70%);mix-blend-mode:screen}
.hero__vignette{position:absolute;inset:0;z-index:-1;background:
  linear-gradient(180deg,rgba(13,7,8,.75),rgba(13,7,8,.25) 35%,rgba(13,7,8,.55) 70%,var(--bg)),
  radial-gradient(120% 100% at 50% 38%,transparent 45%,rgba(13,7,8,.8))}
.hero__content{max-width:760px}
.hero__wordmark{margin:0 0 1.5rem;display:flex;flex-direction:column;align-items:center;gap:.6rem}
.hero__title{font-family:var(--serif);font-weight:700;font-size:clamp(3.2rem,9vw,7rem);line-height:.9;letter-spacing:.02em;
  background:linear-gradient(176deg,var(--cream) 0%,var(--gold-light) 52%,var(--gold) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent;
  filter:drop-shadow(0 8px 30px rgba(0,0,0,.7));animation:logoglow 6s ease-in-out infinite}
@supports not ((-webkit-background-clip:text) or (background-clip:text)){.hero__title{color:var(--gold-light);-webkit-text-fill-color:var(--gold-light)}}
.hero__subtitle{display:inline-flex;align-items:center;gap:.9em;font-family:var(--serif);font-weight:600;
  font-size:clamp(.85rem,.7rem + .9vw,1.2rem);letter-spacing:.4em;text-transform:uppercase;color:var(--gold-light);
  padding-left:.4em;text-shadow:0 2px 12px rgba(0,0,0,.7)}
.hero__subtitle::before,.hero__subtitle::after{content:"";width:clamp(18px,5vw,52px);height:1px;background:linear-gradient(90deg,transparent,var(--gold))}
.hero__subtitle::after{background:linear-gradient(90deg,var(--gold),transparent)}
@keyframes logoglow{0%,100%{filter:drop-shadow(0 8px 30px rgba(0,0,0,.7)) drop-shadow(0 0 0 rgba(191,216,201,0))}50%{filter:drop-shadow(0 8px 34px rgba(0,0,0,.7)) drop-shadow(0 0 26px rgba(191,216,201,.45))}}
.hero__tagline{font-family:var(--serif);font-style:italic;font-weight:500;font-size:clamp(1.25rem,1rem + 1.5vw,2rem);color:var(--cream);text-shadow:0 2px 18px rgba(0,0,0,.8);margin-bottom:1.8rem;line-height:1.35}
.hero__cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.hero__status{margin-top:1.4rem;font-size:.85rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-light);text-shadow:0 1px 8px rgba(0,0,0,.8)}
.hero__status span{white-space:nowrap}
.hero__scroll{position:absolute;bottom:1.6rem;left:50%;transform:translateX(-50%);z-index:1;opacity:.9}
.hero__lantern{width:30px;height:auto;animation:sway 4s ease-in-out infinite;transform-origin:top center}
@keyframes sway{0%,100%{transform:rotate(-5deg) translateY(0)}50%{transform:rotate(5deg) translateY(6px)}}

/* ============================================================
   STORY  (solid dark, no busy bg)
   ============================================================ */
.story{position:relative;overflow:hidden;padding:clamp(4.5rem,9vw,8rem) var(--pad);background:var(--bg-2)}
.story::before{content:"";position:absolute;inset:0;background:radial-gradient(80% 90% at 80% 30%,rgba(201,139,168,.10),transparent 60%),radial-gradient(70% 80% at 10% 80%,rgba(92,169,138,.07),transparent 60%);pointer-events:none}
.story__inner{position:relative;max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.6rem,4vw,3.5rem);align-items:center}
.story__panel{max-width:none;padding:clamp(1.8rem,3vw,3rem);border-left:4px solid var(--vermillion);background:var(--surface);border-radius:4px}
.story__media{position:relative;margin:0;border-radius:6px;overflow:hidden;box-shadow:0 0 0 1px var(--gold),0 0 0 6px var(--oxblood),0 30px 64px -26px rgba(0,0,0,.85)}
.story__media img{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:center;display:block;transition:transform .8s var(--ease)}
.story__media:hover img{transform:scale(1.05)}
.story__media .filigree{z-index:2}
.story__media figcaption{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:1.4rem 1rem .9rem;
  font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cream);
  background:linear-gradient(transparent,rgba(13,7,8,.85))}
.story__media figcaption .kanji{color:var(--vermillion-glow);font-weight:700;margin-right:.5em}
.story__panel p{margin-bottom:1rem;color:var(--muted)}
.story__panel .lede{margin-bottom:1.2rem;color:var(--cream)}
.story__panel strong{color:var(--vermillion-glow)}
.pullquote{font-family:var(--serif);font-style:italic;font-size:clamp(1.3rem,1.1rem + 1vw,1.8rem);margin-top:1.6rem;padding-top:1.2rem;border-top:1px solid var(--line);
  background:linear-gradient(120deg,var(--gold-light),var(--gold));-webkit-background-clip:text;background-clip:text;color:transparent}
@supports not ((-webkit-background-clip:text) or (background-clip:text)){.pullquote{color:var(--gold-light)}}

/* ============================================================
   GATE OF WORLDS
   ============================================================ */
.gate{padding:clamp(4rem,8vw,7rem) var(--pad);background:var(--bg);text-align:center}
.gate__head{max-width:640px;margin:0 auto 2.5rem}
.gate__sub{color:var(--muted);max-width:48ch;margin:0 auto}
.gate__stage{max-width:var(--maxw);margin:0 auto}
.gate__frame{position:relative;border-radius:6px;padding:14px;background:linear-gradient(var(--oxblood),var(--maroon));box-shadow:0 30px 70px -28px rgba(0,0,0,.8),inset 0 0 0 1px var(--line)}
.gate__tag{position:absolute;bottom:26px;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cream);background:rgba(13,7,8,.7);padding:.3rem .7rem;border-radius:999px;border:1px solid var(--line);z-index:4}
.gate__tag--l{left:26px}
.gate__tag--r{right:26px}
.ba{position:relative;overflow:hidden;border-radius:4px;aspect-ratio:16/9;user-select:none;touch-action:none}
.ba__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ba__before{position:absolute;inset:0;clip-path:inset(0 50% 0 0)}
.ba__handle{position:absolute;top:0;bottom:0;left:50%;width:44px;transform:translateX(-50%);display:grid;place-items:center;cursor:ew-resize;z-index:3;touch-action:none}
.ba__line{position:absolute;top:0;bottom:0;width:2px;background:var(--gold);box-shadow:0 0 12px rgba(201,162,75,.9)}
.ba__grip{width:44px;height:44px;border-radius:50%;background:var(--vermillion);color:#fff;display:grid;place-items:center;box-shadow:0 4px 16px rgba(0,0,0,.6),inset 0 0 0 2px var(--gold-light)}
.ba__grip svg{width:22px;height:22px}

/* ============================================================
   FEATURES
   ============================================================ */
.features{background:var(--bg-2);padding:clamp(4.5rem,9vw,8rem) var(--pad);position:relative;overflow:hidden}
.features::before{content:"";position:absolute;inset:0;background:radial-gradient(110% 80% at 50% 0,rgba(232,129,74,.10),transparent 55%);pointer-events:none}
.features__head{position:relative;max-width:var(--maxw);margin:0 auto 3rem;text-align:center}
.features__grid{position:relative;max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.card{position:relative;background:var(--surface);color:var(--cream);border-radius:6px;padding:2.1rem 1.9rem;border:1px solid var(--line);
  box-shadow:0 22px 50px -28px rgba(0,0,0,.8);transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s}
.card:hover{transform:translateY(-5px);border-color:color-mix(in srgb,var(--gold) 55%,transparent);box-shadow:0 30px 60px -24px rgba(0,0,0,.9)}
.card__ico{display:grid;place-items:center;width:62px;height:62px;border-radius:50%;margin-bottom:1.1rem;color:var(--vermillion-glow);
  background:radial-gradient(circle,rgba(232,129,74,.16),transparent 70%);border:1px solid var(--line)}
.card__ico svg{width:34px;height:34px}
.card h3{font-size:1.5rem;margin-bottom:.6rem;color:var(--gold-light)}
.card p{color:var(--muted);font-size:1rem;line-height:1.65}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery{background:var(--bg);padding:clamp(4rem,8vw,7rem) var(--pad)}
.gallery__head{max-width:var(--maxw);margin:0 auto 2.6rem;text-align:center}
.gallery__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:180px;gap:14px}
.shot{position:relative;overflow:hidden;border-radius:4px;padding:0;
  box-shadow:0 0 0 1px var(--gold),0 0 0 5px var(--oxblood),0 16px 30px -16px rgba(0,0,0,.8);
  transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.shot img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.shot--wide{grid-column:span 2}
.shot--tall{grid-row:span 2}
.shot::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(13,7,8,.88));opacity:.75;transition:opacity .35s}
.shot__cap{position:absolute;left:.9rem;bottom:.75rem;z-index:2;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--cream);font-weight:500;transform:translateY(6px);opacity:0;transition:.35s}
.shot:hover{transform:translateY(-4px);box-shadow:0 0 0 1px var(--gold-light),0 0 0 5px var(--oxblood),0 26px 44px -18px rgba(0,0,0,.95)}
.shot:hover img{transform:scale(1.07)}
.shot:hover::after{opacity:.95}
.shot:hover .shot__cap{opacity:1;transform:none}
.shot:focus-visible{outline:2px solid var(--gold-light);outline-offset:4px}

/* ============================================================
   TRAILERS
   ============================================================ */
.trailers{background:var(--bg-2);padding:clamp(4.5rem,9vw,8rem) var(--pad);text-align:center}
.trailers__head{max-width:var(--maxw);margin:0 auto 2.6rem}
.trailers__embed{position:relative;max-width:920px;margin:0 auto;aspect-ratio:16/9;border-radius:8px;overflow:hidden;
  box-shadow:0 0 0 1px var(--gold),0 0 0 6px var(--oxblood),0 30px 60px -26px rgba(0,0,0,.85);background:var(--oxblood)}
.video{position:absolute;inset:0;width:100%;height:100%;padding:0;display:block;cursor:pointer;border-radius:inherit;overflow:hidden}
.video__poster{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease),filter .35s}
.video::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(13,7,8,.15),rgba(13,7,8,.5));transition:opacity .35s}
.video__play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:84px;height:84px;border-radius:50%;
  background:var(--vermillion);color:#fff;display:grid;place-items:center;z-index:2;
  box-shadow:0 0 0 8px rgba(242,231,206,.14),0 10px 30px rgba(0,0,0,.6),inset 0 0 0 2px var(--gold-light);
  transition:transform .3s var(--ease),background .3s}
.video__play svg{width:40px;height:40px;margin-left:5px}
.video:hover .video__poster{transform:scale(1.04)}
.video:hover::after{opacity:.7}
.video:hover .video__play{transform:translate(-50%,-50%) scale(1.1);background:var(--vermillion-glow)}
.video:focus-visible{outline:2px solid var(--gold-light);outline-offset:4px}
.trailers__embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0;border-radius:inherit;display:block}
.trailers__note{margin-top:1.4rem;font-size:.85rem;color:var(--muted);letter-spacing:.04em}
.trailers__note a{color:var(--gold-light);text-decoration:underline;text-underline-offset:3px}
.trailers__note a:hover{color:var(--vermillion-glow)}

/* ============================================================
   FAQ
   ============================================================ */
.faq{background:var(--bg);padding:clamp(4rem,8vw,7rem) var(--pad)}
.faq__head{max-width:760px;margin:0 auto 2.4rem;text-align:center}
.faq__list{max-width:760px;margin:0 auto;border-top:1px solid var(--line)}
.qa{border-bottom:1px solid var(--line)}
.qa summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.15rem .4rem;font-family:var(--serif);font-weight:600;font-size:clamp(1.15rem,1rem + .6vw,1.4rem);color:var(--cream);transition:color .2s}
.qa summary::-webkit-details-marker{display:none}
.qa summary:hover{color:var(--gold-light)}
.qa__mark{position:relative;flex:none;width:20px;height:20px}
.qa__mark::before,.qa__mark::after{content:"";position:absolute;background:var(--vermillion-glow);transition:transform .3s var(--ease),opacity .3s}
.qa__mark::before{top:9px;left:0;width:20px;height:2px}
.qa__mark::after{top:0;left:9px;width:2px;height:20px}
.qa[open] .qa__mark::after{transform:rotate(90deg);opacity:0}
.qa__body{overflow:hidden;transition:height .3s var(--ease)}
.qa__body p{padding:0 .4rem 1.3rem;color:var(--muted);max-width:64ch}

/* ============================================================
   DOWNLOAD  (solid dark, no busy bg)
   ============================================================ */
.download{position:relative;overflow:hidden;padding:clamp(4.5rem,9vw,8rem) var(--pad);background:var(--bg-2)}
.download::before{content:"";position:absolute;inset:0;background:radial-gradient(80% 90% at 20% 30%,rgba(232,129,74,.12),transparent 60%);pointer-events:none}
.download__inner{position:relative;max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,4vw,4rem);align-items:center}
.download__cta{color:var(--cream)}
.download__copy{color:var(--muted);max-width:46ch;margin-bottom:1.8rem}
.download__btns{display:flex;gap:1rem;flex-wrap:wrap}

.sysreq{padding:1.8rem clamp(1.4rem,2.5vw,2.2rem)}
.sysreq__tabs{display:flex;gap:.5rem;margin-bottom:1.4rem;border-bottom:1px solid var(--line)}
.sysreq__tab{font-family:var(--sans);font-weight:700;font-size:.95rem;letter-spacing:.06em;padding:.55rem .9rem;color:var(--muted);position:relative}
.sysreq__tab.is-active{color:var(--gold-light)}
.sysreq__tab.is-active::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--vermillion)}
.sysreq__panel{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem}
.sysreq__panel.is-hidden{display:none}
.sysreq__col h4{font-family:var(--sans);font-weight:700;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--vermillion-glow);margin-bottom:.7rem;padding-bottom:.4rem;border-bottom:1px solid var(--line)}
.sysreq dl{display:grid;grid-template-columns:auto 1fr;gap:.4rem .8rem;font-size:.9rem}
.sysreq dt{font-weight:700;color:var(--cream);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;padding-top:.2rem}
.sysreq dd{color:var(--muted);font-variant-numeric:tabular-nums}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:linear-gradient(var(--bg-2),var(--ink-deep));color:var(--cream);text-align:center;padding:clamp(3rem,6vw,5rem) var(--pad) 2.5rem;border-top:1px solid var(--line)}
.footer__top{display:flex;flex-direction:column;align-items:center;gap:.4rem;margin-bottom:1.8rem}
.footer__torii{width:46px;height:auto;color:var(--vermillion-glow);margin-bottom:.4rem}
.footer__title{font-family:var(--serif);font-weight:700;font-size:1.7rem;letter-spacing:.04em;color:var(--cream)}
.footer__studio{color:var(--muted);font-size:.95rem}
.footer__studio strong{color:var(--gold-light)}
.footer__seal{margin-top:.6rem;display:inline-block;font-family:var(--serif);font-style:italic;font-size:.9rem;letter-spacing:.1em;color:var(--vermillion-glow);border:1px solid var(--vermillion);padding:.3rem 1rem;border-radius:999px;transform:rotate(-3deg)}
.social{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center;list-style:none;margin:0 0 1.8rem}
.social a{display:grid;place-items:center;width:44px;height:44px;border-radius:50%;color:var(--gold);border:1px solid var(--line);transition:.25s var(--ease)}
.social svg{width:20px;height:20px}
.social a:hover{background:var(--vermillion);color:#fff;border-color:var(--vermillion);transform:translateY(-3px)}
.footer__legal{font-size:.78rem;color:color-mix(in srgb,var(--cream) 40%,transparent);max-width:60ch;margin:0 auto;line-height:1.6}

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lightbox{position:fixed;inset:0;z-index:400;display:grid;place-items:center;background:rgba(13,7,8,.93);backdrop-filter:blur(6px);opacity:0;transition:opacity .3s}
.lightbox[hidden]{display:none}
.lightbox.show{opacity:1}
.lightbox__stage{position:relative;max-width:min(92vw,1280px);max-height:86vh;margin:0;padding:10px;background:var(--surface);border-radius:6px;box-shadow:0 0 0 1px var(--gold),0 30px 80px -20px #000}
.lightbox__stage img{max-width:100%;max-height:74vh;object-fit:contain;border-radius:3px}
.lightbox__stage figcaption{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.7rem .3rem .2rem;color:var(--cream);font-size:.82rem;letter-spacing:.08em;text-transform:uppercase}
.lightbox__count{color:var(--gold-light);font-weight:700}
.lightbox__close{position:absolute;top:1.1rem;right:1.3rem;font-size:2rem;line-height:1;color:var(--cream);width:46px;height:46px;border-radius:50%;border:1px solid var(--line);transition:.2s}
.lightbox__close:hover{background:var(--vermillion);border-color:var(--vermillion)}
.lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);font-size:1.6rem;color:var(--cream);width:54px;height:54px;border-radius:50%;display:grid;place-items:center;border:1px solid var(--line);background:rgba(13,7,8,.5);transition:.2s}
.lightbox__nav:hover{background:var(--vermillion);border-color:var(--vermillion)}
.lightbox__prev{left:2vw}
.lightbox__next{right:2vw}

/* ============================================================
   DOWNLOAD / BUILD MODAL
   ============================================================ */
.modal{position:fixed;inset:0;z-index:420;display:flex;overflow-y:auto;padding:1.5rem;
  background:rgba(13,7,8,.82);backdrop-filter:blur(8px);opacity:0;transition:opacity .3s}
.modal[hidden]{display:none}
.modal.show{opacity:1}
.modal__dialog{position:relative;margin:auto;width:min(94vw,660px);background:linear-gradient(var(--surface),var(--bg-2));
  border:1px solid var(--line);border-radius:12px;padding:clamp(1.9rem,4vw,3rem);text-align:center;
  box-shadow:0 50px 120px -30px #000,inset 0 0 0 1px rgba(201,162,75,.06);
  transform:translateY(28px) scale(.95);opacity:0;transition:transform .5s var(--ease),opacity .45s var(--ease)}
.modal.show .modal__dialog{transform:none;opacity:1}
.modal__title{font-size:clamp(1.7rem,1.2rem + 1.8vw,2.5rem);margin-bottom:.5rem}
.modal__sub{color:var(--muted);margin-bottom:2rem;max-width:42ch;margin-left:auto;margin-right:auto}
.modal__close{position:absolute;top:1rem;right:1rem;font-size:1.9rem;line-height:1;color:var(--cream);width:44px;height:44px;border-radius:50%;border:1px solid var(--line);transition:.2s}
.modal__close:hover{background:var(--vermillion);border-color:var(--vermillion);transform:rotate(90deg)}
.modal__builds{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;text-align:left}
.build{position:relative;display:block;padding:1.6rem 1.5rem;border-radius:10px;background:var(--bg);border:1px solid var(--line);
  opacity:0;transition:border-color .25s var(--ease),box-shadow .25s var(--ease),background .25s}
.modal.show .build{animation:buildIn .55s var(--ease) forwards}
.modal.show .build:nth-child(1){animation-delay:.1s}
.modal.show .build:nth-child(2){animation-delay:.2s}
@keyframes buildIn{from{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:none}}
.build:hover,.build:focus-visible{border-color:var(--gold);background:var(--surface-2);box-shadow:0 20px 44px -22px #000}
.build__badge{position:absolute;top:-11px;right:16px;background:var(--vermillion);color:#fff;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;padding:.28rem .65rem;border-radius:999px;box-shadow:0 4px 12px -4px rgba(196,57,35,.8)}
.build__ico{display:grid;place-items:center;width:48px;height:48px;border-radius:50%;color:var(--vermillion-glow);
  background:radial-gradient(circle,rgba(232,129,74,.18),transparent 70%);border:1px solid var(--line);margin-bottom:1rem}
.build__ico svg{width:24px;height:24px}
.build--legacy .build__ico{color:var(--gold-light)}
.build__name{display:block;font-family:var(--serif);font-weight:700;font-size:1.4rem;color:var(--cream);line-height:1.1}
.build__ver{display:block;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-light);margin:.25rem 0 .7rem}
.build__desc{display:block;font-size:.9rem;color:var(--muted);line-height:1.55}
.modal__note{margin-top:1.6rem;font-size:.82rem;letter-spacing:.04em;color:var(--muted);min-height:1.2em;transition:color .2s}
.modal__note.flash{color:var(--gold-light)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1000px){
  .gallery__grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}
  .shot--wide{grid-column:span 2}
  .shot--tall{grid-row:span 1}
}
@media (max-width:880px){
  .nav__links,.nav__cta{display:none}
  .nav__toggle{display:flex}
  .nav__mobile{display:flex;flex-direction:column;background:color-mix(in srgb,var(--ink-deep) 95%,transparent);max-height:0;overflow:hidden;transition:max-height .35s var(--ease);backdrop-filter:blur(10px)}
  .nav__mobile.open{max-height:360px;border-top:1px solid var(--line)}
  .nav__mobile a{color:var(--cream);padding:.95rem var(--pad);border-bottom:1px solid color-mix(in srgb,var(--gold) 14%,transparent)}
  .nav.menu-open{background:color-mix(in srgb,var(--ink-deep) 95%,transparent)}
  .nav__toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav__toggle.open span:nth-child(2){opacity:0}
  .nav__toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .features__grid{grid-template-columns:1fr}
  .download__inner{grid-template-columns:1fr}
  .trailers__grid{grid-template-columns:1fr}
  .story__inner{grid-template-columns:1fr;gap:1.6rem}
  .story__media img{aspect-ratio:16/10}
}
@media (max-width:560px){
  .gallery__grid{grid-template-columns:1fr;grid-auto-rows:200px}
  .shot--wide{grid-column:span 1}
  .sysreq__panel{grid-template-columns:1fr;gap:1.4rem}
  .gate__tag{display:none}
  .modal__builds{grid-template-columns:1fr}
  .hero__cta{flex-direction:column;width:100%}
  .hero__cta .btn{width:100%}
  .download__btns .btn{width:100%}
  .lightbox__prev{left:.4rem}.lightbox__next{right:.4rem}
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  .hero__bg{inset:0}
  .ambient{display:none}
}
