/* ============================================================
   KERUVA MORA — velour.css
   CONSTITUTION (the design is this; the CSS just types it out)
   Concept ... a members-only Art-Deco casino lounge at midnight:
               plum velvet, champagne-gold brass inlay, warm marquee glow.
   Colours ... grounds  plum #1d1033 / velvet #2a1745 / ink #120821
               accent   champagne gold (f6e6a8 > e3bd5f > b8862f)
               glow     warm magenta #ff5fa2 — used VERY sparingly
   Type ...... Cinzel (engraved deco caps: wordmark, headings, numerals)
               + Sora (body, UI, figures)
   Surface ... velvet radials + 1px gold hairlines + faint grain;
               soft warm glow behind feature tiles (tasteful, not tacky)
   Signature . gold corner-bracket frames + a small diamond before every
               eyebrow + deco sunburst / fan dividers
   ============================================================ */

@font-face{
  font-family:"Cinzel";
  src:url("./fonts/cinzel.woff2") format("woff2");
  font-weight:400 800;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Sora";
  src:url("./fonts/sora.woff2") format("woff2");
  font-weight:400 700;font-style:normal;font-display:swap;
}

:root{
  --ink:#120821;
  --plum:#1d1033;
  --plum-2:#241341;
  --velvet:#2a1745;
  --panel:#221037;
  --panel-2:#2c1850;

  --gold:#e8c66a;
  --gold-soft:#f6e6a8;
  --gold-deep:#b8862f;
  --gold-line:rgba(232,198,106,.34);
  --gold-line-strong:rgba(232,198,106,.62);

  --magenta:#ff5fa2;

  --text:#ece3f6;
  --muted:#b6a6d2;
  --muted-2:#8f7fb2;

  --gold-grad:linear-gradient(180deg,#f6e6a8 0%,#e3bd5f 52%,#b8862f 100%);
  --maxw:1280px;
  --gut:clamp(18px,4.4vw,40px);
  --r:14px;
  --shadow:0 24px 60px -28px rgba(0,0,0,.8);
  --glow:0 0 0 1px var(--gold-line),0 26px 60px -30px rgba(0,0,0,.85);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  font-family:"Sora",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--text);
  background:var(--ink);
  line-height:1.62;
  font-size:clamp(15px,1.05vw,16.5px);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
/* layered velvet field */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(1100px 720px at 78% -8%,rgba(124,58,153,.42),transparent 60%),
    radial-gradient(900px 640px at 8% 12%,rgba(56,30,99,.55),transparent 58%),
    radial-gradient(1200px 900px at 50% 116%,rgba(86,38,120,.4),transparent 60%),
    linear-gradient(180deg,#160a29 0%,#120821 60%,#16092b 100%);
}
.grain{
  position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.05;
  mix-blend-mode:overlay;
  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.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:4px}

.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut)}
.eyebrow{
  font-family:"Sora";font-weight:600;letter-spacing:.34em;text-transform:uppercase;
  font-size:.7rem;color:var(--gold);display:inline-flex;align-items:center;gap:.7em;margin:0 0 .8rem;
}
.eyebrow::before{content:"";width:.5em;height:.5em;background:var(--gold-grad);transform:rotate(45deg);box-shadow:0 0 12px rgba(232,198,106,.6)}
.eyebrow--c{justify-content:center}
.eyebrow--c::after{content:"";width:.5em;height:.5em;background:var(--gold-grad);transform:rotate(45deg)}

h1,h2,h3{font-family:"Cinzel",Georgia,serif;font-weight:700;line-height:1.06;margin:0;letter-spacing:.005em}
h2.title{font-size:clamp(1.9rem,4.6vw,3.1rem);text-transform:uppercase;letter-spacing:.04em}
.lede{color:var(--muted);font-size:clamp(1rem,1.5vw,1.15rem);max-width:60ch}
.gold-word{
  background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent;
}

/* deco divider */
.fan{display:flex;align-items:center;justify-content:center;gap:1rem;margin:0 auto}
.fan::before,.fan::after{content:"";height:1px;width:min(120px,18vw);background:linear-gradient(90deg,transparent,var(--gold-line-strong))}
.fan::after{background:linear-gradient(90deg,var(--gold-line-strong),transparent)}
.fan span{width:12px;height:12px;border:1px solid var(--gold-line-strong);transform:rotate(45deg)}

/* ---- buttons ---- */
.btn{
  --bx:1.5rem;
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:"Sora";font-weight:600;font-size:.95rem;letter-spacing:.02em;
  padding:.85rem var(--bx);border-radius:999px;cursor:pointer;border:1px solid transparent;
  transition:transform .25s ease,box-shadow .25s ease,background .25s ease,color .25s ease;
  text-align:center;
}
.btn--gold{background:var(--gold-grad);color:#231405;box-shadow:0 10px 30px -12px rgba(232,198,106,.6);font-weight:700}
.btn--gold:hover{transform:translateY(-2px);box-shadow:0 16px 38px -12px rgba(232,198,106,.78)}
.btn--ghost{background:rgba(255,255,255,.02);color:var(--text);border-color:var(--gold-line-strong)}
.btn--ghost:hover{background:rgba(232,198,106,.1);border-color:var(--gold);transform:translateY(-2px)}
.btn--block{width:100%}
.btn--sm{padding:.6rem 1.1rem;font-size:.85rem}

/* =================== HEADER =================== */
.site-head{position:sticky;top:0;z-index:60;backdrop-filter:blur(10px)}
.site-head::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold-line-strong),transparent)}
.site-head__bg{position:absolute;inset:0;background:rgba(18,8,33,.82);z-index:-1}
.bar{display:flex;align-items:center;justify-content:space-between;gap:.8rem;min-height:74px;min-width:0}
.brand{display:flex;align-items:center;gap:.7rem;min-width:0}
.brand__name{min-width:0}
.brand__mark{width:38px;height:38px;flex:0 0 auto}
.brand__name{font-family:"Cinzel";font-weight:700;font-size:1.12rem;letter-spacing:.16em;text-transform:uppercase;line-height:1}
.brand__name small{display:block;font-family:"Sora";font-weight:500;font-size:.56rem;letter-spacing:.42em;color:var(--gold);margin-top:.28em}

.nav{display:flex;align-items:center;gap:.4rem}
.nav a{
  position:relative;font-size:.92rem;font-weight:500;color:var(--muted);padding:.5rem .85rem;border-radius:8px;
  transition:color .2s ease;
}
.nav a:hover,.nav a[aria-current="page"]{color:var(--text)}
.nav a::after{content:"";position:absolute;left:.85rem;right:.85rem;bottom:.28rem;height:1px;background:var(--gold-grad);transform:scaleX(0);transform-origin:left;transition:transform .25s ease}
.nav a:hover::after,.nav a[aria-current="page"]::after{transform:scaleX(1)}

.head-tools{display:flex;align-items:center;gap:.7rem}
.badge18{
  font-family:"Sora";font-weight:700;font-size:.74rem;letter-spacing:.06em;
  border:1px solid var(--gold-line-strong);color:var(--gold);border-radius:999px;padding:.34rem .6rem;white-space:nowrap;
}
.burger{display:none}

/* mobile velvet curtain */
.curtain{display:none}

/* =================== HERO =================== */
.hero{position:relative;overflow:hidden;isolation:isolate}
.hero__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;filter:saturate(1.05)}
.hero__veil{position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(180deg,rgba(18,8,33,.66),rgba(18,8,33,.78) 55%,rgba(18,8,33,.97)),
    radial-gradient(700px 480px at 24% 36%,rgba(255,95,162,.18),transparent 60%);
}
.hero__inner{padding-top:clamp(3.4rem,8vw,6.4rem);padding-bottom:clamp(2.6rem,6vw,4.4rem)}
.hero__frame{position:relative;border:1px solid var(--gold-line);border-radius:20px;padding:clamp(1.6rem,4.4vw,3.4rem);
  background:linear-gradient(180deg,rgba(34,16,55,.5),rgba(20,10,38,.35));box-shadow:var(--shadow);max-width:880px}
.corner{position:absolute;width:26px;height:26px;border:2px solid var(--gold);opacity:.85}
.corner.tl{top:-1px;left:-1px;border-right:0;border-bottom:0;border-top-left-radius:20px}
.corner.tr{top:-1px;right:-1px;border-left:0;border-bottom:0;border-top-right-radius:20px}
.corner.bl{bottom:-1px;left:-1px;border-right:0;border-top:0;border-bottom-left-radius:20px}
.corner.br{bottom:-1px;right:-1px;border-left:0;border-top:0;border-bottom-right-radius:20px}

.hero h1{font-size:clamp(2.4rem,6.6vw,4.5rem);text-transform:uppercase;letter-spacing:.02em;margin:0 0 1.1rem}
.hero h1 em{font-style:italic;font-weight:400}
.hero .lede{margin:0 0 1.7rem;color:#d9cdec;max-width:46ch}
.hero__cta{display:flex;flex-wrap:wrap;gap:.8rem}
.hero__note{margin-top:1.4rem;font-size:.82rem;color:var(--muted-2);display:flex;align-items:center;gap:.5rem}
.hero__note::before{content:"◆";color:var(--gold)}

/* stat strip */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--gold-line);
  border:1px solid var(--gold-line);border-radius:16px;overflow:hidden;margin-top:clamp(1.8rem,4vw,2.6rem)}
.stat{background:linear-gradient(180deg,rgba(36,19,65,.92),rgba(24,12,44,.92));padding:1.2rem 1rem;text-align:center}
.stat b{display:block;font-family:"Cinzel";font-weight:700;font-size:clamp(1.4rem,3.2vw,2rem);background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat span{display:block;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:.3rem}

/* disclaimer ribbon */
.ribbon{border-top:1px solid var(--gold-line);border-bottom:1px solid var(--gold-line);
  background:rgba(18,8,33,.6)}
.ribbon .wrap{display:flex;align-items:center;gap:.9rem;padding-block:.95rem;flex-wrap:wrap;justify-content:center;text-align:center}
.ribbon p{margin:0;font-size:.82rem;color:var(--muted);letter-spacing:.01em}
.ribbon strong{color:var(--gold);font-weight:600}

/* =================== SECTIONS =================== */
section{position:relative}
.band{padding-block:clamp(3.4rem,8vw,6rem)}
.sec-head{margin-bottom:clamp(2rem,5vw,3rem)}
.sec-head--c{text-align:center;max-width:64ch;margin-inline:auto}
.sec-head--c .lede{margin-inline:auto}

/* games grid */
.reel{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1rem,2.2vw,1.5rem)}
.tile{position:relative;border:1px solid var(--gold-line);border-radius:var(--r);overflow:hidden;
  background:linear-gradient(180deg,var(--panel),var(--ink));display:flex;flex-direction:column;
  transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease}
.tile:hover{transform:translateY(-6px);border-color:var(--gold-line-strong);box-shadow:0 30px 60px -34px rgba(232,198,106,.5),0 0 50px -20px rgba(255,95,162,.4)}
.tile__media{position:relative;aspect-ratio:1/1;overflow:hidden}
.tile__media img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.tile:hover .tile__media img{transform:scale(1.06)}
.tile__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(18,8,33,.9))}
.tile__tag{position:absolute;top:.7rem;left:.7rem;z-index:2;font-size:.64rem;font-weight:600;letter-spacing:.12em;
  text-transform:uppercase;color:var(--gold);background:rgba(18,8,33,.72);border:1px solid var(--gold-line);
  border-radius:999px;padding:.3rem .6rem}
.tile__body{position:relative;z-index:2;padding:.95rem 1rem 1.15rem;margin-top:-2.4rem;display:flex;flex-direction:column;gap:.7rem;flex:1}
.tile__body h3{font-size:1.02rem;text-transform:uppercase;letter-spacing:.05em;line-height:1.15}
.tile__body p{margin:0;font-size:.8rem;color:var(--muted);flex:1}
.tile__cta{display:inline-flex;align-items:center;gap:.5em;font-weight:600;font-size:.85rem;color:var(--gold)}
.tile__cta svg{transition:transform .25s ease}
.tile:hover .tile__cta svg{transform:translateX(4px)}

/* steps (numbered deco) */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,2.4vw,1.8rem)}
.step{position:relative;padding:1.7rem 1.5rem;border:1px solid var(--gold-line);border-radius:var(--r);
  background:linear-gradient(180deg,rgba(36,19,65,.6),rgba(20,10,38,.5))}
.step__n{font-family:"Cinzel";font-weight:700;font-size:2.6rem;line-height:1;background:var(--gold-grad);
  -webkit-background-clip:text;background-clip:text;color:transparent;display:block;margin-bottom:.6rem}
.step h3{font-size:1.05rem;text-transform:uppercase;letter-spacing:.04em;margin-bottom:.5rem}
.step p{margin:0;color:var(--muted);font-size:.9rem}
.step::after{content:"";position:absolute;top:1.7rem;right:1.5rem;width:10px;height:10px;border:1px solid var(--gold-line-strong);transform:rotate(45deg)}

/* feature / why-us — alternating */
.feat{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(1.6rem,4vw,3.4rem);align-items:center}
.feat__media{position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--gold-line);box-shadow:var(--shadow)}
.feat__media img{width:100%;aspect-ratio:4/3;object-fit:cover}
.feat__media .corner{z-index:3}
.perks{display:grid;gap:1rem;margin:1.4rem 0 0;padding:0;list-style:none}
.perk{display:flex;gap:.95rem;align-items:flex-start;padding:1rem 1.1rem;border:1px solid var(--gold-line);
  border-radius:12px;background:rgba(36,19,65,.4)}
.perk__ic{flex:0 0 auto;width:38px;height:38px;border-radius:10px;display:grid;place-items:center;
  background:rgba(232,198,106,.1);border:1px solid var(--gold-line-strong)}
.perk__ic svg{width:20px;height:20px;stroke:var(--gold)}
.perk h3{font-family:"Sora";font-weight:600;font-size:.98rem;text-transform:none;letter-spacing:0;margin-bottom:.2rem;color:var(--text)}
.perk p{margin:0;font-size:.85rem;color:var(--muted)}

/* responsible play block */
.rg-band{border:1px solid var(--gold-line);border-radius:20px;overflow:hidden;
  background:linear-gradient(135deg,rgba(43,23,75,.85),rgba(20,10,38,.85));position:relative}
.rg-band .wrap-in{padding:clamp(2rem,5vw,3.2rem);display:grid;grid-template-columns:1.3fr 1fr;gap:2rem;align-items:center}
.rg-band ul{margin:1rem 0 0;padding:0;list-style:none;display:grid;gap:.6rem}
.rg-band li{position:relative;padding-left:1.4rem;font-size:.9rem;color:var(--muted);overflow-wrap:anywhere}
.rg-band li::before{content:"◆";position:absolute;left:0;top:.05rem;color:var(--gold);font-size:.7rem}
.rg-side{border-left:1px solid var(--gold-line);padding-left:2rem}
.rg-side a{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.85rem 1rem;
  border:1px solid var(--gold-line);border-radius:12px;margin-bottom:.7rem;transition:border-color .2s,background .2s}
.rg-side a:hover{border-color:var(--gold);background:rgba(232,198,106,.08)}
.rg-side a span{font-weight:600;font-size:.92rem}
.rg-side a small{display:block;color:var(--muted-2);font-size:.74rem;font-weight:400}

/* =================== GAME PAGE =================== */
.gp-head{padding-top:clamp(2.4rem,6vw,4rem);padding-bottom:clamp(1.4rem,3vw,2rem)}
.crumb{font-size:.8rem;color:var(--muted-2);margin-bottom:1rem;display:flex;gap:.5rem;flex-wrap:wrap}
.crumb a:hover{color:var(--gold)}
.gp-title{display:flex;flex-wrap:wrap;align-items:baseline;gap:.5rem 1rem}
.gp-title h1{font-size:clamp(2rem,5vw,3.2rem);text-transform:uppercase;letter-spacing:.03em}
.gp-title .by{font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}
.frame-wrap{position:relative;border:1px solid var(--gold-line-strong);border-radius:18px;overflow:hidden;
  background:var(--ink);box-shadow:var(--shadow)}
.frame-ratio{position:relative;width:100%;aspect-ratio:16/9}
.frame-ratio iframe{position:absolute;inset:0;width:100%;height:100%;border:0;background:#0c0518}
.frame-ph{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;gap:1rem;padding:2rem;
  background:radial-gradient(700px 420px at 50% 30%,rgba(124,58,153,.4),transparent 60%),linear-gradient(180deg,#1a0f30,#0e0620)}
.frame-ph__mark{width:74px;height:74px;animation:spin 9s linear infinite}
@media (prefers-reduced-motion:reduce){.frame-ph__mark{animation:none}}
@keyframes spin{to{transform:rotate(360deg)}}
.frame-ph h2{font-size:1.3rem;text-transform:uppercase;letter-spacing:.06em}
.frame-ph p{margin:0;color:var(--muted);max-width:40ch;font-size:.9rem}
.gp-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:clamp(1.4rem,3.4vw,2.6rem);align-items:start;margin-top:2rem}
.prose p{color:var(--muted)}
.prose p+p{margin-top:.9rem}
.gp-aside{border:1px solid var(--gold-line);border-radius:16px;padding:1.4rem;background:rgba(36,19,65,.45);position:sticky;top:96px}
.gp-aside h3{font-family:"Sora";font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:.78rem;color:var(--gold);margin-bottom:.9rem}
.spec{display:flex;justify-content:space-between;gap:1rem;padding:.55rem 0;border-bottom:1px dashed var(--gold-line);font-size:.88rem}
.spec:last-child{border-bottom:0}
.spec span{color:var(--muted)}
.spec b{font-weight:600}

/* disclaimer card */
.disc{border:1px solid var(--gold-line);border-left:3px solid var(--gold);border-radius:12px;
  padding:1.2rem 1.3rem;background:rgba(18,8,33,.5);margin-top:1.6rem}
.disc h3{font-family:"Sora";font-weight:700;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem}
.disc p{margin:0;font-size:.84rem;color:var(--muted)}
.disc p+p{margin-top:.5rem}

/* mini game rail */
.rail{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.rail a{border:1px solid var(--gold-line);border-radius:12px;overflow:hidden;position:relative;transition:border-color .2s,transform .2s}
.rail a:hover{border-color:var(--gold-line-strong);transform:translateY(-3px)}
.rail img{aspect-ratio:1/1;object-fit:cover;width:100%}
.rail span{position:absolute;left:0;right:0;bottom:0;padding:.6rem .7rem;font-family:"Cinzel";font-weight:700;
  font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;background:linear-gradient(transparent,rgba(14,6,30,.92))}

/* =================== LEGAL =================== */
.legal-head{padding-top:clamp(2.6rem,6vw,4.2rem);padding-bottom:clamp(1.6rem,3vw,2.4rem);text-align:center;
  border-bottom:1px solid var(--gold-line)}
.legal-head h1{font-size:clamp(2rem,5vw,3rem);text-transform:uppercase;letter-spacing:.04em}
.legal-head p{color:var(--muted);margin:.8rem auto 0;max-width:50ch}
.legal-wrap{max-width:820px}
.legal-body h2{font-size:1.3rem;text-transform:none;letter-spacing:.01em;margin:2.2rem 0 .7rem;color:var(--gold-soft)}
.legal-body h2:first-child{margin-top:0}
.legal-body h3{font-family:"Sora";font-weight:600;font-size:1rem;margin:1.4rem 0 .4rem}
.legal-body p,.legal-body li{color:var(--muted);font-size:.95rem}
.legal-body ul{padding-left:1.2rem;display:grid;gap:.4rem;margin:.6rem 0}
.legal-body a{color:var(--gold);text-decoration:underline;text-underline-offset:3px}
.toc{border:1px solid var(--gold-line);border-radius:14px;padding:1.3rem 1.5rem;background:rgba(36,19,65,.4);margin-bottom:2.2rem}
.toc h2{margin:0 0 .7rem;font-family:"Sora";font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold)}
.toc ol{margin:0;padding-left:1.2rem;columns:2;gap:1rem;color:var(--muted);font-size:.9rem}
.toc a:hover{color:var(--gold)}

/* =================== 404 =================== */
.nf{min-height:64vh;display:grid;place-items:center;text-align:center;padding-block:4rem}
.nf__big{font-family:"Cinzel";font-weight:700;font-size:clamp(5rem,22vw,12rem);line-height:.9;
  background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent}

/* =================== FOOTER =================== */
.site-foot{position:relative;border-top:1px solid var(--gold-line);background:linear-gradient(180deg,rgba(18,8,33,.4),rgba(12,5,24,.9));margin-top:clamp(3rem,7vw,5rem)}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:clamp(1.6rem,3vw,2.6rem);padding-block:clamp(2.6rem,6vw,4rem)}
.foot-brand .brand{margin-bottom:1rem}
.foot-brand p{color:var(--muted);font-size:.88rem;max-width:34ch}
.foot-col h4{font-family:"Sora";font-weight:600;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin:0 0 1rem}
.foot-col ul{list-style:none;margin:0;padding:0;display:grid;gap:.55rem}
.foot-col a{color:var(--muted);font-size:.9rem;transition:color .2s}
.foot-col a:hover{color:var(--text)}
.nap{font-style:normal;color:var(--muted);font-size:.88rem;display:grid;gap:.55rem}
.nap a:hover{color:var(--gold)}
.nap span{position:relative;padding-left:1.1rem;overflow-wrap:anywhere}
.nap span::before{content:"";position:absolute;left:0;top:.5rem;width:7px;height:7px;background:var(--gold-grad);transform:rotate(45deg)}
.help-links{display:flex;gap:.7rem;flex-wrap:wrap;margin-top:1rem}
.help-links a{display:inline-flex;align-items:center;gap:.4rem;border:1px solid var(--gold-line);border-radius:999px;
  padding:.4rem .8rem;font-size:.78rem;color:var(--muted);transition:border-color .2s,color .2s}
.help-links a:hover{border-color:var(--gold);color:var(--gold)}
.foot-disc{border-top:1px solid var(--gold-line);padding-block:1.6rem}
.foot-disc p{margin:0 0 .7rem;font-size:.78rem;color:var(--muted-2);max-width:none}
.foot-disc strong{color:var(--muted)}
.foot-bottom{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding-block:1.3rem;border-top:1px solid var(--gold-line);
  font-size:.78rem;color:var(--muted-2);align-items:center}
.foot-bottom .badge18{font-size:.68rem}

/* =================== AGE GATE =================== */
.age{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;padding:1.4rem;
  background:rgba(8,3,18,.86);backdrop-filter:blur(8px)}
.age.show{display:flex}
.age__card{max-width:440px;width:100%;border:1px solid var(--gold-line-strong);border-radius:20px;
  background:linear-gradient(180deg,#241341,#150a29);box-shadow:var(--shadow);padding:clamp(1.8rem,5vw,2.6rem);text-align:center;position:relative}
.age__mark{width:62px;height:62px;margin:0 auto 1.1rem}
.age__card h2{font-size:1.5rem;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.7rem}
.age__card p{color:var(--muted);font-size:.92rem;margin:0 0 1.5rem}
.age__btns{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}
.age__fine{margin-top:1.2rem;font-size:.74rem;color:var(--muted-2)}

/* =================== COOKIE =================== */
.cookie{position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:150;display:none;
  max-width:620px;margin-inline:auto;border:1px solid var(--gold-line-strong);border-radius:16px;
  background:linear-gradient(180deg,rgba(40,21,71,.98),rgba(22,11,42,.98));box-shadow:var(--shadow);
  padding:1.1rem 1.2rem;backdrop-filter:blur(8px)}
.cookie.show{display:block}
.cookie p{margin:0 0 .8rem;font-size:.84rem;color:var(--muted)}
.cookie a{color:var(--gold);text-decoration:underline}
.cookie__btns{display:flex;gap:.6rem;flex-wrap:wrap}

/* skip link */
.skip{position:absolute;left:-999px;top:0;z-index:300;background:var(--gold);color:#231405;padding:.6rem 1rem;border-radius:0 0 8px 0;font-weight:600}
.skip:focus{left:0}

/* shrink-safety: let flex/grid children fall below content width */
.feat>*,.rg-band .wrap-in>*,.gp-grid>*,.osig-shell>*,.hero__frame,.tile__body,.step{min-width:0}
.rg-side a{min-width:0}
.rg-side a span{min-width:0;overflow-wrap:anywhere}
.nap span,.foot-col a,.legal-body p,.legal-body li,.prose p{overflow-wrap:anywhere}

/* =================== RESPONSIVE =================== */
@media (max-width:1080px){
  .reel{grid-template-columns:repeat(3,1fr)}
  .rail{grid-template-columns:repeat(4,1fr)}
  .foot-grid{grid-template-columns:1.4fr 1fr 1.3fr}
  .foot-brand{grid-column:1 / -1}
}
@media (max-width:900px){
  .nav,.head-tools .btn{display:none}
  .burger{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;
    border:1px solid var(--gold-line-strong);border-radius:10px;background:rgba(232,198,106,.06);cursor:pointer}
  .burger span{position:relative;width:20px;height:2px;background:var(--gold);transition:.3s}
  .burger span::before,.burger span::after{content:"";position:absolute;left:0;width:20px;height:2px;background:var(--gold);transition:.3s}
  .burger span::before{top:-6px}.burger span::after{top:6px}
  .burger[aria-expanded="true"] span{background:transparent}
  .burger[aria-expanded="true"] span::before{top:0;transform:rotate(45deg)}
  .burger[aria-expanded="true"] span::after{top:0;transform:rotate(-45deg)}
  .curtain{display:block;position:fixed;left:0;right:0;top:0;z-index:55;
    background:linear-gradient(180deg,#1c1033,#140a28);border-bottom:1px solid var(--gold-line-strong);
    box-shadow:0 30px 60px -20px rgba(0,0,0,.7);
    transform:translateY(-100%);transition:transform .42s cubic-bezier(.5,0,.2,1);padding-top:84px}
  .curtain.open{transform:translateY(0)}
  .curtain nav{display:flex;flex-direction:column;padding:0 var(--gut) 1.6rem}
  .curtain nav a{font-family:"Cinzel";font-weight:700;font-size:1.1rem;text-transform:uppercase;letter-spacing:.06em;
    padding:1rem 0;border-bottom:1px solid var(--gold-line);display:flex;align-items:center;gap:.9rem;color:var(--text)}
  .curtain nav a::before{content:"0" counter(m);counter-increment:m;font-size:.7rem;color:var(--gold);font-family:"Sora";letter-spacing:.1em}
  .curtain nav{counter-reset:m}
  .curtain .btn{margin-top:1.3rem}
  .feat{grid-template-columns:1fr}
  .feat--rev .feat__media{order:-1}
  .rg-band .wrap-in{grid-template-columns:1fr}
  .rg-side{border-left:0;border-top:1px solid var(--gold-line);padding-left:0;padding-top:1.4rem}
  .gp-grid{grid-template-columns:1fr}
  .gp-aside{position:static}
  .steps{grid-template-columns:1fr 1fr}
}
@media (max-width:640px){
  .reel{grid-template-columns:1fr 1fr}
  .rail{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr}
  .toc ol{columns:1}
  .foot-grid{grid-template-columns:1fr 1fr}
  .foot-brand{grid-column:1 / -1}
  .foot-bottom{flex-direction:column;align-items:flex-start}
}
@media (max-width:400px){
  .head-tools{gap:.5rem}
  .badge18{padding:.3rem .5rem}
  .brand__name{font-size:1rem;letter-spacing:.1em}
  .brand__name small{letter-spacing:.26em}
  .brand__mark{width:34px;height:34px}
}
@media (max-width:380px){
  .reel{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}
}

/* =================== LOUNGE DISPATCH / SUBSCRIBE =================== */
.osig-shell{
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.6rem,4vw,3.4rem);align-items:center;
  border:1px solid var(--gold-line);border-radius:20px;overflow:hidden;
  background:
    radial-gradient(640px 420px at 88% -10%,rgba(255,95,162,.14),transparent 60%),
    linear-gradient(135deg,rgba(43,23,75,.85),rgba(20,10,38,.85));
  padding:clamp(1.8rem,4.4vw,3.4rem);position:relative;box-shadow:var(--shadow);
}
.osig-shell::before{content:"";position:absolute;left:0;top:0;height:100%;width:3px;background:var(--gold-grad);opacity:.85}
.osig-copy>.lede{margin-top:.4rem}
.osig-perks{list-style:none;margin:1.4rem 0 0;padding:0;display:grid;gap:.6rem}
.osig-perks li{position:relative;padding-left:1.5rem;font-size:.9rem;color:var(--muted)}
.osig-perks li::before{content:"◆";position:absolute;left:0;top:.05rem;color:var(--gold);font-size:.72rem}

/* form card */
.osig-wrap{
  position:relative;border:1px solid var(--gold-line-strong);border-radius:16px;
  background:linear-gradient(180deg,rgba(36,19,65,.66),rgba(18,8,33,.72));
  box-shadow:var(--glow);padding:clamp(1.4rem,3vw,2rem);text-align:left;
}
.osig-head{
  font-family:"Cinzel",Georgia,serif;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  font-size:1.05rem;margin:0 0 1.2rem;color:var(--gold-soft);
}
.osig-g{margin-bottom:1rem}
.osig-g label{
  display:block;font-family:"Sora";font-weight:600;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold);margin-bottom:.4rem;
}
.osig-g input[type=text],
.osig-g input[type=tel],
.osig-g input[type=email]{
  width:100%;box-sizing:border-box;padding:.8rem .9rem;font-family:"Sora";font-size:.95rem;
  color:var(--text);background:rgba(18,8,33,.6);
  border:1px solid var(--gold-line);border-radius:10px;
  transition:border-color .2s ease,box-shadow .2s ease,background .2s ease;
}
.osig-g input[type=text]::placeholder,
.osig-g input[type=tel]::placeholder,
.osig-g input[type=email]::placeholder{color:var(--muted-2);opacity:1}
.osig-g input[type=text]:focus,
.osig-g input[type=tel]:focus,
.osig-g input[type=email]:focus{
  outline:none;border-color:var(--gold);background:rgba(18,8,33,.78);
  box-shadow:0 0 0 3px rgba(232,198,106,.16);
}
.osig-consent{margin-top:.4rem}
.osig-consent label{
  display:flex;align-items:flex-start;gap:.6rem;text-transform:none;letter-spacing:0;font-weight:400;
  font-size:.8rem;color:var(--muted);margin-bottom:0;
}
.osig-consent input[type=checkbox]{
  flex:0 0 auto;width:1.05rem;height:1.05rem;margin-top:.12rem;accent-color:var(--gold);cursor:pointer;
}
.osig-consent a{color:var(--gold);text-decoration:underline;text-underline-offset:3px}
.osig-consent a:hover{color:var(--gold-soft)}

/* submit — matches .btn--gold */
.osig-btn{
  width:100%;margin-top:1.2rem;display:inline-flex;align-items:center;justify-content:center;
  font-family:"Sora";font-weight:700;font-size:.95rem;letter-spacing:.02em;
  padding:.9rem 1.5rem;border:1px solid transparent;border-radius:999px;cursor:pointer;
  background:var(--gold-grad);color:#231405;box-shadow:0 10px 30px -12px rgba(232,198,106,.6);
  transition:transform .25s ease,box-shadow .25s ease;
}
.osig-btn:hover{transform:translateY(-2px);box-shadow:0 16px 38px -12px rgba(232,198,106,.78)}

/* success message */
.osig-ok{
  display:none;margin-top:1rem;text-align:center;font-size:.85rem;font-weight:600;color:var(--gold-soft);
  border:1px solid var(--gold-line);border-radius:10px;padding:.7rem .9rem;background:rgba(232,198,106,.08);
}
.osig-ok.show{display:block}

@media (max-width:900px){
  .osig-shell{grid-template-columns:1fr}
}
