/* ==========================================================================
   Casino Kompas — Design System (hinoord.nl)
   Shared stylesheet for every page. Deep navy + gold + green-CTA on white.
   ========================================================================== */

:root{
  --navy:#0f1b2d;
  --navy-2:#13233b;
  --navy-3:#1c3252;
  --gold:#f5b301;
  --gold-2:#e0a500;
  --green:#1a9d5a;
  --green-2:#158049;
  --red:#d64545;
  --ink:#1d2733;
  --muted:#5b6b7d;
  --line:#e4e9ef;
  --bg:#f5f7fa;
  --white:#ffffff;
  --radius:12px;
  --radius-sm:8px;
  --shadow:0 6px 24px rgba(15,27,45,.08);
  --shadow-lg:0 12px 40px rgba(15,27,45,.14);
  --wrap:1160px;
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);line-height:1.65;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:var(--green-2);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:var(--wrap);margin:0 auto;padding:0 20px}

h1,h2,h3,h4{line-height:1.25;color:var(--navy);font-weight:800}
h1{font-size:2.2rem;margin-bottom:.5em}
h2{font-size:1.7rem;margin:1.4em 0 .5em}
h3{font-size:1.25rem;margin:1.2em 0 .4em}
h4{font-size:1.05rem;margin:1em 0 .3em}
p{margin:0 0 1em}
ul,ol{margin:0 0 1em 1.2em}
li{margin-bottom:.4em}

/* ---------- 18+ / compliance top bar ---------- */
.agebar{background:var(--navy);color:#cdd8e6;font-size:.82rem;text-align:center;padding:7px 12px}
.agebar strong{color:var(--gold)}
.agebar a{color:#fff;text-decoration:underline}

/* ---------- Header / Nav ---------- */
.site-header{background:var(--white);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:66px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;color:var(--navy);font-size:1.2rem}
.brand:hover{text-decoration:none}
.brand .mark{width:34px;height:34px;border-radius:8px;background:linear-gradient(135deg,var(--gold),var(--gold-2));display:grid;place-items:center;color:var(--navy);font-weight:900;font-size:1.1rem}
.brand small{display:block;font-size:.62rem;color:var(--muted);font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.nav{display:flex;align-items:center;gap:22px}
.nav a{color:var(--ink);font-weight:600;font-size:.95rem}
.nav a:hover{color:var(--green-2);text-decoration:none}
.nav-toggle{display:none;background:none;border:0;font-size:1.6rem;color:var(--navy);cursor:pointer}
@media(max-width:900px){
  .nav{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;align-items:flex-start;padding:14px 20px;border-bottom:1px solid var(--line);gap:14px}
  .nav.open{display:flex}
  .nav-toggle{display:block}
}

/* ---------- Hero ---------- */
.hero{background:linear-gradient(160deg,var(--navy) 0%,var(--navy-3) 100%);color:#eaf1fa;padding:56px 0}
.hero h1{color:#fff;max-width:820px}
.hero p.lead{font-size:1.15rem;color:#c6d4e6;max-width:720px}
.hero .meta{margin-top:14px;font-size:.85rem;color:#9fb2c9}
.hero .meta strong{color:var(--gold)}

/* ---------- Buttons ---------- */
.btn{display:inline-block;padding:12px 22px;border-radius:var(--radius-sm);font-weight:700;text-align:center;cursor:pointer;border:0;font-size:.95rem;transition:transform .06s ease,box-shadow .15s ease}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn-cta{background:linear-gradient(135deg,var(--green),var(--green-2));color:#fff;box-shadow:0 4px 14px rgba(26,157,90,.35)}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold-2));color:var(--navy)}
.btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.5)}
.btn-sm{padding:8px 16px;font-size:.85rem}

/* ---------- Sections ---------- */
main section{padding:8px 0}
.section{padding:34px 0}
.section-white{background:#fff}
.prose{max-width:820px}
.prose p,.prose li{color:#2c3a48}
.lastupd{font-size:.82rem;color:var(--muted);margin-bottom:6px}
.lastupd .dot{color:var(--green)}

/* ---------- Operator badge (logo substitute) ---------- */
.oplogo{width:64px;height:64px;border-radius:12px;display:grid;place-items:center;font-weight:900;color:#fff;font-size:1.5rem;flex:none;box-shadow:inset 0 0 0 1px rgba(255,255,255,.15)}

/* ---------- Toplist / ranking cards ---------- */
.toplist{display:flex;flex-direction:column;gap:14px;margin:18px 0}
.op-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);display:grid;grid-template-columns:44px 64px 1fr auto;gap:16px;align-items:center;padding:16px 18px;position:relative;overflow:hidden}
.op-card.top::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--gold)}
.op-rank{font-weight:900;font-size:1.3rem;color:var(--muted);text-align:center}
.op-card.top .op-rank{color:var(--gold-2)}
.op-body h3{margin:0;font-size:1.15rem}
.op-body .rating{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--muted);margin-top:2px}
.stars{color:var(--gold);letter-spacing:1px}
.op-body .bonus{font-size:.9rem;color:#2c3a48;margin-top:4px}
.op-body .feats{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.tag{font-size:.72rem;background:#eef3f8;color:#41566b;border-radius:20px;padding:3px 10px;font-weight:600}
.op-cta{display:flex;flex-direction:column;gap:6px;align-items:stretch;min-width:150px}
.op-cta .score{font-size:1.6rem;font-weight:900;color:var(--green-2);text-align:center;line-height:1}
.op-cta .score small{display:block;font-size:.62rem;color:var(--muted);font-weight:600;text-transform:uppercase}
@media(max-width:720px){
  .op-card{grid-template-columns:36px 52px 1fr;grid-template-areas:"rank logo body" "cta cta cta"}
  .op-rank{grid-area:rank}.oplogo{grid-area:logo;width:52px;height:52px;font-size:1.2rem}
  .op-body{grid-area:body}.op-cta{grid-area:cta;flex-direction:row;margin-top:6px}
  .op-cta .btn{flex:1}
}

/* ---------- Comparison table ---------- */
.tbl-wrap{overflow-x:auto;margin:18px 0}
table.cmp{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);font-size:.92rem}
table.cmp th,table.cmp td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--line)}
table.cmp th{background:var(--navy);color:#fff;font-weight:700;font-size:.85rem}
table.cmp tr:last-child td{border-bottom:0}
table.cmp tr:nth-child(even) td{background:#fafbfd}
table.cmp .brand-cell{font-weight:700;color:var(--navy);white-space:nowrap}

/* ---------- Cards grid ---------- */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:18px;margin:18px 0}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.card h3{margin-top:0}
.card .ico{width:44px;height:44px;border-radius:10px;background:#eef7f1;color:var(--green-2);display:grid;place-items:center;font-size:1.3rem;margin-bottom:10px}

/* ---------- Callouts ---------- */
.callout{border-left:4px solid var(--gold);background:#fff8e6;padding:14px 18px;border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin:18px 0}
.callout.info{border-color:var(--green);background:#eefaf2}
.callout.warn{border-color:var(--red);background:#fdecec}
.callout h4{margin-top:0}

/* ---------- FAQ ---------- */
.faq details{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);margin-bottom:10px;padding:0 18px}
.faq summary{cursor:pointer;font-weight:700;color:var(--navy);padding:14px 0;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;color:var(--gold-2);font-weight:900}
.faq details[open] summary::after{content:"–"}
.faq details[open] summary{border-bottom:1px solid var(--line)}
.faq details p{padding:12px 0}

/* ---------- Breadcrumbs ---------- */
.crumbs{font-size:.82rem;color:var(--muted);padding:12px 0}
.crumbs a{color:var(--muted)}
.crumbs a:hover{color:var(--green-2)}

/* ---------- Author box (E-E-A-T) ---------- */
.authorbox{display:flex;gap:16px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;margin:24px 0;box-shadow:var(--shadow)}
.authorbox .avatar{width:56px;height:56px;border-radius:50%;background:var(--navy-3);color:#fff;display:grid;place-items:center;font-weight:800;font-size:1.2rem;flex:none}
.authorbox .meta{font-size:.9rem}
.authorbox .meta strong{color:var(--navy)}
.authorbox .meta .role{color:var(--muted);font-size:.82rem}

/* ---------- Responsible gambling strip ---------- */
.rg-strip{background:#eef3f8;border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;margin:24px 0;font-size:.9rem;color:#41566b}
.rg-strip strong{color:var(--navy)}
.rg-strip .logos{display:flex;flex-wrap:wrap;gap:14px;margin-top:8px;font-weight:700;color:var(--navy)}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy);color:#b9c7d8;padding:48px 0 24px;margin-top:48px;font-size:.9rem}
.site-footer h4{color:#fff;font-size:.95rem;margin:0 0 12px}
.site-footer a{color:#b9c7d8}
.site-footer a:hover{color:#fff;text-decoration:none}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:28px}
.footer-grid ul{list-style:none;margin:0}
.footer-grid li{margin-bottom:8px}
.footer-bottom{border-top:1px solid var(--navy-3);margin-top:30px;padding-top:18px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.8rem;color:#8598ad}
.footer-18{display:inline-grid;place-items:center;width:30px;height:30px;border-radius:50%;background:var(--red);color:#fff;font-weight:900;font-size:.8rem;margin-right:8px}
@media(max-width:820px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer-grid{grid-template-columns:1fr}}

/* ---------- Utility ---------- */
.text-center{text-align:center}
.mt0{margin-top:0}.mb0{margin-bottom:0}
.pill{display:inline-block;background:var(--gold);color:var(--navy);font-weight:800;font-size:.7rem;padding:3px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:.03em}
.disc{font-size:.78rem;color:var(--muted);font-style:italic}
.toc{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:16px 20px;margin:18px 0}
.toc ul{margin:.4em 0 0 1.1em}
.toc a{color:var(--green-2)}

.authorbox img.avatar{object-fit:cover}
