/* ===== Gransino Casino — shared styles ===== */
:root{
  --bg:#111213;
  --surface:#161718;
  --surface-2:#1c1d1f;
  --border:#2a2b2d;
  --text:#999999;
  --text-strong:#e8e8e8;
  --text-mid:#c4c4c4;
  --cta:#FFB178;
  --cta-text:#000000;
  --cta2:#4F5254;
  --cta2-text:#e6e6e6;
  --sidebar-w:230px;
  --maxw:1080px;
  --radius:10px;
  --gap:18px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  font-size:16px;
  line-height:1.6;
  -webkit-text-size-adjust:100%;
  text-rendering:optimizeSpeed;
}
h1,h2,h3{color:var(--text-strong);line-height:1.2;letter-spacing:-.01em;margin:0 0 .5em}
h1{font-size:clamp(1.7rem,4.5vw,2.5rem);font-weight:800}
h2{font-size:clamp(1.35rem,3vw,1.9rem);font-weight:800}
h3{font-size:1.08rem;font-weight:700;color:var(--text-mid)}
p{margin:0 0 1em}
a{color:var(--cta);text-decoration:none}
img{max-width:100%;display:block}
.visually-hidden,caption.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.skip-link{position:absolute;left:-999px;top:0}
.skip-link:focus{left:8px;top:8px;background:var(--cta);color:#000;padding:8px 12px;border-radius:8px;z-index:200}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.95rem;line-height:1;
  padding:13px 20px;border-radius:8px;border:1px solid transparent;
  cursor:pointer;text-align:center;transition:transform .12s ease,opacity .12s ease;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--cta);color:var(--cta-text)}
.btn-primary:hover{opacity:.92}
.btn-secondary{background:var(--cta2);color:var(--cta2-text);border-color:var(--cta2)}
.btn-secondary:hover{opacity:.9}

/* ===== Header / Sidebar ===== */
.site-bar{
  position:fixed;top:0;left:0;height:100vh;width:var(--sidebar-w);
  background:var(--surface);border-right:1px solid var(--border);
  display:flex;flex-direction:column;padding:18px 14px;gap:14px;z-index:100;overflow-y:auto;
}
.bar-top{display:flex;align-items:center;gap:10px}
.logo{display:inline-flex;align-items:center}
.logo-img{height:60px;width:auto;display:block}
.bar-cta{display:none}
.burger{display:none}
.nav{display:flex;flex-direction:column;gap:2px}
.nav a{color:var(--text);padding:9px 10px;border-radius:7px;font-size:.92rem;font-weight:500}
.nav a:hover{background:var(--surface-2);color:var(--text-strong)}
.nav-cta{margin-top:10px;color:#000 !important}
.nav-age{margin-top:8px;font-size:.72rem;color:#6b6d6f;padding:0 10px}

/* ===== Main layout ===== */
.main{max-width:var(--maxw);margin:0 auto;padding:26px clamp(16px,3vw,34px) 60px}
.block{padding:34px 0;border-top:1px solid var(--border);scroll-margin-top:20px}
.block:first-of-type{border-top:0}
.lead{max-width:70ch;margin-bottom:1.4em}
.note{font-size:.85rem;color:#7c7e80;margin-top:.6em}

/* ===== Hero ===== */
.hero{padding-top:8px;scroll-margin-top:20px}
.hero-banner{position:relative;margin:0 0 22px;overflow:hidden;border:1px solid var(--border)}
.banner-link{position:relative;display:block}
.banner-img{width:100%;aspect-ratio:1040/520;object-fit:cover;object-position:55% 28%;background:var(--surface-2)}
.banner-tag{position:absolute;top:16px;left:16px;background:var(--cta);color:#000;font-weight:800;font-size:.72rem;letter-spacing:.05em;text-transform:uppercase;padding:6px 11px;border-radius:6px}
.banner-content{position:absolute;left:16px;bottom:16px;max-width:min(460px,82%);background:rgba(10,11,12,.72);border:1px solid rgba(255,255,255,.09);border-radius:12px;padding:16px 18px;display:flex;flex-direction:column;align-items:flex-start;gap:10px}
.banner-offer{color:#fff;font-weight:800;font-size:clamp(1.15rem,3.2vw,1.8rem);line-height:1.15}
.banner-sub{color:#d4d4d4;font-size:.82rem;line-height:1.4}
.banner-btn{padding:13px 22px;font-size:1rem;box-shadow:0 6px 18px rgba(0,0,0,.35)}
.banner-link:hover .banner-btn{transform:translateY(-1px)}
.hero-head{color:var(--text-strong);font-size:clamp(1.05rem,2.4vw,1.4rem);font-weight:600;margin-bottom:.4em}
.hero-sub{max-width:72ch}
.hero-hook{max-width:72ch;margin-top:18px}

/* fact ribbon */
.fact-ribbon{display:flex;flex-wrap:wrap;gap:0;margin:18px 0 20px;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--surface)}
.fact-ribbon div{flex:1 1 130px;padding:12px 14px;border-right:1px solid var(--border)}
.fact-ribbon div:last-child{border-right:0}
.fact-ribbon dt{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:#7c7e80;margin:0}
.fact-ribbon dd{margin:2px 0 0;font-size:1.15rem;font-weight:800;color:var(--text-strong)}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin:8px 0 4px}

/* ===== Games ===== */
.games-tools{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px}
.filters{display:flex;flex-wrap:wrap;gap:8px}
.chip{background:var(--surface);color:var(--text);border:1px solid var(--border);padding:8px 14px;border-radius:20px;font-size:.85rem;font-weight:600;cursor:pointer}
.chip:hover{color:var(--text-strong)}
.chip.is-active{background:var(--cta);color:#000;border-color:var(--cta)}
.sort{display:flex;align-items:center;gap:8px;font-size:.85rem}
.sort select{background:var(--surface);color:var(--text-strong);border:1px solid var(--border);border-radius:8px;padding:8px 10px;font:inherit}

.games-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:14px}
.tile{position:relative;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--surface)}
.tile-thumb{position:relative}
.tile[hidden]{display:none}
.tile-img{width:100%;aspect-ratio:3/4;object-fit:cover;background:var(--surface-2);color:transparent;font-size:0}
.tile-rtp{position:absolute;top:8px;right:8px;background:rgba(0,0,0,.7);color:var(--cta);font-size:.7rem;font-weight:800;padding:3px 7px;border-radius:5px}
.tile-new{position:absolute;top:8px;left:8px;background:var(--cta);color:#000;font-size:.62rem;font-weight:800;letter-spacing:.04em;padding:3px 6px;border-radius:5px;text-transform:uppercase}
.tile-meta{padding:8px 9px 10px}
.tile-name{font-size:.82rem;font-weight:700;color:var(--text-strong);line-height:1.25;display:block}
.tile-prov{font-size:.72rem;color:#7c7e80}
.tile-actions{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;gap:8px;padding:0 12px;background:rgba(17,18,19,.86);opacity:0;transition:opacity .15s ease}
.tile:hover .tile-actions,.tile:focus-within .tile-actions{opacity:1}
.tile-actions .btn{width:100%;padding:10px}
@media(hover:none){.tile-actions{position:static;inset:auto;opacity:1;background:transparent;flex-direction:row;padding:8px 9px 10px;gap:6px}.tile-actions .btn{padding:8px;font-size:.8rem}}

/* ===== Cards ===== */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--gap)}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 18px}
.card h3{color:var(--text-strong);margin-bottom:.4em}
.card p{margin:0;font-size:.93rem}

/* ===== Steps ===== */
.steps{list-style:none;counter-reset:none;margin:0;padding:0;display:grid;gap:10px}
.steps li{display:flex;gap:14px;align-items:flex-start;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px}
.step-n{flex:0 0 28px;width:28px;height:28px;border-radius:50%;background:var(--cta);color:#000;font-weight:800;display:grid;place-items:center;font-size:.9rem}
.steps strong{color:var(--text-strong);display:block}
.steps p{margin:.2em 0 0;font-size:.9rem}

/* ===== Lists ===== */
.ticks{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.ticks li{position:relative;padding-left:26px}
.ticks li::before{content:"";position:absolute;left:4px;top:.55em;width:9px;height:9px;border-right:2px solid var(--cta);border-bottom:2px solid var(--cta);transform:rotate(45deg)}

/* ===== Tables (responsive stacking, geen overflow) ===== */
.r-table{width:100%;border-collapse:collapse;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;font-size:.92rem}
.r-table caption{text-align:left}
.r-table th,.r-table td{padding:11px 14px;text-align:left;border-bottom:1px solid var(--border);vertical-align:top}
.r-table thead th{background:var(--surface-2);color:var(--text-strong);font-size:.8rem;text-transform:uppercase;letter-spacing:.03em}
.r-table tbody th{color:var(--text-strong);font-weight:700;background:var(--surface)}
.r-table td{background:var(--surface)}
.r-table tr:last-child th,.r-table tr:last-child td{border-bottom:0}

@media(max-width:680px){
  .r-table,.r-table thead,.r-table tbody,.r-table tr,.r-table th,.r-table td{display:block;width:100%}
  .r-table thead{position:absolute;left:-9999px}
  .r-table tr{border-bottom:1px solid var(--border)}
  .r-table tr:last-child{border-bottom:0}
  .r-table th,.r-table td{border-bottom:1px solid var(--border);padding:9px 14px}
  .r-table td[data-label]::before,.r-table th[data-label]::before{
    content:attr(data-label);display:block;font-size:.68rem;text-transform:uppercase;
    letter-spacing:.04em;color:#7c7e80;margin-bottom:2px;
  }
}

/* ===== FAQ ===== */
.faq{display:grid;gap:8px}
.faq details{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.faq summary{list-style:none;cursor:pointer;padding:14px 44px 14px 16px;position:relative}
.faq summary::-webkit-details-marker{display:none}
.faq summary h3{display:inline;margin:0;font-size:1rem;color:var(--text-strong)}
.faq summary::after{content:"+";position:absolute;right:16px;top:12px;color:var(--cta);font-size:1.3rem;font-weight:700}
.faq details[open] summary::after{content:"–"}
.faq details p{margin:0;padding:0 16px 16px;font-size:.92rem}

/* ===== Footer ===== */
.site-footer{text-align:center;padding:40px 20px 48px;border-top:1px solid var(--border)}
.pay-row{display:flex;justify-content:center;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:22px}
.pay-chip{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:8px 14px;min-width:60px;min-height:34px;display:inline-flex;align-items:center;justify-content:center}
.pay-chip img{background:var(--surface-2)}
.pay-more{font-weight:700}
.age-circle{width:48px;height:48px;border:2px solid var(--text);border-radius:50%;display:grid;place-items:center;margin:0 auto 18px;font-weight:800;color:var(--text-mid);font-size:.85rem}
.footer-nav{display:flex;justify-content:center;flex-wrap:wrap;gap:6px 18px;margin-bottom:18px}
.footer-nav a{color:var(--text);font-size:.85rem}
.footer-nav a:hover{color:var(--text-strong)}
.rg{max-width:62ch;margin:0 auto 8px;font-size:.8rem;color:#6f7173;line-height:1.7}
.rg-link{color:var(--cta)}
.copy{font-size:.78rem;color:#5c5e60;margin:0}

/* ===== Responsive: header naar boven op mobiel ===== */
@media(max-width:1023px){
  .site-bar{position:sticky;top:0;left:0;height:auto;width:100%;flex-direction:column;padding:12px 16px;border-right:0;border-bottom:1px solid var(--border)}
  .bar-top{justify-content:space-between;width:100%}
  .bar-cta{display:inline-flex;margin-left:auto;padding:10px 16px}
  .burger{display:inline-flex;flex-direction:column;gap:5px;background:none;border:0;padding:6px;cursor:pointer}
  .burger span{width:24px;height:2px;background:var(--text-strong);display:block;transition:transform .2s,opacity .2s}
  .burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .burger[aria-expanded="true"] span:nth-child(2){opacity:0}
  .burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .nav{display:none;width:100%;padding-top:8px}
  .nav.open{display:flex}
  .nav-cta{display:none}
  .nav-age{padding:6px 10px 0}
}
@media(min-width:1024px){
  body{padding-left:var(--sidebar-w)}
}
@media(min-width:1024px){
  .bar-top{flex-direction:column;align-items:flex-start;gap:6px}
}
.center{
  margin:0 auto;
  margin-top:30px;
}
/* ===== Split: tekst naast afbeelding ===== */
.split{display:grid;grid-template-columns:1fr 1fr;gap:26px;align-items:center;margin:6px 0 30px}
.split-text h3:first-child{margin-top:0}
.split-media{margin:0}
.split-img{width:100%;height:auto;aspect-ratio:4/3;object-fit:cover;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-2)}
@media(max-width:760px){.split{grid-template-columns:1fr;gap:18px}}

.faq-item{
  font-size:1.08rem;font-weight:700;color:var(--text-mid)
}