/* =========================================================
   {platform_name} — Regulated Markets Prospectus / White Paper
   LIGHT institutional document: porcelain ground, ink charcoal,
   deep claret accent, steel-blue secondary, hairline rules.
   Schibsted Grotesk (display) + Libre Franklin (body).
   Mobile-first.
   ========================================================= */

/* ---------- Fonts ---------- */
@font-face { font-family:"Schibsted Grotesk"; font-weight:600; font-style:normal; font-display:swap; src:url("../fonts/schibsted-600.woff2") format("woff2"),url("../fonts/schibsted-600.woff") format("woff"); }
@font-face { font-family:"Schibsted Grotesk"; font-weight:700; font-style:normal; font-display:swap; src:url("../fonts/schibsted-700.woff2") format("woff2"),url("../fonts/schibsted-700.woff") format("woff"); }
@font-face { font-family:"Schibsted Grotesk"; font-weight:800; font-style:normal; font-display:swap; src:url("../fonts/schibsted-800.woff2") format("woff2"),url("../fonts/schibsted-800.woff") format("woff"); }
@font-face { font-family:"Libre Franklin"; font-weight:400; font-style:normal; font-display:swap; src:url("../fonts/franklin-400.woff2") format("woff2"),url("../fonts/franklin-400.woff") format("woff"); }
@font-face { font-family:"Libre Franklin"; font-weight:500; font-style:normal; font-display:swap; src:url("../fonts/franklin-500.woff2") format("woff2"),url("../fonts/franklin-500.woff") format("woff"); }
@font-face { font-family:"Libre Franklin"; font-weight:600; font-style:normal; font-display:swap; src:url("../fonts/franklin-600.woff2") format("woff2"),url("../fonts/franklin-600.woff") format("woff"); }
@font-face { font-family:"Libre Franklin"; font-weight:700; font-style:normal; font-display:swap; src:url("../fonts/franklin-700.woff2") format("woff2"),url("../fonts/franklin-700.woff") format("woff"); }

/* ---------- Tokens ---------- */
:root {
  --paper: #f4f2ec;
  --paper-2: #eceae2;
  --card: #faf9f5;
  --ink: #1b1e25;
  --ink-2: #3c424e;
  --ink-soft: #5d6473;
  --ink-mute: #8b9099;
  --rule: #d3cfc4;
  --rule-strong: #bdb8aa;
  --claret: #8a2b34;
  --claret-deep: #6d2129;
  --steel: #3f5566;
  --up: #2f7a52;
  --down: #a8443a;

  --maxw: 1120px;
  --gut: 20px;

  --disp: "Schibsted Grotesk", system-ui, sans-serif;
  --body: "Libre Franklin", system-ui, -apple-system, "Segoe UI", sans-serif;
}

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--body);
  font-size: 16px;
  line-height: 1.62;
  overflow-wrap: break-word;
  word-break: normal;
  -webkit-font-smoothing: antialiased;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
ul, ol { margin: 0; padding: 0; list-style: none; }
button { font: inherit; cursor: pointer; }
:focus-visible { outline: 2px solid var(--claret); outline-offset: 2px; }
.iti__country-name {color: #111111;}

/* ---------- Primitives ---------- */
.wrap { width: 100%; max-width: var(--maxw); margin: 0 auto; padding-inline: var(--gut); }
.sec { padding-block: 56px; }
.sec--alt { background: var(--paper-2); }

.sec-index {
  display: flex; align-items: center; gap: 14px; margin: 0 0 22px;
  font-family: var(--body); font-weight: 600; font-size: 0.74rem;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-mute);
}
.sec-index__no { color: var(--claret); font-weight: 700; font-family: var(--disp); letter-spacing: 0.04em; }
.sec-index::after { content: ""; flex: 1; height: 1px; background: var(--rule); }

.h2 { font-family: var(--disp); font-weight: 700; font-size: clamp(1.6rem, 4.6vw, 2.3rem); line-height: 1.14; letter-spacing: -0.015em; margin: 0 0 14px; color: var(--ink); }
.intro { color: var(--ink-soft); max-width: 64ch; margin: 0; font-size: 1.02rem; }

/* ---------- Buttons ---------- */
.btn { display: inline-flex; align-items: center; gap: 9px; font-family: var(--disp); font-weight: 600; font-size: 0.92rem; padding: 13px 24px; border: 1.5px solid transparent; border-radius: 2px; transition: background .15s, color .15s, border-color .15s; }
.btn--claret { background: var(--claret); color: #fdf6f1; border-color: var(--claret); }
.btn--claret:hover { background: var(--claret-deep); border-color: var(--claret-deep); }
.btn--outline { background: transparent; color: var(--ink); border-color: var(--rule-strong); }
.btn--outline:hover { border-color: var(--ink); }
.btn--full { width: 100%; justify-content: center; }
.tlink { font-family: var(--disp); font-weight: 600; font-size: 0.9rem; color: var(--claret); border-bottom: 1.5px solid currentColor; padding-bottom: 1px; display: inline-flex; }
.tlink:hover { color: var(--claret-deep); }

/* ---------- Document header ---------- */
.topwrap { position: sticky; top: 0; z-index: 60; }
.credbar { background: var(--ink); color: var(--paper); }
.credbar__row { display: flex; align-items: center; justify-content: center; gap: 8px 18px; min-height: 32px; flex-wrap: wrap; font-size: 0.7rem; letter-spacing: 0.06em; padding-block: 6px; }
.credbar__lbl { color: var(--ink-mute); text-transform: uppercase; letter-spacing: 0.14em; }
.credbar__items { display: flex; gap: 14px; }
.credbar__items span { font-family: var(--disp); font-weight: 600; color: var(--paper); }
.dochead { background: rgba(244,242,236,0.94); backdrop-filter: blur(8px); border-bottom: 1px solid var(--rule-strong); }
.dochead__row { display: flex; align-items: center; justify-content: space-between; gap: 14px; height: 64px; }
.brand { display: inline-flex; align-items: center; gap: 11px; }
.brand__seal { width: 32px; height: 32px; flex: none; }
.brand__name { font-family: var(--disp); font-weight: 800; font-size: 1.16rem; letter-spacing: -0.01em; }
.brand__tag { display: block; font-size: 0.6rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-mute); margin-top: -1px; }
.docnav { display: none; align-items: center; gap: 28px; }
.docnav a { font-family: var(--disp); font-weight: 600; font-size: 0.86rem; color: var(--ink-2); }
.docnav a:hover { color: var(--claret); }
.dochead__cta { display: none; }
.burger { display: inline-flex; flex-direction: column; gap: 5px; width: 40px; height: 36px; align-items: center; justify-content: center; background: transparent; border: 1px solid var(--rule-strong); border-radius: 2px; }
.burger span { width: 17px; height: 2px; background: var(--ink); }
.tray { display: none; background: var(--card); border-bottom: 1px solid var(--rule-strong); }
.tray.show { display: block; }
.tray nav { display: flex; flex-direction: column; }
.tray nav a { padding: 13px 0; border-bottom: 1px solid var(--rule); font-family: var(--disp); font-weight: 600; font-size: 0.9rem; color: var(--ink-2); }
.tray .btn { margin: 14px 0; }

/* ---------- Hero (text-led document) ---------- */
.hero { padding-block: 52px 44px; border-bottom: 1px solid var(--rule); }
.hero__doclabel { font-family: var(--body); font-weight: 600; font-size: 0.72rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-mute); margin: 0 0 8px; }
.hero__eyebrow { font-family: var(--disp); font-weight: 600; font-size: 0.84rem; letter-spacing: 0.04em; color: var(--claret); margin: 0 0 18px; display: inline-flex; align-items: center; gap: 10px; }
.hero__eyebrow::before { content: ""; width: 24px; height: 2px; background: var(--claret); }
.hero__title { font-family: var(--disp); font-weight: 800; font-size: clamp(2.2rem, 7vw, 3.7rem); line-height: 1.04; letter-spacing: -0.025em; margin: 0 0 20px; max-width: 16ch; }
.hero__lead { color: var(--ink-soft); font-size: 1.1rem; margin: 0 0 26px; max-width: 60ch; }
.hero__actions { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }
.hero__rating { display: flex; align-items: center; gap: 12px; margin-top: 28px; padding-top: 22px; border-top: 1px solid var(--rule); }
.hero__stars { color: var(--claret); letter-spacing: 2px; font-size: 0.95rem; }
.hero__rating-v { font-family: var(--disp); font-weight: 700; font-size: 1.1rem; }
.hero__rating-n { font-size: 0.86rem; color: var(--ink-mute); }
.hero__stats { display: flex; gap: 36px; margin-top: 24px; }
.hero__stat-v { font-family: var(--disp); font-weight: 800; font-size: 1.7rem; color: var(--ink); letter-spacing: -0.02em; }
.hero__stat-l { font-size: 0.8rem; color: var(--ink-mute); }

/* ---------- Feature columns ---------- */
.feat { display: grid; gap: 0; margin-top: 28px; border-top: 2px solid var(--ink); }
.feat__col { padding: 24px 0; border-bottom: 1px solid var(--rule); }
.feat__tag { font-family: var(--body); font-weight: 700; font-size: 0.7rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--claret); }
.feat__title { font-family: var(--disp); font-weight: 700; font-size: 1.3rem; margin: 8px 0 8px; }
.feat__text { color: var(--ink-soft); margin: 0; font-size: 0.95rem; }

/* ---------- Dashboard ---------- */
.dash__grid { display: grid; gap: 30px; }
.dash__panel { border: 1px solid var(--rule-strong); border-radius: 4px; background: var(--card); box-shadow: 0 14px 40px -28px rgba(27,30,37,0.5); }
.dash__panel-bar { display: flex; align-items: center; justify-content: space-between; padding: 13px 16px; border-bottom: 1px solid var(--rule); }
.dash__panel-title { font-family: var(--disp); font-weight: 700; font-size: 0.92rem; }
.dash__panel-tag { font-size: 0.66rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--steel); border: 1px solid var(--rule-strong); border-radius: 2px; padding: 2px 8px; }
.dash__feed { padding: 4px 16px; }
.dash__row { display: grid; grid-template-columns: 1fr auto auto; gap: 4px 14px; align-items: center; padding: 12px 0; border-bottom: 1px solid var(--rule); }
.dash__row:last-child { border-bottom: 0; }
.dash__pair { font-family: var(--disp); font-weight: 700; font-size: 0.92rem; }
.dash__side { font-size: 0.72rem; color: var(--ink-mute); }
.dash__px { font-family: var(--disp); font-weight: 600; font-variant-numeric: tabular-nums; }
.dash__chg { font-family: var(--disp); font-weight: 700; font-size: 0.84rem; font-variant-numeric: tabular-nums; }
.dash__chg.up { color: var(--up); }
.dash__chg.down { color: var(--down); }
.dash__ago { grid-column: 1 / -1; font-size: 0.7rem; color: var(--ink-mute); }
.dash__metrics { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--rule); }
.dash__metric { padding: 14px 16px; border-right: 1px solid var(--rule); }
.dash__metric:last-child { border-right: 0; }
.dash__metric-v { font-family: var(--disp); font-weight: 700; font-size: 1.05rem; color: var(--claret); }
.dash__metric-l { font-size: 0.68rem; color: var(--ink-mute); margin-top: 2px; }
.dash__caption { font-size: 0.72rem; color: var(--ink-mute); margin: 14px 0 0; }

/* ---------- Protocol (steps) ---------- */
.protocol { counter-reset: p; margin-top: 26px; }
.protocol__row { display: grid; grid-template-columns: auto 1fr; gap: 18px; padding: 22px 0; border-top: 1px solid var(--rule); align-items: baseline; }
.protocol__row:first-child { border-top: 2px solid var(--ink); }
.protocol__no { font-family: var(--disp); font-weight: 800; font-size: 1.6rem; color: var(--rule-strong); line-height: 1; }
.protocol__title { font-family: var(--disp); font-weight: 700; font-size: 1.2rem; margin: 0 0 5px; }
.protocol__text { color: var(--ink-soft); margin: 0; font-size: 0.95rem; }

/* ---------- Security ledger ---------- */
.safe__grid { display: grid; gap: 0; margin-top: 26px; border-top: 1px solid var(--rule); }
.safe__item { display: grid; gap: 6px; padding: 20px 0; border-bottom: 1px solid var(--rule); }
.safe__top { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; }
.safe__title { font-family: var(--disp); font-weight: 700; font-size: 1.08rem; margin: 0; }
.safe__tag { font-family: var(--body); font-size: 0.64rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--steel); white-space: nowrap; }
.safe__text { color: var(--ink-soft); margin: 0; font-size: 0.9rem; }
.compliance { margin-top: 26px; border: 1px solid var(--rule-strong); border-radius: 4px; background: var(--card); padding: 22px; }
.compliance__title { font-family: var(--disp); font-weight: 700; font-size: 1rem; margin: 0 0 8px; }
.compliance__note { color: var(--ink-soft); font-size: 0.9rem; margin: 0 0 16px; }
.compliance__badges { display: flex; flex-wrap: wrap; gap: 10px; }
.compliance__badge { display: inline-flex; align-items: center; gap: 8px; border: 1px solid var(--rule-strong); border-radius: 2px; padding: 8px 12px; font-family: var(--disp); font-weight: 700; font-size: 0.82rem; }
.compliance__badge::before { content: ""; width: 8px; height: 8px; background: var(--steel); border-radius: 50%; }
.compliance__reg { margin-top: 16px; padding-top: 14px; border-top: 1px dashed var(--rule-strong); font-size: 0.78rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-mute); }

/* ---------- Access form ---------- */
.access__grid { display: grid; gap: 28px; }
.access__points { display: grid; gap: 12px; margin-top: 22px; }
.access__points li { position: relative; padding-left: 26px; color: var(--ink-2); font-size: 0.95rem; }
.access__points li::before { content: ""; position: absolute; left: 0; top: 8px; width: 11px; height: 11px; border: 2px solid var(--claret); border-radius: 50%; }
.access__form { border: 1px solid var(--rule-strong); border-top: 3px solid var(--claret); border-radius: 4px; background: var(--card); padding: 24px; }
.lead-grid { display: grid; gap: 14px; }
.fld { display: grid; gap: 6px; }
.fld label { font-family: var(--disp); font-weight: 600; font-size: 0.74rem; letter-spacing: 0.04em; color: var(--ink-2); }
.fld input { width: 100%; background: var(--paper); border: 1px solid var(--rule-strong); border-radius: 2px; color: var(--ink); padding: 12px 13px; font-size: 0.95rem; font-family: var(--body); transition: border-color .15s, box-shadow .15s; }
.fld input::placeholder { color: var(--ink-mute); }
.fld input:focus { outline: none; border-color: var(--claret); box-shadow: 0 0 0 3px rgba(138,43,52,0.12); }
.lead-foot { display: grid; gap: 12px; margin-top: 16px; }
.lead-secure { display: flex; align-items: center; gap: 8px; font-size: 0.76rem; color: var(--ink-mute); margin: 0; }
.lead-secure svg { color: var(--claret); flex: none; }
.lead-consent { font-size: 0.76rem; color: var(--ink-mute); margin: 0; line-height: 1.55; }
.iti { width: 100%; }

/* ---------- Horizons (table + modules) ---------- */
.specsheet { width: 100%; border-collapse: collapse; margin-top: 24px; border-top: 2px solid var(--ink); }
.specsheet caption { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); }
.specsheet thead th { text-align: left; font-family: var(--body); font-size: 0.68rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-mute); padding: 12px 14px 12px 0; font-weight: 600; border-bottom: 1px solid var(--rule); }
.specsheet tbody th { text-align: left; font-family: var(--disp); font-weight: 700; color: var(--ink); padding: 14px 14px 14px 0; border-bottom: 1px solid var(--rule); font-size: 0.96rem; }
.specsheet tbody td { padding: 14px 14px 14px 0; border-bottom: 1px solid var(--rule); color: var(--ink-soft); font-size: 0.9rem; }
.specsheet tbody td:last-child { color: var(--claret); font-family: var(--disp); font-weight: 600; }
.horizons__mods { display: grid; gap: 16px; margin-top: 30px; }
.hmod { border: 1px solid var(--rule-strong); border-radius: 4px; background: var(--card); padding: 22px; }
.hmod__title { font-family: var(--disp); font-weight: 700; font-size: 1.14rem; margin: 0 0 8px; }
.hmod__text { color: var(--ink-soft); margin: 0 0 14px; font-size: 0.9rem; }
.hmod__points { display: grid; gap: 8px; }
.hmod__points li { position: relative; padding-left: 20px; font-size: 0.84rem; color: var(--ink-2); }
.hmod__points li::before { content: "—"; position: absolute; left: 0; color: var(--claret); }

/* ---------- Testimonials ---------- */
.voices__rate { display: flex; align-items: baseline; gap: 12px; margin: 22px 0 0; }
.voices__rate-v { font-family: var(--disp); font-weight: 800; font-size: 2rem; color: var(--claret); }
.voices__rate-s { color: var(--claret); letter-spacing: 2px; }
.voices__rate-n { font-size: 0.82rem; color: var(--ink-mute); }
.voices__feature { border-left: 3px solid var(--claret); padding: 4px 0 4px 22px; margin: 26px 0; }
.voices__feature blockquote { font-family: var(--disp); font-weight: 600; font-size: clamp(1.1rem, 2.4vw, 1.4rem); line-height: 1.4; color: var(--ink); margin: 0 0 14px; letter-spacing: -0.01em; }
.voices__feature cite { font-style: normal; }
.voices__feature .vname { font-family: var(--disp); font-weight: 700; }
.voices__feature .vrole { color: var(--ink-mute); font-size: 0.88rem; }
.voices__grid { display: grid; gap: 14px; }
.vcard { border: 1px solid var(--rule); border-radius: 4px; background: var(--card); padding: 18px; }
.vcard__rating { font-family: var(--disp); font-weight: 700; color: var(--claret); font-size: 0.84rem; }
.vcard__quote { margin: 8px 0 14px; color: var(--ink-2); font-size: 0.92rem; }
.vcard__meta { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; border-top: 1px solid var(--rule); padding-top: 12px; }
.vcard__name { font-family: var(--disp); font-weight: 700; font-size: 0.9rem; }
.vcard__city { font-size: 0.78rem; color: var(--ink-mute); }
.voices__disclaimer { font-size: 0.78rem; color: var(--ink-mute); margin-top: 18px; font-style: italic; }

/* ---------- FAQ ---------- */
.qa { margin-top: 24px; border-top: 2px solid var(--ink); }
.qa-item { border-bottom: 1px solid var(--rule); }
.qa-item > summary { list-style: none; cursor: pointer; display: grid; grid-template-columns: auto 1fr auto; gap: 16px; align-items: baseline; padding: 18px 0; }
.qa-item > summary::-webkit-details-marker { display: none; }
.qa-item__no { font-family: var(--disp); font-weight: 700; color: var(--claret); font-size: 0.84rem; }
.qa-item__q { font-family: var(--disp); font-weight: 700; font-size: 1.06rem; color: var(--ink); }
.qa-item__sign { width: 14px; height: 14px; position: relative; align-self: center; }
.qa-item__sign::before, .qa-item__sign::after { content: ""; position: absolute; background: var(--claret); }
.qa-item__sign::before { top: 6px; left: 0; width: 100%; height: 2px; }
.qa-item__sign::after { left: 6px; top: 0; width: 2px; height: 100%; transition: opacity .2s; }
.qa-item[open] .qa-item__sign::after { opacity: 0; }
.qa-item__a { padding: 0 0 20px 40px; color: var(--ink-soft); font-size: 0.94rem; }

/* ---------- Final CTA ---------- */
.closing { background: var(--ink); color: var(--paper); }
.closing__inner { display: grid; gap: 22px; }
.closing__eyebrow { font-family: var(--disp); font-weight: 600; font-size: 0.78rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--claret); }
.closing__title { font-family: var(--disp); font-weight: 800; font-size: clamp(1.7rem, 5vw, 2.5rem); line-height: 1.1; letter-spacing: -0.02em; margin: 8px 0 0; color: #fbf7f2; }
.closing__desc { color: #c4c0b6; margin: 0; max-width: 56ch; }
.closing__note { font-size: 0.78rem; color: var(--ink-mute); margin: 0; }
.closing .btn--outline { color: var(--paper); border-color: rgba(244,242,236,0.4); }
.closing .btn--outline:hover { border-color: var(--paper); }

/* ---------- Footer ---------- */
.colophon { background: var(--paper-2); border-top: 1px solid var(--rule-strong); padding-block: 44px 26px; }
.colophon__top { display: grid; gap: 22px; padding-bottom: 26px; border-bottom: 1px solid var(--rule); }
.colophon__about { color: var(--ink-soft); font-size: 0.9rem; margin: 14px 0 0; max-width: 64ch; }
.colophon__offices { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; padding-block: 24px; border-bottom: 1px solid var(--rule); }
.office h4 { font-family: var(--disp); font-weight: 700; font-size: 0.88rem; margin: 0 0 2px; }
.office span { display: block; font-size: 0.78rem; color: var(--ink-mute); }
.colophon__cols { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 22px; padding-block: 24px; border-bottom: 1px solid var(--rule); }
.colophon__col h3 { font-family: var(--body); font-size: 0.68rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-mute); margin: 0 0 12px; }
.colophon__col a { display: block; color: var(--ink-2); font-size: 0.88rem; padding: 4px 0; }
.colophon__col a:hover { color: var(--claret); }
.colophon__risk { padding-block: 22px; }
.colophon__risk h3 { font-family: var(--disp); font-size: 0.74rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--claret); margin: 0 0 10px; }
.colophon__risk p { color: var(--ink-mute); font-size: 0.8rem; line-height: 1.6; margin: 0; }
.colophon__base { padding-top: 18px; border-top: 1px solid var(--rule); font-size: 0.8rem; color: var(--ink-mute); display: flex; flex-wrap: wrap; gap: 8px 18px; justify-content: space-between; }

/* ---------- Service pages ---------- */
.page { min-height: 100vh; display: flex; flex-direction: column; }
.page__main { flex: 1 0 auto; display: flex; align-items: center; justify-content: center; padding-block: 56px; }
.sys { max-width: 560px; text-align: center; }
.sys__eyebrow { font-family: var(--disp); font-weight: 600; font-size: 0.74rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--claret); border-top: 1px solid var(--rule-strong); border-bottom: 1px solid var(--rule-strong); padding: 8px 0; display: inline-block; }
.sys__title { font-family: var(--disp); font-weight: 800; font-size: clamp(1.9rem, 7vw, 2.9rem); line-height: 1.06; letter-spacing: -0.02em; margin: 18px 0 12px; }
.sys__desc { color: var(--ink-soft); margin: 0 auto 26px; max-width: 46ch; }

/* ---------- Utility ---------- */
.skip { position: absolute; left: 12px; top: -60px; background: var(--claret); color: #fff; padding: 10px 16px; z-index: 100; transition: top .15s; font-weight: 700; border-radius: 2px; }
.skip:focus { top: 12px; }

/* =========================================================
   Tablet
   ========================================================= */
@media (min-width: 720px) {
  .feat { grid-template-columns: repeat(3, 1fr); }
  .feat__col { padding: 24px 24px 24px 0; border-bottom: 0; border-right: 1px solid var(--rule); }
  .feat__col + .feat__col { padding-left: 24px; }
  .feat__col:last-child { border-right: 0; }
  .safe__grid { grid-template-columns: 1fr 1fr; column-gap: 36px; }
  .lead-grid { grid-template-columns: 1fr 1fr; }
  .horizons__mods { grid-template-columns: repeat(3, 1fr); }
  .voices__grid { grid-template-columns: repeat(3, 1fr); }
  .colophon__offices { grid-template-columns: repeat(4, 1fr); }
}

/* =========================================================
   Desktop
   ========================================================= */
@media (min-width: 980px) {
  :root { --gut: 36px; }
  .sec { padding-block: 80px; }
  .docnav, .dochead__cta { display: flex; }
  .burger { display: none; }
  .tray { display: none !important; }

  .hero { padding-block: 72px 60px; }
  .hero__grid { display: grid; grid-template-columns: 1.35fr 0.65fr; gap: 50px; align-items: end; }
  .hero__aside { border-left: 1px solid var(--rule); padding-left: 40px; }
  .hero__rating { border-top: 0; padding-top: 0; margin-top: 0; flex-direction: column; align-items: flex-start; gap: 6px; }
  .hero__stats { flex-direction: column; gap: 22px; margin-top: 30px; }

  .dash__grid { grid-template-columns: 1.1fr 0.9fr; gap: 50px; align-items: center; }
  .dash__copy { order: 2; }

  .protocol { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; }
  .protocol__row { border-top: 2px solid var(--ink); border-right: 1px solid var(--rule); padding: 22px 24px 0 0; align-content: start; }
  .protocol__row + .protocol__row { padding-left: 24px; }
  .protocol__row:last-child { border-right: 0; }

  .safe__inner { display: grid; grid-template-columns: 0.8fr 1.2fr; gap: 48px; align-items: start; }
  .safe__head { position: sticky; top: 104px; }
  .safe__grid { margin-top: 0; border-top: 2px solid var(--ink); }

  .access__grid { grid-template-columns: 0.85fr 1.15fr; gap: 50px; align-items: start; }
  .access__head { position: sticky; top: 104px; }

  .horizons__inner { display: grid; grid-template-columns: 0.7fr 1.3fr; gap: 48px; align-items: start; }
  .specsheet { margin-top: 0; }
  .horizons__mods { grid-column: 1 / -1; }

  .voices__split { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; }
  .voices__grid { grid-template-columns: 1fr; }

  .qa__inner { display: grid; grid-template-columns: 0.6fr 1.4fr; gap: 48px; align-items: start; }
  .qa { margin-top: 0; }

  .closing__inner { grid-template-columns: 1.4fr auto; align-items: center; gap: 44px; }

  .colophon__top { grid-template-columns: 1.4fr 1fr; align-items: start; }
  .colophon__cols { grid-template-columns: repeat(3, 1fr); }
}

@media (prefers-reduced-motion: reduce) { * { scroll-behavior: auto !important; transition: none !important; } }
