/* =====================================================================
   LA RIVIERA CASINO — Shared stylesheet
   Font override: Cormorant Garamond (display) + DM Sans (UI)
   Built on the Casinoshka design system foundations (tokens, type, gold
   foil, card-suit iconography). The felt-green field is rotated toward a
   Mediterranean NAVY / AZURE to evoke the French Riviera, while gold +
   warm ivory + wine accents are kept from the bound system.
   Requires: colors_and_type.css (DS tokens) loaded first.
   ===================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,600&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&display=swap');

:root{
  /* font override — replaces Bodoni Moda + Hanken Grotesk */
  --font-display:'Cormorant Garamond','Didot',Georgia,serif;
  --font-ui:'DM Sans',system-ui,-apple-system,'Segoe UI',sans-serif;
  --font-num:'Cormorant Garamond',Georgia,serif;
  /* ---- Riviera base: near-black with a cool navy undertone ---- */
  --riv-ink-900:#05070D;
  --riv-ink-800:#080B14;   /* page base */
  --riv-navy-900:#0A101F;  /* deep sea */
  --riv-navy-800:#0E1626;  /* surface */
  --riv-navy-700:#14203A;  /* raised card */
  --riv-navy-600:#1B2C4A;  /* hover / highest lift */
  --riv-navy-500:#24385E;

  /* ---- Azure (Mediterranean highlight) ---- */
  --riv-azure-700:#163A5F;
  --riv-azure-600:#1F5C8F;
  --riv-azure-500:#2E86C1;
  --riv-azure-400:#4AA3DF;
  --riv-azure-300:#7FC2EE;

  /* ---- Wine / burgundy (heat, alerts, accent detail) ---- */
  --riv-wine-700:#5E1626;
  --riv-wine-600:#7B1E33;
  --riv-wine-500:#9B2742;
  --riv-wine-400:#C13B5B;

  /* ---- Gold + ivory inherited from DS, aliased for clarity ---- */
  --riv-gold:var(--gold-500);
  --riv-gold-soft:var(--gold-300);
  --riv-ivory:var(--fg-1);

  /* hairlines tuned for navy */
  --riv-line:rgba(212,175,55,.16);
  --riv-line-soft:rgba(246,241,228,.08);
  --riv-line-strong:rgba(212,175,55,.42);
  --riv-line-azure:rgba(74,163,223,.28);

  --riv-glow-azure:0 0 0 1px rgba(46,134,193,.40),0 12px 34px rgba(46,134,193,.22);
  --riv-shadow-3:0 28px 70px rgba(0,0,0,.62);

  --riv-maxw:1200px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;padding:0}
body{
  font-family:var(--font-ui);
  color:var(--riv-ivory);
  font-size:17px;line-height:1.65;
  background:
    radial-gradient(110% 70% at 50% -8%, rgba(46,134,193,.14), transparent 58%),
    radial-gradient(80% 50% at 80% 4%, rgba(212,175,55,.07), transparent 55%),
    var(--riv-ink-800);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:var(--font-ui);cursor:pointer;border:none;background:none}
h1,h2,h3,h4{margin:0}
p{margin:0}
ul{margin:0}

.wrap{max-width:var(--riv-maxw);margin:0 auto;padding:0 22px}
.section-skip{height:0}

/* heading scale */
h1,.h1{font-family:var(--font-display);font-weight:600;font-size:clamp(34px,6.4vw,58px);line-height:1.04;letter-spacing:-.01em}
h2,.h2{font-family:var(--font-display);font-weight:600;font-size:clamp(26px,4.8vw,38px);line-height:1.08;letter-spacing:-.005em}
h3,.h3{font-family:var(--font-ui);font-weight:700;font-size:clamp(18px,3.4vw,22px);line-height:1.25}
.eyebrow{font-size:12px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--riv-gold-soft)}
.lede{font-size:clamp(16px,3.6vw,19px);line-height:1.6;color:var(--fg-2)}
.muted{color:var(--fg-2)}
.foil{background:var(--gold-foil);-webkit-background-clip:text;background-clip:text;color:transparent}
.azure-text{color:var(--riv-azure-400)}
.num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}

/* shimmer for hero foil */
.shimmer{background:linear-gradient(110deg,#A8801F 0%,#D4AF37 28%,#FBEFC4 47%,#D4AF37 66%,#A8801F 100%);
  background-size:240% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;
  animation:rivSheen 7s linear infinite}
@keyframes rivSheen{0%{background-position:140% 0}100%{background-position:-40% 0}}

/* ============ BUTTONS ============ */
.btn{font-weight:700;font-size:15px;letter-spacing:.02em;border-radius:var(--r-pill);white-space:nowrap;
  padding:15px 28px;display:inline-flex;align-items:center;justify-content:center;gap:10px;line-height:1;
  transition:transform var(--dur) var(--ease-lux),box-shadow var(--dur),filter var(--dur),background var(--dur),border-color var(--dur)}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--gold-foil);color:var(--fg-on-gold);box-shadow:var(--glow-gold)}
.btn-primary:hover{filter:brightness(1.07);transform:translateY(-2px)}
.btn-secondary{background:transparent;color:var(--riv-gold-soft);border:1px solid var(--riv-line-strong)}
.btn-secondary:hover{background:rgba(212,175,55,.09)}
.btn-azure{background:linear-gradient(160deg,var(--riv-azure-500),var(--riv-azure-700));color:#fff;box-shadow:var(--riv-glow-azure)}
.btn-azure:hover{filter:brightness(1.08);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--riv-ivory);border:1px solid var(--riv-line-soft)}
.btn-ghost:hover{color:var(--riv-gold-soft);border-color:var(--riv-line)}
.btn-block{width:100%}
.btn-sm{padding:10px 18px;font-size:13px}
.btn:focus-visible{outline:2px solid var(--gold-400);outline-offset:2px}

/* ============ BADGES ============ */
.badge{font-size:11px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;padding:5px 11px;border-radius:var(--r-pill);
  display:inline-flex;align-items:center;gap:6px;line-height:1}
.badge-gold{background:var(--gold-foil);color:var(--fg-on-gold)}
.badge-azure{background:var(--riv-azure-600);color:#fff}
.badge-wine{background:var(--riv-wine-600);color:#fff}
.badge-outline{background:transparent;color:var(--riv-gold-soft);border:1px solid var(--riv-line-strong)}

/* ============ HEADER ============ */
.hdr{position:sticky;top:0;z-index:50;backdrop-filter:blur(16px);
  background:rgba(5,7,13,.78);border-bottom:1px solid var(--riv-line)}
.hdr-in{display:flex;align-items:center;gap:24px;height:74px}
.brand{display:flex;align-items:center;gap:11px;flex-shrink:0}
.brand .mark{width:42px;height:42px;flex-shrink:0}
.brand .wm{display:flex;flex-direction:column;line-height:1}
.brand .wm .a{font-size:9px;letter-spacing:.42em;color:var(--riv-gold-soft);font-weight:600;text-transform:uppercase;margin-bottom:2px}
.brand .wm .b{font-family:var(--font-display);font-weight:700;font-size:21px;letter-spacing:.04em}
.nav{display:flex;gap:22px;margin-left:14px}
.nav a{font-size:14px;font-weight:600;color:var(--fg-2);position:relative;padding:8px 0;transition:color var(--dur)}
.nav a:hover{color:var(--riv-ivory)}
.nav a.active{color:var(--riv-gold-soft)}
.nav a.active::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--gold-foil);border-radius:2px}
.hdr-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.hdr-right .btn{padding:11px 18px;font-size:13px}
.burger{display:none;width:44px;height:44px;border-radius:var(--r-md);border:1px solid var(--riv-line);
  align-items:center;justify-content:center;flex-direction:column;gap:4px;margin-left:auto}
.burger span{width:18px;height:2px;background:var(--riv-gold-soft);border-radius:2px;transition:all var(--dur)}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:60;display:none}
.drawer.open{display:block}
.drawer-scrim{position:absolute;inset:0;background:rgba(3,5,10,.74);backdrop-filter:blur(5px);animation:rivFade .25s var(--ease-out)}
.drawer-panel{position:absolute;top:0;right:0;height:100%;width:min(86vw,360px);background:var(--riv-navy-900);
  border-left:1px solid var(--riv-line);padding:22px;display:flex;flex-direction:column;gap:8px;
  box-shadow:var(--riv-shadow-3);animation:rivSlide .3s var(--ease-out);overflow-y:auto}
@keyframes rivSlide{from{transform:translateX(100%)}to{transform:none}}
@keyframes rivFade{from{opacity:0}to{opacity:1}}
.drawer-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.drawer-close{width:40px;height:40px;border-radius:var(--r-md);border:1px solid var(--riv-line);color:var(--riv-gold-soft);font-size:22px}
.drawer-panel a.dlink{padding:14px 14px;border-radius:var(--r-md);font-size:16px;font-weight:600;color:var(--fg-1);
  display:flex;align-items:center;gap:12px;transition:background var(--dur)}
.drawer-panel a.dlink:hover,.drawer-panel a.dlink.active{background:var(--riv-navy-700);color:var(--riv-gold-soft)}
.drawer-cta{margin-top:auto;display:flex;flex-direction:column;gap:10px;padding-top:18px;border-top:1px solid var(--riv-line-soft)}

/* ============ BREADCRUMB ============ */
.crumbs{padding:18px 0 0}
.crumbs ol{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:13px;color:var(--fg-3)}
.crumbs a{color:var(--fg-2)}
.crumbs a:hover{color:var(--riv-gold-soft)}
.crumbs .sep{color:var(--riv-line-strong)}
.crumbs li[aria-current]{color:var(--riv-gold-soft)}

/* ============ HERO ============ */
.hero{position:relative;padding:54px 0 46px}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:46px;align-items:center}
.hero h1{margin:16px 0 0}
.hero .lede{max-width:520px;margin:20px 0 26px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.hero-notes{display:flex;gap:18px;margin-top:24px;color:var(--fg-3);font-size:13px;flex-wrap:wrap;align-items:center;justify-content:center}
.hero-notes span{display:inline-flex;align-items:center;gap:7px;white-space:nowrap}
.hero-art{position:relative;height:440px;border-radius:var(--r-xl);overflow:hidden;
  border:1px solid var(--riv-line);box-shadow:var(--riv-shadow-3),var(--inset-sheen)}
.hero-art img,.hero-art svg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-floatcard{position:absolute;left:22px;right:22px;bottom:22px;background:rgba(5,7,13,.62);
  backdrop-filter:blur(8px);border:1px solid var(--riv-line-strong);border-radius:var(--r-lg);padding:18px 20px;
  box-shadow:var(--inset-sheen);display:flex;align-items:center;gap:16px}
.hero-floatcard .k{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--riv-gold-soft)}
.hero-floatcard .v{font-family:var(--font-num);font-weight:700;font-size:clamp(22px,3.1vw,32px);line-height:1;margin-top:4px;white-space:nowrap}
.hero-floatcard .div{width:1px;align-self:stretch;background:var(--riv-line)}

/* ============ STAT STRIP ============ */
.strip{border-top:1px solid var(--riv-line);border-bottom:1px solid var(--riv-line);background:var(--riv-navy-900)}
.strip-in{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding:20px 0}
.strip .item .k{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-3)}
.strip .item .v{font-family:var(--font-num);font-weight:700;font-size:clamp(20px,3vw,26px);margin-top:3px}

/* ============ SECTIONS ============ */
.sec{padding:54px 0}
.sec.tight{padding:36px 0}
.sec-head{margin-bottom:26px;max-width:720px}
.sec-head .eyebrow{display:block;margin-bottom:10px}
.sec-head p{margin-top:12px;color:var(--fg-2)}
.divider-suits{display:flex;gap:14px;justify-content:center;color:var(--riv-gold);opacity:.45;font-size:17px;padding:8px 0}

/* prose content */
.prose p{color:var(--fg-2);margin:0 0 16px;max-width:760px}
.prose h2{margin:36px 0 14px}
.prose h3{margin:26px 0 10px;color:var(--riv-ivory)}
.prose ul.bullets{list-style:none;padding:0;margin:0 0 18px;display:flex;flex-direction:column;gap:10px;max-width:760px}
.prose ul.bullets li{position:relative;padding-left:26px;color:var(--fg-2)}
.prose ul.bullets li::before{content:"\2666";position:absolute;left:0;top:1px;color:var(--riv-gold);font-size:14px}

/* ============ CARDS ============ */
.card{background:var(--riv-navy-800);border:1px solid var(--riv-line);border-radius:var(--r-lg);
  box-shadow:var(--shadow-2),var(--inset-sheen);padding:24px}
.card.hoverable{transition:transform var(--dur) var(--ease-lux),box-shadow var(--dur),border-color var(--dur)}
.card.hoverable:hover{transform:translateY(-4px);border-color:var(--riv-line-strong);box-shadow:var(--riv-shadow-3),var(--glow-gold)}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}

/* feature card with icon */
.feature{display:flex;flex-direction:column;gap:12px}
.feature .ic{width:48px;height:48px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;
  background:linear-gradient(160deg,var(--riv-navy-600),var(--riv-navy-900));border:1px solid var(--riv-line);color:var(--riv-gold-soft)}
.feature h3{margin:0}
.feature p{color:var(--fg-2);font-size:15px;margin:0}

/* TOC */
.toc{background:var(--riv-navy-900);border:1px solid var(--riv-line);border-radius:var(--r-lg);padding:8px}
.toc summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px;font-weight:700;font-size:14px;letter-spacing:.04em}
.toc summary::-webkit-details-marker{display:none}
.toc summary .chev{transition:transform var(--dur);color:var(--riv-gold-soft)}
.toc[open] summary .chev{transform:rotate(180deg)}
.toc .toc-list{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;padding:6px 8px 10px}
.toc .toc-list a{font-size:14px;color:var(--fg-2);padding:9px 12px;border-radius:var(--r-sm);transition:all var(--dur);display:flex;align-items:center;gap:9px}
.toc .toc-list a:hover{background:var(--riv-navy-700);color:var(--riv-gold-soft)}
.toc .toc-list a .n{color:var(--riv-gold);font-family:var(--font-num);font-size:12px;width:18px}

/* ============ TABLE ============ */
.tbl{width:100%;border-collapse:collapse;border:1px solid var(--riv-line);border-radius:var(--r-lg);overflow:hidden;font-size:15px}
.tbl thead th{background:var(--riv-navy-700);text-align:left;padding:14px 16px;font-size:12px;letter-spacing:.08em;
  text-transform:uppercase;color:var(--riv-gold-soft);font-weight:700;border-bottom:1px solid var(--riv-line)}
.tbl td{padding:13px 16px;border-bottom:1px solid var(--riv-line-soft);color:var(--fg-1)}
.tbl tbody tr:nth-child(even){background:rgba(20,32,58,.4)}
.tbl tbody tr:last-child td{border-bottom:none}
.tbl tbody tr.total td{background:var(--riv-azure-700);color:#fff;font-weight:700}
.tbl td .num{color:var(--riv-gold-soft);font-weight:600}
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}

/* ============ QUICK FACTS ============ */
.facts{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border:1px solid var(--riv-line);border-radius:var(--r-lg);overflow:hidden}
.facts .f{display:flex;flex-direction:column;gap:4px;padding:16px 18px;border-bottom:1px solid var(--riv-line-soft);border-right:1px solid var(--riv-line-soft)}
.facts .f:nth-child(2n){border-right:none}
.facts .f .k{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-3)}
.facts .f .v{font-size:15px;font-weight:600;color:var(--riv-ivory)}

/* ============ STEPS ============ */
.steps{display:flex;flex-direction:column;gap:14px;counter-reset:s}
.step{display:flex;gap:16px;align-items:flex-start;background:var(--riv-navy-800);border:1px solid var(--riv-line);
  border-radius:var(--r-lg);padding:18px 20px}
.step .n{flex-shrink:0;width:38px;height:38px;border-radius:50%;background:var(--gold-foil);color:var(--fg-on-gold);
  font-family:var(--font-num);font-weight:700;font-size:18px;display:flex;align-items:center;justify-content:center}
.step .c h3{font-size:16px;margin:0 0 4px}
.step .c p{color:var(--fg-2);font-size:14px;margin:0}

/* ============ BONUS / PROMO CARD ============ */
.promo{position:relative;overflow:hidden;background:var(--riv-navy-800);border:1px solid var(--riv-line);
  border-radius:var(--r-lg);padding:26px;box-shadow:var(--shadow-2),var(--inset-sheen);display:flex;flex-direction:column;gap:6px}
.promo.feat{background:linear-gradient(165deg,#14203A,#0A101F);border-color:var(--riv-line-strong)}
.promo .fil{position:absolute;top:-28px;right:-12px;font-size:130px;color:var(--riv-gold);opacity:.08;line-height:1;font-family:var(--font-display)}
.promo .amt{font-family:var(--font-display);font-weight:700;font-size:clamp(30px,5vw,42px);line-height:1;margin:10px 0 2px}
.promo .desc{font-size:14px;color:var(--fg-2);line-height:1.55;margin-top:8px;flex:1}
.promo .foot{margin-top:18px}

/* ============ GAME TILES ============ */
.games{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.tile{border-radius:var(--r-lg);overflow:hidden;background:var(--riv-navy-800);border:1px solid var(--riv-line);
  box-shadow:var(--shadow-2);transition:transform var(--dur) var(--ease-lux),box-shadow var(--dur),border-color var(--dur)}
.tile:hover{transform:translateY(-5px);border-color:var(--riv-line-strong);box-shadow:var(--riv-shadow-3),var(--glow-gold)}
.tile .art{height:150px;position:relative;display:block}
.tile .art img,.tile .art svg{width:100%;height:100%;object-fit:cover}
.tile .topbadge{position:absolute;top:10px;left:10px;z-index:2}
.tile .meta{padding:13px 14px}
.tile .nm{font-size:15px;font-weight:700}
.tile .sub{font-size:12px;color:var(--fg-3);margin-top:3px}

/* ============ PROS / CONS ============ */
.pc{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.pc .col{border-radius:var(--r-lg);padding:22px;border:1px solid var(--riv-line)}
.pc .col.pro{background:linear-gradient(165deg,rgba(46,134,193,.12),transparent)}
.pc .col.con{background:linear-gradient(165deg,rgba(155,39,66,.12),transparent)}
.pc h3{display:flex;align-items:center;gap:10px;margin:0 0 14px;font-size:17px}
.pc ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:11px}
.pc li{position:relative;padding-left:26px;color:var(--fg-2);font-size:15px}
.pc .pro li::before{content:"+";position:absolute;left:0;top:0;color:var(--riv-azure-400);font-weight:700;font-size:17px}
.pc .con li::before{content:"\2013";position:absolute;left:0;top:0;color:var(--riv-wine-400);font-weight:700;font-size:17px}

/* ============ PAYMENT CHIPS ============ */
.pays{display:flex;flex-wrap:wrap;gap:10px}
.paychip{display:flex;align-items:center;gap:9px;background:var(--riv-navy-800);border:1px solid var(--riv-line);
  border-radius:var(--r-md);padding:11px 16px;font-size:14px;font-weight:600}
.paychip .paylogo{height:22px;width:auto;display:block;border-radius:4px}
.paychip .paylogo.sq{width:22px}
.paychip .dot{width:26px;height:26px;border-radius:6px;display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:800;color:#05070D;background-repeat:no-repeat;background-position:center;background-size:16px 16px}
.paychip .dot.pay-visa{background-color:#1a1f71;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2' stroke-linecap='round'><rect x='2.5' y='5' width='19' height='14' rx='2'/><path d='M2.5 10h19'/><path d='M6 15h4'/></svg>")}
.paychip .dot.pay-mc{background-color:#cc0000;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><circle cx='9' cy='12' r='6' fill='%23fff' fill-opacity='.95'/><circle cx='15' cy='12' r='6' fill='%23fff' fill-opacity='.55'/></svg>")}
.paychip .dot.pay-neteller{background-color:#00ac41;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2' stroke-linejoin='round'><path d='M4 7h14a2 2 0 012 2v8a2 2 0 01-2 2H6a2 2 0 01-2-2V7z'/><path d='M4 7V6a2 2 0 012-2h10'/><circle cx='17' cy='13' r='1.4' fill='%23fff'/></svg>")}
.paychip .dot.pay-skrill{background-color:#6f2cff;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2' stroke-linejoin='round'><path d='M4 7h14a2 2 0 012 2v8a2 2 0 01-2 2H6a2 2 0 01-2-2V7z'/><path d='M4 7V6a2 2 0 012-2h10'/><circle cx='17' cy='13' r='1.4' fill='%23fff'/></svg>")}
.paychip .dot.pay-paysafe{background-color:#ee3124;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2'><rect x='3' y='5' width='18' height='14' rx='2'/><circle cx='12' cy='12' r='3.2'/></svg>")}
.paychip .dot.pay-btc{background-color:#f7931a;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><text x='12' y='17' text-anchor='middle' font-family='Arial,sans-serif' font-weight='900' font-size='17' fill='%23fff'>%E2%82%BF</text></svg>")}
.paychip .dot.pay-bank{background-color:#345d9d;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23fff'><path d='M12 2L2 7v1h20V7L12 2zM4 9v9h2V9H4zm5 0v9h2V9H9zm5 0v9h2V9h-2zm5 0v9h2V9h-2zM2 20v2h20v-2H2z'/></svg>")}

/* ============ FAQ ============ */
.faq{display:flex;flex-direction:column;gap:10px;max-width:840px}
.faq details{background:var(--riv-navy-800);border:1px solid var(--riv-line);border-radius:var(--r-lg);overflow:hidden}
.faq summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:18px 20px;font-weight:600;font-size:16px;color:var(--riv-ivory)}
.faq summary::-webkit-details-marker{display:none}
.faq summary .chev{flex-shrink:0;color:var(--riv-gold-soft);transition:transform var(--dur)}
.faq details[open] summary .chev{transform:rotate(180deg)}
.faq .ans{padding:0 20px 18px;color:var(--fg-2);font-size:15px;line-height:1.6}

/* ============ CTA BAND ============ */
.cta-band{position:relative;overflow:hidden;border-radius:var(--r-xl);padding:48px 40px;text-align:center;
  background:linear-gradient(150deg,#14203A 0%,#0A101F 60%);border:1px solid var(--riv-line-strong);box-shadow:var(--inset-sheen)}
.cta-band::before{content:"\2660";position:absolute;font-family:var(--font-display);color:var(--riv-gold);opacity:.06;
  font-size:300px;right:-40px;top:-90px;line-height:1}
.cta-band h2{position:relative}
.cta-band p{position:relative;color:var(--fg-2);margin:14px auto 24px;max-width:560px}
.cta-band .hero-cta{position:relative;justify-content:center}

/* page card links */
.pagecards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.pagecard{display:flex;flex-direction:column;gap:8px;background:var(--riv-navy-800);border:1px solid var(--riv-line);
  border-radius:var(--r-lg);padding:22px;transition:transform var(--dur) var(--ease-lux),border-color var(--dur),box-shadow var(--dur)}
.pagecard:hover{transform:translateY(-4px);border-color:var(--riv-line-strong);box-shadow:var(--glow-gold)}
.pagecard .ic{color:var(--riv-gold-soft);margin-bottom:4px}
.pagecard h3{font-size:17px}
.pagecard p{font-size:14px;color:var(--fg-2);margin:0;flex:1}
.pagecard .go{font-size:13px;font-weight:700;color:var(--riv-gold-soft);display:inline-flex;align-items:center;gap:6px;margin-top:6px}

/* responsible-gambling note */
.rg-note{display:flex;align-items:flex-start;gap:14px;background:var(--riv-navy-900);border:1px solid var(--riv-line);
  border-left:3px solid var(--riv-gold);border-radius:var(--r-md);padding:16px 18px;font-size:14px;color:var(--fg-2)}
.rg-note .eighteen{flex-shrink:0;width:30px;height:30px;border-radius:50%;border:1.5px solid var(--riv-gold-soft);
  display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--riv-gold-soft)}

/* ============ FOOTER ============ */
.ftr{margin-top:30px;padding:52px 0 28px;border-top:1px solid var(--riv-line);background:var(--riv-navy-900)}
.ftr-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:32px;padding-bottom:28px;border-bottom:1px solid var(--riv-line)}
.ftr .blurb{font-size:14px;color:var(--fg-3);line-height:1.65;max-width:300px;margin-top:14px}
.ftr .col .ttl{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--fg-3);margin:0 0 14px;font-weight:700}
.ftr .col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.ftr .col li a{font-size:14px;color:var(--fg-2);transition:color var(--dur)}
.ftr .col li a:hover{color:var(--riv-gold-soft)}
.ftr-bottom{display:flex;align-items:center;justify-content:space-between;gap:18px;padding-top:22px;flex-wrap:wrap;color:var(--fg-3);font-size:13px}
.ftr-bottom .eighteen{width:26px;height:26px;border-radius:50%;border:1.5px solid var(--fg-3);display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;margin-right:8px}
.ftr-rg{display:flex;align-items:center;flex-wrap:wrap;gap:6px}

/* fade-in entrance */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s var(--ease-out),transform .6s var(--ease-out)}
.reveal.in{opacity:1;transform:none}

/* ============ RESPONSIVE ============ */
@media (max-width:920px){
  .hero-grid{grid-template-columns:1fr;gap:30px}
  .hero-art{height:300px;order:-1}
  .grid-3,.grid-4,.pagecards,.promos{grid-template-columns:1fr}
  .games{grid-template-columns:repeat(2,1fr)}
  .promos{grid-template-columns:1fr}
  .ftr-top{grid-template-columns:1fr 1fr}
  .strip-in{grid-template-columns:repeat(2,1fr)}
  .pc{grid-template-columns:1fr}
  .nav,.hdr-right .btn{display:none}
  .burger{display:flex}
  .toc .toc-list{grid-template-columns:1fr}
}
@media (max-width:560px){
  .wrap{padding:0 16px}
  .grid-2{grid-template-columns:1fr}
  .facts{grid-template-columns:1fr}
  .facts .f{border-right:none}
  .games{grid-template-columns:repeat(2,1fr)}
  .ftr-top{grid-template-columns:1fr}
  .cta-band{padding:36px 22px}
  .sec{padding:42px 0}
}
@media (prefers-reduced-motion:reduce){
  .shimmer{animation:none}
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

.promos{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
