/* ============================================================
   Lama-style theme — warm-black canvas, cream ink, mono labels,
   oversized uppercase display type. Token-driven (vars from brand.json).
   ============================================================ */
/* ---------- Self-hosted fonts (CSP-safe, no external requests) ---------- */
@font-face{
  font-family:'Archivo';font-style:normal;font-weight:400 900;font-display:swap;
  src:url(../fonts/archivo-latin.woff2) format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:'Archivo';font-style:normal;font-weight:400 900;font-display:swap;
  src:url(../fonts/archivo-latin-ext.woff2) format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}
@font-face{
  font-family:'Sometype Mono';font-style:normal;font-weight:400 700;font-display:swap;
  src:url(../fonts/sometypemono-latin.woff2) format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:'Sometype Mono';font-style:normal;font-weight:400 700;font-display:swap;
  src:url(../fonts/sometypemono-latin-ext.woff2) format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}

:root{
  --bg:#1a1c1c;
  --bg-2:#232525;
  --bg-3:#2a2c2c;
  --cream:#f9f4eb;
  --muted:rgba(249,244,235,.55);
  --faint:rgba(249,244,235,.35);
  --line:rgba(249,244,235,.14);
  --line-2:rgba(249,244,235,.22);
  --accent:var(--color-accent);
  --mono:'Sometype Mono',ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  --display:'Archivo','Helvetica Neue',Helvetica,Arial,sans-serif;
  --shadow:0 24px 60px rgba(0,0,0,.45);
}
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--font);
  color:var(--cream);
  background:var(--bg);
  line-height:1.6;
  padding-bottom:44px; /* fixed status bar */
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--cream);text-decoration:none;transition:color .18s,opacity .18s}
a:hover{text-decoration:none;opacity:.7}

h1,h2,h3,h4{
  font-family:var(--display);
  font-weight:800;
  line-height:.95;
  letter-spacing:-.02em;
  text-transform:uppercase;
  margin:0 0 .4em;
}
h1{font-size:clamp(2.6rem,7vw,5.2rem)}
h2{font-size:clamp(1.8rem,3.6vw,2.8rem)}
h3{font-size:1.25rem}
p{margin:0 0 1em}

.wrap{max-width:1280px;margin:0 auto;padding:0 32px}
.muted{color:var(--muted)}
.center{text-align:center}
.main{min-height:50vh}

/* Mono micro-label / eyebrow */
.eyebrow{
  display:inline-block;
  font-family:var(--mono);
  font-size:.72rem;
  font-weight:500;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--cream);
  margin-bottom:1.4rem;
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  border:1px solid transparent;border-radius:999px;
  padding:.7em 1.4em;
  font-family:var(--mono);font-size:.78rem;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;
  cursor:pointer;text-decoration:none;white-space:nowrap;
  transition:background .2s,color .2s,border-color .2s,opacity .2s;
}
.btn:hover{text-decoration:none;opacity:1}
.btn--accent{background:var(--cream);color:var(--bg);border-color:var(--cream)}
.btn--accent:hover{background:var(--accent);border-color:var(--accent);color:var(--cream)}
.btn--ghost{background:transparent;border-color:var(--line-2);color:var(--cream)}
.btn--ghost:hover{border-color:var(--cream);background:rgba(249,244,235,.06)}
.btn--lg{padding:.95em 1.9em;font-size:.82rem}
.btn--text{background:none;border:0;color:var(--cream);padding:.5em .2em}
.btn--text:hover{color:var(--accent)}

/* ---------- Demo bar ---------- */
.demo-bar{
  background:var(--accent);color:var(--cream);text-align:center;
  font-family:var(--mono);font-size:.72rem;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;padding:.5em 10px;
}

/* ---------- Top utility bar ---------- */
.utility{
  background:var(--bg);
  border-bottom:1px solid var(--line);
  font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;
}
.utility__row{display:flex;justify-content:space-between;align-items:center;min-height:40px;gap:12px}
.utility__notice{color:var(--muted)}
.utility__right{display:flex;align-items:center;gap:18px}
.utility a{color:var(--muted)}
.utility a:hover{color:var(--cream);opacity:1}
.utility__age{border:1px solid var(--line-2);border-radius:999px;padding:.15em .7em;font-weight:600;color:var(--cream)}
.utility__lang.is-active{color:var(--cream);font-weight:700}

/* ---------- Header / pill nav ---------- */
.header{position:sticky;top:0;z-index:50;background:var(--bg);padding:18px 0}
.header__row{
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  min-height:60px;padding:0 22px;
  background:rgba(20,21,21,.85);
  -webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);
  border:1px solid var(--line);border-radius:999px;
}
.brand{display:inline-flex;align-items:center;gap:10px}
.brand__logo{height:34px;width:auto}
.brand__name{
  font-family:var(--display);font-size:1.35rem;font-weight:900;
  color:var(--cream);letter-spacing:-.03em;text-transform:uppercase;
}
.header__tag{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);display:none;
}
@media(min-width:880px){.header__tag{display:inline}}
.header__actions{display:flex;align-items:center;gap:10px}

/* ---------- Games nav ---------- */
.gamesnav{background:var(--bg);border-bottom:1px solid var(--line)}
.gamesnav__row{display:flex;justify-content:space-between;align-items:stretch;gap:10px;flex-wrap:wrap}
.gamesnav__list{display:flex;list-style:none;margin:0;padding:0;flex-wrap:wrap;gap:4px}
.gamesnav__list a{
  display:flex;align-items:center;gap:8px;color:var(--muted);
  padding:16px 18px;font-family:var(--mono);font-size:.72rem;font-weight:500;
  text-transform:uppercase;letter-spacing:.08em;
}
.gamesnav__list a:hover{color:var(--cream);opacity:1}
.gamesnav__icon{width:18px;height:18px;stroke:currentColor;fill:none}
.gamesnav__limits{
  display:flex;align-items:center;gap:8px;color:var(--bg);background:var(--cream);
  padding:0 22px;font-family:var(--mono);font-size:.72rem;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;margin:8px 0;border-radius:999px;
}
.gamesnav__limits:hover{background:var(--accent);color:var(--cream);opacity:1}

/* ---------- Hero ---------- */
.hero{background:var(--bg);padding:clamp(60px,11vw,150px) 0 clamp(40px,7vw,90px);border-bottom:1px solid var(--line)}
.hero h1{max-width:16ch;margin:0 0 .15em}
.hero__foot{
  display:flex;justify-content:space-between;align-items:flex-end;gap:40px;
  flex-wrap:wrap;margin-top:clamp(28px,5vw,56px);
}
.hero p{
  font-family:var(--font);font-size:1.15rem;line-height:1.5;color:var(--cream);
  max-width:46ch;margin:0;
}

/* ---------- Generic sections ---------- */
.section{padding:clamp(48px,7vw,90px) 0;border-bottom:1px solid var(--line)}
.section h2{margin-bottom:1em}
.sectionhead{display:flex;justify-content:space-between;align-items:baseline;gap:20px;flex-wrap:wrap;margin-bottom:1em}
.sectionhead h2{margin:0}
.sectionhead .link-back{color:var(--muted)}
.sectionhead .link-back:hover{color:var(--cream);opacity:1}
.pagehead{background:var(--bg);padding:clamp(60px,9vw,120px) 0 clamp(28px,4vw,48px);border-bottom:1px solid var(--line)}
.pagehead h1{font-size:clamp(2.2rem,5.5vw,4rem)}
/* Category banner image: full-bleed art faded into the dark bg on the left so the heading stays readable */
.pagehead--media{position:relative;overflow:hidden;isolation:isolate}
.pagehead--media::before{
  content:"";position:absolute;inset:0;z-index:0;
  background-image:var(--cat-img);background-size:cover;background-position:center right;
}
.pagehead--media::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(90deg,var(--bg) 0%,rgba(26,28,28,.85) 34%,rgba(26,28,28,.45) 60%,rgba(26,28,28,.25) 100%),
             linear-gradient(180deg,rgba(26,28,28,.25),rgba(26,28,28,.55));
}
.pagehead--media .wrap{position:relative;z-index:2}
.narrow{max-width:760px}
.prose{max-width:780px;color:rgba(249,244,235,.82)}
.prose h2{font-size:1.4rem;margin-top:1.6em}

/* ---------- Promos ---------- */
.promos{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;padding-top:clamp(40px,6vw,72px);padding-bottom:0}
.promo{
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px;display:flex;flex-direction:column;transition:border-color .2s,transform .2s;
}
.promo:hover{border-color:var(--line-2);transform:translateY(-3px)}
.promo__headline{font-family:var(--display);font-size:2.4rem;font-weight:800;line-height:.95;text-transform:uppercase;letter-spacing:-.02em;color:var(--cream)}
.promo__sub{color:var(--muted);margin-bottom:.4em}
.promo__name{font-family:var(--mono);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin:.6em 0 1.2em}
.promo__actions{display:flex;gap:8px;margin-top:auto}

/* ---------- Game grid ---------- */
.gamegrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}
.gamecard{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:border-color .2s,transform .2s}
.gamecard:hover{border-color:var(--line-2);transform:translateY(-3px)}
.gamecard__art{aspect-ratio:4/3;background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center}
.gamecard__art.is-placeholder{background:linear-gradient(135deg,var(--bg-3),#3a1410)}
.gamecard__art span{font-family:var(--display);font-weight:800;font-size:1.4rem;text-transform:uppercase;letter-spacing:-.02em;padding:10px;text-align:center;color:var(--cream)}
.gamecard__body{padding:20px}
.gamecard__jackpot{color:var(--accent);font-family:var(--display);font-weight:800;font-size:1.5rem}
.gamecard__meta{color:var(--muted);font-family:var(--mono);font-size:.72rem;letter-spacing:.05em;text-transform:uppercase;margin:.4em 0 1.1em}
.gamecard .btn{width:100%;justify-content:center}

/* ---------- Winners / news ---------- */
.winners{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.winner{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:24px;text-align:center}
.winner__amt{font-family:var(--display);font-size:1.9rem;font-weight:800;color:var(--accent)}
.winner__meta{font-family:var(--mono);font-size:.72rem;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin-top:.4em}
.winner time{font-family:var(--mono);font-size:.7rem;color:var(--faint)}
.news{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}
.newscard{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:24px;transition:border-color .2s}
.newscard:hover{border-color:var(--line-2)}
.newscard time{font-family:var(--mono);font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;color:var(--faint)}
.newscard h3{margin:.5em 0;color:var(--cream)}
.newscard p{color:var(--muted);margin:0}

/* ---------- RG tip ---------- */
.rgtip{background:var(--bg-2);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:var(--radius);padding:18px 22px;margin:32px auto;font-family:var(--mono);font-size:.8rem;letter-spacing:.03em}
.rgtip strong{text-transform:uppercase;letter-spacing:.08em}
.rgtip a{color:var(--accent);font-weight:600;margin-left:6px}
.rgbox{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:24px;margin-bottom:24px}
.rgbox__line{margin-top:8px;font-weight:700;color:var(--accent)}
.rgtools{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;margin-bottom:24px}
.rgtool{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.rgtool h3{font-size:1.1rem}

/* ---------- Newsletter ---------- */
.newsletter{background:var(--bg-2);border-top:1px solid var(--line);padding:clamp(40px,6vw,72px) 0}
.newsletter__row{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.newsletter h3{margin:0;font-size:clamp(1.6rem,3vw,2.4rem)}
.newsletter__form{display:flex;gap:10px;flex-wrap:wrap}
.newsletter__form input{
  padding:.85em 1.2em;border:1px solid var(--line-2);border-radius:999px;min-width:260px;
  font-family:var(--mono);font-size:.8rem;background:transparent;color:var(--cream);
}
.newsletter__form input::placeholder{color:var(--faint)}
.newsletter__form input:focus{outline:none;border-color:var(--cream)}
.newsletter__done{font-family:var(--mono);font-weight:600;text-transform:uppercase;letter-spacing:.06em}

/* ---------- Footer ---------- */
.footer{background:var(--bg);border-top:1px solid var(--line);padding:clamp(48px,7vw,80px) 0 36px;font-size:.92rem}
.footer a{color:var(--muted)}
.footer a:hover{color:var(--cream);opacity:1}
.footer__cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:32px;margin-bottom:32px}
.footer__col h4{color:var(--cream);font-family:var(--mono);font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-bottom:1em}
.footer__col ul{list-style:none;margin:0;padding:0;display:grid;gap:10px;font-size:.92rem}
.footer__rg{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:16px 20px;margin-bottom:24px;color:var(--muted)}
.footer__rg a{color:var(--accent);font-weight:600}
.badges,.payments{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin:16px 0}
.badge__img,.payment__img{height:40px;width:auto;background:var(--cream);border-radius:8px;padding:5px}
.badge__chip{display:inline-block;border:1px solid var(--line-2);border-radius:999px;padding:.45em .9em;font-family:var(--mono);font-size:.7rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--cream)}
.payment__chip{display:inline-block;background:var(--cream);color:var(--bg);border-radius:8px;padding:.45em .9em;font-family:var(--mono);font-size:.7rem;font-weight:600;letter-spacing:.04em}
.footer__disc{color:var(--faint);font-size:.8rem;margin:18px 0 6px}
.footer__copy{color:var(--faint);font-size:.8rem;margin:0}

/* ---------- Fixed status bar (live clock) ---------- */
.statusbar{
  position:fixed;left:0;right:0;bottom:0;z-index:55;
  background:rgba(20,21,21,.92);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
  border-top:1px solid var(--line);
  font-family:var(--mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;
}
.statusbar__row{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:44px}
.statusbar__item{color:var(--muted);white-space:nowrap}
.statusbar__clock{color:var(--cream);font-weight:600}
.statusbar__col{color:var(--accent)}
.statusbar__right{display:flex;gap:14px}
.statusbar__lang{color:var(--muted)}
.statusbar__lang.is-active{color:var(--cream);font-weight:700}
.statusbar__sep{display:none}
@media(min-width:980px){.statusbar__sep{display:inline}}

/* ---------- Forms ---------- */
.form{display:grid;gap:18px;max-width:560px}
.form--grid{grid-template-columns:1fr 1fr;max-width:820px}
.form label{display:flex;flex-direction:column;gap:8px;font-family:var(--mono);font-size:.72rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.form .full{grid-column:1/-1}
.form input,.form select,.form textarea{
  padding:.85em 1em;border:1px solid var(--line-2);border-radius:12px;
  font-family:var(--font);font-size:1rem;background:var(--bg-2);color:var(--cream);
}
.form input::placeholder,.form textarea::placeholder{color:var(--faint)}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--cream)}
.form select{appearance:none}
.consents{display:grid;gap:12px}
.check{flex-direction:row !important;align-items:flex-start;gap:12px;font-weight:400;text-transform:none;letter-spacing:0;color:var(--muted)}
.check input{margin-top:3px;width:auto}
.captcha{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.captcha__label{font-size:.8rem;color:var(--muted);width:100%}
.captcha input{max-width:140px}
.captcha-img{border:1px solid var(--line-2);border-radius:8px}
.demo-hint code{background:var(--bg-3);padding:.15em .5em;border-radius:5px;font-family:var(--mono)}

/* ---------- Alerts ---------- */
.alert{padding:14px 18px;border-radius:12px;margin-bottom:18px;font-size:.92rem}
.alert--ok{background:rgba(64,160,96,.12);border:1px solid rgba(64,160,96,.4);color:#9fe0b6}
.alert--err{background:rgba(229,67,42,.12);border:1px solid rgba(229,67,42,.45);color:#f3a99a}
.alert ul{margin:0;padding-left:18px}

/* ---------- Account / cards ---------- */
.account__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:18px;margin-bottom:32px}
.card{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.card h3{font-size:1.1rem}
.account__bal{font-family:var(--mono);font-size:.95rem;letter-spacing:.04em}
.account__bal span{font-family:var(--display);font-weight:800;color:var(--accent)}
.usermenu{display:flex;align-items:center;gap:12px}
.usermenu__bal{color:var(--cream);font-family:var(--mono);font-size:.74rem;letter-spacing:.05em;text-transform:uppercase}
.usermenu__logout{margin:0}

/* ---------- Tables ---------- */
.table-wrap{overflow-x:auto}
.table{width:100%;border-collapse:collapse;font-size:.9rem}
.table th,.table td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--line)}
.table th{font-family:var(--mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:600}
.table .win{color:#9fe0b6;font-weight:700}

/* ---------- Play / number picker ---------- */
.play__head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.play__hint{font-size:1.05rem;color:var(--muted);margin:.5em 0 1.2em}
.numgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(52px,1fr));gap:10px;max-width:600px;margin-bottom:22px}
.num{position:relative}
.num input{position:absolute;opacity:0;width:0;height:0}
.num span{display:flex;align-items:center;justify-content:center;aspect-ratio:1;border:1px solid var(--line-2);border-radius:50%;font-family:var(--mono);font-weight:600;cursor:pointer;background:var(--bg-2);color:var(--cream);user-select:none;transition:background .15s,border-color .15s}
.num span:hover{border-color:var(--cream)}
.num input:checked+span{background:var(--accent);color:var(--cream);border-color:var(--accent)}
.num input:disabled+span{opacity:.3;cursor:not-allowed}
.playform__actions{display:flex;gap:10px;flex-wrap:wrap}
.result{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:24px;margin-bottom:22px}
.result--win{background:rgba(64,160,96,.1);border-color:rgba(64,160,96,.4)}
.result__win{font-family:var(--display);font-size:1.5rem;font-weight:800;color:#9fe0b6}
.link-back{font-family:var(--mono);font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;font-weight:600}

/* ---------- Legal ---------- */
.legal{display:grid;grid-template-columns:240px 1fr;gap:40px;padding:clamp(40px,6vw,72px) 32px;max-width:1280px;margin:0 auto}
.legal__nav ul{list-style:none;margin:0;padding:0;display:grid;gap:10px;font-family:var(--mono);font-size:.78rem;letter-spacing:.04em}
.legal__body h2{font-size:1.3rem;margin-top:1.4em}

/* ---------- Cookie + age gate ---------- */
.cookie{position:fixed;inset:auto 0 44px 0;z-index:60;display:flex;justify-content:center;padding:18px}
.cookie__box{background:var(--bg-2);border:1px solid var(--line-2);border-radius:var(--radius);box-shadow:var(--shadow);max-width:780px;padding:28px}
.cookie__actions{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap;margin-top:16px}
.agegate{position:fixed;inset:0;z-index:70;background:rgba(10,11,11,.94);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:20px}
.agegate__box{background:var(--bg-2);border:1px solid var(--line-2);border-radius:var(--radius);max-width:460px;padding:40px;text-align:center;box-shadow:var(--shadow)}
.agegate__badge{display:inline-flex;align-items:center;justify-content:center;width:68px;height:68px;border-radius:50%;background:var(--accent);color:var(--cream);font-family:var(--display);font-weight:800;font-size:1.4rem;margin-bottom:14px}
.agegate__actions{display:flex;gap:10px;justify-content:center;margin-top:20px}
[hidden]{display:none !important}

/* ---------- Contact ---------- */
.contact{display:grid;grid-template-columns:1fr 320px;gap:40px}
.contact__info{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:24px;height:fit-content}

/* ---------- Showcase tiles ---------- */
.tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.tile{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:border-color .2s,transform .2s}
.tile:hover{border-color:var(--line-2);transform:translateY(-3px)}
.tile__art{position:relative;aspect-ratio:16/10;background-size:cover;background-position:center;display:flex;align-items:flex-end;padding:16px}
.tile__art.is-placeholder{background:linear-gradient(135deg,var(--bg-3),#3a1410)}
.tile__tag{font-family:var(--mono);font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;background:var(--cream);color:var(--bg);border-radius:999px;padding:.35em .8em}
.tile__body{padding:22px}
.tile__body h3{margin:0 0 .4em}
.tile__body p{color:var(--muted);margin:0;font-size:.95rem}

/* ---------- Features grid ---------- */
.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.feature{background:var(--bg);padding:32px 28px}
.feature__num{font-family:var(--mono);font-size:.74rem;letter-spacing:.1em;color:var(--accent);display:block;margin-bottom:1.4em}
.feature h3{font-size:1.15rem;margin:0 0 .5em}
.feature p{color:var(--muted);margin:0;font-size:.95rem}

/* ---------- Steps ---------- */
.steps{list-style:none;margin:0;padding:0;display:grid;gap:0;counter-reset:step;max-width:820px}
.steps__item{display:flex;gap:24px;padding:28px 0;border-top:1px solid var(--line)}
.steps__item:last-child{border-bottom:1px solid var(--line)}
.steps__n{flex:none;width:48px;height:48px;border:1px solid var(--line-2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:800;font-size:1.25rem;color:var(--accent)}
.steps__item h3{margin:.2em 0 .35em;font-size:1.2rem}
.steps__item p{color:var(--muted);margin:0}

/* ---------- FAQ ---------- */
.faq{max-width:820px;border-top:1px solid var(--line)}
.faq__item{border-bottom:1px solid var(--line)}
.faq__item summary{
  list-style:none;cursor:pointer;padding:22px 0;display:flex;justify-content:space-between;align-items:center;gap:20px;
  font-family:var(--display);font-weight:700;font-size:1.1rem;text-transform:uppercase;letter-spacing:-.01em;color:var(--cream);
}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"+";font-family:var(--mono);font-weight:400;font-size:1.4rem;color:var(--accent);transition:transform .2s}
.faq__item[open] summary::after{transform:rotate(45deg)}
.faq__item p{color:var(--muted);margin:0 0 22px;max-width:64ch}

/* ---------- CTA band ---------- */
.ctaband{background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:clamp(48px,7vw,80px) 0}
.ctaband__row{display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap}
.ctaband h2{margin:0 0 .3em}
.ctaband p{margin:0}

/* ---------- Game detail ---------- */
.gamecard__body h3 a{color:var(--cream)}
.gamecard__body h3 a:hover{color:var(--accent);opacity:1}
.game__jackpot{font-family:var(--mono);font-size:.95rem;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}
.game__jackpot strong{color:var(--accent);font-family:var(--display);font-size:1.4rem}
.game__grid{display:grid;grid-template-columns:1fr 320px;gap:40px;align-items:start}
.game__main h2{margin:1.4em 0 .6em}
.game__main h2:first-child{margin-top:0}
.game__prizes td,.game__prizes th{font-family:var(--mono)}
.game__side{position:sticky;top:100px;display:grid;gap:18px}
.game__facts dl{display:grid;grid-template-columns:auto 1fr;gap:10px 16px;margin:0 0 20px}
.game__facts dt{font-family:var(--mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.game__facts dd{margin:0;font-weight:600;text-align:right}
.game__facts .btn{width:100%;justify-content:center;margin-bottom:12px}
.game__facts .link-back{display:block;text-align:center;color:var(--muted)}
.game__facts .link-back:hover{color:var(--cream);opacity:1}
.game__rg{font-size:.9rem}
.game__rg strong{display:block;margin-bottom:.4em}
.game__rg p{margin:0;color:var(--muted)}
.game__rg a{color:var(--accent)}
@media(max-width:760px){.game__grid{grid-template-columns:1fr}.game__side{position:static}}

/* ---------- Home promo banner ---------- */
.homebanner{position:relative;overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-2)}
.homebanner--media{background-image:var(--banner-img);background-size:cover;background-position:center}
.homebanner--media::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(20,21,21,.92),rgba(20,21,21,.55))}
.homebanner__inner{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;padding:clamp(40px,6vw,72px) 32px;max-width:1280px;margin:0 auto}
.homebanner__inner h2{margin:.2em 0;font-size:clamp(1.8rem,3.6vw,2.8rem)}
.homebanner__inner p{margin:0;color:var(--muted);max-width:52ch}

/* ---------- Winner stats / stories ---------- */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.stat{background:var(--bg);padding:32px 28px;text-align:center}
.stat__value{font-family:var(--display);font-weight:800;font-size:clamp(2rem,4vw,3rem);color:var(--accent);line-height:1}
.stat__label{font-family:var(--mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-top:.6em}
.stories{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px}
.story{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:30px;margin:0}
.story__amt{font-family:var(--display);font-weight:800;font-size:1.9rem;color:var(--accent);margin-bottom:.4em}
.story blockquote{margin:0 0 1.2em;font-size:1.1rem;line-height:1.5;color:var(--cream)}
.story figcaption{display:flex;flex-direction:column;gap:3px;font-family:var(--mono);font-size:.74rem;letter-spacing:.04em}
.story figcaption strong{color:var(--cream);text-transform:uppercase}
.story figcaption span{color:var(--muted)}

/* ---------- Misc ---------- */
.catcount{font-family:var(--mono);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;margin:0 0 22px}
.rgtool__phone a{font-family:var(--display);font-weight:800;font-size:1.3rem;color:var(--accent)}
.game__lastdraw{display:flex;flex-direction:column;gap:10px;margin-top:1.4em}
.game__lastdraw-label{font-family:var(--mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.game__lastdraw-balls{display:flex;gap:8px;flex-wrap:wrap}

/* ---------- Results ---------- */
.results{display:grid;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.result-row{background:var(--bg);display:flex;justify-content:space-between;align-items:center;gap:24px;padding:22px 26px;flex-wrap:wrap}
.result-row__head{display:flex;flex-direction:column;gap:4px;min-width:180px}
.result-row__game{font-family:var(--display);font-weight:800;text-transform:uppercase;letter-spacing:-.01em;font-size:1.15rem}
.result-row__date{font-family:var(--mono);font-size:.72rem;letter-spacing:.05em;color:var(--faint)}
.result-row__balls{display:flex;gap:10px;flex-wrap:wrap}
.ball{display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;border:1px solid var(--line-2);font-family:var(--mono);font-weight:600;font-size:.9rem;color:var(--cream)}
.ball--bonus{background:var(--accent);border-color:var(--accent);color:var(--cream)}

/* ---------- RG sub-links ---------- */
.rg-more{display:flex;gap:24px;flex-wrap:wrap;margin-top:18px}
.rg-lead{font-size:clamp(1.15rem,2vw,1.5rem);line-height:1.5;max-width:60ch;margin:0 0 32px;color:var(--cream)}
.rg-list{list-style:none;margin:0;padding:0;display:grid;gap:0;max-width:760px}
.rg-list li{padding:16px 0 16px 28px;border-top:1px solid var(--line);position:relative;color:rgba(249,244,235,.82)}
.rg-list li:last-child{border-bottom:1px solid var(--line)}
.rg-list li::before{content:"—";position:absolute;left:0;color:var(--accent)}

/* ---------- Animated brand mark ---------- */
.brandmark{color:var(--cream);overflow:visible;flex:none}
.brand:hover .brandmark{color:var(--accent)}
.brandmark__ring{
  stroke-dasharray:98;stroke-dashoffset:98;transform-origin:20px 20px;transform-box:view-box;
  animation:bm-draw 1.1s .15s ease forwards;
}
.brandmark__spark{
  transform-origin:20px 20px;transform-box:view-box;
  animation:bm-pulse 3.2s ease-in-out infinite, bm-spin 14s linear infinite;
}
.brandmark__orbit{transform-origin:20px 20px;transform-box:view-box;animation:bm-orbit 7s linear infinite}
.brandmark__dot{filter:drop-shadow(0 0 4px var(--accent))}
@keyframes bm-draw{to{stroke-dashoffset:0}}
@keyframes bm-pulse{0%,100%{transform:scale(.82)}50%{transform:scale(1)}}
@keyframes bm-spin{to{transform:rotate(360deg)}}
@keyframes bm-orbit{to{transform:rotate(360deg)}}

/* ---------- Scroll-reveal ---------- */
.js .reveal{
  opacity:0;transform:translateY(26px);
  transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1);
  transition-delay:calc(var(--reveal-i,0) * .07s);will-change:opacity,transform;
}
.js .reveal.is-in{opacity:1;transform:none}

/* ---------- Animated hero background ---------- */
.hero{position:relative;overflow:hidden;isolation:isolate}
.hero__inner{position:relative;z-index:2}
.hero__bg{position:absolute;inset:0;z-index:0;pointer-events:none}
/* Midjourney still → slow ken-burns drift + zoom */
.hero--media .hero__bg{
  background-image:var(--hero-img);background-size:cover;background-position:center;
  animation:hero-kenburns 28s ease-in-out infinite alternate;
  opacity:.55;
}
.hero--media .hero__bg::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(120% 90% at 30% 20%, transparent 40%, rgba(26,28,28,.85) 100%),
    linear-gradient(180deg, rgba(26,28,28,.35), rgba(26,28,28,.9)),
    linear-gradient(90deg, rgba(26,28,28,.92) 0%, rgba(26,28,28,.55) 38%, transparent 65%);
}
/* Video background → no ken-burns on the container; cover video, keep left dark for the headline */
.hero--video .hero__bg{animation:none;opacity:1;background:none}
.hero__video{
  position:absolute;inset:0;width:100%;height:100%;z-index:0;
  object-fit:cover;object-position:70% center;opacity:.6;
}
/* Fallback (no image yet): animated accent aurora on warm-black */
.hero:not(.hero--media) .hero__bg{
  background:
    radial-gradient(40% 55% at 18% 30%, rgba(229,67,42,.20), transparent 60%),
    radial-gradient(45% 60% at 82% 70%, rgba(249,244,235,.07), transparent 60%),
    radial-gradient(35% 50% at 60% 12%, rgba(229,67,42,.10), transparent 60%);
  animation:hero-aurora 18s ease-in-out infinite alternate;
}
/* Film grain overlay (both modes) */
.hero__bg-grain{
  position:absolute;inset:-50%;opacity:.05;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  animation:hero-grain 1.2s steps(4) infinite;
}
@keyframes hero-kenburns{0%{transform:scale(1.06) translate(0,0)}100%{transform:scale(1.16) translate(-2%,-2%)}}
@keyframes hero-aurora{0%{transform:translate(0,0) scale(1)}100%{transform:translate(2%,-2%) scale(1.1)}}
@keyframes hero-grain{0%{transform:translate(0,0)}25%{transform:translate(-4%,2%)}50%{transform:translate(3%,-3%)}75%{transform:translate(-2%,4%)}100%{transform:translate(2%,-2%)}}

@media(prefers-reduced-motion:reduce){
  .brandmark__ring,.brandmark__spark,.brandmark__orbit,
  .hero--media .hero__bg,.hero:not(.hero--media) .hero__bg,.hero__bg-grain{animation:none}
  .brandmark__ring{stroke-dashoffset:0}
  .js .reveal{opacity:1;transform:none;transition:none}
}

/* ---------- Responsive ---------- */
@media(max-width:760px){
  .wrap{padding:0 20px}
  .hero__foot{flex-direction:column;align-items:flex-start;gap:24px}
  .form--grid{grid-template-columns:1fr}
  .legal{grid-template-columns:1fr;padding-left:20px;padding-right:20px}
  .contact{grid-template-columns:1fr}
  .gamesnav__list a{padding:12px 12px}
  .newsletter__row{flex-direction:column;align-items:flex-start}
  .statusbar__brand{display:none}
  .header__row{padding:0 16px}
}
