/* ============================================================
   IGNITE — esports arena & tournaments
   Reference DNA: ausify.com.au (black / CRT chromatic-glitch /
   Instrument Serif / dot-matrix mono) × HyperX immersive arena
   Accent: acid ember (fire)
   ============================================================ */

:root{
  --bg:#050506;
  --bg-2:#0b0b0e;
  --bg-3:#121216;
  --panel:#16161b;
  --ink:#f4f1ea;
  --ink-dim:#a7a299;
  --ink-faint:#6a665e;
  --ember:#ff5a1f;
  --ember-2:#ff8a3d;
  --ember-deep:#cf3c12;
  --cyan:#27e0ff;
  --lilac:#caa8ff;
  --line:rgba(244,241,234,.12);
  --line-2:rgba(244,241,234,.07);

  --serif:"Instrument Serif",serif;
  --mincho:"Shippori Mincho B1","Instrument Serif",serif;
  --jp:"Noto Sans JP",sans-serif;
  --mono:"JetBrains Mono","DotGothic16",monospace;
  --dot:"DotGothic16","JetBrains Mono",monospace;

  --maxw:1320px;
  --pad:clamp(20px,5vw,80px);
}

*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--jp);
  font-weight:400;
  line-height:1.7;
  letter-spacing:.01em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
li{list-style:none}
::selection{background:var(--ember);color:#000}

/* ---------- CRT overlays ---------- */
.fx-scan{
  position:fixed;inset:0;z-index:900;pointer-events:none;
  background:repeating-linear-gradient(0deg,rgba(0,0,0,0) 0,rgba(0,0,0,0) 2px,rgba(0,0,0,.16) 3px,rgba(0,0,0,0) 4px);
  mix-blend-mode:multiply;opacity:.5;
}
.fx-vignette{
  position:fixed;inset:0;z-index:899;pointer-events:none;
  background:radial-gradient(120% 110% at 50% 40%,transparent 55%,rgba(0,0,0,.55) 100%);
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ---------- scroll progress ---------- */
.scroll-progress{position:fixed;top:0;left:0;right:0;height:4px;z-index:1990;background:rgba(255,255,255,.05)}
.scroll-progress span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--ember-deep),var(--ember),var(--ember-2) 60%,var(--cyan));box-shadow:0 0 14px rgba(255,90,31,.7)}

/* ---------- glitch / chromatic aberration ---------- */
.glitch{
  position:relative;
  text-shadow:.018em 0 var(--cyan),-.018em 0 var(--ember);
}
.glitch.soft{text-shadow:.012em 0 rgba(39,224,255,.7),-.012em 0 rgba(255,90,31,.8)}
@keyframes flicker{
  0%,97%,100%{opacity:1}
  98%{opacity:.82}
  99%{opacity:.94}
}
.logo.glitch,.foot-logo.glitch{animation:flicker 7s infinite}

/* ---------- shared bits ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.wrap-narrow{max-width:560px}
.eyebrow,.sec-label,.cat-head,.mod-no,.pt-label,.com-tag,.trn-no,.case-kicker{
  font-family:var(--mono);font-weight:500;text-transform:uppercase;letter-spacing:.22em;
}
.sec-label{
  font-size:12px;color:var(--ink-faint);margin-bottom:clamp(22px,3vw,40px);
  display:flex;align-items:center;gap:.7em;
}
.sec-label::after{content:"";flex:1;height:1px;background:var(--line);max-width:240px}
.sec-label.center{justify-content:center}
.sec-label.center::after,.sec-label.center::before{display:none}
.em{color:var(--ember)}
.dim{color:var(--ink-faint)}
.ital-serif{font-family:var(--serif);font-style:italic}
.spark{color:var(--ember);font-style:normal}

.sec-title{
  font-family:var(--mincho);font-weight:800;line-height:1.12;letter-spacing:.01em;
  font-size:clamp(2rem,5.4vw,4.6rem);
  margin-bottom:clamp(30px,4vw,56px);
}
.sec-title.sm{font-size:clamp(1.8rem,4vw,3rem)}

.section{padding:clamp(72px,11vw,150px) 0;position:relative}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--mono);font-weight:700;font-size:13px;letter-spacing:.08em;
  padding:14px 24px;border:1px solid transparent;border-radius:2px;
  cursor:pointer;transition:transform .25s cubic-bezier(.2,.7,.2,1),background .25s,color .25s,box-shadow .25s,border-color .25s;
  white-space:nowrap;
}
.btn .arr{font-style:normal;transition:transform .25s}
.btn:hover .arr{transform:translateX(4px)}
.btn-lg{padding:18px 32px;font-size:14px}
.btn-ember{background:var(--ember);color:#0a0500;box-shadow:0 0 0 rgba(255,90,31,0)}
.btn-ember:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(255,90,31,.35),0 0 18px rgba(255,90,31,.4)}
.btn-line{border-color:var(--line);color:var(--ink);background:transparent}
.btn-line:hover{border-color:var(--ember);color:var(--ember);transform:translateY(-2px)}
.btn-ghost{color:var(--ink);background:transparent;border-color:transparent;padding:10px 14px}
.btn-ghost:hover{color:var(--ember)}

/* ============================================================
   SPLASH (image → sandstorm glitch → glass shatter → hero)
   ============================================================ */
.splash{position:fixed;inset:0;z-index:2000;background:#000;overflow:hidden;transition:opacity .45s ease,visibility 0s linear .45s}
.splash.gone{opacity:0;visibility:hidden;pointer-events:none}
.splash-bg{background-size:cover;background-position:center;background-image:url('../images/splash-pc.jpg')}
.splash-img{position:absolute;inset:0}
/* neon-tube flicker (replaces sandstorm) */
.splash-img.neon{animation:neonFlicker 2.4s linear infinite}
.splash-img.neon-hard{animation:neonFlicker .42s linear infinite}
@keyframes neonFlicker{
  0%{filter:brightness(1) saturate(1)}
  6%{filter:brightness(1.5) saturate(1.35)}
  7%{filter:brightness(.5)}
  9%{filter:brightness(1.4)}
  15%{filter:brightness(1)}
  37%{filter:brightness(1.3)}
  38%{filter:brightness(.45)}
  40%{filter:brightness(1.55) saturate(1.45)}
  47%{filter:brightness(1)}
  67%{filter:brightness(1.1)}
  69%{filter:brightness(.55)}
  70%{filter:brightness(1.45)}
  80%{filter:brightness(1)}
  100%{filter:brightness(1)}
}
.splash-neon{position:absolute;inset:0;pointer-events:none;mix-blend-mode:screen;opacity:0;background:radial-gradient(58% 50% at 50% 44%,rgba(255,90,31,.28),transparent 70%),radial-gradient(42% 42% at 72% 62%,rgba(39,224,255,.2),transparent 70%)}
.splash-neon.on{animation:neonGlow 1.7s ease-in-out infinite}
@keyframes neonGlow{0%,100%{opacity:.18}45%{opacity:.6}}
.splash-crack{position:absolute;inset:0;width:100%;height:100%;opacity:0;pointer-events:none;filter:drop-shadow(0 0 1.5px rgba(255,255,255,.85)) drop-shadow(0 0 4px rgba(120,200,255,.35))}
.splash-crack.on{animation:crackIn .28s cubic-bezier(.2,.8,.2,1) forwards}
@keyframes crackIn{0%{opacity:0;transform:scale(.9)}40%{opacity:1}100%{opacity:.95;transform:scale(1.01)}}
.splash-crack svg{width:100%;height:100%;display:block}
.splash-crack path{fill:none;stroke:rgba(244,250,255,.92);stroke-width:.8;vector-effect:non-scaling-stroke;stroke-linejoin:round;stroke-linecap:round}
.splash-flash{position:absolute;inset:0;background:#fff;opacity:0;pointer-events:none}
.splash-flash.on{animation:splashFlash .2s ease}
@keyframes splashFlash{0%{opacity:0}35%{opacity:.7}100%{opacity:0}}
.shard{position:absolute;inset:0;background-size:cover;background-position:center;background-image:url('../images/splash-pc.jpg');will-change:transform,opacity;transition:transform .85s cubic-bezier(.2,.55,.3,1),opacity .85s ease;backface-visibility:hidden}
@media(max-width:680px){.splash-bg,.shard{background-image:url('../images/splash-mobile.jpg')}}

/* ---- hero power-on stagger (index) ---- */
body:not(.is-loaded) .hero-inner > *{opacity:0;transform:translateY(24px)}
.hero .eyebrow{transition:opacity .7s ease,transform .9s cubic-bezier(.2,.7,.2,1)}
.hero-title{transition:opacity .8s ease .15s,transform 1s cubic-bezier(.2,.7,.2,1) .15s}
.hero-lede{transition:opacity .8s ease .34s,transform 1s cubic-bezier(.2,.7,.2,1) .34s}
.hero-actions{transition:opacity .8s ease .5s,transform 1s cubic-bezier(.2,.7,.2,1) .5s}
.hero-meta{transition:opacity .8s ease .64s,transform 1s cubic-bezier(.2,.7,.2,1) .64s}
body.is-loaded .hero-inner > *{opacity:1;transform:none}

/* ---- constant subtle chromatic jitter (alive, ausify logo feel) ---- */
@keyframes chromaJit{
  0%,90%,100%{text-shadow:.018em 0 var(--cyan),-.018em 0 var(--ember);transform:translate(0,0)}
  92%{text-shadow:.06em 0 var(--cyan),-.05em 0 var(--ember);transform:translate(-1px,0)}
  94%{text-shadow:-.04em 0 var(--cyan),.05em 0 var(--ember);transform:translate(1px,0)}
  96%{text-shadow:.018em 0 var(--cyan),-.018em 0 var(--ember);transform:translate(0,0)}
}
.logo.glitch{animation:chromaJit 4.5s infinite}
.foot-logo.glitch{animation:chromaJit 6s infinite}
.hero-title .line.glitch{animation:chromaJit 7s infinite}
.hero-title .line.glitch.ital{animation-duration:8.5s;animation-delay:.6s}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:18px var(--pad);
  transition:background .4s,padding .4s,border-color .4s;
  border-bottom:1px solid transparent;
  z-index:1900;
}
.site-header.solid{background:rgba(5,5,6,.82);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom-color:var(--line);padding-top:12px;padding-bottom:12px}
.logo{font-family:var(--dot);font-size:22px;letter-spacing:.04em;color:var(--ink);z-index:2;display:inline-flex;align-items:center}
.logo img{height:clamp(34px,3.6vw,46px);width:auto;display:block;transition:opacity .25s}
.logo:hover img{opacity:.82}
.nav{display:flex;gap:clamp(14px,2vw,30px);font-family:var(--mono);font-size:12px;font-weight:500;letter-spacing:.16em}
.nav a{color:var(--ink-dim);position:relative;padding:4px 0;transition:color .25s}
.nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--ember);transition:width .3s}
.nav a:hover{color:var(--ink)}
.nav a:hover::after{width:100%}
.header-cta{display:flex;align-items:center;gap:8px}

/* burger */
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;z-index:2;padding:6px}
.burger span{width:24px;height:2px;background:var(--ink);transition:.3s}
body.menu-open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.drawer{
  position:fixed;inset:0;z-index:1850;background:var(--bg);
  display:flex;flex-direction:column;justify-content:flex-start;gap:22px;padding:100px var(--pad) 100px;
  overflow-y:auto;
  opacity:0;visibility:hidden;transform:translateY(-10px);
  transition:opacity .35s ease,transform .35s ease,visibility 0s linear .35s;
}
body.menu-open .drawer{opacity:1;visibility:visible;transform:none;transition:opacity .35s ease,transform .35s ease,visibility 0s}
body.menu-open .site-header{background:rgba(5,5,6,.92);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.drawer nav{display:flex;flex-direction:column;gap:2px}
.drawer nav a{font-family:var(--mincho);font-weight:700;font-size:clamp(21px,6vw,32px);color:var(--ink);letter-spacing:.04em;padding:7px 0}
.drawer nav a:active{color:var(--ember)}
.drawer-cta{display:flex;flex-direction:column;gap:12px;margin-top:20px}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;padding:104px var(--pad) clamp(56px,8vh,96px)}
.hero-media{position:absolute;inset:0;z-index:0}
.hero-img{position:absolute;inset:0;background:#0a0a0c url('../images/hero.jpg') center/cover no-repeat;animation:kb 22s ease-in-out infinite alternate}
@keyframes kb{from{transform:scale(1.04)}to{transform:scale(1.12)}}
.hero-img::after{content:"";position:absolute;inset:0;background:
  radial-gradient(80% 70% at 70% 30%,rgba(255,90,31,.16),transparent 60%),
  repeating-linear-gradient(0deg,transparent 0,transparent 2px,rgba(0,0,0,.14) 3px,transparent 4px)}
.hero-shade{position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(5,5,6,.55) 0%,rgba(5,5,6,.2) 30%,rgba(5,5,6,.55) 70%,var(--bg) 100%),
  linear-gradient(90deg,rgba(5,5,6,.7) 0%,transparent 55%)}
.hero-inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;width:100%}
.hero .eyebrow{font-size:12px;color:var(--ink);margin-bottom:clamp(20px,3vw,34px);display:flex;align-items:center;gap:.6em}
.hero-title{font-family:var(--mincho);font-weight:800;line-height:.98;letter-spacing:.005em;margin-bottom:clamp(26px,3.5vw,40px)}
.hero-title .line{display:block;font-size:clamp(2.8rem,min(12.5vw,15.5vh),10.5rem)}
.hero-title .line.ital{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--ember);text-shadow:.012em 0 var(--cyan),-.012em 0 rgba(255,90,31,.6)}
.hero-lede{font-size:clamp(15px,1.5vw,18px);line-height:1.9;color:var(--ink-dim);max-width:720px;margin-bottom:clamp(28px,3.5vw,42px);text-wrap:pretty;word-break:auto-phrase}
.nb{white-space:nowrap}
.hero-lede .em{font-family:var(--mincho);font-weight:700}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:clamp(34px,4vw,52px)}
.hero-meta{display:flex;flex-wrap:wrap;gap:clamp(20px,4vw,52px);border-top:1px solid var(--line);padding-top:22px}
.hero-meta li{display:flex;flex-direction:column;gap:2px}
.hero-meta b{font-family:var(--mono);font-weight:800;font-size:clamp(18px,2vw,24px);color:var(--ink);letter-spacing:.02em}
.hero-meta span{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--ink-faint);text-transform:uppercase}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-2);padding:18px 0}
.marquee-track{display:flex;align-items:center;gap:42px;width:max-content;animation:marq 32s linear infinite}
.marquee-track span{font-family:var(--mincho);font-weight:800;font-size:clamp(20px,3vw,34px);color:var(--ink);white-space:nowrap;letter-spacing:.02em}
.marquee-track i{color:var(--ember);font-style:normal;font-size:14px}
@keyframes marq{to{transform:translateX(-50%)}}

/* ============================================================
   ENTRIES (jewel-case cards)
   ============================================================ */
.entries{background:var(--bg)}
.sec-title .em{color:var(--ember)}
.entry-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(18px,2.4vw,32px)}
.case{
  position:relative;border:1px solid var(--line);border-radius:4px;overflow:hidden;
  padding:clamp(22px,2.6vw,34px);background:var(--bg-2);
  transition:transform .4s cubic-bezier(.2,.7,.2,1),border-color .4s,box-shadow .4s;
  display:flex;flex-direction:column;
}
.case::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent 0,transparent 2px,rgba(0,0,0,.18) 3px,transparent 4px);pointer-events:none;opacity:.6}
.case-spine{position:absolute;left:0;top:0;bottom:0;width:7px;background:linear-gradient(180deg,rgba(255,255,255,.14),rgba(255,255,255,.02));border-right:1px solid rgba(0,0,0,.5)}
.case:hover{transform:translateY(-6px);border-color:var(--ember);box-shadow:0 24px 60px rgba(0,0,0,.6),0 0 30px rgba(255,90,31,.12)}
.case-art{aspect-ratio:16/10;display:flex;align-items:center;justify-content:center;margin-bottom:24px;border:1px solid var(--line-2);position:relative;overflow:hidden;background:radial-gradient(130% 130% at 50% 38%,#16161b,#070709)}
.case-art::after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;background:repeating-linear-gradient(0deg,transparent 0,transparent 2px,rgba(0,0,0,.24) 3px,transparent 4px)}
.ill{width:60%;height:60%;position:relative;z-index:2}
.ill *{fill:none;stroke-width:2.2;vector-effect:non-scaling-stroke;stroke-linecap:round;stroke-linejoin:round}

/* PLAYERS = aim reticle (ember) — brackets lock on hover */
.ill-aim .ring2{stroke:rgba(255,90,31,.5);transform-origin:50% 50%;transition:transform .6s cubic-bezier(.2,.7,.2,1),stroke .35s}
.ill-aim .cross{stroke:rgba(244,241,234,.28);transition:stroke .35s}
.ill-aim .brk{stroke:var(--ember);transition:transform .45s cubic-bezier(.34,1.5,.6,1)}
.ill-aim .dot{fill:var(--ember);stroke:none;transform-origin:50% 50%}
.ill-aim .pulse{fill:none;stroke:var(--ember);opacity:0;transform-origin:50% 50%}
.case:hover .ill-aim .ring2{transform:rotate(45deg);stroke:var(--ember)}
.case:hover .ill-aim .cross{stroke:var(--ember)}
.case:hover .ill-aim .b1{transform:translate(11px,11px)}
.case:hover .ill-aim .b2{transform:translate(-11px,11px)}
.case:hover .ill-aim .b3{transform:translate(11px,-11px)}
.case:hover .ill-aim .b4{transform:translate(-11px,-11px)}
.case:hover .ill-aim .pulse{animation:aimPulse 1.1s ease-out infinite}
@keyframes aimPulse{0%{transform:scale(.5);opacity:.9}80%{opacity:0}100%{transform:scale(2.6);opacity:0}}

/* BUSINESS = tournament bracket — ONE winner advances to the crown */
.ill-brk .struct{stroke:rgba(39,224,255,.18);stroke-width:1.8;transition:stroke .4s}
.ill-brk .win{fill:none;stroke:var(--ember);stroke-width:2.7;opacity:.6;transition:opacity .35s}
.ill-brk .champ{fill:rgba(255,90,31,.4);stroke:none;transform-box:fill-box;transform-origin:center;transition:fill .4s,transform .5s cubic-bezier(.34,1.5,.6,1)}
.case:hover .ill-brk .struct{stroke:rgba(39,224,255,.3)}
.case:hover .ill-brk .win{opacity:1;stroke-dasharray:6 7;animation:flowWin 1.1s linear infinite}
.case:hover .ill-brk .champ{fill:var(--ember);transform:scale(1.18)}
@keyframes flowWin{from{stroke-dashoffset:0}to{stroke-dashoffset:-26}}
.case-kicker{font-size:11px;color:var(--ink-faint);margin-bottom:12px}
.case-name{font-family:var(--mincho);font-weight:800;font-size:clamp(1.4rem,2.4vw,2rem);margin-bottom:12px;line-height:1.2}
.case-desc{font-size:14px;color:var(--ink-dim);line-height:1.8;margin-bottom:20px}
.case-go{font-family:var(--mono);font-weight:700;font-size:12px;letter-spacing:.1em;color:var(--ember)}
.case-foot{position:relative;z-index:2}

/* ============================================================
   ABOUT
   ============================================================ */
.bigquote{font-family:var(--mincho);font-weight:500;font-size:clamp(1.5rem,3.6vw,3rem);line-height:1.5;letter-spacing:.01em;margin-bottom:clamp(34px,4vw,56px);text-wrap:pretty;word-break:auto-phrase}
.bigquote .em{font-weight:800}
.bigquote.sm{font-size:clamp(1.4rem,3vw,2.4rem)}
.about-cols{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,64px);max-width:980px}
.about-cols p{font-size:15px;color:var(--ink-dim);line-height:2}

/* ============================================================
   TITLES
   ============================================================ */
.title-cat{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,64px)}
.cat-head{font-size:12px;margin-bottom:20px}
.tag{background:var(--ember);color:#0a0500;padding:5px 12px;border-radius:2px;letter-spacing:.18em}
.title-list li{
  display:flex;align-items:baseline;gap:18px;
  font-family:var(--mincho);font-weight:700;font-size:clamp(1.4rem,3vw,2.2rem);
  padding:18px 0;border-bottom:1px solid var(--line);transition:color .3s,padding .3s;
}
.title-list li:hover{color:var(--ember);padding-left:8px}
.title-list .no{font-family:var(--mono);font-size:12px;color:var(--ink-faint);font-weight:500;min-width:24px}
.title-list i{font-family:var(--mono);font-style:normal;font-size:12px;color:var(--ink-faint);letter-spacing:.1em}
.title-note{font-family:var(--mono);font-size:12px;color:var(--ink-faint);margin-top:28px;letter-spacing:.04em}

/* ============================================================
   FACILITY
   ============================================================ */
.fac-mod{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:clamp(24px,4vw,60px);max-width:var(--maxw);margin:0 auto;padding:clamp(40px,5vw,70px) var(--pad)}
.fac-mod.rev .fac-text{order:2}
.mod-no{font-size:11px;color:var(--ember);margin-bottom:16px}
.mod-title{font-family:var(--mincho);font-weight:800;font-size:clamp(1.6rem,3vw,2.6rem);margin-bottom:18px;line-height:1.2}
.mod-desc{font-size:15px;color:var(--ink-dim);line-height:1.95;margin-bottom:24px}
.spec{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line)}
.spec li{display:flex;gap:18px;align-items:baseline;font-family:var(--mono);font-size:13px;color:var(--ink-dim);padding:11px 0;border-bottom:1px solid var(--line)}
.spec li span{color:var(--ember);font-weight:700;font-size:11px;letter-spacing:.14em;min-width:84px}
.fac-img .img{aspect-ratio:4/3;background:#0d0d10 center/cover no-repeat;border:1px solid var(--line);border-radius:3px;position:relative}
.fac-img .img::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent 0,transparent 2px,rgba(0,0,0,.12) 3px,transparent 4px);border-radius:3px}
.amen{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:clamp(34px,4vw,56px);border-top:1px solid var(--line);padding-top:34px}
.amen li{font-family:var(--mono);font-size:13px;color:var(--ink-dim);display:flex;gap:10px;align-items:baseline}
.amen i{color:var(--ember);font-style:normal}

/* ============================================================
   PRICE
   ============================================================ */
.price-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(12px,1.6vw,20px);margin-bottom:clamp(34px,4vw,56px)}
.ptile{border:1px solid var(--line);border-radius:3px;padding:clamp(22px,2.4vw,32px);background:var(--bg-2);transition:border-color .3s,transform .3s}
.ptile:hover{border-color:var(--ember);transform:translateY(-4px)}
.ptile.feat{border-color:var(--ember);background:linear-gradient(180deg,rgba(255,90,31,.08),transparent)}
.pt-label{font-size:11px;color:var(--ink-faint);margin-bottom:18px}
.pt-amt{font-family:var(--mono);font-weight:800;font-size:clamp(2rem,4vw,3rem);color:var(--ink);line-height:1;letter-spacing:-.01em}
.pt-amt .cur{font-size:.55em;color:var(--ember);margin-right:2px}
.pt-note{font-size:12px;color:var(--ink-dim);margin-top:14px;font-family:var(--jp)}
.price-info{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,56px);border-top:1px solid var(--line);padding-top:clamp(30px,3.5vw,44px)}
.pinfo h4{font-family:var(--mono);font-size:13px;letter-spacing:.1em;color:var(--ember);margin-bottom:14px;font-weight:700}
.pinfo p{font-size:14px;color:var(--ink-dim);line-height:1.9}

/* ============================================================
   FIRST TIME
   ============================================================ */
.firsttime{background:var(--bg-2)}
.ft-list{display:grid;grid-template-columns:repeat(2,1fr);gap:0 clamp(24px,4vw,56px);margin-bottom:clamp(30px,3.5vw,44px)}
.ft-list li{display:flex;gap:18px;align-items:baseline;font-size:clamp(15px,1.7vw,19px);color:var(--ink);padding:18px 0;border-bottom:1px solid var(--line)}
.ft-list i{font-family:var(--mono);font-style:normal;color:var(--ember);font-weight:700;font-size:13px}
.ft-close{font-family:var(--mincho);font-weight:500;font-size:clamp(1.1rem,2vw,1.5rem);color:var(--ink-dim)}

/* ============================================================
   TOURNAMENT
   ============================================================ */
.trn-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(14px,2vw,22px);margin-bottom:clamp(34px,4vw,52px)}
.trn{border:1px solid var(--line);border-radius:3px;padding:clamp(24px,3vw,38px);background:var(--bg-2);position:relative;transition:border-color .3s,transform .3s}
.trn:hover{border-color:var(--ember);transform:translateY(-4px)}
.trn-no{font-family:var(--serif);font-size:clamp(2.4rem,5vw,4rem);color:var(--ember);line-height:.8;margin-bottom:18px;opacity:.85}
.trn h3{font-family:var(--mincho);font-weight:800;font-size:clamp(1.2rem,2vw,1.6rem);margin-bottom:12px}
.trn p{font-size:14px;color:var(--ink-dim);line-height:1.8}
.trn-note{display:grid;grid-template-columns:repeat(2,1fr);gap:12px 32px}
.trn-note li{font-family:var(--mono);font-size:13px;color:var(--ink-dim);display:flex;gap:10px;align-items:baseline}
.trn-note i{color:var(--ember);font-style:normal}

/* ============================================================
   RESULT
   ============================================================ */
.result{background:linear-gradient(180deg,var(--bg),#0a0708)}
.res-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2vw,28px);margin-bottom:clamp(28px,3vw,40px)}
.res{border-top:2px solid var(--ember);padding-top:22px}
.res-num{font-family:var(--mincho);font-weight:800;font-size:clamp(2.2rem,5vw,3.6rem);line-height:1;color:var(--ink)}
.res-num .plus{color:var(--ember);font-size:.6em;margin-left:.04em}
.res-unit{font-family:var(--mono);font-size:12px;letter-spacing:.16em;color:var(--ember);margin:10px 0 14px;text-transform:uppercase}
.res-cap{font-size:13px;color:var(--ink-dim);line-height:1.7}
.res-stream{font-family:var(--mono);font-size:13px;color:var(--ink-faint);letter-spacing:.03em;border-top:1px solid var(--line);padding-top:24px}

/* ============================================================
   BUSINESS
   ============================================================ */
.business{background:var(--bg-2)}
.biz-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(14px,2vw,22px);margin-bottom:clamp(34px,4vw,52px)}
.biz{border:1px solid var(--line);border-left:2px solid var(--ember);border-radius:3px;padding:clamp(24px,3vw,36px);background:var(--bg);transition:transform .3s,background .3s}
.biz:hover{transform:translateY(-4px);background:var(--bg-3)}
.biz h3{font-family:var(--mincho);font-weight:800;font-size:clamp(1.15rem,2vw,1.5rem);margin-bottom:12px}
.biz p{font-size:14px;color:var(--ink-dim);line-height:1.85}
.biz-cta{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:24px;border-top:1px solid var(--line);padding-top:clamp(28px,3.5vw,40px)}
.biz-cta p{font-size:15px;color:var(--ink-dim);max-width:560px;line-height:1.9}

/* ============================================================
   COMMUNITY
   ============================================================ */
.com-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,2vw,22px)}
.com{border:1px solid var(--line);border-radius:3px;padding:clamp(24px,3vw,36px);background:var(--bg-2);display:flex;flex-direction:column;transition:transform .3s,border-color .3s}
.com:hover{transform:translateY(-6px);border-color:var(--ember)}
.com-tag{font-size:11px;color:var(--ink-faint);margin-bottom:18px}
.com h3{font-family:var(--mincho);font-weight:800;font-size:clamp(1.2rem,2vw,1.6rem);margin-bottom:12px}
.com p{font-size:14px;color:var(--ink-dim);line-height:1.8;margin-bottom:22px;flex:1}
.com-go{font-family:var(--mono);font-weight:700;font-size:12px;letter-spacing:.1em;color:var(--ember)}

/* ============================================================
   ACCESS
   ============================================================ */
.acc-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,56px);align-items:start}
.acc-dl{margin:clamp(24px,3vw,36px) 0 clamp(28px,3vw,40px);border-top:1px solid var(--line)}
.acc-dl>div{display:grid;grid-template-columns:120px 1fr;gap:18px;padding:16px 0;border-bottom:1px solid var(--line)}
.acc-dl dt{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--ink-faint);text-transform:uppercase;padding-top:3px}
.acc-dl dd{font-size:15px;color:var(--ink);line-height:1.7}
.acc-dl dd a{color:var(--ember)}
.acc-map{aspect-ratio:1/1.05;border:1px solid var(--line);border-radius:3px;position:relative;overflow:hidden;background:#08080a}
.acc-map iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:invert(.92) hue-rotate(185deg) brightness(.95) contrast(.9) saturate(.85)}
.acc-map::after{content:"";position:absolute;inset:0;pointer-events:none;box-shadow:inset 0 0 60px rgba(0,0,0,.5);border-radius:3px}
.map-grid{position:absolute;inset:0;background-image:linear-gradient(var(--line-2) 1px,transparent 1px),linear-gradient(90deg,var(--line-2) 1px,transparent 1px);background-size:34px 34px}
.map-pin{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--mono);font-weight:700;font-size:14px;letter-spacing:.1em;color:var(--ember);text-shadow:0 0 16px rgba(255,90,31,.6)}

/* ============================================================
   COMPANY
   ============================================================ */
.comp-table{width:100%;border-collapse:collapse;max-width:920px}
.comp-table th,.comp-table td{text-align:left;padding:16px 0;border-bottom:1px solid var(--line);vertical-align:top}
.comp-table th{font-family:var(--mono);font-size:12px;font-weight:500;letter-spacing:.08em;color:var(--ink-faint);width:200px;text-transform:none}
.comp-table td{font-size:15px;color:var(--ink)}
.comp-table td a{color:var(--ember)}

/* ============================================================
   FINAL CTA
   ============================================================ */
.finalcta{text-align:center;background:radial-gradient(80% 120% at 50% 0%,rgba(255,90,31,.12),transparent 60%),var(--bg)}
.cta-big{font-family:var(--mincho);font-weight:800;font-size:clamp(2.6rem,9vw,7rem);line-height:1;margin-bottom:clamp(34px,4vw,52px);letter-spacing:.02em}
.cta-actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-bottom:28px}
.cta-tel{font-family:var(--mono);font-size:14px;color:var(--ink-dim);letter-spacing:.04em}
.cta-tel a{color:var(--ember);font-weight:700;font-size:18px;margin:0 8px}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{border-top:1px solid var(--line);padding:clamp(48px,6vw,80px) 0 clamp(90px,8vw,40px);background:var(--bg)}
.foot-grid{display:flex;flex-wrap:wrap;justify-content:space-between;gap:32px;margin-bottom:40px}
.foot-logo{font-family:var(--dot);font-size:30px;color:var(--ink);margin-bottom:12px}
.foot-logo img{height:clamp(42px,5.2vw,58px);width:auto;display:block;margin-bottom:14px}
.foot-tag{font-family:var(--mincho);font-size:15px;color:var(--ink-dim)}
.foot-nav{display:grid;grid-template-columns:repeat(3,auto);gap:12px 32px;font-family:var(--mono);font-size:12px;letter-spacing:.12em}
.foot-nav a{color:var(--ink-dim);transition:color .25s}
.foot-nav a:hover{color:var(--ember)}
.foot-base{display:flex;justify-content:space-between;gap:16px;border-top:1px solid var(--line);padding-top:24px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--ink-faint)}

/* ============================================================
   MOBILE STICKY CTA
   ============================================================ */
.mobile-cta{position:fixed;left:0;right:0;bottom:0;z-index:980;display:none;gap:1px;background:var(--line)}
.mobile-cta a{flex:1;text-align:center;padding:16px;font-family:var(--mono);font-weight:700;font-size:13px;letter-spacing:.08em}
.mc-tel{background:var(--bg-3);color:var(--ink)}
.mc-book{background:var(--ember);color:#0a0500}

/* ============================================================
   REVEAL
   ============================================================ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}

/* power-on glitch on section titles as they reveal */
@keyframes powerOn{
  0%{clip-path:inset(46% 0 48% 0);text-shadow:.1em 0 var(--cyan),-.08em 0 var(--ember)}
  30%{clip-path:inset(10% 0 12% 0)}
  46%{clip-path:inset(0);text-shadow:-.06em 0 var(--cyan),.06em 0 var(--ember)}
  100%{clip-path:inset(0);text-shadow:none}
}
.sec-title.in{animation:powerOn .55s ease .06s both}
.cta-big{animation:chromaJit 6s infinite}
/* hover chroma on nav, pause marquee on hover */
.nav a:hover{text-shadow:.028em 0 var(--cyan),-.028em 0 var(--ember)}
.marquee:hover .marquee-track{animation-play-state:paused}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .nav{display:none}
  .header-cta{display:none}
  .burger{display:flex}
  .entry-grid,.about-cols,.title-cat,.price-info,.acc-grid,.biz-cta{grid-template-columns:1fr}
  .fac-mod{grid-template-columns:1fr;gap:28px}
  .fac-mod.rev .fac-text{order:0}
  .price-grid{grid-template-columns:repeat(2,1fr)}
  .res-grid{grid-template-columns:repeat(2,1fr)}
  .com-grid{grid-template-columns:1fr}
  .amen{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:680px){
  .mobile-cta{display:flex}
  body{padding-bottom:0}
  .hero{min-height:100svh;align-items:flex-start;padding-top:112px;padding-bottom:36px}
  .hero-img{background-image:url('../images/hero-mobile.jpg')}
  .hero .eyebrow{flex-wrap:wrap;font-size:11px;letter-spacing:.16em}
  .hero-shade{background:linear-gradient(180deg,rgba(5,5,6,.45) 0%,rgba(5,5,6,.35) 40%,rgba(5,5,6,.7) 75%,var(--bg) 100%)}
  .entry-grid,.trn-grid,.biz-grid,.ft-list,.trn-note,.price-grid{grid-template-columns:1fr}
  .title-cat{gap:36px}
  .res-grid{grid-template-columns:1fr 1fr}
  .amen{grid-template-columns:1fr}
  .hero-meta{gap:18px 28px}
  .foot-grid{flex-direction:column}
  .acc-dl>div{grid-template-columns:96px 1fr;gap:12px}
  .comp-table th{width:120px;font-size:11px}
  .site-footer{padding-bottom:90px}
  .finalcta .cta-actions{flex-direction:column}
  .finalcta .btn{width:100%;justify-content:center}
}

/* ============================================================
   SUB-PAGE COMPONENTS
   ============================================================ */
.nav a.current{color:var(--ember)}
.nav a.current::after{width:100%}
.page-hero{position:relative;padding:clamp(118px,16vh,184px) 0 clamp(46px,7vw,90px);border-bottom:1px solid var(--line);overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(70% 130% at 82% 0%,rgba(255,90,31,.16),transparent 58%);pointer-events:none}
.page-hero::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent 0,transparent 2px,rgba(0,0,0,.14) 3px,transparent 4px);pointer-events:none;opacity:.5}
.page-hero .wrap{position:relative;z-index:2}
.crumb{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--ink-faint);text-transform:uppercase;margin-bottom:26px;display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.crumb a{color:var(--ink-faint);transition:color .25s}
.crumb a:hover{color:var(--ember)}
.crumb i{color:var(--ember);font-style:normal}
.page-hero h1{font-family:var(--mincho);font-weight:800;line-height:1.04;font-size:clamp(2.5rem,7.5vw,5.6rem);letter-spacing:.01em}
.page-hero .en{font-family:var(--serif);font-style:italic;color:var(--ember);font-size:clamp(1rem,3vw,1.8rem);display:block;margin-bottom:.4em;letter-spacing:.02em;text-shadow:.012em 0 var(--cyan),-.012em 0 rgba(255,90,31,.6)}
.page-hero .lead{margin-top:26px;max-width:660px;color:var(--ink-dim);font-size:clamp(15px,1.6vw,17px);line-height:1.95;text-wrap:pretty;word-break:auto-phrase}
.page-main{padding-top:clamp(56px,7vw,96px)}

/* digest "more" link */
.more{display:inline-flex;align-items:center;gap:.55em;font-family:var(--mono);font-weight:700;font-size:13px;letter-spacing:.08em;color:var(--ember)}
.more i{font-style:normal;transition:transform .25s}
.more:hover i{transform:translateX(5px)}
.sec-foot{margin-top:clamp(26px,3.4vw,44px)}

/* compact facility digest cards */
.fac-mini{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,2vw,22px)}
.fmini{border:1px solid var(--line);border-radius:3px;padding:clamp(22px,2.6vw,32px);background:var(--bg-2);transition:border-color .3s,transform .3s}
.fmini:hover{border-color:var(--ember);transform:translateY(-4px)}
.fmini .fm-no{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--ember);margin-bottom:14px}
.fmini h3{font-family:var(--mincho);font-weight:800;font-size:clamp(1.2rem,2vw,1.5rem);margin-bottom:10px}
.fmini p{font-size:13px;color:var(--ink-dim);line-height:1.8}

/* pager (related pages) */
.pager{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;border-top:1px solid var(--line);padding-top:clamp(34px,4vw,52px);margin-top:clamp(48px,7vw,96px)}
.pager a{border:1px solid var(--line);border-radius:3px;padding:22px;transition:border-color .3s,transform .3s;display:flex;flex-direction:column;gap:10px;min-height:108px;justify-content:space-between}
.pager a:hover{border-color:var(--ember);transform:translateY(-4px)}
.pager .pg-lbl{font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--ink-faint)}
.pager .pg-name{font-family:var(--mincho);font-weight:700;font-size:clamp(15px,1.6vw,18px)}
.pager .pg-go{font-family:var(--mono);font-size:11px;color:var(--ember);letter-spacing:.08em}

/* generic prose helpers for sub-pages */
.lead-block{max-width:780px;margin-bottom:clamp(40px,5vw,72px)}
.lead-block p{font-size:clamp(15px,1.7vw,18px);color:var(--ink-dim);line-height:2;text-wrap:pretty;word-break:auto-phrase}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,64px)}
.divider{height:1px;background:var(--line);margin:clamp(48px,7vw,96px) 0}

/* about pillars */
.pillars{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,2.4vw,28px)}
.pillar{border:1px solid var(--line);border-radius:3px;padding:clamp(26px,3.2vw,44px);background:var(--bg-2);position:relative;overflow:hidden}
.pillar .p-no{font-family:var(--serif);font-style:italic;font-size:clamp(2.2rem,5vw,3.4rem);color:var(--ember);line-height:.8;margin-bottom:18px;opacity:.9}
.pillar h3{font-family:var(--mincho);font-weight:800;font-size:clamp(1.4rem,2.4vw,1.9rem);margin-bottom:14px}
.pillar p{font-size:14px;color:var(--ink-dim);line-height:1.9}

/* numbered steps */
.steps{counter-reset:s;display:grid;gap:0;border-top:1px solid var(--line);max-width:860px}
.steps li{display:grid;grid-template-columns:64px 1fr;gap:20px;padding:24px 0;border-bottom:1px solid var(--line);align-items:baseline}
.steps li::before{counter-increment:s;content:"0" counter(s);font-family:var(--mono);font-weight:700;color:var(--ember);font-size:14px;letter-spacing:.1em}
.steps h4{font-family:var(--mincho);font-weight:700;font-size:clamp(1.1rem,1.8vw,1.4rem);margin-bottom:6px}
.steps p{font-size:14px;color:var(--ink-dim);line-height:1.8}

/* contact form */
.form{display:grid;gap:20px;max-width:700px}
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--ink-faint);text-transform:uppercase}
.field input,.field textarea,.field select{background:var(--bg-2);border:1px solid var(--line);border-radius:2px;padding:14px 16px;color:var(--ink);font-family:var(--jp);font-size:15px;transition:border-color .25s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--ember)}
.field textarea{min-height:150px;resize:vertical}
.form-note{font-family:var(--mono);font-size:11px;color:var(--ink-faint);letter-spacing:.04em;line-height:1.7}

/* contact method cards */
.cmethods{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:clamp(40px,5vw,64px)}
.cmethod{border:1px solid var(--line);border-radius:3px;padding:clamp(22px,2.6vw,30px);background:var(--bg-2)}
.cmethod .cm-tag{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--ember);margin-bottom:12px}
.cmethod h3{font-family:var(--mincho);font-weight:700;font-size:1.2rem;margin-bottom:8px}
.cmethod p{font-size:13px;color:var(--ink-dim);line-height:1.7}
.cmethod a{color:var(--ember)}

@media(max-width:1024px){.fac-mini{grid-template-columns:1fr}.pager{grid-template-columns:repeat(2,1fr)}.split{grid-template-columns:1fr}.pillars{grid-template-columns:1fr}.cmethods{grid-template-columns:1fr}}
@media(max-width:680px){.pager{grid-template-columns:1fr}.steps li{grid-template-columns:48px 1fr;gap:14px}}

