/* ma.css — zelfstandige SUPERP-huisstijl voor Management Assessment + Portaal.
   Geen afhankelijkheid van pilot.css (dat is gescoped op body.tm-pilot).
   Officieel SUPERP-palet: Aero #39C2DD (LOGO-only), Light Sky #59E2F7 (accent),
   Dark Sky #00343D (petrol), Medium Land #F2E6D0 + Light Land #F5F0EA. */

:root{
  --aero:#39C2DD;          /* ALLEEN logo/wordmark — niet voor accenten */
  --petrol:#00343D;        /* Dark Sky */
  --petrol-700:#00242B;    /* Dark Sky, donkerder (gradients/hover) */
  --cyaan:#59E2F7;         /* Light Sky — accentkleur */
  --cyaan-700:#1C8FA3;     /* donkere Light Sky — accenten op wit / badge-tekst */
  --cream:#F2E6D0;         /* Medium Land — canvas */
  --offwhite:#F5F0EA;      /* Light Land — kaarten/oppervlakken */
  --dark-land:#25221D;     /* Dark Land — donkere badge/achtergrond */
  --white:#ffffff;
  --on-petrol:#eaf6f8;     /* lichte tekst/elementen op petrol-achtergrond */
  --ink:#10242b;
  --ink-soft:#3f565e;
  --line:#ddd3c2;
  --line-soft:#e8e0d2;

  --ok:#2e7d32; --ok-bg:#e6f4ea;
  --warn:#b26a00; --warn-bg:#fcefd9;
  --err:#b00020; --err-bg:#fde7ea;
  --info:#01579b; --info-bg:#e3f2fd;

  --radius:14px; --radius-sm:9px;
  --shadow:0 10px 30px rgba(0,4,8,.10);
  --shadow-sm:0 2px 10px rgba(0,4,8,.06);
  --font:"Segoe UI",system-ui,-apple-system,Roboto,Arial,sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--font);font-size:14px;color:var(--ink);background:var(--cream);line-height:1.45}
a{color:var(--petrol);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{margin:0 0 .4em}

/* ===== Topbar ===== */
.topbar{
  background:linear-gradient(180deg,var(--petrol),var(--petrol-700));
  color:var(--on-petrol);position:sticky;top:0;z-index:50;box-shadow:0 2px 12px rgba(0,0,0,.15);
}
.topbar-inner{
  max-width:1280px;margin:0 auto;height:58px;display:flex;align-items:center;gap:18px;padding:0 20px;
}
.brand{display:flex;align-items:center;gap:10px;color:var(--on-petrol)}
.brand:hover{text-decoration:none}
.brand-badge{
  background:var(--aero);color:var(--petrol-700);font-weight:800;font-size:12px;letter-spacing:.5px;
  padding:4px 8px;border-radius:7px;
}
.brand-title{font-weight:700;font-size:16px;letter-spacing:.2px}
.mainnav{display:flex;gap:4px;align-items:center}
.mainnav a{
  color:#cfeaef;padding:8px 13px;border-radius:9px;font-size:13.5px;line-height:1;
}
.mainnav a:hover{background:rgba(255,255,255,.10);text-decoration:none}
.mainnav a.active{background:var(--cyaan);color:var(--petrol-700);font-weight:700}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:12px}
.userchip{font-size:12.5px;color:#bfe0e6}

/* ===== Layout ===== */
.container{max-width:1280px;margin:0 auto;padding:22px 20px 60px}
.page-title{font-size:23px;margin:0 0 4px;color:var(--petrol);font-weight:800}
.page-sub{margin:0 0 20px;color:var(--ink-soft);font-size:14px;max-width:80ch}

/* ===== Cards ===== */
.card{
  background:var(--offwhite);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);padding:18px;
}
.card-head{
  display:flex;align-items:center;justify-content:space-between;gap:12px;margin:-2px 0 14px;
}

/* ===== Buttons ===== */
.btn{
  height:36px;padding:0 15px;border:1px solid var(--line);border-radius:var(--radius-sm);
  background:var(--white);color:var(--ink);font-size:14px;font-family:inherit;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;text-decoration:none;
  transition:background .12s,border-color .12s,box-shadow .12s;white-space:nowrap;
}
.btn:hover{border-color:var(--cyaan);background:var(--cream);text-decoration:none}
.btn:disabled{opacity:.45;cursor:not-allowed}
.btn-primary{background:var(--petrol);color:var(--on-petrol);border-color:var(--petrol)}
.btn-primary:hover:not(:disabled){background:var(--petrol-700);border-color:var(--petrol-700)}
.btn-accent{background:var(--cyaan);color:var(--petrol-700);border-color:var(--cyaan);font-weight:700}
.btn-accent:hover:not(:disabled){background:var(--cyaan-700);border-color:var(--cyaan-700)}
.btn-ghost{background:transparent}
.btn-ghost:hover{background:rgba(0,56,69,.06)}
.btn-danger{background:var(--err);color:#fff;border-color:var(--err)}
.btn-danger:hover:not(:disabled){background:#8e0019;border-color:#8e0019}
.btn-sm{height:30px;padding:0 11px;font-size:12.5px}
/* ghost-knop in de petrol topbar leesbaar houden */
.topbar .btn-ghost{color:#dbeef1;border-color:rgba(255,255,255,.28)}
.topbar .btn-ghost:hover{background:rgba(255,255,255,.12)}

/* ===== Forms ===== */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field label,label{font-size:12.5px;color:var(--ink-soft);font-weight:600}
.input,select,textarea{
  width:100%;height:36px;padding:0 11px;border:1px solid var(--line);border-radius:var(--radius-sm);
  background:var(--white);color:var(--ink);font-size:14px;font-family:inherit;
}
textarea{height:auto;min-height:64px;padding:9px 11px;resize:vertical;line-height:1.4}
.input:focus,select:focus,textarea:focus{
  outline:none;border-color:var(--cyaan);box-shadow:0 0 0 3px rgba(89,226,247,.30);
}

/* ===== Tables ===== */
.table{width:100%;border-collapse:collapse;font-size:14px}
.table th,.table td{padding:10px 12px;border-bottom:1px solid var(--line-soft);text-align:left;vertical-align:top}
.table thead th{background:var(--cream);color:var(--ink);font-weight:700;font-size:12.5px;letter-spacing:.2px}
.table tbody tr:hover td{background:rgba(89,226,247,.06)}
.table .num{text-align:right;white-space:nowrap}
.table th[colspan]{background:var(--cream);color:var(--petrol);font-weight:800}

/* ===== Badges ===== */
.badge{display:inline-flex;align-items:center;height:22px;padding:0 10px;border-radius:999px;font-size:11.5px;font-weight:700}
.badge-info{background:var(--info-bg);color:var(--info)}
.badge-muted{background:#ece6da;color:#6b6356}
.badge-ok{background:var(--ok-bg);color:var(--ok)}
.badge-warn{background:var(--warn-bg);color:var(--warn)}
.badge-err{background:var(--err-bg);color:var(--err)}

/* ===== Modal ===== */
.modal-backdrop{position:fixed;inset:0;background:rgba(4,34,42,.48);display:flex;align-items:center;justify-content:center;z-index:150;padding:20px}
.modal{background:var(--offwhite);border-radius:var(--radius);box-shadow:var(--shadow);width:520px;max-width:96vw;max-height:90vh;overflow:auto}
.modal-head{padding:16px 20px;border-bottom:1px solid var(--line)}
.modal-body{padding:18px 20px}
.modal-foot{padding:14px 20px;border-top:1px solid var(--line);display:flex;gap:8px;justify-content:flex-end}

/* ===== Utilities ===== */
.flex{display:flex}
.gap{gap:10px}
.mt{margin-top:16px}
.mb{margin-bottom:16px}
.right{margin-left:auto}
.muted{color:var(--ink-soft)}
.hidden{display:none}

/* ===== Twee-koloms (tree + detail) ===== */
.ma-split{display:grid;grid-template-columns:340px 1fr;gap:18px;align-items:start}
@media(max-width:900px){.ma-split{grid-template-columns:1fr}}

/* ===== Donkere tree-pane ===== */
.tree-pane{
  background:linear-gradient(180deg,var(--petrol),var(--petrol-700));
  border-radius:var(--radius);padding:12px;min-height:480px;box-shadow:var(--shadow);
}
.tree-pane .as-head{color:#9fd6e0;text-transform:uppercase;font-size:11px;letter-spacing:.6px;font-weight:800;margin:14px 8px 5px}
.tree-pane .as-head:first-child{margin-top:4px}
.tree-pane .t-children{margin-left:14px;border-left:1px solid rgba(255,255,255,.12);padding-left:6px}
.tree-pane .t-node{display:flex;align-items:center;gap:8px;padding:7px 9px;border-radius:8px;cursor:pointer;color:#dbeef3;font-size:13.5px}
.tree-pane .t-node:hover{background:rgba(255,255,255,.09)}
.tree-pane .t-node.active{background:var(--cyaan);color:var(--petrol-700);font-weight:700}
.tree-pane .t-node .twi{opacity:.7;font-size:11px;width:12px;text-align:center;flex:0 0 auto}
.tree-pane .t-node .lbl{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tree-pane .t-node .mini{opacity:.65;font-size:11px;flex:0 0 auto}
.tree-pane .t-node.add{opacity:.8;font-style:italic}
/* vraag-nodes: volledige tekst, meerdere regels (leesbaar) */
.tree-pane .t-node.t-vraag{align-items:flex-start}
.tree-pane .t-node.t-vraag .twi{margin-top:2px}
.tree-pane .t-node.t-vraag .lbl{white-space:normal;overflow:visible;text-overflow:clip;line-height:1.35}

/* ===== Niveau-grid (onderhoud) ===== */
.niveau-grid{display:flex;flex-direction:column;gap:10px}
.niveau-row{display:grid;grid-template-columns:92px 1fr;gap:10px;align-items:start}
.niveau-row .nlabel{display:inline-flex;align-items:center;justify-content:center;height:38px;border-radius:9px;background:var(--petrol);color:#eafcff;font-weight:700;font-size:13px}

/* ===== Invulformulier ===== */
.as-head-fill{font-size:12px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.6px;font-weight:800;margin:0 0 12px}
.comp-head{font-size:16px;color:var(--petrol);font-weight:800;margin:20px 0 12px;border-bottom:2px solid var(--cyaan);padding-bottom:6px}
.comp-head:first-of-type{margin-top:2px}
.q-block{border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px;margin-bottom:12px;background:var(--cream)}
.q-block .q-tekst{font-weight:700;margin-bottom:10px;color:var(--ink)}
.scale{display:flex;gap:8px;flex-wrap:wrap}
.scale .opt{flex:1 1 165px;border:1px solid var(--line);border-radius:9px;padding:9px 11px;cursor:pointer;background:var(--white);display:flex;gap:8px;align-items:flex-start}
.scale .opt:hover{border-color:var(--cyaan)}
.scale .opt.sel{border-color:var(--cyaan);background:rgba(89,226,247,.12);box-shadow:inset 0 0 0 1px var(--cyaan)}
.scale .opt input{margin-top:3px;flex:0 0 auto}
.scale .opt .sc{font-weight:800;color:var(--petrol)}
.scale .opt .om{font-size:12px;color:var(--ink-soft)}

/* sticky opslaan-balk */
.save-bar{position:sticky;bottom:14px;display:flex;align-items:center;gap:14px;margin-top:16px}

/* ===== Resultaat ===== */
.res-split{display:grid;grid-template-columns:1fr 360px;gap:18px;align-items:start}
@media(max-width:900px){.res-split{grid-template-columns:1fr}}

/* ===== Toasts ===== */
.toast-wrap{position:fixed;right:18px;bottom:18px;display:flex;flex-direction:column;gap:8px;z-index:200}
.toast{padding:11px 14px;border-radius:10px;box-shadow:var(--shadow);font-size:13px;min-width:240px;animation:ma-tin .18s ease}
.toast.ok{background:var(--ok-bg);color:var(--ok);border:1px solid #b8e0c2}
.toast.err{background:var(--err-bg);color:var(--err);border:1px solid #f3c0c8}
@keyframes ma-tin{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ===== Compacte invul-layout (Likert) ===== */
.comp-head{margin:14px 0 6px;font-size:14.5px;padding-bottom:4px}
.comp-head:first-of-type{margin-top:0}
.as-head-fill{margin:0 0 8px}
.q-row{padding:9px 0;border-bottom:1px solid var(--line-soft)}
.q-row:last-child{border-bottom:0}
.q-top{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.q-nr{color:var(--ink-soft);font-size:12px;min-width:22px;text-align:right;flex:0 0 auto}
.q-top .q-tekst{flex:1 1 300px;font-weight:600;margin:0}
.scale5{display:inline-flex;gap:6px;flex:0 0 auto;margin-left:auto}
.scale5 .s{
  width:34px;height:34px;border-radius:8px;border:1px solid var(--line);background:var(--white);
  cursor:pointer;font-weight:700;font-size:14px;color:var(--ink-soft);transition:all .1s;
}
.scale5 .s:hover{border-color:var(--cyaan);color:var(--petrol);background:rgba(89,226,247,.08)}
.scale5 .s.sel{background:var(--petrol);border-color:var(--petrol);color:#fff}
.lvl-desc{font-size:12px;color:var(--ink-soft);margin:5px 0 0 34px;min-height:1.1em;line-height:1.35}
.lvl-desc.is-set{color:var(--ink)}
@media(max-width:620px){
  .scale5{margin-left:34px}
  .lvl-desc{margin-left:0}
}

/* progress-balk in opslaan-bar */
.progress-wrap{flex:1 1 auto;height:8px;background:var(--line-soft);border-radius:999px;overflow:hidden;max-width:320px}
.progress-bar{height:100%;background:var(--cyaan);width:0;transition:width .2s}

/* ===== Resultaat: toelichting per vraag ===== */
.pv-as{font-size:12px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.5px;font-weight:800;margin:18px 0 4px}
.pv-as:first-child{margin-top:0}
.pv-comp{font-weight:800;color:var(--petrol);margin:8px 0 4px;border-bottom:1px solid var(--line);padding-bottom:3px}
.pv-q{padding:9px 0;border-bottom:1px solid var(--line-soft)}
.pv-q:last-child{border-bottom:0}
.pv-tekst{font-weight:600;margin-bottom:6px}
.pv-line{display:flex;gap:8px;align-items:flex-start;font-size:13px;margin:4px 0;color:var(--ink-soft);line-height:1.4}
.pv-badge{flex:0 0 auto;color:#fff;border-radius:6px;padding:2px 9px;font-size:12px;font-weight:700;white-space:nowrap}

/* radar hover-tooltip */
#rtip{position:fixed;pointer-events:none;background:var(--petrol-700);color:var(--on-petrol);font-size:12px;padding:7px 10px;
  border-radius:8px;box-shadow:0 6px 20px rgba(0,0,0,.3);z-index:300;display:none;max-width:260px;line-height:1.4}
