/* ============================================================
   CEDAR HORIZONS — Luxury Swiss Night Edition
   Design system. Prefix: chz-  | Fonts: Sora / Manrope / IBM Plex Mono
   ============================================================ */

:root{
  --chz-void:#070b12; --chz-graphite:#0e1521; --chz-surface:#131c2b; --chz-surface-2:#172234;
  --chz-line:rgba(120,170,255,.14); --chz-line-2:rgba(120,170,255,.22); --chz-line-3:rgba(120,170,255,.34);
  --chz-cyan:#22e0d6; --chz-blue:#3f82ff; --chz-red:#ff3b40; --chz-plat:#cbb888;
  --chz-text:#eaf1fb; --chz-muted:#93a3bd; --chz-dim:#647795;
  --chz-glow:0 0 0 1px rgba(34,224,214,.18),0 24px 60px rgba(0,0,0,.5);
  --chz-shadow:0 22px 60px rgba(0,0,0,.45);
  --chz-grad:linear-gradient(120deg,#3f82ff,#22e0d6);
  --chz-radius:18px;
  --chz-mono:'IBM Plex Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  --chz-display:'Sora',system-ui,sans-serif;
  --chz-body:'Manrope',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}

/* ---------- base ---------- */
body{font-family:var(--chz-body);background:var(--chz-void);color:var(--chz-text)}
p{margin:0 0 14px}
.chz-container{max-width:1200px;margin:0 auto;padding:0 24px}
.chz-narrow{max-width:860px}
:focus-visible{outline:2px solid var(--chz-cyan);outline-offset:3px;border-radius:4px}

/* section rhythm */
.chz-section{padding:96px 0;position:relative}
.chz-section--tight{padding:68px 0}
.chz-section--alt{background:linear-gradient(180deg,#0a111c,#070b12)}
.chz-section--panel{background:var(--chz-graphite);border-top:1px solid var(--chz-line);border-bottom:1px solid var(--chz-line)}
.chz-head-block{max-width:660px;margin-bottom:46px}
.chz-head-block.center{margin-left:auto;margin-right:auto;text-align:center}

/* eyebrow + ridge marker (signature structural device) */
.chz-eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--chz-mono);font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--chz-cyan);margin-bottom:16px}
.chz-eyebrow::before{content:"";width:26px;height:1px;background:linear-gradient(90deg,transparent,var(--chz-cyan));display:inline-block}
.chz-head-block.center .chz-eyebrow{justify-content:center}
.chz-h2{font-family:var(--chz-display);font-size:clamp(28px,3.6vw,44px);font-weight:700}
.chz-lead{color:var(--chz-muted);font-size:18px;margin-top:14px}

/* ---------- buttons ---------- */
.chz-btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--chz-body);font-weight:600;font-size:15.5px;padding:13px 24px;border-radius:13px;border:1px solid transparent;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,background .16s ease,border-color .16s ease;text-align:center;line-height:1}
.chz-btn-primary{background:var(--chz-grad);color:#04121a;box-shadow:0 12px 30px rgba(34,224,214,.22)}
.chz-btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 42px rgba(34,224,214,.34);color:#04121a}
.chz-btn-ghost{background:rgba(120,170,255,.05);color:var(--chz-text);border-color:var(--chz-line-2)}
.chz-btn-ghost:hover{transform:translateY(-2px);border-color:var(--chz-line-3);background:rgba(120,170,255,.1)}
.chz-btn-red{background:var(--chz-red);color:#fff}
.chz-btn-red:hover{transform:translateY(-2px);filter:brightness(1.05);color:#fff}
.chz-btn-lg{padding:16px 30px;font-size:16.5px}
.chz-btn-sm{padding:9px 16px;font-size:14px}
.chz-btn:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}
.chz-btn-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:26px}

/* ---------- mobile nav panel ---------- */
.chz-mobile{display:none;flex-direction:column;padding:10px 24px 20px;background:rgba(7,11,18,.96);border-bottom:1px solid var(--chz-line)}
.chz-mobile[hidden]{display:none}
.chz-mobile.open{display:flex}
.chz-mobile a{padding:12px 4px;color:var(--chz-muted);border-bottom:1px solid var(--chz-line);font-weight:500}
.chz-mobile a:hover{color:var(--chz-text)}

/* ---------- hero ---------- */
.chz-hero{position:relative;overflow:hidden;padding:118px 0 96px;border-bottom:1px solid var(--chz-line)}
.chz-hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none}
.chz-aurora{position:absolute;left:50%;top:-22%;width:1100px;height:680px;transform:translateX(-50%);
  background:radial-gradient(50% 55% at 50% 40%,rgba(34,224,214,.18),transparent 70%),radial-gradient(40% 45% at 30% 35%,rgba(63,130,255,.2),transparent 72%);
  filter:blur(20px);animation:chz-drift 16s ease-in-out infinite alternate}
@keyframes chz-drift{from{transform:translateX(-52%) translateY(0)}to{transform:translateX(-48%) translateY(26px)}}
.chz-hero-ridge{position:absolute;left:0;right:0;bottom:-2px;z-index:1}
.chz-hero-ridge svg{width:100%;height:auto;display:block}
.chz-stars{position:absolute;inset:0;background-image:radial-gradient(1px 1px at 20% 30%,rgba(255,255,255,.5),transparent),radial-gradient(1px 1px at 70% 20%,rgba(255,255,255,.35),transparent),radial-gradient(1px 1px at 45% 55%,rgba(255,255,255,.3),transparent),radial-gradient(1px 1px at 85% 45%,rgba(255,255,255,.4),transparent),radial-gradient(1px 1px at 12% 60%,rgba(255,255,255,.25),transparent);opacity:.7}
.chz-hero-in{position:relative;z-index:2;max-width:760px}
.chz-hero h1{font-family:var(--chz-display);font-weight:800;font-size:clamp(40px,6vw,72px);letter-spacing:-.03em}
.chz-hero h1 .glow{background:var(--chz-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.chz-hero .sub{font-size:clamp(17px,2vw,21px);color:var(--chz-muted);margin:20px 0 6px;max-width:48ch}
.chz-hero-rail{display:flex;gap:30px;flex-wrap:wrap;margin-top:40px;padding-top:26px;border-top:1px solid var(--chz-line)}
.chz-hero-rail .item{font-family:var(--chz-mono)}
.chz-hero-rail .num{font-size:24px;color:var(--chz-text);font-weight:600}
.chz-hero-rail .lbl{display:block;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--chz-dim);margin-top:4px}

/* ---------- index / stat rail ---------- */
.chz-index{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--chz-line);border:1px solid var(--chz-line);border-radius:var(--chz-radius);overflow:hidden}
.chz-index .cell{background:var(--chz-graphite);padding:30px 26px}
.chz-index .v{font-family:var(--chz-mono);font-size:30px;font-weight:600;color:var(--chz-cyan)}
.chz-index .k{display:block;margin-top:8px;color:var(--chz-muted);font-size:14.5px}
.chz-index .d{display:block;margin-top:4px;color:var(--chz-dim);font-size:13px}

/* ---------- bento showcase ---------- */
.chz-bento{display:grid;grid-template-columns:1.4fr 1fr;grid-auto-rows:1fr;gap:18px}
.chz-show{position:relative;border-radius:22px;overflow:hidden;border:1px solid var(--chz-line-2);background:var(--chz-surface);padding:34px;display:flex;flex-direction:column;justify-content:flex-end;min-height:300px;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}
.chz-show::before{content:"";position:absolute;inset:0 0 auto 0;height:2px;background:var(--chz-grad);opacity:.85}
.chz-show::after{content:"";position:absolute;inset:0;background:radial-gradient(80% 90% at 80% 0%,rgba(34,224,214,.12),transparent 60%);z-index:0}
.chz-show:hover{transform:translateY(-4px);border-color:var(--chz-line-3);box-shadow:var(--chz-glow)}
.chz-show>*{position:relative;z-index:1}
.chz-show .kind{font-family:var(--chz-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--chz-cyan)}
.chz-show h3{font-family:var(--chz-display);font-size:27px;font-weight:700;margin:12px 0 8px}
.chz-show p{color:var(--chz-muted);max-width:42ch}
.chz-show .emoji{position:absolute;top:26px;right:30px;font-size:46px;filter:drop-shadow(0 8px 20px rgba(0,0,0,.5));opacity:.9}
.chz-show--tall{grid-row:span 2;min-height:420px}

/* ---------- generic cards / grids ---------- */
.chz-grid{display:grid;gap:18px}
.chz-grid-2{grid-template-columns:repeat(2,1fr)}
.chz-grid-3{grid-template-columns:repeat(3,1fr)}
.chz-grid-4{grid-template-columns:repeat(4,1fr)}
.chz-card{background:var(--chz-surface);border:1px solid var(--chz-line);border-radius:var(--chz-radius);padding:28px;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}
.chz-card:hover{transform:translateY(-3px);border-color:var(--chz-line-2);box-shadow:var(--chz-shadow)}
.chz-card .ic{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;background:rgba(34,224,214,.08);border:1px solid var(--chz-line-2);margin-bottom:16px}
.chz-card h3{font-family:var(--chz-display);font-size:19px;font-weight:600;margin-bottom:8px}
.chz-card p{color:var(--chz-muted);margin:0;font-size:15px}

/* split panel */
.chz-split{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center}
.chz-split.rev .col-text{order:2}
.chz-feat{list-style:none;margin:22px 0 0;padding:0;display:grid;gap:14px}
.chz-feat li{display:flex;gap:12px;color:var(--chz-muted)}
.chz-feat li::before{content:"";flex:0 0 auto;width:20px;height:20px;margin-top:2px;border-radius:6px;background:rgba(34,224,214,.12);border:1px solid var(--chz-line-2);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 20 20'%3E%3Cpath d='M5 10.5l3 3 7-7' fill='none' stroke='%2322e0d6' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")}
.chz-feat li b{color:var(--chz-text);font-weight:600}

/* glass panel (used for credits + lounge visual) */
.chz-glass{position:relative;border-radius:22px;border:1px solid var(--chz-line-2);background:linear-gradient(160deg,rgba(23,34,52,.9),rgba(14,21,33,.9));padding:34px;overflow:hidden}
.chz-glass::before{content:"";position:absolute;inset:0;background:radial-gradient(70% 80% at 100% 0%,rgba(63,130,255,.16),transparent 60%)}
.chz-glass>*{position:relative}
.chz-meter{font-family:var(--chz-mono);background:#04070d;border:1px solid var(--chz-line-2);border-radius:14px;padding:20px 22px;margin-top:18px}
.chz-meter .row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px dashed var(--chz-line)}
.chz-meter .row:last-child{border-bottom:0}
.chz-meter .lab{color:var(--chz-muted);font-size:13px}
.chz-meter .val{color:var(--chz-cyan);font-size:16px}

/* numbered editorial (Swiss design philosophy — a real sequence) */
.chz-steps{counter-reset:chz;display:grid;gap:0;border:1px solid var(--chz-line);border-radius:var(--chz-radius);overflow:hidden}
.chz-steps .step{counter-increment:chz;display:grid;grid-template-columns:84px 1fr;gap:18px;padding:28px 30px;background:var(--chz-graphite);border-bottom:1px solid var(--chz-line)}
.chz-steps .step:last-child{border-bottom:0}
.chz-steps .step::before{content:counter(chz,decimal-leading-zero);font-family:var(--chz-mono);font-size:22px;color:var(--chz-cyan);opacity:.8}
.chz-steps .step h3{font-family:var(--chz-display);font-size:19px;font-weight:600;margin-bottom:6px}
.chz-steps .step p{color:var(--chz-muted);margin:0}

/* trust / CTA band */
.chz-band{position:relative;border-radius:26px;overflow:hidden;padding:56px;text-align:center;border:1px solid var(--chz-line-2);background:linear-gradient(130deg,#0c1830,#0a1422)}
.chz-band::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 90% at 50% 0%,rgba(34,224,214,.16),transparent 60%)}
.chz-band>*{position:relative}
.chz-band h2{font-family:var(--chz-display);font-size:clamp(26px,3.4vw,40px);font-weight:700}
.chz-band p{color:var(--chz-muted);max-width:54ch;margin:14px auto 0}

/* callout / faq / noscript */
.chz-callout{background:var(--chz-surface);border:1px solid var(--chz-line-2);border-left:3px solid var(--chz-red);border-radius:14px;padding:20px 24px;margin:26px 0}
.chz-callout p:last-child{margin:0}
.chz-callout.cyan{border-left-color:var(--chz-cyan)}
.chz-faq{border:1px solid var(--chz-line);border-radius:14px;background:var(--chz-surface);margin-bottom:12px;overflow:hidden}
.chz-faq summary{cursor:pointer;padding:18px 22px;font-family:var(--chz-display);font-weight:600;color:var(--chz-text);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px}
.chz-faq summary::-webkit-details-marker{display:none}
.chz-faq summary::after{content:"+";color:var(--chz-cyan);font-size:22px}
.chz-faq[open] summary::after{content:"\2013"}
.chz-faq .a{padding:0 22px 20px;color:var(--chz-muted)}
.chz-noscript{background:rgba(255,59,64,.1);border:1px solid rgba(255,59,64,.3);color:#ffd7d8;border-radius:12px;padding:14px 18px;margin:0 auto 0;max-width:1152px}

/* ---------- prose / legal ---------- */
.chz-prose-hero{padding:96px 0 56px;border-bottom:1px solid var(--chz-line);background:linear-gradient(180deg,#0a111c,#070b12)}
.chz-prose-hero h1{font-family:var(--chz-display);font-weight:700;font-size:clamp(32px,4.6vw,52px)}
.chz-prose-hero p{color:var(--chz-muted);font-size:19px;max-width:60ch;margin:14px 0 0}
.chz-prose{max-width:820px;margin:0 auto;padding:64px 24px}
.chz-prose h2{font-family:var(--chz-display);font-size:25px;font-weight:600;margin:42px 0 12px}
.chz-prose h3{font-family:var(--chz-display);font-size:18px;font-weight:600;margin:28px 0 8px}
.chz-prose p,.chz-prose li{color:#bccadf}
.chz-prose a{color:var(--chz-cyan);text-decoration:underline;text-underline-offset:3px}
.chz-prose ul{margin:0 0 16px;padding-left:22px}
.chz-prose li{margin-bottom:8px}
.chz-prose strong{color:var(--chz-text)}
.chz-prose .updated{font-family:var(--chz-mono);font-size:13px;color:var(--chz-dim);margin-bottom:6px}

/* ============================================================
   GAME 1 — GLACIER FORTUNE REELS
   ============================================================ */
.chz-game-wrap{display:grid;grid-template-columns:1.5fr 1fr;gap:24px;align-items:start}
.chz-machine{background:linear-gradient(180deg,#0c1626,#070d18);border:1px solid var(--chz-line-2);border-radius:24px;padding:28px;box-shadow:var(--chz-shadow);position:relative;overflow:hidden}
.chz-machine::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:var(--chz-grad)}
.chz-reels{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;background:#04070d;border:1px solid var(--chz-line-2);border-radius:18px;padding:16px;position:relative}
.chz-payline{position:absolute;left:10px;right:10px;top:50%;height:2px;background:linear-gradient(90deg,transparent,rgba(34,224,214,.7),transparent);transform:translateY(-50%);opacity:0;transition:opacity .3s}
.chz-payline.on{opacity:1}
.chz-reel{height:240px;overflow:hidden;border-radius:12px;background:linear-gradient(180deg,#0a1220,#0e1828);border:1px solid var(--chz-line);position:relative}
.chz-reel-strip{display:flex;flex-direction:column;transition:transform .1s linear}
.chz-cell{height:80px;display:flex;align-items:center;justify-content:center;font-size:44px;flex:0 0 80px}
.chz-reel::before,.chz-reel::after{content:"";position:absolute;left:0;right:0;height:60px;z-index:2;pointer-events:none}
.chz-reel::before{top:0;background:linear-gradient(180deg,#0a1220,transparent)}
.chz-reel::after{bottom:0;background:linear-gradient(0deg,#0e1828,transparent)}
.chz-reel.win{box-shadow:0 0 0 1px var(--chz-cyan),0 0 24px rgba(34,224,214,.35)}
.chz-machine-msg{min-height:26px;text-align:center;font-family:var(--chz-mono);font-size:15px;color:var(--chz-cyan);margin:16px 0 4px}
.chz-machine-msg.big{color:var(--chz-plat)}
.chz-controls{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:10px}
.chz-bet{display:flex;align-items:center;gap:10px}
.chz-bet button{width:40px;height:40px;border-radius:10px;border:1px solid var(--chz-line-2);background:var(--chz-surface);color:var(--chz-text);font-size:20px;cursor:pointer}
.chz-bet button:hover{border-color:var(--chz-line-3)}
.chz-bet .bv{font-family:var(--chz-mono);min-width:70px;text-align:center;color:var(--chz-text)}
.chz-bet .bl{font-family:var(--chz-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--chz-dim)}
.chz-spin{flex:1;min-width:160px}

.chz-sidepanel{display:grid;gap:18px}
.chz-balance{background:var(--chz-surface);border:1px solid var(--chz-line-2);border-radius:18px;padding:24px}
.chz-balance .lab{font-family:var(--chz-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--chz-dim)}
.chz-balance .amt{font-family:var(--chz-mono);font-size:38px;font-weight:600;color:var(--chz-cyan);margin:6px 0 14px}
.chz-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--chz-line);border:1px solid var(--chz-line);border-radius:14px;overflow:hidden}
.chz-stats .s{background:var(--chz-graphite);padding:16px 18px}
.chz-stats .s .v{font-family:var(--chz-mono);font-size:22px;color:var(--chz-text)}
.chz-stats .s .k{font-size:12.5px;color:var(--chz-muted)}
.chz-paytable{background:var(--chz-surface);border:1px solid var(--chz-line);border-radius:18px;padding:22px 24px}
.chz-paytable h3{font-family:var(--chz-display);font-size:16px;margin-bottom:12px}
.chz-paytable .pt{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px dashed var(--chz-line);font-family:var(--chz-mono);font-size:14px}
.chz-paytable .pt:last-child{border-bottom:0}
.chz-paytable .pt .sym{font-size:18px}
.chz-paytable .pt .x{color:var(--chz-cyan)}

/* ============================================================
   GAME 2 — ALPINE PRESTIGE BLACKJACK
   ============================================================ */
.chz-table{background:radial-gradient(120% 100% at 50% 0%,#10362f,#0a1f1c 55%,#070d12);border:1px solid var(--chz-line-2);border-radius:24px;padding:30px;box-shadow:var(--chz-shadow);position:relative;overflow:hidden}
.chz-table::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:linear-gradient(90deg,var(--chz-plat),var(--chz-cyan))}
.chz-felt-label{font-family:var(--chz-mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:rgba(203,184,136,.85);text-align:center;margin-bottom:4px}
.chz-felt-sub{text-align:center;color:rgba(234,241,251,.55);font-size:13px;margin-bottom:22px}
.chz-hand{margin:14px 0}
.chz-hand .htitle{display:flex;justify-content:space-between;align-items:center;font-family:var(--chz-mono);font-size:13px;color:rgba(234,241,251,.7);margin-bottom:10px;text-transform:uppercase;letter-spacing:.12em}
.chz-hand .hval{color:var(--chz-cyan);font-size:16px}
.chz-cards{display:flex;gap:10px;flex-wrap:wrap;min-height:104px}
.chz-pcard{width:72px;height:100px;border-radius:11px;background:linear-gradient(160deg,#fbfdff,#dfe7f2);color:#0c1626;display:flex;flex-direction:column;justify-content:space-between;padding:9px 10px;font-family:var(--chz-display);font-weight:700;box-shadow:0 10px 24px rgba(0,0,0,.4);animation:chz-deal .28s ease}
.chz-pcard.red{color:#c01b22}
.chz-pcard .r2{align-self:flex-end;transform:rotate(180deg)}
.chz-pcard.back{background:repeating-linear-gradient(45deg,#13314a,#13314a 6px,#1a4060 6px,#1a4060 12px);color:transparent}
@keyframes chz-deal{from{opacity:0;transform:translateY(-12px) scale(.96)}to{opacity:1;transform:none}}
.chz-table-msg{min-height:24px;text-align:center;font-family:var(--chz-mono);font-size:15px;color:var(--chz-cyan);margin:18px 0}
.chz-bj-controls{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.chz-chips{display:flex;gap:10px;justify-content:center;margin:6px 0 18px}
.chz-chip{width:54px;height:54px;border-radius:50%;border:2px dashed rgba(234,241,251,.5);background:radial-gradient(circle at 50% 35%,#1b2740,#0c1626);color:var(--chz-text);font-family:var(--chz-mono);font-size:14px;cursor:pointer;transition:transform .14s ease,border-color .14s ease}
.chz-chip:hover{transform:translateY(-2px)}
.chz-chip.sel{border-style:solid;border-color:var(--chz-cyan);box-shadow:0 0 16px rgba(34,224,214,.3)}
.chz-bj-score{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--chz-line);border:1px solid var(--chz-line);border-radius:14px;overflow:hidden;margin-top:8px}
.chz-bj-score .s{background:var(--chz-graphite);padding:16px;text-align:center}
.chz-bj-score .s .v{font-family:var(--chz-mono);font-size:24px}
.chz-bj-score .s .k{font-size:12.5px;color:var(--chz-muted)}
.chz-bj-score .won .v{color:var(--chz-cyan)}
.chz-bj-score .lost .v{color:var(--chz-red)}
.chz-bj-score .push .v{color:var(--chz-plat)}

/* ---------- footer (signature) ---------- */
.chz-foot{position:relative;background:linear-gradient(180deg,#070b12,#04070d);border-top:1px solid var(--chz-line);padding-bottom:30px;margin-top:10px}
.chz-foot-ridge{line-height:0}
.chz-foot-ridge svg{width:100%;height:80px;display:block}
.chz-foot-grid{display:grid;grid-template-columns:1.2fr 2fr;gap:40px;padding-top:18px}
.chz-foot-brand p{color:var(--chz-muted);max-width:38ch;margin:0 0 14px}
.chz-tag{font-family:var(--chz-mono);font-size:12px;letter-spacing:.08em;color:var(--chz-cyan);border:1px solid var(--chz-line-2);border-radius:999px;padding:6px 14px;display:inline-block}
.chz-foot-links{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.chz-foot-links h4{font-family:var(--chz-display);font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--chz-text);margin:0 0 14px}
.chz-foot-links a{display:block;color:var(--chz-muted);font-size:14.5px;padding:5px 0}
.chz-foot-links a:hover{color:var(--chz-cyan)}
.chz-foot-compliance{margin-top:42px;padding:24px 26px;background:var(--chz-graphite);border:1px solid var(--chz-line);border-radius:16px}
.chz-foot-compliance p{color:var(--chz-muted);font-size:14px;margin:0 0 10px}
.chz-foot-compliance p:last-child{margin:0}
.chz-foot-compliance a{color:var(--chz-cyan)}
.chz-foot-base{display:flex;justify-content:space-between;align-items:center;gap:18px;margin-top:30px;padding-top:22px;border-top:1px solid var(--chz-line);color:var(--chz-dim);font-size:13px;flex-wrap:wrap}
.chz-foot-word{font-family:var(--chz-display);font-weight:800;font-size:clamp(22px,4vw,40px);letter-spacing:.06em;color:transparent;-webkit-text-stroke:1px rgba(120,170,255,.16);background:none}

/* ---------- cookie ---------- */
.chz-cookie{position:fixed;left:18px;right:18px;bottom:18px;z-index:120;max-width:760px;margin:0 auto;display:flex;align-items:center;gap:18px;background:rgba(14,21,33,.96);backdrop-filter:blur(10px);border:1px solid var(--chz-line-2);border-radius:16px;padding:16px 20px;box-shadow:var(--chz-shadow)}
.chz-cookie[hidden]{display:none}
.chz-cookie p{margin:0;font-size:13.5px;color:var(--chz-muted)}
.chz-cookie a{color:var(--chz-cyan)}

/* ---------- scroll reveal ---------- */
.chz-reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.chz-reveal.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .chz-bento{grid-template-columns:1fr}
  .chz-show--tall{grid-row:auto;min-height:300px}
  .chz-split{grid-template-columns:1fr;gap:28px}
  .chz-split.rev .col-text{order:0}
  .chz-grid-3,.chz-grid-4{grid-template-columns:repeat(2,1fr)}
  .chz-index{grid-template-columns:repeat(2,1fr)}
  .chz-game-wrap{grid-template-columns:1fr}
  .chz-foot-grid{grid-template-columns:1fr;gap:30px}
}
@media(max-width:620px){
  .chz-section{padding:64px 0}
  .chz-hero{padding:90px 0 70px}
  .chz-grid-2,.chz-grid-3,.chz-grid-4{grid-template-columns:1fr}
  .chz-index{grid-template-columns:1fr}
  .chz-foot-links{grid-template-columns:1fr 1fr}
  .chz-band{padding:38px 24px}
  .chz-cell{font-size:34px}
  .chz-reel{height:210px}
  .chz-cell{flex-basis:70px;height:70px}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
  .chz-aurora{animation:none}
}
