/* ============================================================================
   Stadium Night — KAVVV publieke site thema
   Bron-ontwerp: homepage-a.html. Alles is gescoped (sn-* prefix of onder
   .sn-home) zodat het de bestaande admin/clubportaal/binnenpagina-styling
   niet breekt. Donkere chrome (topbar/header/footer) site-breed; homepage
   volledig donker; binnenpagina's in een lichte content-canvas.
   ============================================================================ */

:root{
  --sn-bg:#0c0d10;
  --sn-panel:#15171c;
  --sn-panel-2:#1c1f26;
  --sn-line:#262a33;
  --sn-ink:#f4f5f7;
  --sn-muted:#8b909c;
  --sn-volt:#c8f135;
  --sn-volt-deep:#a6cc1f;
  --sn-red:#ff4d3d;
  --sn-r:14px;
  --sn-font:'Archivo',-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --sn-display:'Anton',sans-serif;
}

/* Fonts laden gebeurt in layout.php (Anton + Archivo). */

/* ── Body in publieke modus ─────────────────────────────────────────────── */
body.sn-body{
  background:var(--sn-bg);
  color:var(--sn-ink);
  font-family:var(--sn-font);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  margin:0;
}
.sn-display{font-family:var(--sn-display);font-weight:400;letter-spacing:.005em;text-transform:uppercase;line-height:.92}
.sn-wrap{max-width:1280px;margin:0 auto;padding:0 56px}
.sn-eyebrow{font-size:12px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--sn-volt)}
.sn-body a{color:inherit;text-decoration:none}

/* ── Header / nav ───────────────────────────────────────────────────────── */
.sn-header{position:sticky;top:0;z-index:1000;background:rgba(12,13,16,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--sn-line)}
.sn-header .sn-wrap{display:flex;align-items:center;justify-content:space-between;height:78px;gap:20px}
.sn-brand{display:flex;align-items:center;gap:14px}
.sn-brand img{height:46px;width:auto}
.sn-brand .bt{line-height:1.05}
.sn-brand .bt b{font-family:var(--sn-display);font-size:21px;letter-spacing:.04em;color:#fff;display:block}
.sn-brand .bt span{display:block;font-size:10.5px;letter-spacing:.22em;color:var(--sn-muted);text-transform:uppercase;font-weight:700;margin-top:2px}
.sn-nav{display:flex;align-items:center;gap:28px}
.sn-nav .sn-navlink{font-size:14px;font-weight:600;color:#cfd2da;letter-spacing:.01em;position:relative;padding:4px 0;white-space:nowrap}
.sn-nav a.sn-navlink:hover{color:#fff}
.sn-nav .sn-navlink.active{color:var(--sn-volt)}
/* dropdown (kindpagina's) — hoofditem is NIET klikbaar */
.sn-nav .sn-navlink-parent{cursor:default;display:inline-flex;align-items:center;gap:5px;color:#cfd2da}
.sn-nav .sn-has-children:hover .sn-navlink-parent{color:#fff}
.sn-nav .sn-caret{display:inline-block;width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;
  border-top:5px solid currentColor;opacity:.65;transition:transform .15s}
.sn-nav .sn-has-children:hover .sn-caret{transform:rotate(180deg)}
.sn-nav .sn-has-children{position:relative}
.sn-nav .sn-submenu{position:absolute;top:100%;left:0;margin-top:10px;background:var(--sn-panel);border:1px solid var(--sn-line);
  border-radius:10px;padding:6px;min-width:200px;box-shadow:0 14px 40px rgba(0,0,0,.5);opacity:0;visibility:hidden;
  transform:translateY(-6px);transition:.15s;z-index:1001}
.sn-nav .sn-has-children:hover .sn-submenu{opacity:1;visibility:visible;transform:translateY(0)}
.sn-nav .sn-submenu a{display:block;padding:8px 12px;border-radius:6px;font-size:13.5px;font-weight:600;color:#cfd2da}
.sn-nav .sn-submenu a:hover{background:rgba(200,241,53,.1);color:var(--sn-volt)}
.sn-header-cta{display:flex;gap:12px;align-items:center}

.sn-btn{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:13.5px;letter-spacing:.03em;padding:11px 20px;border-radius:999px;transition:.15s;cursor:pointer;border:none;font-family:inherit}
.sn-btn-volt{background:var(--sn-volt);color:#0c0d10}
.sn-btn-volt:hover{background:#fff}
.sn-btn-ghost{border:1px solid var(--sn-line);color:var(--sn-ink);background:transparent}
.sn-btn-ghost:hover{border-color:var(--sn-volt);color:var(--sn-volt)}
.sn-btn-dark{background:#0c0d10;color:var(--sn-volt)}
.sn-btn-dark:hover{background:#fff;color:#0c0d10}
/* Tekstkleur forceren: een <a>-knop erft anders de lichte .sn-body a-kleur,
   waardoor de volt-knop bijna-witte (slecht leesbare) tekst krijgt. */
.sn-body .sn-btn-volt{color:#0c0d10;font-weight:700}
.sn-body .sn-btn-ghost{color:var(--sn-ink)}
.sn-body .sn-btn-ghost:hover{color:var(--sn-volt)}
.sn-body .sn-btn-dark{color:var(--sn-volt)}

/* hamburger (mobiel) */
.sn-burger{display:none;background:transparent;border:none;cursor:pointer;padding:8px;flex-direction:column;gap:5px}
.sn-burger span{display:block;width:24px;height:2px;background:var(--sn-ink);border-radius:2px}

/* mobiel drawer */
.sn-drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1100;opacity:0;visibility:hidden;transition:.2s}
.sn-drawer-overlay.open{opacity:1;visibility:visible}
.sn-drawer{position:fixed;top:0;right:0;bottom:0;width:280px;max-width:84vw;background:var(--sn-panel);z-index:1101;
  transform:translateX(100%);transition:transform .22s ease;padding:20px;overflow-y:auto;border-left:1px solid var(--sn-line)}
.sn-drawer.open{transform:translateX(0)}
.sn-drawer-head{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.sn-drawer-head img{height:34px}
.sn-drawer-head b{font-family:var(--sn-display);font-size:18px}
.sn-drawer-close{margin-left:auto;background:transparent;border:none;color:var(--sn-muted);font-size:26px;line-height:1;cursor:pointer}
.sn-drawer a{display:block;padding:11px 10px;border-radius:8px;color:#cfd2da;font-weight:600;font-size:15px;border-bottom:1px solid var(--sn-line)}
.sn-drawer a:hover{background:rgba(200,241,53,.08);color:var(--sn-volt)}
.sn-drawer .sn-drawer-sub a{padding-left:24px;font-size:14px;font-weight:500;border-bottom:none}
/* Niet-klikbaar hoofditem (met kinderen) in het mobiele menu */
.sn-drawer .sn-drawer-parent{padding:11px 10px 4px;color:var(--sn-muted);font-weight:700;font-size:12px;
  text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--sn-line)}

/* ── Lichte content-canvas voor binnenpagina's ──────────────────────────── */
/* color expliciet donker: body.sn-body zet de tekst licht voor de donkere
   chrome — zonder deze reset erft lichte-canvas-inhoud die lichte kleur en
   wordt 'gewone' tekst onleesbaar (wit op wit). */
.sn-canvas{background:#f0f2f4;min-height:60vh;padding:26px 0 50px;color:#2c3e50}
.sn-canvas a{color:#2980b9}
.sn-canvas-inner{max-width:1180px;margin:0 auto;padding:0 20px}

/* ── Donkere content-canvas (publieke DB-pagina's) ──────────────────────── */
.sn-canvas--dark{background:var(--sn-bg);color:var(--sn-ink)}
.sn-canvas--dark #titel1,
.sn-canvas--dark .titel1{color:var(--sn-ink) !important}
.sn-canvas--dark a{color:var(--sn-volt)}

/* Klassement (views/klassement_db.php) */
.sn-canvas--dark .kl-card{background:var(--sn-panel) !important;box-shadow:none !important;border:1px solid var(--sn-line)}
.sn-canvas--dark .kl-toolbar a{background:var(--sn-panel-2) !important;border-color:var(--sn-line) !important;color:var(--sn-muted) !important}
.sn-canvas--dark .kl-toolbar a:hover{border-color:var(--sn-volt) !important;color:var(--sn-volt) !important;background:var(--sn-panel-2) !important}
.sn-canvas--dark .kl-afd-title{background:var(--sn-volt) !important;color:#0c0d10 !important}
.sn-canvas--dark .kl-table th{color:var(--sn-muted) !important;border-bottom-color:var(--sn-line) !important}
.sn-canvas--dark .kl-table td{color:var(--sn-ink) !important;border-bottom-color:var(--sn-line) !important}
.sn-canvas--dark .kl-table td.kl-td-pos{color:var(--sn-muted) !important}
.sn-canvas--dark .kl-table td.kl-td-pnt{color:var(--sn-volt) !important}
.sn-canvas--dark .kl-table td a{color:var(--sn-ink) !important}
.sn-canvas--dark .kl-table td a:hover{color:var(--sn-volt) !important}
.sn-canvas--dark .kl-table tr:hover td{background:rgba(255,255,255,.03) !important}
.sn-canvas--dark .kl-table tr.firstLine td{border-bottom-color:var(--sn-volt) !important}
.sn-canvas--dark .kl-empty{color:var(--sn-muted) !important}

/* Uitslagen (views/uitslagen_db.php) */
.sn-canvas--dark .ud-day{background:var(--sn-panel) !important;box-shadow:none !important;border:1px solid var(--sn-line)}
.sn-canvas--dark .ud-day-head{background:var(--sn-panel-2) !important;border-bottom-color:var(--sn-line) !important}
.sn-canvas--dark .ud-day-head:hover{background:#22262f !important}
.sn-canvas--dark .ud-day-date{color:var(--sn-ink) !important}
.sn-canvas--dark .ud-day-count{color:var(--sn-muted) !important}
.sn-canvas--dark .ud-afd-label{color:var(--sn-muted) !important;border-top-color:var(--sn-line) !important}
.sn-canvas--dark .ud-match{border-bottom-color:var(--sn-line) !important}
.sn-canvas--dark a.ud-match:hover{background:rgba(255,255,255,.05) !important}
.sn-canvas--dark .ud-team{color:var(--sn-ink) !important}
.sn-canvas--dark .ud-sep{color:var(--sn-muted) !important}
.sn-canvas--dark .ud-badge-score{background:var(--sn-panel-2) !important;color:var(--sn-volt) !important}
.sn-canvas--dark .ud-badge-uur{background:var(--sn-panel-2) !important;color:var(--sn-muted) !important}
.sn-canvas--dark .ud-badge-wacht{background:var(--sn-panel-2) !important;color:var(--sn-muted) !important}
.sn-canvas--dark .ud-empty{color:var(--sn-muted) !important}

/* Generieke Bootstrap-fallbacks binnen donkere canvas */
.sn-canvas--dark .table{color:var(--sn-ink)}
.sn-canvas--dark .table>thead>tr>th,.sn-canvas--dark .table>tbody>tr>td,
.sn-canvas--dark .table>tbody>tr>th,.sn-canvas--dark .table>tfoot>tr>td{border-color:var(--sn-line) !important;color:#cdd2da}
/* striped tabellen: lichte zebra-strepen (op de TR) weg, subtiele donkere hover */
.sn-canvas--dark .table-striped>tbody>tr:nth-of-type(odd),
.sn-canvas--dark .table-striped>tbody>tr:nth-of-type(odd)>td,
.sn-canvas--dark .table-striped>tbody>tr:nth-of-type(odd)>th{background:transparent !important}
.sn-canvas--dark .table-striped>tbody>tr:hover>td{background:rgba(255,255,255,.04) !important}
/* beker-accordion 'Speeldag …' kop */
.sn-canvas--dark .speeldag{color:var(--sn-ink);font-weight:700;cursor:pointer}
.sn-canvas--dark .speeldag .material-icons{color:var(--sn-volt);vertical-align:middle}
.sn-canvas--dark .pageContent b{color:var(--sn-ink)}
.sn-canvas--dark .row-even{background:var(--sn-panel) !important;color:var(--sn-ink)}
.sn-canvas--dark .row-odd{background:var(--sn-panel-2) !important;color:var(--sn-ink)}
.sn-canvas--dark .panel{background:var(--sn-panel);border-color:var(--sn-line);color:var(--sn-ink)}
.sn-canvas--dark .panel-heading{background:var(--sn-panel-2) !important;border-color:var(--sn-line) !important;color:var(--sn-ink)}
.sn-canvas--dark .well{background:var(--sn-panel);border-color:var(--sn-line)}
/* inline-witte panelen (bv. zoekbalk clubs_db .adm-card style="background:#fff") */
.sn-canvas--dark .adm-card{background:var(--sn-panel) !important;border:1px solid var(--sn-line);box-shadow:none !important}
.sn-canvas--dark .adm-card label{color:var(--sn-ink) !important}
.sn-canvas--dark .form-control{background:var(--sn-panel-2);color:var(--sn-ink);border-color:var(--sn-line)}
.sn-canvas--dark .form-control::placeholder{color:var(--sn-muted)}
.sn-canvas--dark .form-control:focus{background:var(--sn-panel-2);color:var(--sn-ink);border-color:var(--sn-volt);background-image:none !important;box-shadow:none !important;outline:none}
.sn-canvas--dark label,.sn-canvas--dark .control-label{color:var(--sn-ink)}
.sn-canvas--dark .btn-default{background:var(--sn-panel-2);color:var(--sn-ink);border-color:var(--sn-line)}
.sn-canvas--dark .btn-default:hover{background:#22262f;color:#fff}
/* btn-primary (bv. "Zoeken" op clubs_db) rendert standaard als rode platte tekst — volt-knop forceren */
.sn-canvas--dark .btn-primary{background:var(--sn-volt) !important;color:#0c0d10 !important;border:none !important;font-weight:700;box-shadow:none !important}
.sn-canvas--dark .btn-primary:hover,.sn-canvas--dark .btn-primary:focus,.sn-canvas--dark .btn-primary:active{background:#d6ff45 !important;color:#0c0d10 !important}
.sn-canvas--dark .input-group-btn .btn{margin-left:6px}

/* Kalender (views/kalender_db.php) */
.sn-canvas--dark .kd-day{background:var(--sn-panel) !important;box-shadow:none !important;border:1px solid var(--sn-line)}
.sn-canvas--dark .kd-day-head{background:var(--sn-panel-2) !important;border-bottom-color:var(--sn-line) !important}
.sn-canvas--dark .kd-day-head:hover{background:#22262f !important}
.sn-canvas--dark .kd-day-date{color:var(--sn-ink) !important}
.sn-canvas--dark .kd-day-count,.sn-canvas--dark .kd-afd-label,
.sn-canvas--dark .kd-uur,.sn-canvas--dark .kd-memo,.sn-canvas--dark .kd-empty{color:var(--sn-muted) !important}
.sn-canvas--dark .kd-match{border-bottom-color:var(--sn-line) !important}
.sn-canvas--dark .kd-team a{color:var(--sn-ink) !important}
.sn-canvas--dark .kd-team a:hover{color:var(--sn-volt) !important}
.sn-canvas--dark .kd-badge-uit{background:rgba(230,126,34,.15) !important;color:#e67e22 !important}
.sn-canvas--dark .kd-badge-ff{background:rgba(146,43,33,.25) !important;color:#ff6b5e !important}
.sn-canvas--dark .kd-badge-terrein{background:rgba(39,174,96,.15) !important;color:#2ecc71 !important}

/* Clubs (views/clubs_db.php) */
.sn-canvas--dark .cdb-card{background:var(--sn-panel) !important;box-shadow:none !important;border:1px solid var(--sn-line)}
.sn-canvas--dark .cdb-card-head{background:var(--sn-panel-2) !important;border-bottom-color:var(--sn-line) !important}
.sn-canvas--dark .cdb-stamnr,.sn-canvas--dark .cdb-info,
.sn-canvas--dark .cdb-kit-naam,.sn-canvas--dark .cdb-row i{color:var(--sn-muted) !important}
/* clubnaam standaard in volt (hover-kleur), onderlijnen bij hover */
.sn-canvas--dark .cdb-ploegnaam,
.sn-canvas--dark .cdb-ploegnaam a{color:var(--sn-volt) !important;text-decoration:none}
.sn-canvas--dark .cdb-ploegnaam a:hover{color:var(--sn-volt) !important;text-decoration:underline}
.sn-canvas--dark .cdb-row a,
.sn-canvas--dark .cdb-kalender{color:var(--sn-volt) !important}
.sn-canvas--dark .cdb-afdeling{background:var(--sn-volt) !important;color:#0c0d10 !important}
.sn-canvas--dark .cdb-kit-badge.thuis{background:rgba(39,174,96,.15) !important;color:#2ecc71 !important}
.sn-canvas--dark .cdb-kit-badge.uit{background:rgba(41,128,185,.18) !important;color:#5dade2 !important}
.sn-canvas--dark .cdb-kunstgras{background:rgba(39,174,96,.12) !important;color:#2ecc71 !important;border-color:rgba(39,174,96,.3) !important}

/* Schorsingen (views/schorsingenbekijken*.php) */
.sn-canvas--dark .sbk-card,.sn-canvas--dark .sbh-card{background:var(--sn-panel) !important;box-shadow:none !important;border:1px solid var(--sn-line)}
.sn-canvas--dark .sbk-section-title,.sn-canvas--dark .sbh-section-title{color:var(--sn-muted) !important;border-bottom-color:var(--sn-line) !important}
.sn-canvas--dark .sbk-table thead th,.sn-canvas--dark .sbh-table thead th{color:var(--sn-muted) !important;border-bottom-color:var(--sn-line) !important}
.sn-canvas--dark .sbk-table tbody td,.sn-canvas--dark .sbh-table tbody td{color:var(--sn-ink) !important;border-bottom-color:var(--sn-line) !important}
.sn-canvas--dark .sbk-table tbody tr:hover td,.sn-canvas--dark .sbh-table tbody tr:hover td{background:rgba(255,255,255,.03) !important}

/* Clubnieuws publiek (views/clubnieuws_publiek.php) */
.sn-canvas--dark .cpub-card{background:var(--sn-panel) !important;box-shadow:none !important;border:1px solid var(--sn-line)}
.sn-canvas--dark .cpub-clubnaam{color:var(--sn-volt) !important}
.sn-canvas--dark .cpub-titel{color:var(--sn-ink) !important}
.sn-canvas--dark .cpub-tekst{color:#c8ccd4 !important}
.sn-canvas--dark .cpub-meta,.sn-canvas--dark .cpub-empty{color:var(--sn-muted) !important}
.sn-canvas--dark .cpub-pdf-link{background:var(--sn-panel-2) !important;border-color:var(--sn-line) !important;color:var(--sn-ink) !important}
.sn-canvas--dark .cpub-pdf-link:hover{background:#22262f !important;color:#fff !important}
.sn-canvas--dark .cpub-sep{border-top-color:var(--sn-line) !important}

/* CMS-tekstpagina (view=page) met dark_theme=1 — zelf geschreven inhoud */
/* Titelbalk als nette kop boven het inhoudskaartje */
.sn-canvas--dark .titel1{
    max-width:900px;margin:0 0 16px !important;
    font-family:var(--sn-display);font-size:30px !important;line-height:1.1;
    color:var(--sn-ink) !important;text-transform:uppercase;letter-spacing:.01em;
    padding-bottom:14px;border-bottom:3px solid var(--sn-volt);font-weight:400 !important;
}
/* Inhoud in een donker kaartje, links uitgelijnd onder de titel */
.sn-canvas--dark .pageContent{
    background:var(--sn-panel);border:1px solid var(--sn-line);border-radius:var(--sn-r);
    padding:30px 36px;max-width:900px;margin:0;
    color:#cdd2da;font-size:15.5px;line-height:1.7;
}
.sn-canvas--dark .pageContent p{margin:0 0 14px}
.sn-canvas--dark .pageContent h1,.sn-canvas--dark .pageContent h2,.sn-canvas--dark .pageContent h3,
.sn-canvas--dark .pageContent h4,.sn-canvas--dark .pageContent h5,.sn-canvas--dark .pageContent h6{
    color:var(--sn-ink);margin:22px 0 10px;font-weight:700;line-height:1.25}
.sn-canvas--dark .pageContent strong,.sn-canvas--dark .pageContent b{color:var(--sn-ink)}
.sn-canvas--dark .pageContent u{text-decoration-color:var(--sn-volt)}
/* #content a / #main a (styles.css) forceren content-links naar #1e2d3d met
   ID-specificiteit, wat op donkere pagina's onleesbaar is — overschrijven met
   !important zodat content- en tabel-links volt worden (bv. club_uniek uitslagen). */
.sn-canvas--dark .pageContent a,
.sn-canvas--dark .table a,
.sn-canvas--dark .table-responsive a{color:var(--sn-volt) !important}
.sn-canvas--dark .pageContent a:hover,
.sn-canvas--dark .table a:hover,
.sn-canvas--dark .table-responsive a:hover{color:#fff !important}
.sn-canvas--dark .pageContent hr{border-color:var(--sn-line);margin:18px 0}
.sn-canvas--dark .pageContent img{max-width:100%;height:auto;border-radius:6px}
.sn-canvas--dark .pageContent ul,.sn-canvas--dark .pageContent ol{padding-left:22px;margin:0 0 14px}
.sn-canvas--dark .pageContent li{margin-bottom:5px}
.sn-canvas--dark .pageContent table{color:#cdd2da;width:100%;border-collapse:collapse;margin:6px 0 16px}
.sn-canvas--dark .pageContent table td,.sn-canvas--dark .pageContent table th{border:1px solid var(--sn-line) !important;padding:7px 10px}
.sn-canvas--dark .pageContent table th{background:var(--sn-panel-2);color:var(--sn-ink)}
.sn-canvas--dark .pageContent blockquote{border-left:3px solid var(--sn-volt);color:#cdd2da;margin:14px 0;padding:6px 0 6px 16px}
.sn-canvas--dark .pageContent .list-group-item{background:var(--sn-panel-2);border-color:var(--sn-line);color:#cdd2da}

/* ── Footer ─────────────────────────────────────────────────────────────── */
.sn-footer{background:#000;border-top:1px solid var(--sn-line);padding:56px 0 28px;margin-top:0}
.sn-footer .fgrid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px}
.sn-footer .fbrand img{height:50px;margin-bottom:16px}
.sn-footer .fbrand p{color:var(--sn-muted);font-size:14px;line-height:1.6;max-width:300px}
.sn-footer .fcol h4{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--sn-volt);margin-bottom:14px;font-weight:700}
.sn-footer .fcol a{display:block;color:#aeb3bd;font-size:14px;padding:6px 0}
.sn-footer .fcol a:hover{color:#fff}
.sn-footer .fbot{display:flex;justify-content:space-between;align-items:center;margin-top:42px;padding-top:22px;border-top:1px solid var(--sn-line);font-size:12.5px;color:#5b606b;flex-wrap:wrap;gap:10px}

/* ════════════════════════════════════════════════════════════════════════
   HOMEPAGE (.sn-home)
   ════════════════════════════════════════════════════════════════════════ */
.sn-home{color:var(--sn-ink)}
.sn-home *{box-sizing:border-box}
.sn-home .display{font-family:var(--sn-display);font-weight:400;letter-spacing:.005em;text-transform:uppercase;line-height:.92}
.sn-home .eyebrow{font-size:12px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--sn-volt)}

/* hero */
.sn-home .hero{position:relative;padding:84px 0 70px;overflow:hidden}
.sn-home .hero::before{content:"";position:absolute;inset:0;background:
   radial-gradient(120% 90% at 88% -10%, rgba(200,241,53,.16), transparent 55%),
   radial-gradient(80% 80% at 0% 110%, rgba(255,77,61,.10), transparent 60%)}
.sn-home .hero .grid{position:absolute;inset:0;background-image:linear-gradient(var(--sn-line) 1px,transparent 1px),linear-gradient(90deg,var(--sn-line) 1px,transparent 1px);background-size:64px 64px;opacity:.25;mask-image:linear-gradient(180deg,#000,transparent 80%)}
.sn-home .hero .sn-wrap{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:54px;align-items:center}
.sn-home .hero h1{font-size:104px;margin:22px 0 0}
.sn-home .hero h1 .vt{color:var(--sn-volt)}
.sn-home .hero p.lead{font-size:18px;line-height:1.55;color:#c2c6cf;max-width:440px;margin-top:26px}
.sn-home .hero .cta{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap}
.sn-home .season-tag{display:inline-flex;align-items:center;gap:10px;font-size:12.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#0c0d10;background:var(--sn-volt);padding:7px 14px;border-radius:6px}

/* scorecard */
.sn-home .scorecard{background:var(--sn-panel);border:1px solid var(--sn-line);border-radius:18px;overflow:hidden;box-shadow:0 30px 70px -30px rgba(0,0,0,.8)}
.sn-home .sc-h{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--sn-line);font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--sn-muted)}
.sn-home .live{display:flex;align-items:center;gap:7px;color:var(--sn-red)}
.sn-home .live .dot{width:8px;height:8px;border-radius:50%;background:var(--sn-red);animation:sn-pulse 1.6s infinite}
@keyframes sn-pulse{0%{box-shadow:0 0 0 0 rgba(255,77,61,.55)}70%{box-shadow:0 0 0 9px rgba(255,77,61,0)}100%{box-shadow:0 0 0 0 rgba(255,77,61,0)}}
.sn-home .sc-row{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:18px;gap:10px}
.sn-home .sc-team{display:flex;align-items:center;gap:12px;font-weight:700;font-size:16px}
.sn-home .sc-team.r{flex-direction:row-reverse;text-align:right}
.sn-home .sc-badge{width:34px;height:34px;border-radius:9px;background:var(--sn-panel-2);border:1px solid var(--sn-line);display:grid;place-items:center;font-family:var(--sn-display);font-size:13px;color:var(--sn-volt)}
.sn-home .sc-score{font-family:var(--sn-display);font-size:42px;letter-spacing:.04em;display:flex;gap:12px;align-items:center}
.sn-home .sc-foot{display:flex;justify-content:space-between;padding:12px 18px;border-top:1px solid var(--sn-line);font-size:12.5px;color:var(--sn-muted)}
.sn-home .sc-mini{padding:0 18px 16px}
.sn-home .sc-mini .m{display:flex;justify-content:space-between;align-items:center;padding:11px 0;border-top:1px solid var(--sn-line);font-size:14px}
.sn-home .sc-mini .m b{font-family:var(--sn-display);font-size:16px;letter-spacing:.03em}
.sn-home .sc-mini .m .nm{color:#cfd2da;font-weight:600}

/* champion-card (vervangt topper wanneer competitie afgelopen) */
.sn-home .sc-champ{background:linear-gradient(160deg,#1a1d24 0%,#0f1116 100%);border-color:rgba(212,175,55,.3);box-shadow:0 30px 70px -30px rgba(212,175,55,.25),0 0 0 1px rgba(212,175,55,.1) inset}
.sn-home .sc-champ .sc-h{border-bottom-color:rgba(212,175,55,.18);color:#d4af37}
.sn-home .sc-champ .sc-h .live{color:#d4af37}
.sn-home .sc-champ .sc-h .live .dot{background:#d4af37;animation:sn-pulse-gold 1.8s infinite}
@keyframes sn-pulse-gold{0%{box-shadow:0 0 0 0 rgba(212,175,55,.55)}70%{box-shadow:0 0 0 10px rgba(212,175,55,0)}100%{box-shadow:0 0 0 0 rgba(212,175,55,0)}}
.sn-home .sc-champ-body{padding:22px 18px 16px;text-align:center}
.sn-home .sc-champ-trofee{font-size:58px;line-height:1;filter:drop-shadow(0 6px 18px rgba(212,175,55,.45));margin-bottom:8px}
.sn-home .sc-champ-naam{font-family:var(--sn-display);font-size:30px;letter-spacing:.02em;color:#fff;margin-bottom:4px;line-height:1.05}
.sn-home .sc-champ-afd{font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#d4af37;margin-bottom:18px}
.sn-home .sc-champ-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;border-top:1px solid rgba(212,175,55,.18);padding-top:14px}
.sn-home .sc-champ-stats .cs{display:flex;flex-direction:column;align-items:center;gap:2px}
.sn-home .sc-champ-stats .cs b{font-family:var(--sn-display);font-size:24px;color:#fff;letter-spacing:.04em}
.sn-home .sc-champ-stats .cs span{font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--sn-muted)}
/* overige reeks-kampioenen onderaan de hero kampioenskaart */
.sn-home .sc-champ-rest{padding:14px 18px 18px;border-top:1px solid rgba(212,175,55,.18)}
.sn-home .sc-champ-rest-title{font-size:10.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--sn-muted);margin-bottom:8px}
.sn-home .sc-champ-rest-row{display:grid;grid-template-columns:24px 60px 1fr auto;align-items:center;gap:8px;padding:6px 0;border-top:1px solid rgba(212,175,55,.08);font-size:13.5px}
.sn-home .sc-champ-rest-row:first-of-type{border-top:0}
.sn-home .sc-champ-rest-row .r-medal{font-size:14px;line-height:1;opacity:.85}
.sn-home .sc-champ-rest-row .r-reeks{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#d4af37}
.sn-home .sc-champ-rest-row .r-naam{color:#fff;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sn-home .sc-champ-rest-row .r-pnt{font-family:var(--sn-display);font-size:15px;color:#d4af37;letter-spacing:.04em;padding-left:6px}
.sn-home .sc-champ-rest-row .r-pnt::after{content:" ptn";font-family:var(--sn-sans, inherit);font-size:10.5px;color:var(--sn-muted);font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-left:2px}

/* ticker */
.sn-home .ticker{background:var(--sn-volt);color:#0c0d10;overflow:hidden;white-space:nowrap;border-top:1px solid #0c0d10;border-bottom:1px solid #0c0d10}
.sn-home .ticker .run{display:inline-flex;gap:40px;padding:11px 0;font-weight:700;font-size:13.5px;letter-spacing:.04em;text-transform:uppercase;animation:sn-scroll 32s linear infinite}
.sn-home .ticker .run span{display:inline-flex;gap:40px}
.sn-home .ticker .run a{display:inline-flex;align-items:center;color:#0c0d10;text-decoration:none}
.sn-home .ticker .run a:hover{text-decoration:underline}
.sn-home .ticker:hover .run{animation-play-state:paused}  /* pauzeer zodat items klikbaar zijn */
.sn-home .ticker b{font-family:var(--sn-display);letter-spacing:.05em}
@keyframes sn-scroll{to{transform:translateX(-50%)}}

/* section frame */
.sn-home section.blk{padding:74px 0}
.sn-home .sec-h{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:34px;gap:16px;flex-wrap:wrap}
.sn-home .sec-h h2{font-size:44px;margin-top:8px}
.sn-home .sec-h a.more{font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--sn-muted);display:inline-flex;gap:7px;align-items:center}
.sn-home .sec-h a.more:hover{color:var(--sn-volt)}

/* news */
.sn-home .news-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:22px}
.sn-home .ncard.feat{grid-row:span 2}   /* uitgelichte kaart links, 4 kleine rechts (2×2) */
.sn-home .ncard{background:var(--sn-panel);border:1px solid var(--sn-line);border-radius:var(--sn-r);overflow:hidden;display:flex;flex-direction:column;transition:.18s}
.sn-home .ncard:hover{border-color:#3a3f4b;transform:translateY(-3px)}
.sn-home .ncard .ph{position:relative;height:200px;background:#0e0f13;background-size:contain;background-repeat:no-repeat;background-position:center}
.sn-home .ncard.feat .ph{height:280px}
.sn-home .ph .tag{position:absolute;left:14px;top:14px;background:var(--sn-volt);color:#0c0d10;font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:5px 11px;border-radius:6px;z-index:2}
.sn-home .ph .ghost{position:absolute;inset:0;display:grid;place-items:center;color:#3a3f4b;font-family:ui-monospace,monospace;font-size:12px;letter-spacing:.08em}
.sn-home .ncard .bd{padding:20px 20px 22px;display:flex;flex-direction:column;gap:10px;flex:1}
.sn-home .ncard .meta{font-size:12px;color:var(--sn-muted);font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.sn-home .ncard h3{font-size:19px;font-weight:700;line-height:1.25}
.sn-home .ncard.feat h3{font-size:26px}
.sn-home .ncard p{font-size:14px;color:#aeb3bd;line-height:1.5}

/* results + standings */
.sn-home .two{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.sn-home .pane{background:var(--sn-panel);border:1px solid var(--sn-line);border-radius:var(--sn-r);overflow:hidden}
.sn-home .pane .ph2{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--sn-line)}
.sn-home .pane .ph2 h3{font-family:var(--sn-display);font-size:22px;letter-spacing:.03em}
.sn-home .pane .ph2 .pick{font-size:12px;font-weight:700;color:var(--sn-volt);letter-spacing:.06em;text-transform:uppercase}
.sn-home .res{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;border-bottom:1px solid var(--sn-line);font-size:15px}
.sn-home .res:last-child{border-bottom:0}
.sn-home .res .t{flex:1;font-weight:600}
.sn-home .res .t.a{text-align:right}
.sn-home .res .sc{font-family:var(--sn-display);font-size:20px;background:var(--sn-panel-2);border:1px solid var(--sn-line);border-radius:8px;padding:4px 12px;letter-spacing:.06em;margin:0 16px;min-width:74px;text-align:center}
.sn-home .res .sc.win{color:var(--sn-volt)}
/* Klikbare wedstrijd-links naar wedstrijd_publiek */
.sn-home a.res,.sn-home a.sc-link,.sn-home .sc-mini a.m{text-decoration:none;color:inherit;cursor:pointer}
.sn-home a.sc-link{display:block;transition:background .12s}
.sn-home a.res{transition:background .12s}
.sn-home a.res:hover{background:rgba(255,255,255,.04)}
.sn-home a.sc-link:hover{background:rgba(255,255,255,.03)}
.sn-home a.res:hover .t{color:var(--sn-volt)}
.sn-home .sc-mini a.m:hover .nm{color:var(--sn-volt)}
.sn-home .tbl{width:100%;border-collapse:collapse}
.sn-home .tbl th{text-align:left;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--sn-muted);font-weight:700;padding:14px 22px;border-bottom:1px solid var(--sn-line)}
.sn-home .tbl td{padding:13px 22px;border-bottom:1px solid var(--sn-line);font-size:14.5px;font-weight:600}
.sn-home .tbl tr:last-child td{border-bottom:0}
.sn-home .tbl .pos{font-family:var(--sn-display);color:var(--sn-muted);width:30px}
.sn-home .tbl .pts{font-family:var(--sn-display);color:var(--sn-volt);text-align:right}
.sn-home .tbl .center{text-align:center;color:var(--sn-muted);font-weight:600}
.sn-home .tbl tr.top td{background:linear-gradient(90deg,rgba(200,241,53,.07),transparent)}
.sn-home .tbl tr.top .pos{color:var(--sn-volt)}

/* scorers */
.sn-home .scorers{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.sn-home .scr{background:var(--sn-panel);border:1px solid var(--sn-line);border-radius:var(--sn-r);padding:22px;position:relative;overflow:hidden}
.sn-home .scr .rk{font-family:var(--sn-display);font-size:60px;color:var(--sn-panel-2);position:absolute;right:14px;top:2px;line-height:1}
.sn-home .scr .nm{font-weight:700;font-size:17px;position:relative}
.sn-home .scr .cl{font-size:13px;color:var(--sn-muted);margin-top:3px}
.sn-home .scr .scr-reeks{display:inline-block;margin-left:6px;padding:1px 7px;border-radius:9px;
    font-size:10px;font-weight:700;background:rgba(200,241,53,.14);color:var(--sn-volt);
    text-transform:uppercase;letter-spacing:.03em;vertical-align:middle}
.sn-home .scr .gl{font-family:var(--sn-display);font-size:38px;color:var(--sn-volt);margin-top:14px;display:flex;align-items:baseline;gap:7px}
.sn-home .scr .gl span{font-family:var(--sn-font);font-size:12px;font-weight:700;color:var(--sn-muted);letter-spacing:.08em;text-transform:uppercase}

/* topaffiches (aankomend, op moeilijkheid) */
.sn-home .affiches{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.sn-home .aff{display:flex;flex-direction:column;gap:12px;background:var(--sn-panel);border:1px solid var(--sn-line);border-radius:var(--sn-r);padding:20px 22px;text-decoration:none;color:inherit;transition:background .12s,border-color .12s}
.sn-home .aff:hover{background:var(--sn-panel-2);border-color:#33384280}
.sn-home .aff.top{border-color:var(--sn-volt)}
.sn-home .aff-top{display:flex;align-items:center;justify-content:space-between;gap:8px}
.sn-home .aff-date{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--sn-muted)}
.sn-home .aff-tag{font-family:var(--sn-display);font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:#0c0d10;background:var(--sn-volt);padding:2px 9px;border-radius:20px}
.sn-home .aff-teams{display:flex;align-items:center;gap:10px;font-family:var(--sn-display);font-size:21px;line-height:1.1;color:var(--sn-ink)}
.sn-home .aff-teams span{flex:1}
.sn-home .aff-teams span:last-of-type{text-align:right}
.sn-home .aff-teams b{font-family:var(--sn-font);font-size:12px;font-weight:700;color:var(--sn-muted);text-transform:uppercase}
.sn-home .aff:hover .aff-teams{color:var(--sn-volt)}
.sn-home .aff-foot{font-size:12.5px;color:var(--sn-muted);margin-top:auto}
@media(max-width:760px){.sn-home .affiches{grid-template-columns:1fr}}

/* calendar */
.sn-home .cal{background:var(--sn-panel);border:1px solid var(--sn-line);border-radius:var(--sn-r);overflow:hidden}
.sn-home .cal .ch{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--sn-line)}
.sn-home .cal .ch .dd{font-family:var(--sn-display);font-size:20px;letter-spacing:.03em}
.sn-home .crow{display:grid;grid-template-columns:90px 1fr auto;align-items:center;gap:20px;padding:16px 24px;border-bottom:1px solid var(--sn-line)}
.sn-home .crow:last-child{border-bottom:0}
.sn-home .crow .tm{font-family:var(--sn-display);font-size:18px;color:var(--sn-volt)}
.sn-home .crow .mt{font-weight:700;font-size:15.5px}
.sn-home .crow .mt span{color:var(--sn-muted);font-weight:500;padding:0 8px}
.sn-home .crow .vn{font-size:13px;color:var(--sn-muted);text-align:right}

/* facebook paginawidget */
.sn-home .fbx{display:grid;grid-template-columns:1.3fr auto;align-items:center;gap:40px;background:var(--sn-panel);border:1px solid var(--sn-line);border-radius:20px;padding:42px 48px}
.sn-home .fbx-l .display{font-size:42px}
.sn-home .fbx-l .display .vt{color:var(--sn-volt)}
.sn-home .fbx-l p{font-size:16px;color:var(--sn-muted);margin:14px 0 24px;max-width:430px;line-height:1.6}
.sn-home .fbx-r{background:#fff;border-radius:12px;padding:6px;line-height:0;justify-self:end}
.sn-home .fbx-r iframe{border-radius:8px;max-width:100%}
@media(max-width:860px){
    .sn-home .fbx{grid-template-columns:1fr;padding:28px 22px}
    .sn-home .fbx-r{justify-self:center}
}

/* ref CTA */
.sn-home .ref{position:relative;border-radius:20px;overflow:hidden;background:var(--sn-volt);color:#0c0d10;display:grid;grid-template-columns:1.3fr 1fr;align-items:center}
.sn-home .ref .l{padding:50px 54px}
.sn-home .ref h2{font-size:50px}
.sn-home .ref p{font-size:17px;font-weight:600;margin:16px 0 26px;max-width:430px;line-height:1.5}
.sn-home .ref .r{align-self:stretch;background:repeating-linear-gradient(135deg,#b9df2a 0 22px,#c8f135 22px 44px);position:relative;min-height:200px}
.sn-home .ref .r .ws{position:absolute;inset:0;display:grid;place-items:center}
.sn-home .ref .r .ws .wh{font-family:var(--sn-display);font-size:130px;color:rgba(12,13,16,.12);letter-spacing:.05em}

/* stats */
.sn-home .stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--sn-line);border-radius:var(--sn-r);overflow:hidden;background:var(--sn-panel)}
.sn-home .stat{padding:34px 30px;border-right:1px solid var(--sn-line)}
.sn-home .stat:last-child{border-right:0}
.sn-home .stat .n{font-family:var(--sn-display);font-size:52px;color:var(--sn-ink)}
.sn-home .stat .n .vt{color:var(--sn-volt)}
.sn-home .stat .l{font-size:13px;color:var(--sn-muted);font-weight:600;letter-spacing:.06em;text-transform:uppercase;margin-top:6px}

/* ════════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════════════════════════ */
@media (max-width:1100px){
  .sn-home .hero h1{font-size:78px}
  .sn-home .scorers{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:960px){
  .sn-nav,.sn-header-cta{display:none}
  .sn-burger{display:flex}
  .sn-home .hero .sn-wrap{grid-template-columns:1fr;gap:34px}
  .sn-home .two{grid-template-columns:1fr}
  .sn-home .ref{grid-template-columns:1fr}
  .sn-home .ref .r{display:none}
  .sn-footer .fgrid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .sn-wrap{padding:0 22px}
  .sn-home .hero{padding:54px 0 44px}
  .sn-home .hero h1{font-size:58px}
  .sn-home section.blk{padding:48px 0}
  .sn-home .sec-h h2{font-size:34px}
  .sn-home .news-grid{grid-template-columns:1fr}
  .sn-home .ncard.feat{grid-row:auto}
  .sn-home .stats{grid-template-columns:1fr 1fr}
  .sn-home .stat{border-bottom:1px solid var(--sn-line)}
  .sn-home .scorers{grid-template-columns:1fr 1fr}
  .sn-footer .fgrid{grid-template-columns:1fr}
}
@media (max-width:480px){
  .sn-home .hero h1{font-size:46px}
  .sn-home .scorers{grid-template-columns:1fr}
  .sn-home .crow{grid-template-columns:64px 1fr;gap:10px}
  .sn-home .crow .vn{display:none}
}
