/* ============================================================
   SPINNERS BAR & BOWL — design system v2 · "Electric Dive"
   ============================================================ */
:root{
  --ink:#08080a; --ink-2:#0e0e12; --ink-3:#16161c;
  --paper:#f4f1ea;
  --red:#ff2244; --red-dim:rgba(255,34,68,.55);
  --cyan:#19e3ff; --acid:#b6ff2e; --amber:#ffb300;
  --line:rgba(244,241,234,.09);
  --mut:rgba(244,241,234,.55); --mut-2:rgba(244,241,234,.34);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--ink);color:var(--paper);font-family:'Archivo',sans-serif;-webkit-font-smoothing:antialiased;overflow-x:hidden}
::selection{background:var(--red);color:#fff}
img{max-width:100%}
body::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:200;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3CfeColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.05 0'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)'/%3E%3C/svg%3E")}
h1,h2,h3,h4,.display{font-family:'Anton',sans-serif;font-weight:400;text-transform:uppercase}
.mono{font-family:'IBM Plex Mono',monospace}

/* ---------- nav ---------- */
nav.site{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;
  padding:18px 28px;transition:background .4s,border-color .4s,padding .4s;border-bottom:1px solid transparent}
nav.site.scrolled{background:rgba(8,8,10,.82);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-color:var(--line);padding:12px 28px}
nav.site .logo img{height:44px;display:block;filter:drop-shadow(0 0 12px rgba(255,34,68,.35))}
nav.site.home .logo{opacity:0;pointer-events:none;transition:opacity .4s}
nav.site.home.scrolled .logo{opacity:1;pointer-events:auto}
.nav-links{display:flex;align-items:center;gap:26px}
.nav-links a:not(.btn){color:var(--paper);text-decoration:none;font-size:12.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;opacity:.75;transition:.25s}
.nav-links a:not(.btn):hover,.nav-links a.active{opacity:1;color:var(--red)}
.hamb{display:none;background:none;border:0;cursor:pointer;z-index:110}
.hamb span{display:block;width:26px;height:2px;background:var(--paper);margin:6px 0;transition:.3s}

/* ---------- buttons ---------- */
.btn{font-family:'Anton',sans-serif;text-transform:uppercase;letter-spacing:.14em;display:inline-flex;align-items:center;gap:12px;
  background:var(--red);color:#fff;text-decoration:none;padding:15px 30px 13px;font-size:15px;line-height:1;border:0;cursor:pointer;
  position:relative;overflow:hidden;clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
  transition:box-shadow .3s,transform .15s}
.btn:hover{box-shadow:0 0 34px rgba(255,34,68,.55);transform:translateY(-1px)}
.btn:active{transform:translateY(1px)}
.btn::after{content:"";position:absolute;top:0;left:-80%;width:50%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.35),transparent);transform:skewX(-20deg);transition:left .5s}
.btn:hover::after{left:130%}
.btn.ghost{background:transparent;color:var(--paper);box-shadow:inset 0 0 0 1.5px rgba(244,241,234,.4)}
.btn.ghost:hover{box-shadow:inset 0 0 0 1.5px var(--paper),0 0 24px rgba(244,241,234,.15)}
.btn.lg{padding:19px 40px 17px;font-size:18px}

/* ---------- hero (home) ---------- */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden}
.hero video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero::before{content:"";position:absolute;inset:0;z-index:2;background:linear-gradient(to bottom,rgba(8,8,10,.55) 0%,rgba(8,8,10,.18) 38%,rgba(8,8,10,.42) 68%,rgba(8,8,10,.96) 100%)}
.hero::after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;background:radial-gradient(ellipse 120% 90% at 50% 110%,rgba(255,34,68,.16),transparent 55%)}
.hero-inner{position:relative;z-index:5;padding:110px 5vw 11vh;max-width:1500px}
.hero-brand{display:block;width:min(460px,78vw);margin:0 0 4vh -8px;opacity:0;animation:fade 1s ease .1s forwards}
.hero-brand img{width:100%;display:block;filter:drop-shadow(0 6px 24px rgba(0,0,0,.85)) drop-shadow(0 0 44px rgba(255,34,68,.45))}
.hero-eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:3.2vh;flex-wrap:wrap}
.pill{display:inline-flex;align-items:center;gap:9px;font-family:'IBM Plex Mono',monospace;font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;
  padding:8px 16px;border:1px solid var(--line);border-radius:99px;background:rgba(8,8,10,.55);backdrop-filter:blur(8px);color:var(--mut)}
.pill .dot{width:7px;height:7px;border-radius:50%;background:var(--acid);box-shadow:0 0 10px var(--acid);animation:pulse 1.8s infinite}
@keyframes pulse{50%{opacity:.4}}
.hero h2.slam{font-size:clamp(52px,8.6vw,150px);line-height:.88;letter-spacing:.005em;margin:0 0 3vh -4px}
.hero .slam .w{display:block;overflow:hidden}
.hero .slam .w i{display:inline-block;font-style:normal;transform:translateY(110%);animation:rise .9s cubic-bezier(.2,.7,.2,1) forwards}
.hero .slam .w:nth-child(1) i{animation-delay:.15s}
.hero .slam .w:nth-child(2) i{animation-delay:.28s}
.hero .slam .w:nth-child(3) i{animation-delay:.41s}
@keyframes rise{to{transform:translateY(0)}}
.hero .slam .roll{color:transparent;-webkit-text-stroke:2px var(--paper)}
.hero .slam .revel{color:var(--red);text-shadow:0 0 18px rgba(255,34,68,.55),0 0 70px rgba(255,34,68,.35)}
.hero-sub{font-size:clamp(15px,1.35vw,19px);line-height:1.55;color:var(--mut);max-width:520px;margin-bottom:4.2vh;font-weight:500;opacity:0;animation:fade .8s ease .65s forwards}
.hero-sub strong{color:var(--paper);font-weight:600}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;opacity:0;animation:fade .8s ease .8s forwards}
@keyframes fade{to{opacity:1}}
.seo-h1{font-family:'IBM Plex Mono',monospace;font-size:11px;font-weight:400;letter-spacing:.3em;text-transform:uppercase;color:rgba(244,241,234,.3);margin-bottom:14px}

/* ---------- page hero (subpages) ---------- */
.page-hero{position:relative;min-height:72svh;display:flex;align-items:flex-end;overflow:hidden}
.page-hero .bg{position:absolute;inset:0}
.page-hero .bg img{width:100%;height:100%;object-fit:cover;filter:saturate(.95)}
.page-hero::before{content:"";position:absolute;inset:0;z-index:2;background:linear-gradient(to bottom,rgba(8,8,10,.6) 0%,rgba(8,8,10,.25) 45%,rgba(8,8,10,.97) 100%)}
.page-hero::after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;background:radial-gradient(ellipse 110% 80% at 50% 110%,color-mix(in srgb,var(--ac,var(--red)) 16%,transparent),transparent 55%)}
.page-hero .inner{position:relative;z-index:5;padding:140px 5vw 8vh;max-width:1500px}
.page-hero .kicker{color:var(--ac,var(--red))}
.page-hero .kicker::before{background:var(--ac,var(--red))}
.page-hero h1{font-size:clamp(56px,9.5vw,160px);line-height:.9;margin:14px 0 20px -3px}
.page-hero h1 .ax{color:var(--ac,var(--red));text-shadow:0 0 20px color-mix(in srgb,var(--ac,var(--red)) 55%,transparent)}
.page-hero p{max-width:560px;color:var(--mut);font-size:clamp(15px,1.3vw,18px);line-height:1.6;margin-bottom:30px}
.page-hero p strong,.page-hero p a{color:var(--paper)}

/* ---------- ticker ---------- */
.ticker{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--ink);overflow:hidden;position:relative;z-index:6;padding:15px 0}
.ticker-track{display:flex;gap:44px;width:max-content;animation:tick 30s linear infinite}
.ticker:hover .ticker-track{animation-play-state:paused}
.ticker-item{font-family:'IBM Plex Mono',monospace;font-size:12.5px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--mut);display:flex;align-items:center;gap:44px;white-space:nowrap}
.ticker-item b{color:var(--red);font-weight:600}
.ticker-item::after{content:"●";color:var(--red);font-size:7px}
@keyframes tick{to{transform:translateX(-50%)}}

/* ---------- scaffolding ---------- */
section{position:relative}
.wrap{max-width:1500px;margin:0 auto;padding:0 5vw}
.kicker{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--red);display:flex;align-items:center;gap:12px;margin-bottom:18px}
.kicker::before{content:"";width:34px;height:1px;background:var(--red)}
.sec-head{display:flex;align-items:baseline;justify-content:space-between;gap:24px;margin-bottom:54px;flex-wrap:wrap}
.sec-head h2{font-size:clamp(42px,6vw,92px);line-height:.95}
.sec-head .side{font-family:'IBM Plex Mono',monospace;font-size:12.5px;color:var(--mut-2);letter-spacing:.12em;text-transform:uppercase;max-width:260px;line-height:1.8;text-align:right}
.rv{opacity:0;transform:translateY(36px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.7,.2,1)}
.rv.on{opacity:1;transform:none}

/* ---------- games grid (home) ---------- */
.games-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.game{position:relative;overflow:hidden;text-decoration:none;color:var(--paper);background:var(--ink-2);display:block;min-height:430px;border:1px solid var(--line)}
.game img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.1s cubic-bezier(.2,.7,.2,1),filter .6s;filter:saturate(.92)}
.game:hover img{transform:scale(1.06);filter:saturate(1.1)}
.game::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(8,8,10,.95) 0%,rgba(8,8,10,.25) 52%,rgba(8,8,10,.12) 100%)}
.game::after{content:"";position:absolute;inset:0;z-index:3;pointer-events:none;border:1px solid transparent;transition:.4s}
.game:hover::after{border-color:var(--ac);box-shadow:inset 0 0 60px -30px var(--ac)}
.game .tag{position:absolute;top:20px;left:20px;z-index:4;font-family:'IBM Plex Mono',monospace;font-size:11px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);background:var(--ac);padding:7px 12px 6px}
.game .body{position:absolute;left:0;right:0;bottom:0;z-index:4;padding:26px 96px 24px 26px}
.game h3{font-size:clamp(34px,3.4vw,56px);line-height:.95;margin-bottom:10px;transition:.3s}
.game:hover h3{color:var(--ac);text-shadow:0 0 26px color-mix(in srgb,var(--ac) 50%,transparent)}
.game .meta{font-family:'IBM Plex Mono',monospace;font-size:12.5px;color:var(--mut);letter-spacing:.06em;line-height:1.8}
.game .go{position:absolute;right:22px;bottom:22px;z-index:4;width:46px;height:46px;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;transition:.35s;background:rgba(8,8,10,.4);backdrop-filter:blur(6px)}
.game:hover .go{background:var(--ac);color:var(--ink);border-color:var(--ac);transform:rotate(-45deg)}
.g-7{grid-column:span 7}.g-5{grid-column:span 5}

/* ---------- statement ---------- */
.statement{font-family:'Anton',sans-serif;text-transform:uppercase;font-size:clamp(34px,4.6vw,76px);line-height:1.12;max-width:1240px}
.statement .chip{display:inline-block;width:1.7em;height:1.05em;border-radius:6px;overflow:hidden;vertical-align:-.16em;margin:0 .08em;border:1px solid var(--line)}
.statement .chip img{width:100%;height:100%;object-fit:cover}
.statement .neon{color:var(--red);text-shadow:0 0 16px var(--red-dim)}
.statement .stroke{color:transparent;-webkit-text-stroke:1.6px var(--paper)}
.vibe-foot{display:flex;gap:40px;align-items:center;margin-top:48px;flex-wrap:wrap}
.vibe-foot .stat{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--mut)}
.vibe-foot .stat b{display:block;font-family:'Anton',sans-serif;font-size:40px;color:var(--paper);letter-spacing:.02em;margin-bottom:4px}
.vibe-foot .stat:nth-child(1) b{color:var(--red)}
.vibe-foot .stat:nth-child(2) b{color:var(--cyan)}
.vibe-foot .stat:nth-child(3) b{color:var(--acid)}
.vibe-foot .stat:nth-child(4) b{color:var(--amber)}

/* ---------- polaroid strip ---------- */
.strip-wrap{margin-top:90px;position:relative}
.strip{display:flex;gap:26px;width:max-content;animation:tick 55s linear infinite;padding:30px 0}
.strip-wrap:hover .strip{animation-play-state:paused}
.polaroid{background:#101014;border:1px solid var(--line);padding:10px 10px 34px;transform:rotate(var(--r));transition:transform .4s,box-shadow .4s;position:relative;flex-shrink:0}
.polaroid:hover{transform:rotate(0) scale(1.05);z-index:5;box-shadow:0 24px 60px -20px rgba(0,0,0,.9)}
.polaroid img{display:block;height:240px;width:auto;filter:saturate(1.02)}
.polaroid span{position:absolute;bottom:9px;left:12px;font-family:'IBM Plex Mono',monospace;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--mut-2)}

/* ---------- split feature (subpages) ---------- */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;padding:70px 0}
.feature.flip .f-media{order:2}
.f-media{position:relative;border:1px solid var(--line);overflow:hidden;aspect-ratio:4/3;background:var(--ink-2)}
.f-media img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s cubic-bezier(.2,.7,.2,1)}
.feature:hover .f-media img{transform:scale(1.04)}
.f-media::after{content:"";position:absolute;inset:0;border:1px solid transparent;transition:.4s;pointer-events:none}
.feature:hover .f-media::after{border-color:color-mix(in srgb,var(--ac,var(--red)) 60%,transparent);box-shadow:inset 0 0 60px -34px var(--ac,var(--red))}
.f-body .kicker{color:var(--ac,var(--red))}
.f-body .kicker::before{background:var(--ac,var(--red))}
.f-body h2{font-size:clamp(34px,3.8vw,60px);line-height:.98;margin-bottom:22px}
.f-body p{color:var(--mut);font-size:16px;line-height:1.75;margin-bottom:18px;max-width:520px}
.f-body p strong{color:var(--paper)}
.f-body p a{color:var(--ac,var(--red));text-decoration:none;border-bottom:1px solid color-mix(in srgb,var(--ac,var(--red)) 40%,transparent)}
.f-body .btn{margin-top:10px}

/* ---------- pricing ---------- */
.price-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:18px;margin:0 0 18px}
.price-card{border:1px solid var(--line);background:var(--ink-2);padding:34px 30px;position:relative;transition:.3s}
.price-card:hover{border-color:color-mix(in srgb,var(--ac,var(--red)) 55%,transparent);box-shadow:0 0 40px -18px var(--ac,var(--red));transform:translateY(-3px)}
.price-card .pc-tag{font-family:'IBM Plex Mono',monospace;font-size:10.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--ac,var(--red));margin-bottom:8px}
.price-card h3{font-size:30px;margin-bottom:18px}
.price-row{display:flex;align-items:baseline;justify-content:space-between;padding:13px 0;border-bottom:1px dashed rgba(244,241,234,.13)}
.price-row:last-child{border-bottom:0}
.price-row .amt{font-family:'Anton',sans-serif;font-size:38px;color:var(--paper)}
.price-row .lbl{font-family:'IBM Plex Mono',monospace;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--mut)}
.price-card .pc-note{font-family:'IBM Plex Mono',monospace;font-size:11.5px;color:var(--mut-2);line-height:1.8;margin-top:14px;letter-spacing:.04em}
.price-card.hot{border-color:rgba(255,34,68,.5)}
.price-card.hot::before{content:"MOST POPULAR";position:absolute;top:-11px;left:24px;font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.22em;background:var(--red);color:#fff;padding:5px 10px 4px}
.price-banner{border:1px solid rgba(255,34,68,.4);background:linear-gradient(120deg,rgba(255,34,68,.12),transparent 60%);padding:26px 30px;display:flex;gap:24px;align-items:baseline;flex-wrap:wrap;margin-bottom:18px}
.price-banner b{font-family:'Anton',sans-serif;font-size:clamp(18px,2vw,26px);letter-spacing:.06em;text-transform:uppercase;color:var(--red);text-shadow:0 0 12px rgba(255,34,68,.45)}
.price-banner span{font-family:'IBM Plex Mono',monospace;font-size:13px;color:var(--mut);letter-spacing:.06em}
.extras{display:flex;gap:14px;flex-wrap:wrap}
.extra{font-family:'IBM Plex Mono',monospace;font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--mut);border:1px solid var(--line);padding:12px 18px}
.extra b{color:var(--paper);font-weight:600}

/* ---------- steps / chips / icon-row ---------- */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.step{border:1px solid var(--line);background:var(--ink-2);padding:34px 30px}
.step .num{font-family:'Anton',sans-serif;font-size:46px;color:transparent;-webkit-text-stroke:1.5px var(--red);margin-bottom:14px;display:block}
.step h3{font-size:22px;margin-bottom:12px}
.step p{color:var(--mut);font-size:14.5px;line-height:1.7}
.chips{display:flex;gap:12px;flex-wrap:wrap}
.chips .chip-t{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.18em;text-transform:uppercase;border:1px solid var(--line);color:var(--mut);padding:11px 18px;transition:.25s}
.chips .chip-t:hover{border-color:var(--red);color:var(--paper)}
.icon-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:18px}
.icon-cell{border:1px solid var(--line);background:var(--ink-2);text-align:center;padding:30px 16px}
.icon-cell .em{font-size:34px;display:block;margin-bottom:12px}
.icon-cell h3{font-size:19px;letter-spacing:.06em}
.icon-cell p{font-family:'IBM Plex Mono',monospace;font-size:11.5px;color:var(--mut-2);margin-top:8px;line-height:1.7}

/* ---------- big red button ---------- */
.redbtn-banner{text-align:center;padding:90px 5vw;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:radial-gradient(ellipse 60% 100% at 50% 0%,rgba(255,34,68,.1),transparent)}
.redbtn-banner .dot-big{width:74px;height:74px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#ff5c75,var(--red) 60%,#a3001d);box-shadow:0 0 50px rgba(255,34,68,.7),0 10px 24px rgba(0,0,0,.6);margin:0 auto 26px;animation:pulse 2.2s infinite}
.redbtn-banner h2{font-size:clamp(34px,4.5vw,64px);margin-bottom:18px}
.redbtn-banner p{max-width:620px;margin:0 auto 12px;color:var(--mut);line-height:1.75;font-size:16px}
.redbtn-banner p strong{color:var(--paper)}

/* ---------- SEO text block ---------- */
.seo-block{padding:90px 0;border-top:1px solid var(--line)}
.seo-block h2{font-size:clamp(26px,2.8vw,40px);margin-bottom:24px;color:var(--paper)}
.seo-block p{color:var(--mut);font-size:15.5px;line-height:1.9;max-width:860px;margin-bottom:18px}
.seo-block a{color:var(--red);text-decoration:none;border-bottom:1px solid rgba(255,34,68,.3)}

/* ---------- CTA banner ---------- */
.cta-banner{text-align:center;padding:110px 5vw;position:relative;overflow:hidden;border-top:1px solid var(--line)}
.cta-banner::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 70% 90% at 50% 100%,rgba(255,34,68,.14),transparent 60%)}
.cta-banner h2{font-size:clamp(44px,6.5vw,100px);line-height:.95;margin-bottom:18px;position:relative}
.cta-banner p{color:var(--mut);font-size:16.5px;margin-bottom:34px;position:relative}
.cta-banner .btn{position:relative}

/* ---------- parties banner (home) ---------- */
.takeover{margin:60px 0 0;position:relative;overflow:hidden;min-height:560px;display:flex;align-items:center}
.takeover .bg{position:absolute;inset:0}
.takeover .bg img{width:100%;height:100%;object-fit:cover;filter:saturate(1.05)}
.takeover .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(8,8,10,.95) 25%,rgba(8,8,10,.55) 60%,rgba(255,34,68,.18) 100%)}
.takeover .wrap{position:relative;z-index:2;padding-top:90px;padding-bottom:90px}
.takeover h2{font-size:clamp(46px,6.4vw,104px);line-height:.93;margin-bottom:22px}
.takeover h2 em{font-style:normal;color:var(--amber);text-shadow:0 0 24px rgba(255,179,0,.4)}
.takeover p{max-width:480px;color:var(--mut);font-size:16.5px;line-height:1.65;margin-bottom:36px}
.takeover p strong{color:var(--paper)}

/* ---------- plan / panels ---------- */
.plan-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:18px}
.panel{border:1px solid var(--line);background:var(--ink-2);padding:42px}
.panel h3{font-size:clamp(30px,2.6vw,44px);line-height:1}
.hours-table{width:100%;border-collapse:collapse;margin-top:26px}
.hours-table td{font-family:'IBM Plex Mono',monospace;font-size:14px;letter-spacing:.1em;text-transform:uppercase;padding:15px 0;border-bottom:1px dashed rgba(244,241,234,.13);color:var(--mut)}
.hours-table td:last-child{text-align:right;color:var(--paper);font-weight:500}
.hours-table tr.today td{color:var(--paper)}
.hours-table tr.today td:first-child::after{content:"● TONIGHT";color:var(--acid);font-size:10px;margin-left:12px;letter-spacing:.2em}
.addr{font-family:'IBM Plex Mono',monospace;font-size:13.5px;line-height:2.1;letter-spacing:.08em;color:var(--mut);margin:24px 0 30px;text-transform:uppercase}
.addr b{color:var(--paper);font-weight:500}
.map{height:280px;border:1px solid var(--line);filter:grayscale(1) invert(.92) contrast(.9);margin-top:8px}
.map iframe{width:100%;height:100%;border:0}
.contact-line{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}

/* ---------- chat widget (events) ---------- */
.chatbot{border:1px solid rgba(255,34,68,.4);background:var(--ink-2);max-width:760px;margin:0 auto;display:flex;flex-direction:column;height:560px;box-shadow:0 0 60px -20px rgba(255,34,68,.35)}
.chat-head{padding:18px 24px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px}
.chat-head .dot{width:9px;height:9px;border-radius:50%;background:var(--acid);box-shadow:0 0 10px var(--acid);animation:pulse 1.8s infinite}
.chat-head span{font-family:'IBM Plex Mono',monospace;font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--mut)}
#chat-messages{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:14px}
.msg{max-width:82%;padding:13px 17px;font-size:14.5px;line-height:1.65;white-space:pre-wrap}
.msg.bot{background:var(--ink-3);border:1px solid var(--line);align-self:flex-start;color:var(--paper)}
.msg.user{background:var(--red);color:#fff;align-self:flex-end;clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px)}
.msg.loading{color:var(--mut);font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.2em}
.chat-input-area{display:flex;border-top:1px solid var(--line)}
#chat-input{flex:1;background:transparent;border:0;padding:18px 22px;color:var(--paper);font-family:'Archivo',sans-serif;font-size:15px;outline:none}
#chat-input::placeholder{color:var(--mut-2)}
#chat-send{background:var(--red);color:#fff;border:0;padding:0 30px;font-family:'Anton',sans-serif;letter-spacing:.14em;font-size:14px;cursor:pointer;text-transform:uppercase;transition:.25s}
#chat-send:hover{box-shadow:0 0 24px rgba(255,34,68,.5)}

/* ---------- menu (food) ---------- */
.menu-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:18px}
.menu-cat{border:1px solid var(--line);background:var(--ink-2);padding:36px 32px}
.menu-cat h3{font-size:26px;margin-bottom:6px;color:var(--ac,var(--paper))}
.menu-cat .cat-note{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--mut-2);margin-bottom:20px}
.food-item{display:flex;justify-content:space-between;gap:16px;align-items:baseline;padding:11px 0;border-bottom:1px dashed rgba(244,241,234,.1)}
.food-item:last-child{border-bottom:0}
.food-item .fi-name{font-size:15px;font-weight:500}
.food-item .fi-sub{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--mut-2);display:block;margin-top:3px;letter-spacing:.04em}
.food-item .fi-price{font-family:'Anton',sans-serif;font-size:19px;color:var(--red);white-space:nowrap}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line);padding:80px 0 120px;position:relative;overflow:hidden}
.foot-grid{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;align-items:flex-start}
footer .logo-big img{width:min(420px,70vw);opacity:.95;filter:drop-shadow(0 0 30px rgba(255,34,68,.25))}
.foot-col{font-family:'IBM Plex Mono',monospace;font-size:12.5px;line-height:2.4;letter-spacing:.1em;text-transform:uppercase;color:var(--mut)}
.foot-col a{color:var(--mut);text-decoration:none;transition:.25s}
.foot-col a:hover{color:var(--red)}
.foot-col h4{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--mut-2);letter-spacing:.3em;margin-bottom:12px}
.socials{display:flex;gap:14px;margin-top:10px}
.socials a{width:42px;height:42px;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--mut);transition:.25s}
.socials a:hover{color:#fff;border-color:var(--red);box-shadow:0 0 18px rgba(255,34,68,.4)}
.fine{margin-top:70px;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;font-family:'IBM Plex Mono',monospace;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--mut-2)}
.fine a{color:var(--mut-2);text-decoration:none}
.fine a:hover{color:var(--red)}

/* ---------- sticky book ---------- */
.sticky-book{position:fixed;left:16px;right:16px;bottom:16px;z-index:90;display:none;text-align:center;justify-content:center;box-shadow:0 10px 40px rgba(255,34,68,.45)}

/* ---------- booking overlay ---------- */
.overlay{position:fixed;inset:0;z-index:300;background:rgba(8,8,10,.88);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:.35s}
.overlay.active{opacity:1;pointer-events:auto}
.overlay .box{background:linear-gradient(160deg,#15151b,#0b0b0e 60%);border:1px solid rgba(255,34,68,.5);padding:52px 44px 44px;width:min(560px,92vw);
  position:relative;text-align:center;transform:scale(.9) translateY(30px);opacity:0;transition:.45s cubic-bezier(.18,1.1,.3,1);
  clip-path:polygon(22px 0,100% 0,100% calc(100% - 22px),calc(100% - 22px) 100%,0 100%,0 22px);
  box-shadow:0 0 80px -10px rgba(255,34,68,.45),0 40px 80px -30px rgba(0,0,0,.9)}
.overlay .box::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 90% 50% at 50% 0%,rgba(255,34,68,.14),transparent 60%)}
.overlay.active .box{transform:none;opacity:1}
.overlay .box h3{font-size:clamp(44px,6vw,58px);line-height:1;margin-bottom:8px;color:#fff;text-shadow:0 0 22px rgba(255,34,68,.8),0 0 70px rgba(255,34,68,.45)}
.overlay .box .sub{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.34em;color:var(--red);text-transform:uppercase;margin-bottom:38px}
.overlay .box .sub::before,.overlay .box .sub::after{content:"—";margin:0 10px;color:var(--mut-2)}
.overlay .box .opts{display:flex;flex-direction:column;gap:12px}
.overlay .box .opt{font-family:'Anton',sans-serif;text-transform:uppercase;letter-spacing:.1em;font-size:clamp(19px,2.4vw,23px);
  background:rgba(244,241,234,.03);border:1px solid var(--line);border-left:4px solid var(--ac);color:var(--paper);text-decoration:none;
  padding:19px 22px;transition:.22s;display:flex;align-items:center;justify-content:space-between;gap:14px;text-align:left;cursor:pointer;
  opacity:0;transform:translateX(-18px)}
.overlay.active .opt{opacity:1;transform:none;transition:opacity .4s ease,transform .4s cubic-bezier(.2,.9,.3,1),border-color .22s,background .22s,box-shadow .22s,color .22s}
.overlay.active .opt:nth-child(1){transition-delay:.12s,.12s,0s,0s,0s,0s}
.overlay.active .opt:nth-child(2){transition-delay:.2s,.2s,0s,0s,0s,0s}
.overlay.active .opt:nth-child(3){transition-delay:.28s,.28s,0s,0s,0s,0s}
.overlay.active .opt:nth-child(4){transition-delay:.36s,.36s,0s,0s,0s,0s}
.overlay .box .opt::after{content:"→";font-family:'Archivo',sans-serif;font-weight:700;font-size:22px;color:var(--ac);transition:transform .22s;flex-shrink:0}
.overlay .box .opt:hover{border-color:var(--ac);background:color-mix(in srgb,var(--ac) 10%,transparent);box-shadow:0 0 34px -8px var(--ac),inset 0 0 24px -16px var(--ac);color:#fff;transform:translateX(6px)}
.overlay .box .opt:hover::after{transform:translateX(5px)}
.overlay .close{position:absolute;top:14px;right:18px;background:none;border:0;color:var(--mut);font-size:30px;cursor:pointer;line-height:1;z-index:5}
.overlay .close:hover{color:var(--paper)}
.overlay .frame-wrap{display:none;width:min(920px,94vw);height:min(82vh,760px);position:relative;background:#fff}
.overlay .frame-wrap iframe{width:100%;height:100%;border:0}
.overlay .frame-wrap .close{color:#333}

/* ---------- responsive ---------- */
@media(max-width:1020px){
  .g-7,.g-5{grid-column:span 12}
  .game{min-height:380px}
  .plan-grid{grid-template-columns:1fr}
  .sec-head .side{display:none}
  .feature{grid-template-columns:1fr;gap:30px;padding:50px 0}
  .feature.flip .f-media{order:0}
}
@media(max-width:760px){
  .nav-links{position:fixed;inset:0;background:rgba(8,8,10,.97);flex-direction:column;justify-content:center;gap:30px;transform:translateX(100%);transition:.4s;z-index:105}
  .nav-links.open{transform:none}
  .nav-links a:not(.btn){font-size:20px}
  .hamb{display:block;position:relative;z-index:110}
  .hamb.x span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  .hamb.x span:nth-child(2){opacity:0}
  .hamb.x span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
  .hero-inner{padding-bottom:13vh}
  .hero-brand{width:min(380px,86vw);margin:0 auto 3.5vh}
  .hero-eyebrow .pill:last-child{display:none}
  .vibe-foot{gap:26px}
  .vibe-foot .stat b{font-size:32px}
  .sticky-book{display:flex}
  footer{padding-bottom:160px}
  .panel{padding:30px 22px}
  .overlay .box{padding:42px 24px 34px}
  .overlay .box .opt{font-size:17px;padding:17px 16px;white-space:nowrap}
  .chatbot{height:70vh}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}
