/* ============================================================
   Bröder huisstijl — globale override (v2)
   Brengt alle pagina's in lijn met index.html + brandbook.
   - Montserrat overal
   - Bröder Blauw + Rood + Off-black + Cream palette
   - "De Hoek" als doorlopend brand-element
   - Topbar, hero, KPI-kaarten, content-kaarten, knoppen, tabellen
   ============================================================ */

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

:root{
  --broder-blauw:#223e42;
  --broder-blauw-hover:#2e545a;
  --broder-blauw-22:#d3d8d9;
  --broder-blauw-5:#f0f1f1;
  --broder-rood:#c74336;
  --broder-rood-hover:#a8362b;
  --broder-rood-22:#f3d9d6;
  --broder-zwart:#1a1a1a;
  --broder-wit:#ffffff;
  --broder-cream:#f4efe6;
  --broder-cream-edge:#e2dccc;
  --broder-cream-soft:#faf5e9;

  --c-primary:#223e42;
  --c-primary-light:#2e545a;
  --c-primary-dark:#1a3134;
  --c-accent:#c74336;
  --c-accent2:#d59a3a;
  --c-green:#2f8460;
  --c-green-bg:#dcebe2;
  --c-red:#c74336;
  --c-star:#d59a3a;

  --c-gray-50:#faf5e9;
  --c-gray-100:#efeadb;
  --c-gray-200:#e2dccc;
  --c-gray-300:#c4bca5;
  --c-gray-400:#9a9486;
  --c-gray-500:#6e6a60;
  --c-gray-600:#4d4a44;
  --c-gray-700:#363430;
  --c-gray-800:#222220;
  --c-gray-900:#1a1a1a;

  --radius:14px;
  --radius-sm:10px;
}

html, body, body *:not(code):not(pre):not([class*="mono"]):not([class*="Mono"]){
  font-family:'Montserrat',system-ui,-apple-system,'Segoe UI',sans-serif !important;
}
body{
  background:
    radial-gradient(900px 500px at 10% -10%, color-mix(in oklab, var(--broder-rood) 6%, transparent), transparent 60%),
    radial-gradient(700px 400px at 100% 0%, color-mix(in oklab, var(--broder-blauw) 6%, transparent), transparent 70%),
    var(--broder-cream) !important;
  color:var(--broder-zwart) !important;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"ss01","tnum";
  min-height:100vh;
}

/* ---- "De Hoek" — paginabreed brand-element rechtsboven ---- */
body::before{
  content:"";position:fixed;top:0;right:0;
  width:140px;height:140px;
  background:var(--broder-rood);opacity:.08;
  border-radius:0 0 0 110px;
  pointer-events:none;z-index:0;
}
@media(max-width:700px){body::before{width:72px;height:72px;border-radius:0 0 0 56px}}
@media print{body::before{display:none}}
.container{position:relative;z-index:1;max-width:1140px}

/* ---- TOPBAR — logo + nav + currency, zoals index ---- */
.topbar{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:14px 18px;margin-bottom:24px;
  background:#fff;border:1px solid var(--broder-cream-edge);
  border-radius:24px;
  box-shadow:0 2px 6px -2px rgba(34,62,66,.06);
  position:relative;z-index:2;
}
.brand{display:inline-flex;align-items:center;gap:10px;text-decoration:none;color:inherit;flex-shrink:0}
.brand-mark{
  width:38px;height:38px;border-radius:14px 14px 14px 4px;
  background:var(--broder-blauw);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  position:relative;
  box-shadow:0 4px 10px -2px rgba(34,62,66,.35);
}
.brand-mark svg{width:18px;height:18px;position:relative;z-index:1}
.brand-mark::after{content:'';position:absolute;left:7px;bottom:-3px;width:9px;height:9px;background:var(--broder-rood);border-radius:50%;border:2px solid #fff}
.brand-name{font-family:'Montserrat',sans-serif !important;font-weight:700;font-size:15px;letter-spacing:-.005em;line-height:1.05;text-transform:none;color:var(--broder-blauw)}
.brand-name small{display:block;font-size:10px;font-weight:600;color:var(--broder-rood);letter-spacing:.08em;text-transform:uppercase;margin-top:2px}

/* When .nav is inside .topbar, drop the pill styling — let the topbar be the pill */
.topbar .nav, .topbar > nav.nav{
  background:transparent !important;border:none !important;box-shadow:none !important;
  padding:0 !important;margin:0 !important;border-radius:0 !important;
  flex:1;justify-content:center;width:auto;
}
@media(max-width:780px){
  .topbar{flex-wrap:wrap;border-radius:20px;padding:12px 14px}
  .topbar .nav, .topbar > nav.nav{order:3;flex-basis:100%;justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap}
}

/* ---- TOPBAR / NAV — pill-style zoals index ---- */
.nav{display:flex;justify-content:center;gap:4px;margin-bottom:24px;flex-wrap:wrap;padding:8px;background:#fff;border:1px solid var(--broder-cream-edge);border-radius:99px;width:fit-content;margin-left:auto;margin-right:auto;box-shadow:0 2px 6px -2px rgba(34,62,66,.06)}
.nav a{font-size:13px;padding:8px 16px;border-radius:99px;text-decoration:none;font-weight:600;transition:all .15s;letter-spacing:.01em}
.nav a.active{background:var(--broder-blauw) !important;color:#fff !important}
.nav a:not(.active){background:transparent !important;color:var(--broder-blauw) !important;border:none !important}
.nav a:not(.active):hover{background:var(--broder-cream) !important;color:var(--broder-blauw) !important}

/* ---- HEADER / HERO — match index ---- */
.header{
  position:relative;text-align:left !important;padding:28px 28px 24px !important;margin-bottom:28px !important;
  background:#fff;border:1px solid var(--broder-cream-edge);border-radius:var(--radius);
  box-shadow:0 4px 12px -2px rgba(34,62,66,.06);
  overflow:hidden;
}
.header::before{
  content:'' !important;position:absolute !important;
  top:0 !important;right:0 !important;left:auto !important;
  width:140px !important;height:140px !important;
  background:var(--broder-rood) !important;opacity:.10 !important;
  border-radius:0 var(--radius) 0 80px !important;
  transform:none !important;
}
.logo{display:inline-flex;align-items:center;gap:12px;margin-bottom:14px}
.logo-icon{
  width:40px !important;height:40px !important;
  background:var(--broder-blauw) !important;
  border-radius:14px 14px 14px 4px !important;
  position:relative;
  box-shadow:0 4px 10px -2px rgba(34,62,66,.30);
  color:#fff !important;
  display:flex !important;align-items:center !important;justify-content:center !important;
}
.logo-icon::after{
  content:"";position:absolute;left:7px;bottom:-3px;
  width:10px;height:10px;border-radius:50%;
  background:var(--broder-rood);
  border:2px solid #fff;
}
.logo-text{
  color:var(--broder-blauw) !important;
  font-size:11px !important;font-weight:700 !important;
  letter-spacing:.14em !important;text-transform:uppercase !important;
}
h1{
  font-size:clamp(28px,4vw,40px) !important;font-weight:800 !important;
  color:var(--broder-zwart) !important;letter-spacing:-.025em !important;
  line-height:1.08 !important;margin-bottom:10px !important;text-wrap:balance;max-width:780px;
}
.subtitle{font-size:15px !important;color:var(--broder-zwart) !important;opacity:.7;max-width:680px;line-height:1.55}
.header::after{content:"Onafhankelijke rekentool · update 2026";position:absolute;top:28px;right:28px;font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--broder-rood);background:var(--broder-rood-22);padding:5px 12px;border-radius:99px;z-index:2}
@media(max-width:700px){.header::after{display:none}}

/* ---- Section titles ---- */
.section-title{font-size:13px !important;font-weight:700 !important;color:var(--broder-blauw) !important;letter-spacing:.10em !important;text-transform:uppercase !important;margin:32px 0 4px !important}
.section-sub{font-size:14px !important;color:var(--broder-zwart) !important;opacity:.65;margin-bottom:14px !important;line-height:1.5}

/* ---- KPI / stat-cards ---- */
.stats-row{gap:14px !important;margin-bottom:22px !important}
.stat-card{
  background:#fff !important;
  border:1px solid var(--broder-cream-edge) !important;
  border-radius:var(--radius) !important;
  padding:18px 18px 16px !important;
  text-align:left !important;
  box-shadow:0 2px 6px -2px rgba(34,62,66,.06) !important;
  transition:transform .15s, box-shadow .15s;
}
.stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px -6px rgba(34,62,66,.12) !important}
.stat-card::before{
  height:3px !important;background:var(--broder-blauw) !important;
  border-radius:var(--radius) var(--radius) 0 0;
}
.stat-card.now::before{background:var(--broder-rood) !important}
.stat-card.low::before{background:var(--c-green) !important}
.stat-card.high::before{background:var(--broder-rood) !important}
.stat-value{
  font-size:26px !important;font-weight:800 !important;
  color:var(--broder-blauw) !important;letter-spacing:-.02em !important;
  font-variant-numeric:tabular-nums;font-family:'JetBrains Mono','SF Mono',monospace !important;
}
.stat-card.now .stat-value{color:var(--broder-rood) !important}
.stat-card.low .stat-value{color:var(--c-green) !important}
.stat-card.high .stat-value{color:var(--broder-rood) !important}
.stat-label{font-size:11px !important;color:var(--broder-zwart) !important;opacity:.6;text-transform:uppercase !important;letter-spacing:.08em !important;font-weight:600 !important;margin-top:4px !important}

/* ---- Generic content cards ---- */
.chart-card, .suppliers-card, .formula-card,
.articles-section, .card-info, .card-review,
.status-box, .now-banner{
  background:#fff !important;
  border:1px solid var(--broder-cream-edge) !important;
  border-radius:var(--radius) !important;
  box-shadow:0 2px 6px -2px rgba(34,62,66,.06) !important;
  padding:22px !important;margin-bottom:16px;
}
.chart-card h2, .suppliers-card h2, .formula-card h2,
.articles-section h2{
  font-size:14px !important;font-weight:700 !important;
  color:var(--broder-blauw) !important;letter-spacing:.06em !important;
  text-transform:uppercase !important;margin-bottom:14px !important;
}
.formula-card{background:var(--broder-blauw-5) !important;border-color:var(--broder-blauw-22) !important}
.formula-card code{background:#fff !important;color:var(--broder-blauw) !important;font-family:'JetBrains Mono',ui-monospace,monospace !important;border:1px solid var(--broder-cream-edge);font-size:11.5px !important;padding:2px 8px;border-radius:6px}

/* ---- Buttons ---- */
.btn-calc, .filter-btn.active, .filter-btn:hover{
  background:var(--broder-blauw) !important;color:#fff !important;
  border-color:var(--broder-blauw) !important;
  border-radius:10px !important;padding:9px 18px !important;
  font-weight:600 !important;font-size:13px !important;letter-spacing:.01em !important;
}
.filter-btn{
  background:#fff !important;color:var(--broder-blauw) !important;
  border:1px solid var(--broder-cream-edge) !important;
  border-radius:10px !important;padding:9px 18px !important;font-weight:600 !important;
}
.btn-calc:hover{background:var(--broder-blauw-hover) !important;transform:translateY(-1px);box-shadow:0 6px 14px -4px rgba(34,62,66,.25)}

/* ---- Brand CTA banner (reviews / artikelen) ---- */
.brand-cta{
  background:var(--broder-blauw) !important;
  position:relative;overflow:hidden;
  border-radius:14px 14px 14px 4px !important;
  padding:40px 32px !important;
  border:none !important;
}
.brand-cta::after{
  content:"";position:absolute;top:0;right:0;width:200px;height:200px;
  background:var(--broder-rood);opacity:.22;
  border-radius:0 0 0 140px;
  pointer-events:none;
}
.brand-cta h2{color:#fff !important;font-size:26px !important;font-weight:800 !important;letter-spacing:-.015em !important;text-transform:none !important}
.brand-cta p{color:#fff !important;opacity:.85}
.brand-cta .btn{
  color:var(--broder-blauw) !important;background:#fff !important;
  font-weight:700 !important;border-radius:10px !important;
  padding:12px 22px !important;
}

/* ---- Promoted / sponsored ---- */
.promoted-banner, .sponsored-tag{
  background:var(--broder-rood-22) !important;color:var(--broder-rood) !important;
  border-color:var(--broder-rood) !important;
  border-radius:99px !important;font-weight:600 !important;letter-spacing:.04em !important;text-transform:uppercase !important;font-size:10px !important;
}

/* ---- Article / review cards ---- */
.article-card{
  background:#fff !important;border:1px solid var(--broder-cream-edge) !important;
  border-radius:var(--radius) !important;padding:20px !important;
  transition:all .15s;
}
.article-card:hover{
  border-color:var(--broder-rood) !important;transform:translateY(-2px);
  box-shadow:0 10px 24px -8px rgba(34,62,66,.14) !important;
}
.article-card .source{color:var(--broder-rood) !important;font-size:10px !important;letter-spacing:.14em !important}
.article-card .title{color:var(--broder-blauw) !important;font-size:16px !important;font-weight:700 !important;letter-spacing:-.005em !important;line-height:1.3}
.article-card .descr{color:var(--broder-zwart) !important;opacity:.7}

/* ---- Review section bullets ---- */
.review-verdict{
  background:var(--broder-cream) !important;
  border-left:4px solid var(--broder-rood) !important;
  border-radius:0 var(--radius-sm) var(--radius-sm) 0 !important;
}
.review-section.pros li::before{background:var(--c-green) !important}
.review-section.cons li::before{background:var(--broder-rood) !important}

/* ---- Tables ---- */
table{border-radius:var(--radius);overflow:hidden}
table th{
  background:var(--broder-blauw) !important;color:#fff !important;
  font-weight:600 !important;letter-spacing:.04em !important;
  text-transform:uppercase !important;font-size:11px !important;
  padding:10px 12px !important;
}
table td{padding:9px 12px !important;border-bottom:1px solid var(--broder-cream-edge) !important;font-family:'JetBrains Mono',ui-monospace,monospace !important;font-variant-numeric:tabular-nums}
table td:first-child{font-family:'Montserrat',sans-serif !important;font-weight:500 !important}
table tr:hover td{background:var(--broder-cream) !important}

/* ---- Status box ---- */
.status-box{padding:12px 16px !important;border-radius:10px !important;font-size:13px !important;font-weight:500}
.status-box.ok{background:var(--c-green-bg) !important;border:1px solid #a8c8b3 !important;color:#1f6d4e !important}
.status-box.err{background:var(--broder-rood-22) !important;border:1px solid #e0a8a3 !important;color:var(--broder-rood) !important}

/* ---- Now banner (huidige prijs hero) ---- */
.now-banner{
  background:linear-gradient(135deg, var(--broder-blauw), var(--broder-blauw-hover)) !important;
  color:#fff !important;border:none !important;
  border-radius:var(--radius) !important;padding:24px 28px !important;position:relative;overflow:hidden;
}
.now-banner::after{content:"";position:absolute;top:0;right:0;width:140px;height:140px;background:var(--broder-rood);opacity:.22;border-radius:0 0 0 100px;pointer-events:none}
.now-banner *{color:#fff !important}

/* ---- Footer ---- */
.footer{font-size:12px !important;color:var(--broder-zwart) !important;opacity:.55;padding:24px 0 !important;border-top:1px solid var(--broder-cream-edge) !important;margin-top:32px !important}
.footer strong{opacity:1;color:var(--broder-blauw) !important}

/* ---- Suppliers (gehouden, zelfde maar matched op brand) ---- */
.supplier{
  background:var(--broder-cream-soft) !important;
  border:1px solid var(--broder-cream-edge) !important;
  border-radius:var(--radius-sm) !important;
  border-left-width:4px !important;
  padding:14px 16px !important;
}
.supplier .name{color:var(--broder-zwart) !important;font-weight:700 !important;font-size:14px !important}
.supplier .markup{color:var(--broder-zwart) !important;opacity:.65;font-size:12px;font-family:'JetBrains Mono',monospace !important;font-variant-numeric:tabular-nums}
.supplier .extra{color:var(--broder-zwart) !important;opacity:.55;font-size:12px;margin-top:6px;line-height:1.45}
