/* ==========================================================================
   disclosures.css — Disclosures product page (Product ▸ Disclosures).
   SAME tokens / palette / type as the rest of the site, but a deliberately
   DIFFERENT layout language: a document / dossier with a sticky numbered
   section index, the recurring "disclosure draft" card, and a legal notice.
   Layers on tokens + coverage-model + landing + story + home.
   ========================================================================== */

/* ── Hero (document-forward) ──────────────────────────────────────────── */
.dhero-kicker { display: inline-flex; align-items: center; gap: 9px; font-family: var(--mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--accent); font-weight: 600; margin-bottom: 20px; }
.dhero-kicker i { font-size: 15px; }
.dhero-sup { display: flex; align-items: center; gap: 9px; margin-top: 20px; font-size: 13.5px; color: var(--brown-4); }
.dhero-sup i { font-size: 17px; color: var(--accent); }

/* ── The "disclosure draft" card — signature motif (hero + §5) ────────── */
.draft { border: 1px solid var(--line-strong); border-radius: 14px; overflow: hidden; background: var(--bg); box-shadow: 0 36px 80px -48px rgba(36,30,22,0.5); }
.draft + .draft { margin-top: 16px; }
.draft-row { padding: 15px 18px; }
.draft-q { background: var(--surface); border-bottom: 1px solid var(--line); }
.draft-lab { display: flex; align-items: center; gap: 7px; font-family: var(--mono); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--brown-4); margin-bottom: 7px; }
.draft-lab i { font-size: 13px; }
.draft-q .draft-lab i { color: var(--gold); }
.draft-a .draft-lab i { color: var(--accent); }
.draft-q p { margin: 0; font-family: var(--serif); font-size: 17px; line-height: 1.3; color: var(--brown); }
.draft-a p { margin: 0; font-size: 16px; line-height: 1.55; color: var(--brown-2); }
.draft-src { display: inline-flex; align-items: center; gap: 7px; margin-top: 12px; font-family: var(--mono); font-size: 11px; color: var(--accent); background: rgba(23,95,100,0.07); border: 1px solid rgba(23,95,100,0.16); padding: 5px 11px; border-radius: 100px; }
.draft-src i { font-size: 13px; }
.draft-note { padding: 13px 18px; background: var(--surface-2); border-top: 1px solid var(--line); }
.draft-note .dn-lab { font-family: var(--mono); font-size: 9px; letter-spacing: .14em; text-transform: uppercase; color: var(--gold); font-weight: 600; }
.draft-note p { margin: 5px 0 0; font-size: 11px; line-height: 1.5; color: var(--brown-4); text-wrap: pretty; }

/* ── Document grid: sticky index + editorial body ─────────────────────── */
.docband { padding: 70px 0 84px; }
.doc { display: grid; grid-template-columns: 236px 1fr; gap: 64px; align-items: start; }
.doc-index { position: sticky; top: 92px; }
.di-lab { font-family: var(--mono); font-size: 10px; letter-spacing: .16em; text-transform: uppercase; color: var(--brown-4); font-weight: 600; padding: 0 0 14px 12px; }
.doc-index ol { list-style: none; margin: 0; padding: 0; }
.di-item { display: flex; gap: 11px; align-items: baseline; padding: 9px 12px; border-left: 2px solid var(--line); color: var(--brown-4); font-size: 13px; line-height: 1.35; transition: color .16s, border-color .16s; cursor: pointer; }
.di-item:hover { color: var(--brown-2); }
.di-item .di-n { font-family: var(--mono); font-size: 11px; flex: 0 0 auto; }
.di-item.active { border-left-color: var(--accent); color: var(--accent); font-weight: 600; }

.doc-body { max-width: 720px; min-width: 0; }
.doc-sec { padding: 40px 0 46px; border-top: 1px solid var(--line); scroll-margin-top: 88px; }
.doc-sec:first-child { border-top: 0; padding-top: 4px; }
.sec-head { display: flex; gap: 18px; align-items: flex-start; margin-bottom: 18px; }
.sec-n { font-family: var(--serif); font-size: 38px; font-weight: 600; color: var(--gold); line-height: .9; flex: 0 0 auto; }
.doc-sec h2 { font-family: var(--serif); font-weight: 600; font-size: clamp(25px, 3vw, 34px); line-height: 1.08; margin: 4px 0 0; color: var(--brown); text-wrap: balance; }
.doc-sec p { font-size: 16px; line-height: 1.65; color: var(--brown-2); margin: 0 0 14px; max-width: 64ch; text-wrap: pretty; }
.doc-sec p:last-child { margin-bottom: 0; }
.doc-key { display: flex; gap: 11px; align-items: flex-start; margin-top: 22px; font-family: var(--serif); font-size: clamp(19px, 2.1vw, 23px); line-height: 1.32; color: var(--accent); font-weight: 600; text-wrap: pretty; }
.doc-key i { font-size: 22px; margin-top: 2px; flex: 0 0 auto; }

/* a soft "lede" inside a section */
.doc-sec .runlist { list-style: none; margin: 18px 0 0; padding: 0; display: flex; flex-direction: column; gap: 2px; }
.doc-sec .runlist li { display: flex; gap: 11px; align-items: flex-start; font-size: 16px; line-height: 1.5; color: var(--brown-2); padding: 9px 0; border-bottom: 1px solid var(--line); }
.doc-sec .runlist li:last-child { border-bottom: 0; }
.doc-sec .runlist li i { font-size: 18px; color: var(--accent); flex: 0 0 auto; margin-top: 1px; }

/* ── §3 serious-questions list (form/interview feel) ──────────────────── */
.qlist { margin: 22px 0 0; }
.qrow { display: flex; gap: 14px; align-items: center; padding: 14px 0; border-bottom: 1px solid var(--line); }
.qrow:first-child { border-top: 1px solid var(--line); }
.qmk { flex: 0 0 auto; width: 30px; height: 30px; border-radius: 50%; display: grid; place-items: center; font-family: var(--serif); font-size: 17px; font-weight: 600; color: var(--gold); border: 1.5px solid var(--gold); }
.qrow span { font-family: var(--serif); font-size: 18px; color: var(--brown); line-height: 1.3; }

/* ── §5 weaker → stronger pairs ───────────────────────────────────────── */
.vs2 { display: flex; flex-direction: column; gap: 12px; margin: 22px 0 0; }
.vs2-row { display: grid; grid-template-columns: 1fr 34px 1fr; gap: 12px; align-items: stretch; }
.vs2-cell { border-radius: 11px; padding: 15px 16px; font-size: 13.5px; line-height: 1.45; }
.vs2-weak { background: var(--surface); border: 1px solid var(--line); color: var(--brown-4); }
.vs2-weak .vl { display: block; font-family: var(--mono); font-size: 9px; letter-spacing: .12em; text-transform: uppercase; color: var(--danger); margin-bottom: 6px; }
.vs2-strong { background: rgba(23,95,100,0.05); border: 1px solid rgba(23,95,100,0.2); color: var(--brown-2); }
.vs2-strong .vl { display: block; font-family: var(--mono); font-size: 9px; letter-spacing: .12em; text-transform: uppercase; color: var(--accent); margin-bottom: 6px; }
.vs2-arrow { display: grid; place-items: center; color: var(--brown-4); font-size: 18px; }

/* ── recurring legal NOTICE callout ───────────────────────────────────── */
.notice { display: flex; gap: 15px; align-items: flex-start; margin-top: 22px; padding: 20px 22px; background: var(--surface); border: 1px solid var(--line-strong); border-radius: 12px; }
.notice .n-seal { flex: 0 0 auto; width: 40px; height: 40px; border-radius: 50%; display: grid; place-items: center; color: var(--accent); font-size: 20px; background: radial-gradient(circle at 50% 38%, #fbfaf4, #f1ede0); box-shadow: inset 0 0 0 1.5px var(--gold); }
.n-lab { font-family: var(--mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--gold); font-weight: 600; }
.notice p { margin: 6px 0 0; font-size: 15px; line-height: 1.6; color: var(--brown-3); }

/* ── §7 vertical numbered steps ───────────────────────────────────────── */
.steps-v { margin: 24px 0 0; }
.sv { display: grid; grid-template-columns: 44px 1fr; gap: 18px; padding-bottom: 26px; position: relative; }
.sv:not(:last-child)::before { content: ""; position: absolute; left: 21px; top: 44px; bottom: 0; width: 2px; background: var(--line); }
.sv-n { width: 44px; height: 44px; border-radius: 50%; display: grid; place-items: center; font-family: var(--serif); font-weight: 600; font-size: 19px; color: #f5f2e7; background: radial-gradient(circle at 50% 36%, #237b80, #175f64 72%); box-shadow: 0 6px 16px -8px rgba(23,95,100,.55); z-index: 1; }
.sv-tx h4 { font-family: var(--serif); font-size: 20px; font-weight: 600; margin: 8px 0 6px; color: var(--brown); }
.sv-tx p { font-size: 16px; line-height: 1.55; color: var(--brown-3); margin: 0; max-width: 60ch; }

/* ── §8 what it does NOT replace ──────────────────────────────────────── */
.notdo { list-style: none; margin: 20px 0 0; padding: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 10px 24px; }
.notdo li { display: flex; gap: 11px; align-items: flex-start; font-size: 16px; line-height: 1.45; color: var(--brown-2); }
.notdo li i { font-size: 17px; color: var(--danger); flex: 0 0 auto; margin-top: 1px; }

/* ── responsive ───────────────────────────────────────────────────────── */
@media (max-width: 1000px) {
  .doc { grid-template-columns: 1fr; gap: 0; }
  .doc-index { display: none; }
  .vs2-row { grid-template-columns: 1fr; }
  .vs2-arrow { transform: rotate(90deg); height: 22px; }
  .notdo { grid-template-columns: 1fr; }
}
