/* ══════════════════════════════════════════
   DETAILED ARABIC — STYLE.CSS
══════════════════════════════════════════ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body { overflow-x: hidden; max-width: 100%; }

:root {
  --ink:            #1a1209;
  --parchment:      #f5efe2;
  --parchment-dark: #ede3cc;
  --gold:           #c8952a;
  --gold-light:     #e8bc5a;
  --shadow:         rgba(26,18,9,0.12);

  --raf:  #7a3b2e;
  --nasb: #2e5c7a;
  --jarr: #2e7a4f;
  --jazm: #5a2e7a;

  /* Scales from 16px (phones/1080p) up to 22px (2K+) */
  font-size: clamp(16px, 1.2vw, 22px);
}

body {
  background: var(--parchment);
  color: var(--ink);
  font-family: 'Spectral', Georgia, serif;
  min-height: 100vh;
}

/* ── Lucide iconen ── */
[data-lucide] {
  display: inline-block;
  vertical-align: -3px;
  stroke-width: 1.6;
  flex-shrink: 0;
}

/* Nav-iconen */
.nav-btn [data-lucide]     { width: 13px; height: 13px; }

/* Mode-iconen (oefenen keuze) */
.mode-icon, .extra-mode-btn [data-lucide] { width: 16px; height: 16px; stroke-width: 1.5; display: block; margin-bottom: 0.3rem; }

/* Home CTA / sec-nav */
.home-cta-tashkeel [data-lucide] { width: 18px; height: 18px; }
.home-sec-btn [data-lucide]      { width: 14px; height: 14px; }
.tashkeel-featured [data-lucide] { width: 18px; height: 18px; }

/* Actie-knoppen */
.actie-btn [data-lucide], .oefen-stop-btn [data-lucide] { width: 12px; height: 12px; }

/* Auth uitlog */
.auth-uitlog-knop [data-lucide] { width: 13px; height: 13px; vertical-align: -2px; }

/* ══ HEADER ══ */
.header {
  background: var(--ink);
  padding: 0 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 3.5rem;
  position: sticky;
  top: 0;
  z-index: 200;
  gap: 1rem;
}

.logo         { display: flex; align-items: baseline; gap: 0.6rem; flex-shrink: 0; }
.logo-ar      { font-family: 'Amiri', serif; font-size: 1.5rem; color: var(--gold); }
.logo-sub     { font-size: 0.65rem; color: #8a7060; letter-spacing: 0.15em; text-transform: uppercase; }

.nav          { display: flex; gap: 0.2rem; overflow-x: auto; }
.nav-btn {
  background: none; border: none;
  color: #8a7060; font-family: 'Spectral', serif;
  font-size: 0.82rem; padding: 0.45rem 0.9rem;
  border-radius: 6px; cursor: pointer;
  transition: all 0.15s; white-space: nowrap; flex-shrink: 0;
}
.nav-btn:hover  { color: var(--gold-light); background: rgba(200,149,42,0.1); }
.nav-btn.actief { color: var(--gold-light); background: rgba(200,149,42,0.15); }

.header-rechts { display: flex; align-items: center; gap: 0.75rem; flex-shrink: 0; }
.db-status     { display: flex; align-items: center; gap: 0.5rem; }
.db-dot        { width: 7px; height: 7px; border-radius: 50%; background: #555; }
.db-dot.ok     { background: #2e7a4f; }
.db-dot.laden  { background: var(--gold); animation: pulse 1s infinite; }
#db-tekst      { font-size: 0.62rem; color: #8a7060; }


@keyframes pulse  { 0%,100%{opacity:1} 50%{opacity:0.3} }
@keyframes fadeUp { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }
@keyframes popIn  { from{opacity:0;transform:scale(0.96)} to{opacity:1;transform:scale(1)} }

/* ── Mobiele waterval: kleinere woorden ── */
@media (max-width: 640px) {
  .zwevend-woord { font-size: 0.75rem !important; }
}

/* ── Mobiele header ── */
@media (max-width: 640px) {
  .header {
    flex-wrap: wrap;
    height: auto;
    padding: 0.5rem 1rem 0;
    gap: 0;
  }
  .logo         { order: 1; padding: 0.4rem 0; }
  .header-rechts{ order: 2; margin-left: auto; padding: 0.4rem 0; }
  .nav {
    order: 3;
    width: 100%;
    overflow: hidden;
    padding: 0.3rem 0 0.4rem;
    gap: 0;
    justify-content: space-around;
    border-top: 1px solid rgba(255,255,255,0.06);
  }
  .nav-btn {
    font-size: 0.68rem;
    padding: 0.3rem 0.4rem;
    white-space: nowrap;
    flex-shrink: 1;
  }
  .nav-btn [data-lucide] { display: none; }
  #pagina-home.actief, #pagina-oefenen.actief, #pagina-contact.actief { height: calc(100dvh - 5.6rem); }
}

/* ── Auth header ── */
.header-auth          { display: flex; align-items: center; }
.auth-aanmeld-knop {
  background: rgba(200,149,42,0.15); border: 1px solid rgba(200,149,42,0.35);
  color: var(--gold-light); border-radius: 6px;
  padding: 0.28rem 0.85rem; font-family: 'Spectral', serif;
  font-size: 0.74rem; cursor: pointer; transition: all 0.15s;
}
.auth-aanmeld-knop:hover { background: rgba(200,149,42,0.28); }

.auth-gebruiker-info { display: flex; align-items: center; gap: 0.5rem; }
.auth-naam           { font-size: 0.74rem; color: var(--gold-light); }
.auth-admin-badge {
  font-size: 0.6rem; font-weight: 600; letter-spacing: 0.03em;
  color: #4caf7d; border: 1px solid rgba(76,175,125,0.4);
  border-radius: 20px; padding: 0.15rem 0.5rem;
  white-space: nowrap; cursor: default;
}

/* ── Settings modal ─────────────────────────────────────────── */
.inst-modal { gap: 0; padding: 1.6rem; }
.inst-account-blok {
  text-align: center; padding-bottom: 1.2rem;
  border-bottom: 1px solid rgba(200,149,42,0.15); margin-bottom: 1rem;
}
.inst-avatar {
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--goud, #c8952a); color: #1a1209;
  font-size: 1.2rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 0.5rem;
}
.inst-naam-display  { font-size: 0.95rem; font-weight: 600; color: var(--goud, #c8952a); }
.inst-email-display { font-size: 0.72rem; color: #8a7a60; margin-top: 0.1rem; }
.inst-sectie { padding: 0.8rem 0; border-bottom: 1px solid rgba(200,149,42,0.1); }
.inst-sectie-label {
  font-size: 0.62rem; font-weight: 700; letter-spacing: 0.08em;
  text-transform: uppercase; color: #8a7a60; margin-bottom: 0.55rem;
}
.taal-keuze-rij { display: flex; gap: 0.5rem; }
.taal-keuze-btn {
  flex: 1; padding: 0.45rem 0.6rem; font-size: 0.8rem;
  border: 1px solid rgba(200,149,42,0.25); border-radius: 8px;
  background: none; color: #8a7a60; cursor: pointer; transition: all 0.15s;
}
.taal-keuze-btn.actief {
  border-color: var(--goud, #c8952a); color: var(--goud, #c8952a);
  background: rgba(200,149,42,0.08);
}
.taal-keuze-btn:hover:not(.actief) { border-color: #8a7a60; color: var(--ink, #1a1209); }
.inst-thema-btn, .inst-prog-btn {
  width: 100%; padding: 0.5rem; font-size: 0.82rem;
  border: 1px solid rgba(200,149,42,0.25); border-radius: 8px;
  background: none; color: #8a7a60; cursor: pointer;
  transition: all 0.15s; display: flex; align-items: center; gap: 0.4rem; justify-content: center;
}
.inst-thema-btn:hover, .inst-prog-btn:hover {
  border-color: var(--goud, #c8952a); color: var(--goud, #c8952a);
}
.inst-prog-btn [data-lucide], .inst-uitlog-btn [data-lucide] { width: 14px; height: 14px; }
.inst-uitlog-btn {
  width: 100%; margin-top: 1rem; padding: 0.55rem;
  font-size: 0.82rem; border: 1px solid rgba(180,60,60,0.3);
  border-radius: 8px; background: none; color: #b44040;
  cursor: pointer; transition: all 0.15s;
  display: flex; align-items: center; gap: 0.4rem; justify-content: center;
}
.inst-uitlog-btn:hover { background: rgba(180,60,60,0.08); border-color: #b44040; }
[data-thema="donker"] .taal-keuze-btn { color: #8a7a60; }
[data-thema="donker"] .taal-keuze-btn.actief { color: #e8bc5a; border-color: #e8bc5a; }
.auth-uitlog-knop {
  background: none; border: 1px solid #444; color: #8a7060;
  border-radius: 6px; padding: 0.22rem 0.45rem;
  font-size: 0.8rem; cursor: pointer; transition: all 0.15s;
}
.auth-uitlog-knop:hover { color: var(--gold); border-color: var(--gold); }

/* ── Auth modal ── */
.auth-modal-overlay {
  position: fixed; inset: 0; z-index: 500;
  background: rgba(26,18,9,0.6);
  display: flex; align-items: center; justify-content: center;
  padding: 1rem;
}
.auth-modal {
  background: var(--parchment); border-radius: 16px;
  padding: 2rem 2rem 1.8rem; width: 100%; max-width: 400px;
  position: relative; box-shadow: 0 12px 48px rgba(26,18,9,0.3);
  animation: popIn 0.22s ease;
}
.auth-sluit {
  position: absolute; top: 0.75rem; right: 0.75rem;
  background: none; border: none; font-size: 1.4rem;
  cursor: pointer; color: #8a7a60; transition: color 0.15s;
  width: 36px; height: 36px; display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
}
.auth-sluit:hover { background: rgba(0,0,0,0.06); }
.auth-sluit:hover { color: var(--ink); }
.auth-logo-ar {
  font-family: 'Amiri', serif; font-size: 2rem; color: var(--gold);
  text-align: center; margin-bottom: 1.2rem;
}
.auth-tabs {
  display: flex; margin-bottom: 1.5rem;
  border-bottom: 2px solid var(--parchment-dark);
}
.auth-tab {
  background: none; border: none; padding: 0.5rem 1.2rem;
  font-family: 'Spectral', serif; font-size: 0.85rem;
  cursor: pointer; color: #8a7a60; transition: all 0.15s;
  border-bottom: 2px solid transparent; margin-bottom: -2px;
}
.auth-tab.actief { color: var(--ink); border-bottom-color: var(--gold); font-weight: 600; }
.auth-veld       { margin-bottom: 1rem; }
.auth-veld label { display: block; font-size: 0.72rem; font-weight: 600; color: var(--ink); margin-bottom: 0.3rem; }
.auth-veld input {
  width: 100%; background: white; border: 1.5px solid var(--parchment-dark);
  border-radius: 8px; padding: 0.6rem 0.9rem;
  font-family: 'Spectral', serif; font-size: 0.9rem; color: var(--ink); outline: none;
}
.auth-veld input:focus { border-color: var(--gold); }
.auth-submit-btn {
  width: 100%; padding: 0.75rem;
  background: var(--ink); color: var(--gold-light);
  border: none; border-radius: 8px;
  font-family: 'Spectral', serif; font-size: 0.92rem;
  font-weight: 600; cursor: pointer; transition: all 0.15s; margin-top: 0.25rem;
}
.auth-submit-btn:hover    { background: #2e1a00; }
.auth-submit-btn:disabled { background: #888; cursor: not-allowed; }
.auth-fout      { color: var(--raf);  font-size: 0.78rem; margin-top: 0.75rem; text-align: center; }
.auth-succes    { color: var(--jarr); font-size: 0.78rem; margin-top: 0.75rem; text-align: center; }
.auth-alpha-melding { font-size: 0.72rem; color: #a08060; text-align: center; margin: 0.5rem 0 0.25rem; }
.auth-spam-note { display: block; margin-top: 0.25rem; font-size: 0.72rem; opacity: 0.75; font-style: italic; }
.auth-vergeet-wrap { text-align: center; margin-top: 0.6rem; }
.auth-vergeet-link {
  background: none; border: none; font-family: 'Spectral', serif;
  font-size: 0.75rem; color: #a09070; cursor: pointer;
  text-decoration: underline; padding: 0;
}
.auth-vergeet-link:hover { color: var(--ink); }

/* ── Home welkomstbegroeting ── */
.home-welkom      { text-align: center; margin-bottom: 1.2rem; }
.home-welkom-ar   { font-family: 'Amiri', serif; font-size: 1.1rem; color: var(--gold); direction: rtl; }
.home-welkom-naam { font-size: 1.5rem; font-weight: 600; color: var(--ink); margin-top: 0.1rem; }

/* ── Home stat-kaartjes ── */
.home-stats-sectie {
  display: flex; gap: 0.75rem; margin-bottom: 1.5rem; flex-wrap: wrap;
}
.home-stat-kaart {
  flex: 1; min-width: 90px;
  background: white; border: 1.5px solid var(--parchment-dark);
  border-radius: 12px; padding: 0.9rem 1rem;
  text-align: center; cursor: pointer;
  transition: all 0.15s; box-shadow: 0 1px 6px var(--shadow);
}
.home-stat-kaart:hover { border-color: var(--gold); transform: translateY(-2px); }
.home-stat-num       { font-size: 1.6rem; font-weight: 700; color: var(--gold); line-height: 1; }
.home-stat-tekst     { font-size: 1rem; line-height: 1.3; }
.home-stat-label     { font-size: 0.62rem; color: #8a7a60; text-transform: uppercase; letter-spacing: 0.1em; margin-top: 0.2rem; }

/* ══ PAGINA's ══ */
.pagina        { display: none; }
.pagina.actief { display: block; position: relative; z-index: 1; animation: fadeUp 0.22s ease; }

/* Home + Practice + Contact: locked to viewport, no page scroll */
#pagina-home.actief,
#pagina-oefenen.actief,
#pagina-contact.actief {
  display: flex;
  flex-direction: column;
  height: calc(100dvh - 3.5rem);
  overflow: hidden;
}

/* ══════════════════════════════════════════
   HOME
══════════════════════════════════════════ */
.home-hero { display: none; }
.home-hero-ar { display: none; }
.home-hero-nl { display: none; }

.home-inhoud  { max-width: min(1100px, 90vw); width: 100%; margin: 0 auto; padding: 1rem 1.5rem 1rem; position: relative; z-index: 1; flex: 1; overflow-y: auto; overflow-x: hidden; scrollbar-width: none; -webkit-overflow-scrolling: touch; display: flex; flex-direction: column; justify-content: flex-start; }
.home-inhoud::-webkit-scrollbar { display: none; }

/* ── Vallende woorden — fixed, op alle pagina's zichtbaar ── */
.zijkant-woorden {
  position: fixed;
  top: 3.5rem; bottom: 0;
  width: calc((100vw - 700px) / 2);
  max-width: max(0px, calc((100vw - 700px) / 2));
  pointer-events: none;
  overflow: hidden;
  z-index: 0;
}
#zijkant-links  { left: 0; }
#zijkant-rechts { right: 0; }

/* Mobiel: beide kolommen bedekken de achtergrond */
@media (max-width: 900px) {
  #zijkant-links  { display: block; left: 0;  width: 50vw; max-width: 50vw; opacity: 0.4; }
  #zijkant-rechts { display: block; right: 0; width: 50vw; max-width: 50vw; opacity: 0.4; }
}

/* Content altijd boven de woorden */
.home-inhoud { position: relative; z-index: 1; }

.zwevend-woord {
  position: absolute;
  font-family: 'Amiri', serif;
  direction: rtl;
  white-space: nowrap;
  animation: valWoord linear infinite;
  user-select: none;
}

@keyframes valWoord {
  0%   { transform: translateY(-60px); opacity: 0; }
  6%   { opacity: 1; }
  88%  { opacity: 1; }
  100% { transform: translateY(100vh); opacity: 0; }
}

/* Doel van de site */
.home-doel {
  background: white; border: 1.5px solid var(--parchment-dark);
  border-radius: 14px; padding: 1.2rem 1.5rem;
  margin-bottom: 1rem; box-shadow: 0 1px 8px var(--shadow);
}
.home-doel-tekst {
  font-size: 1rem; color: #3a2a10; line-height: 1.7;
  margin-bottom: 0.5rem;
}
.home-doel-tekst strong { color: var(--ink); }
.home-doel-tekst em     { color: var(--gold); font-style: normal; font-weight: 600; }
.home-doel-ar {
  font-family: 'Amiri', serif; font-size: 1.15rem; direction: rtl;
  color: #8a7a60; text-align: right; border-top: 1px solid var(--parchment-dark);
  padding-top: 0.6rem; margin-top: 0.2rem;
}

/* Hoofd-CTA: Tashkeel */
.home-cta-wrap    { margin-bottom: 0.75rem; }
.home-cta-tashkeel {
  background: var(--ink); color: var(--gold-light);
  border-radius: 16px; padding: 1.5rem 1.75rem 1.4rem;
  cursor: pointer; text-align: center;
  transition: all 0.2s; box-shadow: 0 4px 20px rgba(26,18,9,0.2);
}
.home-cta-tashkeel:hover { background: #2a1400; transform: translateY(-3px); box-shadow: 0 8px 28px rgba(26,18,9,0.28); }
.home-cta-ar    { font-family: 'Amiri', serif; font-size: 1.75rem; margin-bottom: 0.3rem; }
.home-cta-titel { font-size: 1.05rem; font-weight: 600; margin-bottom: 0.4rem; }
.home-cta-beschr{ font-size: 0.88rem; color: #c8b080; line-height: 1.6; margin-bottom: 0.85rem; }
.home-cta-knop  { display: inline-block; background: var(--gold); color: var(--ink); font-weight: 700; font-size: 0.85rem; padding: 0.5rem 1.6rem; border-radius: 8px; }

/* Secundaire navigatie */
.home-sec-nav {
  display: flex; gap: 0.6rem;
  justify-content: center; flex-wrap: wrap;
  margin-top: 0.75rem;
}
.home-sec-btn {
  background: white; border: 1.5px solid var(--parchment-dark);
  border-radius: 10px; padding: 0.6rem 1.2rem;
  font-family: 'Spectral', serif; font-size: 0.82rem;
  cursor: pointer; transition: all 0.15s; color: var(--ink);
}
.home-sec-btn:hover { border-color: var(--gold); background: #fffbf3; transform: translateY(-1px); }

.actie-btn {
  background: white; border: 1.5px solid var(--parchment-dark);
  border-radius: 8px; padding: 0.45rem 1rem;
  font-family: 'Spectral', serif; font-size: 0.78rem;
  cursor: pointer; transition: all 0.15s; color: var(--ink);
}
.actie-btn:hover { border-color: var(--gold); background: #fffbf3; }

/* Geval-badges — ook gebruikt in Situaties-pagina */
.geval-badge { display: inline-block; padding: 0.07rem 0.4rem; border-radius: 20px; font-size: 0.56rem; font-weight: 700; text-transform: uppercase; }
.badge-raf  { background: rgba(122,59,46,0.1);   color: var(--raf); }
.badge-nasb { background: rgba(46,92,122,0.1);   color: var(--nasb); }
.badge-jarr { background: rgba(46,122,79,0.1);   color: var(--jarr); }
.badge-jazm { background: rgba(90,46,122,0.1);   color: var(--jazm); }
.badge-nvt  { background: rgba(100,100,100,0.1); color: #888; }

/* ══════════════════════════════════════════
   BIEB — DETAIL PANEL (zin-analyse)
══════════════════════════════════════════ */
.bieb-detail {
  background: white; border: 1.5px solid var(--parchment-dark);
  border-radius: 14px; padding: 1.5rem;
  margin-bottom: 1.5rem;
  box-shadow: 0 4px 24px var(--shadow);
  animation: fadeUp 0.25s ease;
}
.bieb-detail-header {
  display: flex; align-items: flex-start;
  justify-content: space-between; gap: 1rem; margin-bottom: 1rem;
}
.bieb-detail-info    { flex: 1; }
.bieb-detail-info .zin-ar    { font-family: 'Amiri', serif; font-size: 1.8rem; direction: rtl; line-height: 1.8; }
.bieb-detail-info .zin-trans { font-size: 0.82rem; color: #8a7a60; font-style: italic; }
.bieb-detail-info .zin-nl    { font-size: 0.88rem; color: #5a4a30; font-weight: 600; }
.bieb-detail-info .zin-bron  { font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.12em; color: #b0a080; margin-bottom: 0.4rem; display: flex; align-items: center; gap: 0.4rem; }
.bieb-detail-hint    { font-size: 0.72rem; color: #a08060; font-style: italic; margin-bottom: 0.8rem; }

/* Actieve bieb-kaart markering */
.bieb-kaart.geselecteerd { border-color: var(--gold); background: #fffbf3; box-shadow: 0 0 0 2px rgba(200,149,42,0.25); }

/* Woord-rij */
.woorden-rij {
  display: flex; gap: 0.6rem; justify-content: center;
  flex-wrap: wrap; margin-bottom: 1.5rem; direction: rtl;
  align-items: flex-start;
}

/* Woord-kaarten */
.woord-kaart {
  background: white; border: 2px solid var(--parchment-dark);
  border-radius: 10px; cursor: pointer;
  transition: all 0.2s ease; text-align: center;
  min-width: 82px; box-shadow: 0 1px 6px var(--shadow);
  position: relative; overflow: hidden;
}
.woord-kaart:hover         { border-color: var(--gold); transform: translateY(-3px); box-shadow: 0 6px 20px rgba(200,149,42,0.2); }
.woord-kaart.actief        { border-color: var(--gold); background: #fffbf3; box-shadow: 0 6px 24px rgba(200,149,42,0.3); }
.woord-kaart.actief::after { content:''; position:absolute; bottom:-10px; left:50%; transform:translateX(-50%); border:6px solid transparent; border-top-color:var(--gold); }
.woord-kaart.is-trigger    { border-color: var(--gold); border-style: dashed; }

.kaart-hoofd { padding: 0.7rem 0.8rem 0.45rem; }
.woord-num   { font-size: 0.52rem; color: #b0a080; margin-bottom: 0.1rem; }
.woord-ar    { font-family: 'Amiri', serif; font-size: 1.4rem; line-height: 1.8; direction: rtl; }

.badge-wrap     { display: flex; flex-direction: column; align-items: center; gap: 0.15rem; padding-bottom: 0.45rem; }
.toestand-badge { display: inline-block; padding: 0.05rem 0.35rem; border-radius: 20px; font-size: 0.52rem; font-style: italic; }

.kaart-lagen     { border-top: 1px dashed var(--parchment-dark); display: flex; direction: rtl; }
.laag            { flex: 1; padding: 0.4rem 0.35rem 0.5rem; cursor: pointer; transition: background 0.15s; border-left: 1px dashed var(--parchment-dark); text-align: center; }
.laag:last-child { border-left: none; }
.laag:hover      { background: rgba(200,149,42,0.07); }
.laag.laag-actief{ background: rgba(200,149,42,0.13); }
.laag-ar         { font-family: 'Amiri', serif; font-size: 1rem; direction: rtl; line-height: 1.6; color: var(--gold); }
.laag-naam       { font-size: 0.48rem; color: #8a7a60; margin-bottom: 0.1rem; }

/* Uitleg-paneel */
.uitleg-paneel  { background: white; border: 1px solid var(--parchment-dark); border-radius: 12px; overflow: hidden; box-shadow: 0 2px 16px var(--shadow); }
.paneel-header  { background: var(--ink); color: var(--gold-light); padding: 0.9rem 1.5rem; display: flex; align-items: center; justify-content: space-between; }
.paneel-ar      { font-family: 'Amiri', serif; font-size: 1.8rem; direction: rtl; }
.paneel-meta    { font-size: 0.78rem; color: #c8b080; font-style: italic; margin-top: 0.1rem; }
.paneel-ws      { font-size: 0.66rem; color: #8a7060; text-align: right; max-width: 200px; }
.paneel-body    { padding: 1.2rem 1.5rem; display: grid; grid-template-columns: 1fr 1fr; gap: 0.8rem; }
.info-cel       { background: var(--parchment); border-radius: 8px; padding: 0.75rem 0.9rem; }
.info-label     { font-size: 0.58rem; text-transform: uppercase; letter-spacing: 0.14em; color: #8a7a60; margin-bottom: 0.2rem; }
.info-waarde    { font-size: 0.86rem; font-weight: 600; color: var(--ink); line-height: 1.4; }
.ar             { font-family: 'Amiri', serif; font-size: 1.05em; direction: rtl; display: inline; }

.geval-cel      { border-radius: 8px; padding: 0.75rem 0.9rem; }
.geval-cel.raf  { background: rgba(122,59,46,0.07); border: 1px solid rgba(122,59,46,0.2); }
.geval-cel.nasb { background: rgba(46,92,122,0.07); border: 1px solid rgba(46,92,122,0.2); }
.geval-cel.jarr { background: rgba(46,122,79,0.07); border: 1px solid rgba(46,122,79,0.2); }
.geval-cel.jazm { background: rgba(90,46,122,0.07); border: 1px solid rgba(90,46,122,0.2); }
.geval-cel.nvt  { background: rgba(100,100,100,0.05); border: 1px solid rgba(100,100,100,0.15); }
.geval-rij      { display: flex; align-items: center; gap: 0.4rem; flex-wrap: wrap; margin-top: 0.12rem; }
.geval-hoofd    { font-size: 0.92rem; font-weight: 700; }
.geval-hoofd.raf  { color: var(--raf); } .geval-hoofd.nasb { color: var(--nasb); }
.geval-hoofd.jarr { color: var(--jarr); } .geval-hoofd.jazm { color: var(--jazm); }
.geval-hoofd.nvt  { color: #888; }
.geval-pijl     { color: #bbb; font-size: 0.8rem; }
.toestand-tekst { font-size: 0.83rem; font-style: italic; color: #5a4a30; }
.klinker-sub    { font-size: 0.73rem; color: #7a6a50; margin-top: 0.25rem; }

.trigger-cel      { background: #fffbf3; border: 1.5px solid rgba(200,149,42,0.35); border-radius: 8px; padding: 0.75rem 0.9rem; display: flex; align-items: flex-start; gap: 0.75rem; }
.trigger-ar-groot { font-family: 'Amiri', serif; font-size: 1.5rem; color: var(--gold); direction: rtl; line-height: 1; flex-shrink: 0; }
.trigger-inhoud   { flex: 1; }
.trigger-naam     { font-weight: 700; font-size: 0.83rem; margin-bottom: 0.1rem; }
.trigger-uitleg   { font-size: 0.74rem; color: #5a4a30; line-height: 1.5; }

.reden-blok  { grid-column: 1/-1; background: #fffbf3; border: 1px solid rgba(200,149,42,0.25); border-radius: 8px; padding: 0.85rem 1rem; }
.reden-label { font-size: 0.58rem; text-transform: uppercase; letter-spacing: 0.14em; color: var(--gold); margin-bottom: 0.3rem; }
.reden-tekst { font-size: 0.84rem; color: #3a2a10; line-height: 1.65; }
.regel-id    { display: inline-block; margin-top: 0.4rem; font-size: 0.58rem; background: rgba(200,149,42,0.12); color: var(--gold); padding: 0.1rem 0.45rem; border-radius: 4px; font-family: monospace; }

.leeg-paneel { padding: 2rem; text-align: center; color: #a08060; font-style: italic; }
.leeg-ar     { font-family: 'Amiri', serif; display: block; margin-top: 0.3rem; }

.legende      { display: flex; gap: 1rem; margin-top: 1.2rem; justify-content: center; flex-wrap: wrap; }
.legende-item { display: flex; align-items: center; gap: 0.35rem; font-size: 0.7rem; color: #5a4a30; }
.legende-dot  { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }

/* ── Resultaat-acties ── */
.res-acties { display: flex; gap: 0.75rem; justify-content: center; margin-top: 1.5rem; flex-wrap: wrap; }
.res-bieb-btn {
  background: var(--parchment); border: 1.5px solid var(--parchment-dark);
  border-radius: 8px; padding: 0.6rem 1.4rem;
  font-family: 'Spectral', serif; font-size: 0.85rem;
  cursor: pointer; transition: all 0.15s; color: var(--ink);
}
.res-bieb-btn:hover { border-color: var(--gold); background: #fffbf3; }

/* ── Bieb sessie-panel ── */
.bieb-sessie-panel {
  margin-top: 1rem; background: var(--parchment);
  border: 1.5px solid var(--parchment-dark); border-radius: 12px;
  padding: 1.1rem 1.3rem;
}
.sessie-laden, .sessie-leeg { font-size: 0.78rem; color: #a08060; font-style: italic; }
.sessie-kop      { display: flex; align-items: center; justify-content: space-between; margin-bottom: 0.6rem; flex-wrap: wrap; gap: 0.4rem; }
.sessie-kop-titel{ font-size: 0.82rem; font-weight: 600; color: var(--ink); }
.sessie-kop-meta { font-size: 0.7rem; color: #8a7a60; }

.sessie-hist { display: flex; flex-wrap: wrap; gap: 0.4rem; margin-bottom: 0.8rem; }
.sessie-hist-item { font-size: 0.72rem; color: #5a4a30; }

.sessie-antwoorden-titel { font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.12em; color: #b0a080; margin-bottom: 0.4rem; }
.sessie-antwoorden { display: flex; flex-direction: column; gap: 0.35rem; margin-bottom: 0.9rem; }

.sa-rij {
  display: flex; align-items: center; gap: 0.55rem;
  padding: 0.4rem 0.6rem; border-radius: 7px; flex-wrap: wrap;
}
.sa-ok    { background: rgba(46,122,79,0.08);  }
.sa-fout  { background: rgba(122,59,46,0.07); }
.sa-icoon { font-size: 0.78rem; font-weight: 700; flex-shrink: 0; }
.sa-ok   .sa-icoon { color: var(--jarr); }
.sa-fout .sa-icoon { color: var(--raf); }
.sa-ar   { font-family: 'Amiri', serif; font-size: 1.05rem; direction: rtl; }
.sa-bet  { font-size: 0.7rem; color: #8a7a60; font-style: italic; flex: 1; }
.sa-vergelijk { display: flex; align-items: center; gap: 0.3rem; font-size: 0.75rem; flex-shrink: 0; }
.sa-gekozen   { color: var(--raf); font-weight: 600; }
.sa-juist     { color: var(--jarr); font-weight: 600; }

.sessie-opnieuw-btn {
  width: 100%; padding: 0.55rem;
  background: var(--ink); color: var(--gold-light);
  border: none; border-radius: 8px;
  font-family: 'Spectral', serif; font-size: 0.82rem;
  cursor: pointer; transition: all 0.15s;
}
.sessie-opnieuw-btn:hover { background: #2e1a00; }

/* ══════════════════════════════════════════
   PROGRESSIE PAGINA
══════════════════════════════════════════ */
.prog-wrap { max-width: min(1100px, 90vw); width: 100%; margin: 0 auto; padding: 1.5rem 1.5rem 2rem; position: relative; z-index: 1; }

/* Naam in header klikbaar */
.auth-naam { cursor: pointer; text-decoration: underline; text-underline-offset: 3px; text-decoration-color: rgba(200,149,42,0.4); }
.auth-naam:hover { color: white; }

/* Login-prompt */
.prog-login-prompt { text-align: center; padding: 4rem 2rem; }
.prog-login-ar     { font-family: 'Amiri', serif; font-size: 2.5rem; color: var(--gold); margin-bottom: 0.75rem; }
.prog-login-tekst  { font-size: 0.92rem; color: #6a5a40; }

/* Profielkop */
.prog-kop {
  display: flex; align-items: center; gap: 1.2rem;
  background: var(--ink); border-radius: 14px;
  padding: 1.5rem 1.8rem; margin-bottom: 1.5rem;
  color: var(--gold-light);
}
.prog-avatar {
  width: 52px; height: 52px; border-radius: 50%;
  background: rgba(200,149,42,0.2); display: flex;
  align-items: center; justify-content: center;
  font-family: 'Amiri', serif; font-size: 1.5rem; color: var(--gold);
  flex-shrink: 0;
}
.prog-naam-groot  { font-size: 1.15rem; font-weight: 600; margin-bottom: 0.2rem; }
.prog-email-klein { font-size: 0.72rem; color: #8a7060; }

/* Totaalcijfers */
.prog-totalen {
  display: flex; gap: 0.75rem; margin-bottom: 1.8rem; flex-wrap: wrap;
}
.prog-totaal-kaart {
  flex: 1; min-width: 130px;
  background: white; border: 1.5px solid var(--parchment-dark);
  border-radius: 12px; padding: 0.9rem 1rem; text-align: center;
  box-shadow: 0 1px 6px var(--shadow);
}
.prog-totaal-num   { font-size: 1.7rem; font-weight: 700; color: var(--gold); line-height: 1; }
.prog-totaal-label { font-size: 0.65rem; color: #8a7a60; text-transform: uppercase; letter-spacing: 0.1em; margin-top: 0.2rem; }

/* Per modus */
.prog-sectie-titel {
  font-size: 0.68rem; text-transform: uppercase; letter-spacing: 0.15em;
  color: #8a7a60; margin-bottom: 0.75rem;
}
.prog-modi-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 0.65rem; margin-bottom: 1.8rem;
}
.prog-modus-kaart {
  background: white; border: 1.5px solid var(--parchment-dark);
  border-radius: 10px; padding: 0.85rem 1rem;
  box-shadow: 0 1px 4px var(--shadow);
}
.prog-modus-naam  { font-size: 0.82rem; font-weight: 600; margin-bottom: 0.5rem; }
.prog-modus-balk-wrap { background: var(--parchment-dark); border-radius: 4px; height: 6px; margin-bottom: 0.35rem; }
.prog-modus-balk  { height: 100%; border-radius: 4px; background: var(--gold); transition: width 0.4s ease; }
.prog-modus-cijfers { font-size: 0.72rem; color: #6a5a40; }

/* Oefenmodi-overzicht (tashkeel / woordenschat / lezen) */
.prog-modus-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: .65rem;
  margin-bottom: 1.5rem;
}
.prog-modus-grid .prog-modus-kaart {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .2rem;
  padding: .9rem .75rem .7rem;
  text-align: center;
}
.pmk-icon   { font-size: 1.3rem; line-height: 1; }
.pmk-naam   { font-size: .72rem; font-weight: 600; color: var(--ink); }
.pmk-score  { font-size: .78rem; margin: .15rem 0; }
.pmk-balk   { width: 100%; height: 5px; background: var(--parchment-dark); border-radius: 3px; overflow: hidden; }
.pmk-balk-inner { height: 100%; border-radius: 3px; transition: width .4s ease; }
.pmk-count  { font-size: .65rem; color: #8a7a60; }
.pmk-leeg   { font-size: .78rem; color: #b0a080; }

/* Sessie-tijdlijn */
.prog-sessies-lijst { display: flex; flex-direction: column; gap: 0.5rem; }
.prog-sessie-rij {
  display: flex; align-items: center; gap: 0.75rem;
  background: white; border: 1.5px solid var(--parchment-dark);
  border-radius: 9px; padding: 0.65rem 0.9rem;
  cursor: pointer; transition: all 0.15s;
}
.prog-sessie-rij:hover { border-color: var(--gold); background: #fffbf3; }
.prog-sessie-datum { font-size: 0.65rem; color: #b0a080; white-space: nowrap; flex-shrink: 0; }

/* ── Progressie: niveau/set grid ── */
.prog-niveau-sectie  { margin-bottom: 1.8rem; }

.prog-niveau-header {
  display: flex; align-items: center; justify-content: space-between;
  border-left: 4px solid; padding-left: 0.75rem; margin-bottom: 0.85rem;
}
.prog-niveau-titels { display: flex; align-items: baseline; gap: 0.55rem; }
.prog-niveau-ar     { font-family: 'Amiri', serif; font-size: 1.2rem; direction: rtl; color: var(--ink); }
.prog-niveau-nl     { font-size: 0.8rem; color: #8a7a60; font-weight: 600; }
.prog-niveau-vg     { font-size: 0.7rem; color: #a08060; }

.prog-set-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 0.75rem;
}

.prog-set-kaart {
  background: white; border: 1.5px solid var(--parchment-dark);
  border-radius: 12px; padding: 0.9rem 1rem;
  display: flex; flex-direction: column; gap: 0.4rem;
  transition: box-shadow 0.15s;
}
.prog-set-kaart:hover   { box-shadow: 0 2px 10px var(--shadow); }
.prog-set-voltooid      { border-color: var(--jarr); background: rgba(46,122,79,0.04); }
.prog-set-bezig         { border-color: rgba(200,149,42,0.4); }

.prog-set-kop    { display: flex; align-items: center; justify-content: space-between; margin-bottom: 0.1rem; }
.prog-set-nummer { font-size: 0.82rem; font-weight: 700; color: var(--ink); }
.prog-set-score  { font-size: 0.78rem; font-weight: 600; color: var(--gold); }
.prog-set-balk-wrap { height: 4px; background: var(--parchment-dark); border-radius: 2px; }
.prog-set-balk      { height: 100%; border-radius: 2px; transition: width 0.4s; }
.prog-set-meta   { font-size: 0.65rem; color: #a08060; }

.prog-set-zinnen { display: flex; flex-direction: column; gap: 0.18rem; margin: 0.4rem 0; }
.prog-zin-rij {
  display: flex; align-items: center; justify-content: space-between;
  gap: 0.5rem; padding: 0.18rem 0;
  border-bottom: 1px solid var(--parchment-dark); cursor: pointer;
}
.prog-zin-rij:last-child { border-bottom: none; }
.prog-zin-rij:hover .prog-zin-ar { color: var(--gold); }
.prog-zin-nieuw { cursor: default; opacity: 0.45; }
.prog-zin-nieuw:hover .prog-zin-ar { color: inherit; }
.prog-zin-ar    { font-family: 'Amiri', serif; font-size: 0.88rem; direction: rtl; flex: 1; line-height: 1.5; }
.prog-zin-leeg  { font-size: 0.65rem; color: #c0b090; flex-shrink: 0; }

.prog-niveau-pijl {
  font-size: 0.7rem; color: #a08060; flex-shrink: 0; margin-right: 0.2rem;
  transition: transform 0.15s;
}
.prog-niveau-header:hover .prog-niveau-pijl { color: var(--gold); }

.prog-set-acties {
  display: flex; gap: 0.4rem; margin-top: 0.4rem; flex-wrap: wrap;
}
.prog-oefen-btn {
  flex: 1;
  background: var(--ink); color: var(--gold-light);
  border: none; border-radius: 7px; padding: 0.38rem 0.5rem;
  font-family: 'Spectral', serif; font-size: 0.72rem; font-weight: 600;
  cursor: pointer; transition: background 0.15s; text-align: center;
}
.prog-oefen-btn:hover     { background: #2e1a00; }
.prog-oefen-bet           { background: rgba(46,92,122,0.15); color: var(--nasb); border: 1.5px solid rgba(46,92,122,0.3); }
.prog-oefen-bet:hover     { background: rgba(46,92,122,0.25); }
.prog-sessie-ar    { font-family: 'Amiri', serif; font-size: 1rem; direction: rtl; flex: 1; line-height: 1.5; }
.prog-sessie-nl    { font-size: 0.7rem; color: #8a7a60; font-style: italic; }

/* ══════════════════════════════════════════
   OEFENEN
══════════════════════════════════════════ */
.oefen-wrap { max-width: min(1520px, 96vw); width: 100%; margin: 0 auto; padding: 1.5rem 1.5rem 2rem; flex: 1; overflow-y: auto; overflow-x: hidden; scrollbar-width: none; -webkit-overflow-scrolling: touch; display: flex; flex-direction: column; justify-content: flex-start; position: relative; z-index: 1; }
.oefen-wrap::-webkit-scrollbar { display: none; }

/* ── Zin-kiezer & voortgang ── */

.voortgang-lijst    { display: flex; flex-direction: column; gap: 0.5rem; margin-bottom: 1.4rem; }

.vg-rij {
  background: white; border: 1.5px solid var(--parchment-dark);
  border-radius: 10px; padding: 0.75rem 1rem;
  display: flex; flex-direction: column; gap: 0.5rem;
}
.vg-ar              { font-family: 'Amiri', serif; font-size: 1.1rem; direction: rtl; color: var(--ink); line-height: 1.8; }
.vg-rij-rechts      { display: flex; align-items: center; justify-content: space-between; gap: 0.5rem; }
.vg-meta            { display: flex; align-items: center; gap: 0.5rem; }
.vg-keer            { font-size: 0.68rem; color: #8a7a60; }
.vg-acties          { display: flex; gap: 0.4rem; }
.vg-herhaal-btn, .vg-bieb-btn {
  background: none; border: 1.5px solid var(--parchment-dark);
  border-radius: 6px; padding: 0.25rem 0.7rem;
  font-family: 'Spectral', serif; font-size: 0.72rem;
  cursor: pointer; transition: all 0.15s; color: var(--ink);
}
.vg-herhaal-btn:hover { border-color: var(--gold); background: #fffbf3; }
.vg-bieb-btn:hover    { border-color: var(--nasb);  color: var(--nasb); }

.vg-score-badge  { display: inline-block; padding: 0.15rem 0.5rem; border-radius: 10px; font-size: 0.65rem; font-weight: 700; }
.vg-score-goed   { background: rgba(46,122,79,0.12);  color: var(--jarr); }
.vg-score-matig  { background: rgba(200,149,42,0.12); color: var(--gold); }
.vg-score-slecht { background: rgba(122,59,46,0.1);   color: var(--raf); }
.vg-score-nieuw  { background: rgba(100,100,100,0.1); color: #888; }

/* ── Zin-kiezer modal ── */
.zin-kiezer-modal     { max-width: 560px; max-height: 85vh; display: flex; flex-direction: column; }
.zk-titel             { font-size: 1rem; font-weight: 600; color: var(--ink); margin-bottom: 1rem; }
.zk-zoek              {
  width: 100%; border: 1.5px solid var(--parchment-dark); border-radius: 8px;
  padding: 0.55rem 0.9rem; font-family: 'Spectral', serif; font-size: 0.85rem;
  color: var(--ink); outline: none; margin-bottom: 0.75rem; background: white;
}
.zk-zoek:focus        { border-color: var(--gold); }
.zk-lijst             { overflow-y: auto; flex: 1; display: flex; flex-direction: column; gap: 0.4rem; }
.zk-rij {
  display: flex; align-items: center; gap: 0.75rem;
  border: 1.5px solid var(--parchment-dark); border-radius: 9px;
  padding: 0.7rem 0.9rem; cursor: pointer; transition: all 0.15s;
  background: white;
}
.zk-rij:hover         { border-color: var(--gold); background: #fffbf3; }
.zk-ar                { font-family: 'Amiri', serif; font-size: 1.05rem; direction: rtl; flex: 1; line-height: 1.6; }
.zk-info              { text-align: right; flex-shrink: 0; }
.zk-vertaling         { font-size: 0.7rem; color: #8a7a60; font-style: italic; }

/* ── Keuze-scherm ── */
.oefen-kop   { text-align: center; margin-bottom: 1.8rem; }
.oefen-titel { font-family: 'Amiri', serif; font-size: 1.8rem; color: var(--gold); }
.oefen-sub   { font-size: 0.82rem; color: #8a7a60; margin-top: 0.2rem; }

/* Tashkeel — uitgelicht */
.tashkeel-featured {
  background: var(--ink); color: var(--gold-light);
  border-radius: 16px; padding: 2.2rem 2rem 1.8rem;
  cursor: pointer; text-align: center;
  transition: all 0.2s; margin-bottom: 1.8rem;
  box-shadow: 0 4px 20px rgba(26,18,9,0.18);
}
.tashkeel-featured:hover { background: #2a1400; transform: translateY(-3px); box-shadow: 0 8px 28px rgba(26,18,9,0.25); }

.tf-ar    { font-family: 'Amiri', serif; font-size: 2.2rem; margin-bottom: 0.4rem; }
.tf-titel { font-size: 1.1rem; font-weight: 600; margin-bottom: 0.6rem; }
.tf-beschr{ font-size: 0.82rem; color: #c8b080; line-height: 1.6; margin-bottom: 1rem; }
.tf-start { display: inline-block; background: var(--gold); color: var(--ink); font-weight: 700; font-size: 0.85rem; padding: 0.5rem 1.5rem; border-radius: 8px; }

/* Overige modi */
.oefen-extra-label {
  font-size: 0.68rem; text-transform: uppercase; letter-spacing: 0.15em;
  color: #8a7a60; text-align: center; margin-bottom: 0.75rem;
}
.oefen-extra-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 0.65rem;
}
.extra-mode-btn {
  background: white; border: 1.5px solid var(--parchment-dark);
  border-radius: 12px; padding: 1rem 1rem 0.9rem;
  cursor: pointer; transition: all 0.15s;
  display: flex; flex-direction: column; align-items: flex-start; gap: 0.15rem;
  text-align: left;
}
.extra-mode-btn:hover { border-color: var(--gold); background: #fffbf3; transform: translateY(-2px); }
.extra-mode-slot      { opacity: 0.45; cursor: not-allowed; pointer-events: none; }
.extra-mode-slot:hover{ transform: none; border-color: var(--parchment-dark); background: white; }
.slot-label           { font-size: 0.6rem; color: #a08060; font-weight: 400; margin-left: 0.3rem; font-style: italic; }
.emb        { font-size: 1.2rem; margin-bottom: 0.1rem; }
.extra-naam { font-size: 0.88rem; font-weight: 600; color: var(--ink); }
.extra-beschr{ font-size: 0.72rem; color: #8a7a60; line-height: 1.4; }

/* Actieve oefening header */
.oefen-actief-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 1rem; gap: 0.75rem;
}
.oefen-stop-btn {
  background: white; border: 1.5px solid var(--parchment-dark);
  border-radius: 8px; padding: 0.4rem 0.9rem;
  font-family: 'Spectral', serif; font-size: 0.78rem;
  cursor: pointer; transition: all 0.15s; color: var(--ink); white-space: nowrap;
}
.oefen-stop-btn:hover { border-color: var(--raf); color: var(--raf); }

.oefen-actief-naam {
  font-size: 0.85rem; font-weight: 600; color: var(--ink);
  flex: 1; text-align: center;
}
.oefen-actief-score {
  display: flex; align-items: center; gap: 0.4rem; flex-shrink: 0;
}
#score-display { font-size: 0.82rem; font-weight: 600; color: var(--ink); }

.reset-btn {
  background: none; border: 1px solid var(--parchment-dark);
  border-radius: 6px; padding: 0.2rem 0.55rem;
  font-size: 0.72rem; cursor: pointer; color: #8a7a60;
  transition: all 0.15s;
}
.reset-btn:hover { border-color: var(--raf); color: var(--raf); }

.vraag-container { min-height: 0; }

.vraag-laden {
  text-align: center; padding: 4rem 2rem;
  color: #a08060; font-style: italic;
}

.vraag-kaart {
  background: white; border: 1.5px solid var(--parchment-dark);
  border-radius: 16px; padding: 1.5rem 1.5rem 1.25rem;
  box-shadow: 0 4px 24px var(--shadow);
  animation: popIn 0.22s ease;
  max-width: 740px; width: 100%; margin-left: auto; margin-right: auto;
}

/* Zincontext boven de vraag */
.vraag-zin-context {
  background: var(--parchment);
  border-radius: 10px;
  padding: 0.75rem 1rem;
  margin-bottom: 0;
  text-align: right;
  user-select: none;
}
.vraag-zin-ar {
  font-family: 'Amiri', serif; font-size: 1.5rem;
  direction: rtl; line-height: 1.85; color: var(--ink);
}
.vraag-zin-nl {
  font-size: 0.85rem; color: #6a5a40;
  font-style: italic; margin-top: 0.2rem; text-align: left;
}

.vraag-scheiding {
  border-top: 1px dashed var(--parchment-dark);
  margin: 0.6rem 0 0.5rem;
}

.vraag-label {
  font-size: 0.8rem; text-transform: uppercase;
  letter-spacing: 0.12em; color: #8a7a60;
  margin-bottom: 0.5rem; text-align: center;
}

.vraag-woord-ar {
  font-family: 'Amiri', serif; font-size: 2.2rem;
  direction: rtl; text-align: center;
  color: var(--ink); line-height: 1.5; margin-bottom: 0.2rem;
}

/* Onderstreept target-woord */
.vraag-woord-onderstreept {
  text-decoration: underline;
  text-decoration-color: var(--gold);
  text-underline-offset: 6px;
  text-decoration-thickness: 2px;
}

.vraag-context {
  font-size: 0.85rem; color: #8a7a60; text-align: center;
  font-style: italic; margin-bottom: 1rem; min-height: 1.2rem;
}

.vraag-voortgang {
  font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--gold); text-align: center; margin-bottom: 0.3rem;
  font-weight: 600;
}

.opties-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; margin-top: 1rem; }

.optie-btn {
  background: var(--parchment); border: 2px solid var(--parchment-dark);
  border-radius: 10px; padding: 0.85rem 1rem;
  font-family: 'Spectral', serif; font-size: 0.88rem;
  cursor: pointer; transition: all 0.15s;
  text-align: center; color: var(--ink); line-height: 1.35;
}
.optie-btn:hover:not(:disabled) { border-color: var(--gold); background: #fffbf3; transform: translateY(-1px); }
.optie-btn:disabled { cursor: default; }
.optie-btn.correct  { border-color: var(--jarr); background: rgba(46,122,79,0.1); color: var(--jarr); font-weight: 600; }
.optie-btn.fout     { border-color: var(--raf);  background: rgba(122,59,46,0.1); color: var(--raf); }

.vraag-feedback   { margin-top: 1.2rem; text-align: center; }
.feedback-correct { color: var(--jarr); font-weight: 600; font-size: 0.9rem; margin-bottom: 0.8rem; }
.feedback-fout    { color: var(--raf); font-size: 0.88rem; margin-bottom: 0.8rem; line-height: 1.45; }

.volgende-btn {
  background: var(--ink); color: var(--gold-light);
  border: none; border-radius: 8px; padding: 0.6rem 1.6rem;
  font-family: 'Spectral', serif; font-size: 0.85rem;
  cursor: pointer; transition: all 0.15s; margin-top: 0.5rem;
}
.volgende-btn:hover { background: #2e1a00; }

/* ── Tashkeel-oefening ── */
.tashkeel-voortgang {
  text-align: center; font-size: 0.7rem;
  color: #b0a080; letter-spacing: 0.12em;
  text-transform: uppercase; margin-bottom: 0.75rem;
}

.tashkeel-opties {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.5rem;
  margin-top: 0.75rem;
}

.tashkeel-btn {
  background: var(--parchment); border: 2px solid var(--parchment-dark);
  border-radius: 12px; padding: 0.6rem 0.4rem 0.5rem;
  cursor: pointer; transition: all 0.15s;
  display: flex; flex-direction: column; align-items: center; gap: 0.2rem;
}
.tashkeel-btn:hover:not(:disabled) { border-color: var(--gold); background: #fffbf3; transform: translateY(-2px); box-shadow: 0 4px 12px rgba(200,149,42,0.15); }
.tashkeel-btn:disabled { cursor: default; }
.tashkeel-btn.correct  { border-color: var(--jarr); background: rgba(46,122,79,0.1); }
.tashkeel-btn.fout     { border-color: var(--raf);  background: rgba(122,59,46,0.1); }

/* Groot teken bovenaan */
.tashkeel-teken {
  font-family: 'Amiri', serif; font-size: 1.75rem;
  line-height: 1.2; color: var(--ink); direction: rtl;
  padding-bottom: 0.25rem;
  border-bottom: 1px solid var(--parchment-dark);
  width: 100%; text-align: center;
}
/* Arabische naam */
.tashkeel-ar {
  font-family: 'Amiri', serif; font-size: 0.82rem;
  color: var(--ink); direction: rtl;
}
/* Nederlandse naam */
.tashkeel-nl  { font-size: 0.65rem; color: #4a3a20; font-weight: 600; }
/* Geval-aanduiding */
.tashkeel-sub { font-size: 0.58rem; color: #8a7a60; font-style: italic; }

.tashkeel-klinker-uitleg {
  font-size: 0.76rem; color: #6a5a40; margin-top: 0.35rem;
  font-style: italic;
}

/* ── Tashkeel resultaatscherm ── */
.res-kaart       { padding: 1.5rem 1.5rem 1rem; }

.res-score-kop   {
  display: flex; align-items: center; justify-content: center;
  gap: 1rem; padding: 1rem; border-radius: 10px; margin-bottom: 1.2rem;
}
.score-goed   { background: rgba(46,122,79,0.1);  border: 1px solid rgba(46,122,79,0.25); }
.score-matig  { background: rgba(200,149,42,0.1); border: 1px solid rgba(200,149,42,0.3); }
.score-slecht { background: rgba(122,59,46,0.08); border: 1px solid rgba(122,59,46,0.2); }

.score-goed   .res-score-getal, .score-goed   .res-score-pct { color: var(--jarr); }
.score-matig  .res-score-getal, .score-matig  .res-score-pct { color: var(--gold); }
.score-slecht .res-score-getal, .score-slecht .res-score-pct { color: var(--raf);  }

/* ── Proef-voltooid scherm ── */
.proef-voltooid-kaart {
  text-align: center;
  padding: 2.5rem 1.5rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
}
.proef-ar {
  font-family: 'Amiri', serif;
  font-size: 2.6rem;
  color: var(--gold);
  line-height: 1.6;
  direction: rtl;
}
.proef-titel {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--ink);
}
.proef-uitleg {
  font-size: 0.88rem;
  color: #5a4a30;
  line-height: 1.65;
  max-width: 340px;
}
.proef-aanmeld-btn {
  background: var(--gold);
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 0.75rem 1.5rem;
  font-size: 0.95rem;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.2s;
  width: 100%;
  max-width: 320px;
}
.proef-aanmeld-btn:hover { background: #b07a20; }
.proef-terug-btn {
  background: none;
  border: none;
  color: #a08060;
  font-size: 0.82rem;
  cursor: pointer;
  text-decoration: underline;
  padding: 0.2rem;
}
.proef-terug-btn:hover { color: var(--ink); }

/* ── Showcase-oefening (proef-scherm) ── */
#oefen-proef { width: 100%; }

.proef-oef-wrap {
  max-width: 540px;
  margin: 0 auto;
  padding: .75rem 1rem 2rem;
}

.proef-oef-header {
  display: flex;
  align-items: center;
  margin-bottom: .5rem;
}
.proef-oef-terug {
  background: none;
  border: none;
  color: var(--gold);
  cursor: pointer;
  display: flex;
  align-items: center;
  padding: .3rem;
  border-radius: 6px;
}
.proef-oef-terug:hover { background: rgba(200,149,42,.1); }

.proef-oef-resultaat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .9rem;
  padding-top: 2rem;
  text-align: center;
}

.res-score-getal { font-size: 1.4rem; font-weight: 700; }
.res-score-pct   { font-size: 2rem;   font-weight: 700; }

.res-zin-blok { text-align: center; margin-bottom: 1.2rem; }
.res-zin-ar   { font-family: 'Amiri', serif; font-size: 1.6rem; direction: rtl; line-height: 1.9; color: var(--ink); }
.res-zin-nl   { font-size: 0.8rem; color: #5a4a30; font-style: italic; }

.res-label    { font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.13em; color: #b0a080; margin-bottom: 0.6rem; }

.res-woorden  { display: flex; flex-direction: column; gap: 0.55rem; }

.res-rij {
  border-radius: 9px; padding: 0.65rem 0.85rem;
  display: grid;
  grid-template-columns: 1.2rem 1fr auto auto;
  align-items: center; gap: 0.6rem;
}
.res-correct { background: rgba(46,122,79,0.07);  border: 1px solid rgba(46,122,79,0.2); }
.res-fout    { background: rgba(122,59,46,0.06);  border: 1px solid rgba(122,59,46,0.18);
               grid-template-columns: 1.2rem 1fr; flex-direction: column; display: flex; flex-wrap: wrap; }

.res-icoon    { font-size: 0.85rem; font-weight: 700; flex-shrink: 0; }
.res-correct .res-icoon { color: var(--jarr); }
.res-fout    .res-icoon { color: var(--raf); }

.res-woord    { font-family: 'Amiri', serif; font-size: 1.2rem; direction: rtl; }
.res-betekenis{ font-size: 0.72rem; color: #8a7a60; font-style: italic; }

/* Fout-uitleg sectie */
.res-fout-uitleg {
  grid-column: 1/-1; width: 100%;
  background: rgba(122,59,46,0.05); border-radius: 7px;
  padding: 0.55rem 0.75rem; margin-top: 0.35rem;
  display: flex; flex-direction: column; gap: 0.3rem;
}
.res-fout-vergelijk {
  display: flex; align-items: center; gap: 0.5rem;
  font-size: 0.8rem; flex-wrap: wrap;
}
.res-gekozen  { color: var(--raf); }
.res-juist    { color: var(--jarr); }
.res-pijl     { color: #bbb; }
.res-klinker-uitleg { font-size: 0.76rem; color: #5a4a30; font-style: italic; }
.res-geval-info     { font-size: 0.72rem; color: #7a6a50; display: flex; align-items: center; gap: 0.4rem; flex-wrap: wrap; }

/* ══════════════════════════════════════════
   BIBLIOTHEEK
══════════════════════════════════════════ */
.bieb-wrap { max-width: min(1600px, 94vw); width: 100%; margin: 0 auto; padding: 1.5rem 1.5rem 2rem; position: relative; z-index: 1; }

.bieb-kop      { text-align: center; margin-bottom: 1.5rem; }
.bieb-titel-ar { font-family: 'Amiri', serif; font-size: 2rem; color: var(--gold); direction: rtl; }
.bieb-titel-nl { font-size: 0.78rem; color: #8a7a60; letter-spacing: 0.15em; text-transform: uppercase; }

.bieb-filters { margin-bottom: 1.2rem; }
.filter-rij   { display: flex; gap: 0.75rem; margin-bottom: 0.75rem; flex-wrap: wrap; }

.bieb-zoek {
  flex: 1; min-width: 220px;
  background: white; border: 1.5px solid var(--parchment-dark);
  border-radius: 8px; padding: 0.55rem 1rem;
  font-family: 'Spectral', serif; font-size: 0.85rem;
  color: var(--ink); outline: none;
}
.bieb-zoek:focus { border-color: var(--gold); }

.bieb-select {
  background: white; border: 1.5px solid var(--parchment-dark);
  border-radius: 8px; padding: 0.55rem 0.9rem;
  font-family: 'Spectral', serif; font-size: 0.82rem;
  color: var(--ink); cursor: pointer; outline: none;
}
.bieb-select:focus { border-color: var(--gold); }

.cat-tabs { display: flex; gap: 0.4rem; flex-wrap: wrap; }
.cat-tab {
  background: white; border: 1.5px solid var(--parchment-dark);
  border-bottom: 3px solid transparent;
  border-radius: 8px; padding: 0.4rem 0.9rem;
  font-family: 'Amiri', serif; font-size: 0.9rem;
  cursor: pointer; transition: all 0.15s; color: #5a4a30;
}
.cat-tab:hover  { background: #fffbf3; }
.cat-tab.actief { background: var(--ink); color: var(--gold-light); border-color: var(--ink); border-bottom-color: var(--gold); }
.tab-count      { font-family: 'Spectral', serif; font-size: 0.65rem; opacity: 0.7; }

/* View-toggle */
.bieb-view-toggle {
  display: flex; gap: 0.5rem;
  margin-bottom: 1.2rem;
}
.bieb-view-btn {
  background: white; border: 1.5px solid var(--parchment-dark);
  border-radius: 10px; padding: 0.55rem 1.3rem;
  font-family: 'Spectral', serif; font-size: 0.85rem;
  cursor: pointer; transition: all 0.15s; color: #5a4a30;
}
.bieb-view-btn:hover  { border-color: var(--gold); }
.bieb-view-btn.actief { background: var(--ink); color: var(--gold-light); border-color: var(--ink); }

.bieb-result-info { font-size: 0.72rem; color: #8a7a60; margin-bottom: 1rem; text-align: right; }

/* Woordenlijst */
.woorden-groep        { margin-bottom: 2rem; }
.woorden-groep-header {
  display: flex; align-items: center; justify-content: space-between;
  padding-bottom: 0.5rem; margin-bottom: 0.85rem;
  border-bottom: 2px solid var(--parchment-dark);
}
.woorden-groep-naam  { font-size: 0.88rem; font-weight: 600; color: var(--ink); }
.woorden-groep-ar    { font-family: 'Amiri', serif; font-size: 1rem; color: var(--gold); margin-left: 0.5rem; }
.woorden-groep-count { font-size: 0.7rem; color: #8a7a60; background: var(--parchment-dark); padding: 0.1rem 0.6rem; border-radius: 10px; }

/* Woordenlijst — lijst-layout (was grid) */
.woorden-lijst {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.woord-kaartje {
  background: white; border: 1.5px solid var(--parchment-dark);
  border-radius: 12px; padding: 1rem 1.2rem;
  transition: border-color 0.15s;
}
.woord-kaartje:hover { border-color: var(--gold); }

/* Kopje: basisvorm + betekenis */
.woord-kaartje-kop {
  display: flex; align-items: baseline;
  gap: 1rem; margin-bottom: 0.6rem;
  flex-wrap: wrap;
}
.woord-kaartje-basis {
  font-family: 'Amiri', serif; font-size: 1.6rem;
  direction: rtl; color: var(--ink); line-height: 1.3;
  flex-shrink: 0;
}
.woord-kaartje-meta  { display: flex; flex-direction: column; gap: 0.1rem; }
.woord-kaartje-bet   { font-size: 0.88rem; color: #3a2a10; font-weight: 600; }
.woord-kaartje-trans { font-size: 0.7rem; color: #8a7a60; font-style: italic; }

/* Vormen-sectie */
.woord-vormen       { border-top: 1px solid var(--parchment-dark); padding-top: 0.6rem; display: flex; flex-direction: column; gap: 0.5rem; }
.woord-vormen-label { font-size: 0.58rem; text-transform: uppercase; letter-spacing: 0.12em; color: #b0a080; margin-bottom: 0.1rem; }

.woord-vorm {
  background: var(--parchment); border-radius: 8px;
  padding: 0.55rem 0.8rem;
}
.woord-vorm-top      { display: flex; align-items: center; gap: 0.6rem; margin-bottom: 0.25rem; }
.woord-vorm-ar       { font-family: 'Amiri', serif; font-size: 1.25rem; direction: rtl; color: var(--ink); }
.woord-vorm-zin      { font-family: 'Amiri', serif; font-size: 0.95rem; direction: rtl; color: #5a4a30; line-height: 1.7; }
.woord-vorm-vertaling{ font-size: 0.72rem; color: #8a7a60; font-style: italic; margin-top: 0.1rem; }

.bieb-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
  gap: 1rem;
}

.bieb-kaart {
  background: white; border: 1.5px solid var(--parchment-dark);
  border-radius: 12px; padding: 1.1rem 1.2rem 1rem;
  cursor: pointer; transition: all 0.18s;
  box-shadow: 0 1px 6px var(--shadow);
  display: flex; flex-direction: column; gap: 0.5rem;
}
.bieb-kaart:hover { transform: translateY(-3px); box-shadow: 0 8px 22px var(--shadow); border-color: var(--gold); }

.bieb-kaart-cat    { font-family: 'Amiri', serif; font-size: 0.85rem; direction: rtl; opacity: 0.75; }
.bieb-kaart-ar     { font-family: 'Amiri', serif; font-size: 1.25rem; direction: rtl; line-height: 1.7; color: var(--ink); }
.bieb-kaart-nl     { font-size: 0.78rem; color: #5a4a30; font-style: italic; line-height: 1.4; }
.bieb-kaart-footer { display: flex; align-items: center; justify-content: space-between; margin-top: 0.25rem; }
.bieb-bron         { font-size: 0.62rem; color: #b0a080; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 60%; }

.bieb-niveau           { font-size: 0.6rem; text-transform: uppercase; letter-spacing: 0.1em; padding: 0.15rem 0.55rem; border-radius: 10px; flex-shrink: 0; }
.bieb-niveau-beginner  { background: rgba(46,122,79,0.12);  color: var(--jarr); }
.bieb-niveau-gemiddeld { background: rgba(200,149,42,0.12); color: var(--gold); }
.bieb-niveau-gevorderd { background: rgba(122,59,46,0.12);  color: var(--raf); }

.bieb-leeg { text-align: center; padding: 4rem 2rem; color: #a08060; font-style: italic; }

.bieb-leeg-prompt {
  text-align: center; padding: 3rem 2rem;
  display: flex; flex-direction: column; align-items: center; gap: 0.5rem;
}
.bieb-leeg-ar    { font-family: 'Amiri', serif; font-size: 2rem; color: var(--gold); }
.bieb-leeg-tekst { font-size: 0.88rem; color: #6a5a40; line-height: 1.7; max-width: 320px; }


/* ══════════════════════════════════════════
   SITUATIES (Grammatica)
══════════════════════════════════════════ */
.sit-wrap { max-width: min(1600px, 94vw); width: 100%; margin: 0 auto; padding: 1.5rem 1.5rem 2rem; position: relative; z-index: 1; }

.sit-kop   { text-align: center; margin-bottom: 2rem; }
.sit-titel { font-size: 1.5rem; font-weight: 600; color: var(--ink); }
.sit-sub   { font-family: 'Amiri', serif; font-size: 1.1rem; color: #8a7a60; margin-top: 0.25rem; }

.geval-overzicht {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
  gap: 1.25rem; margin-bottom: 2.5rem;
}

.geval-uitleg-kaart {
  border-radius: 14px; padding: 1.6rem 1.6rem;
  cursor: pointer; transition: all 0.2s;
  border: 2px solid transparent;
  box-shadow: 0 2px 12px var(--shadow);
}
.geval-uitleg-kaart:hover { transform: translateY(-4px); box-shadow: 0 8px 28px var(--shadow); }

/* Solid colours = rgba tint pre-composited onto parchment (#f5efe2) */
.raf-kleur    { background: #ece2d5; border-color: rgba(122,59,46,0.25); }
.nasb-kleur   { background: #e7e5db; border-color: rgba(46,92,122,0.25); }
.jarr-kleur   { background: #e7e7d8; border-color: rgba(46,122,79,0.25); }
.jazm-kleur   { background: #eae2db; border-color: rgba(90,46,122,0.25); }
.mabni-kleur  { background: #ece7da; border-color: rgba(100,100,100,0.2); }
.tawabi-kleur { background: #eee6d3; border-color: rgba(139,101,8,0.25); }
.mahall-kleur { background: #e9e6dc; border-color: rgba(50,80,120,0.22); }

.raf-kleur    .geval-kaart-naam-ar, .raf-kleur    .geval-kaart-naam-nl { color: var(--raf); }
.nasb-kleur   .geval-kaart-naam-ar, .nasb-kleur   .geval-kaart-naam-nl { color: var(--nasb); }
.jarr-kleur   .geval-kaart-naam-ar, .jarr-kleur   .geval-kaart-naam-nl { color: var(--jarr); }
.jazm-kleur   .geval-kaart-naam-ar, .jazm-kleur   .geval-kaart-naam-nl { color: var(--jazm); }
.mabni-kleur  .geval-kaart-naam-ar, .mabni-kleur  .geval-kaart-naam-nl { color: #666; }
.tawabi-kleur  .geval-kaart-naam-ar, .tawabi-kleur  .geval-kaart-naam-nl { color: #8b6508; }
.mahall-kleur  .geval-kaart-naam-ar, .mahall-kleur  .geval-kaart-naam-nl { color: #2e5c7a; }

.geval-kaart-naam-ar  { font-family: 'Amiri', serif; font-size: 2.1rem; direction: rtl; line-height: 1.8; }
.geval-kaart-naam-nl  { font-size: 0.95rem; font-weight: 600; margin-bottom: 0.25rem; }
.geval-kaart-toestand { font-size: 0.8rem; color: #6a5a40; font-style: italic; margin-bottom: 0.2rem; }
.geval-kaart-klinker  { font-size: 0.75rem; color: #8a7a60; margin-bottom: 0.9rem; }
.geval-kaart-beschr   { font-size: 0.83rem; color: #4a3a20; line-height: 1.6; }
.geval-kaart-knop     { margin-top: 1.1rem; font-size: 0.76rem; color: var(--gold); font-weight: 600; }

/* Regels sectie */
.sit-regels-sectie {
  margin-top: 1.5rem; background: white;
  border: 1.5px solid var(--parchment-dark);
  border-radius: 14px; padding: 1.5rem;
  animation: fadeUp 0.25s ease;
}

.sit-sectie-header {
  display: flex; align-items: center;
  justify-content: space-between; margin-bottom: 1.2rem;
}
.sit-sectie-titel { font-size: 1rem; font-weight: 600; color: var(--ink); }

.sit-laden {
  text-align: center; padding: 2rem;
  color: #a08060; font-style: italic;
}

.sit-regels-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1rem;
}

.sit-regel-kaart {
  background: var(--parchment);
  border: 1.5px solid var(--parchment-dark);
  border-radius: 12px; padding: 1.2rem 1.3rem;
  display: flex; flex-direction: column; gap: 0.4rem;
}

.sit-regel-id       { font-family: monospace; font-size: 0.6rem; color: var(--gold); background: rgba(200,149,42,0.12); padding: 0.1rem 0.5rem; border-radius: 4px; align-self: flex-start; }
.sit-regel-naam-ar  { font-family: 'Amiri', serif; font-size: 1.5rem; direction: rtl; color: var(--ink); line-height: 1.3; margin-top: 0.2rem; }
.sit-regel-naam-nl  { font-size: 0.88rem; font-weight: 600; color: var(--ink); }
.sit-regel-beschr   { font-size: 0.78rem; color: #4a3a20; line-height: 1.6; margin-top: 0.2rem; flex: 1; }

.mahall-groep-label { display: flex; align-items: center; gap: 0.5rem; margin-bottom: 0.3rem; flex-wrap: wrap; }

.mahall-vb-lijst    { display: flex; flex-direction: column; gap: 0.35rem; margin-top: 0.6rem; }
.mahall-vb-item     { display: flex; align-items: baseline; gap: 0.5rem; font-size: 0.78rem; padding: 0.25rem 0; border-bottom: 1px solid var(--parchment-dark); }
.mahall-vb-item:last-child { border-bottom: none; }
.mahall-vb-ar       { font-family: 'Amiri', serif; font-size: 1.1rem; direction: rtl; color: var(--ink); flex-shrink: 0; }
.mahall-vb-bet      { color: #5a4a30; font-style: italic; flex: 1; }
.mahall-vb-functie  { color: #8a7a60; font-size: 0.7rem; text-align: right; }

.sit-vb-btn {
  margin-top: 0.8rem;
  background: var(--ink); color: var(--gold-light);
  border: none; border-radius: 7px;
  padding: 0.45rem 0.9rem; font-family: 'Spectral', serif;
  font-size: 0.75rem; cursor: pointer; transition: all 0.15s;
  align-self: flex-start;
}
.sit-vb-btn:hover { background: #2e1a00; }

/* Voorbeelden sectie */
.sit-voorbeelden-sectie {
  margin-top: 1rem; background: white;
  border: 1.5px solid var(--parchment-dark);
  border-radius: 14px; padding: 1.5rem;
  animation: fadeUp 0.25s ease;
}

.sit-vb-header {
  display: flex; align-items: center;
  justify-content: space-between; margin-bottom: 1.2rem;
}
.sit-vb-titel { font-size: 1rem; font-weight: 600; color: var(--ink); }

.sit-voorbeelden-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 0.85rem;
}
.sit-vb-kaart {
  background: var(--parchment); border: 1px solid var(--parchment-dark);
  border-radius: 10px; padding: 1rem 1.1rem;
}
.sit-vb-ar      { font-family: 'Amiri', serif; font-size: 1.4rem; direction: rtl; margin-bottom: 0.25rem; }
.sit-vb-bet     { font-size: 0.82rem; color: #5a4a30; font-style: italic; margin-bottom: 0.4rem; }
.sit-vb-info    { display: flex; align-items: center; gap: 0.5rem; margin-bottom: 0.4rem; flex-wrap: wrap; }
.sit-vb-functie { font-size: 0.72rem; color: #7a6a50; }
.sit-vb-reden   { font-size: 0.74rem; color: #6a5a40; line-height: 1.5; border-top: 1px solid var(--parchment-dark); padding-top: 0.4rem; margin-top: 0.2rem; }

/* ══════════════════════════════════════════
   TAAL-TOGGLE KNOP
══════════════════════════════════════════ */
.taal-toggle {
  background: none;
  border: 1px solid rgba(200,149,42,0.2);
  border-radius: 4px;
  color: #6a5a40;
  font-family: 'Spectral', serif;
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  padding: 0.18rem 0.45rem;
  cursor: pointer;
  transition: all 0.15s;
  flex-shrink: 0;
}
.taal-toggle:hover { color: var(--gold-light); border-color: rgba(200,149,42,0.5); }
[data-thema="donker"] .taal-toggle { color: #8a7a60; }

/* ══════════════════════════════════════════
   THEMA-TOGGLE KNOP
══════════════════════════════════════════ */
.thema-toggle {
  background: none;
  border: 1px solid rgba(200,149,42,0.2);
  border-radius: 20px;
  width: 28px; height: 20px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  padding: 0; flex-shrink: 0;
  transition: border-color 0.15s;
}
.thema-toggle:hover  { border-color: rgba(200,149,42,0.5); }
.thema-toggle::before {
  content: "☾";
  font-size: 0.72rem;
  color: #6a5a40;
  line-height: 1;
  font-style: normal;
  transition: color 0.15s;
}
.thema-toggle:hover::before { color: var(--gold-light); }
[data-thema="donker"] .thema-toggle::before { content: "☀"; color: #8a7a60; }

/* ══ OEFENEN — MODUS KEUZE ══ */
.oefen-modus-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-bottom: 1.5rem;
}
@media (max-width: 560px) { .oefen-modus-grid { grid-template-columns: 1fr; } }

.oefen-modus-kaart {
  background: white;
  border: 1.5px solid var(--parchment-dark);
  border-radius: 16px;
  padding: 1.8rem 1.5rem 1.4rem;
  cursor: pointer;
  transition: all 0.18s;
  display: flex; flex-direction: column; gap: 0.4rem;
}
.oefen-modus-kaart:hover { border-color: var(--gold); transform: translateY(-2px); box-shadow: 0 6px 20px var(--shadow); }
.oefen-modus-primair { background: var(--ink); color: var(--gold-light); border-color: var(--ink); }
.oefen-modus-primair:hover { background: #2a1400; border-color: #2a1400; transform: translateY(-2px); box-shadow: 0 6px 20px var(--shadow); }

.omk-ar     { font-family: 'Amiri', serif; font-size: 1.8rem; direction: rtl; line-height: 1.4; }
.omk-titel  { font-size: 1rem; font-weight: 600; display: flex; align-items: center; gap: 0.4rem; }
.omk-beschr { font-size: 0.8rem; color: #6a5a40; line-height: 1.55; flex: 1; margin-top: 0.1rem; }
.oefen-modus-primair .omk-beschr { color: #c8b080; }
.omk-start  { font-size: 0.78rem; font-weight: 600; color: var(--gold); margin-top: 0.6rem; display: flex; align-items: center; gap: 0.3rem; }
.oefen-modus-primair .omk-start { color: var(--gold-light); }
.oefen-modus-kaart [data-lucide] { width: 16px; height: 16px; }

/* ══ OEFENEN — NIVEAU / SET KEUZE ══ */
.oefen-keuze-nav {
  display: flex; align-items: center; gap: 0.85rem; margin-bottom: 1.2rem;
}
.oefen-keuze-nav-titel { font-size: 0.78rem; color: #a08060; font-style: italic; }

.oefen-terug-btn {
  background: white; border: 1.5px solid var(--parchment-dark);
  border-radius: 8px; padding: 0.38rem 0.9rem;
  font-family: 'Spectral', serif; font-size: 0.78rem;
  cursor: pointer; display: flex; align-items: center; gap: 0.35rem;
  transition: all 0.15s; color: var(--ink);
}
.oefen-terug-btn:hover { border-color: var(--gold); }
.oefen-terug-btn [data-lucide] { width: 12px; height: 12px; }

.oefen-keuze-kop {
  font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.13em;
  color: #b0a080; margin-bottom: 0.85rem;
}

/* Niveau kaarten */
.niveau-kaarten-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
  gap: 0.9rem;
}

.niveau-kaart {
  background: white; border: 1.5px solid var(--parchment-dark);
  border-top: 4px solid; border-radius: 14px;
  padding: 1.5rem 1.3rem 1.2rem;
  cursor: pointer; transition: all 0.18s;
  display: flex; flex-direction: column; gap: 0.3rem;
}
.niveau-kaart:hover { transform: translateY(-3px); box-shadow: 0 8px 24px var(--shadow); }
.niveau-kaart-ar   { font-family: 'Amiri', serif; font-size: 1.6rem; direction: rtl; }
.niveau-kaart-naam { font-size: 1rem; font-weight: 600; }
.niveau-kaart-meta { font-size: 0.72rem; color: #a08060; margin-bottom: 0.4rem; }
.niveau-kaart-balk-wrap { height: 4px; background: var(--parchment-dark); border-radius: 2px; }
.niveau-kaart-balk      { height: 100%; border-radius: 2px; transition: width 0.4s; }
.niveau-kaart-vg   { font-size: 0.65rem; color: #a08060; }
.niveau-kaart-pijl { font-size: 0.85rem; color: var(--gold); margin-top: auto; font-weight: 700; padding-top: 0.5rem; }

/* Set kaarten */
.set-kaarten-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 0.75rem;
}

.set-kaart {
  background: white; border: 1.5px solid var(--parchment-dark);
  border-radius: 12px; padding: 1rem 1rem 0.85rem;
  cursor: pointer; transition: all 0.18s;
  display: flex; flex-direction: column; gap: 0.45rem;
}
.set-kaart:hover        { border-color: var(--gold); transform: translateY(-2px); box-shadow: 0 4px 16px var(--shadow); }
.set-kaart-voltooid     { border-color: var(--jarr); background: rgba(46,122,79,0.04); }
.set-kaart-header       { display: flex; align-items: center; justify-content: space-between; }
.set-kaart-nummer       { font-size: 0.9rem; font-weight: 700; }
.set-kaart-check        { color: var(--jarr); font-weight: 700; font-size: 0.85rem; }
.set-kaart-balk-wrap    { height: 4px; background: var(--parchment-dark); border-radius: 2px; }
.set-kaart-balk         { height: 100%; border-radius: 2px; transition: width 0.4s; }
.set-kaart-meta         { font-size: 0.68rem; color: #a08060; }

/* ── Niveau-badge in actieve oefening ── */
.actief-niveau-badge {
  display: inline-block;
  font-size: 0.58rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  background: rgba(200,149,42,0.18);
  color: var(--gold-light);
  border-radius: 4px;
  padding: 0.1rem 0.45rem;
  margin-left: 0.5rem;
  vertical-align: middle;
  position: relative;
  top: -1px;
}

/* ══════════════════════════════════════════
   TF-VOORTGANG BADGE
══════════════════════════════════════════ */
.tf-voortgang {
  font-size: 0.74rem; color: #c8b080;
  margin-bottom: 0.9rem; line-height: 1.5;
  display: flex; align-items: center; gap: 0.4rem; flex-wrap: wrap;
}
.tf-vg-label  { opacity: 0.85; }
.tf-vg-ar     { font-family: 'Amiri', serif; font-size: 0.88rem; direction: rtl; color: var(--gold-light); }
.tf-vg-sep    { opacity: 0.5; }
.tf-vg-check  { color: #7abf80; font-size: 0.72rem; }

/* ══════════════════════════════════════════
   ANIMATIES — CORRECT ANTWOORD
══════════════════════════════════════════ */
@keyframes correctBounce {
  0%   { transform: scale(1); }
  35%  { transform: scale(1.05); }
  70%  { transform: scale(0.98); }
  100% { transform: scale(1); }
}

@keyframes perfectGloed {
  0%, 100% { box-shadow: 0 0 0 rgba(200,149,42,0); }
  50%       { box-shadow: 0 0 32px rgba(200,149,42,0.6); }
}

.optie-btn.correct    { animation: correctBounce 0.35s ease; }
.tashkeel-btn.correct { animation: correctBounce 0.35s ease; }

.res-perfect .res-score-kop { animation: perfectGloed 1.6s ease 0.2s; }

/* ══════════════════════════════════════════
   DONKER THEMA
══════════════════════════════════════════ */
:root[data-thema="donker"] {
  --ink:            #e8dcc8;
  --parchment:      #18140f;
  --parchment-dark: #2e261e;
  --shadow:         rgba(0,0,0,0.45);
}

/* Vaste donkere achtergronden die 'background: var(--ink)' gebruiken — moeten donker blijven */
[data-thema="donker"] .header            { background: #18140f; border-bottom: 1px solid #2e261e; }
[data-thema="donker"] .home-hero         { background: #18140f; }
[data-thema="donker"] .home-cta-tashkeel,
[data-thema="donker"] .home-cta-tashkeel:hover { background: #1a1209; }
[data-thema="donker"] .tashkeel-featured,
[data-thema="donker"] .tashkeel-featured:hover { background: #1a1209; }
[data-thema="donker"] .paneel-header     { background: #2e261e; }
[data-thema="donker"] .auth-submit-btn   { background: #2e261e; }
[data-thema="donker"] .auth-submit-btn:hover { background: #3a3028; }
[data-thema="donker"] .volgende-btn      { background: #2e261e; }
[data-thema="donker"] .volgende-btn:hover { background: #3a3028; }
[data-thema="donker"] .sessie-opnieuw-btn { background: #2e261e; }
[data-thema="donker"] .sessie-opnieuw-btn:hover { background: #3a3028; }
[data-thema="donker"] .tf-start          { color: #1a1209; }
[data-thema="donker"] .proef-aanmeld-btn { color: #fff; }

/* Cat-tab actief: gebruik goud ipv ink */
[data-thema="donker"] .cat-tab.actief    { background: var(--gold); color: #1a1209; border-color: var(--gold); }
[data-thema="donker"] .bieb-view-btn.actief { background: var(--gold); color: #1a1209; border-color: var(--gold); }

/* Alle witte kaarten → donker oppervlak */
[data-thema="donker"] .home-doel,
[data-thema="donker"] .home-stat-kaart,
[data-thema="donker"] .home-sec-btn,
[data-thema="donker"] .actie-btn,
[data-thema="donker"] .bieb-detail,
[data-thema="donker"] .woord-kaart,
[data-thema="donker"] .uitleg-paneel,
[data-thema="donker"] .prog-totaal-kaart,
[data-thema="donker"] .prog-modus-kaart,
[data-thema="donker"] .prog-sessie-rij,
[data-thema="donker"] .vg-rij,
[data-thema="donker"] .extra-mode-btn,
[data-thema="donker"] .oefen-stop-btn,
[data-thema="donker"] .vraag-kaart,
[data-thema="donker"] .cat-tab,
[data-thema="donker"] .bieb-view-btn,
[data-thema="donker"] .woord-kaartje,
[data-thema="donker"] .bieb-kaart,
[data-thema="donker"] .sit-regels-sectie,
[data-thema="donker"] .sit-voorbeelden-sectie,
[data-thema="donker"] .auth-modal { background: #221c15; border-color: #2e261e; }

/* Inputs en zoekbalken */
[data-thema="donker"] .auth-veld input,
[data-thema="donker"] .bieb-zoek,
[data-thema="donker"] .bieb-select {
  background: #2a2218; border-color: #3a2e22; color: #e8dcc8;
}

/* Trigger-cel en reden-blok */
[data-thema="donker"] .trigger-cel,
[data-thema="donker"] .reden-blok { background: #2a2218; border-color: rgba(200,149,42,0.2); }

/* Hover-states (waren #fffbf3) */
[data-thema="donker"] .home-sec-btn:hover,
[data-thema="donker"] .actie-btn:hover,
[data-thema="donker"] .prog-sessie-rij:hover,
[data-thema="donker"] .extra-mode-btn:hover,
[data-thema="donker"] .cat-tab:hover,
[data-thema="donker"] .bieb-view-btn:hover,
[data-thema="donker"] .res-bieb-btn:hover { background: #2e261e; }

/* Actieve / geselecteerde kaarten */
[data-thema="donker"] .woord-kaart.actief,
[data-thema="donker"] .bieb-kaart.geselecteerd { background: #2a3020; border-color: var(--jarr); }

/* Extra mode slot — niet hoverable */
[data-thema="donker"] .extra-mode-slot,
[data-thema="donker"] .extra-mode-slot:hover { background: #221c15 !important; border-color: #2e261e !important; }

/* Kleurtekst die donker moet blijven in donker thema */
[data-thema="donker"] .home-doel-tekst { color: #c8b898; }
[data-thema="donker"] .home-doel-ar    { color: #7a6a50; }
[data-thema="donker"] .sit-vb-bet,
[data-thema="donker"] .sit-vb-reden,
[data-thema="donker"] .sit-vb-functie  { color: #a09070; }
[data-thema="donker"] .prog-modus-cijfers { color: #9a8a70; }

/* Thema-toggle kleur in donker thema */
[data-thema="donker"] .thema-toggle { color: #8a7a60; }

/* Nieuwe oefenen-schermen */
[data-thema="donker"] .oefen-modus-kaart:not(.oefen-modus-primair),
[data-thema="donker"] .oefen-terug-btn,
[data-thema="donker"] .niveau-kaart,
[data-thema="donker"] .set-kaart { background: #221c15; border-color: #2e261e; }

[data-thema="donker"] .oefen-modus-primair,
[data-thema="donker"] .oefen-modus-primair:hover { background: #1a1209; border-color: #1a1209; }

[data-thema="donker"] .oefen-modus-kaart:not(.oefen-modus-primair):hover,
[data-thema="donker"] .oefen-terug-btn:hover,
[data-thema="donker"] .niveau-kaart:hover,
[data-thema="donker"] .set-kaart:hover { background: #2e261e; }

[data-thema="donker"] .set-kaart-voltooid { background: rgba(46,122,79,0.08); border-color: var(--jarr); }

[data-thema="donker"] .prog-set-kaart { background: #221c15; border-color: #2e261e; }
[data-thema="donker"] .prog-set-voltooid { background: rgba(46,122,79,0.08); border-color: var(--jarr); }
[data-thema="donker"] .prog-set-bezig { border-color: rgba(200,149,42,0.3); }
[data-thema="donker"] .prog-oefen-btn:not(.prog-oefen-bet) { background: #2e261e; }
[data-thema="donker"] .prog-oefen-btn:not(.prog-oefen-bet):hover { background: #3a3028; }
[data-thema="donker"] .prog-zin-rij { border-color: #2e261e; }
[data-thema="donker"] .prog-sessie-rij:hover { background: #2e261e; }

/* ══════════════════════════════════════════
   WELKOM MODAL — TAALKEUZR
══════════════════════════════════════════ */

.welkom-overlay {
  position: fixed;
  inset: 0;
  background: rgba(20, 14, 6, 0.96);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9000;
  backdrop-filter: blur(6px);
}

.welkom-card {
  background: #1a1209;
  border: 1px solid rgba(200,149,42,0.3);
  border-radius: 20px;
  padding: 2.75rem 2rem 2.25rem;
  max-width: 420px;
  width: 90%;
  text-align: center;
}

.welkom-logo-ar {
  font-family: 'Amiri', Georgia, serif;
  font-size: 3.5rem;
  color: #c8952a;
  margin-bottom: .2rem;
  line-height: 1;
}

.welkom-logo-sub {
  font-size: .65rem;
  letter-spacing: 5px;
  color: #c8952a;
  opacity: .55;
  margin-bottom: 1.75rem;
}

.welkom-vraag {
  font-family: 'Spectral', Georgia, serif;
  font-size: 1rem;
  color: #d4c4a0;
  margin-bottom: 1.5rem;
}

.welkom-talen {
  display: flex;
  gap: .85rem;
}

.welkom-taal {
  flex: 1;
  background: rgba(200,149,42,0.07);
  border: 1.5px solid rgba(200,149,42,0.18);
  border-radius: 14px;
  padding: 1.25rem .75rem;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .35rem;
  transition: background .18s, border-color .18s, transform .15s;
}

.welkom-taal:hover {
  background: rgba(200,149,42,0.18);
  border-color: #c8952a;
  transform: translateY(-2px);
}

.wt-vlag  { font-size: 2rem; }
.wt-naam  { font-size: 1.05rem; font-weight: 600; color: #f5efe2; }
.wt-sub   { font-size: .72rem; color: #a89068; }

/* ══════════════════════════════════════════
   LANDING PAGE — NIET INGELOGD
══════════════════════════════════════════ */

#home-landing { width: 100%; }

/* ── Landing preview window ────────────────────────────────── */
.land-preview {
  margin: 0 0 1.25rem;
  border-radius: 12px;
  border: 1px solid rgba(200,149,42,0.25);
  box-shadow: 0 6px 32px rgba(0,0,0,0.13);
  background: var(--card);
  width: 100%;
  overflow: hidden;
}
.land-preview-bar {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  background: rgba(0,0,0,0.06);
  border-bottom: 1px solid rgba(0,0,0,0.07);
}
.land-preview-dot { width: 8px; height: 8px; border-radius: 50%; }
.land-preview-dot:nth-child(1) { background: #ff5f57; }
.land-preview-dot:nth-child(2) { background: #febc2e; }
.land-preview-dot:nth-child(3) { background: #28c840; }
.land-preview-title {
  flex: 1; text-align: center; font-size: 0.68rem; opacity: 0.45; font-weight: 500;
}
.land-preview-body {
  padding: 20px 22px;
}
.land-preview-slide {
  display: none;
}
.land-preview-slide.actief { display: block; animation: lpFadeIn 0.4s ease; }
@keyframes lpFadeIn { from { opacity: 0; } to { opacity: 1; } }
.land-preview-dots {
  display: flex; justify-content: center; gap: 6px; padding: 8px 0 12px;
}
.land-preview-dot-nav {
  width: 6px; height: 6px; border-radius: 50%;
  background: rgba(200,149,42,0.25); transition: background 0.3s;
}
.land-preview-dot-nav.actief { background: var(--gold); }
[data-thema="donker"] .land-preview { background: #1c1810; }
[data-thema="donker"] .land-preview-bar { background: rgba(255,255,255,0.04); }

.land-concept {
  text-align: center;
  padding: 0.75rem 1.25rem 0.5rem;
  max-width: 600px;
  margin: 0 auto;
}

.land-concept-titel {
  font-family: 'Spectral', Georgia, serif;
  font-size: 1.55rem;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: .45rem;
  line-height: 1.3;
}

.land-concept-tekst {
  font-size: .92rem;
  color: #6b5a3a;
  line-height: 1.65;
}

.land-features {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .6rem;
  padding: 0.4rem 1.25rem 0.75rem;
  max-width: 680px;
  margin: 0 auto;
}

/* CTA buttons row directly below concept — always visible above the fold */
.land-cta-rij {
  display: flex;
  gap: .6rem;
  justify-content: center;
  flex-wrap: wrap;
  padding: 0.1rem 1.25rem 0.85rem;
  max-width: 480px;
  margin: 0 auto;
}

@media (max-width: 520px) {
  /* Normalize horizontal padding — home-inhoud already has 1.5rem on each side */
  .land-concept { padding: 0.5rem 0 0.3rem; }
  .land-concept-titel { font-size: 1.3rem; }
  .land-concept-tekst { font-size: .83rem; }
  .land-cta-rij { padding: 0.1rem 0 0.75rem; }
  .land-aanmeld-btn-primary, .land-aanmeld-btn-secondary { flex: 1 1 140px; }
  /* Keep 3-column grid on mobile — just tighter */
  .land-features { gap: .35rem; padding: 0.3rem 0 0.65rem; }
  .land-feat-kaart { padding: 0.6rem 0.55rem; }
  .land-feat-icon-svg { width: 1.1rem; height: 1.1rem; margin: 0 auto .2rem; }
  .land-feat-naam { font-size: .78rem; margin-bottom: .2rem; }
  .land-feat-beschr { font-size: .67rem; line-height: 1.4; }
}

.land-feat-kaart {
  background: rgba(200,149,42,0.05);
  border: 1px solid var(--parchment-dark);
  border-radius: 12px;
  padding: 0.75rem 1rem;
  text-align: center;
}

.land-feat-icon  { font-size: 1.75rem; margin-bottom: .5rem; }
.land-feat-icon-svg { width: 1.75rem; height: 1.75rem; color: var(--gold); margin: 0 auto .5rem; display: block; stroke-width: 1.5; }
.land-feat-naam  { font-weight: 600; font-size: .9rem; margin-bottom: .35rem; color: var(--ink); }
.land-feat-beschr { font-size: .78rem; color: #7a6a4a; line-height: 1.5; }

.land-probeer {
  text-align: center;
  background: linear-gradient(140deg, #1a1209 0%, #2d1f0e 100%);
  color: #f5efe2;
  padding: 1.25rem 1.5rem calc(1.25rem + env(safe-area-inset-bottom, 0px));
  margin: 0 1.25rem 0.5rem;
  border-radius: 16px;
}

.land-probeer-ar {
  font-family: 'Amiri', Georgia, serif;
  font-size: 2rem;
  color: #c8952a;
  margin-bottom: .15rem;
  line-height: 1;
}

.land-probeer-titel {
  font-family: 'Spectral', Georgia, serif;
  font-size: 1.2rem;
  margin-bottom: .3rem;
  font-weight: 600;
}

.land-probeer-beschr {
  color: #a89068;
  font-size: .85rem;
  margin-bottom: 0.75rem;
  line-height: 1.5;
}

.land-probeer-btn {
  background: #c8952a;
  color: #1a1209;
  border: none;
  border-radius: 9px;
  padding: .85rem 2.25rem;
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
  transition: background .18s, transform .15s;
  font-family: inherit;
}

.land-probeer-btn:hover { background: #e8bc5a; transform: translateY(-1px); }

.land-aanmeld {
  text-align: center;
  padding: 1rem 1.5rem 1.25rem;
  max-width: 480px;
  margin: 0 auto;
}

.land-aanmeld-titel {
  font-family: 'Spectral', Georgia, serif;
  font-size: 1.1rem;
  margin-bottom: .3rem;
  font-weight: 600;
}

.land-aanmeld-beschr {
  color: #6b5a3a;
  font-size: .85rem;
  margin-bottom: 0.85rem;
  line-height: 1.55;
}

.land-aanmeld-knoppen {
  display: flex;
  gap: .75rem;
  justify-content: center;
  flex-wrap: wrap;
}

.land-aanmeld-btn-primary {
  background: #c8952a;
  color: #1a1209;
  border: none;
  border-radius: 8px;
  padding: .7rem 1.5rem;
  font-size: .9rem;
  font-weight: 600;
  cursor: pointer;
  transition: background .18s;
  font-family: inherit;
}

.land-aanmeld-btn-primary:hover { background: #e8bc5a; }

.land-aanmeld-btn-secondary {
  background: transparent;
  color: var(--ink);
  border: 1.5px solid rgba(200,149,42,0.35);
  border-radius: 8px;
  padding: .7rem 1.5rem;
  font-size: .9rem;
  cursor: pointer;
  transition: border-color .18s;
  font-family: inherit;
}

.land-aanmeld-btn-secondary:hover { border-color: #c8952a; }

/* Dark theme */
[data-thema="donker"] .land-feat-kaart    { background: rgba(200,149,42,0.07); border-color: #2e261e; }
[data-thema="donker"] .land-feat-beschr   { color: #a89068; }
[data-thema="donker"] .land-concept-tekst { color: #a89068; }
[data-thema="donker"] .land-aanmeld-beschr { color: #a89068; }
[data-thema="donker"] .land-aanmeld-btn-secondary { color: #f5efe2; }

/* ══════════════════════════════════════════
   LEZEN — READING EXERCISE
══════════════════════════════════════════ */

.lezen-kaart { padding: 0; }

.lezen-kop {
  display: flex;
  align-items: center;
  gap: .5rem;
  padding: 1rem 1.25rem .75rem;
  border-bottom: 1px solid var(--parchment-dark);
}

.lezen-titel {
  font-weight: 600;
  font-size: .95rem;
  color: var(--ink);
}

.lezen-tekst {
  font-family: 'Amiri', serif;
  font-size: 1.35rem;
  line-height: 2.2;
  padding: .75rem 1.25rem;
  background: rgba(200,149,42,0.04);
  border-bottom: 1px solid var(--parchment-dark);
  word-spacing: .15em;
}


.lezen-hl {
  background: rgba(200,149,42,0.35);
  border-radius: 3px;
  padding: 0 .15em;
  font-weight: 700;
  color: var(--ink);
  text-decoration: none;
}

.lezen-vertaling {
  font-size: .82rem;
  color: #6b5a3a;
  padding: .6rem 1.25rem .8rem;
  font-style: italic;
  border-bottom: 1px solid var(--parchment-dark);
  line-height: 1.5;
}

.lezen-zin {
  display: block;
  padding: .3rem 0;
  line-height: 2;
}

.lezen-kaart .opties-grid {
  max-width: 520px;
  margin-left: auto;
  margin-right: auto;
}

.lezen-voortgang {
  text-align: center;
  font-size: .75rem;
  color: #8a7a60;
  padding: .5rem 0 .15rem;
  letter-spacing: .04em;
}

.lezen-uitleg {
  font-size: .82rem;
  color: #4a3a1e;
  background: rgba(200,149,42,0.07);
  border-left: 3px solid var(--gold);
  border-radius: 0 4px 4px 0;
  padding: .55rem .8rem;
  margin-top: .6rem;
  line-height: 1.55;
  font-style: italic;
}

.lezen-res-titel {
  font-size: 1.05rem;
  font-weight: 600;
  text-align: center;
  margin: .5rem 0 .25rem;
  font-family: 'Amiri', serif;
}

.lezen-res-tekst {
  font-family: 'Amiri', serif;
  font-size: 1.15rem;
  line-height: 2;
  text-align: right;
  padding: .75rem 1rem;
  background: rgba(200,149,42,0.04);
  border-radius: 6px;
  margin: .5rem 0 1rem;
  color: var(--ink);
}

/* ── Dark theme ─────────────────────────────────────────────── */
[data-thema="donker"] .lezen-tekst      { background: rgba(200,149,42,0.06); }
[data-thema="donker"] .lezen-vertaling  { color: #a89878; }
[data-thema="donker"] .lezen-uitleg     { background: rgba(200,149,42,0.1); color: #d4b97a; }
[data-thema="donker"] .lezen-res-tekst  { background: rgba(200,149,42,0.06); color: #e8d9b8; }
[data-thema="donker"] .lezen-hl         { background: rgba(200,149,42,0.45); color: #f5efe2; }


/* ══════════════════════════════════════════
   LEERPAD — KAARTGRID (6 progressieve stijlen)
══════════════════════════════════════════ */

#leerpad-sectie { padding: 0.25rem 0 0.5rem; }

/* Leerpad / Vrij oefenen tab toggle */
.oefen-tabs-rij {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 1.25rem;
  flex-wrap: wrap;
  justify-content: center;
}
.oefen-tab-btn {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.5rem 1.1rem;
  border: 1.5px solid var(--parchment-dark);
  border-radius: 10px;
  background: transparent;
  color: #8a7a60;
  font-family: inherit;
  font-size: 0.85rem;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.18s, border-color 0.18s, color 0.18s;
}
.oefen-tab-btn.actief {
  background: var(--gold);
  color: var(--ink);
  border-color: var(--gold);
  font-weight: 700;
}
.oefen-tab-btn:not(.actief):hover { border-color: var(--gold); color: var(--ink); }
.oefen-tab-btn [data-lucide] { width: 0.9rem; height: 0.9rem; flex-shrink: 0; }

[data-thema="donker"] .oefen-tab-btn { border-color: #2e261e; color: #8a7a60; }
[data-thema="donker"] .oefen-tab-btn:not(.actief):hover { border-color: var(--gold); color: #f5efe2; }

/* Kop */
.lp-kop {
  margin: 0 auto 0.75rem;
  background: rgba(255, 255, 255, 0.96);
  border: 1.5px solid var(--parchment-dark);
  border-radius: 12px;
  padding: 0.75rem 1rem;
  box-shadow: 0 2px 14px rgba(160, 120, 60, 0.13);
  display: block;
  max-width: 36rem;
  width: fit-content;
}
.lp-kop-titel  { font-size: 1.05rem; font-weight: 600; color: var(--ink); }
.lp-kop-beschr { font-size: 0.78rem; color: #8a7a60; font-style: italic; margin: 0.15rem 0 0.2rem; line-height: 1.4; }

[data-thema="donker"] .lp-kop { background: rgba(22, 16, 8, 0.88); border-color: #2e261e; }

/* Status badge (vervangt ring) */
.lp-status-badge {
  display: inline-flex; align-items: center; gap: 0.3rem;
  font-size: 0.72rem; color: #8a7a60; margin-top: 0.1rem;
}
.lp-status-vol { color: var(--gold); font-weight: 600; }
.lp-status-badge [data-lucide] { width: 0.75rem; height: 0.75rem; }

/* ── Nav-strip (6 gekleurde segmenten) ── */
.lp-nav-strip {
  display: flex;
  gap: 0.4rem;
  margin-bottom: 0.8rem;
}

.lp-nav-item {
  flex: 1;
  height: 3.6rem;
  border-radius: 10px;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 0.1rem;
  cursor: pointer;
  opacity: 0.38;
  transition: transform 0.15s, box-shadow 0.15s, opacity 0.15s;
  padding: 0.25rem 0.15rem;
}
.lp-nav-item.lp-nav-gehaald { opacity: 1; }
.lp-nav-item.lp-nav-actief  { opacity: 1; box-shadow: 0 0 0 2.5px var(--gold), 0 4px 14px rgba(200,149,42,0.35) !important; }
.lp-nav-item:hover           { transform: translateY(-2px); opacity: 1; }

.lp-nav-nr    { font-size: 0.55rem; font-weight: 700; letter-spacing: 0.08em; color: var(--gold); line-height: 1; }
.lp-nav-icon  { width: 0.68rem; height: 0.68rem; stroke-width: 2.5; color: var(--gold); display: block; }
.lp-nav-label { font-size: 0.46rem; font-weight: 600; color: var(--gold); line-height: 1.15; text-align: center; letter-spacing: 0.02em; margin-top: 0.05rem; word-break: break-word; }

/* Lichte nav-items: donkerdere goudtint */
.lp-nav-item.lp-s1 .lp-nav-nr,
.lp-nav-item.lp-s2 .lp-nav-nr    { color: #9a6e18; }
.lp-nav-item.lp-s1 .lp-nav-icon,
.lp-nav-item.lp-s2 .lp-nav-icon  { color: #9a6e18; }
.lp-nav-item.lp-s1 .lp-nav-label,
.lp-nav-item.lp-s2 .lp-nav-label { color: #9a6e18; }

/* Horizontale kaartengallerij */
.lp-kaarten-rij {
  display: flex;
  gap: 0.75rem;
  overflow-x: auto;
  scrollbar-width: none;
  padding: 0.5rem 0.25rem 1.25rem;
}
.lp-kaarten-rij::-webkit-scrollbar { display: none; }

/* Basiskaart — flex-1 zodat ze gelijk de ruimte verdelen maar nooit smaller dan 210px */
.lp-kaart {
  flex: 1 1 210px;
  min-width: 210px;
  border-radius: 16px;
  padding: 1.3rem 1.25rem 1.1rem;
  display: flex; flex-direction: column; gap: 0.3rem;
  cursor: pointer; position: relative;
  box-shadow: 0 2px 10px var(--shadow);
  transition: transform 0.18s, box-shadow 0.18s;
}
.lp-kaart:hover { transform: translateY(-4px); }

/* ── 6 kaart-stijlen (geen lichtgroen — altijd goud tekst) ── */

/* Level 1 — Wit, minimaal */
.lp-s1 {
  background: white;
  border: 1.5px solid var(--parchment-dark);
  box-shadow: 0 3px 14px var(--shadow);
}
.lp-s1:hover { box-shadow: 0 8px 24px var(--shadow); border-color: var(--gold); }

/* Level 2 — Warme crème (anders dan wit, geen groen) */
.lp-s2 {
  background: #f7ede0;
  border: 1.5px solid #e0c8a8;
  box-shadow: 0 3px 14px rgba(180,120,60,0.12);
}
.lp-s2:hover { box-shadow: 0 8px 24px rgba(180,120,60,0.22); border-color: var(--gold); }

/* Level 3 — Donker groen (eerste grote sprong in moeilijkheid) */
.lp-s3 {
  background: linear-gradient(150deg, #1f3a1c 0%, #162814 100%);
  border: 1.5px solid rgba(120,200,140,0.2);
  box-shadow: 0 4px 18px rgba(20,60,24,0.35);
}
.lp-s3:hover { box-shadow: 0 10px 28px rgba(20,60,24,0.5); border-color: rgba(120,200,140,0.4); }

/* Level 4 — Donker antraciet (mijlpaal — zware stap) */
.lp-s4 {
  background: linear-gradient(150deg, #18140e 0%, #221c14 100%);
  border: 2px solid rgba(200,149,42,0.3);
  box-shadow: 0 4px 18px rgba(10,8,4,0.4);
}
.lp-s4:hover { box-shadow: 0 10px 28px rgba(10,8,4,0.55); border-color: rgba(200,149,42,0.55); }

/* Level 5 — Donker groen/goud blend */
.lp-s5 {
  background: linear-gradient(150deg, #1e2a1a 0%, #2a3820 100%);
  border: 1.5px solid rgba(200,149,42,0.38);
  box-shadow: 0 5px 20px rgba(20,30,16,0.4);
}
.lp-s5:hover { box-shadow: 0 10px 30px rgba(20,30,16,0.55); border-color: var(--gold); }

/* Level 6 — Inkt/goud (rijkste, meest elaborate) */
.lp-s6 {
  background: linear-gradient(150deg, #1a1209 0%, #231808 100%);
  border: 2px solid rgba(200,149,42,0.6);
  box-shadow: 0 6px 24px rgba(26,18,9,0.45);
}
.lp-s6:hover { box-shadow: 0 12px 36px rgba(26,18,9,0.6); border-color: var(--gold-light); }

/* ── Kaart tekst (altijd goud, passend per achtergrond) ── */
.lp-kaart-nr    { font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.12em; color: var(--gold); opacity: 0.7; }
.lp-kaart-ar    {
  font-family: 'Amiri', serif;
  font-size: 1.35rem;
  direction: rtl;
  text-align: center;
  color: var(--gold);
  line-height: 1.7;
  margin: 0.5rem 0 0.6rem;
  padding-bottom: 0.6rem;
  border-bottom: 1px solid rgba(200,149,42,0.22);
}
.lp-kaart-titel { font-size: 0.92rem; font-weight: 700; color: var(--gold); line-height: 1.3; }
.lp-kaart-beschr{ font-size: 0.74rem; line-height: 1.55; flex: 1; margin-top: 0.2rem; }

/* Beschrijving tekstkleur per achtergrond */
.lp-s1 .lp-kaart-beschr, .lp-s2 .lp-kaart-beschr { color: #7a6040; }
.lp-s3 .lp-kaart-beschr, .lp-s4 .lp-kaart-beschr,
.lp-s5 .lp-kaart-beschr, .lp-s6 .lp-kaart-beschr { color: #a89068; }

/* Op lichte kaarten: goud kan iets donkerder voor contrast */
.lp-s1 .lp-kaart-titel, .lp-s2 .lp-kaart-titel { color: #9a6e18; }
.lp-s1 .lp-kaart-ar,    .lp-s2 .lp-kaart-ar    { color: #b88020; }

/* Actiebadge rechtsonder */
.lp-actie-label  { font-size: 0.75rem; font-weight: 700; color: var(--gold); margin-top: 0.5rem; }
.lp-actie-replay { font-size: 0.68rem; color: #8a7a60; margin-top: 0.4rem; }
.lp-s3 .lp-actie-replay, .lp-s4 .lp-actie-replay,
.lp-s5 .lp-actie-replay, .lp-s6 .lp-actie-replay { color: #7a6848; }

/* Hoekbadge (✓ / 🔒) */
.lp-hoek-badge {
  position: absolute; top: 0.7rem; right: 0.7rem;
  width: 1.4rem; height: 1.4rem; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: rgba(200,149,42,0.18); color: var(--gold);
}
.lp-hoek-badge [data-lucide] { width: 0.8rem; height: 0.8rem; stroke-width: 2.5; }
.lp-hoek-lock { background: rgba(0,0,0,0.12); color: #a09070; }
.lp-s3 .lp-hoek-badge, .lp-s4 .lp-hoek-badge,
.lp-s5 .lp-hoek-badge, .lp-s6 .lp-hoek-badge { background: rgba(200,149,42,0.2); }

/* ── Status modifiers ── */
.lp-actief { box-shadow: 0 0 0 2.5px var(--gold), 0 8px 28px rgba(200,149,42,0.25) !important; }
.lp-zacht  { cursor: default; }

/* Dark theme */
[data-thema="donker"] .lp-s1 { background: #2a2218; border-color: #3a2e22; }
[data-thema="donker"] .lp-s2 { background: #2e2415; border-color: #3a2e1e; }
[data-thema="donker"] .lp-s1 .lp-kaart-beschr,
[data-thema="donker"] .lp-s2 .lp-kaart-beschr { color: #a89068; }
[data-thema="donker"] .lp-s1 .lp-kaart-titel,
[data-thema="donker"] .lp-s2 .lp-kaart-titel { color: var(--gold); }
[data-thema="donker"] .lp-nav-item.lp-s1 { background: #2a2218; border-color: #3a2e22; }

/* ══════════════════════════════════════════
   أَقْسَامُ الكَلَام — WOORDSOORTEN MODULE
══════════════════════════════════════════ */

/* Mode card in oefenen */
.oefen-modus-aqsam {
  background: linear-gradient(135deg, #1e2a1a 0%, #2a3820 100%);
  color: var(--gold-light);
  border: 1.5px solid rgba(200,149,42,0.3);
}
.oefen-modus-aqsam .omk-ar   { color: var(--gold); }
.oefen-modus-aqsam .omk-titel { color: var(--gold-light); }
.oefen-modus-aqsam .omk-beschr { color: #a89868; }
.oefen-modus-aqsam .omk-start  { color: var(--gold); }
.oefen-modus-aqsam:hover { background: linear-gradient(135deg, #253320 0%, #334825 100%); transform: translateY(-3px); }

[data-thema="donker"] .oefen-modus-aqsam { background: linear-gradient(135deg, #141a10 0%, #1a2214 100%); }

/* Sub-oefening keuze grid */
.ws-type-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
  padding: 0.5rem 0;
}

.ws-type-kaart {
  background: white; border: 1.5px solid var(--parchment-dark);
  border-radius: 14px; padding: 1.25rem 1.25rem 1rem;
  cursor: pointer; transition: all 0.18s;
  box-shadow: 0 2px 10px var(--shadow);
}
.ws-type-kaart:hover { border-color: var(--gold); transform: translateY(-2px); box-shadow: 0 6px 20px var(--shadow); }

.wstk-ar    { font-family: 'Amiri', serif; font-size: 1.3rem; color: var(--gold); direction: rtl; margin-bottom: 0.4rem; line-height: 1.4; }
.wstk-titel { font-size: 0.95rem; font-weight: 600; color: var(--ink); margin-bottom: 0.3rem; }
.wstk-beschr{ font-size: 0.8rem; color: #6a5a40; line-height: 1.55; }

[data-thema="donker"] .ws-type-kaart { background: #221c15; border-color: #2e261e; }
[data-thema="donker"] .ws-type-kaart:hover { border-color: var(--gold); }
[data-thema="donker"] .wstk-beschr { color: #a89068; }

/* Highlight in zin */
.ws-hl {
  background: rgba(200,149,42,0.22);
  border-radius: 3px;
  padding: 0 2px;
  font-weight: 700;
}
[data-thema="donker"] .ws-hl { background: rgba(200,149,42,0.35); }

/* Functie-context blok (geval-oefening) */
.ws-functie-context {
  font-size: 0.82rem; color: #6a5a40; text-align: center;
  font-style: italic; margin-bottom: 0.75rem;
  padding: 0.4rem 0.75rem;
  background: var(--parchment); border-radius: 6px;
}
[data-thema="donker"] .ws-functie-context { background: #2a2218; color: #a89068; }

@media (max-width: 640px) {
  .ws-type-grid { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════
   HOME — CONTACT TEASER
══════════════════════════════════════════ */
.home-contact-teaser {
  margin-top: 1.25rem; text-align: center;
  cursor: pointer; padding: 0.5rem;
  color: #8a7a60; font-size: 0.85rem;
  transition: color 0.15s;
}
.home-contact-teaser:hover { color: var(--gold); }
.hct-link { margin-left: 0.4rem; color: var(--gold); font-weight: 600; }

/* ══════════════════════════════════════════
   CONTACT PAGE
══════════════════════════════════════════ */
.contact-wrap {
  max-width: min(960px, 90vw); width: 100%; margin: 0 auto;
  padding: 1rem 1.5rem 0.75rem; position: relative; z-index: 1;
  flex: 1; overflow-y: auto; overflow-x: hidden;
  scrollbar-width: none; display: flex; flex-direction: column; justify-content: center;
}
.contact-wrap::-webkit-scrollbar { display: none; }

.contact-kop { text-align: center; margin-bottom: 1rem; }
.contact-ar  { font-family: 'Amiri', serif; font-size: 1.9rem; color: var(--gold); direction: rtl; line-height: 1.2; margin-bottom: 0.2rem; }
.contact-titel { font-size: 1.35rem; font-weight: 600; color: var(--ink); margin-bottom: 0.35rem; }
.contact-sub { font-size: 0.85rem; color: #6a5a40; line-height: 1.6; max-width: 560px; margin: 0 auto; }

.contact-kaarten {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 0.75rem; margin-bottom: 0.85rem;
}
.contact-kaart {
  background: white; border: 1.5px solid var(--parchment-dark);
  border-radius: 14px; padding: 1rem 1.1rem;
  text-align: center; box-shadow: 0 2px 12px var(--shadow);
  transition: all 0.2s;
}
.contact-kaart:hover { transform: translateY(-3px); border-color: var(--gold); box-shadow: 0 6px 24px var(--shadow); }

.ck-icon { width: 1.5rem; height: 1.5rem; color: var(--gold); margin: 0 auto 0.5rem; display: block; stroke-width: 1.5; }
.ck-titel { font-size: 0.95rem; font-weight: 600; color: var(--ink); margin-bottom: 0.35rem; }
.ck-beschr { font-size: 0.82rem; color: #6a5a40; line-height: 1.6; }

/* Fout rapport formulier */
.fout-formulier {
  background: white; border: 1.5px solid var(--parchment-dark);
  border-radius: 14px; padding: 1rem 1.25rem;
  box-shadow: 0 2px 12px var(--shadow); margin-bottom: 0.75rem;
  display: flex; flex-direction: column; gap: 0.65rem;
}

.fout-form-kop {
  display: flex; align-items: flex-start; gap: 0.85rem;
}
.fout-form-icon {
  width: 1.5rem; height: 1.5rem; color: var(--gold);
  flex-shrink: 0; margin-top: 0.15rem; stroke-width: 1.5;
}
.fout-form-titel { font-size: 1rem; font-weight: 600; color: var(--ink); margin-bottom: 0.2rem; }
.fout-form-sub   { font-size: 0.83rem; color: #6a5a40; line-height: 1.5; }

.fout-form-veld  { display: flex; flex-direction: column; gap: 0.35rem; }
.fout-form-label { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.1em; color: #8a7a60; }

.fout-form-input,
.fout-form-textarea {
  background: var(--parchment); border: 1.5px solid var(--parchment-dark);
  border-radius: 8px; padding: 0.6rem 0.85rem;
  font-family: 'Spectral', serif; font-size: 0.88rem; color: var(--ink);
  transition: border-color 0.15s; width: 100%; resize: vertical;
}
.fout-form-input:focus,
.fout-form-textarea:focus { outline: none; border-color: var(--gold); }

.fout-form-acties { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }

.fout-form-btn {
  display: inline-flex; align-items: center; gap: 0.5rem;
  background: var(--ink); color: var(--gold-light);
  border: none; border-radius: 8px; padding: 0.6rem 1.25rem;
  font-family: 'Spectral', serif; font-size: 0.88rem; font-weight: 600;
  cursor: pointer; transition: all 0.2s;
}
.fout-form-btn:hover { background: #2a1400; }
.fout-form-btn [data-lucide] { width: 14px; height: 14px; }

.fout-form-bevestiging {
  font-size: 0.82rem; color: var(--jarr); font-style: italic;
}

[data-thema="donker"] .fout-formulier { background: #221c15; border-color: #2e261e; }
[data-thema="donker"] .fout-form-input,
[data-thema="donker"] .fout-form-textarea { background: #2a2218; border-color: #3a2e22; color: #e8dcc8; }

.contact-cta { text-align: center; padding: 0.5rem 1.5rem 0; }
.contact-cta-label { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.14em; color: #8a7a60; margin-bottom: 0.6rem; }
.contact-email-btn {
  display: inline-block; background: var(--ink); color: var(--gold-light);
  font-family: 'Spectral', serif; font-size: 1.1rem; font-weight: 600;
  padding: 0.9rem 2.5rem; border-radius: 12px; text-decoration: none;
  transition: all 0.2s; box-shadow: 0 4px 20px rgba(26,18,9,0.2);
  letter-spacing: 0.01em;
}
.contact-email-btn:hover { background: #2a1400; transform: translateY(-2px); box-shadow: 0 8px 28px rgba(26,18,9,0.3); color: var(--gold-light); }
.contact-respons { margin-top: 0.6rem; font-size: 0.8rem; color: #8a7a60; font-style: italic; }

[data-thema="donker"] .contact-kaart { background: #221c15; border-color: #2e261e; }
[data-thema="donker"] .contact-kaart:hover { border-color: var(--gold); }
[data-thema="donker"] .contact-sub,
[data-thema="donker"] .ck-beschr { color: #a89068; }

@media (max-width: 640px) {
  .contact-kaarten { grid-template-columns: 1fr; }
  .contact-ar { font-size: 2.2rem; }
  .contact-titel { font-size: 1.4rem; }
}

/* ══════════════════════════════════════════
   PREFERENCES BUTTON + POPUP
══════════════════════════════════════════ */
.pref-open-btn {
  background: none; border: none;
  color: #8a7060; cursor: pointer;
  padding: 0.35rem 0.5rem; border-radius: 6px;
  transition: color 0.15s, background 0.15s;
  display: flex; align-items: center;
}
.pref-open-btn:hover { color: var(--gold-light); background: rgba(200,149,42,0.1); }
.pref-open-btn [data-lucide] { width: 16px; height: 16px; }

.pref-popup {
  position: fixed;
  top: calc(3.5rem + 0.5rem);
  right: 1rem;
  background: var(--parchment);
  border: 1.5px solid var(--parchment-dark);
  border-radius: 14px;
  padding: 1rem 1.1rem;
  box-shadow: 0 8px 32px var(--shadow);
  z-index: 500;
  min-width: 220px;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}

.pref-kop {
  font-size: 0.75rem; text-transform: uppercase;
  letter-spacing: 0.12em; color: #8a7a60;
  font-weight: 600; margin-bottom: 0.1rem;
}

.pref-sectie { display: flex; flex-direction: column; gap: 0.4rem; }

.pref-label {
  font-size: 0.72rem; color: #8a7a60;
  text-transform: uppercase; letter-spacing: 0.1em;
}

.pref-toggle-btn {
  display: flex; align-items: center; gap: 0.5rem;
  background: var(--parchment-dark); border: 1.5px solid transparent;
  border-radius: 8px; padding: 0.45rem 0.75rem;
  font-family: 'Spectral', serif; font-size: 0.85rem;
  cursor: pointer; color: var(--ink); transition: all 0.15s;
  width: 100%; text-align: left;
}
.pref-toggle-btn:hover { border-color: var(--gold); background: #fffbf3; }
.pref-toggle-btn [data-lucide] { width: 14px; height: 14px; color: var(--gold); flex-shrink: 0; }

[data-thema="donker"] .pref-popup { background: #221c15; border-color: #2e261e; }
[data-thema="donker"] .pref-toggle-btn { background: #2e261e; color: #e8dcc8; }
[data-thema="donker"] .pref-toggle-btn:hover { background: #3a3028; border-color: var(--gold); }

/* ══════════════════════════════════════════
   UPDATE TOAST
══════════════════════════════════════════ */

/* ══════════════════════════════════════════
   PATCH NOTES MODAL
══════════════════════════════════════════ */

.patch-open-btn { position: relative; }

.patch-modal { max-width: 460px !important; padding: 1.75rem 1.75rem 1.5rem !important; max-height: 88vh; overflow-y: auto; -webkit-overflow-scrolling: touch; }

.patch-kop { text-align: center; margin-bottom: 1.25rem; }
.patch-logo { font-family: 'Amiri', serif; font-size: 1.6rem; color: var(--gold); }
.patch-versie { font-size: 0.7rem; color: #8a7a60; letter-spacing: 0.15em; text-transform: uppercase; margin-top: 2px; }

.patch-sectie { margin-bottom: 1.1rem; }
.patch-sectie-label {
  font-size: 0.65rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.12em; color: var(--gold);
  border-bottom: 1.5px solid rgba(200,149,42,0.25);
  padding-bottom: 5px; margin-bottom: 0.75rem;
}

.patch-item { display: flex; gap: 0.65rem; align-items: flex-start; margin-bottom: 0.7rem; }
.patch-dot { width: 10px; height: 10px; border-radius: 3px; flex-shrink: 0; margin-top: 4px; }
.lp-s2-bg  { background: #f7ede0; border: 1px solid #e0c8a8; }
.lp-s3-bg  { background: linear-gradient(135deg,#1f3a1c,#162814); }
.lp-s5-bg  { background: linear-gradient(135deg,#1e2a1a,#2a3820); }
.lp-s6-bg  { background: linear-gradient(135deg,#1a1209,#231808); }

.patch-item-titel  { font-size: 0.82rem; font-weight: 700; color: var(--ink); margin-bottom: 2px; }
.patch-item-beschr { font-size: 0.77rem; color: #7a6a50; line-height: 1.55; }

.patch-aankomend { font-size: 0.8rem; color: #7a6a50; line-height: 1.6; margin-bottom: 0.35rem; }
.patch-aankomend::before { content: '→ '; color: var(--gold); font-weight: 700; }

.patch-issue-sectie { background: rgba(180,100,40,0.06); border-radius: 10px; padding: 0.85rem 1rem; }
.patch-issue-label { color: #b87a4a !important; border-bottom-color: rgba(184,122,74,0.3) !important; }
.patch-issue { font-size: 0.78rem; color: #7a4a20; line-height: 1.6; }
.patch-issue strong { display: block; margin-bottom: 3px; }

[data-thema="donker"] .patch-item-beschr,
[data-thema="donker"] .patch-aankomend { color: #a89068; }
[data-thema="donker"] .patch-issue { color: #c8906a; }
[data-thema="donker"] .patch-issue-sectie { background: rgba(180,100,40,0.1); }

.update-overlay {
  position: fixed;
  inset: 0;
  background: rgba(20, 14, 6, 0.88);
  backdrop-filter: blur(6px);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
}

.update-modal {
  background: var(--parchment);
  border-radius: 20px;
  padding: 2.5rem 2.25rem 2rem;
  text-align: center;
  max-width: 420px;
  width: 90%;
  box-shadow: 0 32px 80px rgba(0,0,0,0.45);
  animation: popIn 0.3s ease;
}

.update-modal-logo {
  font-family: 'Amiri', serif;
  font-size: 2rem;
  color: var(--gold);
  margin-bottom: 1.25rem;
}

.update-modal-icoon-ring {
  width: 3.25rem; height: 3.25rem;
  background: rgba(200,149,42,0.12);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 1.25rem;
}
.update-modal-icoon-ring [data-lucide] {
  width: 1.5rem; height: 1.5rem; color: var(--gold);
}

.update-modal-titel {
  font-size: 1.4rem; font-weight: 600;
  color: var(--ink); margin-bottom: 0.65rem;
}

.update-modal-sub {
  font-size: 0.92rem; color: #6a5a40;
  line-height: 1.7; margin-bottom: 2rem;
}

.update-modal-btn {
  background: var(--gold);
  color: #1a1209;
  border: none;
  padding: 0.85rem 2rem;
  border-radius: 10px;
  font-family: inherit;
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.15s, transform 0.15s;
  width: 100%;
}
.update-modal-btn:hover { background: var(--gold-light); transform: translateY(-1px); }

[data-thema="donker"] .update-modal { background: #221c15; }
[data-thema="donker"] .update-modal-sub { color: #a89068; }

/* Grammar cards — dark theme (tint composited onto dark parchment #18140f) */
[data-thema="donker"] .raf-kleur    { background: #201710; }
[data-thema="donker"] .nasb-kleur   { background: #171a20; }
[data-thema="donker"] .jarr-kleur   { background: #171f18; }
[data-thema="donker"] .jazm-kleur   { background: #1a1720; }
[data-thema="donker"] .mabni-kleur  { background: #1c1a16; }
[data-thema="donker"] .tawabi-kleur { background: #1f1c10; }
[data-thema="donker"] .mahall-kleur { background: #171a1f; }

/* ══════════════════════════════════════════
   MOBILE EXERCISE — fit everything on screen
══════════════════════════════════════════ */
@media (max-width: 640px) {
  .oefen-wrap { justify-content: flex-start; padding: 0.75rem 0.75rem 1rem; }
  .oefen-actief-header { margin-bottom: 0.6rem; }

  /* Leerpad: één kaart tegelijk op mobiel */
  .lp-kaart { flex: 0 0 76vw; min-width: 0; }

  .vraag-kaart { padding: 1rem 1rem 0.85rem; }
  .vraag-zin-context { padding: 0.55rem 0.75rem; }
  .vraag-zin-ar { font-size: 1.2rem; line-height: 1.75; }
  .vraag-zin-nl { font-size: 0.78rem; }
  .vraag-scheiding { margin: 0.4rem 0 0.35rem; }
  .vraag-label { font-size: 0.72rem; margin-bottom: 0.35rem; }
  .vraag-woord-ar { font-size: 1.8rem; line-height: 1.4; margin-bottom: 0.1rem; }
  .vraag-context { font-size: 0.78rem; margin-bottom: 0.6rem; }
  .vraag-voortgang { margin-bottom: 0.2rem; }

  .tashkeel-opties { gap: 0.3rem; margin-top: 0.5rem; }
  .tashkeel-btn { padding: 0.45rem 0.25rem 0.35rem; }
  .tashkeel-teken { font-size: 1.45rem; padding-bottom: 0.18rem; }
  .tashkeel-ar { font-size: 0.72rem; }
  .tashkeel-nl { font-size: 0.58rem; }
  .tashkeel-sub { font-size: 0.52rem; }
}
