/* Muzische Vorming Team 3 — jaarpakket */
:root{
  --paper:#F6F7F4;
  --ink:#1E2430;
  --ink-soft:#4A5264;
  --line:#DDE1DA;
  --card:#FFFFFF;
  --muziek:#E39A17;
  --beeld:#D95440;
  --drama:#8A4FBF;
  --dans:#E0568D;
  --media:#3E8FD8;
  --kunst:#2F9E77;
  --integratie:#4A5BD0;
  --reserve:#9AA3AF;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);font-family:"Public Sans",system-ui,sans-serif;font-size:16px;line-height:1.6}
h1,h2,h3,.display{font-family:"Bricolage Grotesque","Public Sans",sans-serif}
code,.code,.chip{font-family:"IBM Plex Mono",monospace}

/* header */
header.site{background:var(--ink);color:#fff;padding:0}
.nav{max-width:1100px;margin:0 auto;display:flex;flex-wrap:wrap;align-items:center;gap:.25rem;padding:.6rem 1.25rem}
.nav .brand{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:1.05rem;margin-right:auto;color:#fff;text-decoration:none;letter-spacing:.02em}
.nav a{color:#E7EAF1;text-decoration:none;font-size:.85rem;padding:.35rem .6rem;border-radius:.4rem}
.nav a:hover,.nav a:focus-visible{background:rgba(255,255,255,.14);outline:none}
.nav a.actief{background:rgba(255,255,255,.22);font-weight:600}

/* hero */
.hero{max-width:1100px;margin:0 auto;padding:3rem 1.25rem 1.5rem}
.hero h1{font-size:clamp(2rem,5vw,3.4rem);line-height:1.05;margin:0 0 .75rem;font-weight:800}
.hero p.lead{max-width:46rem;color:var(--ink-soft);font-size:1.05rem;margin:0}
.eyebrow{font-family:"IBM Plex Mono",monospace;font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:.75rem}
.hero .eyebrow{display:block}

/* jaarlijn (signature) */
.jaarlijn{display:flex;gap:3px;max-width:1100px;margin:1.75rem auto 0;padding:0 1.25rem;height:46px}
.jaarlijn a{flex:1;border-radius:4px;position:relative;min-width:8px}
.jaarlijn a:hover::after,.jaarlijn a:focus-visible::after{content:attr(data-tip);position:absolute;bottom:110%;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;font-size:.7rem;font-family:"IBM Plex Mono",monospace;padding:.3rem .5rem;border-radius:.3rem;white-space:nowrap;z-index:5}
.legende{max-width:1100px;margin:.75rem auto 0;padding:0 1.25rem;display:flex;flex-wrap:wrap;gap:.75rem;font-size:.78rem;color:var(--ink-soft)}
.legende span{display:inline-flex;align-items:center;gap:.35rem}
.legende i{width:.8rem;height:.8rem;border-radius:3px;display:inline-block}

/* sections */
main{max-width:1100px;margin:0 auto;padding:1rem 1.25rem 4rem}
section{margin-top:3rem}
h2{font-size:1.6rem;font-weight:800;margin:0 0 1rem}
.intro{max-width:46rem;color:var(--ink-soft)}

/* domain cards on home */
.domeinen{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:1rem}
.domein-card{background:var(--card);border:1px solid var(--line);border-radius:.9rem;padding:1.1rem 1.1rem 1rem;text-decoration:none;color:var(--ink);display:block;border-top:6px solid var(--kleur,var(--ink));transition:transform .15s ease, box-shadow .15s ease}
.domein-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(30,36,48,.10)}
.domein-card h3{margin:.1rem 0 .3rem;font-size:1.15rem}
.domein-card p{margin:0;font-size:.85rem;color:var(--ink-soft)}
.domein-card .aantal{font-family:"IBM Plex Mono",monospace;font-size:.72rem;color:var(--ink-soft)}

/* planning table */
table.planning{width:100%;border-collapse:collapse;font-size:.88rem;background:var(--card);border:1px solid var(--line);border-radius:.75rem;overflow:hidden}
.planning th{background:var(--ink);color:#fff;text-align:left;padding:.55rem .7rem;font-weight:600;font-size:.78rem;letter-spacing:.05em;text-transform:uppercase}
.planning td{padding:.5rem .7rem;border-top:1px solid var(--line);vertical-align:top}
.planning tr.vak td{background:#EDEFEA;color:var(--ink-soft);font-style:italic}
.planning .dot{display:inline-block;width:.65rem;height:.65rem;border-radius:50%;margin-right:.45rem;vertical-align:baseline}
.planning a{color:var(--ink);font-weight:600;text-decoration:none}
.planning a:hover{text-decoration:underline}
.tabelwrap{overflow-x:auto;border-radius:.75rem}

/* domain page header */
.domein-hero{border-bottom:6px solid var(--kleur,var(--ink));background:var(--card)}
.domein-hero .binnen{max-width:1100px;margin:0 auto;padding:2.5rem 1.25rem 1.75rem}
.domein-hero h1{margin:0 0 .5rem;font-size:clamp(1.8rem,4vw,2.6rem);font-weight:800}
.domein-hero p{max-width:46rem;color:var(--ink-soft);margin:0}

/* lesfiche */
details.les{background:var(--card);border:1px solid var(--line);border-left:8px solid var(--kleur,var(--ink));border-radius:.75rem;margin:1rem 0;overflow:hidden}
details.les summary{list-style:none;cursor:pointer;padding:1rem 1.25rem;display:flex;flex-wrap:wrap;align-items:baseline;gap:.4rem 1rem}
details.les summary::-webkit-details-marker{display:none}
details.les summary:hover{background:#FBFBF9}
details.les summary .lesnr{font-family:"IBM Plex Mono",monospace;font-size:.72rem;letter-spacing:.08em;color:var(--ink-soft);text-transform:uppercase}
details.les summary h3{margin:0;font-size:1.2rem;flex-basis:100%;font-weight:800}
details.les summary .tags{display:flex;flex-wrap:wrap;gap:.4rem}
details.les[open] summary{border-bottom:1px solid var(--line)}
.fiche{padding:1.25rem 1.5rem 1.75rem}
.fiche h4{margin:1.5rem 0 .5rem;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);font-family:"IBM Plex Mono",monospace}
.fiche h4:first-child{margin-top:0}
.fiche ul,.fiche ol{margin:.25rem 0 .25rem 1.2rem;padding:0}
.fiche li{margin:.3rem 0}
.fiche p{margin:.4rem 0}
.fase{font-weight:700;margin-top:.9rem !important}
.fase .tijd{font-family:"IBM Plex Mono",monospace;font-weight:400;font-size:.78rem;color:var(--ink-soft)}
.chip{display:inline-block;font-size:.7rem;padding:.15rem .5rem;border-radius:99px;background:#EEF0EC;color:var(--ink);border:1px solid var(--line)}
.chip.doel{background:color-mix(in srgb,var(--kleur,var(--ink)) 12%,white);border-color:color-mix(in srgb,var(--kleur,var(--ink)) 35%,white)}
.meta{display:flex;flex-wrap:wrap;gap:1.25rem;font-size:.85rem;color:var(--ink-soft);background:#F4F5F1;border:1px solid var(--line);border-radius:.6rem;padding:.6rem .9rem;margin-bottom:1rem}
.meta b{color:var(--ink)}
.voorbeeld{background:#F4F5F1;border-left:4px solid var(--kleur,var(--ink));border-radius:.4rem;padding:.7rem 1rem;font-size:.92rem}
.observatie{background:#FFF;border:1px dashed color-mix(in srgb,var(--kleur,var(--ink)) 55%,white);border-radius:.6rem;padding:.75rem 1rem}
.observatie li{margin:.35rem 0}

/* doelen page */
.doelgroep{background:var(--card);border:1px solid var(--line);border-radius:.75rem;margin:1rem 0;padding:1.25rem 1.5rem;border-left:8px solid var(--kleur,var(--ink))}
.doelgroep h3{margin:0 0 .75rem}
.doelgroep table{width:100%;border-collapse:collapse;font-size:.88rem}
.doelgroep td{padding:.45rem .5rem;border-top:1px solid var(--line);vertical-align:top}
.doelgroep td.code{font-family:"IBM Plex Mono",monospace;font-size:.75rem;white-space:nowrap;color:var(--ink-soft)}
.doelgroep td.lessen{font-size:.78rem;white-space:nowrap}
.doelgroep td.lessen a{color:var(--ink);text-decoration:none;font-weight:600}
.doelgroep td.lessen a:hover{text-decoration:underline}

footer.site{background:var(--ink);color:#B9C0CE;margin-top:2rem}
footer.site .binnen{max-width:1100px;margin:0 auto;padding:1.5rem 1.25rem;font-size:.82rem;display:flex;flex-wrap:wrap;gap:.5rem 2rem;justify-content:space-between}
footer.site a{color:#fff}

.terug{font-size:.85rem}
.terug a{color:var(--ink-soft)}

@media (max-width:640px){
  .jaarlijn{height:34px}
  .fiche{padding:1rem}
  details.les summary{padding:.85rem 1rem}
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .domein-card{transition:none}
}
@media print{
  header.site,.jaarlijn,.legende,footer.site,.terug{display:none}
  details.les{border:1px solid #999;page-break-inside:avoid}
  details.les:not([open]) .fiche{display:block}
  body{background:#fff}
}
