/* =========================================================
   SAPERPLAY — MINES REVIEW PORTAL
   Shared stylesheet for all pages
   ========================================================= */

:root{
  /* palette */
  --bg:            #f6f7f3;
  --bg-warm:       #fbfaf6;
  --surface:       #ffffff;
  --surface-tint:  #f0efe7;
  --ink:           #0e1714;
  --ink-2:         #2a3733;
  --muted:         #6c7a74;
  --line:          #e5e6df;

  --emerald:       #0fb37a;
  --emerald-deep:  #057a52;
  --emerald-soft:  #d6f3e6;

  --gold:          #e3a72c;
  --gold-deep:     #a26b00;
  --gold-soft:     #fbe9bf;

  --crimson:       #e0394d;
  --crimson-soft:  #ffd9de;

  --ink-grad: linear-gradient(135deg,#0e1714 0%, #1e2a26 100%);
  --gem-grad: linear-gradient(135deg,#0fb37a 0%, #28d4a0 50%, #ffd271 100%);
  --shine:    linear-gradient(110deg,transparent 30%,rgba(255,255,255,.45) 50%,transparent 70%);

  /* typography */
  --f-display:'Unbounded', 'Manrope', system-ui, sans-serif;
  --f-body:   'Manrope',   system-ui, sans-serif;

  /* radius & motion */
  --r-sm: 10px;
  --r-md: 16px;
  --r-lg: 22px;
  --r-xl: 32px;

  --shadow-1: 0 1px 2px rgba(14,23,20,.04), 0 4px 14px rgba(14,23,20,.06);
  --shadow-2: 0 6px 24px rgba(14,23,20,.08), 0 24px 60px -10px rgba(14,23,20,.10);
  --shadow-em: 0 12px 40px -12px rgba(15,179,122,.45);

  --ease: cubic-bezier(.22,.61,.36,1);
}

/* =========================================================
   RESET & BASE
   ========================================================= */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--f-body);
  background:var(--bg);
  color:var(--ink);
  line-height:1.6;
  font-size:16px;
  font-weight:400;
  overflow-x:hidden;
  position:relative;
  background-image:
    radial-gradient(1200px 600px at 80% -10%, #e7f7ee 0%, transparent 60%),
    radial-gradient(900px 500px at -10% 30%, #fff3d8 0%, transparent 55%);
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul,ol{list-style:none}

::selection{background:var(--emerald);color:#fff}

/* subtle grain overlay */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.35;
  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'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .035 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

.container{max-width:1240px;margin:0 auto;padding:0 22px;position:relative;z-index:2}
.container-narrow{max-width:920px;margin:0 auto;padding:0 22px;position:relative;z-index:2}

/* =========================================================
   TYPOGRAPHY
   ========================================================= */
h1,h2,h3,h4{font-family:var(--f-display);font-weight:600;line-height:1.15;letter-spacing:-.02em;color:var(--ink)}
h1{font-size:clamp(2.2rem, 4.8vw, 3.7rem);font-weight:700;letter-spacing:-.03em}
h2{font-size:clamp(1.65rem, 3vw, 2.4rem)}
h3{font-size:clamp(1.2rem, 1.7vw, 1.45rem);letter-spacing:-.015em}
h4{font-size:1.05rem;font-weight:600;letter-spacing:0}

p{margin:0 0 1em}
.lead{font-size:1.12rem;color:var(--ink-2);max-width:62ch}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--f-body);font-weight:600;font-size:.78rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--emerald-deep);
  background:var(--emerald-soft);padding:8px 14px;border-radius:99px;
}
.eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--emerald);box-shadow:0 0 0 4px rgba(15,179,122,.18)}

article p,article li{color:var(--ink-2)}
article a{color:var(--emerald-deep);font-weight:600;border-bottom:1px solid rgba(15,179,122,.3);transition:.2s}
article a:hover{color:var(--emerald);border-bottom-color:var(--emerald)}

article h2{margin:2.2em 0 .7em;position:relative;padding-left:18px}
article h2::before{content:"";position:absolute;left:0;top:.32em;bottom:.32em;width:5px;border-radius:99px;background:var(--gem-grad)}
article h3{margin:1.6em 0 .55em;color:var(--ink)}
article ul,article ol{margin:.6em 0 1.4em 0;padding-left:0}
article ul li,article ol li{position:relative;padding:.35em 0 .35em 30px;color:var(--ink-2)}
article ul li::before{
  content:"";position:absolute;left:6px;top:.85em;width:10px;height:10px;
  background:var(--gem-grad);
  clip-path:polygon(50% 0,100% 50%,50% 100%,0 50%);
  box-shadow:0 0 0 3px rgba(15,179,122,.12);
}
article ol{counter-reset:n}
article ol li{counter-increment:n;padding-left:42px}
article ol li::before{
  content:counter(n);position:absolute;left:0;top:.2em;width:28px;height:28px;
  background:var(--ink);color:#fff;border-radius:8px;
  display:grid;place-items:center;font-family:var(--f-display);font-size:.78rem;font-weight:600;
}

/* =========================================================
   HEADER & NAV
   ========================================================= */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(246,247,243,.78);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid rgba(14,23,20,.06);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{display:flex;align-items:center;gap:12px;font-family:var(--f-display);font-weight:700;font-size:1.25rem;letter-spacing:-.02em}
.logo img{width:38px;height:38px;border-radius:10px;box-shadow:var(--shadow-1)}
.logo span{background:var(--ink-grad);-webkit-background-clip:text;background-clip:text;color:transparent}

.nav-links{display:flex;align-items:center;gap:6px}
.nav-links a{
  font-weight:500;font-size:.94rem;color:var(--ink-2);
  padding:10px 14px;border-radius:10px;transition:.2s var(--ease);position:relative;
}
.nav-links a:hover{color:var(--ink);background:rgba(14,23,20,.04)}
.nav-links a.is-active{color:var(--emerald-deep);background:var(--emerald-soft)}

.nav-cta{
  margin-left:8px;
  display:inline-flex;align-items:center;gap:8px;
  background:var(--ink);
  color:#fff !important;
  font-weight:600;
  font-size:.9rem;
  padding:11px 18px;border-radius:11px;transition:.25s var(--ease);
  box-shadow:0 4px 14px -4px rgba(14,23,20,.4);
}
.nav-cta:hover{background:var(--emerald-deep);transform:translateY(-1px);box-shadow:var(--shadow-em); color: #2a3733 !important;}
.nav-cta::after{content:"→";font-size:1.05em;transition:.25s}
.nav-cta:hover::after{transform:translateX(3px)}

.menu-toggle{display:none;width:42px;height:42px;border-radius:10px;background:var(--surface);box-shadow:var(--shadow-1);position:relative}
.menu-toggle span,.menu-toggle span::before,.menu-toggle span::after{
  content:"";position:absolute;left:50%;top:50%;width:18px;height:2px;
  background:var(--ink);border-radius:2px;transform:translate(-50%,-50%);transition:.3s
}
.menu-toggle span::before{top:-6px}
.menu-toggle span::after{top:6px}
.menu-toggle.is-open span{background:transparent}
.menu-toggle.is-open span::before{top:0;transform:rotate(45deg)}
.menu-toggle.is-open span::after{top:0;transform:rotate(-45deg)}

@media (max-width:920px){
  .menu-toggle{display:block}
  .nav-links{
    position:fixed;top:72px;right:0;left:0;background:var(--surface);
    flex-direction:column;align-items:stretch;gap:0;padding:14px 22px 22px;
    border-bottom:1px solid var(--line);
    transform:translateY(-110%);transition:.35s var(--ease);box-shadow:var(--shadow-2);
  }
  .nav-links.is-open{transform:translateY(0)}
  .nav-links a{padding:14px 12px;border-radius:8px;font-size:1rem}
  .nav-links .nav-cta{margin:8px 0 0;justify-content:center;padding:14px 18px}
}

/* =========================================================
   BUTTONS
   ========================================================= */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--f-body);font-weight:600;font-size:1rem;
  padding:15px 26px;border-radius:14px;transition:.25s var(--ease);
  position:relative;overflow:hidden;isolation:isolate;
}
.btn--primary{background:var(--ink);color:#fff;box-shadow:0 8px 24px -10px rgba(14,23,20,.5)}
.btn--primary::before{
  content:"";position:absolute;inset:0;background:var(--gem-grad);opacity:0;transition:.35s;z-index:-1
}
.btn--primary:hover{transform:translateY(-2px);color:#0e1714;box-shadow:var(--shadow-em)}
.btn--primary:hover::before{opacity:1}

.btn--ghost{background:var(--surface);color:var(--ink);border:1px solid var(--line)}
.btn--ghost:hover{border-color:var(--ink);transform:translateY(-1px)}

.btn--gold{background:var(--gold);color:#3a2700}
.btn--gold:hover{background:var(--gold-deep);color:#fff;transform:translateY(-2px)}

.btn--lg{padding:17px 30px;font-size:1.05rem;border-radius:16px}

/* =========================================================
   HERO
   ========================================================= */
.hero{padding:60px 0 90px;position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
@media (max-width:980px){.hero-grid{grid-template-columns:1fr;gap:50px}}

.hero h1{margin:18px 0 22px}
.hero .accent{
  background:var(--gem-grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  position:relative;display:inline-block;
}
.hero .lead{font-size:1.18rem;margin-bottom:32px}

.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:36px}

.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:520px}
.hero-stat{
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-md);padding:16px 18px;
  transition:.3s var(--ease);
}
.hero-stat:hover{transform:translateY(-3px);border-color:var(--emerald);box-shadow:var(--shadow-1)}
.hero-stat .num{font-family:var(--f-display);font-size:1.55rem;font-weight:700;background:var(--gem-grad);-webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:-.02em}
.hero-stat .label{font-size:.78rem;color:var(--muted);margin-top:2px;font-weight:500}

/* Mines board on hero */
.mines-board{
  position:relative;aspect-ratio:1/1;max-width:520px;margin:0 auto;
  background:var(--surface);border-radius:var(--r-xl);
  padding:26px;
  box-shadow:var(--shadow-2);
  border:1px solid var(--line);
}
.mines-board::before{
  content:"";position:absolute;inset:-1px;border-radius:var(--r-xl);padding:1px;
  background:linear-gradient(135deg,rgba(15,179,122,.6),rgba(255,210,113,.4),transparent 60%);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;
}
.mines-board-head{
  display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;
  font-family:var(--f-display);font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);
}
.mines-board-head .multi{
  font-size:1rem;color:var(--ink);background:var(--gold-soft);padding:5px 12px;border-radius:99px;letter-spacing:0;text-transform:none;font-weight:700;
}
.mines-board-head .multi b{color:var(--gold-deep);margin-right:5px}

.mines-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;height:calc(100% - 90px)}
.mine-cell{
  position:relative;background:linear-gradient(180deg,#f8f9f3 0%, #ebebe1 100%);
  border-radius:14px;cursor:pointer;
  display:grid;place-items:center;
  transition:.4s var(--ease);overflow:hidden;
  border:1px solid rgba(14,23,20,.04);
}
.mine-cell::after{
  content:"";position:absolute;inset:0;background:var(--shine);
  transform:translateX(-100%);transition:.6s;pointer-events:none;
}
.mine-cell:hover::after{transform:translateX(100%)}
.mine-cell:hover{transform:translateY(-2px);box-shadow:0 6px 16px -8px rgba(14,23,20,.25)}
.mine-cell .icon{font-size:1.6rem;opacity:0;transform:scale(.4) rotate(-30deg);transition:.4s cubic-bezier(.34,1.56,.64,1)}

.mine-cell.is-gem{background:linear-gradient(180deg,#cdf3df,#7be3b7);border-color:rgba(5,122,82,.25)}
.mine-cell.is-gem .icon{opacity:1;transform:scale(1) rotate(0)}
.mine-cell.is-gem .icon::before{content:"◆";color:var(--emerald-deep);text-shadow:0 0 18px rgba(15,179,122,.5)}

.mine-cell.is-mine{background:linear-gradient(180deg,#ffd6dc,#ff95a3);border-color:rgba(224,57,77,.4)}
.mine-cell.is-mine .icon{opacity:1;transform:scale(1) rotate(0)}
.mine-cell.is-mine .icon::before{content:"●";color:var(--crimson);text-shadow:0 0 16px rgba(224,57,77,.6)}

.mine-cell.is-gold{background:linear-gradient(180deg,#fff0c1,#ffd271);border-color:rgba(162,107,0,.3)}
.mine-cell.is-gold .icon{opacity:1;transform:scale(1) rotate(0)}
.mine-cell.is-gold .icon::before{content:"★";color:var(--gold-deep);text-shadow:0 0 18px rgba(227,167,44,.55)}

@keyframes pulseSoft{0%,100%{box-shadow:0 0 0 0 rgba(15,179,122,.4)}50%{box-shadow:0 0 0 10px rgba(15,179,122,0)}}
.mine-cell.is-pulse{animation:pulseSoft 2.4s ease-in-out infinite}

/* floating gems */
.float-gem{position:absolute;font-size:1.2rem;opacity:.55;pointer-events:none;animation:floatY 7s ease-in-out infinite}
.float-gem.g1{top:8%;left:-3%;color:var(--emerald);animation-delay:-2s}
.float-gem.g2{bottom:12%;right:-2%;color:var(--gold);animation-delay:-4s}
.float-gem.g3{top:30%;right:-4%;color:var(--emerald);animation-delay:-1s;font-size:.9rem}
@keyframes floatY{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-22px) rotate(15deg)}}

/* =========================================================
   SECTIONS
   ========================================================= */
section{padding:80px 0;position:relative}
.section-head{max-width:740px;margin:0 auto 56px;text-align:center}
.section-head .eyebrow{margin-bottom:16px}
.section-head h2{margin-bottom:14px}
.section-head p{color:var(--muted);font-size:1.08rem;margin:0}
.section-tinted{background:linear-gradient(180deg,transparent,rgba(255,255,255,.55) 30%, rgba(255,255,255,.55) 70%, transparent)}

/* =========================================================
   FEATURE GRID
   ========================================================= */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:880px){.feature-grid{grid-template-columns:1fr 1fr}}
@media (max-width:580px){.feature-grid{grid-template-columns:1fr}}

.feature-card{
  background:var(--surface);border-radius:var(--r-lg);padding:30px 26px;
  border:1px solid var(--line);transition:.35s var(--ease);
  position:relative;overflow:hidden;
}
.feature-card::before{
  content:"";position:absolute;top:-1px;left:24px;right:24px;height:3px;
  background:var(--gem-grad);border-radius:0 0 99px 99px;transform:scaleX(0);transform-origin:left;transition:.45s var(--ease);
}
.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-2);border-color:transparent}
.feature-card:hover::before{transform:scaleX(1)}

.feature-icon{
  width:54px;height:54px;border-radius:14px;
  background:var(--surface-tint);
  display:grid;place-items:center;margin-bottom:20px;
  font-size:1.45rem;font-family:var(--f-display);font-weight:700;
  color:var(--emerald-deep);
  transition:.35s var(--ease);
}
.feature-card:hover .feature-icon{background:var(--emerald-soft);transform:rotate(-6deg) scale(1.05)}

.feature-card h3{margin-bottom:10px}
.feature-card p{color:var(--ink-2);font-size:.95rem;line-height:1.55;margin:0}

/* =========================================================
   PROVIDERS / CARDS
   ========================================================= */
.providers-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media (max-width:980px){.providers-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:680px){.providers-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:420px){.providers-grid{grid-template-columns:1fr}}

.provider-card{
  background:var(--surface);border-radius:var(--r-lg);padding:24px 20px;
  border:1px solid var(--line);text-align:center;
  transition:.35s var(--ease);position:relative;overflow:hidden;
  display:flex;flex-direction:column;align-items:center;gap:14px;
}
.provider-card::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 50% 0%,rgba(15,179,122,.12),transparent 70%);
  opacity:0;transition:.4s;pointer-events:none;
}
.provider-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-2);border-color:transparent}
.provider-card:hover::after{opacity:1}

.provider-logo{
  width:96px;height:96px;border-radius:18px;background:var(--surface-tint);
  display:grid;place-items:center;padding:14px;
  transition:.35s var(--ease);
}
.provider-card:hover .provider-logo{background:#fff;transform:scale(1.06);box-shadow:0 6px 16px -8px rgba(14,23,20,.18)}
.provider-logo img{width:100%;height:100%;object-fit:contain}

.provider-card h3{font-size:1.08rem;margin:0}
.provider-card .meta{font-size:.82rem;color:var(--muted);margin:0}
.provider-card .rtp-mini{
  margin-top:auto;display:inline-flex;align-items:center;gap:6px;
  background:var(--emerald-soft);color:var(--emerald-deep);
  padding:5px 11px;border-radius:99px;font-size:.78rem;font-weight:700;
}

/* Detailed provider review (used on providers.html) */
.provider-review{
  background:var(--surface);border-radius:var(--r-xl);
  border:1px solid var(--line);overflow:hidden;
  margin-bottom:32px;transition:.3s var(--ease);
}
.provider-review:hover{box-shadow:var(--shadow-2)}
.review-head{
  display:grid;grid-template-columns:120px 1fr auto;gap:24px;align-items:center;
  padding:24px 30px;border-bottom:1px solid var(--line);background:var(--bg-warm);
}
@media (max-width:680px){.review-head{grid-template-columns:80px 1fr;gap:16px;padding:20px}}
.review-head .logo-cell{
  width:120px;height:120px;border-radius:20px;background:#fff;
  display:grid;place-items:center;padding:16px;border:1px solid var(--line);
}
@media (max-width:680px){.review-head .logo-cell{width:80px;height:80px;padding:10px}}
.review-head .logo-cell img{width:100%;height:100%;object-fit:contain}
.review-head h2{margin:0 0 6px;font-size:1.65rem}
.review-head .tagline{color:var(--muted);font-size:.95rem;margin:0}
.review-head .rating{
  font-family:var(--f-display);font-size:2rem;font-weight:700;
  background:var(--gem-grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  text-align:center;
}
.review-head .rating small{display:block;font-size:.7rem;color:var(--muted);font-weight:500;letter-spacing:.1em}
@media (max-width:680px){.review-head .rating{grid-column:span 2;font-size:1.5rem;text-align:left}}

.review-body{padding:30px;display:grid;grid-template-columns:1.4fr 1fr;gap:36px}
@media (max-width:780px){.review-body{grid-template-columns:1fr;padding:24px}}
.review-body p{color:var(--ink-2)}
.review-body h3{margin:0 0 12px;font-size:1.15rem}

.spec-list{display:grid;gap:10px}
.spec-row{display:flex;justify-content:space-between;gap:12px;padding:10px 14px;background:var(--bg-warm);border-radius:10px;font-size:.92rem}
.spec-row b{color:var(--ink);font-weight:600}
.spec-row span{color:var(--muted)}

.proscons{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:18px}
@media (max-width:480px){.proscons{grid-template-columns:1fr}}
.proscons .col{background:var(--bg-warm);border-radius:14px;padding:16px 18px}
.proscons h4{font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:10px}
.proscons .pros h4{color:var(--emerald-deep)}
.proscons .cons h4{color:var(--crimson)}
.proscons li{font-size:.9rem;padding:4px 0 4px 20px;position:relative;color:var(--ink-2)}
.proscons .pros li::before{content:"+";position:absolute;left:0;top:4px;color:var(--emerald-deep);font-weight:700}
.proscons .cons li::before{content:"−";position:absolute;left:0;top:4px;color:var(--crimson);font-weight:700}

/* =========================================================
   COMPARISON TABLE
   ========================================================= */
.table-wrap{overflow-x:auto;border-radius:var(--r-lg);box-shadow:var(--shadow-1);background:var(--surface);border:1px solid var(--line)}
.compare-table{width:100%;border-collapse:collapse;min-width:680px}
.compare-table th,.compare-table td{padding:16px 18px;text-align:left;font-size:.92rem;border-bottom:1px solid var(--line)}
.compare-table thead th{
  background:var(--ink-grad);color:#fff;font-family:var(--f-display);font-weight:600;
  font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;border-bottom:none;
}
.compare-table thead th:first-child{border-radius:var(--r-lg) 0 0 0}
.compare-table thead th:last-child{border-radius:0 var(--r-lg) 0 0}
.compare-table tbody tr{transition:.2s}
.compare-table tbody tr:hover{background:var(--bg-warm)}
.compare-table tbody tr:last-child td{border-bottom:none}
.compare-table .name{display:flex;align-items:center;gap:12px;font-weight:600;color:var(--ink)}
.compare-table .name img{width:36px;height:36px;border-radius:9px;background:var(--surface-tint);padding:4px}
.compare-table .pill{
  display:inline-flex;align-items:center;
  background:var(--emerald-soft);color:var(--emerald-deep);
  padding:4px 10px;border-radius:99px;font-weight:700;font-size:.82rem;
}
.compare-table .pill.gold{background:var(--gold-soft);color:var(--gold-deep)}
.compare-table .pill.red{background:var(--crimson-soft);color:var(--crimson)}

/* =========================================================
   PROGRESS BARS (RTP visual)
   ========================================================= */
.rtp-bars{display:grid;gap:14px}
.rtp-bar{
  background:var(--surface);border:1px solid var(--line);border-radius:14px;
  padding:14px 18px;
}
.rtp-bar-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:.92rem}
.rtp-bar-head b{font-family:var(--f-display);color:var(--emerald-deep);font-weight:700;letter-spacing:-.01em}
.rtp-track{height:10px;background:var(--surface-tint);border-radius:99px;overflow:hidden;position:relative}
.rtp-fill{
  height:100%;background:var(--gem-grad);border-radius:99px;
  width:0;transition:width 1.4s cubic-bezier(.22,.61,.36,1);
  position:relative;
}
.rtp-fill::after{
  content:"";position:absolute;inset:0;background:var(--shine);
  animation:shineMove 3s linear infinite;
}
@keyframes shineMove{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}

/* =========================================================
   STEPS
   ========================================================= */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:s}
@media (max-width:880px){.steps{grid-template-columns:1fr 1fr}}
@media (max-width:480px){.steps{grid-template-columns:1fr}}

.step{
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:26px 22px;position:relative;
  transition:.3s var(--ease);counter-increment:s;
}
.step:hover{transform:translateY(-3px);box-shadow:var(--shadow-1);border-color:var(--emerald)}
.step::before{
  content:"0" counter(s);position:absolute;top:18px;right:20px;
  font-family:var(--f-display);font-size:2.1rem;font-weight:700;color:var(--surface-tint);letter-spacing:-.03em;
  transition:.3s;
}
.step:hover::before{color:var(--emerald-soft)}
.step h3{font-size:1.05rem;margin-bottom:8px;max-width:80%}
.step p{font-size:.92rem;color:var(--ink-2);margin:0}

/* =========================================================
   CTA BANNER
   ========================================================= */
.cta-banner{
  background:var(--ink-grad);color:#fff;
  border-radius:var(--r-xl);padding:54px 50px;
  position:relative;overflow:hidden;
  display:grid;grid-template-columns:1.5fr auto;gap:30px;align-items:center;
}
@media (max-width:780px){.cta-banner{grid-template-columns:1fr;padding:38px 28px;text-align:center}}
.cta-banner::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 90% 20%,rgba(15,179,122,.4),transparent 40%),
    radial-gradient(circle at 10% 110%,rgba(255,210,113,.25),transparent 50%);
  pointer-events:none;
}
.cta-banner::after{
  content:"";position:absolute;top:-20px;right:-20px;width:240px;height:240px;
  background:
    radial-gradient(circle 14px at 30px 30px,rgba(15,179,122,.5) 14px,transparent 16px),
    radial-gradient(circle 12px at 90px 60px,rgba(255,210,113,.4) 12px,transparent 14px),
    radial-gradient(circle 8px at 160px 30px,rgba(15,179,122,.4) 8px,transparent 10px),
    radial-gradient(circle 10px at 200px 100px,rgba(255,210,113,.3) 10px,transparent 12px),
    radial-gradient(circle 8px at 60px 140px,rgba(15,179,122,.3) 8px,transparent 10px);
  filter:blur(.5px);
  pointer-events:none;
}
.cta-banner h2{color:#fff;margin-bottom:12px;position:relative;z-index:1}
.cta-banner p{color:rgba(255,255,255,.78);margin:0;font-size:1.05rem;max-width:54ch;position:relative;z-index:1}
.cta-banner .btn{position:relative;z-index:1;justify-self:end}
@media (max-width:780px){.cta-banner .btn{justify-self:center}}

/* =========================================================
   IMAGE SHOWCASE
   ========================================================= */
.showcase-split{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
@media (max-width:880px){.showcase-split{grid-template-columns:1fr;gap:40px}}
.showcase-split.reverse > :first-child{order:2}
@media (max-width:880px){.showcase-split.reverse > :first-child{order:0}}

.showcase-img{
  position:relative;border-radius:var(--r-xl);overflow:hidden;
  box-shadow:var(--shadow-2);
  aspect-ratio:16/10;background:var(--surface-tint);
}
.showcase-img img{width:100%;height:100%;object-fit:cover;transition:.6s var(--ease)}
.showcase-img:hover img{transform:scale(1.04)}
.showcase-img::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg,transparent 60%,rgba(15,179,122,.18));
  pointer-events:none;z-index:1;
}
.showcase-img .badge{
  position:absolute;top:18px;left:18px;z-index:2;
  background:rgba(255,255,255,.95);backdrop-filter:blur(8px);
  padding:8px 14px;border-radius:99px;font-size:.78rem;font-weight:700;color:var(--ink);letter-spacing:.06em;
}

.showcase-text h2{margin-bottom:18px}
.showcase-text p{color:var(--ink-2);font-size:1.02rem}

/* triple screenshot strip */
.shots-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media (max-width:780px){.shots-strip{grid-template-columns:1fr;gap:18px}}
.shot-item{
  position:relative;border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-1);background:var(--surface-tint);
  aspect-ratio:4/3;
  transition:.4s var(--ease);
}
.shot-item img{width:100%;height:100%;object-fit:cover;transition:.6s var(--ease)}
.shot-item:hover{transform:translateY(-5px);box-shadow:var(--shadow-2)}
.shot-item:hover img{transform:scale(1.08)}
.shot-caption{
  position:absolute;left:0;right:0;bottom:0;padding:16px 18px;
  background:linear-gradient(transparent,rgba(14,23,20,.85));
  color:#fff;font-weight:600;font-size:.92rem;
}

/* =========================================================
   FAQ
   ========================================================= */
.faq{display:grid;gap:12px;max-width:820px;margin:0 auto}
.faq-item{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);
  overflow:hidden;transition:.3s var(--ease);
}
.faq-item:hover{border-color:rgba(15,179,122,.5)}
.faq-item.is-open{border-color:var(--emerald);box-shadow:var(--shadow-1)}
.faq-q{
  width:100%;text-align:left;display:flex;justify-content:space-between;align-items:center;gap:18px;
  padding:20px 24px;font-family:var(--f-display);font-weight:600;font-size:1.02rem;color:var(--ink);
}
.faq-q .ico{
  flex-shrink:0;width:30px;height:30px;border-radius:9px;background:var(--surface-tint);
  display:grid;place-items:center;transition:.3s var(--ease);
  position:relative;
}
.faq-q .ico::before,.faq-q .ico::after{
  content:"";position:absolute;background:var(--ink);border-radius:2px;transition:.3s
}
.faq-q .ico::before{width:12px;height:2px}
.faq-q .ico::after{width:2px;height:12px}
.faq-item.is-open .faq-q .ico{background:var(--emerald);transform:rotate(180deg)}
.faq-item.is-open .faq-q .ico::before,.faq-item.is-open .faq-q .ico::after{background:#fff}
.faq-item.is-open .faq-q .ico::after{transform:scaleY(0)}

.faq-a{
  max-height:0;overflow:hidden;transition:max-height .4s var(--ease), padding .3s var(--ease);
  padding:0 24px;
}
.faq-item.is-open .faq-a{padding:0 24px 22px;max-height:600px}
.faq-a p{color:var(--ink-2);margin:0;font-size:.96rem;line-height:1.65}

/* =========================================================
   CALLOUTS — pro tips, strategy boxes
   ========================================================= */
.callout{
  display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:start;
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:24px 28px;
  margin:32px 0;position:relative;overflow:hidden;
}
.callout::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--gem-grad);
}
.callout .ico{
  width:48px;height:48px;border-radius:12px;background:var(--emerald-soft);
  display:grid;place-items:center;font-size:1.4rem;color:var(--emerald-deep);font-family:var(--f-display);font-weight:700;
}
.callout h4{margin:0 0 6px;font-family:var(--f-display);font-size:1.05rem;color:var(--ink)}
.callout p{margin:0;color:var(--ink-2);font-size:.95rem}

.callout--gold::before{background:linear-gradient(180deg,var(--gold),var(--gold-deep))}
.callout--gold .ico{background:var(--gold-soft);color:var(--gold-deep)}

.callout--red::before{background:linear-gradient(180deg,var(--crimson),#9a1f2e)}
.callout--red .ico{background:var(--crimson-soft);color:var(--crimson)}

/* =========================================================
   BANKROLL / RISK CARDS
   ========================================================= */
.risk-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media (max-width:880px){.risk-grid{grid-template-columns:1fr}}
.risk-card{
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:28px;position:relative;overflow:hidden;
  transition:.35s var(--ease);
}
.risk-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-2)}
.risk-card .level{
  display:inline-block;padding:5px 12px;border-radius:99px;font-size:.75rem;
  font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px;
}
.risk-card.low  .level{background:var(--emerald-soft);color:var(--emerald-deep)}
.risk-card.mid  .level{background:var(--gold-soft);color:var(--gold-deep)}
.risk-card.high .level{background:var(--crimson-soft);color:var(--crimson)}
.risk-card h3{margin-bottom:10px;font-size:1.18rem}
.risk-card p{font-size:.95rem;color:var(--ink-2);margin-bottom:14px}
.risk-card .meta-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:auto}
.risk-card .meta-row > div{background:var(--bg-warm);padding:10px 12px;border-radius:10px;font-size:.82rem}
.risk-card .meta-row b{display:block;color:var(--ink);font-family:var(--f-display);font-size:1rem;margin-top:2px}

/* =========================================================
   DEVICES / DOWNLOAD PAGE
   ========================================================= */
.device-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
@media (max-width:780px){.device-cards{grid-template-columns:1fr}}
.device-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:30px 28px;display:flex;flex-direction:column;gap:18px;
  transition:.35s var(--ease);position:relative;overflow:hidden;
}
.device-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-2)}
.device-head{display:flex;align-items:center;gap:16px}
.device-icon{
  width:56px;height:56px;border-radius:14px;background:var(--surface-tint);
  display:grid;place-items:center;font-family:var(--f-display);font-weight:700;font-size:1.2rem;
  color:var(--ink);
}
.device-card.ios .device-icon{background:var(--ink);color:#fff}
.device-card.android .device-icon{background:var(--emerald-soft);color:var(--emerald-deep)}
.device-card h3{margin:0;font-size:1.25rem}
.device-card .sub{color:var(--muted);font-size:.88rem;margin-top:2px}
.device-card ul{margin:0}
.device-card ul li{padding:8px 0 8px 26px;font-size:.93rem;color:var(--ink-2);position:relative}
.device-card ul li::before{
  content:"✓";position:absolute;left:0;top:7px;
  width:18px;height:18px;border-radius:5px;background:var(--emerald-soft);color:var(--emerald-deep);
  display:grid;place-items:center;font-size:.78rem;font-weight:700;
}

/* =========================================================
   PAYMENT METHODS
   ========================================================= */
.pay-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px}
.pay-item{
  background:var(--surface);border:1px solid var(--line);border-radius:14px;
  padding:18px 16px;display:flex;flex-direction:column;align-items:center;gap:8px;
  transition:.25s var(--ease);text-align:center;
}
.pay-item:hover{transform:translateY(-3px);border-color:var(--emerald);box-shadow:var(--shadow-1)}
.pay-item .name{font-family:var(--f-display);font-weight:600;font-size:.95rem;color:var(--ink)}
.pay-item .speed{font-size:.78rem;color:var(--muted)}
.pay-item .speed b{color:var(--emerald-deep)}

/* =========================================================
   CASINO RANK CARDS (casinos.html)
   ========================================================= */
.rank-list{display:grid;gap:22px}
.rank-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);
  padding:28px 30px;display:grid;grid-template-columns:auto 1fr auto;gap:28px;align-items:center;
  position:relative;transition:.35s var(--ease);overflow:hidden;
}
.rank-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-2);border-color:transparent}
@media (max-width:780px){.rank-card{grid-template-columns:auto 1fr;gap:18px;padding:22px}}

.rank-num{
  font-family:var(--f-display);font-size:3rem;font-weight:700;line-height:1;
  background:var(--gem-grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  letter-spacing:-.04em;
}
.rank-body h3{margin:0 0 6px;font-size:1.32rem}
.rank-body .tagline{color:var(--muted);font-size:.92rem;margin:0 0 14px}
.rank-features{display:flex;flex-wrap:wrap;gap:8px}
.rank-feature{
  background:var(--bg-warm);padding:6px 12px;border-radius:99px;font-size:.82rem;color:var(--ink-2);
}
.rank-side{display:flex;flex-direction:column;align-items:center;gap:14px;min-width:170px}
@media (max-width:780px){.rank-side{grid-column:span 2;min-width:auto;flex-direction:row;justify-content:space-between;width:100%;padding-top:14px;border-top:1px solid var(--line)}}
.rank-bonus{
  text-align:center;background:var(--gold-soft);color:var(--gold-deep);
  padding:12px 18px;border-radius:14px;font-family:var(--f-display);font-weight:700;
  width:100%;
}
.rank-bonus small{display:block;font-size:.7rem;letter-spacing:.08em;margin-bottom:2px;color:var(--gold-deep);opacity:.8}
.rank-bonus span{font-size:1.15rem;letter-spacing:-.02em}

/* =========================================================
   AUTHOR / TRUST / META BLOCKS
   ========================================================= */
.trust-strip{
  display:flex;flex-wrap:wrap;gap:14px 22px;align-items:center;justify-content:center;
  padding:18px 22px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-md);margin-top:36px;
}
.trust-strip .item{display:flex;align-items:center;gap:8px;font-size:.86rem;color:var(--ink-2);font-weight:500}
.trust-strip .item .dot{
  width:10px;height:10px;border-radius:50%;background:var(--emerald);
  box-shadow:0 0 0 4px var(--emerald-soft);
}

.responsible-banner{
  background:var(--surface-tint);border:1px dashed rgba(14,23,20,.18);
  border-radius:var(--r-md);padding:22px 26px;margin-top:36px;
  display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:center;
}
@media (max-width:540px){.responsible-banner{grid-template-columns:1fr;text-align:center}}
.responsible-banner .ico-18{
  width:54px;height:54px;border-radius:50%;background:var(--ink);color:#fff;
  display:grid;place-items:center;font-family:var(--f-display);font-weight:700;font-size:1.05rem;
}
.responsible-banner h4{margin:0 0 4px;font-family:var(--f-display);font-size:1rem}
.responsible-banner p{margin:0;font-size:.88rem;color:var(--ink-2)}

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{
  background:var(--ink);color:rgba(255,255,255,.7);
  padding:70px 0 32px;margin-top:80px;position:relative;overflow:hidden;
}
.site-footer::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(800px 400px at 80% -20%,rgba(15,179,122,.18),transparent 50%),
    radial-gradient(600px 300px at -10% 120%,rgba(255,210,113,.12),transparent 50%);
  pointer-events:none;
}
.footer-grid{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px;
}
@media (max-width:880px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:540px){.footer-grid{grid-template-columns:1fr}}
.footer-brand .logo{color:#fff;margin-bottom:14px}
.footer-brand .logo span{background:linear-gradient(135deg,#fff,rgba(255,255,255,.7));-webkit-background-clip:text;background-clip:text;color:transparent}
.footer-brand p{font-size:.9rem;line-height:1.6;color:rgba(255,255,255,.6);max-width:38ch;margin-bottom:18px}

.footer-col h5{
  font-family:var(--f-display);font-weight:600;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
  color:#fff;margin-bottom:18px;
}
.footer-col ul{display:flex;flex-direction:column;gap:10px}
.footer-col ul li a{font-size:.92rem;color:rgba(255,255,255,.65);transition:.2s}
.footer-col ul li a:hover{color:var(--emerald);padding-left:6px}

.footer-bottom{
  position:relative;z-index:1;
  border-top:1px solid rgba(255,255,255,.08);padding-top:24px;
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;
  font-size:.82rem;color:rgba(255,255,255,.5);
}

.age-mark{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.06);padding:6px 12px;border-radius:99px;
}
.age-mark::before{
  content:"18+";background:#fff;color:var(--ink);
  width:30px;height:22px;border-radius:5px;display:grid;place-items:center;
  font-family:var(--f-display);font-weight:700;font-size:.72rem;
}

/* =========================================================
   TOC / SIDE NAV (article pages)
   ========================================================= */
.article-layout{display:grid;grid-template-columns:240px 1fr;gap:60px;align-items:start}
@media (max-width:980px){.article-layout{grid-template-columns:1fr;gap:30px}}
.toc{
  position:sticky;top:90px;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);
  padding:22px 22px;
}
@media (max-width:980px){.toc{position:static}}
.toc h5{font-family:var(--f-display);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.toc ol{margin:0;padding:0;counter-reset:t;list-style:none}
.toc ol li{counter-increment:t;padding:0;margin:0}
.toc ol li::before{content:none}
.toc ol li a{
  display:flex;gap:10px;font-size:.9rem;color:var(--ink-2);padding:7px 0;transition:.2s;
  border-bottom:1px solid transparent;
}
.toc ol li a::before{content:counter(t,decimal-leading-zero);color:var(--emerald);font-family:var(--f-display);font-weight:700;font-size:.78rem;flex-shrink:0;width:24px}
.toc ol li a:hover{color:var(--emerald-deep)}

/* =========================================================
   REVEAL ANIMATIONS
   ========================================================= */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease), transform .7s var(--ease)}
.reveal.is-in{opacity:1;transform:none}
.reveal-d1{transition-delay:.05s}
.reveal-d2{transition-delay:.12s}
.reveal-d3{transition-delay:.2s}
.reveal-d4{transition-delay:.28s}

/* =========================================================
   UTILITIES
   ========================================================= */
.center{text-align:center}
.mt-0{margin-top:0}
.mt-md{margin-top:32px}
.mt-lg{margin-top:48px}
.mb-md{margin-bottom:32px}
.dim{color:var(--muted)}
.divider{height:1px;background:var(--line);margin:40px 0;border:none}

@media (prefers-reduced-motion: reduce){
  *{animation:none!important;transition:none!important}
}
