:root{
  --grass:#E20613;        /* ASV-rood — hoofdkleur (knoppen, koppen, accenten) */
  --grass-2:#C40510;      /* iets dieper rood voor verlopen/hover */
  --pitch-ink:#1D1E1E;    /* ASV-zwart — scorebord, donkere vlakken */
  --line:rgba(255,255,255,.82);
  --paper:#F2F2F0;
  --card:#FFFFFF;
  --ink:#1D1E1E;          /* tekst: clubzwart */
  --ink-2:#6E6E6C;        /* gedempte tekst, neutraal grijs */
  --hair:#E2E2DE;
  --fluo:#FFFFFF;         /* accent op donkere vlakken (cijfers, klok, login-titel) */
  --accent:#E20613;       /* accent op lichte vlakken (badges, pijlen, knoppen) */
  --veld:#2E7D46;         /* het voetbalveld blijft groen */
  --veld-2:#28713F;
  --in:#3FB950;
  --uit:#E5484D;
  --keeper:#F2A33C;
  --radius:14px;
  --shadow:0 1px 2px rgba(29,30,30,.08), 0 4px 14px rgba(29,30,30,.07);
  /* beoordeling: 5-niveau kleurenschaal */
  --n1:#E5484D; --n2:#F2913C; --n3:#F2C94C; --n4:#7DCB6A; --n5:#2EA043;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--paper);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  overscroll-behavior-y:none;
}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select{font:inherit;color:inherit}
.cond{font-family:'Barlow Condensed',sans-serif}

.app{max-width:540px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column}
.view{flex:1;padding:16px 16px 96px;display:none}
.view.actief{display:block}

/* ---------- Kop ---------- */
.kop{display:flex;align-items:center;gap:10px;margin-bottom:16px;min-height:40px}
.kop h1{font-family:'Barlow Condensed';font-weight:700;font-size:26px;letter-spacing:.3px;text-transform:uppercase;flex:1;line-height:1.05}
.kop .sub{font-size:13px;color:var(--ink-2);font-family:'Inter';text-transform:none;letter-spacing:0;font-weight:500;display:block;margin-top:2px}
.terug{width:38px;height:38px;border-radius:10px;background:var(--card);box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}

/* ---------- Knoppen ---------- */
.knop{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:11px;padding:11px 18px;font-weight:600;font-size:15px;background:var(--pitch-ink);color:#fff;box-shadow:var(--shadow)}
.knop.vol{width:100%}
.knop.licht{background:var(--card);color:var(--ink)}
.knop.fluo{background:var(--accent);color:#fff}
.knop.klein{padding:7px 12px;font-size:13px;border-radius:9px}
.knop.gevaar{background:#fff;color:var(--uit)}
.knop:disabled{opacity:.45;cursor:default}

/* ---------- Kaarten / lijsten ---------- */
.kaart{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px;margin-bottom:12px}
.lijst-item{display:flex;align-items:center;gap:12px;padding:13px 14px;background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:10px;width:100%;text-align:left}
.lijst-item .titel{font-weight:600;font-size:15px}
.lijst-item .meta{font-size:12.5px;color:var(--ink-2);margin-top:1px}
.lijst-item .pijl{margin-left:auto;color:var(--ink-2)}
.leeg{padding:34px 20px;text-align:center;color:var(--ink-2);font-size:14px;line-height:1.55}
.leeg b{color:var(--ink)}

/* ---------- Formulieren ---------- */
.veldgroep{margin-bottom:14px}
.veldgroep label{display:block;font-size:12.5px;font-weight:600;color:var(--ink-2);margin-bottom:6px;text-transform:uppercase;letter-spacing:.4px}
.invoer{width:100%;padding:11px 13px;border:1.5px solid var(--hair);border-radius:11px;background:#fff;font-size:15px}
textarea.invoer{font-family:inherit;line-height:1.5;resize:vertical;min-height:64px}
.invoer:focus{outline:none;border-color:var(--grass)}
.rij{display:flex;gap:10px}
.rij>*{flex:1}

/* ---------- Segment (formaat, kwarten) ---------- */
.segment{display:flex;background:#E3E8E0;border-radius:11px;padding:3px;gap:3px}
.segment.wrap{flex-wrap:wrap}
.segment.wrap button{flex:1 1 30%;min-width:80px}
.segment button{flex:1;padding:9px 4px;border-radius:9px;font-weight:600;font-size:14px;color:var(--ink-2)}
.segment button.actief{background:var(--card);color:var(--ink);box-shadow:0 1px 3px rgba(16,39,26,.15)}

/* ---------- Geplande wissels ---------- */
.plan-lijst{margin-top:12px;border-top:1px solid rgba(255,255,255,.12);padding-top:10px}
.plan-kop{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:8px}
.plan-item{display:flex;align-items:center;gap:9px;background:rgba(255,255,255,.07);border-radius:10px;padding:8px 10px;margin-bottom:6px;font-size:13px;color:#fff}
.plan-item .nr{font-family:'Barlow Condensed';font-weight:700;font-size:20px;line-height:1}
.plan-item .nr.in{color:var(--in)}
.plan-item .nr.uit{color:var(--uit)}
.plan-item .min{margin-left:auto;font-family:"Barlow Condensed";font-weight:700;font-size:17px;color:var(--accent)}
.plan-item .pk{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.plan-item .pk.ok{background:var(--accent);color:#fff}
.plan-item .pk.weg{color:rgba(255,255,255,.5)}
.plan-item.nu{outline:2px solid var(--accent);animation:planPuls 1.1s ease-in-out infinite}
@keyframes planPuls{0%,100%{box-shadow:0 0 0 0 rgba(226,6,19,.45)}50%{box-shadow:0 0 0 7px rgba(226,6,19,0)}}
.plan-toevoegen{width:100%;margin-top:4px;padding:9px;border:1.5px dashed rgba(255,255,255,.3);border-radius:10px;color:rgba(255,255,255,.65);font-size:13px;font-weight:600}

/* ---------- Kwart-tabs ---------- */
.kwarten{display:flex;gap:6px;margin-bottom:12px}
.kwarten button{flex:1;padding:10px 0;border-radius:11px;background:var(--card);box-shadow:var(--shadow);font-family:'Barlow Condensed';font-weight:700;font-size:18px;letter-spacing:.5px;color:var(--ink-2)}
.kwarten button.actief{background:var(--pitch-ink);color:var(--fluo)}

/* ---------- Het veld ---------- */
.veld-wrap{position:relative;border-radius:16px;overflow:hidden;box-shadow:var(--shadow)}
.veld{
  position:relative;aspect-ratio:3/4;width:100%;
  background:repeating-linear-gradient(0deg,var(--veld) 0 12.5%,var(--veld-2) 12.5% 25%);
}
.veld .lijn{position:absolute;border:2px solid var(--line)}
.veld .midden{left:0;right:0;top:50%;border-width:1px 0 0}
.veld .cirkel{left:50%;top:50%;width:24%;aspect-ratio:1;transform:translate(-50%,-50%);border-radius:50%}
.veld .zestien-b{left:22%;right:22%;bottom:-2px;height:13%;border-bottom:none}
.veld .zestien-o{left:22%;right:22%;top:-2px;height:13%;border-top:none}
.veld .vijf-b{left:36%;right:36%;bottom:-2px;height:5.5%;border-bottom:none}
.veld .vijf-o{left:36%;right:36%;top:-2px;height:5.5%;border-top:none}

/* posities en chips */
.slot{position:absolute;transform:translate(-50%,-50%);width:64px;display:flex;flex-direction:column;align-items:center;gap:3px}
.slot .ring{width:46px;height:46px;border-radius:50%;border:2px dashed rgba(255,255,255,.55);display:flex;align-items:center;justify-content:center;font-family:'Barlow Condensed';font-weight:600;font-size:14px;color:rgba(255,255,255,.75);letter-spacing:.5px}
.slot.doel ring{border-color:rgba(242,163,60,.8)}
.chip{display:flex;flex-direction:column;align-items:center;gap:3px;user-select:none;-webkit-user-select:none;cursor:pointer}
.chip .shirt{
  width:46px;height:46px;border-radius:50%;
  background:#fff;color:var(--pitch-ink);
  display:flex;align-items:center;justify-content:center;
  font-family:'Barlow Condensed';font-weight:700;font-size:21px;
  box-shadow:0 2px 6px rgba(0,0,0,.28);
  border:2.5px solid #fff;
}
.chip.keeper .shirt{background:var(--keeper);border-color:var(--keeper);color:#fff}
.chip .naam{font-size:10.5px;font-weight:600;color:#fff;background:rgba(16,39,26,.78);padding:2px 7px;border-radius:99px;max-width:78px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chip.geselecteerd .shirt{border-color:var(--accent);box-shadow:0 0 0 4px rgba(226,6,19,.45)}
.slot.doelwit .ring{border-color:var(--accent);border-style:solid;background:rgba(226,6,19,.14)}
.chip.sleept{opacity:.35}

/* sleep-kloon */
#sleepKloon{position:fixed;z-index:99;pointer-events:none;transform:translate(-50%,-60%)}

/* ---------- Kwart-stippen (gespeeld/bank historie) ---------- */
.dots{display:flex;gap:2.5px;margin-top:2px;justify-content:center}
.dot{width:5px;height:5px;border-radius:50%}
.dot.s{background:var(--in)}
.dot.b{background:var(--uit)}

/* ---------- Scorebord ---------- */
.scorebord{background:var(--pitch-ink);border-radius:var(--radius);padding:10px 12px;margin-bottom:12px;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow)}
.scorebord .sb-team{flex:1;font-family:'Barlow Condensed';font-weight:600;font-size:14px;letter-spacing:.5px;color:rgba(255,255,255,.75);text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:center}
.scorebord .sb-cijfers{font-family:'Barlow Condensed';font-weight:700;font-size:34px;letter-spacing:2px;color:var(--fluo);line-height:1;font-variant-numeric:tabular-nums;white-space:nowrap}
.scorebord .sb-goal{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.1);font-size:17px;flex-shrink:0}
.goal-kies{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;padding:8px 0 4px}
.goal-kies .chip .naam{color:var(--ink);background:#E3E8E0}
.log .goal-bal{font-size:18px;min-width:30px;text-align:center}

/* ---------- Aanvoerdersband ---------- */
.aanvoerder-band{position:absolute;top:-3px;right:-3px;width:18px;height:18px;border-radius:50%;background:var(--accent);color:#fff;font-family:'Barlow Condensed';font-weight:700;font-size:12px;display:flex;align-items:center;justify-content:center;border:2px solid #fff;box-shadow:0 1px 3px rgba(0,0,0,.3);z-index:2}
.chip .shirt{position:relative}

/* ---------- Kaarten / straffen ---------- */
.kaart-knop{background:rgba(255,255,255,.1);color:#fff;font-size:14px}
.kaart-icoon{display:inline-block;width:13px;height:17px;border-radius:2px;vertical-align:-3px;margin-right:4px;box-shadow:0 1px 2px rgba(0,0,0,.3)}
.kaart-icoon.geel{background:#F5C400}
.kaart-icoon.rood{background:#E5484D}
.kaart-icoon.tijd{background:#F5C400;position:relative}
.kaart-icoon.tijd::after{content:'⏱';position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-size:11px;color:#000}
.log .log-item.kaart{border-left:3px solid #F5C400}
.log .log-item.kaart.rood{border-left-color:#E5484D}

/* ---------- Handleiding ---------- */
.hl{font-size:14px;line-height:1.6;color:var(--ink)}
.hl h3{font-family:'Barlow Condensed';font-weight:700;font-size:18px;text-transform:uppercase;letter-spacing:.5px;color:var(--grass);margin:18px 0 8px;display:flex;align-items:center;gap:8px}
.hl h3:first-child{margin-top:0}
.hl p{margin-bottom:10px}
.hl ul{margin:0 0 12px 0;padding-left:4px;list-style:none}
.hl ul li{padding:6px 0 6px 26px;position:relative}
.hl ul li::before{content:'→';position:absolute;left:4px;top:6px;color:var(--grass);font-weight:700}
.hl b{color:var(--pitch-ink)}
.hl .tip{background:#FFF3CD;border-left:3px solid #F5C400;padding:10px 12px;border-radius:8px;margin:10px 0;font-size:13.5px}
.hl .tip b{color:#8B6F00}
.hl kbd{display:inline-block;background:var(--card);border:1px solid var(--hair);border-bottom-width:2px;border-radius:6px;padding:1px 7px;font-size:12.5px;font-weight:600;font-family:inherit;color:var(--ink)}

/* ---------- Club & trainingen ---------- */
.club-badge{display:inline-flex;align-items:center;gap:5px;background:var(--accent);color:#fff;font-family:'Barlow Condensed';font-weight:700;font-size:12px;padding:3px 8px;border-radius:99px;letter-spacing:.5px;text-transform:uppercase;flex-shrink:0}
.club-badge.licht{background:rgba(226,6,19,.18);color:var(--grass)}
.tablabel{position:relative}
.tablabel .puntje{position:absolute;top:-2px;right:-10px;width:8px;height:8px;border-radius:50%;background:var(--uit)}
.uitnodig-link{font-family:'Barlow Condensed';font-weight:600;font-size:13px;background:#0F1E14;color:var(--fluo);padding:9px 12px;border-radius:10px;word-break:break-all;letter-spacing:.3px;line-height:1.5}
.training-rij{display:flex;align-items:center;gap:12px;background:var(--card);border-radius:11px;padding:11px 13px;margin-bottom:8px;box-shadow:var(--shadow)}
.video-rij{display:flex;align-items:center;gap:12px;background:var(--card);border-radius:11px;padding:9px 11px;margin-bottom:8px;box-shadow:var(--shadow)}
.video-rij .thumb{position:relative;width:64px;height:44px;border-radius:7px;overflow:hidden;flex-shrink:0;background:#000}
.video-rij .thumb img{width:100%;height:100%;object-fit:cover;display:block}
.video-rij .thumb .play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:17px;text-shadow:0 1px 4px rgba(0,0,0,.7)}
.video-rij .v{flex:1;min-width:0}
.video-rij .v-titel{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.video-rij .v-meta{font-size:11.5px;color:var(--ink-2);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.video-rij .acties{display:flex;gap:4px;flex-shrink:0}
.video-rij .acties button{width:32px;height:32px;border-radius:8px;color:var(--ink-2);font-size:14px}
.training-rij .ico{width:38px;height:38px;border-radius:10px;background:rgba(229,72,77,.12);color:var(--uit);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;font-weight:700;font-family:'Barlow Condensed'}
.training-rij .t{flex:1;min-width:0}
.training-rij .t-titel{font-weight:600;font-size:14.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.training-rij .t-meta{font-size:12px;color:var(--ink-2);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.training-rij .acties{display:flex;gap:4px;flex-shrink:0}
.training-rij button{width:34px;height:34px;border-radius:8px;color:var(--ink-2);font-size:15px}
.training-rij.ongelezen{border-left:3px solid var(--uit)}
.training-rij.ongelezen .ico{background:var(--uit);color:#fff}
.team-chip-kies{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.team-chip-kies label{display:inline-flex;align-items:center;gap:6px;background:var(--card);padding:7px 11px;border-radius:99px;font-size:13px;font-weight:500;cursor:pointer;box-shadow:var(--shadow);border:1.5px solid transparent}
.team-chip-kies label.aan{border-color:var(--grass);background:rgba(226,6,19,.07);color:var(--grass);font-weight:600}
.team-chip-kies input{display:none}
.upload-knop{display:block;width:100%;padding:18px;border:2px dashed var(--hair);border-radius:12px;background:#FAFBF9;color:var(--ink-2);font-size:14px;font-weight:500;text-align:center;cursor:pointer;margin-bottom:14px}
.upload-knop.bezig{border-color:var(--grass);color:var(--grass);background:rgba(226,6,19,.06)}
.club-knop{background:var(--pitch-ink);color:var(--fluo)}

/* ---------- PDF-import preview ---------- */
.preview-team{background:var(--card);border-radius:12px;padding:12px 14px;margin-bottom:10px;box-shadow:var(--shadow);border-left:3px solid var(--grass)}
.preview-team.uit{opacity:.45;border-left-color:var(--hair)}
.preview-team-kop{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.preview-team-kop input[type="checkbox"]{width:18px;height:18px;accent-color:var(--grass)}
.preview-team-kop .naam{font-weight:600;font-size:15px;flex:1}
.preview-team-kop .meta{font-size:11.5px;font-weight:600;color:var(--ink-2);background:#E3E8E0;padding:2px 8px;border-radius:99px}
.preview-spelers{display:flex;flex-wrap:wrap;gap:5px}
.preview-spelers .speler{display:inline-flex;align-items:center;gap:4px;background:#F0F4ED;padding:4px 8px 4px 10px;border-radius:99px;font-size:13px}
.preview-spelers .speler input{border:none;background:transparent;font:inherit;width:auto;padding:0;color:var(--ink);font-size:13px;min-width:50px}
.preview-spelers .speler input:focus{outline:none;background:#fff}
.preview-spelers .speler button{width:18px;height:18px;border-radius:50%;background:var(--hair);color:var(--ink-2);font-size:11px;line-height:1;display:flex;align-items:center;justify-content:center}
.preview-spelers .dubbel input{color:var(--uit);font-weight:600;background:#FFE5E5}
.preview-spelers .toevoeg{background:rgba(226,6,19,.08);color:var(--grass);font-weight:600;cursor:pointer;border:1px dashed var(--grass)}
.link-rij{background:var(--card);border-radius:11px;padding:11px 13px;margin-bottom:8px;box-shadow:var(--shadow)}
.link-rij-kop{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.link-rij .titel{font-weight:600;font-size:14.5px;flex:1}
.link-rij .meta{font-size:11.5px;color:var(--ink-2)}
.link-rij .link-actie{display:flex;gap:6px}
.link-rij .link-actie button{padding:6px 10px;border-radius:8px;font-size:12.5px;font-weight:600;background:var(--card);box-shadow:var(--shadow)}
.link-rij .link-actie .wa{background:var(--accent);color:#fff}

/* ---------- Leden beheren ---------- */
.lid-rij{display:flex;align-items:center;gap:12px;background:var(--card);border-radius:11px;padding:10px 12px;margin-bottom:8px;box-shadow:var(--shadow)}
.lid-rij .lid-avatar{width:36px;height:36px;border-radius:50%;background:var(--grass);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Barlow Condensed';font-weight:700;font-size:16px;flex-shrink:0}
.lid-rij .lid-naam{font-weight:600;font-size:14.5px;flex:1;min-width:0}
.lid-rij .lid-naam .jij{font-size:11px;font-weight:600;color:var(--grass);margin-left:4px}
.lid-rij .lid-weg{color:var(--uit);font-size:15px;padding:6px;flex-shrink:0}

/* ---------- Bank / wissels ---------- */
.bank{background:var(--pitch-ink);border-radius:var(--radius);padding:12px;margin-top:12px;box-shadow:var(--shadow)}
.bank .bank-kop{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.bank .bank-kop .t{font-family:'Barlow Condensed';font-weight:700;font-size:17px;letter-spacing:1px;color:var(--fluo);text-transform:uppercase}
.bank .bank-kop .n{font-size:12px;color:rgba(255,255,255,.6);font-weight:500}
.bank-chips{display:flex;gap:12px;flex-wrap:wrap;min-height:74px;align-items:flex-start}
.bank .chip .naam{background:rgba(255,255,255,.12)}
.bank .leeg-bank{color:rgba(255,255,255,.45);font-size:13px;padding:18px 6px}
.bank.doelwit{outline:2px solid var(--accent);outline-offset:-2px}

/* ---------- Klok / wisselbord ---------- */
.klok{background:var(--pitch-ink);border-radius:var(--radius);padding:12px 14px;margin-bottom:12px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow)}
.klok .tijd{font-family:'Barlow Condensed';font-weight:700;font-size:38px;letter-spacing:2px;color:var(--fluo);line-height:1;min-width:108px;font-variant-numeric:tabular-nums}
.klok .label{font-size:11px;color:rgba(255,255,255,.55);text-transform:uppercase;letter-spacing:1px;font-weight:600;margin-top:3px}
.klok .acties{margin-left:auto;display:flex;gap:8px}
.klok .acties button{width:42px;height:42px;border-radius:10px;background:rgba(255,255,255,.1);color:#fff;font-size:16px}
.klok .acties button.primair{background:var(--accent);color:#fff}

/* ---------- Wissel-log ---------- */
.log{margin-top:12px}
.log .log-item{display:flex;align-items:center;gap:10px;background:var(--card);border-radius:11px;padding:9px 12px;margin-bottom:7px;box-shadow:var(--shadow);font-size:13.5px}
.log .log-item.bewerkbaar{cursor:pointer}
.log .log-item.bewerkbaar:active{transform:scale(.992)}
.log .nr{font-family:'Barlow Condensed';font-weight:700;font-size:22px;min-width:30px;text-align:center;line-height:1}
.log .nr.in{color:var(--in)}
.log .nr.uit{color:var(--uit)}
.log .min{margin-left:auto;font-family:'Barlow Condensed';font-weight:600;font-size:16px;color:var(--ink-2)}
.log .verwijder{color:var(--ink-2);font-size:15px;padding:4px}
.log .bewerk-hint{color:var(--ink-2);font-size:14px;padding:4px;opacity:.55}

/* ---------- Speler-rijen ---------- */
.speler-rij{display:flex;align-items:center;gap:12px;background:var(--card);border-radius:11px;padding:10px 12px;margin-bottom:8px;box-shadow:var(--shadow)}
.speler-rij .mini-shirt{width:36px;height:36px;border-radius:50%;background:var(--pitch-ink);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Barlow Condensed';font-weight:700;font-size:17px;flex-shrink:0}
.speler-rij .n{font-weight:600;font-size:14.5px;flex:1}
.speler-rij .actie{color:var(--ink-2);padding:6px;font-size:15px}

/* ---------- Statistiek-tabel ---------- */
.stat-tabel{width:100%;border-collapse:collapse;background:var(--card);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);font-size:13px}
.stat-tabel th{font-family:'Barlow Condensed';font-weight:600;font-size:14px;letter-spacing:.6px;text-transform:uppercase;color:var(--ink-2);padding:10px 8px;border-bottom:1.5px solid var(--hair);text-align:center}
.stat-tabel th:first-child,.stat-tabel td:first-child{text-align:left;padding-left:14px}
.stat-tabel td{padding:10px 8px;border-bottom:1px solid var(--hair);text-align:center;font-variant-numeric:tabular-nums}
.stat-tabel tr:last-child td{border-bottom:none}
.stat-tabel .naam-cel{font-weight:600}
.stat-tabel .tijd-cel{font-family:'Barlow Condensed';font-weight:700;font-size:16px}

/* ---------- Correctie-menu (goal / kaart) ---------- */
.correctie-opties{display:flex;flex-direction:column;gap:8px}
.correctie-opties .knop{justify-content:flex-start}

/* ---------- Onderbalk ---------- */
.onderbalk{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:540px;background:var(--card);border-top:1px solid var(--hair);display:flex;padding:6px 4px calc(6px + env(safe-area-inset-bottom));z-index:20}
.onderbalk button{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:7px 0;font-size:9.5px;font-weight:600;color:var(--ink-2);border-radius:10px;min-width:0}
.onderbalk .tablabel{white-space:nowrap}
.onderbalk button.actief{color:var(--grass)}
.onderbalk .ico{font-size:19px;line-height:1}

/* ---------- Modal ---------- */
.modal-achter{position:fixed;inset:0;background:rgba(16,39,26,.45);z-index:50;display:none;align-items:flex-end;justify-content:center}
.modal-achter.open{display:flex}
.modal{background:var(--paper);width:100%;max-width:540px;border-radius:20px 20px 0 0;padding:18px 16px calc(20px + env(safe-area-inset-bottom));max-height:86dvh;overflow-y:auto}
.modal h2{font-family:'Barlow Condensed';font-weight:700;font-size:22px;text-transform:uppercase;letter-spacing:.4px;margin-bottom:14px}
.modal .sluitbalk{width:42px;height:4px;border-radius:2px;background:var(--hair);margin:0 auto 14px}

/* ---------- Login ---------- */
.login{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;text-align:center;background:
  repeating-linear-gradient(0deg,var(--accent) 0 12.5%,var(--grass-2) 12.5% 25%)}
.login .bord{background:var(--pitch-ink);border-radius:20px;padding:30px 26px;max-width:340px;width:100%;box-shadow:0 12px 40px rgba(0,0,0,.35)}
.login h1{font-family:'Barlow Condensed';font-weight:700;font-size:34px;letter-spacing:1px;color:var(--fluo);text-transform:uppercase;line-height:1}
.login p{color:rgba(255,255,255,.65);font-size:13.5px;margin:10px 0 22px;line-height:1.5}
.login .of{display:flex;align-items:center;gap:10px;margin:14px 0;color:rgba(255,255,255,.4);font-size:12px}
.login .of::before,.login .of::after{content:'';flex:1;height:1px;background:rgba(255,255,255,.18)}
.invoer.donker{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.2);color:#fff}
.invoer.donker::placeholder{color:rgba(255,255,255,.35)}
.invoer.donker:focus{border-color:var(--accent)}
.code-invoer{text-transform:uppercase;text-align:center;font-family:'Barlow Condensed';font-size:20px;letter-spacing:2px}

/* ---------- Klein spul ---------- */
.badge{display:inline-block;font-size:11px;font-weight:700;padding:3px 8px;border-radius:99px;background:#E3E8E0;color:var(--ink-2);letter-spacing:.3px}
.teamcode{font-family:'Barlow Condensed';font-weight:700;font-size:30px;letter-spacing:6px;text-align:center;background:var(--pitch-ink);color:var(--fluo);border-radius:12px;padding:12px;margin:8px 0}
.melding{position:fixed;top:14px;left:50%;transform:translateX(-50%);background:var(--pitch-ink);color:#fff;font-size:13.5px;font-weight:500;padding:10px 18px;border-radius:99px;box-shadow:var(--shadow);z-index:99;opacity:0;transition:opacity .25s;pointer-events:none;max-width:90%}
.melding.zichtbaar{opacity:1}
.sectie-kop{font-family:'Barlow Condensed';font-weight:700;font-size:17px;text-transform:uppercase;letter-spacing:.8px;color:var(--ink-2);margin:18px 0 10px}
.uitklap{margin-top:12px}
.uitklap summary{cursor:pointer;font-weight:600;font-size:14px;padding:12px 14px;background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);list-style:none;display:flex;align-items:center}
.uitklap summary::after{content:'▾';margin-left:auto;color:var(--ink-2)}
.uitklap[open] summary::after{content:'▴'}
.uitklap .inhoud{margin-top:8px}
@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}

/* ==================================================================
   ENERGIEKE STIJL — flashy look met subtiele beweging
   (toegevoegd als blok zodat het makkelijk terug te draaien is)
================================================================== */

/* --- Lijst-items: fluo-accent, gloed, condensed titel --- */
.lijst-item{
  border:1.5px solid transparent;
  border-radius:16px;
  box-shadow:0 1px 2px rgba(16,39,26,.06), 0 6px 18px rgba(16,39,26,.07);
  transition:transform .14s ease, box-shadow .2s ease, border-color .2s ease;
  animation:kaartIn .32s cubic-bezier(.2,.7,.3,1) both;
}
.lijst-item:active{ transform:scale(.985); }
.lijst-item:hover{
  border-color:rgba(226,6,19,.55);
  box-shadow:0 2px 6px rgba(16,39,26,.08), 0 8px 26px rgba(226,6,19,.22);
}
.lijst-item .titel{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700;font-size:18px;letter-spacing:.3px;text-transform:uppercase;line-height:1.05;
}
.lijst-item .meta{ font-size:12px; }
.lijst-item .li-tekst{ flex:1; min-width:0; }
.lijst-item .pijl{
  margin-left:auto;flex-shrink:0;
  width:30px;height:30px;border-radius:10px;
  background:var(--accent);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:17px;font-weight:700;line-height:1;
}

/* --- Team-shirt: groot, speels gedraaid rugnummer-blok --- */
.team-shirt{
  width:46px;height:46px;border-radius:14px;flex-shrink:0;
  background:var(--grass);color:#fff;
  display:flex;align-items:baseline;justify-content:center;gap:1px;
  font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:22px;
  transform:rotate(-4deg);
  box-shadow:0 3px 8px rgba(226,6,19,.3);
  transition:transform .16s ease;
}
.team-shirt small{ font-size:11px;font-weight:600;opacity:.85; }
.lijst-item:hover .team-shirt{ transform:rotate(-4deg) scale(1.06); }

/* --- Club-shirt: donker blok met fluo icoon --- */
.club-shirt{
  width:46px;height:46px;border-radius:14px;flex-shrink:0;
  background:var(--pitch-ink);color:var(--fluo);
  display:flex;align-items:center;justify-content:center;font-size:20px;
  transform:rotate(-4deg);
  box-shadow:0 3px 8px rgba(16,39,26,.25);
  transition:transform .16s ease;
}
.lijst-item:hover .club-shirt{ transform:rotate(-4deg) scale(1.06); }

/* --- Diepere, gelaagde schaduw op kaarten --- */
.kaart{
  box-shadow:0 1px 2px rgba(16,39,26,.05), 0 6px 18px rgba(16,39,26,.06);
  border-radius:16px;
}

/* --- Zachte inschuif-animatie bij het laden van een view --- */
.view.actief{ animation:viewIn .28s ease both; }
.view.actief > .kaart,
.view.actief > .lijst-item,
.view.actief .speler-rij,
.view.actief .training-rij,
.view.actief .video-rij{
  animation:kaartIn .3s cubic-bezier(.2,.7,.3,1) both;
}
/* trapsgewijs binnenkomen — geeft "leven" zonder traag te voelen */
.view.actief .lijst-item:nth-child(2){ animation-delay:.03s; }
.view.actief .lijst-item:nth-child(3){ animation-delay:.06s; }
.view.actief .lijst-item:nth-child(4){ animation-delay:.09s; }
.view.actief .lijst-item:nth-child(5){ animation-delay:.12s; }
.view.actief .lijst-item:nth-child(6){ animation-delay:.15s; }

/* --- Speler- en mediarijen: subtiele fluo-rand bij hover --- */
.speler-rij,.training-rij,.video-rij,.lid-rij{
  border:1.5px solid transparent;
  transition:border-color .2s ease, transform .12s ease, box-shadow .2s ease;
}
.speler-rij:hover,.training-rij:hover,.video-rij:hover{
  border-color:rgba(226,6,19,.5);
  box-shadow:0 4px 16px rgba(226,6,19,.18);
}

/* --- Actieve onderbalk-tab: fluo-stip eronder + lift --- */
.onderbalk button{ transition:color .18s ease, transform .12s ease; position:relative; }
.onderbalk button.actief{ transform:translateY(-1px); }
.onderbalk button.actief::after{
  content:'';position:absolute;top:-2px;left:50%;transform:translateX(-50%);
  width:18px;height:3px;border-radius:2px;background:var(--grass);
}

/* --- Knoppen: iets levendiger indrukken --- */
.knop{ transition:transform .1s ease, box-shadow .2s ease, filter .15s ease; }
.knop:active{ transform:scale(.97); }
.knop.fluo:hover{ filter:brightness(1.04); box-shadow:0 4px 16px rgba(226,6,19,.4); }

/* --- Sectiekoppen met fluo-streepje ervoor --- */
.sectie-kop{ display:flex;align-items:center;gap:8px; }
.sectie-kop::before{
  content:'';width:4px;height:15px;border-radius:2px;
  background:var(--accent);flex-shrink:0;
}

/* --- Keyframes --- */
@keyframes kaartIn{
  from{ opacity:0; transform:translateY(8px); }
  to{ opacity:1; transform:translateY(0); }
}
@keyframes viewIn{
  from{ opacity:0; }
  to{ opacity:1; }
}

/* Respecteer "minder beweging" — alle animaties uit voor wie dat wil */
@media (prefers-reduced-motion:reduce){
  .lijst-item,.view.actief,.view.actief>*,
  .view.actief .lijst-item,.team-shirt{ animation:none!important; transition:none!important; }
}

/* ==================== WARM STARTSCHERM (begroeting + overzicht) ==================== */
.welkom-kop{
  display:flex;align-items:flex-start;justify-content:space-between;
  background:var(--accent);
  border-radius:18px;padding:18px 18px 20px;margin-bottom:14px;
  position:relative;overflow:hidden;
}
.welkom-kop::after{
  content:'';position:absolute;top:-40px;right:-30px;
  width:130px;height:130px;border-radius:50%;
  background:rgba(255,255,255,.10);
}
.welkom-tekst{ position:relative;z-index:1; }
.welkom-datum{ color:rgba(255,255,255,.82);font-size:12.5px;font-weight:600;margin-bottom:2px; }
.welkom-groet{
  color:#fff;font-family:'Barlow Condensed',sans-serif;font-weight:700;
  font-size:27px;line-height:1.05;text-transform:uppercase;letter-spacing:.4px;margin:0;
}
.welkom-kop .terug{ color:rgba(255,255,255,.7);position:relative;z-index:1; }
.uitlog-knop{
  position:relative;z-index:1;flex-shrink:0;
  width:42px;height:42px;border-radius:12px;
  background:rgba(255,255,255,.12);
  border:1.5px solid rgba(255,255,255,.25);
  color:#fff;font-size:19px;line-height:1;
  display:flex;align-items:center;justify-content:center;
  transition:background .15s ease, transform .12s ease;
}
.uitlog-knop:hover{ background:rgba(229,72,77,.9);border-color:transparent; }
.uitlog-knop:active{ transform:scale(.94); }

.overzicht-blokjes{ display:flex;gap:10px;margin-bottom:18px; }
.ov-blok{
  flex:1;border-radius:14px;padding:14px 12px;text-align:center;
  background:var(--card);box-shadow:0 1px 2px rgba(16,39,26,.05),0 6px 16px rgba(16,39,26,.06);
  display:flex;flex-direction:column;align-items:center;gap:3px;
  transition:transform .12s ease, box-shadow .2s ease;
}
.ov-blok:active{ transform:scale(.97); }
.ov-getal{
  font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:30px;line-height:1;
  color:var(--grass);
}
.ov-label{ font-size:11.5px;color:var(--ink-2);font-weight:500; }
.ov-blok.ov-actief{ background:rgba(229,72,77,.08);box-shadow:0 6px 16px rgba(229,72,77,.12); }
.ov-blok.ov-actief .ov-getal{ color:var(--uit); }
.ov-blok.ov-wedstrijden .ov-getal{ color:var(--veld); }
.ov-blok.ov-wedstrijden:hover{ box-shadow:0 6px 18px rgba(46,125,70,.22); }

/* ==================== PRESENTIE ==================== */
/* Geschiedenis-rij in het Training-tabblad */
.presentie-rij{
  display:flex;align-items:center;gap:12px;background:var(--card);
  border-radius:12px;padding:11px 13px;margin-bottom:8px;
  box-shadow:0 1px 2px rgba(16,39,26,.05),0 4px 14px rgba(16,39,26,.05);
  border:1.5px solid transparent;transition:border-color .2s ease;
}
.presentie-rij:hover{ border-color:rgba(226,6,19,.5); }
.pr-datum{ flex-shrink:0; }
.pr-dag{ font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:14px;text-transform:uppercase;color:var(--pitch-ink); }
.pr-info{ flex:1;min-width:0;display:flex;flex-direction:column;gap:1px; }
.pr-afw{ font-size:13px;font-weight:700;color:var(--uit); }
.pr-namen{ font-size:11.5px;color:var(--ink-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
.pr-allen{ font-size:13px;font-weight:600;color:var(--veld); }

/* Speler-knoppen in de presentie-modal */
.pres-lijst{ display:flex;flex-direction:column;gap:7px;max-height:50vh;overflow-y:auto; }
.pres-speler{
  display:flex;align-items:center;gap:11px;width:100%;text-align:left;
  padding:9px 11px;border-radius:11px;border:1.5px solid transparent;
  transition:background .15s ease, border-color .15s ease;
}
.pres-speler.aanwezig{ background:rgba(46,125,70,.10);border-color:rgba(46,125,70,.25); }
.pres-speler.afwezig{ background:rgba(229,72,77,.10);border-color:rgba(229,72,77,.3); }
.pres-shirt{
  width:32px;height:32px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:14px;color:#fff;
}
.pres-speler.aanwezig .pres-shirt{ background:var(--veld); }
.pres-speler.afwezig .pres-shirt{ background:var(--uit); }
.pres-naam{ flex:1;font-weight:600;font-size:14px;color:var(--ink); }
.pres-status{ font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.3px; }
.pres-speler.aanwezig .pres-status{ color:var(--veld); }
.pres-speler.afwezig .pres-status{ color:var(--uit); }

/* Opkomst-kolom in statistieken */
.opkomst-cel{ font-weight:700;font-size:12px; }
.opkomst-cel.goed{ color:var(--veld); }
.opkomst-cel.matig{ color:#C8860A; }
.opkomst-cel.laag{ color:var(--uit); }

/* Maand-groepen in de presentie-historie */
.maand-groep{ margin-bottom:8px; }
.maand-kop{
  display:flex;align-items:center;gap:10px;width:100%;text-align:left;
  padding:11px 13px;border-radius:11px;background:var(--card);
  box-shadow:0 1px 2px rgba(16,39,26,.05);
  transition:background .15s ease;
}
.maand-kop:hover{ background:var(--card-2,#f4f6f2); }
.maand-naam{ font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:16px;text-transform:uppercase;letter-spacing:.3px;color:var(--pitch-ink); }
.maand-tel{ font-size:11.5px;color:var(--ink-2);margin-left:auto; }
.maand-pijl{ font-size:13px;color:var(--ink-2);transition:transform .2s ease;flex-shrink:0; }
.maand-pijl.open{ transform:rotate(180deg); }
.maand-inhoud{ padding:8px 0 2px 0; }
.toon-meer{
  width:100%;text-align:center;padding:9px;border-radius:10px;
  font-size:12.5px;font-weight:600;color:var(--grass);
  background:rgba(46,125,70,.07);margin-top:2px;
}
.toon-meer:hover{ background:rgba(46,125,70,.13); }

/* ASV-logo op het inlogscherm */
.login-logo{
  display:block;width:84px;height:84px;margin:0 auto 14px;
  border-radius:20px;background:#fff;padding:8px;
  box-shadow:0 6px 20px rgba(0,0,0,.25);
  object-fit:contain;
}

/* ==================== SEIZOENSPLANNING ==================== */
.plan-kop{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}
.plan-seizoen{font-family:'Barlow Condensed';font-weight:700;font-size:19px;text-transform:uppercase;letter-spacing:.5px;color:var(--ink)}
.plan-chips{display:flex;gap:7px;overflow-x:auto;margin-bottom:14px;padding-bottom:2px;-webkit-overflow-scrolling:touch}
.plan-chip{flex:0 0 auto;padding:6px 13px;border-radius:20px;background:var(--card);border:1.5px solid var(--hair);font-size:12.5px;font-weight:600;color:var(--ink-2);white-space:nowrap}
.plan-chip.aan{background:var(--grass);border-color:var(--grass);color:#fff}

.plan-maand{margin-bottom:10px}
.plan-maand-kop{display:flex;align-items:center;gap:10px;width:100%;padding:7px 4px;background:none;border:none;font-family:'Barlow Condensed';font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:1px;color:var(--ink-2)}
.plan-maand-kop .plan-aantal{background:var(--paper);border-radius:10px;padding:1px 9px;font-family:'Inter';font-size:11px;font-weight:700;letter-spacing:0}
.plan-maand-kop .plan-pijl{margin-left:auto;font-size:12px;color:var(--ink-2)}
.plan-lijst{display:flex;flex-direction:column;gap:6px;margin-top:4px}

.plan-rij{display:flex;align-items:center;gap:11px;width:100%;text-align:left;background:var(--card);border:1px solid var(--hair);border-left:4px solid var(--ink-2);border-radius:11px;padding:9px 12px;box-shadow:var(--shadow)}
.plan-rij.wd{border-left-color:var(--veld)}
.plan-rij.wedstrijd{border-left-color:#E20613;background:var(--surface-2)}
.plan-rij.beker{border-left-color:#7C4DBC}
.plan-rij.inhaal{border-left-color:var(--keeper)}
.plan-rij.vrij{border-left-color:#B7B7B2;background:var(--surface-2)}
.plan-rij.eigen{border-left-color:var(--grass)}
.plan-rij.verleden{opacity:.55}

.plan-datum{flex:0 0 auto;text-align:center;min-width:34px;line-height:1}
.plan-datum .d{display:block;font-family:'Barlow Condensed';font-weight:700;font-size:19px;color:var(--ink)}
.plan-datum .w{display:block;font-size:9.5px;text-transform:uppercase;color:var(--ink-2);letter-spacing:.3px}
.plan-tekst{flex:1;min-width:0}
.plan-titel{font-size:13.5px;font-weight:600;color:var(--ink)}
.plan-rij.wedstrijd .plan-titel{font-weight:800;font-size:14px}
.plan-mark{font-size:11px;font-weight:600;color:var(--ink-2)}
.plan-sub{font-size:11.5px;color:var(--ink-2);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.plan-sub.eigen{color:var(--grass)}

.plan-badge{flex:0 0 auto;font-family:'Barlow Condensed';font-weight:700;font-size:11px;letter-spacing:.5px;padding:3px 8px;border-radius:7px;color:#fff}
.plan-badge.wd{background:var(--veld)}
.plan-badge.wedstrijd{background:#E20613;font-size:13px;padding:3px 7px}
.plan-badge.beker{background:#7C4DBC}
.plan-badge.inhaal{background:var(--keeper)}
.plan-badge.vrij{background:#fff;color:var(--ink-2);border:1px solid var(--hair)}
.plan-bewerk{flex:0 0 auto;color:var(--ink-2);font-size:14px}

/* ==================== TRAINING AFGELAST ==================== */
/* --- banner op het teamscherm (trainingen-tab), zichtbaar voor alle teamleden --- */
.afgelast-banner{
  background:linear-gradient(135deg,var(--grass),var(--grass-2));
  color:#fff;border-radius:16px;padding:16px 16px 14px;margin-bottom:16px;
  box-shadow:0 6px 20px rgba(226,6,19,.32);
  animation:afgelastIn .4s cubic-bezier(.2,.8,.25,1);
}
@keyframes afgelastIn{from{opacity:0;transform:translateY(-8px) scale(.98)}to{opacity:1;transform:none}}
.afgelast-banner .ab-kop{display:flex;align-items:center;gap:9px;margin-bottom:4px}
.afgelast-banner .ab-ico{font-size:22px;line-height:1}
.afgelast-banner h2{
  font-family:'Barlow Condensed';font-weight:700;font-size:21px;
  text-transform:uppercase;letter-spacing:.6px;margin:0;color:#fff;
}
.afgelast-banner .ab-tekst{font-size:13.5px;line-height:1.5;opacity:.96;margin-bottom:13px}
.afgelast-banner .ab-tekst b{font-weight:700}
.afgelast-banner .ab-reden{font-size:12.5px;opacity:.92;margin-top:5px;font-style:italic}
.afgelast-banner .ab-wa-vol{
  width:100%;border:none;border-radius:11px;padding:12px;
  background:#fff;color:#1d8a3f;font-weight:700;font-size:14px;font-family:'Inter';
  display:flex;align-items:center;justify-content:center;gap:8px;
}
.afgelast-banner .ab-wa-vol:active{background:#f0f0f0}

/* --- afgelast-blok op het clubscherm (teams-tab): knop, stats, historie --- */
.club-afgelast-blok{
  background:#fff;border-radius:14px;padding:14px;margin-bottom:14px;
  box-shadow:0 2px 10px rgba(0,0,0,.06);
}
.club-afgelast-blok .caf-aflast{margin-bottom:0}
.club-afgelast-blok .caf-actief{
  background:linear-gradient(135deg,var(--grass),var(--grass-2));
  color:#fff;border-radius:12px;padding:13px 14px;margin-bottom:12px;
}
.caf-actief-kop{display:flex;align-items:center;gap:8px;font-size:15px}
.caf-actief-kop b{font-weight:700}
.caf-actief-reden{font-size:12.5px;opacity:.92;margin-top:4px;font-style:italic}
.caf-op{margin-top:11px;background:rgba(255,255,255,.16);color:#fff;border:1.5px solid rgba(255,255,255,.45)}
.caf-op:active{background:rgba(255,255,255,.26)}
.caf-stats{display:flex;gap:10px;margin-top:12px}
.caf-stat{
  flex:1;background:rgba(226,6,19,.06);border-radius:11px;padding:11px 8px;
  display:flex;flex-direction:column;align-items:center;
}
.caf-getal{font-family:'Barlow Condensed';font-weight:700;font-size:26px;color:var(--grass);line-height:1}
.caf-label{font-size:11px;color:var(--ink-2);margin-top:3px;text-align:center}
.caf-historie{margin-top:12px}
.caf-historie-kop{font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--ink-2);margin-bottom:7px}
.caf-rij{display:flex;gap:10px;padding:7px 0;border-top:1px solid #f0f0ee;font-size:13px}
.caf-rij:first-of-type{border-top:none}
.caf-rij-datum{font-weight:600;min-width:74px;text-transform:capitalize}
.caf-rij-reden{color:var(--ink-2);flex:1}

/* ==================== VOETBAL.NL TOKEN-BEHEER ==================== */
.tok-rij{display:flex;flex-direction:column;gap:7px;padding:13px 0;border-top:1px solid #f0f0ee}
.tok-rij:first-of-type{border-top:none}
.tok-kop{display:flex;align-items:center;gap:8px}
.tok-team{font-weight:700;font-size:15px;flex:1}
.tok-status{font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;letter-spacing:.3px}
.tok-status.gekoppeld{background:rgba(29,138,63,.12);color:#1d8a3f}
.tok-status.leeg{background:rgba(110,110,108,.12);color:var(--ink-2)}
.tok-invoer{display:flex;gap:7px}
.tok-invoer input{flex:1;min-width:0;border:1.5px solid #e3e3e0;border-radius:10px;padding:10px 11px;font-size:13px;font-family:'Inter';background:#fafafa}
.tok-invoer input:focus{outline:none;border-color:var(--grass);background:#fff}
.tok-invoer button{border:none;border-radius:10px;padding:0 15px;font-weight:700;font-size:13px;background:var(--grass);color:#fff;white-space:nowrap}
.tok-invoer button:disabled{opacity:.6}
.tok-laatste{font-size:11px;color:var(--ink-2)}
.tok-laatste b{color:#1d8a3f;font-weight:600}

/* ==================================================================
   DARK THEME — "Pitch × Scoreboard" laatste layout
   Donkere bankapp-stijl met ASV'33-rood als identiteit,
   amber voor afwezig/let-op, groen voor aanwezig/goed.
================================================================== */
:root{
  --bg:#0e1116;
  --surface:#181d24;
  --surface-2:#1f262f;
  --line-d:rgba(255,255,255,.06);

  --paper:#0e1116;          /* body achtergrond donker */
  --card:#181d24;           /* alle kaarten donker */
  --ink:#f5f6f8;            /* hoofdtekst licht */
  --ink-2:#8b95a1;          /* gedempte tekst */
  --hair:rgba(255,255,255,.08);
  --pitch-ink:#1f262f;      /* donkere vlakken iets lichter dan bg voor contrast */

  --accent:#e2342f;         /* ASV'33 rood — identiteit */
  --grass:#e2342f;
  --grass-2:#b3211d;

  --ok:#35c47a;             /* aanwezig / goed */
  --warn:#f5b13d;           /* afwezig / let op */
  --uit:#f5b13d;            /* "uit/afwezig" wordt amber i.p.v. rood */
  --in:#35c47a;
  --veld:#16361f;           /* veld donkerder groen */
  --veld-2:#11291a;
  --keeper:#f5b13d;
  --fluo:#ffffff;

  --shadow:0 1px 2px rgba(0,0,0,.4), 0 6px 18px rgba(0,0,0,.35);

  /* beoordeling: 5-niveau kleurenschaal (iets opgehelderd voor donkere bg) */
  --n1:#F0565B; --n2:#F59C4A; --n3:#F2C94C; --n4:#7DCB6A; --n5:#35C47A;
}

body{ background:var(--bg); color:var(--ink); }

/* ---- Kop ---- */
.kop h1{ color:var(--ink); }
.terug{ background:var(--surface); color:#cbd2da; box-shadow:none; border:1px solid var(--line-d); }

/* ---- Knoppen ---- */
.knop{ background:var(--surface-2); color:#fff; box-shadow:none; }
.knop.licht{ background:var(--surface-2); color:var(--ink); }
.knop.fluo{ background:var(--accent); color:#fff; box-shadow:0 8px 22px rgba(226,52,47,.32); }
.knop.gevaar{ background:var(--surface-2); color:var(--warn); }

/* ---- Kaarten / lijst-items ---- */
.kaart{ background:var(--surface); border:1px solid var(--line-d);
  box-shadow:0 6px 18px rgba(0,0,0,.3); }
.lijst-item{ background:var(--surface); border:1px solid var(--line-d);
  box-shadow:0 6px 18px rgba(0,0,0,.3); }
.lijst-item:hover{ border-color:color-mix(in srgb,var(--accent) 55%, transparent);
  box-shadow:0 8px 26px rgba(226,52,47,.18); }
.lijst-item .titel{ color:var(--ink); }
.lijst-item .pijl{ background:var(--accent); color:#fff; }
.leeg{ color:var(--ink-2); } .leeg b{ color:var(--ink); }

/* ---- Formulieren ---- */
.invoer{ background:var(--surface-2); border-color:var(--line-d); color:var(--ink); }
.invoer:focus{ border-color:var(--accent); }

/* ---- Segment ---- */
.segment{ background:var(--surface-2); }
.segment button{ color:var(--ink-2); }
.segment button.actief{ background:var(--accent); color:#fff; box-shadow:none; }

/* ---- Kwart-tabs ---- */
.kwarten button{ background:var(--surface); color:var(--ink-2); box-shadow:none; border:1px solid var(--line-d); }
.kwarten button.actief{ background:var(--accent); color:#fff; }

/* ---- Welkom-kop / overzicht ---- */
.welkom-kop{ background:linear-gradient(150deg,var(--accent),var(--grass-2)); }
.ov-blok{ background:var(--surface); border:1px solid var(--line-d); box-shadow:none; }
.ov-getal{ color:var(--accent); }
.ov-label{ color:var(--ink-2); }
.ov-blok.ov-actief{ background:color-mix(in srgb,var(--warn) 12%, var(--surface)); }
.ov-blok.ov-actief .ov-getal{ color:var(--warn); }
.ov-blok.ov-wedstrijden .ov-getal{ color:var(--ok); }

/* ---- Shirts in lijsten ---- */
.team-shirt{ background:var(--accent); box-shadow:0 3px 8px rgba(226,52,47,.3); }
.club-shirt{ background:var(--surface-2); color:#fff; }

/* ---- Scorebord / klok / bank (waren al donker, nu consistent) ---- */
.scorebord{ background:var(--surface); border:1px solid var(--line-d); }
.scorebord .sb-cijfers{ color:#fff; }
.klok{ background:var(--surface); border:1px solid var(--line-d); }
.klok .tijd{ color:#fff; }
.klok .acties button.primair{ background:var(--accent); }
.bank{ background:var(--surface); border:1px solid var(--line-d); }

/* ---- Speler/training/video/lid-rijen ---- */
.speler-rij,.training-rij,.video-rij,.lid-rij{ background:var(--surface); border:1px solid var(--line-d); box-shadow:none; }
.speler-rij:hover,.training-rij:hover,.video-rij:hover{
  border-color:color-mix(in srgb,var(--accent) 50%, transparent);
  box-shadow:0 4px 16px rgba(226,52,47,.18); }
.speler-rij .mini-shirt{ background:var(--surface-2); }
.training-rij .ico{ background:color-mix(in srgb,var(--accent) 16%, var(--surface)); color:var(--accent); }
.training-rij.ongelezen{ border-left:3px solid var(--accent); }
.training-rij.ongelezen .ico{ background:var(--accent); color:#fff; }
.training-rij button,.video-rij .acties button{ color:var(--ink-2); }

/* ---- Stats-tabel ---- */
.stat-tabel{ background:var(--surface); border:1px solid var(--line-d); box-shadow:none; }
.stat-tabel th{ color:var(--ink-2); border-bottom-color:var(--line-d); }
.stat-tabel td{ border-bottom-color:var(--line-d); color:var(--ink); }
.opkomst-cel.goed{ color:var(--ok); }
.opkomst-cel.matig{ color:var(--warn); }
.opkomst-cel.laag{ color:var(--warn); }

/* ---- Presentie ---- */
.presentie-rij{ background:var(--surface); border:1px solid var(--line-d); box-shadow:none; }
.pr-dag{ color:var(--ink); }
.pr-afw{ color:var(--warn); }
.pr-allen{ color:var(--ok); }
.pres-speler.aanwezig{ background:color-mix(in srgb,var(--ok) 12%, var(--surface)); border-color:color-mix(in srgb,var(--ok) 28%, transparent); }
.pres-speler.afwezig{ background:color-mix(in srgb,var(--warn) 12%, var(--surface)); border-color:color-mix(in srgb,var(--warn) 32%, transparent); }
.pres-speler.aanwezig .pres-shirt{ background:var(--ok); }
.pres-speler.afwezig .pres-shirt{ background:var(--warn); color:#1a1206; }
.pres-naam{ color:var(--ink); }
.pres-speler.aanwezig .pres-status{ color:var(--ok); }
.pres-speler.afwezig .pres-status{ color:var(--warn); }

/* ---- Diverse kleine vlakken ---- */
.badge{ background:var(--surface-2); color:var(--ink-2); }
.sectie-kop{ color:var(--ink-2); }
.uitklap summary{ background:var(--surface); box-shadow:none; border:1px solid var(--line-d); }
.uitklap summary::after{ color:var(--ink-2); }
.melding{ background:var(--surface-2); border:1px solid var(--line-d); }
.team-chip-kies label{ background:var(--surface); box-shadow:none; }
.team-chip-kies label.aan{ border-color:var(--accent); background:color-mix(in srgb,var(--accent) 10%, transparent); color:#ff7d78; }
.upload-knop{ background:var(--surface); border-color:var(--line-d); color:var(--ink-2); }
.upload-knop.bezig{ border-color:var(--accent); color:var(--accent); background:color-mix(in srgb,var(--accent) 8%, transparent); }
.lid-rij .lid-avatar{ background:var(--accent); }
.link-rij{ background:var(--surface); border:1px solid var(--line-d); box-shadow:none; }
.link-rij .link-actie button{ background:var(--surface-2); box-shadow:none; }
.link-rij .link-actie .wa{ background:var(--accent); }
.teamcode{ background:var(--surface-2); }
.modal{ background:var(--bg); }
.modal .sluitbalk{ background:var(--surface-2); }

/* ---- Handleiding ---- */
.hl{ color:var(--ink); }
.hl b{ color:#fff; }
.hl .tip{ background:color-mix(in srgb,var(--warn) 12%, var(--surface)); border-left-color:var(--warn); }
.hl .tip b{ color:var(--warn); }
.hl kbd{ background:var(--surface-2); border-color:var(--line-d); color:var(--ink); }

/* ---- Chip-namen op het veld op donkere achtergrond ---- */
.chip .naam{ background:rgba(0,0,0,.55); }
/* "Wie scoorde er?"-paneel: lichte tekst op donkere pill (was wit-op-lichtgrijs) */
.goal-kies .chip .naam{ color:var(--ink); background:var(--surface-2); }

/* ==================================================================
   ONDERBALK — strakke SVG-iconen (laatste layout)
================================================================== */
.onderbalk{ background:rgba(14,17,22,.93); -webkit-backdrop-filter:blur(14px); backdrop-filter:blur(14px);
  border-top:1px solid var(--line-d); padding:9px 4px calc(12px + env(safe-area-inset-bottom)); }
.onderbalk button{ color:var(--ink-2); gap:3px; }
.onderbalk button.actief{ color:var(--accent); }
.onderbalk .ico{ display:grid; place-items:center; line-height:1; }
.onderbalk .ico svg{ width:22px; height:22px; display:block; }
.onderbalk button.actief .ico svg{ filter:drop-shadow(0 0 6px color-mix(in srgb,var(--accent) 50%, transparent)); }
.onderbalk button.actief::after{ background:var(--accent); }
.tablabel .puntje{ background:var(--accent); }


/* ==================== BEOORDELINGEN (dark theme) ==================== */
/* AVG-balk — amber accent op donkere ondergrond */
.avg-balk{display:flex;align-items:center;gap:8px;background:color-mix(in srgb,var(--warn) 12%, var(--surface));border:1px solid color-mix(in srgb,var(--warn) 30%, transparent);border-radius:10px;padding:9px 12px;font-size:11.5px;color:var(--warn);margin-bottom:14px;line-height:1.4}
.avg-balk .slot{font-size:15px;flex-shrink:0}
.leen-strook{display:flex;align-items:center;gap:11px;background:color-mix(in srgb,var(--warn) 12%, var(--surface));border:1px solid color-mix(in srgb,var(--warn) 30%, transparent);border-radius:12px;padding:11px 13px;margin-bottom:12px}
.leen-strook .ic{font-size:18px;flex-shrink:0}
.leen-strook .tx{flex:1;font-size:12.5px;line-height:1.4;color:var(--ink)}
.leen-strook .tx b{color:var(--warn)}
.leen-strook button{border:none;background:var(--surface);color:var(--ink);font-size:12px;font-weight:600;padding:7px 11px;border-radius:8px;box-shadow:var(--shadow);flex-shrink:0}

/* spelerrij klikbaar + kleurstip (erft basis uit dark-blok hierboven) */
.speler-rij{width:100%;text-align:left;padding:12px 14px}
.speler-rij .n{flex:1}
.speler-rij .pijl{color:var(--ink-2);font-size:18px;margin-left:auto}
.beoordeel-stip{width:14px;height:14px;border-radius:50%;flex-shrink:0;box-shadow:inset 0 0 0 1.5px rgba(0,0,0,.25)}
.beoordeel-stip.leeg{background:var(--surface-2);box-shadow:inset 0 0 0 1.5px var(--line-d)}
.chip-info{background:var(--surface-2);border-radius:8px;padding:4px 9px;font-size:11px;color:var(--ink-2);font-weight:600;flex-shrink:0}

/* klein segment */
.segment.klein-seg{margin-bottom:10px}
.segment.klein-seg button{padding:7px 4px;font-size:13px}

/* kleurenbalk */
.kleurbalk{display:flex;gap:6px;margin:6px 0 2px}
.kleurbalk button{flex:1;height:46px;border-radius:10px;border:2px solid transparent;position:relative;font-weight:700;color:#fff;font-size:14px;transition:transform .08s}
.kleurbalk button:active{transform:scale(.95)}
.kleurbalk button.gekozen{border-color:#fff;transform:scale(1.04);box-shadow:0 0 0 2px rgba(255,255,255,.25)}
.kleurbalk .lbl{position:absolute;bottom:3px;left:0;right:0;font-size:8px;font-weight:700;letter-spacing:.2px;opacity:.95}
.kleurbalk.dom button{height:38px}
.kn1{background:var(--n1)}.kn2{background:var(--n2)}.kn3{background:var(--n3);color:#1D1E1E}.kn4{background:var(--n4);color:#1D1E1E}.kn5{background:var(--n5)}

/* tags */
.tag-rij{display:flex;flex-wrap:wrap;gap:7px;margin:6px 0 2px}
.tag{padding:7px 12px;border-radius:20px;font-size:12.5px;font-weight:600;background:var(--surface-2);color:var(--ink-2);border:1.5px solid var(--line-d)}
.tag.aan{background:var(--accent);color:#fff;border-color:var(--accent)}

/* veldlabel */
.veldlabel{font-size:11.5px;font-weight:700;color:var(--ink-2);text-transform:uppercase;letter-spacing:.5px;margin:14px 0 4px}

/* snel-kop in modal */
.snel-kop{display:flex;align-items:center;gap:11px;margin-bottom:6px}
.snel-kop .mini-shirt{width:38px;height:38px;border-radius:50%;background:var(--surface-2);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Barlow Condensed';font-weight:700;font-size:18px;flex-shrink:0}
.snel-kop .nm{font-weight:700;font-size:17px}
.snel-kop .pos{font-size:12px;color:var(--ink-2)}

/* profiel */
.profiel-terug{display:inline-flex;align-items:center;gap:4px;background:var(--surface);border:1px solid var(--line-d);border-radius:10px;padding:8px 13px;font-size:13px;font-weight:600;color:var(--ink-2);margin-bottom:12px}
.profiel-top{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--line-d);border-radius:var(--radius);padding:18px;color:var(--ink);margin-bottom:14px;position:relative;overflow:hidden}
.profiel-top::after{content:"";position:absolute;right:-30px;top:-30px;width:120px;height:120px;background:var(--accent);opacity:.16;border-radius:50%}
.profiel-top .pt-shirt{width:48px;height:48px;border-radius:12px;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Barlow Condensed';font-weight:700;font-size:24px;flex-shrink:0;z-index:1}
.profiel-top h2{font-family:'Barlow Condensed';font-weight:700;font-size:28px;text-transform:uppercase;line-height:1;z-index:1;position:relative}
.profiel-top .meta{font-size:12.5px;color:var(--ink-2);z-index:1;position:relative;margin-top:2px}

/* stat grid */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:14px}
.stat-box{background:var(--surface);border:1px solid var(--line-d);border-radius:11px;padding:11px 6px;text-align:center}
.stat-box .v{font-family:'Barlow Condensed';font-weight:700;font-size:20px;line-height:1;color:var(--accent)}
.stat-box .l{font-size:10px;color:var(--ink-2);margin-top:3px;text-transform:uppercase;letter-spacing:.3px}

/* TIPS balken */
.tips-rij{display:flex;align-items:center;gap:10px;margin-bottom:11px}
.tips-letter{width:32px;height:30px;border-radius:8px;background:var(--surface-2);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Barlow Condensed';font-weight:700;font-size:13px;letter-spacing:.5px;flex-shrink:0}
.tips-naam{font-size:12px;font-weight:600;width:84px;flex-shrink:0}
.tips-track{flex:1;height:10px;background:var(--surface-2);border-radius:6px;overflow:hidden;display:flex;gap:2px}
.tips-seg{flex:1;border-radius:2px}
.tips-score{font-family:'Barlow Condensed';font-weight:700;font-size:16px;width:20px;text-align:right}

/* leerpunten */
.leerpunt{display:flex;gap:11px;align-items:flex-start;padding:12px;border-radius:11px;background:var(--surface-2);border:1px solid var(--line-d);margin-bottom:9px}
.lp-check{width:24px;height:24px;border-radius:7px;border:2px solid var(--line-d);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:14px;color:#fff;background:transparent}
.lp-check.klaar{background:var(--n5);border-color:var(--n5)}
.lp-tekst{flex:1}
.lp-tekst .t{font-size:14px;font-weight:600;line-height:1.3}
.lp-tekst .d{font-size:11.5px;color:var(--ink-2);margin-top:3px}
.lp-domein{font-size:10px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.4px;margin-bottom:2px}
.lp-weg{flex-shrink:0;font-size:14px;opacity:.5;background:none;border:none;color:var(--ink-2)}
.leerpunt.klaar .lp-tekst .t{text-decoration:line-through;color:var(--ink-2)}

/* tijdlijn */
.tijdlijn-item{display:flex;gap:11px;margin-bottom:12px;width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:0}
.tl-stip{width:14px;height:14px;border-radius:50%;flex-shrink:0;margin-top:3px}
.tl-lijn{flex:1}
.tl-lijn .dat{font-size:11px;color:var(--ink-2);font-weight:600}
.tl-lijn .wat{font-size:13.5px;font-weight:600;margin-top:1px}
.tl-lijn .det{font-size:12px;color:var(--ink-2);margin-top:2px}

/* fab-rij */
.fab-rij{display:flex;gap:9px;margin-bottom:10px}

/* leercurve-keuze in leerpunt-modal */
.leercurve-keuze{display:flex;flex-wrap:wrap;gap:6px;margin:4px 0 2px}
.lc-thema{display:inline-flex;align-items:center;gap:6px;padding:7px 11px;border-radius:18px;font-size:12px;font-weight:600;background:var(--surface-2);color:var(--ink-2);border:1.5px solid var(--line-d)}
.lc-thema.rel{color:var(--ink)}
.lc-thema.gekozen{background:var(--accent);color:#fff;border-color:var(--accent)}
.lc-thema.gekozen .lc-dot{background:#fff !important}
.lc-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}

/* ==================== VORIGE CONFRONTATIE ==================== */
.confro-regel{display:flex;align-items:center;gap:8px;width:100%;
  background:transparent;border:none;border-bottom:1px solid var(--line-d);
  padding:9px 2px 11px;margin:-2px 0 12px;cursor:pointer;color:var(--ink-2);
  font-size:13px;font-family:inherit;text-align:left}
.confro-regel:active{opacity:.6}
.confro-regel .ico{font-size:13px;opacity:.85}
.confro-tekst{flex:1;color:var(--ink-2)}
.confro-tekst b{color:var(--ink);font-weight:600}
.confro-uitslag{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:15px;
  letter-spacing:.5px;padding:1px 8px;border-radius:7px;background:var(--surface-2);color:var(--ink)}
.confro-uitslag.w{color:var(--ok)}
.confro-uitslag.v{color:#f0565b}
.confro-uitslag.g{color:var(--ink-2)}
.confro-chev{transition:transform .22s;color:var(--ink-2);font-size:12px}
.confro-regel.open .confro-chev{transform:rotate(180deg)}

.confro-paneel{overflow:hidden;max-height:0;transition:max-height .28s ease;margin-bottom:0}
.confro-paneel.open{max-height:600px;margin-bottom:12px}
.confro-card{background:var(--surface);border:1px solid var(--line-d);border-radius:var(--radius);
  padding:13px 14px 14px;box-shadow:var(--shadow)}
.confro-titel{font-size:11.5px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;
  color:var(--ink-2);margin-bottom:9px}
.confro-uitslagblok{display:flex;align-items:center;justify-content:space-between;gap:10px;
  background:var(--surface-2);border-radius:11px;padding:10px 13px;margin-bottom:12px}
.confro-uitslagblok .partij{font-size:13.5px;font-weight:600;flex:1;line-height:1.2}
.confro-uitslagblok .partij.r{text-align:right}
.confro-uitslagblok .score{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:26px;
  letter-spacing:2px;color:var(--fluo);white-space:nowrap}
.confro-uitslagblok .datum{display:block;font-size:11px;color:var(--ink-2);font-weight:500;margin-top:1px}
.confro-rij{margin-bottom:11px}
.confro-rij .lbl{font-size:11px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;
  color:var(--ink-2);margin-bottom:3px}
.confro-rij .val{font-size:13.5px;line-height:1.5;color:var(--ink)}
.confro-rij.doel .val{padding-left:9px;border-left:3px solid var(--grass,var(--accent))}
.confro-link{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;
  margin-top:4px;padding:10px;border-radius:10px;border:1px solid var(--line-d);
  background:var(--surface-2);color:var(--ink);font-size:13px;font-weight:600;
  font-family:inherit;cursor:pointer}
.confro-link:active{opacity:.7}
