/* ============================================================
   Fire & Lightning Collectibles — "THE ARENA"
   Concept: the shop's own name as the design system.
   FIRE = the shop (stock, singles, trade-ins).
   LIGHTNING = the play (tables, tournaments, Friday nights).
   A dark storm arena, split down the middle.
   No framework. No build step.
   ============================================================ */

:root{
  --void:    #0b0d14;            /* page base — storm black    */
  --storm:   #12151f;            /* panel                       */
  --storm-2: #191d2b;            /* raised panel                */
  --bone:    #f2f0ea;            /* primary text                */
  --dim:     #aab0c0;            /* secondary text (≥4.5:1)     */
  --faint:   #7c8296;            /* meta text (large/bold only) */

  --fire:      #ff7a2f;
  --fire-hot:  #ffa14d;
  --fire-deep: #c2410c;
  --volt:      #58b8ff;
  --volt-hot:  #8fd0ff;
  --volt-deep: #1d6fd1;

  --line: rgba(242,240,234,0.11);

  --font-display: "Bebas Neue", "Arial Narrow", sans-serif;
  --font-body:    "Barlow", system-ui, sans-serif;
  --font-cond:    "Barlow Condensed", "Arial Narrow", sans-serif;

  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  /* z scale */
  --z-sticky: 40; --z-callbar: 50; --z-drawer: 60;
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; scroll-padding-top:92px; }
body{
  font-family:var(--font-body);
  background:var(--void);
  color:var(--bone);
  font-size:16.5px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{ display:block; max-width:100%; }
a{ color:inherit; }
::selection{ background:var(--fire-deep); color:#fff; }

.wrap{ width:min(1220px, 100% - 48px); margin-inline:auto; }
@media (max-width:600px){ .wrap{ width:calc(100% - 36px); } }

h1,h2,h3{
  font-family:var(--font-display);
  font-weight:400;
  line-height:0.94;
  letter-spacing:0.012em;
  text-transform:uppercase;
  text-wrap:balance;
}
p{ text-wrap:pretty; max-width:70ch; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--font-cond); font-weight:600; font-size:17px;
  letter-spacing:0.09em; text-transform:uppercase;
  padding:15px 32px; border:0; cursor:pointer; text-decoration:none;
  white-space:nowrap; position:relative;
  clip-path:polygon(10px 0, 100% 0, 100% calc(100% - 10px), calc(100% - 10px) 100%, 0 100%, 0 10px);
  transition:transform .22s var(--ease-out), background-color .22s var(--ease-out), box-shadow .22s var(--ease-out), color .22s var(--ease-out);
}
.btn svg{ width:17px; height:17px; flex:none; }
.btn-fire{ background:var(--fire); color:#160b04; }
.btn-fire:hover{ background:var(--fire-hot); transform:translateY(-2px); }
.btn-volt{ background:var(--volt); color:#04101c; }
.btn-volt:hover{ background:var(--volt-hot); transform:translateY(-2px); }
.btn-ghost{
  background:rgba(242,240,234,0.04); color:var(--bone);
  box-shadow:inset 0 0 0 1.5px rgba(242,240,234,0.4);
}
.btn-ghost:hover{ box-shadow:inset 0 0 0 1.5px var(--bone); transform:translateY(-2px); }
.btn-lg{ padding:18px 40px; font-size:19px; }
.btn-block{ width:100%; }

/* ---------- clash seam (diagonal energy divider) ---------- */
.seam{
  height:8px; position:relative;
  background:linear-gradient(90deg, var(--fire-deep), var(--fire) 38%, #fff 50%, var(--volt) 62%, var(--volt-deep));
  opacity:0.85;
}
.seam::after{
  content:""; position:absolute; inset:0;
  background:repeating-linear-gradient(-60deg, transparent 0 14px, rgba(11,13,20,0.55) 14px 28px);
}

/* ---------- topbar ---------- */
.topbar{ background:#07080d; font-size:13px; border-bottom:1px solid var(--line); }
.topbar .wrap{ display:flex; justify-content:space-between; align-items:center; gap:16px; padding:8px 0; }
.topbar span{ display:inline-flex; align-items:center; gap:7px; color:var(--dim); font-family:var(--font-cond); font-size:14px; letter-spacing:0.05em; text-transform:uppercase; }
.topbar svg{ width:13px; height:13px; opacity:0.7; }
.topbar b{ color:var(--bone); font-weight:600; }
.topbar a{ color:var(--bone); font-weight:600; text-decoration:none; font-family:var(--font-cond); font-size:14px; letter-spacing:0.05em; text-transform:uppercase; }
.topbar a:hover{ color:var(--fire-hot); }
.tb-l{ display:flex; gap:24px; }
@media (max-width:820px){ .hide-s{ display:none; } }

/* ---------- header ---------- */
.head{
  position:sticky; top:0; z-index:var(--z-sticky);
  background:rgba(11,13,20,0.88); backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.head .wrap{ display:flex; align-items:center; justify-content:space-between; gap:22px; padding:13px 0; }
.brand{ display:flex; align-items:center; gap:12px; text-decoration:none; }
.brand .mark{ width:40px; height:40px; flex:none; }
.brand .bn{
  font-family:var(--font-display); font-size:23px; line-height:1; letter-spacing:0.04em;
  display:flex; flex-direction:column; gap:3px;
}
.brand .bn .fl{ display:flex; gap:7px; }
.brand .bn .w-fire{ color:var(--fire); }
.brand .bn .w-amp{ color:var(--dim); }
.brand .bn .w-volt{ color:var(--volt); }
.brand .bn small{
  font-family:var(--font-cond); font-weight:500; font-size:11px; letter-spacing:0.22em;
  color:var(--faint); text-transform:uppercase;
}
.nav{ display:flex; gap:28px; }
.nav a{
  font-family:var(--font-cond); font-weight:600; font-size:16px;
  letter-spacing:0.1em; text-transform:uppercase;
  text-decoration:none; color:var(--dim); padding:4px 0; position:relative;
}
.nav a:hover{ color:var(--bone); }
.nav a::after{
  content:""; position:absolute; left:0; bottom:-2px; height:2px; width:0;
  background:linear-gradient(90deg, var(--fire), var(--volt));
  transition:width .28s var(--ease-out);
}
.nav a:hover::after{ width:100%; }
.head-cta{ display:flex; align-items:center; gap:14px; }
.head-phone{
  display:inline-flex; align-items:center; gap:8px; text-decoration:none;
  font-family:var(--font-cond); font-weight:600; font-size:16px; letter-spacing:0.06em;
}
.head-phone svg{ width:15px; height:15px; color:var(--fire); }
.head .btn{ padding:12px 24px; font-size:15px; }
@media (max-width:1080px){ .nav, .head-phone{ display:none; } }
.burger{
  width:44px; height:44px; border:1px solid var(--line); cursor:pointer;
  background:var(--storm);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:5px;
}
.burger span{ width:20px; height:2px; background:var(--bone); }
@media (min-width:1081px){ .burger{ display:none; } }
@media (max-width:480px){
  .tb-l{ display:none; }
  .topbar .wrap{ justify-content:center; }
  .head .btn{ display:none; }
}

/* ---------- drawer ---------- */
.drawer{
  position:fixed; inset:0; z-index:var(--z-drawer);
  background:rgba(4,5,9,0.7); backdrop-filter:blur(4px);
  opacity:0; pointer-events:none; transition:opacity .3s var(--ease-out);
}
.drawer.open{ opacity:1; pointer-events:auto; }
.drawer-panel{
  position:absolute; top:0; right:0; height:100%; width:min(340px, 88%);
  background:var(--storm); border-left:1px solid var(--line);
  padding:78px 30px 30px; display:flex; flex-direction:column; gap:4px;
  transform:translateX(100%); transition:transform .35s var(--ease-out);
  overflow-y:auto;
}
.drawer.open .drawer-panel{ transform:none; }
.drawer-panel > a:not(.btn){
  text-decoration:none; font-family:var(--font-display); font-size:27px;
  letter-spacing:0.05em; color:var(--bone);
  padding:13px 2px; border-bottom:1px solid var(--line);
}
.drawer-panel .btn{ margin-top:16px; }
.drawer .x{
  position:absolute; top:18px; right:22px; width:42px; height:42px;
  border:1px solid var(--line); background:var(--storm-2);
  font-size:22px; color:var(--bone); cursor:pointer;
}

/* ---------- hero ---------- */
.hero{
  position:relative; overflow:hidden;
  min-height:min(92vh, 860px);
  display:flex; align-items:center;
  background:var(--void);
}
.hero-bg{
  position:absolute; inset:0;
  background:url("assets/hero-clash.webp") center 62% / cover no-repeat;
}
.hero-bg::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(11,13,20,0.82) 0%, rgba(11,13,20,0.25) 38%, rgba(11,13,20,0.28) 62%, rgba(11,13,20,0.92) 100%);
}
.hero .wrap{ position:relative; text-align:center; padding:clamp(88px,13vh,140px) 0 clamp(72px,11vh,120px); }
.hero-badges{
  display:flex; flex-wrap:wrap; justify-content:center; gap:10px; margin-bottom:30px;
}
.badge{
  font-family:var(--font-cond); font-weight:600; font-size:13.5px;
  letter-spacing:0.18em; text-transform:uppercase;
  padding:9px 18px; color:var(--bone);
  background:rgba(11,13,20,0.55); backdrop-filter:blur(6px);
  clip-path:polygon(8px 0, 100% 0, 100% calc(100% - 8px), calc(100% - 8px) 100%, 0 100%, 0 8px);
  box-shadow:inset 0 0 0 1px rgba(242,240,234,0.28);
}
.badge.b-fire{ box-shadow:inset 0 0 0 1px rgba(255,122,47,0.55); color:var(--fire-hot); }
.badge.b-volt{ box-shadow:inset 0 0 0 1px rgba(88,184,255,0.55); color:var(--volt-hot); }
.hero h1{
  font-size:clamp(3.4rem, 8.4vw, 6rem);
  margin:0 auto;
  text-shadow:0 4px 40px rgba(4,5,9,0.8);
}
.hero h1 .l1{ display:block; }
.hero h1 .fire-w{ color:var(--fire); }
.hero h1 .volt-w{ color:var(--volt); }
.hero .sub{
  margin:26px auto 0; max-width:62ch;
  font-size:clamp(1.02rem, 1.5vw, 1.2rem); color:var(--bone);
  text-shadow:0 2px 18px rgba(4,5,9,0.9);
}
.hero .sub b{ font-weight:700; }
.hero .cta-row{ display:flex; flex-wrap:wrap; justify-content:center; gap:16px; margin-top:38px; }
.hero .meta-row{
  margin-top:40px; display:flex; flex-wrap:wrap; justify-content:center; gap:12px 34px;
  font-family:var(--font-cond); font-size:15px; letter-spacing:0.08em; text-transform:uppercase;
  color:var(--dim);
}
.hero .meta-row b{ color:var(--bone); font-weight:600; }

/* embers + charge motes */
.motes{ position:absolute; inset:0; pointer-events:none; }
.mote{
  position:absolute; bottom:-10px; width:5px; height:5px; border-radius:50%;
  opacity:0;
}
.mote.m-f{ background:var(--fire-hot); box-shadow:0 0 8px 2px rgba(255,122,47,0.6); }
.mote.m-v{ background:var(--volt-hot); box-shadow:0 0 8px 2px rgba(88,184,255,0.6); }
@media (prefers-reduced-motion: no-preference){
  html.js .mote{ animation:rise 7s linear infinite; }
  html.js .mote:nth-child(1){ left:8%;  animation-delay:0s;   animation-duration:8s; }
  html.js .mote:nth-child(2){ left:18%; animation-delay:2.4s; animation-duration:6.5s; }
  html.js .mote:nth-child(3){ left:30%; animation-delay:4.8s; animation-duration:9s; }
  html.js .mote:nth-child(4){ left:44%; animation-delay:1.2s; animation-duration:7.5s; }
  html.js .mote:nth-child(5){ left:58%; animation-delay:3.6s; animation-duration:6s; }
  html.js .mote:nth-child(6){ left:70%; animation-delay:0.8s; animation-duration:8.5s; }
  html.js .mote:nth-child(7){ left:82%; animation-delay:2s;   animation-duration:7s; }
  html.js .mote:nth-child(8){ left:92%; animation-delay:4.2s; animation-duration:6.8s; }
}
@keyframes rise{
  0%{ transform:translateY(0) scale(0.7); opacity:0; }
  12%{ opacity:0.9; }
  80%{ opacity:0.5; }
  100%{ transform:translateY(-88vh) scale(1.1); opacity:0; }
}

/* ---------- ticker ---------- */
.ticker{ background:#07080d; border-block:1px solid var(--line); overflow:hidden; }
.ticker .track{ display:flex; width:max-content; padding:13px 0; }
@media (prefers-reduced-motion: no-preference){
  html.js .ticker .track{ animation:marquee 40s linear infinite; }
}
@keyframes marquee{ to{ transform:translateX(-50%); } }
.ticker span{
  font-family:var(--font-display); font-size:19px; letter-spacing:0.09em;
  color:var(--dim); display:inline-flex; align-items:center; white-space:nowrap; padding-right:20px;
}
.ticker span::after{
  content:"◆"; font-size:9px; margin-left:20px;
}
.ticker span:nth-child(odd)::after{ color:var(--fire); }
.ticker span:nth-child(even)::after{ color:var(--volt); }

/* ---------- sections shared ---------- */
.section{ padding:clamp(76px, 10vh, 120px) 0; }
.shead{ margin-bottom:clamp(38px, 5vh, 56px); display:grid; grid-template-columns:minmax(0,1fr) minmax(0,0.85fr); gap:16px 60px; align-items:end; }
.shead h2{ font-size:clamp(2.4rem, 4.6vw, 3.9rem); }
.shead h2 .hl-f{ color:var(--fire); }
.shead h2 .hl-v{ color:var(--volt); }
.shead .aside{ color:var(--dim); font-size:16px; padding-bottom:8px; }
.shead .aside b{ color:var(--bone); }
@media (max-width:840px){ .shead{ grid-template-columns:1fr; align-items:start; } }

/* ---------- roster: choose your game ---------- */
.roster-grid{
  display:grid; gap:14px;
  grid-template-columns:repeat(12, 1fr);
}
.game{
  position:relative; overflow:hidden;
  background:var(--storm); border:1px solid var(--line);
  padding:26px 24px 22px;
  min-height:150px;
  display:flex; flex-direction:column; justify-content:flex-end; gap:6px;
  transition:transform .25s var(--ease-out), border-color .25s var(--ease-out), box-shadow .25s var(--ease-out);
}
.game .num{
  position:absolute; top:14px; right:16px;
  font-family:var(--font-cond); font-weight:600; font-size:13px; letter-spacing:0.14em;
  color:var(--faint);
}
.game h3{ font-size:clamp(1.5rem, 2vw, 1.9rem); letter-spacing:0.03em; }
.game p{ font-size:14px; color:var(--dim); line-height:1.5; max-width:34ch; }
.game::before{ /* element glow floor */
  content:""; position:absolute; left:0; right:0; bottom:0; height:3px;
  background:currentColor; opacity:0.5;
  transform:scaleX(0); transform-origin:left;
  transition:transform .3s var(--ease-out);
}
.game.g-fire{ color:var(--fire); }
.game.g-volt{ color:var(--volt); }
.game h3, .game p{ color:var(--bone); }
.game p{ color:var(--dim); }
html.js .game:hover{ transform:translateY(-4px); }
html.js .game.g-fire:hover{ border-color:rgba(255,122,47,0.5); box-shadow:0 14px 40px -18px rgba(255,122,47,0.35); }
html.js .game.g-volt:hover{ border-color:rgba(88,184,255,0.5); box-shadow:0 14px 40px -18px rgba(88,184,255,0.35); }
html.js .game:hover::before{ transform:scaleX(1); }
.g-3{ grid-column:span 3; }
.g-4{ grid-column:span 4; }
.g-6{ grid-column:span 6; }
.game.feat{
  min-height:210px; background:var(--storm-2);
  justify-content:flex-end;
}
.game.feat .tagline{
  font-family:var(--font-cond); font-weight:600; font-size:13.5px;
  letter-spacing:0.18em; text-transform:uppercase; margin-bottom:2px;
}
.game.feat.g-fire .tagline{ color:var(--fire); }
.game.feat.g-volt .tagline{ color:var(--volt); }
@media (max-width:900px){
  .g-3, .g-4, .g-6{ grid-column:span 6; }
}
@media (max-width:540px){
  .roster-grid{ grid-template-columns:1fr 1fr; gap:10px; }
  .g-3, .g-4, .g-6{ grid-column:span 2; }
  .game{ min-height:110px; padding:20px 18px 16px; }
}
.roster-note{ margin-top:22px; font-size:14px; color:var(--dim); }
.roster-note b{ color:var(--bone); }

/* ---------- the split: fire vs lightning ---------- */
.duel{ position:relative; overflow:hidden; background:var(--void); }
.duel-bg{
  position:absolute; inset:0;
  background:url("assets/arena-table.webp") center / cover no-repeat;
  opacity:0.4;
}
.duel-bg::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, var(--void) 0%, rgba(11,13,20,0.62) 30%, rgba(11,13,20,0.62) 70%, var(--void) 100%);
}
.duel .wrap{ position:relative; }
.duel-grid{
  display:grid; grid-template-columns:1fr auto 1fr; gap:clamp(20px, 4vw, 56px);
  align-items:stretch;
}
.side{
  padding:clamp(30px, 4vw, 46px);
  background:rgba(11,13,20,0.72); backdrop-filter:blur(6px);
  border:1px solid var(--line);
  position:relative; overflow:hidden;
}
.side::before{
  content:""; position:absolute; top:0; left:0; right:0; height:3px;
}
.side-fire::before{ background:linear-gradient(90deg, var(--fire-deep), var(--fire)); }
.side-volt::before{ background:linear-gradient(90deg, var(--volt), var(--volt-deep)); }
.side .el{
  font-family:var(--font-cond); font-weight:600; font-size:14px;
  letter-spacing:0.24em; text-transform:uppercase; margin-bottom:10px;
}
.side-fire .el{ color:var(--fire); }
.side-volt .el{ color:var(--volt); }
.side h3{ font-size:clamp(1.9rem, 3vw, 2.6rem); margin-bottom:18px; }
.side ul{ list-style:none; display:grid; gap:13px; }
.side li{ display:flex; gap:12px; align-items:flex-start; font-size:15.5px; color:var(--dim); line-height:1.55; }
.side li b{ color:var(--bone); font-weight:600; }
.side li svg{ width:16px; height:16px; flex:none; margin-top:4px; }
.side-fire li svg{ color:var(--fire); }
.side-volt li svg{ color:var(--volt); }
.side .btn{ margin-top:26px; }
.vs{
  align-self:center; text-align:center;
  font-family:var(--font-display); font-size:clamp(2.2rem, 3.4vw, 3.2rem);
  color:var(--bone); position:relative; padding:18px 6px;
}
.vs::before, .vs::after{
  content:""; position:absolute; left:50%; transform:translateX(-50%);
  width:2px; height:clamp(40px, 8vh, 90px);
}
.vs::before{ bottom:100%; background:linear-gradient(0deg, var(--fire), transparent); }
.vs::after{ top:100%; background:linear-gradient(180deg, var(--volt), transparent); }
@media (max-width:900px){
  .duel-grid{ grid-template-columns:1fr; }
  .vs{ padding:6px; }
  .vs::before, .vs::after{ content:none; }
}

/* ---------- the road (signature) ---------- */
.road{ background:var(--storm); border-block:1px solid var(--line); position:relative; overflow:hidden; }
.road::before{ /* faint charge grid */
  content:""; position:absolute; inset:0; pointer-events:none;
  background:
    linear-gradient(rgba(242,240,234,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(242,240,234,0.025) 1px, transparent 1px);
  background-size:56px 56px;
}
.road .wrap{ position:relative; }
.road-line{
  height:4px; margin:8px 2px 34px; position:relative;
  background:rgba(242,240,234,0.1);
}
.road-line .fill{
  position:absolute; inset:0; transform-origin:left;
  background:linear-gradient(90deg, var(--fire-deep), var(--fire) 30%, var(--volt) 75%, var(--volt-hot));
  transform:scaleX(0);
}
html.js .road-line.in .fill{ transition:transform 1.4s var(--ease-out) .2s; transform:scaleX(1); }
html:not(.js) .road-line .fill{ transform:scaleX(1); }
.stages{
  display:grid; grid-template-columns:repeat(4, 1fr); gap:14px;
  counter-reset:stage;
}
.stage{
  background:var(--void); border:1px solid var(--line);
  padding:26px 24px 24px; position:relative;
  display:flex; flex-direction:column; gap:10px;
}
.stage .sn{
  font-family:var(--font-display); font-size:44px; line-height:1;
}
.stage:nth-child(1) .sn{ color:var(--fire); }
.stage:nth-child(2) .sn{ color:var(--fire-hot); }
.stage:nth-child(3) .sn{ color:var(--volt); }
.stage:nth-child(4) .sn{ color:var(--volt-hot); }
.stage h3{ font-size:1.45rem; letter-spacing:0.03em; }
.stage .what{ font-size:14.5px; color:var(--dim); line-height:1.6; flex:1; }
.stage .what b{ color:var(--bone); }
.stage .facts{
  border-top:1px solid var(--line); padding-top:12px;
  display:grid; gap:6px;
}
.stage .facts span{
  font-family:var(--font-cond); font-size:14.5px; letter-spacing:0.05em;
  color:var(--dim); display:flex; justify-content:space-between; gap:10px;
}
.stage .facts b{ color:var(--bone); font-weight:600; text-align:right; }
.stage .tip{
  margin-top:4px; font-size:13.5px; color:var(--dim); line-height:1.55;
  padding:10px 12px; background:var(--storm-2); border:1px solid var(--line);
}
.stage .tip b{ color:var(--bone); }
@media (max-width:1000px){ .stages{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .stages{ grid-template-columns:1fr; } }
.road-caveat{ margin-top:26px; font-size:13.5px; color:var(--dim); }
.road-caveat b{ color:var(--bone); }

/* ---------- what's on board ---------- */
.board .fixture{
  border-top:1px solid var(--line);
}
.fixture-row{
  display:grid; grid-template-columns:120px 1fr auto auto; gap:14px 34px;
  align-items:center; padding:22px 6px;
  border-bottom:1px solid var(--line);
}
.fixture-row .day{
  font-family:var(--font-display); font-size:28px; letter-spacing:0.05em;
}
.fixture-row.f-live .day{ color:var(--volt); }
.fixture-row.f-fire .day{ color:var(--fire); }
.fixture-row .ev b{ display:block; font-size:17px; font-weight:700; color:var(--bone); }
.fixture-row .ev span{ font-size:14.5px; color:var(--dim); }
.fixture-row .when{
  font-family:var(--font-cond); font-weight:600; font-size:16px; letter-spacing:0.08em;
  text-transform:uppercase; color:var(--bone); white-space:nowrap;
}
.fixture-row .cost{
  font-family:var(--font-cond); font-weight:600; font-size:15px; letter-spacing:0.06em;
  color:var(--dim); white-space:nowrap; text-align:right;
}
.fixture-row .cost b{ color:var(--bone); }
@media (max-width:760px){
  .fixture-row{ grid-template-columns:1fr; gap:6px; }
  .fixture-row .cost{ text-align:left; }
}
.board-note{ margin-top:24px; font-size:14px; color:var(--dim); display:flex; gap:10px; align-items:flex-start; }
.board-note svg{ width:16px; height:16px; color:var(--volt); flex:none; margin-top:3px; }
.board-note b{ color:var(--bone); }

/* ---------- community band ---------- */
.storm-band{
  position:relative; overflow:hidden; text-align:center;
}
.storm-band .bg{
  position:absolute; inset:0;
  background:url("assets/clash-band.webp") center / cover no-repeat;
}
.storm-band .bg::after{
  content:""; position:absolute; inset:0;
  background:rgba(7,8,13,0.72);
}
.storm-band .wrap{ position:relative; padding:clamp(70px, 10vh, 110px) 0; }
.storm-band h2{ font-size:clamp(2.6rem, 5vw, 4.2rem); }
.storm-band p{ margin:18px auto 0; max-width:56ch; color:var(--bone); font-size:17px; }
.storm-band .cta-row{ display:flex; flex-wrap:wrap; justify-content:center; gap:14px; margin-top:32px; }
.storm-band .soon{
  margin-top:26px; font-family:var(--font-cond); font-size:14px; letter-spacing:0.16em;
  text-transform:uppercase; color:var(--dim);
}
.storm-band .soon b{ color:var(--fire-hot); }

/* ---------- visit ---------- */
.visit-grid{ display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1fr); gap:clamp(30px,4vw,64px); align-items:start; }
.visit h2{ font-size:clamp(2.2rem, 4vw, 3.4rem); margin-bottom:16px; }
.visit .lead{ color:var(--dim); margin-bottom:28px; font-size:16.5px; }
.visit .lead b{ color:var(--bone); }
.ways{ display:grid; gap:12px; margin-bottom:26px; }
.way{
  display:flex; gap:16px; align-items:center;
  background:var(--storm); border:1px solid var(--line);
  padding:16px 20px;
}
.way .wi{
  width:42px; height:42px; flex:none;
  display:grid; place-items:center;
  background:var(--storm-2); border:1px solid var(--line);
}
.way .wi svg{ width:18px; height:18px; color:var(--fire); }
.way:nth-child(even) .wi svg{ color:var(--volt); }
.way small{
  display:block; font-family:var(--font-cond); font-size:12.5px; font-weight:600;
  letter-spacing:0.16em; text-transform:uppercase; color:var(--faint);
}
.way a, .way b{ font-weight:600; font-size:15.5px; color:var(--bone); text-decoration:none; }
.way a:hover{ color:var(--fire-hot); }
.map{ border:1px solid var(--line); }
.map iframe{ width:100%; height:240px; border:0; display:block; filter:grayscale(0.2) contrast(1.02); }

.form-card{
  background:var(--storm); border:1px solid var(--line);
  padding:34px 34px 30px; position:relative;
}
.form-card::before{
  content:""; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg, var(--fire), var(--volt));
}
.form-card h3{ font-size:1.9rem; margin-bottom:6px; }
.form-card .fsub{ font-size:14.5px; color:var(--dim); margin-bottom:22px; }
.frow{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.field{ margin-bottom:14px; }
.field label{
  display:block; font-family:var(--font-cond); font-weight:600; font-size:13.5px;
  letter-spacing:0.12em; text-transform:uppercase; color:var(--dim); margin-bottom:7px;
}
.field input, .field select, .field textarea{
  width:100%; font-family:var(--font-body); font-size:15px; color:var(--bone);
  background:var(--void); border:1px solid var(--line);
  padding:13px 15px; outline:none;
  transition:border-color .2s var(--ease-out), box-shadow .2s var(--ease-out);
}
.field textarea{ min-height:100px; resize:vertical; }
.field input::placeholder, .field textarea::placeholder{ color:var(--faint); }
.field input:focus, .field select:focus, .field textarea:focus{
  border-color:var(--volt);
  box-shadow:0 0 0 3px rgba(88,184,255,0.18);
}
.form-note{ margin-top:14px; font-size:13.5px; color:var(--dim); text-align:center; }
.form-note b{ color:var(--bone); }
.form-ok{ display:none; text-align:center; padding:34px 10px; }
.form-ok .ok{
  width:62px; height:62px; margin:0 auto 18px;
  background:linear-gradient(135deg, var(--fire), var(--volt));
  display:grid; place-items:center; color:#0b0d14;
}
.form-ok .ok svg{ width:26px; height:26px; }
.form-card.sent form{ display:none; }
.form-card.sent .form-ok{ display:block; }
@media (max-width:880px){ .visit-grid{ grid-template-columns:1fr; } }
@media (max-width:560px){ .frow{ grid-template-columns:1fr; } .form-card{ padding:26px 22px; } }

/* ---------- footer ---------- */
.foot{ background:#07080d; border-top:1px solid var(--line); }
.foot .top{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; padding:58px 0 42px; }
.foot p{ font-size:14.5px; color:var(--dim); margin-top:14px; max-width:42ch; }
.foot h4{
  font-family:var(--font-cond); font-weight:600; font-size:14px;
  letter-spacing:0.2em; text-transform:uppercase; color:var(--bone); margin-bottom:14px;
}
.foot ul{ list-style:none; display:grid; gap:9px; font-size:14.5px; color:var(--dim); }
.foot ul a{ text-decoration:none; }
.foot ul a:hover{ color:var(--bone); }
.foot .bot{
  border-top:1px solid var(--line); padding:20px 0;
  display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap;
  font-size:13px; color:var(--faint);
}
.foot .bot a{ color:var(--dim); text-decoration:none; }
.foot .bot a:hover{ color:var(--bone); }
@media (max-width:760px){ .foot .top{ grid-template-columns:1fr; gap:30px; } }

/* ---------- sticky call bar ---------- */
.callbar{
  position:fixed; bottom:0; left:0; right:0; z-index:var(--z-callbar);
  display:none; gap:10px; padding:11px 14px calc(11px + env(safe-area-inset-bottom));
  background:rgba(7,8,13,0.94); backdrop-filter:blur(12px);
  border-top:1px solid var(--line);
}
.callbar .btn{ flex:1; padding:13px 10px; font-size:15px; }
@media (max-width:760px){
  .callbar{ display:flex; }
  body{ padding-bottom:74px; }
}

/* ---------- reveals: enhance, never gate ---------- */
html.js .reveal{
  opacity:0; transform:translateY(24px);
  transition:opacity .7s var(--ease-out), transform .7s var(--ease-out);
}
html.js .reveal.in{ opacity:1; transform:none; }

@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  html.js .reveal{ opacity:1; transform:none; transition:none; }
  html.js .mote{ animation:none !important; display:none; }
  html.js .ticker .track{ animation:none !important; }
  html.js .road-line.in .fill{ transition:none; }
  .btn, .game, .nav a::after{ transition:none !important; }
}
