:root {
  --kbm-ink: #17202a;
  --kbm-paper: #f6f3ea;
  --kbm-accent: #1f8a70;
  --kbm-calm: #b04d66;
  --kbm-gold: #f1b84b;
  --kbm-soft: color-mix(in srgb, var(--kbm-paper) 82%, white);
  --kbm-line: color-mix(in srgb, var(--kbm-ink) 14%, transparent);
  --kbm-shade: 0 24px 70px rgba(16, 18, 25, .16);
  --kbm-curve: 20px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body.kbm-canvas { margin: 0; font-family: "Rubik", system-ui, sans-serif; color: var(--kbm-ink); background: var(--kbm-paper); line-height: 1.6; }
a { color: inherit; }
.kbm-mast { position: sticky; top: 0; z-index: 20; display: flex; align-items: center; gap: 22px; padding: 16px clamp(18px, 4vw, 54px); background: color-mix(in srgb, var(--kbm-paper) 90%, white); border-bottom: 1px solid var(--kbm-line); backdrop-filter: blur(18px); }
.kbm-mark { font-family: "DM Serif Display", serif; font-size: clamp(22px, 2vw, 31px); text-decoration: none; letter-spacing: 0; margin-right: auto; }
.kbm-navline, .kbm-footnav, .kbm-legalrow { display: flex; gap: 18px; flex-wrap: wrap; align-items: center; }
.kbm-navline a, .kbm-footnav a, .kbm-legalrow a { text-decoration: none; font-size: 14px; }
.kbm-menubtn { display: none; border: 1px solid var(--kbm-line); background: white; padding: 10px 14px; border-radius: 999px; }
.kbm-drawer { display: none; position: absolute; right: 18px; top: 68px; width: min(320px, calc(100vw - 36px)); padding: 18px; border: 1px solid var(--kbm-line); border-radius: var(--kbm-curve); background: white; box-shadow: var(--kbm-shade); }
.kbm-drawer a { display: block; padding: 9px 4px; text-decoration: none; }
.kbm-drawer.kbm-open { display: block; }
.kbm-main { overflow: hidden; }
.kbm-hero { min-height: 78vh; padding: clamp(70px, 10vw, 126px) clamp(18px, 5vw, 72px) 46px; display: grid; gap: 34px; align-items: center; position: relative; }
.kbm-hero::before { content: ""; position: absolute; inset: 18px; border: 1px solid var(--kbm-line); border-radius: calc(var(--kbm-curve) + 16px); pointer-events: none; }
.kbm-hero-split, .kbm-hero-cards, .kbm-hero-trust { grid-template-columns: minmax(0, 1.05fr) minmax(280px, .95fr); }
.kbm-hero-center { text-align: center; justify-items: center; }
.kbm-hero-editorial { grid-template-columns: .3fr 1fr .7fr; }
.kbm-herotext, .kbm-skyplot, .kbm-cardstack, .kbm-minicloud, .kbm-trustbar, .kbm-heronote { position: relative; z-index: 1; }
.kbm-eyebrow, .kbm-sectionhead p, .kbm-lettercopy > p:first-child { text-transform: uppercase; font-size: 12px; letter-spacing: .08em; color: var(--kbm-accent); font-weight: 700; }
.kbm-hero h1, .kbm-band h2, .kbm-doc h1, .kbm-doc h2 { font-family: "DM Serif Display", serif; line-height: 1.05; letter-spacing: 0; }
.kbm-hero h1 { font-size: clamp(42px, 7vw, 88px); margin: 0 0 20px; max-width: 920px; }
.kbm-hero p { max-width: 720px; font-size: clamp(17px, 2vw, 21px); }
.kbm-heroacts, .kbm-finalcall div { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 26px; }
.kbm-heroacts a, .kbm-pathcard a, .kbm-form button, .kbm-finalcall a, .kbm-consent button { border: 0; border-radius: 999px; padding: 13px 18px; text-decoration: none; background: var(--kbm-ink); color: white; font-weight: 700; cursor: pointer; }
.kbm-heroacts a:nth-child(2), .kbm-finalcall a:nth-child(2) { background: transparent; color: var(--kbm-ink); border: 1px solid var(--kbm-line); }
.kbm-skyplot { min-height: 380px; border-radius: var(--kbm-curve); background: radial-gradient(circle at 28% 20%, var(--kbm-gold), transparent 24%), linear-gradient(135deg, var(--kbm-ink), var(--kbm-calm)); color: white; padding: 30px; display: grid; align-content: end; box-shadow: var(--kbm-shade); overflow: hidden; }
.kbm-skyplot span { position: absolute; font-size: clamp(38px, 8vw, 94px); opacity: .18; }
.kbm-skyplot span:nth-child(1) { left: 12%; top: 18%; } .kbm-skyplot span:nth-child(2) { right: 18%; top: 10%; } .kbm-skyplot span:nth-child(3) { left: 45%; bottom: 26%; } .kbm-skyplot span:nth-child(4) { right: 12%; bottom: 16%; }
.kbm-cardstack, .kbm-minicloud { display: grid; gap: 14px; }
.kbm-orbcard { background: white; border: 1px solid var(--kbm-line); border-radius: var(--kbm-curve); padding: 20px; box-shadow: 0 12px 34px rgba(16,18,25,.08); }
.kbm-orbcard b { display: block; font-family: "DM Serif Display", serif; font-size: 26px; }
.kbm-trustbar, .kbm-heronote { padding: 14px 18px; border-radius: 999px; background: white; border: 1px solid var(--kbm-line); }
.kbm-band { padding: clamp(58px, 8vw, 104px) clamp(18px, 5vw, 72px); }
.kbm-sectionhead { max-width: 790px; margin-bottom: 30px; }
.kbm-sectionhead h2, .kbm-doc h1 { font-size: clamp(32px, 4.5vw, 58px); margin: 0; }
.kbm-facetgrid, .kbm-pathgrid, .kbm-voicegrid, .kbm-readgrid, .kbm-contactgrid { display: grid; gap: 18px; grid-template-columns: repeat(3, minmax(0, 1fr)); }
.kbm-facet, .kbm-pathcard, .kbm-voice, .kbm-readtile, .kbm-contactcard, .kbm-docblock, .kbm-qa, .kbm-articleblock { background: color-mix(in srgb, white 80%, var(--kbm-paper)); border: 1px solid var(--kbm-line); border-radius: var(--kbm-curve); padding: 24px; box-shadow: 0 10px 34px rgba(16,18,25,.06); }
.kbm-facet span, .kbm-readtile span, .kbm-articleblock span { color: var(--kbm-accent); font-weight: 700; }
.kbm-paths { background: color-mix(in srgb, var(--kbm-calm) 12%, var(--kbm-paper)); }
.kbm-pathcard { display: flex; flex-direction: column; justify-content: space-between; min-height: 360px; }
.kbm-pathcard em { display: inline-block; color: var(--kbm-accent); font-style: normal; font-weight: 800; margin-bottom: 8px; }
.kbm-pathcard ul { padding-left: 20px; }
.kbm-voice blockquote { margin: 0 0 18px; font-size: 18px; }
.kbm-voice figcaption span { display: block; color: color-mix(in srgb, var(--kbm-ink) 62%, transparent); }
.kbm-readtile { text-decoration: none; min-height: 210px; }
.kbm-letterbox { display: grid; grid-template-columns: .85fr 1.15fr; gap: 24px; background: var(--kbm-ink); color: white; }
.kbm-lettercopy a { color: white; font-weight: 700; }
.kbm-form { display: grid; gap: 14px; background: white; color: var(--kbm-ink); padding: 24px; border-radius: var(--kbm-curve); }
.kbm-form label { display: grid; gap: 7px; font-weight: 700; }
.kbm-form input, .kbm-form textarea { width: 100%; border: 1px solid var(--kbm-line); border-radius: 14px; padding: 13px; font: inherit; }
.kbm-formstate { min-height: 24px; margin: 0; color: var(--kbm-calm); font-weight: 700; }
.kbm-qalist { max-width: 920px; display: grid; gap: 12px; }
.kbm-qatap { width: 100%; text-align: left; border: 0; background: transparent; font: inherit; font-weight: 800; cursor: pointer; padding: 0; }
.kbm-qapanel { display: none; padding-top: 12px; }
.kbm-qa.kbm-awake .kbm-qapanel { display: block; }
.kbm-finalcall { background: linear-gradient(135deg, var(--kbm-accent), var(--kbm-calm)); color: white; }
.kbm-finalcall h2 { max-width: 880px; }
.kbm-footprint { padding: 44px clamp(18px, 5vw, 72px); background: color-mix(in srgb, var(--kbm-ink) 94%, black); color: white; }
.kbm-footgrid { display: grid; gap: 26px; }
.kbm-legalrow { color: rgba(255,255,255,.72); }
.kbm-consent { position: fixed; left: 18px; right: 18px; bottom: 18px; z-index: 30; display: none; gap: 18px; align-items: center; justify-content: space-between; padding: 16px; border-radius: var(--kbm-curve); background: white; color: var(--kbm-ink); box-shadow: var(--kbm-shade); border: 1px solid var(--kbm-line); }
.kbm-consent.kbm-show { display: flex; }
.kbm-doc { max-width: 1050px; margin: 0 auto; padding: clamp(56px, 8vw, 96px) 18px; }
.kbm-crumbs { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 22px; color: var(--kbm-accent); }
.kbm-leadline, .kbm-updated { font-size: 19px; color: color-mix(in srgb, var(--kbm-ink) 72%, transparent); }
.kbm-docblock, .kbm-articleblock { margin: 18px 0; }
.kbm-twocol { columns: 2 320px; column-gap: 20px; }
.kbm-twocol .kbm-articleblock { break-inside: avoid; }
.kbm-seealso { margin-top: 22px; padding: 22px; border-radius: var(--kbm-curve); background: color-mix(in srgb, var(--kbm-gold) 20%, white); }
.kbm-seealso a { margin-right: 14px; font-weight: 800; }
@media (max-width: 860px) {
  .kbm-navline { display: none; }
  .kbm-menubtn { display: inline-flex; }
  .kbm-hero, .kbm-hero-split, .kbm-hero-cards, .kbm-hero-trust, .kbm-hero-editorial, .kbm-letterbox { grid-template-columns: 1fr; }
  .kbm-facetgrid, .kbm-pathgrid, .kbm-voicegrid, .kbm-readgrid, .kbm-contactgrid { grid-template-columns: 1fr; }
  .kbm-hero { min-height: auto; }
  .kbm-consent { flex-direction: column; align-items: flex-start; }
}
