/* SOMAI visual system — from brand-guidelines.md (§2 colour, §3 type, §5 dividers, §13 tokens).
 * Warm cream paper, ink, one oxblood accent (<=5%), hairlines + whitespace only.
 * No boxes, no cards, no shadows, no gradients. Display = Neulis Sans (Roboto fallback); chrome = Source Code Pro. */
:root {
  --paper: #F8F8E8; --paper-hero: #F1F0CC; --ink: #111111; --ink-70: #555555; --ink-50: #888888;
  --hair: #D5D2BD; --accent: #A71D31; --footer-bg: #8D775F; --footer-rule: #3F0D12;
  --f-display: 'Neulis Sans','Roboto',system-ui,-apple-system,sans-serif;
  --f-chrome: 'Source Code Pro',ui-monospace,'SFMono-Regular',Menlo,Consolas,monospace;
}
* { box-sizing: border-box; }
html, body { margin: 0; }
body { background: var(--paper); color: var(--ink); font-family: var(--f-display); font-size: 17px; line-height: 1.55; -webkit-font-smoothing: antialiased; }
b { font-weight: 500; }
.wrap { max-width: 720px; margin: 0 auto; padding: 0 clamp(20px, 7vw, 64px); }

/* Masthead + colophon */
.masthead { display: flex; align-items: center; gap: 12px; padding: 26px 0 18px; }
.mark { width: 36px; height: 36px; background: var(--accent); display: flex; align-items: center; justify-content: center; flex: none; }
.mark span { color: #fff; font-size: 13px; font-weight: 500; }
.tagline { font-family: var(--f-chrome); font-size: 11px; color: var(--ink-70); line-height: 1.45; }
.colophon { background: var(--footer-bg); border-top: 1px solid var(--footer-rule); margin-top: 44px; padding: 12px 0; }
.colophon .wrap { display: flex; justify-content: space-between; align-items: center; }
.colophon span { font-family: var(--f-chrome); font-size: 11px; color: #fff; }

/* Eyebrow */
.eyebrow-block { margin: 26px 0 12px; }
.eyebrow { font-family: var(--f-chrome); font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--ink); }
.rule { width: 124px; height: 1px; background: var(--accent); margin: 7px 0; }
.snum { font-family: var(--f-chrome); font-size: 11px; letter-spacing: .08em; color: var(--accent); }

/* Form */
.lbl { display: block; font-size: 12.5px; color: var(--ink-70); margin: 0 0 5px; }
.sel { font-family: var(--f-display); font-size: 15px; padding: 9px 11px; border: 1px solid var(--hair); background: #FAFAF4; color: var(--ink); width: 100%; border-radius: 0; }
.sel:focus { outline: 1px solid var(--accent); }
.q { padding: 15px 0; border-top: 1px solid var(--hair); }
.q p { margin: 0 0 9px; font-size: 14.5px; }
.opt { display: flex; align-items: flex-start; gap: 9px; font-size: 13.5px; color: #333; padding: 4px 0; cursor: pointer; }
.opt input { margin: 3px 0 0; accent-color: var(--accent); flex: none; }
.muted { color: var(--ink-50); }
.micro { font-size: 12px; }
.big { font-size: 21px; font-weight: 500; line-height: 1.3; max-width: 58ch; margin: 4px 0 10px; }

/* Buttons + nav (brand: one oxblood action button; CTAs otherwise are inline links) */
.btn { font-family: var(--f-chrome); font-size: 13px; color: #fff; background: var(--accent); border: 0; padding: 12px 22px; cursor: pointer; letter-spacing: .04em; }
.btn:hover { opacity: .92; } .btn:disabled { opacity: .4; cursor: not-allowed; }
.link { font-family: var(--f-chrome); font-size: 12.5px; color: var(--accent); background: none; border: 0; cursor: pointer; padding: 0; }
.link:hover { opacity: .7; }
.nav { display: flex; justify-content: space-between; align-items: center; margin: 26px 0 8px; gap: 16px; }

/* Progress */
.progress { display: flex; align-items: center; gap: 12px; margin: 18px 0 4px; }
.pbar { flex: 1; height: 2px; background: var(--hair); }
.pfill { height: 2px; background: var(--accent); }
.pnum { font-family: var(--f-chrome); font-size: 11px; color: var(--ink-50); white-space: nowrap; }

/* Teaser / consents */
.teaser { margin: 18px 0; padding: 14px 0; border-top: 1px solid var(--hair); border-bottom: 1px solid var(--hair); }
.teaser p { margin: 6px 0 0; font-size: 15px; color: var(--ink-70); }
.consents { margin: 14px 0 0; }
.consents .opt { font-size: 13px; }

/* Report */
.woy { font-size: 13px; color: var(--ink-50); margin: 0; }
.hedge { color: var(--ink-50); }
.reversal { font-size: 21px; font-weight: 500; line-height: 1.3; margin: 10px 0 0; max-width: 60ch; }
.srow { display: flex; align-items: baseline; gap: 11px; padding: 10px 0; border-top: 1px solid var(--hair); }
.srow .mark { display: inline-block; width: 12px; height: 3px; background: var(--accent); position: relative; top: -3px; }
.sname { flex: 1; font-size: 15px; font-weight: 500; }
.smeta { font-family: var(--f-chrome); font-size: 11px; color: var(--ink-50); text-align: right; }
.bn { font-family: var(--f-chrome); font-size: 13px; color: var(--accent); min-width: 22px; }
.tag { font-family: var(--f-chrome); font-size: 10.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--accent); }
.lead { font-size: 15px; margin: 8px 0 12px; max-width: 62ch; }
.callout { margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--hair); }
.villain-name { font-size: 19px; font-weight: 500; margin: 8px 0 2px; }
.villain-home { font-size: 14px; color: var(--ink-70); margin: 0 0 4px; }
.villain-meta { font-family: var(--f-chrome); font-size: 11px; color: var(--ink-50); margin: 0; }
.vignette { margin-top: 18px; padding-top: 14px; border-top: 1px solid var(--hair); }
.vrow { display: flex; gap: 14px; align-items: baseline; margin-top: 9px; }
.vk { font-family: var(--f-chrome); font-size: 11px; letter-spacing: .08em; color: var(--accent); min-width: 62px; }
.vk.ink { color: var(--ink); }
.vrow span:last-child { font-size: 15px; max-width: 60ch; }
.how { margin-top: 14px; padding: 11px 0; border-top: 1px solid var(--hair); border-bottom: 1px solid var(--hair); }
.micro-label { font-family: var(--f-chrome); font-size: 10.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-50); }
.how p { font-size: 13px; color: var(--ink-70); margin: 6px 0 0; }
.ink { color: var(--ink); } .ox { color: var(--accent); }
.map { margin: 16px 0 6px; }
.prize { font-size: 15px; color: var(--ink-70); max-width: 64ch; }
.prov { font-family: var(--f-chrome); font-size: 11px; color: var(--ink-50); max-width: 74ch; line-height: 1.55; }
.firstblock { margin-top: 16px; padding: 12px 0; border-top: 1px solid var(--hair); border-bottom: 1px solid var(--hair); }
.firstblock p { font-size: 15px; max-width: 66ch; margin: 6px 0 0; }
.cta { font-family: var(--f-chrome); font-size: 13px; color: var(--accent); margin-top: 18px; }
.lockin { font-family: var(--f-chrome); font-size: 11px; color: var(--ink-50); margin-top: 6px; }
.warn { color: var(--accent); font-size: 15px; }
.reveal { font-size: 13px; color: var(--ink-70); margin: 12px 0 0; max-width: 64ch; }
.reveal b { color: var(--ink); }
