: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);
}
*{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}
.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%);
  touch-action:none;
}
.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;touch-action:none;user-select:none;-webkit-user-select:none}
.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.beker{border-left-color:#7C4DBC}
.plan-rij.inhaal{border-left-color:var(--keeper)}
.plan-rij.vrij{border-left-color:#B7B7B2;background:#FAFAF8}
.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-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.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}
