/* ─────────────────────────────────────────────────
   WatIsOnbalans.nl — Stijlblad
   Thema: Licht, zakelijk, helder leesbaar
   Font: Inter
───────────────────────────────────────────────── */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

/* ── Variabelen ── */
:root {
  --bg:           #f4f6f9;
  --bg-alt:       #edf0f4;
  --white:        #ffffff;
  --surface:      #ffffff;
  --border:       #dde1e8;
  --border-dark:  #c5cad4;

  --blue:         #1a56db;
  --blue-light:   #eff4ff;
  --blue-mid:     #bfcfff;
  --teal:         #0891b2;
  --teal-light:   #ecfeff;
  --green:        #16a34a;
  --green-light:  #f0fdf4;
  --red:          #dc2626;
  --red-light:    #fef2f2;
  --amber:        #d97706;
  --amber-light:  #fffbeb;
  --purple:       #7c3aed;
  --purple-light: #f5f3ff;

  --text:         #1e2433;
  --text-sub:     #4b5568;
  --text-muted:   #6b7280;
  --text-light:   #9ca3af;

  --font:         'Inter', system-ui, -apple-system, sans-serif;
  --font-mono:    'SF Mono', 'Fira Code', 'Consolas', monospace;

  --radius-sm:    5px;
  --radius:       8px;
  --radius-lg:    10px;
  --shadow-sm:    0 1px 3px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.04);
  --shadow:       0 4px 12px rgba(0,0,0,0.08);
}

/* ── Reset ── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { font-size: 16px; scroll-behavior: smooth; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font);
  font-size: 15px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}

/* ── Typografie ── */
h1, h2, h3, h4, h5 {
  font-family: var(--font);
  color: var(--text);
  line-height: 1.3;
  font-weight: 700;
}
h1 { font-size: clamp(1.6rem, 3.5vw, 2.1rem); }
h2 { font-size: clamp(1.2rem, 2.5vw, 1.55rem); font-weight: 600; }
h3 { font-size: 1.05rem; }
h4 { font-size: 0.9rem; font-weight: 600; }

p  { color: var(--text-sub); margin-bottom: 1rem; line-height: 1.7; }
p:last-child { margin-bottom: 0; }

a  { color: var(--blue); text-decoration: none; }
a:hover { text-decoration: underline; }

strong { color: var(--text); font-weight: 600; }
code   { font-family: var(--font-mono); font-size: 0.85em; background: var(--bg-alt); border: 1px solid var(--border); padding: 1px 5px; border-radius: 4px; color: var(--blue); }

ul, ol { padding-left: 1.4rem; }
li { margin-bottom: 0.35rem; color: var(--text-sub); }

/* ── Layout ── */
.container      { max-width: 1100px; margin: 0 auto; padding: 0 24px; }
.container-wide { max-width: 1280px; margin: 0 auto; padding: 0 24px; }

/* ── Navigatie ── */
.topnav {
  background: var(--white);
  border-bottom: 1px solid var(--border);
  position: sticky; top: 0; z-index: 200;
  box-shadow: var(--shadow-sm);
}

.topnav__inner { display:flex; align-items:center; height:58px; }

.topnav__logo {
  display: flex; align-items: center; gap: 9px;
  font-size: 0.95rem; font-weight: 700; color: var(--text);
  text-decoration: none;
  padding-right: 20px; border-right: 1px solid var(--border); margin-right: 8px;
  white-space: nowrap;
}
.topnav__logo:hover { color: var(--blue); text-decoration: none; }

.topnav__logo-icon {
  width: 28px; height: 28px; background: var(--blue); border-radius: 6px;
  display: flex; align-items: center; justify-content: center; font-size: 14px; flex-shrink: 0;
}

.topnav__links { display:flex; align-items:center; gap:1px; list-style:none; flex:1; }

.topnav__links a {
  display: flex; align-items: center; gap: 5px;
  padding: 5px 11px; border-radius: var(--radius-sm);
  font-size: 0.875rem; font-weight: 500; color: var(--text-muted);
  text-decoration: none; transition: background 0.12s, color 0.12s;
}
.topnav__links a:hover  { background:var(--bg); color:var(--text); text-decoration:none; }
.topnav__links a.active { background:var(--blue-light); color:var(--blue); font-weight:600; }
.nav-icon { font-size:14px; }

.topnav__right { margin-left:auto; display:flex; align-items:center; gap:8px; }

#nav-time {
  font-family: var(--font-mono); font-size: 12px; color: var(--text-muted);
  background: var(--bg-alt); padding: 3px 8px; border-radius: 4px; border: 1px solid var(--border);
}

.live-dot {
  display: flex; align-items: center; gap: 5px; font-size: 11px;
  font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase;
  color: var(--green); background: var(--green-light); border: 1px solid #bbf7d0;
  padding: 3px 9px; border-radius: 20px;
}
.live-dot::before {
  content:''; width:6px; height:6px; background:var(--green); border-radius:50%;
  animation: livepulse 2s infinite;
}
@keyframes livepulse { 0%,100%{opacity:1} 50%{opacity:0.3} }

/* ── Hero ── */
.hero {
  background: var(--white);
  border-bottom: 1px solid var(--border);
  padding: 56px 0 48px;
}

.hero__kicker {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 700; color: var(--blue);
  background: var(--blue-light); border: 1px solid var(--blue-mid);
  padding: 3px 10px; border-radius: 4px; margin-bottom: 14px;
  letter-spacing: 0.04em; text-transform: uppercase;
}
.hero__title { margin-bottom: 12px; }
.hero__title span { color: var(--blue); }
.hero__sub   { font-size: 1rem; color: var(--text-sub); max-width: 560px; margin-bottom: 24px; }
.hero__ctas  { display:flex; gap:10px; flex-wrap:wrap; }

/* ── Knoppen ── */
.btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 16px; border-radius: var(--radius);
  font-family: var(--font); font-size: 0.875rem; font-weight: 600;
  text-decoration: none; cursor: pointer; border: 1px solid transparent;
  transition: all 0.12s; line-height: 1;
}
.btn:hover { text-decoration: none; }
.btn-primary   { background:var(--blue);  color:#fff; border-color:var(--blue); }
.btn-primary:hover { background:#1240a8; border-color:#1240a8; color:#fff; }
.btn-secondary { background:var(--white); color:var(--text); border-color:var(--border-dark); }
.btn-secondary:hover { background:var(--bg); }
.btn-outline   { background:transparent; color:var(--blue); border-color:var(--blue-mid); }
.btn-outline:hover { background:var(--blue-light); }
.btn-sm { padding: 5px 11px; font-size: 0.8rem; }

/* ── Secties ── */
.section     { padding: 52px 0; }
.section--sm { padding: 32px 0; }
.section--alt { background:var(--white); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }

.section-kicker {
  font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.05em; color: var(--blue); margin-bottom: 5px;
}
.section-title { margin-bottom: 8px; }
.section-sub   { color:var(--text-muted); max-width:560px; margin-bottom:28px; }

/* ── Kaarten ── */
.card {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 22px; box-shadow: var(--shadow-sm);
}
.card-top        { border-top: 3px solid var(--blue); }
.card-top-green  { border-top: 3px solid var(--green); }
.card-top-amber  { border-top: 3px solid var(--amber); }
.card-top-red    { border-top: 3px solid var(--red); }
.card-top-purple { border-top: 3px solid var(--purple); }
.card-top-teal   { border-top: 3px solid var(--teal); }

/* ── Stat kaarten ── */
.stat-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(175px,1fr)); gap:12px; }

.stat-card {
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:16px 18px; box-shadow:var(--shadow-sm);
}
.stat-card__label { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:0.04em; color:var(--text-muted); margin-bottom:6px; }
.stat-card__value { font-family:var(--font-mono); font-size:1.7rem; font-weight:700; line-height:1; color:var(--text); }
.stat-card__sub   { font-size:12px; color:var(--text-light); margin-top:4px; }

/* ── Grids ── */
.grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }

@media (max-width:900px) { .grid-3,.grid-4 { grid-template-columns:repeat(2,1fr); } }
@media (max-width:640px) {
  .grid-2,.grid-3,.grid-4 { grid-template-columns:1fr; }
  .topnav__links { display:none; }
}

/* ── Info blok ── */
.info-block { display:grid; grid-template-columns:1fr 1fr; gap:44px; align-items:start; }
@media (max-width:800px) { .info-block { grid-template-columns:1fr; gap:24px; } }

/* ── Badges ── */
.badge { display:inline-flex; align-items:center; gap:4px; padding:2px 8px; border-radius:4px; font-size:11px; font-weight:600; }
.badge-blue   { background:var(--blue-light);   color:var(--blue);   border:1px solid var(--blue-mid); }
.badge-green  { background:var(--green-light);  color:var(--green);  border:1px solid #bbf7d0; }
.badge-red    { background:var(--red-light);    color:var(--red);    border:1px solid #fecaca; }
.badge-amber  { background:var(--amber-light);  color:var(--amber);  border:1px solid #fde68a; }
.badge-purple { background:var(--purple-light); color:var(--purple); border:1px solid #ddd6fe; }
.badge-teal   { background:var(--teal-light);   color:var(--teal);   border:1px solid #a5f3fc; }
.badge-gray   { background:var(--bg-alt);       color:var(--text-muted); border:1px solid var(--border); }

/* ── Callouts ── */
.callout       { border-left:3px solid var(--blue); background:var(--blue-light); border-radius:0 var(--radius) var(--radius) 0; padding:13px 16px; margin:18px 0; }
.callout--green { border-left-color:var(--green); background:var(--green-light); }
.callout--amber { border-left-color:var(--amber); background:var(--amber-light); }
.callout--red   { border-left-color:var(--red);   background:var(--red-light); }
.callout strong { display:block; font-size:0.875rem; color:var(--text); margin-bottom:2px; }
.callout p      { font-size:0.875rem; color:var(--text-sub); margin:0; }

/* ── Tabs ── */
.tabs    { display:flex; gap:2px; border-bottom:2px solid var(--border); margin-bottom:28px; }
.tab-btn { padding:8px 15px; font-family:var(--font); font-size:0.875rem; font-weight:500; color:var(--text-muted); background:none; border:none; border-bottom:2px solid transparent; margin-bottom:-2px; cursor:pointer; transition:all 0.12s; white-space:nowrap; }
.tab-btn:hover  { color:var(--text); }
.tab-btn.active { color:var(--blue); border-bottom-color:var(--blue); font-weight:600; }
.tab-pane       { display:none; }
.tab-pane.active { display:block; }

/* ── Tabel ── */
.data-table-wrap { background:var(--white); border:1px solid var(--border); border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-sm); }
.data-table-head { background:var(--bg-alt); padding:11px 16px; border-bottom:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; gap:10px; }
.data-table-head span { font-size:11.5px; font-weight:700; text-transform:uppercase; letter-spacing:0.04em; color:var(--text-muted); }
.data-table { width:100%; border-collapse:collapse; font-size:13.5px; }
.data-table thead tr { border-bottom:1px solid var(--border); }
.data-table th { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:0.04em; color:var(--text-muted); padding:8px 13px; text-align:right; background:var(--bg-alt); }
.data-table th:first-child { text-align:left; }
.data-table td { padding:8px 13px; text-align:right; border-bottom:1px solid var(--bg); }
.data-table td:first-child { text-align:left; font-family:var(--font-mono); font-size:12px; color:var(--text-muted); }
.data-table tbody tr:hover { background:var(--bg); }
.data-table tbody tr.current { background:var(--blue-light); }
.val-pos { color:var(--green); font-family:var(--font-mono); font-weight:600; }
.val-neg { color:var(--red);   font-family:var(--font-mono); font-weight:600; }
.val-mid { color:var(--amber); font-family:var(--font-mono); }
.val-neu { color:var(--text);  font-family:var(--font-mono); }

/* ── Timeline ── */
.timeline { padding-left:30px; position:relative; }
.timeline::before { content:''; position:absolute; left:7px; top:8px; bottom:8px; width:1px; background:var(--border-dark); }
.timeline__item { position:relative; margin-bottom:26px; }
.timeline__item::before { content:''; position:absolute; left:-25px; top:5px; width:10px; height:10px; border-radius:50%; background:var(--blue); border:2px solid var(--white); outline:2px solid var(--blue-mid); }
.timeline__item h4 { color:var(--blue); margin-bottom:3px; font-size:0.9rem; }
.timeline__item p  { font-size:0.875rem; margin:0; }

/* ── Definitielijst ── */
.def-list { border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; }
.def-item { display:grid; grid-template-columns:170px 1fr; border-bottom:1px solid var(--border); }
.def-item:last-child { border-bottom:none; }
.def-item dt { background:var(--bg-alt); padding:10px 13px; font-family:var(--font-mono); font-size:12px; color:var(--blue); font-weight:600; border-right:1px solid var(--border); }
.def-item dd { padding:10px 13px; font-size:0.875rem; color:var(--text-sub); }

/* ── Page hero ── */
.page-hero { background:var(--white); border-bottom:1px solid var(--border); padding:40px 0 32px; }
.page-hero__breadcrumb { font-size:12.5px; color:var(--text-light); margin-bottom:12px; display:flex; gap:6px; align-items:center; }
.page-hero__breadcrumb a { color:var(--text-muted); }
.page-hero__breadcrumb a:hover { color:var(--blue); }

/* ── Sliders ── */
.slider-group { margin-bottom:18px; }
.slider-label { display:flex; justify-content:space-between; align-items:center; margin-bottom:6px; }
.slider-label span   { font-size:0.875rem; color:var(--text-sub); }
.slider-label strong { font-family:var(--font-mono); font-size:0.875rem; color:var(--blue); }

input[type=range] { -webkit-appearance:none; width:100%; height:4px; background:var(--border); border-radius:4px; outline:none; cursor:pointer; }
input[type=range]::-webkit-slider-thumb { -webkit-appearance:none; width:16px; height:16px; border-radius:50%; background:var(--blue); cursor:pointer; box-shadow:0 0 0 2px var(--white),0 0 0 3px var(--blue-mid); transition:transform 0.12s; }
input[type=range]::-webkit-slider-thumb:hover { transform:scale(1.2); }

/* ── Meter ── */
.meter-wrap  { background:var(--bg-alt); border-radius:4px; overflow:hidden; height:8px; border:1px solid var(--border); }
.meter-fill  { height:100%; border-radius:4px; transition:width 0.4s ease; }
.meter-blue  { background:var(--blue); }
.meter-green { background:var(--green); }
.meter-amber { background:var(--amber); }
.meter-red   { background:var(--red); }

/* ── Regeltoestand ── */
.rt-indicator { display:flex; gap:6px; align-items:center; }
.rt-block { width:32px; height:32px; border-radius:6px; display:flex; align-items:center; justify-content:center; font-family:var(--font-mono); font-size:14px; font-weight:700; background:var(--bg-alt); color:var(--text-light); border:1px solid var(--border); transition:all 0.25s; }
.rt-block.active-rt1 { background:var(--teal-light);  color:var(--teal);  border-color:#a5f3fc; }
.rt-block.active-rt2 { background:var(--amber-light); color:var(--amber); border-color:#fde68a; }
.rt-block.active-rt3 { background:var(--red-light);   color:var(--red);   border-color:#fecaca; }

/* ── Live prijskaarten ── */
.price-hero-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-bottom:12px; }
@media (max-width:700px) { .price-hero-grid { grid-template-columns:1fr 1fr; } .price-hero-grid .price-card:last-child { grid-column:span 2; } }

.price-card { background:var(--white); border:1px solid var(--border); border-radius:var(--radius-lg); padding:16px 18px; border-top-width:3px; box-shadow:var(--shadow-sm); }
.price-card--inv  { border-top-color:var(--green); }
.price-card--afn  { border-top-color:var(--teal); }
.price-card--tijd { border-top-color:var(--text-light); }
.price-card__label { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:0.05em; color:var(--text-muted); margin-bottom:8px; }
.price-card__value { font-family:var(--font-mono); font-size:1.85rem; font-weight:700; line-height:1; color:var(--text); margin-bottom:4px; transition:color 0.3s; }
.price-card__sub   { font-size:12px; color:var(--text-light); }

/* ── Countdown ── */
.countdown-strip { background:var(--white); border:1px solid var(--border); border-radius:var(--radius); padding:8px 14px; margin-bottom:12px; display:flex; align-items:center; gap:12px; box-shadow:var(--shadow-sm); }
.countdown-strip > span { font-size:12.5px; color:var(--text-muted); white-space:nowrap; }
.bar-outer { flex:1; height:4px; background:var(--bg-alt); border-radius:4px; overflow:hidden; border:1px solid var(--border); }
.bar-inner { height:100%; background:var(--blue); border-radius:4px; transition:width 1s linear; }
#countdown-num { font-family:var(--font-mono); font-size:12px; color:var(--blue); min-width:28px; text-align:right; }

/* ── Onbalans table badges ── */
.ob-badge        { display:inline-block; font-family:var(--font-mono); font-size:11.5px; font-weight:600; padding:2px 7px; border-radius:4px; }
.ob-badge-green  { background:var(--green-light);  color:var(--green); border:1px solid #bbf7d0; }
.ob-badge-red    { background:var(--red-light);    color:var(--red);   border:1px solid #fecaca; }
.ob-badge-blue   { background:var(--blue-light);   color:var(--blue);  border:1px solid var(--blue-mid); }
.ob-badge-purple { background:var(--purple-light); color:var(--purple); border:1px solid #ddd6fe; }
.ob-dash { color:var(--text-light); }
.price-pos { color:var(--green); font-family:var(--font-mono); font-weight:600; }
.price-mid { color:var(--amber); font-family:var(--font-mono); }
.price-low { color:var(--text-muted); font-family:var(--font-mono); }
.price-neg { color:var(--red);   font-family:var(--font-mono); font-weight:600; }

/* ── Legenda ── */
.legend-strip { display:flex; flex-wrap:wrap; gap:14px; font-size:12.5px; color:var(--text-muted); margin-bottom:12px; }
.legend-item  { display:flex; align-items:center; gap:5px; }
.legend-dot   { width:8px; height:8px; border-radius:2px; flex-shrink:0; }

/* ── Footer ── */
.footer { background:var(--white); border-top:1px solid var(--border); padding:40px 0; margin-top:60px; }
.footer__inner { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:32px; }
@media (max-width:800px) { .footer__inner { grid-template-columns:1fr 1fr; } }
@media (max-width:500px) { .footer__inner { grid-template-columns:1fr; } }
.footer__brand p { font-size:0.875rem; color:var(--text-muted); margin-top:8px; max-width:240px; }
.footer__col h5 { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:0.04em; color:var(--text-muted); margin-bottom:12px; }
.footer__col ul { list-style:none; padding:0; }
.footer__col li { margin-bottom:7px; }
.footer__col a  { font-size:0.875rem; color:var(--text-muted); }
.footer__col a:hover { color:var(--blue); text-decoration:none; }
.footer__bottom { margin-top:24px; padding-top:16px; border-top:1px solid var(--border); display:flex; justify-content:space-between; font-size:12px; color:var(--text-light); flex-wrap:wrap; gap:8px; }

/* ── Hulpklassen ── */
.mono       { font-family:var(--font-mono); }
.muted      { color:var(--text-muted); }
.text-blue  { color:var(--blue); }
.text-green { color:var(--green); }
.text-red   { color:var(--red); }
.text-amber { color:var(--amber); }
.text-sm    { font-size:0.875rem; }
.text-xs    { font-size:0.8rem; }
.mb-0 { margin-bottom:0!important; }
.mb-2 { margin-bottom:8px; }
.mb-4 { margin-bottom:16px; }
.mb-6 { margin-bottom:24px; }
.mt-4 { margin-top:16px; }
.mt-6 { margin-top:24px; }
.chart-wrap { background:var(--bg-alt); border:1px solid var(--border); border-radius:var(--radius); padding:16px; }
