/* ============================================================
   WK 2026 PRONOSTIEK — Hoofdstijlblad v3 (geoptimaliseerd)
   ============================================================ */

/* ── Fonts: self-hosted (geen Google Fonts CDN, AVG-veilig) ── */
/* De @font-face declaraties staan in /assets/fonts/fonts.css */
@import url('fonts/fonts.css');

:root {
  --rood:       #C8102E;
  --rood-dark:  #9B0020;
  --rood-light: #E8203E;
  --goud:       #FFD700;
  --goud-dark:  #C9A800;
  --wit:        #FFFFFF;
  --donker:     #0D0D1A;
  --donker-2:   #161628;
  --donker-3:   #1F1F38;
  --donker-4:   #2A2A48;
  --grijs:      #8888AA;
  --grijs-licht:#CCCCDD;
  --groen:      #27AE60;
  --radius:     10px;
  --schaduw:    0 4px 24px rgba(0,0,0,.4);
  --font-titel: 'Bebas Neue', sans-serif;
  --font-body:  'Outfit', sans-serif;
  --touch-min:  44px;
}

/* ── Reset & Base ────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  font-family: var(--font-body);
  background: var(--donker);
  color: var(--wit);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  /* Vereenvoudigd: geen zware radial-gradients op mobiel */
  background-image:
    radial-gradient(ellipse at 20% 0%, rgba(200,16,46,.12) 0%, transparent 40%),
    radial-gradient(ellipse at 80% 100%, rgba(255,215,0,.06) 0%, transparent 40%);
  overflow-x: hidden;
}

a { color: var(--goud); text-decoration: none; }
a:hover { color: var(--wit); }
img { max-width: 100%; height: auto; }

/* ── Header ──────────────────────────────────────────────── */
.site-header {
  background: rgba(13,13,26,.97);
  border-bottom: 2px solid var(--rood);
  position: sticky;
  top: 0;
  z-index: 100;
  /* backdrop-filter uitgeschakeld op mobiel: kost veel GPU */
}
@media (min-width: 600px) {
  .site-header { backdrop-filter: blur(8px); }
}

.header-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: .6rem 1rem;
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}

.logo {
  display: flex;
  align-items: center;
  gap: .4rem;
  color: var(--wit);
  font-family: var(--font-titel);
  font-size: 1.5rem;
  letter-spacing: 1px;
  flex-shrink: 0;
}
.logo:hover { color: var(--goud); }
.logo strong { color: var(--goud); }

.hoofd-nav {
  display: flex;
  gap: .8rem;
  margin-left: auto;
  flex-wrap: wrap;
}
.hoofd-nav a {
  color: var(--grijs-licht);
  font-weight: 600;
  font-size: .88rem;
  padding: .4rem .5rem;
  border-bottom: 2px solid transparent;
  transition: color .2s, border-color .2s;
  white-space: nowrap;
  min-height: var(--touch-min);
  display: flex;
  align-items: center;
}
.hoofd-nav a:hover, .hoofd-nav a.actief { color: var(--goud); border-bottom-color: var(--goud); }
.admin-link { color: var(--rood-light) !important; }

.header-user { display: flex; align-items: center; gap: .6rem; }
.user-naam { font-size: .85rem; color: var(--grijs-licht); display: none; }
.btn-uitlog {
  background: var(--rood);
  color: var(--wit) !important;
  padding: .4rem .85rem;
  border-radius: 6px;
  font-size: .85rem;
  font-weight: 600;
  transition: background .2s;
  min-height: var(--touch-min);
  display: flex;
  align-items: center;
}
.btn-uitlog:hover { background: var(--rood-light); }

/* ── Pagina-inhoud ───────────────────────────────────────── */
.pagina-inhoud {
  flex: 1;
  max-width: 1100px;
  width: 100%;
  margin: 0 auto;
  padding: 1.5rem 1rem;
  /* content-visibility voor snellere rendering */
}

/* ── Footer ──────────────────────────────────────────────── */
.site-footer {
  background: rgba(13,13,26,.9);
  border-top: 1px solid var(--donker-4);
  padding: 1rem;
  /* content-visibility: auto zorgt dat footer lazy geladen wordt */
  content-visibility: auto;
}
.footer-inner {
  max-width: 1100px;
  margin: 0 auto;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: .4rem .8rem;
  font-size: .78rem;
  color: var(--grijs);
  text-align: center;
}

/* ── Kaarten ─────────────────────────────────────────────── */
.kaart {
  background: var(--donker-2);
  border: 1px solid var(--donker-4);
  border-radius: var(--radius);
  padding: 1.2rem 1rem;
  box-shadow: var(--schaduw);
}
.kaart-titel { font-family: var(--font-titel); font-size: 1.4rem; letter-spacing: 1px; color: var(--goud); margin-bottom: 1rem; }

/* ── Formulieren ─────────────────────────────────────────── */
.formulier-groep { margin-bottom: 1rem; }
.formulier-groep label { display: block; font-size: .88rem; font-weight: 600; color: var(--grijs-licht); margin-bottom: .3rem; }
.formulier-groep input {
  width: 100%;
  padding: .75rem .9rem;
  background: var(--donker-3);
  border: 1px solid var(--donker-4);
  border-radius: 6px;
  color: var(--wit);
  font-family: var(--font-body);
  font-size: 16px; /* Voorkomt iOS zoom */
  transition: border-color .2s;
}
.formulier-groep input:focus { outline: none; border-color: var(--goud); }
.formulier-groep input::placeholder { color: var(--grijs); }

/* ── Knoppen ─────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .75rem 1.4rem;
  border-radius: 6px;
  font-family: var(--font-body);
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
  border: none;
  transition: background .2s;
  min-height: var(--touch-min);
  touch-action: manipulation;
  /* will-change verwijderd: te zwaar voor mobiel */
}
.btn:active { opacity: .85; }

.btn-primair {
  background: var(--rood);
  color: var(--wit);
  width: 100%;
  text-align: center;
  letter-spacing: .5px;
}
.btn-primair:hover { background: var(--rood-light); color: var(--wit); }
.btn-goud { background: var(--goud); color: var(--donker); }
.btn-goud:hover { background: var(--goud-dark); color: var(--donker); }
.btn-outline { background: transparent; border: 2px solid var(--rood); color: var(--rood); }
.btn-outline:hover { background: var(--rood); color: var(--wit); }

/* ── Meldingen ───────────────────────────────────────────── */
.melding { padding: .85rem 1rem; border-radius: 6px; margin-bottom: 1rem; font-size: .9rem; font-weight: 600; line-height: 1.4; }
.melding-fout  { background: rgba(200,16,46,.15); border-left: 4px solid var(--rood);  color: #FF8899; }
.melding-ok    { background: rgba(39,174,96,.15);  border-left: 4px solid var(--groen); color: #7DFFAA; }
.melding-info  { background: rgba(255,215,0,.1);   border-left: 4px solid var(--goud);  color: var(--goud); }
.melding-mb    { margin-bottom: 1.2rem; }
.melding-centraal { max-width: 600px; margin: 0 auto 1rem; }

/* Utility */
.form-inline { display: inline; }
.empty-state { text-align: center; padding: 3rem; color: var(--grijs); }
.empty-state-icoon { font-size: 2.5rem; margin-bottom: .8rem; }
.link-goud { color: var(--goud); }
.link-rood { color: var(--rood); }
.btn-afwijzen { background: transparent; border: 1px solid var(--donker-4); color: var(--grijs); }

/* ── Auth ────────────────────────────────────────────────── */
.auth-wrapper { min-height: calc(100vh - 80px); display: flex; align-items: center; justify-content: center; padding: 1.5rem 1rem; }
.auth-box { width: 100%; max-width: 400px; background: var(--donker-2); border: 1px solid var(--donker-4); border-radius: 14px; padding: 2rem 1.5rem; box-shadow: 0 8px 48px rgba(0,0,0,.5); }
.auth-logo { text-align: center; margin-bottom: 1.5rem; }
.auth-logo .trofee { font-size: 2.2rem; }
.auth-logo h1 { font-family: var(--font-titel); font-size: 1.9rem; letter-spacing: 2px; color: var(--goud); margin: .2rem 0 .1rem; }
.auth-logo p { font-size: .83rem; color: var(--grijs); }
.auth-link { text-align: center; margin-top: 1.2rem; font-size: .88rem; color: var(--grijs); }
.auth-link a { color: var(--goud); font-weight: 600; }
.auth-link.klein { margin-top: .8rem; font-size: .8rem; }
.auth-intro { font-size: .9rem; color: var(--grijs-licht); margin-bottom: 1.2rem; line-height: 1.5; }
.auth-intro strong { color: var(--wit); }
.formulier-label-flex { display: flex; justify-content: space-between; align-items: center; }
.formulier-link { font-size: .78rem; font-weight: 400; color: var(--grijs); }
.btn[disabled] { opacity: .5; cursor: not-allowed; }
.mt-half { margin-top: .5rem; }

/* ── Dashboard ───────────────────────────────────────────── */
.dashboard-welkom { margin-bottom: 1.5rem; }
.dashboard-welkom h2 { font-family: var(--font-titel); font-size: 1.8rem; letter-spacing: 1px; color: var(--goud); }
.dashboard-welkom p { color: var(--grijs-licht); margin-top: .25rem; font-size: .9rem; }

.dashboard-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr));
  gap: 1rem;
  margin-bottom: 1.5rem;
}
.stat-kaart { background: var(--donker-3); border: 1px solid var(--donker-4); border-radius: var(--radius); padding: 1.1rem 1.2rem; display: flex; flex-direction: column; gap: .3rem; }
.stat-kaart .stat-label { font-size: .75rem; color: var(--grijs); text-transform: uppercase; letter-spacing: .8px; }
.stat-kaart .stat-waarde { font-family: var(--font-titel); font-size: 2rem; color: var(--goud); letter-spacing: 1px; line-height: 1; }
.stat-kaart .stat-waarde small { font-size: .9rem; color: var(--grijs); }
.stat-kaart .stat-sub { font-size: .82rem; color: var(--grijs-licht); }
.stat-kaart .stat-sub strong { color: var(--rood); }

.dashboard-knoppen { display: flex; gap: .8rem; flex-wrap: wrap; margin-top: .5rem; }
.dashboard-knoppen .btn { flex: 1; min-width: 180px; padding: .75rem 1.5rem; width: auto; }

/* ── Pronostiek ──────────────────────────────────────────── */
.pagina-hoofd { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: .8rem; margin-bottom: 1.2rem; }
.pagina-hoofd h2 { font-family: var(--font-titel); font-size: 1.8rem; letter-spacing: 1px; color: var(--goud); }
.voortgang-balk { background: var(--donker-3); border-radius: 20px; height: 8px; width: 160px; overflow: hidden; }
.voortgang-vul { height: 100%; background: linear-gradient(90deg, var(--rood), var(--goud)); border-radius: 20px; transition: width .4s ease; }

.groep-sectie { margin-bottom: 1.5rem; }
.groep-titel { font-family: var(--font-titel); font-size: 1.15rem; letter-spacing: 2px; color: var(--wit); background: var(--rood); display: inline-block; padding: .25rem .9rem; border-radius: 6px 6px 0 0; }
.wedstrijd-lijst { background: var(--donker-2); border: 1px solid var(--donker-4); border-radius: 0 var(--radius) var(--radius) var(--radius); overflow: hidden; }
.wedstrijd-rij { display: grid; grid-template-columns: 32px 1fr auto; align-items: center; gap: .75rem; padding: .7rem .9rem; border-bottom: 1px solid var(--donker-4); }
.wedstrijd-rij:last-child { border-bottom: none; }
.wedstrijd-rij.gesloten { opacity: .6; }
.match-nr { font-size: .75rem; color: var(--grijs); text-align: center; font-weight: 700; }
.match-teams { font-weight: 700; font-size: .93rem; color: var(--wit); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.match-meta { font-size: .72rem; color: var(--grijs); }
.match-meta span { margin-right: .5rem; }

.keuze-knoppen { display: flex; gap: .35rem; flex-shrink: 0; }
.keuze-knoppen input[type="radio"] { display: none; }
.keuze-knoppen label {
  display: flex;
  align-items: center;
  justify-content: center;
  width: var(--touch-min);
  height: var(--touch-min);
  border-radius: 8px;
  border: 2px solid var(--donker-4);
  background: var(--donker-3);
  color: var(--grijs-licht);
  font-weight: 700;
  font-size: 1rem;
  cursor: pointer;
  user-select: none;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}
.keuze-knoppen input[value="1"]:checked + label { background: #1a5c2a; border-color: var(--groen); color: #7DFFAA; }
.keuze-knoppen input[value="X"]:checked + label { background: #4a3800; border-color: var(--goud); color: var(--goud); }
.keuze-knoppen input[value="2"]:checked + label { background: #5c0f1f; border-color: var(--rood); color: #FF8899; }
.keuze-knoppen.gesloten label { cursor: not-allowed; opacity: .7; }

.opslaan-balk {
  position: sticky;
  bottom: 0;
  background: rgba(13,13,26,.97);
  border-top: 2px solid var(--rood);
  padding: .85rem 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  margin: 1.5rem -1rem -1.5rem;
  z-index: 50;
}
.opslaan-info { font-size: .88rem; color: var(--grijs-licht); }
.opslaan-info strong { color: var(--goud); }

/* ── Tabel ───────────────────────────────────────────────── */
.tabel-wrapper { overflow-x: auto; -webkit-overflow-scrolling: touch; }
table { width: 100%; border-collapse: collapse; font-size: .9rem; }
thead th { background: var(--donker-3); color: var(--grijs-licht); font-size: .75rem; text-transform: uppercase; letter-spacing: .8px; padding: .6rem .85rem; text-align: left; border-bottom: 2px solid var(--rood); white-space: nowrap; }
tbody tr { border-bottom: 1px solid var(--donker-4); }
tbody td { padding: .6rem .85rem; color: var(--grijs-licht); }
tbody td:first-child { color: var(--wit); font-weight: 600; }

/* ── Klassement ──────────────────────────────────────────── */
.podium { display: flex; justify-content: center; align-items: flex-end; gap: .8rem; margin-bottom: 1.8rem; flex-wrap: wrap; }
.podium-item { display: flex; flex-direction: column; align-items: center; gap: .35rem; }
.podium-naam { font-weight: 700; font-size: .85rem; color: var(--wit); text-align: center; max-width: 90px; word-break: break-word; }
.podium-punten { font-family: var(--font-titel); font-size: 1rem; color: var(--grijs-licht); }
.podium-blok { width: 80px; border-radius: 8px 8px 0 0; display: flex; align-items: center; justify-content: center; font-size: 1.6rem; }
.pos-1 .podium-blok { height: 80px; background: linear-gradient(180deg,#FFD700,#C9A800); }
.pos-2 .podium-blok { height: 62px; background: linear-gradient(180deg,#C0C0C0,#999); }
.pos-3 .podium-blok { height: 50px; background: linear-gradient(180deg,#CD7F32,#A0522D); }
.rang-badge { display: inline-flex; align-items: center; justify-content: center; width: 26px; height: 26px; border-radius: 50%; font-weight: 700; font-size: .8rem; background: var(--donker-4); color: var(--grijs-licht); }
.rang-1 { background: var(--goud); color: var(--donker); }
.rang-2 { background: #C0C0C0; color: var(--donker); }
.rang-3 { background: #CD7F32; color: var(--wit); }
.ik-rij { background: rgba(200,16,46,.12) !important; }
.ik-rij td { color: var(--wit) !important; }
.punten-cel { font-family: var(--font-titel); font-size: 1.15rem; color: var(--goud) !important; }

/* ════════════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════════════ */
@media (min-width: 600px) {
  .user-naam { display: inline; }
  .pagina-inhoud { padding: 2rem 1.5rem; }
  .opslaan-balk { padding: 1rem 1.5rem; backdrop-filter: blur(8px); }
}
@media (min-width: 900px) {
  .header-inner { padding: .75rem 1.5rem; }
  .hoofd-nav { gap: 1.5rem; }
  .hoofd-nav a { font-size: .95rem; }
}
@media (max-width: 500px) {
  .hoofd-nav a { font-size: .8rem; padding: .35rem .3rem; }
  .wedstrijd-rij { grid-template-columns: 26px 1fr; grid-template-rows: auto auto; gap: .4rem .6rem; padding: .65rem .75rem; }
  .keuze-knoppen { grid-column: 1/-1; justify-content: space-between; width: 100%; }
  .keuze-knoppen label { flex: 1; height: 42px; font-size: .95rem; }
  .match-locatie { display: none; }
  .dashboard-grid { grid-template-columns: 1fr 1fr; }
  .stat-kaart:first-child { grid-column: 1/-1; }
  .dashboard-knoppen { flex-direction: column; }
  .dashboard-knoppen .btn { min-width: unset; }
  .auth-box { padding: 1.5rem 1rem; }
}
