/* ============================================================
   KAPUUT — designsysteem voor het consumentenportal
   Definitieve merkrichting (Brandkit Kapuut):
   • Paars #401268 = merk- & actie-leider
   • Groen #7ed957 = merkaccent (wordmark, mascotte, highlights)
   • Veiligheid heeft een EIGEN semantische set die nooit
     merk-thematisch verkleurt. Betekenis gaat boven branding.
   • Eén lettertype: Inter ("zonder poespas").

   Alles scoped onder .fk zodat het de canvas-chrome nooit raakt.
   Class-based & semantisch → direct invulbaar in de SEO-generator.
   ============================================================ */

:root{
  /* — MERK — */
  --purple:#401268;        /* primair · koppen op licht · donkere hero */
  --purple-700:#310d50;    /* hover / diepte */
  --purple-900:#1f0733;
  --purple-200:#cdbbe0;
  --purple-100:#e7dcf1;
  --purple-50:#f3eef9;     /* lavendel oppervlak */

  --lime:#7ed957;          /* merkaccent · NOOIT als status */
  --lime-600:#5cb840;
  --lime-700:#46992f;
  --lime-100:#ecf8e1;
  --lime-50:#f4fbee;

  --blue:#2e5cb8;          /* secundaire actie */
  --blue-600:#264c99;
  --blue-light:#5b8fd9;
  --blue-dark:#1a2b5e;
  --blue-50:#eaf0fb;

  /* — INKT & DRAGERS — */
  --ink:#1a1a2e;           /* bodytekst op licht */
  --ink-2:#6c6c80;         /* secundaire tekst */
  --ink-3:#9897a8;         /* gedempt */
  --bg:#eef1f5;            /* lichte app-achtergrond · koel grijs-blauw */
  --bg-2:#e4e8ef;
  --paper:#ffffff;
  --surf:#e9eef5;          /* koel oppervlak (vervangt lavendel) */
  --surf-line:#d7dfea;
  --dark:#1a1a2e;          /* donkere achtergrond */
  --dark-2:#262640;
  --line:#e2e6ec;
  --line-2:#d0d6e0;

  /* — VEILIGHEID · functioneel statussysteem (onaantastbaar) —
       Bewust losgekoppeld van het merkgroen #7ed957: de 'veilig'-
       kleur is een diepere, koelere emerald die nooit met het
       speelse limegroen verward kan worden. Altijd icoon + label. */
  --safe:#0f8a4d;   --safe-ink:#0a5c34; --safe-bg:#e6f4ec; --safe-line:#aedcc3;
  --warn:#e07b18;   --warn-ink:#8a4a06; --warn-bg:#fdefda; --warn-line:#f5cf99;
  --danger:#d51f1f; --danger-ink:#8e1212; --danger-bg:#fce7e7; --danger-line:#f1b9b9;
  --danger-strong:#c01717;

  /* — RADII — */
  --r-xs:8px; --r-sm:12px; --r-md:16px; --r-lg:22px; --r-xl:30px; --r-pill:999px;

  /* — SPACING SCHAAL — */
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:24px; --s-6:32px; --s-7:48px; --s-8:64px;

  /* — SCHADUW — */
  --sh-sm:0 1px 2px rgba(26,26,46,.05), 0 2px 8px rgba(26,26,46,.05);
  --sh-md:0 2px 6px rgba(26,26,46,.06), 0 14px 30px rgba(26,26,46,.08);
  --sh-lg:0 10px 24px rgba(26,26,46,.09), 0 32px 64px rgba(26,26,46,.13);
  --sh-purple:0 1px 0 rgba(0,0,0,.03), 0 8px 20px rgba(64,18,104,.22);
  --sh-lime:0 1px 0 rgba(0,0,0,.03), 0 8px 18px rgba(92,184,64,.30);

  --sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
}

.fk, .fk *{ box-sizing:border-box; }
.fk{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-feature-settings:"cv11","ss01";
  line-height:1.55;
  font-size:16px;
  position:relative;
}
.fk h1,.fk h2,.fk h3,.fk h4,.fk h5{ margin:0; font-weight:800; letter-spacing:-.02em; line-height:1.08; color:var(--purple); }
.fk p{ margin:0; }
.fk a{ color:inherit; text-decoration:none; }
.fk button{ font-family:inherit; cursor:pointer; }
.fk img{ max-width:100%; display:block; }
.fk ul{ margin:0; padding:0; list-style:none; }
.fk ::selection{ background:var(--lime); color:var(--purple); }

/* ---------- TYPESCHAAL ---------- */
.fk-display{ font-size:60px; font-weight:800; letter-spacing:-.035em; line-height:1.0; color:var(--purple); }
.fk-h1{ font-size:40px; font-weight:800; letter-spacing:-.028em; line-height:1.08; }
.fk-h2{ font-size:28px; font-weight:800; letter-spacing:-.02em; line-height:1.12; }
.fk-h3{ font-size:20px; font-weight:700; letter-spacing:-.01em; line-height:1.2; }
.fk-h4{ font-size:16px; font-weight:700; letter-spacing:-.005em; }
.fk-body{ font-size:16px; line-height:1.6; color:var(--ink); }
.fk-lede{ font-size:19px; line-height:1.6; color:var(--ink-2); font-weight:400; }
.fk-small{ font-size:14px; line-height:1.5; color:var(--ink-2); }
.fk-label{ font-size:13px; font-weight:600; color:var(--ink-2); }
.fk-eyebrow{ font-family:var(--sans); font-weight:700; font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--lime-700); }
.fk-eyebrow--purple{ color:var(--purple); }
.fk-eyebrow--mute{ color:var(--ink-3); }
.fk-muted{ color:var(--ink-3); }
.fk-soft{ color:var(--ink-2); }
.fk-mono{ font-variant-numeric:tabular-nums; font-feature-settings:"tnum"; }

/* ---------- WORDMARK ---------- */
.fk-wordmark{ font-family:var(--sans); font-weight:800; letter-spacing:-.04em; line-height:1; white-space:nowrap; display:inline-flex; align-items:baseline; }
.fk-wordmark .fk-wm-fiks{ color:var(--purple); }
.fk-wordmark .fk-wm-t{ color:var(--lime-600); }
.fk-wordmark--ondark .fk-wm-fiks{ color:#fff; }
.fk-wordmark--ondark .fk-wm-t{ color:var(--lime); }

/* ---------- KNOPPEN ---------- */
.fk-btn{ display:inline-flex; align-items:center; justify-content:center; gap:9px; border:none; border-radius:var(--r-pill);
  font-family:var(--sans); font-weight:700; font-size:15px; line-height:1; padding:13px 22px;
  transition:transform .12s ease, box-shadow .15s ease, background .15s ease; white-space:nowrap; }
.fk-btn svg{ width:18px; height:18px; flex:0 0 auto; }
.fk-btn--primary{ background:var(--purple); color:#fff; box-shadow:var(--sh-purple); }
.fk-btn--primary:hover{ transform:translateY(-1px); background:var(--purple-700); }
.fk-btn--lime{ background:var(--lime); color:var(--purple); box-shadow:var(--sh-lime); font-weight:800; }
.fk-btn--lime:hover{ transform:translateY(-1px); background:#74cf4d; }
.fk-btn--secondary{ background:var(--blue); color:#fff; box-shadow:0 6px 16px rgba(46,92,184,.22); }
.fk-btn--secondary:hover{ transform:translateY(-1px); background:var(--blue-600); }
.fk-btn--ghost{ background:var(--paper); color:var(--purple); box-shadow:inset 0 0 0 1.5px var(--line-2); }
.fk-btn--ghost:hover{ box-shadow:inset 0 0 0 1.5px var(--blue-light); }
.fk-btn--danger{ background:var(--danger); color:#fff; box-shadow:0 6px 16px rgba(213,31,31,.26); }
.fk-btn--danger:hover{ transform:translateY(-1px); background:var(--danger-strong); }
.fk-btn--lg{ font-size:17px; padding:16px 28px; }
.fk-btn--sm{ font-size:13.5px; padding:9px 15px; }
.fk-btn--block{ width:100%; }

.fk-link{ color:var(--purple); font-weight:700; display:inline-flex; align-items:center; gap:6px; border-bottom:2px solid var(--lime); padding-bottom:1px; }
.fk-link svg{ width:15px; height:15px; }
.fk-link:hover{ color:var(--lime-700); }

/* ---------- CHIPS ---------- */
.fk-chip{ display:inline-flex; align-items:center; gap:8px; padding:9px 15px; border-radius:var(--r-pill); white-space:nowrap;
  background:var(--paper); box-shadow:inset 0 0 0 1.5px var(--line-2); font-weight:600; font-size:14.5px; color:var(--ink); transition:box-shadow .14s, transform .12s; }
.fk-chip:hover{ box-shadow:inset 0 0 0 1.5px var(--blue-light); transform:translateY(-1px); }
.fk-chip svg{ width:16px; height:16px; color:var(--ink-3); }
.fk-chip .fk-mono{ color:var(--purple); font-weight:700; }

/* ---------- WEERGAVE-BADGES (display / knippercode / app / servicetool) ---------- */
.fk-badge{ display:inline-flex; align-items:center; gap:7px; padding:6px 12px; border-radius:var(--r-xs); font-size:12.5px; font-weight:700; letter-spacing:.01em; white-space:nowrap;
  background:var(--surf); color:var(--purple); box-shadow:inset 0 0 0 1.3px var(--surf-line); }
.fk-badge svg{ width:14px; height:14px; }
.fk-badge--blink{ background:var(--blue-50); color:var(--blue-dark); box-shadow:inset 0 0 0 1.3px #cfdcf2; }

/* ---------- CODE-BADGE (de grote foutcode) ---------- */
.fk-code{ font-family:var(--sans); font-weight:800; letter-spacing:-.03em; line-height:1; white-space:nowrap; color:var(--purple);
  font-variant-numeric:tabular-nums; }

/* ---------- KAARTEN ---------- */
.fk-card{ background:var(--paper); border-radius:var(--r-lg); box-shadow:var(--sh-sm); border:1px solid var(--line); }
.fk-card--flat{ box-shadow:none; }
.fk-card--lav{ background:var(--surf); border-color:var(--surf-line); }

/* ---------- VEILIGHEIDSBANNER (de harde eis · onmiskenbaar) ----------
   Gas/CO/elektra. Dominant, niet merk-thematisch verkleurbaar. */
.fk-safety{ display:flex; gap:16px; border-radius:var(--r-md); padding:20px 22px; border:2px solid; position:relative; }
.fk-safety__ico{ width:48px; height:48px; border-radius:14px; flex:0 0 auto; display:flex; align-items:center; justify-content:center; color:#fff; }
.fk-safety__ico svg{ width:27px; height:27px; }
.fk-safety__title{ font-size:20px; font-weight:800; letter-spacing:-.01em; line-height:1.15; margin-bottom:5px; }
.fk-safety__body{ font-size:15.5px; line-height:1.55; }
.fk-safety--danger{ background:var(--danger-bg); border-color:var(--danger); }
.fk-safety--danger .fk-safety__ico{ background:var(--danger); }
.fk-safety--danger .fk-safety__title{ color:var(--danger-ink); }
.fk-safety--danger .fk-safety__body{ color:#7a1414; }
.fk-safety--warn{ background:var(--warn-bg); border-color:var(--warn); }
.fk-safety--warn .fk-safety__ico{ background:var(--warn); }
.fk-safety--warn .fk-safety__title{ color:var(--warn-ink); }
.fk-safety--warn .fk-safety__body{ color:#8a5410; }

/* noodinstructie-lijst binnen veiligheidsbanner */
.fk-noodstep{ display:flex; gap:11px; align-items:flex-start; font-size:15px; line-height:1.5; font-weight:600; color:var(--danger-ink); }
.fk-noodstep__n{ width:24px; height:24px; flex:0 0 auto; border-radius:7px; background:var(--danger); color:#fff; display:flex; align-items:center; justify-content:center; font-size:13px; font-weight:800; }

/* ---------- TRIAGE / ERNST-INDICATOR ----------
   Rustige, label-gedreven indicatie. Kleur alleen waar het telt. */
.fk-triage{ display:flex; align-items:flex-start; gap:14px; border-radius:var(--r-md); padding:16px 18px; border:1.5px solid; }
.fk-triage__dot{ width:40px; height:40px; border-radius:12px; flex:0 0 auto; display:flex; align-items:center; justify-content:center; color:#fff; }
.fk-triage__dot svg{ width:22px; height:22px; }
.fk-triage__label{ font-weight:800; font-size:16px; line-height:1.2; }
.fk-triage__sub{ font-size:14.5px; line-height:1.45; margin-top:3px; }
.fk-triage--safe{ background:var(--safe-bg); border-color:var(--safe-line); }
.fk-triage--safe .fk-triage__dot{ background:var(--safe); } .fk-triage--safe .fk-triage__label{ color:var(--safe-ink); } .fk-triage--safe .fk-triage__sub{ color:#256e47; }
.fk-triage--warn{ background:var(--warn-bg); border-color:var(--warn-line); }
.fk-triage--warn .fk-triage__dot{ background:var(--warn); } .fk-triage--warn .fk-triage__label{ color:var(--warn-ink); } .fk-triage--warn .fk-triage__sub{ color:#9a5a12; }
.fk-triage--stop{ background:var(--danger-bg); border-color:var(--danger-line); }
.fk-triage--stop .fk-triage__dot{ background:var(--danger); } .fk-triage--stop .fk-triage__label{ color:var(--danger-ink); } .fk-triage--stop .fk-triage__sub{ color:#8a1818; }
.fk-triage--neutral{ background:var(--bg); border-color:var(--line-2); }
.fk-triage--neutral .fk-triage__dot{ background:var(--ink-2); } .fk-triage--neutral .fk-triage__label{ color:var(--ink); } .fk-triage--neutral .fk-triage__sub{ color:var(--ink-2); }

/* stoplicht — 3 stops, actieve gevuld */
.fk-semaphore{ display:inline-flex; align-items:center; gap:6px; }
.fk-semaphore__d{ width:10px; height:10px; border-radius:50%; }
.fk-semaphore__d--safe{ background:var(--safe); } .fk-semaphore__d--warn{ background:var(--warn); } .fk-semaphore__d--stop{ background:var(--danger); }
.fk-semaphore__d--ghost{ box-shadow:inset 0 0 0 2px currentColor; background:transparent; opacity:.35; }

/* status-tag (klein) */
.fk-tag{ display:inline-flex; align-items:center; gap:6px; padding:5px 11px; border-radius:8px; font-size:12.5px; font-weight:700; white-space:nowrap; }
.fk-tag svg{ width:13px; height:13px; }
.fk-tag--safe{ background:var(--safe-bg); color:var(--safe-ink); box-shadow:inset 0 0 0 1.3px var(--safe-line); }
.fk-tag--warn{ background:var(--warn-bg); color:var(--warn-ink); box-shadow:inset 0 0 0 1.3px var(--warn-line); }
.fk-tag--stop{ background:var(--danger-bg); color:var(--danger-ink); box-shadow:inset 0 0 0 1.3px var(--danger-line); }
.fk-tag--brand{ background:var(--surf); color:var(--purple); box-shadow:inset 0 0 0 1.3px var(--surf-line); }

/* ---------- GENUMMERDE STAPPEN (eerste checks) ---------- */
.fk-step{ display:flex; gap:15px; align-items:flex-start; }
.fk-step__n{ width:34px; height:34px; flex:0 0 auto; border-radius:11px; display:flex; align-items:center; justify-content:center;
  font-weight:800; font-size:15px; background:var(--purple); color:#fff; }
.fk-step__t{ font-weight:700; font-size:16px; margin-bottom:2px; color:var(--ink); }
.fk-step__b{ font-size:15px; color:var(--ink-2); line-height:1.5; }

/* ---------- OORZAKEN-LIJST ---------- */
.fk-cause{ display:flex; gap:12px; align-items:flex-start; font-size:15.5px; line-height:1.5; color:var(--ink); padding:11px 0; border-bottom:1px solid var(--line); }
.fk-cause:last-child{ border-bottom:0; }
.fk-cause__b{ width:7px; height:7px; border-radius:50%; background:var(--lime-600); flex:0 0 auto; margin-top:8px; }

/* ---------- BRONCITAAT ---------- */
.fk-cite{ border-left:3px solid var(--blue-light); background:var(--surf); border-radius:0 var(--r-sm) var(--r-sm) 0; padding:16px 20px; }
.fk-cite__q{ font-size:15.5px; line-height:1.6; color:var(--ink); font-style:italic; }
.fk-cite__src{ font-size:13px; color:var(--ink-2); font-weight:600; margin-top:9px; display:flex; align-items:center; gap:7px; }
.fk-cite__src svg{ width:14px; height:14px; color:var(--purple); }

/* ---------- FAQ-ACCORDION ---------- */
.fk-faq{ border:1px solid var(--line); border-radius:var(--r-md); background:var(--paper); overflow:hidden; }
.fk-faq__item{ border-bottom:1px solid var(--line); }
.fk-faq__item:last-child{ border-bottom:0; }
.fk-faq__q{ display:flex; align-items:center; justify-content:space-between; gap:14px; padding:18px 20px; font-weight:700; font-size:16px; color:var(--purple); cursor:pointer; }
.fk-faq__q svg{ width:18px; height:18px; color:var(--ink-3); flex:0 0 auto; transition:transform .2s; }
.fk-faq__item--open .fk-faq__q svg{ transform:rotate(180deg); }
.fk-faq__a{ padding:0 20px 18px; font-size:15px; line-height:1.6; color:var(--ink-2); }

/* ---------- ZOEK ---------- */
.fk-search{ display:flex; align-items:center; gap:12px; background:var(--paper); border-radius:var(--r-pill);
  box-shadow:var(--sh-md), inset 0 0 0 1.5px var(--line); padding:8px 8px 8px 22px; }
.fk-search__ico{ width:22px; height:22px; color:var(--purple); flex:0 0 auto; }
.fk-search input{ border:none; outline:none; flex:1; font-family:var(--sans); font-size:17px; font-weight:500; color:var(--ink); background:transparent; min-width:0; }
.fk-search input::placeholder{ color:var(--ink-3); font-weight:500; }

/* ---------- VIND-EEN-MONTEUR CTA-BLOK ---------- */
.fk-cta{ border-radius:var(--r-lg); padding:26px 28px; background:var(--purple); color:#fff; display:flex; align-items:center; gap:22px; }
.fk-cta--lime{ background:var(--lime); color:var(--purple); }
.fk-cta h3{ color:inherit; }
.fk-cta--danger{ background:var(--dark); color:#fff; }

/* ---------- GERELATEERD / LINKLIJST ---------- */
.fk-linkrow{ display:flex; align-items:center; justify-content:space-between; gap:12px; padding:14px 16px; border-radius:var(--r-sm);
  background:var(--paper); border:1px solid var(--line); transition:border-color .14s, transform .12s; }
.fk-linkrow:hover{ border-color:var(--blue-light); transform:translateX(2px); }
.fk-linkrow svg{ color:var(--ink-3); }

/* ---------- BREADCRUMB ---------- */
.fk-crumb{ display:flex; align-items:center; gap:9px; font-size:13.5px; font-weight:600; color:var(--ink-3); flex-wrap:wrap; }
.fk-crumb a{ white-space:nowrap; }
.fk-crumb svg{ width:13px; height:13px; opacity:.6; }
.fk-crumb a:hover{ color:var(--purple); }
.fk-crumb .fk-crumb__last{ color:var(--ink); }

/* ---------- HEADER / NAV ---------- */
.fk-nav{ display:flex; align-items:center; justify-content:space-between; }
.fk-nav__links{ display:flex; align-items:center; gap:26px; font-weight:600; font-size:15px; color:var(--ink-2); }
.fk-nav__links a:hover{ color:var(--purple); }

/* ---------- FOOTER ---------- */
.fk-footer{ background:var(--dark); color:#fff; }
.fk-footer a{ color:rgba(255,255,255,.72); }
.fk-footer a:hover{ color:var(--lime); }

/* ---------- LEGE STAAT ---------- */
.fk-empty{ border:1.5px dashed var(--line-2); border-radius:var(--r-md); background:var(--bg); padding:20px 22px; color:var(--ink-3); font-size:14.5px; display:flex; align-items:center; gap:12px; }
.fk-empty svg{ width:18px; height:18px; flex:0 0 auto; }

/* ---------- DIVIDER ---------- */
.fk-hr{ height:1px; background:var(--line); border:0; margin:0; }

/* ---------- DEVICE FRAMES ---------- */
.fk-phone{ width:412px; background:#0d0a14; border-radius:48px; padding:11px; box-shadow:var(--sh-lg); }
.fk-phone__screen{ background:var(--bg); border-radius:38px; overflow:hidden; position:relative; }
.fk-statusbar{ height:50px; display:flex; align-items:center; justify-content:space-between; padding:0 26px 0 30px;
  font-size:14px; font-weight:700; color:var(--ink); }
.fk-statusbar__r{ display:flex; gap:7px; align-items:center; }
.fk-notch{ position:absolute; top:11px; left:50%; transform:translateX(-50%); width:120px; height:30px; background:#0d0a14; border-radius:18px; z-index:5; }

.fk-browser{ border-radius:14px 14px 0 0; overflow:hidden; box-shadow:var(--sh-lg); background:#fff; }
.fk-browser__bar{ height:46px; background:#e6eaf1; display:flex; align-items:center; gap:8px; padding:0 16px; border-bottom:1px solid var(--line); }
.fk-browser__dot{ width:12px; height:12px; border-radius:50%; }
.fk-browser__url{ flex:1; height:28px; background:#fff; border-radius:8px; margin-left:10px; display:flex; align-items:center; padding:0 14px; font-size:13px; color:var(--ink-3); box-shadow:inset 0 0 0 1px var(--line); }

/* ---------- MASCOTTE-BUBBEL ---------- */
.fk-bubble{ position:relative; background:#fff; border:1.5px solid var(--line-2); border-radius:16px; padding:12px 16px; font-size:15px; font-weight:600; color:var(--ink); box-shadow:var(--sh-sm); }
.fk-bubble::after{ content:""; position:absolute; left:-9px; top:22px; width:16px; height:16px; background:#fff; border-left:1.5px solid var(--line-2); border-bottom:1.5px solid var(--line-2); transform:rotate(45deg); }

/* ---------- SWATCH (foundation) ---------- */
.fk-sw{ border-radius:14px; height:80px; box-shadow:inset 0 0 0 1px rgba(0,0,0,.06); display:flex; align-items:flex-end; padding:10px 12px; }
.fk-sw__c{ font-size:12px; font-weight:700; }
.fk-sw__h{ font-size:10.5px; font-weight:600; opacity:.82; font-variant-numeric:tabular-nums; }

/* ---------- TEGEL (categorie) ---------- */
.fk-tile{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:20px; transition:border-color .14s, transform .12s, box-shadow .15s; cursor:pointer; }
.fk-tile:hover{ border-color:var(--blue-light); transform:translateY(-2px); box-shadow:var(--sh-md); }
.fk-tile__ico{ width:46px; height:46px; border-radius:13px; background:var(--surf); color:var(--purple); display:flex; align-items:center; justify-content:center; margin-bottom:14px; }
.fk-tile__ico svg{ width:24px; height:24px; }


/* ---- Kapuut layout (static generator) ---- */
.kx-header{padding:20px 40px;max-width:1200px;margin:0 auto}
.kx-header__l{display:flex;align-items:center;gap:40px}
.kx-wrap{max-width:1120px;margin:0 auto;padding:24px 40px 64px}
.kx-h1{font-size:40px}.kx-codebig{font-size:40px}.kx-display{font-size:54px;margin:10px 0 6px}
.kx-detail{display:grid;grid-template-columns:1.6fr .9fr;gap:32px;margin-top:28px;align-items:start}
.kx-main{display:flex;flex-direction:column;gap:26px;min-width:0}
.kx-uitleg{font-size:16.5px;line-height:1.65}
.kx-checks{padding:28px}
.kx-side{display:flex;flex-direction:column;gap:16px}
.kx-sidecard{padding:20px}
.kx-ctacard{flex-direction:column;align-items:flex-start;gap:12px;padding:22px}
.kx-cta__p{font-size:14.5px;line-height:1.5;opacity:.92}
.fk-cta--lime .kx-cta__p{color:var(--purple)}
.fk-cta--danger .kx-cta__p{color:rgba(255,255,255,.82)}
.kx-related-wrap{margin-top:44px}
.kx-related{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.kx-codelist{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:24px}
.kx-tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}
.kx-hero{padding:24px 0 36px}
.kx-herosearch{max-width:560px;margin-top:22px}
.kx-article{max-width:720px}
.kx-footer{margin-top:56px}
.kx-footer__top{max-width:1120px;margin:0 auto;padding:52px 40px 0;display:flex;gap:60px;justify-content:space-between;flex-wrap:wrap}
.kx-footer__brand{max-width:320px}.kx-footer__brand p{color:rgba(255,255,255,.64);font-size:14.5px;margin-top:14px;line-height:1.55}
.kx-footer__cols{display:grid;grid-template-columns:repeat(3,auto);gap:56px}
.kx-footer__h{font-weight:800;font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;color:#fff;margin-bottom:14px}
.kx-footer__cols a{display:block;font-size:14.5px;margin-bottom:11px}
.kx-footer__bar{max-width:1120px;margin:22px auto 0;padding:22px 40px 34px;border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:13px;color:rgba(255,255,255,.5)}
.kx-footer__bar a{margin-left:18px}
@media(max-width:860px){
  .kx-header{padding:16px 18px}.kx-navlinks{display:none}
  .kx-wrap{padding:18px 18px 48px}
  .kx-detail{grid-template-columns:1fr;gap:22px}
  .kx-related{grid-template-columns:1fr}.kx-codelist{grid-template-columns:1fr}
  .kx-h1,.kx-codebig{font-size:30px}.kx-display{font-size:34px}
  .kx-footer__top{padding:34px 18px 0;gap:28px}.kx-footer__cols{grid-template-columns:1fr 1fr;gap:24px 36px}
  .kx-footer__bar{padding:18px 18px 26px}
}
/* ---- cookiebanner ---- */
.kx-cookie{position:fixed;left:0;right:0;bottom:0;z-index:90;background:var(--purple,#401268);color:#fff;box-shadow:0 -8px 30px rgba(0,0,0,.18)}
.kx-cookie[hidden]{display:none}
.kx-cookie__in{max-width:1120px;margin:0 auto;padding:16px 40px;display:flex;align-items:center;gap:24px;flex-wrap:wrap;justify-content:space-between}
.kx-cookie__txt{display:flex;flex-direction:column;gap:3px;font-size:14px;max-width:700px;line-height:1.45}
.kx-cookie__txt strong{font-size:15px;font-weight:800}
.kx-cookie__txt a{color:var(--lime,#7ED957);text-decoration:underline}
.kx-cookie__btns{display:flex;gap:10px;flex-shrink:0}
.kx-cc{border-radius:var(--r-pill,999px);padding:11px 20px;font-weight:700;font-size:14px;cursor:pointer;border:1.5px solid transparent;font-family:inherit}
.kx-cc--accept{background:var(--lime,#7ED957);color:var(--purple,#401268)}
.kx-cc--reject{background:transparent;color:#fff;border-color:rgba(255,255,255,.45)}
.kx-cc--reject:hover{border-color:#fff}
@media(max-width:860px){
  .kx-cookie__in{padding:14px 18px;gap:12px}
  .kx-cookie__btns{width:100%}.kx-cc{flex:1}
}