/* ============================================================
   CAN'T GET INSURED — Design System v3
   Editorial / investigative-journalism × anti-establishment fintech.
   ============================================================ */

:root {
  color-scheme: only light;
  /* v2 token aliases for legacy pages */
  --cream: #F7F2E9; --cream-deep: #EFE7D6;
  --coral: #FF4D2E; --coral-deep: #D62F12; --coral-soft: #FFE2DA;
  --teal: #1F6B54; --teal-soft: #D2E6DC;
  --ink-faded: #6B6355;
  --ink: #11100E;
  --ink-2: #2B2722;
  --ink-soft: #423C34;
  --ink-muted: #6B6355;
  --paper: #F7F2E9;
  --paper-2: #EFE7D6;
  --paper-edge: #E2D6BE;
  --flame: #FF4D2E;
  --flame-deep: #D62F12;
  --flame-soft: #FFE2DA;
  --forest: #123F32;
  --forest-mid: #1F6B54;
  --forest-soft: #D2E6DC;
  --gold: #E8B84B;
  --gold-deep: #A97D14;
  --rule: #DDD0B6;
  --rule-soft: #EAE0CC;
  --display: 'Fraunces', Georgia, 'Times New Roman', serif;
  --body: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --mono: 'Courier New', ui-monospace, monospace;
  --sh-card: 0 2px 0 var(--ink);
  --sh-pop: 4px 4px 0 var(--ink);
  --sh-flame: 4px 4px 0 var(--flame-deep);
  --maxw: 1180px;
  --gutter: 28px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; background-color: #F7F2E9; color-scheme: only light; }
body {
  font-family: var(--body);
  background: var(--paper);
  color: var(--ink);
  font-size: 17px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
  background-image: radial-gradient(circle at 1px 1px, rgba(17,16,14,0.018) 1px, transparent 0);
  background-size: 4px 4px;
}
img { max-width: 100%; height: auto; display: block; }
::selection { background: var(--flame); color: #fff; }
a { color: var(--flame-deep); text-decoration: none; transition: color .15s, background .15s; }
a:hover { color: var(--ink); }

.container { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--gutter); }
.container-narrow { max-width: 760px; margin: 0 auto; padding: 0 var(--gutter); }
.container-wide { max-width: 1320px; margin: 0 auto; padding: 0 var(--gutter); }

h1 { font-family: var(--display); font-weight: 900; font-size: clamp(48px, 8.5vw, 104px); line-height: 0.92; letter-spacing: -0.045em; font-variation-settings: "opsz" 144; color: var(--ink); }
h1 em { font-style: italic; color: var(--flame); }
h2 { font-family: var(--display); font-weight: 900; font-size: clamp(32px, 5vw, 56px); line-height: 1.0; letter-spacing: -0.04em; font-variation-settings: "opsz" 80; color: var(--ink); }
h2 em { font-style: italic; color: var(--flame); }
h3 { font-family: var(--display); font-weight: 800; font-size: clamp(22px, 3vw, 30px); line-height: 1.08; letter-spacing: -0.025em; color: var(--ink); }

.kicker { display: inline-flex; align-items: center; gap: 9px; font-family: var(--mono); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.18em; color: var(--flame-deep); }
.kicker::before { content: ''; width: 22px; height: 2px; background: var(--flame); }
.kicker.on-dark { color: var(--gold); }
.kicker.on-dark::before { background: var(--gold); }

.site-nav { position: sticky; top: 0; z-index: 100; background: rgba(247,242,233,0.86); backdrop-filter: blur(10px) saturate(1.2); -webkit-backdrop-filter: blur(10px) saturate(1.2); border-bottom: 2px solid var(--ink); }
.nav-inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 14px 0; }
.logo { display: flex; align-items: center; gap: 11px; font-family: var(--display); font-weight: 900; font-size: 19px; letter-spacing: -0.04em; color: var(--ink); }
.logo:hover { color: var(--ink); }
.logo-glyph { width: 36px; height: 36px; display: block; flex-shrink: 0; transform: rotate(-4deg); }
.logo-mark { width: 36px; height: 36px; background: var(--flame); color: #fff; border-radius: 9px; display: grid; place-items: center; font-family: var(--display); font-weight: 900; font-size: 19px; transform: rotate(-5deg); border: 2px solid var(--ink); flex-shrink: 0; }
.logo { white-space: nowrap; flex-shrink: 0; }
.nav-links { display: flex; list-style: none; gap: 4px; align-items: center; }
.nav-links a { color: var(--ink-soft); font-weight: 600; font-size: 14px; padding: 8px 13px; border-radius: 7px; transition: background .15s, color .15s; white-space: nowrap; }
.nav-links a:hover { background: var(--paper-2); color: var(--ink); }
.nav-cta { white-space: nowrap; background: var(--ink); color: var(--paper); padding: 11px 20px; border-radius: 9px; font-weight: 700; font-size: 14px; border: 2px solid var(--ink); transition: transform .12s, box-shadow .12s, background .12s; box-shadow: 3px 3px 0 var(--flame); }
.nav-cta:hover { background: var(--flame); color: #fff; transform: translate(-1px,-1px); box-shadow: 4px 4px 0 var(--ink); }
.nav-toggle { display: none; background: none; border: none; font-size: 26px; color: var(--ink); cursor: pointer; padding: 4px 8px; border-radius: 7px; }
.nav-cta-mobile { display: none; }

@media (max-width: 1000px) {
  .nav-links { display: none; }
  .nav-toggle { display: block; }
  .nav-cta { display: none; }
  .logo { font-size: 17px; }
  .site-nav.mobile-open .nav-links { display: flex; flex-direction: column; position: absolute; top: 100%; left: 0; right: 0; background: var(--paper); border-bottom: 2px solid var(--ink); padding: 14px var(--gutter) 20px; gap: 4px; align-items: stretch; }
  .site-nav.mobile-open .nav-links a { padding: 13px 14px; border-bottom: 1px solid var(--rule); border-radius: 0; font-size: 16px; }
  .site-nav.mobile-open .nav-cta-mobile { display: block; background: var(--ink); color: var(--paper); text-align: center; padding: 14px; border-radius: 9px; margin-top: 10px; font-weight: 700; box-shadow: 3px 3px 0 var(--flame); }
}

.hero { position: relative; padding: clamp(48px, 8vw, 100px) 0 clamp(40px, 6vw, 76px); overflow: hidden; }
.hero-watermark { position: absolute; top: 50%; right: -4%; transform: translateY(-50%); font-family: var(--display); font-weight: 900; font-size: clamp(180px, 34vw, 520px); line-height: 1; color: var(--flame); opacity: 0.05; pointer-events: none; z-index: 0; font-style: italic; }
.hero-inner { position: relative; z-index: 1; }
.hero-grid { display: grid; grid-template-columns: 1.35fr 1fr; gap: clamp(32px, 5vw, 72px); align-items: end; }
@media (max-width: 940px) { .hero-grid { grid-template-columns: 1fr; gap: 36px; } }
.hero-strike { display: flex; flex-wrap: wrap; gap: 10px 18px; font-family: var(--display); font-weight: 900; font-size: clamp(20px, 2.6vw, 30px); letter-spacing: -0.03em; color: var(--ink-muted); margin-bottom: 18px; }
.hero-strike span { position: relative; }
.hero-strike span::after { content: ''; position: absolute; left: -3px; right: -3px; top: 54%; height: 4px; background: var(--flame); transform: rotate(-2.5deg); }
.hero h1 { margin-bottom: 26px; }
.hero-lede { font-size: clamp(17px, 1.7vw, 21px); line-height: 1.5; color: var(--ink-soft); max-width: 540px; margin-bottom: 30px; }
.hero-lede em { font-style: italic; color: var(--flame-deep); font-weight: 500; }
.hero-receipt { background: var(--ink); color: var(--paper); border-radius: 16px; padding: 28px; position: relative; box-shadow: var(--sh-pop); border: 2px solid var(--ink); }
.hero-receipt::before { content: 'THE NUMBERS'; position: absolute; top: -11px; left: 22px; background: var(--flame); color: #fff; font-family: var(--mono); font-size: 10px; font-weight: 700; letter-spacing: 0.16em; padding: 3px 10px; border-radius: 4px; border: 2px solid var(--ink); }
.receipt-row { display: flex; align-items: baseline; justify-content: space-between; gap: 14px; padding: 13px 0; border-bottom: 1px dashed rgba(247,242,233,0.22); }
.receipt-row:last-child { border-bottom: none; }
.receipt-figure { font-family: var(--display); font-weight: 900; font-size: 30px; letter-spacing: -0.03em; color: var(--gold); line-height: 1; flex-shrink: 0; }
.receipt-label { font-size: 13px; color: rgba(247,242,233,0.78); line-height: 1.35; text-align: right; }

.btn { display: inline-flex; align-items: center; gap: 10px; font-family: var(--body); font-weight: 700; font-size: 16px; padding: 16px 28px; border-radius: 11px; border: 2px solid var(--ink); cursor: pointer; transition: transform .12s, box-shadow .12s, background .12s, color .12s; letter-spacing: -0.01em; white-space: nowrap; text-decoration: none; }
.btn svg { width: 18px; height: 18px; }
.btn-flame { background: var(--flame); color: #fff; box-shadow: var(--sh-pop); }
.btn-flame:hover { color: #fff; transform: translate(-2px,-2px); box-shadow: 6px 6px 0 var(--ink); }
.btn-flame:active { transform: translate(2px,2px); box-shadow: 1px 1px 0 var(--ink); }
.btn-ink { background: var(--ink); color: var(--paper); box-shadow: 4px 4px 0 var(--flame); }
.btn-ink:hover { color: var(--paper); transform: translate(-2px,-2px); box-shadow: 6px 6px 0 var(--flame); }
.btn-ghost { background: transparent; color: var(--ink); box-shadow: var(--sh-card); }
.btn-ghost:hover { background: var(--ink); color: var(--paper); transform: translate(-1px,-1px); }
.btn-row { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; }
.hero-trust { display: flex; gap: 18px; flex-wrap: wrap; align-items: center; margin-top: 24px; font-size: 14.5px; color: var(--ink-soft); font-weight: 500; }
.hero-trust .tcheck { display: inline-flex; align-items: center; gap: 7px; }
.hero-trust svg { width: 18px; height: 18px; color: var(--forest-mid); flex-shrink: 0; }
.hero-trust strong { color: var(--ink); font-weight: 700; }

section { padding: clamp(56px, 8vw, 96px) 0; position: relative; }
.section-head { max-width: 720px; margin-bottom: 44px; }
.section-head .kicker { margin-bottom: 16px; }
.section-head p { font-size: 18px; color: var(--ink-soft); line-height: 1.5; margin-top: 14px; }
.bg-ink { background: var(--ink); color: var(--paper); }
.bg-ink h2, .bg-ink h3 { color: #fff; }
.bg-ink p { color: rgba(247,242,233,0.8); }
.bg-paper2 { background: var(--paper-2); }
.bg-forest { background: var(--forest); color: var(--paper); }
.bg-forest h2, .bg-forest h3 { color: #fff; }
.bg-forest p { color: rgba(247,242,233,0.82); }

.index-list { border-top: 2px solid var(--ink); }
.index-item { display: grid; grid-template-columns: 56px 1fr auto; gap: 22px; align-items: center; padding: 26px 8px; border-bottom: 1px solid var(--rule); text-decoration: none; color: var(--ink); transition: background .18s, padding .18s; position: relative; }
.index-item:hover { background: var(--ink); color: var(--paper); padding-left: 22px; padding-right: 22px; }
.index-item:hover .index-num { color: var(--gold); }
.index-item:hover .index-desc { color: rgba(247,242,233,0.72); }
.index-item:hover .index-go { background: var(--flame); color:#fff; border-color: var(--paper); }
.index-num { font-family: var(--mono); font-size: 14px; font-weight: 700; color: var(--flame-deep); letter-spacing: 0.05em; }
.index-title { font-family: var(--display); font-weight: 800; font-size: clamp(22px, 3vw, 32px); letter-spacing: -0.03em; line-height: 1.05; }
.index-desc { font-size: 14.5px; color: var(--ink-muted); margin-top: 4px; line-height: 1.4; max-width: 52ch; }
.index-go { width: 46px; height: 46px; border-radius: 50%; border: 2px solid var(--ink); display: grid; place-items: center; flex-shrink: 0; transition: background .18s, color .18s, transform .18s; }
.index-item:hover .index-go { transform: rotate(-45deg); }
.index-go svg { width: 20px; height: 20px; }
@media (max-width: 640px) { .index-item { grid-template-columns: 1fr auto; gap: 14px; padding: 20px 4px; } .index-num { display: none; } .index-go { width: 40px; height: 40px; } }

.tool-section { background: var(--ink); color: var(--paper); position: relative; overflow: hidden; }
.tool-section::before { content: ''; position: absolute; top: -160px; right: -120px; width: 460px; height: 460px; background: radial-gradient(circle, var(--flame) 0%, transparent 68%); opacity: 0.16; border-radius: 50%; }
.tool-shell { position: relative; z-index: 1; max-width: 720px; margin: 0 auto; }
.tool-shell-head { text-align: center; margin-bottom: 36px; }
.tool-shell-head .kicker { justify-content: center; }
.tool-shell-head h2 { color: #fff; margin: 16px 0 12px; }
.tool-shell-head p { color: rgba(247,242,233,0.76); max-width: 520px; margin: 0 auto; }
.chat { background: var(--paper); border-radius: 20px; border: 2px solid var(--ink); box-shadow: 8px 8px 0 var(--flame); overflow: hidden; }
.chat-top { display: flex; align-items: center; gap: 11px; padding: 16px 22px; border-bottom: 2px solid var(--ink); background: var(--paper-2); }
.chat-avatar { width: 34px; height: 34px; border-radius: 50%; background: var(--flame); color: #fff; display: grid; place-items: center; font-family: var(--display); font-weight: 900; font-size: 17px; border: 2px solid var(--ink); flex-shrink: 0; }
.chat-top-meta strong { display: block; font-size: 14px; font-weight: 700; color: var(--ink); line-height: 1.2; }
.chat-top-meta span { font-size: 12px; color: var(--ink-muted); }
.chat-top-status { margin-left: auto; display: inline-flex; align-items: center; gap: 6px; font-size: 11px; color: var(--forest-mid); font-weight: 700; font-family: var(--mono); text-transform: uppercase; letter-spacing: 0.1em; }
.chat-top-status .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--forest-mid); animation: blink 1.8s ease-in-out infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0.3} }
.chat-body { padding: 26px 22px; min-height: 280px; }
.chat-progress { display: flex; gap: 5px; margin-bottom: 22px; }
.chat-progress i { height: 4px; flex: 1; border-radius: 2px; background: var(--rule); transition: background .3s; }
.chat-progress i.on { background: var(--flame); }
.chat-q { animation: chatIn .3s ease-out; }
@keyframes chatIn { from { opacity:0; transform: translateY(8px) } to { opacity:1; transform: translateY(0) } }
.chat-bubble { display: inline-block; background: var(--ink); color: var(--paper); padding: 14px 18px; border-radius: 16px 16px 16px 4px; font-size: 16px; line-height: 1.4; margin-bottom: 20px; max-width: 90%; }
.chat-bubble small { display:block; color: rgba(247,242,233,0.6); font-size: 13px; margin-top: 4px; }
.chat-options { display: grid; gap: 10px; }
.chat-opt { display: flex; align-items: center; gap: 13px; width: 100%; text-align: left; background: var(--paper); border: 2px solid var(--ink); border-radius: 12px; padding: 15px 17px; font-family: var(--body); font-size: 15.5px; font-weight: 600; color: var(--ink); cursor: pointer; transition: transform .12s, box-shadow .12s, background .12s, color .12s; box-shadow: var(--sh-card); }
.chat-opt:hover { transform: translate(-2px,-2px); box-shadow: var(--sh-flame); background: var(--flame); color: #fff; }
.chat-opt:hover .chat-opt-icon { background: #fff; color: var(--flame); }
.chat-opt-icon { width: 32px; height: 32px; border-radius: 8px; background: var(--flame-soft); color: var(--flame-deep); display: grid; place-items: center; flex-shrink: 0; font-size: 16px; transition: background .12s, color .12s; }
.chat-opt-icon svg { width: 17px; height: 17px; }
.chat-opt small { display: block; font-weight: 400; font-size: 13px; color: var(--ink-muted); margin-top: 1px; }
.chat-opt:hover small { color: rgba(255,255,255,0.85); }
.chat-back { background: none; border: none; color: var(--ink-muted); font-family: var(--body); font-size: 14px; font-weight: 600; cursor: pointer; padding: 8px 0; margin-top: 18px; }
.chat-back:hover { color: var(--ink); }
.chat-result { display: none; animation: chatIn .35s ease-out; }
.chat-result.show { display: block; }
.chat-result-tag { display: inline-block; font-family: var(--mono); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.14em; color: var(--flame-deep); background: var(--flame-soft); padding: 4px 10px; border-radius: 5px; margin-bottom: 14px; }
.chat-result h3 { margin-bottom: 10px; }
.chat-result-body { font-size: 16px; color: var(--ink-soft); line-height: 1.55; margin-bottom: 20px; }
.chat-result-honest { background: var(--forest-soft); border-left: 4px solid var(--forest); border-radius: 0 12px 12px 0; padding: 16px 18px; font-size: 14px; color: var(--ink-soft); line-height: 1.5; margin: 20px 0; }
.chat-result-honest strong { color: var(--forest); }
.chat-result-honest a { color: var(--forest); text-decoration: underline; }
.chat-tips { margin: 18px 0; }
.chat-tip { display: flex; gap: 12px; padding: 11px 0; border-bottom: 1px solid var(--rule); }
.chat-tip:last-child { border-bottom: none; }
.chat-tip-mark { width: 24px; height: 24px; border-radius: 50%; background: var(--forest); color: #fff; display: grid; place-items: center; flex-shrink: 0; font-size: 13px; font-weight: 700; }
.chat-tip-text { font-size: 15px; color: var(--ink-soft); line-height: 1.45; }
.chat-result-cta { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 22px; }
.welcome-back { background: var(--forest-soft); border: 2px solid var(--forest); border-radius: 14px; padding: 16px 20px; margin-bottom: 24px; animation: chatIn .4s ease-out; }
.welcome-back-inner { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.welcome-back-icon { width: 38px; height: 38px; border-radius: 10px; background: var(--forest); color: #fff; display: grid; place-items: center; font-size: 19px; flex-shrink: 0; }
.welcome-back-text { flex: 1; min-width: 200px; font-size: 15px; color: var(--ink); }
.welcome-back-text strong { font-weight: 700; }
.welcome-back-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.btn-tiny { padding: 9px 15px; border-radius: 8px; font-family: var(--body); font-size: 13px; font-weight: 700; cursor: pointer; border: 2px solid var(--ink); white-space: nowrap; transition: transform .12s; }
.btn-tiny-primary { background: var(--forest); color: #fff; }
.btn-tiny-primary:hover { transform: translate(-1px,-1px); }
.btn-tiny-secondary { background: transparent; color: var(--ink); }
.btn-tiny-secondary:hover { background: var(--paper-2); }

.findings-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border: 2px solid var(--paper); border-radius: 16px; overflow: hidden; }
@media (max-width: 760px) { .findings-grid { grid-template-columns: 1fr; } }
.finding { padding: 32px 28px; border-right: 2px solid rgba(247,242,233,0.2); border-bottom: 2px solid rgba(247,242,233,0.2); }
.findings-grid .finding:nth-child(3n) { border-right: none; }
.finding-fig { font-family: var(--display); font-weight: 900; font-size: clamp(42px, 6vw, 64px); line-height: 0.9; letter-spacing: -0.04em; color: var(--gold); margin-bottom: 12px; }
.finding-fig em { font-style: italic; color: var(--flame); }
.finding-text { font-size: 15px; color: rgba(247,242,233,0.82); line-height: 1.5; }
.finding-src { font-family: var(--mono); font-size: 11px; color: rgba(247,242,233,0.5); margin-top: 10px; letter-spacing: 0.04em; }

.lead-wrap { background: var(--paper-2); }
.lead-grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(32px, 5vw, 64px); align-items: start; }
@media (max-width: 880px) { .lead-grid { grid-template-columns: 1fr; gap: 32px; } }
.lead-pitch h2 { margin-bottom: 16px; }
.lead-pitch p { font-size: 17px; color: var(--ink-soft); line-height: 1.55; margin-bottom: 16px; }
.lead-pitch ul { list-style: none; margin-top: 20px; }
.lead-pitch li { display: flex; gap: 11px; align-items: flex-start; padding: 9px 0; font-size: 15px; color: var(--ink-soft); }
.lead-pitch li svg { width: 20px; height: 20px; color: var(--forest-mid); flex-shrink: 0; margin-top: 2px; }
.form-card { background: var(--paper); border: 2px solid var(--ink); border-radius: 18px; padding: clamp(24px, 4vw, 36px); box-shadow: var(--sh-pop); }
.form-row { margin-bottom: 16px; }
.form-row.two { display: grid; grid-template-columns: 1fr 1fr; gap: 13px; }
@media (max-width: 480px) { .form-row.two { grid-template-columns: 1fr; } }
.form-row label { display: block; font-size: 13px; font-weight: 700; color: var(--ink); margin-bottom: 6px; }
.form-row label .req { color: var(--flame-deep); }
.form-row input, .form-row select, .form-row textarea { width: 100%; padding: 13px 14px; background: var(--paper-2); border: 2px solid var(--rule); border-radius: 10px; font-family: var(--body); font-size: 15px; color: var(--ink); -webkit-appearance: none; appearance: none; transition: border-color .15s, background .15s; }
.form-row input:focus, .form-row select:focus, .form-row textarea:focus { outline: none; border-color: var(--flame); background: var(--paper); }
.form-row textarea { min-height: 90px; resize: vertical; }
.form-help { font-size: 12px; color: var(--ink-muted); margin-top: 4px; }
.form-consent { display: flex; gap: 10px; align-items: flex-start; margin: 20px 0; padding: 15px; background: var(--paper-2); border-radius: 11px; font-size: 13px; color: var(--ink-soft); line-height: 1.5; }
.form-consent input { margin-top: 2px; width: 18px; height: 18px; accent-color: var(--flame); flex-shrink: 0; }
.success-panel { display: none; text-align: center; padding: 30px; background: var(--forest-soft); border: 2px solid var(--forest); border-radius: 14px; }
.success-panel.show { display: block; animation: chatIn .3s ease-out; }
.success-icon { width: 54px; height: 54px; border-radius: 50%; background: var(--forest); color: #fff; display: grid; place-items: center; margin: 0 auto 14px; font-size: 26px; }
.success-panel h3 { margin-bottom: 8px; }
.success-panel p { color: var(--ink-soft); }

.faq-list { max-width: 800px; margin: 0 auto; border-top: 2px solid var(--ink); }
.faq-item { border-bottom: 1px solid var(--rule); cursor: pointer; }
.faq-q { display: flex; justify-content: space-between; align-items: center; gap: 16px; padding: 22px 4px; font-family: var(--display); font-weight: 700; font-size: clamp(17px, 2.2vw, 21px); letter-spacing: -0.02em; color: var(--ink); }
.faq-q::after { content: '+'; font-family: var(--display); font-size: 28px; font-weight: 400; color: var(--flame); transition: transform .25s; flex-shrink: 0; line-height: 1; }
.faq-item.open .faq-q::after { transform: rotate(45deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .3s, padding .3s; }
.faq-item.open .faq-a { max-height: 700px; padding: 0 4px 22px; }
.faq-a p { font-size: 15.5px; color: var(--ink-soft); line-height: 1.6; margin-bottom: 12px; }
.faq-a p:last-child { margin-bottom: 0; }
.faq-a a { color: var(--flame-deep); text-decoration: underline; }

.answer-block { background: var(--paper); border: 2px solid var(--ink); border-left: 6px solid var(--flame); border-radius: 0 14px 14px 0; padding: 24px 26px; margin: 28px 0; box-shadow: var(--sh-card); }
.answer-block .ab-label { font-family: var(--mono); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.14em; color: var(--flame-deep); margin-bottom: 10px; }
.answer-block .ab-text { font-size: 17px; line-height: 1.6; color: var(--ink); }

.content-body { padding: clamp(40px,6vw,64px) 0; }
.content-body h2 { margin: 44px 0 16px; }
.content-body h2:first-child { margin-top: 0; }
.content-body h3 { margin: 28px 0 10px; }
.content-body p { margin-bottom: 16px; color: var(--ink-soft); line-height: 1.65; }
.content-body ul, .content-body ol { margin: 0 0 20px; padding-left: 24px; color: var(--ink-soft); }
.content-body li { margin-bottom: 8px; line-height: 1.55; }
.content-body strong { color: var(--ink); font-weight: 700; }
.content-body a { color: var(--flame-deep); text-decoration: underline; }

.breadcrumbs { font-size: 13px; color: var(--ink-muted); margin-bottom: 18px; font-family: var(--mono); letter-spacing: 0.03em; }
.breadcrumbs a { color: var(--ink-muted); }
.breadcrumbs a:hover { color: var(--flame-deep); }
.breadcrumbs .sep { margin: 0 8px; opacity: 0.5; }
.page-byline { margin: 14px 0 22px; font-size: 13px; color: var(--ink-muted); font-family: var(--mono); }
.page-byline .byline-meta { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.byline-sep { opacity: 0.4; }

.table-wrap { overflow-x: auto; margin: 24px 0; border: 2px solid var(--ink); border-radius: 14px; }
table.comparison-table { width: 100%; border-collapse: collapse; font-size: 15px; background: var(--paper); }
table.comparison-table th { background: var(--ink); color: var(--paper); text-align: left; padding: 14px 16px; font-weight: 700; font-size: 12px; text-transform: uppercase; letter-spacing: 0.06em; }
table.comparison-table td { padding: 13px 16px; border-bottom: 1px solid var(--rule); vertical-align: top; line-height: 1.45; color: var(--ink-soft); }
table.comparison-table tbody tr:last-child td { border-bottom: none; }
table.comparison-table tbody tr:hover { background: var(--flame-soft); }
table.comparison-table td strong { color: var(--ink); }
.table-note { font-size: 13px; color: var(--ink-muted); font-style: italic; margin: -12px 0 28px; line-height: 1.5; }

.related-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 14px; margin-top: 28px; }
.related-card { background: var(--paper); border: 2px solid var(--ink); border-radius: 14px; padding: 20px; text-decoration: none; color: var(--ink); transition: transform .14s, box-shadow .14s; box-shadow: var(--sh-card); }
.related-card:hover { transform: translate(-2px,-2px); box-shadow: var(--sh-pop); }
.related-card-title { font-family: var(--display); font-weight: 800; font-size: 18px; letter-spacing: -0.02em; margin-bottom: 6px; }
.related-card-desc { color: var(--ink-muted); font-size: 14px; line-height: 1.45; }

.logo-strip { background: var(--ink); color: var(--paper); padding: 40px 0; position: relative; overflow: hidden; }
.logo-strip-content { position: relative; z-index: 1; }
.trust-strip-grid { display: grid; grid-template-columns: auto repeat(5, 1fr); gap: 20px; align-items: center; }
@media (max-width: 920px) { .trust-strip-grid { grid-template-columns: repeat(2,1fr); gap: 24px; } .trust-strip-label-cell { grid-column: 1/-1; text-align: center; } }
.trust-strip-label { font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.16em; color: var(--gold); font-weight: 700; line-height: 1.4; }
.trust-strip-label strong { display: block; font-family: var(--display); font-size: 21px; color: #fff; letter-spacing: -0.02em; text-transform: none; font-weight: 900; margin-top: 4px; }
.trust-cat { display: flex; flex-direction: column; align-items: center; gap: 10px; text-align: center; }
.trust-cat-icon { width: 46px; height: 46px; border-radius: 12px; background: rgba(247,242,233,0.06); border: 1px solid rgba(232,184,75,0.25); display: grid; place-items: center; color: var(--gold); }
.trust-cat-label { font-size: 12px; font-weight: 600; color: rgba(247,242,233,0.85); line-height: 1.3; }
.partner-row { margin-top: 32px; padding-top: 26px; border-top: 1px solid rgba(247,242,233,0.1); display: flex; align-items: center; justify-content: center; gap: 38px; flex-wrap: wrap; }
.partner-row-label { font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.16em; color: rgba(247,242,233,0.45); font-weight: 700; }
.partner-mark { display: flex; align-items: center; gap: 12px; }
.partner-mark img { height: 26px; width: auto; }
.partner-text-mark { font-family: var(--display); font-size: 24px; font-weight: 900; letter-spacing: -0.03em; color: var(--paper); }
.partner-tag { margin-left: 8px; padding: 3px 8px; background: rgba(232,184,75,0.15); color: var(--gold); border-radius: 4px; font-family: var(--mono); font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; }

.final-cta { background: var(--paper); }
.final-cta-card { background: var(--flame); color: #fff; border: 2px solid var(--ink); border-radius: 24px; padding: clamp(40px, 6vw, 64px); position: relative; overflow: hidden; box-shadow: 8px 8px 0 var(--ink); }
.final-cta-card::before { content: ''; position: absolute; top: -100px; right: -100px; width: 320px; height: 320px; background: radial-gradient(circle, rgba(232,184,75,0.55) 0%, transparent 70%); border-radius: 50%; }
.final-cta-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 48px; align-items: center; position: relative; z-index: 1; }
@media (max-width: 900px) { .final-cta-grid { grid-template-columns: 1fr; gap: 28px; } }
.final-cta h2 { color: #fff; margin-bottom: 14px; }
.final-cta h2 em { color: var(--ink); font-style: italic; }
.final-cta p { color: rgba(255,255,255,0.92); font-size: 17px; line-height: 1.5; margin-bottom: 22px; max-width: 460px; }
.final-cta .btn-flame { background: #fff; color: var(--flame-deep); box-shadow: 4px 4px 0 var(--ink); }
.final-cta .btn-flame:hover { background: var(--paper); color: var(--ink); box-shadow: 6px 6px 0 var(--ink); }
.final-cta-meta { font-family: var(--mono); font-size: 12px; color: rgba(255,255,255,0.8); margin-top: 14px; }

.site-footer { background: var(--ink); color: var(--paper); padding: 70px 0 28px; position: relative; overflow: hidden; }
.site-footer::before { content:''; position:absolute; bottom:-240px; left:-140px; width:480px; height:480px; background: radial-gradient(circle, var(--forest) 0%, transparent 65%); opacity:0.5; border-radius:50%; }
.footer-grid { position: relative; z-index: 1; display: grid; grid-template-columns: 1.2fr 3fr; gap: 60px; padding-bottom: 48px; border-bottom: 1px solid rgba(247,242,233,0.12); margin-bottom: 32px; }
@media (max-width: 900px) { .footer-grid { grid-template-columns: 1fr; gap: 40px; } }
.footer-brand .logo { color: var(--paper); margin-bottom: 16px; }
.footer-brand p { font-family: var(--display); font-size: 18px; font-weight: 700; letter-spacing: -0.02em; line-height: 1.3; color: var(--paper); margin-bottom: 14px; max-width: 320px; }
.footer-brand p em { font-style: italic; color: var(--flame); }
.footer-cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
@media (max-width: 600px) { .footer-cols { grid-template-columns: 1fr 1fr; } }
.footer-col h4 { font-family: var(--display); font-weight: 800; font-size: 15px; letter-spacing: -0.01em; color: var(--gold); margin-bottom: 16px; }
.footer-col ul { list-style: none; }
.footer-col li { margin-bottom: 10px; }
.footer-col a { color: rgba(247,242,233,0.78); font-size: 14px; }
.footer-col a:hover { color: var(--flame); }
.footer-meta { position: relative; z-index: 1; padding: 24px 0 0; border-top: 1px solid rgba(247,242,233,0.08); font-size: 12px; color: rgba(247,242,233,0.55); line-height: 1.65; max-width: 920px; }
.footer-meta strong { color: var(--gold); }
.footer-meta a { color: var(--paper); text-decoration: underline; }
.footer-meta a:hover { color: var(--flame); }
.footer-bottom { position: relative; z-index: 1; margin-top: 20px; font-size: 12px; color: rgba(247,242,233,0.45); font-family: var(--mono); }

.admin-toggle { position: fixed; bottom: 20px; right: 20px; width: 40px; height: 40px; background: var(--ink); color: var(--paper); border: 2px solid var(--flame); border-radius: 50%; font-size: 17px; cursor: pointer; z-index: 50; opacity: 0.35; transition: opacity .2s, transform .2s; }
.admin-toggle:hover { opacity: 1; transform: scale(1.1); }
.admin-panel { position: fixed; top: 0; right: 0; width: min(560px,100vw); height: 100vh; background: var(--paper); z-index: 200; transform: translateX(100%); transition: transform .3s; overflow-y: auto; box-shadow: -16px 0 40px rgba(0,0,0,.15); }
.admin-panel.open { transform: translateX(0); }
.admin-close { position: absolute; top: 16px; right: 16px; background: none; border: none; font-size: 28px; cursor: pointer; color: var(--ink-muted); width: 36px; height: 36px; }
.admin-content { padding: 24px; }
.admin-header-row { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; gap: 12px; flex-wrap: wrap; }
.admin-title { font-family: var(--display); font-weight: 800; font-size: 22px; color: var(--ink); }
.admin-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.admin-btn { padding: 8px 14px; background: var(--paper-2); color: var(--ink); border: 2px solid var(--rule); border-radius: 8px; font-family: inherit; font-size: 12px; font-weight: 600; cursor: pointer; }
.admin-btn:hover { border-color: var(--ink); }
.admin-btn.primary { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.admin-btn.danger { color: var(--flame-deep); border-color: #F5C5BD; }
.admin-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; margin-bottom: 20px; }
.admin-stat { background: var(--paper); padding: 14px; border-radius: 10px; border: 2px solid var(--rule); text-align: center; }
.admin-stat-num { font-family: var(--display); font-weight: 800; font-size: 22px; color: var(--ink); }
.admin-stat-label { font-size: 11px; color: var(--ink-muted); margin-top: 4px; text-transform: uppercase; letter-spacing: 0.1em; }
.lead-row { background: var(--paper); padding: 14px; border-radius: 10px; border: 2px solid var(--rule); margin-bottom: 10px; font-size: 13px; }
.lead-row-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 6px; }
.lead-row-name { font-weight: 700; color: var(--ink); }
.lead-row-date { font-size: 11px; color: var(--ink-muted); }
.lead-row-meta { color: var(--ink-soft); line-height: 1.5; font-size: 12px; }
.lead-row-meta strong { color: var(--ink); }

.skip-link { position: absolute; left: -9999px; top: 0; z-index: 999; background: var(--ink); color: var(--paper); padding: 12px 20px; border-radius: 0 0 10px 0; font-weight: 700; font-size: 14px; }
.skip-link:focus { left: 0; color: var(--paper); }

@media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; scroll-behavior: auto !important; } }

.center { text-align: center; }
.mx-auto { margin-left: auto; margin-right: auto; }


/* ============================================================
   v2 → v3 COMPATIBILITY LAYER
   Legacy page components restyled in the v3 editorial language.
   ============================================================ */

/* hero / type */
.hero:has(.breadcrumbs) h1 { font-size: clamp(38px, 5.5vw, 68px); }
.accent { font-style: italic; color: var(--flame); }
.lede { font-size: clamp(17px, 1.7vw, 20px); line-height: 1.55; color: var(--ink-soft); max-width: 620px; margin: 18px 0 26px; }
.eyebrow { display: inline-flex; align-items: center; gap: 9px; font-family: var(--mono); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.18em; color: var(--flame-deep); margin-bottom: 16px; }
.pulse { width: 8px; height: 8px; border-radius: 50%; background: var(--flame); animation: blink 1.8s ease-in-out infinite; flex-shrink: 0; }
.hero-overline { display: flex; flex-wrap: wrap; gap: 8px 16px; font-family: var(--display); font-weight: 900; font-size: clamp(18px, 2.4vw, 26px); letter-spacing: -0.03em; color: var(--ink-muted); margin-bottom: 16px; }
.strike { position: relative; }
.strike::after { content: ''; position: absolute; left: -3px; right: -3px; top: 54%; height: 4px; background: var(--flame); transform: rotate(-2.5deg); }

/* labels */
.section-label { display: inline-flex; align-items: center; gap: 9px; font-family: var(--mono); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.18em; color: var(--flame-deep); margin-bottom: 14px; }
.section-label::before { content: ''; width: 22px; height: 2px; background: var(--flame); }
.bg-dark .section-label, .tool-section .section-label, .stat-band .section-label { color: var(--gold); }
.bg-dark .section-label::before, .tool-section .section-label::before, .stat-band .section-label::before { background: var(--gold); }
.section-sub { font-size: 17px; color: var(--ink-soft); line-height: 1.55; max-width: 640px; }
.bg-dark .section-sub, .tool-section .section-sub { color: rgba(247,242,233,0.78); }

/* buttons */
.btn-primary { background: var(--flame); color: #fff; box-shadow: var(--sh-pop); }
.btn-primary:hover { color: #fff; transform: translate(-2px,-2px); box-shadow: 6px 6px 0 var(--ink); }
.btn-secondary { background: transparent; color: var(--ink); box-shadow: var(--sh-card); }
.btn-secondary:hover { background: var(--ink); color: var(--paper); transform: translate(-1px,-1px); }
.submit-btn, .btn-reg-submit { display: inline-flex; align-items: center; justify-content: center; gap: 10px; width: 100%; font-family: var(--body); font-weight: 700; font-size: 16px; padding: 16px 28px; border-radius: 11px; border: 2px solid var(--ink); cursor: pointer; background: var(--flame); color: #fff; box-shadow: var(--sh-pop); transition: transform .12s, box-shadow .12s; }
.submit-btn:hover, .btn-reg-submit:hover { transform: translate(-2px,-2px); box-shadow: 6px 6px 0 var(--ink); }

/* backgrounds */
.bg-dark { background: var(--ink); color: var(--paper); }
.bg-dark h2, .bg-dark h3 { color: #fff; }
.bg-dark p { color: rgba(247,242,233,0.8); }
.bg-soft { background: var(--paper-2); }

/* quick answer (the AI citation surface) */
.definition-block { background: var(--paper); border: 2px solid var(--ink); border-left: 6px solid var(--flame); border-radius: 0 14px 14px 0; padding: 22px 24px; margin: 22px 0; box-shadow: var(--sh-card); max-width: 760px; }
.def-label { font-family: var(--mono); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.14em; color: var(--flame-deep); margin-bottom: 10px; }
.def-text { font-size: 16.5px; line-height: 1.6; color: var(--ink); margin: 0; }

/* cards */
.grid-3, .cols-3 { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px,1fr)); gap: 16px; }
.cols-2 { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px,1fr)); gap: 16px; }
.cols-1 { display: grid; gap: 10px; }
.card { background: var(--paper); border: 2px solid var(--ink); border-radius: 14px; padding: 24px 22px; box-shadow: var(--sh-card); transition: transform .14s, box-shadow .14s; color: var(--ink); display: block; text-decoration: none; }
a.card:hover { transform: translate(-2px,-2px); box-shadow: var(--sh-pop); }
.card.dark { background: var(--ink); color: var(--paper); }
.card.dark .card-title { color: #fff; }
.card.dark .card-desc { color: rgba(247,242,233,0.78); }
.card-icon { width: 44px; height: 44px; border-radius: 11px; background: var(--flame-soft); color: var(--flame-deep); display: grid; place-items: center; margin-bottom: 14px; }
.card.dark .card-icon { background: rgba(255,77,46,0.18); color: var(--flame); }
.card-title { font-family: var(--display); font-weight: 800; font-size: 19px; letter-spacing: -0.02em; margin-bottom: 7px; }
.card-desc { color: var(--ink-muted); font-size: 14.5px; line-height: 1.5; }
.card-arrow { margin-top: 14px; font-weight: 700; font-size: 14px; color: var(--flame-deep); }

/* stats */
.stat-band { background: var(--ink); color: var(--paper); }
.stat-band h2 { color: #fff; }
.stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px,1fr)); gap: 0; border: 2px solid var(--paper); border-radius: 16px; overflow: hidden; }
.stats-grid > div, .stat-item { padding: 28px 24px; border-right: 2px solid rgba(247,242,233,0.2); }
.stats-grid > div:last-child { border-right: none; }
.stat-big { font-family: var(--display); font-weight: 900; font-size: clamp(38px, 5vw, 56px); line-height: 0.95; letter-spacing: -0.04em; color: var(--gold); margin-bottom: 10px; }
.stat-label { font-size: 14px; color: rgba(247,242,233,0.82); line-height: 1.45; }
@media (max-width: 720px) { .stats-grid { grid-template-columns: 1fr; } .stats-grid > div { border-right: none; border-bottom: 2px solid rgba(247,242,233,0.2); } .stats-grid > div:last-child { border-bottom: none; } }

/* toc */
.toc-box { background: var(--paper-2); border: 2px solid var(--ink); border-radius: 14px; padding: 20px 22px; margin: 8px 0 8px; box-shadow: var(--sh-card); }
.toc-label { font-family: var(--mono); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.14em; color: var(--flame-deep); margin-bottom: 10px; }
.toc-box ul { list-style: none; margin: 0; padding: 0; columns: 2; column-gap: 28px; }
.toc-box li { margin-bottom: 7px; break-inside: avoid; }
.toc-box a { color: var(--ink-soft); font-size: 14px; font-weight: 600; }
.toc-box a:hover { color: var(--flame-deep); }
@media (max-width: 640px) { .toc-box ul { columns: 1; } }

/* pills */
.pill-grid { display: flex; flex-wrap: wrap; gap: 9px; }
.pill-item { display: inline-block; padding: 9px 15px; border: 2px solid var(--ink); border-radius: 999px; background: var(--paper); font-size: 13.5px; font-weight: 600; color: var(--ink); box-shadow: var(--sh-card); }
a.pill-item:hover { background: var(--flame); color: #fff; transform: translate(-1px,-1px); }

/* duration cards (temporary pages) */
.duration-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(190px,1fr)); gap: 14px; }
.duration-card { background: var(--paper); border: 2px solid var(--ink); border-radius: 14px; padding: 22px 18px; text-align: center; box-shadow: var(--sh-card); color: var(--ink); display: block; text-decoration: none; transition: transform .14s, box-shadow .14s; }
a.duration-card:hover { transform: translate(-2px,-2px); box-shadow: var(--sh-pop); }
.duration-num { font-family: var(--display); font-weight: 900; font-size: 34px; letter-spacing: -0.03em; color: var(--flame-deep); line-height: 1; margin-bottom: 8px; }
.duration-use { font-size: 13.5px; color: var(--ink-muted); line-height: 1.4; }

/* trust bar */
.trust-bar { display: flex; gap: 18px; flex-wrap: wrap; align-items: center; margin-top: 22px; font-size: 14.5px; color: var(--ink-soft); font-weight: 500; }
.trust-bar-item { display: inline-flex; align-items: center; gap: 8px; }
.trust-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--forest-mid); flex-shrink: 0; }

/* legacy forms → v3 form language */
.lead-form-wrap { background: var(--paper-2); }
.reg-form { background: var(--paper); border: 2px solid var(--ink); border-radius: 18px; padding: clamp(24px,4vw,36px); box-shadow: var(--sh-pop); }
.form-header h3 { margin-bottom: 6px; }
.form-header p { color: var(--ink-muted); font-size: 14.5px; margin-bottom: 18px; }
.field-group { margin-bottom: 16px; }
.field-label, .reg-label { display: block; font-size: 13px; font-weight: 700; color: var(--ink); margin-bottom: 6px; }
.required { color: var(--flame-deep); }
.optional { color: var(--ink-muted); font-weight: 400; }
.reg-form input, .reg-form select, .reg-form textarea, .field-group input, .field-group select, .field-group textarea { width: 100%; padding: 13px 14px; background: var(--paper-2); border: 2px solid var(--rule); border-radius: 10px; font-family: var(--body); font-size: 15px; color: var(--ink); -webkit-appearance: none; appearance: none; transition: border-color .15s, background .15s; }
.reg-form input:focus, .reg-form select:focus, .reg-form textarea:focus, .field-group input:focus, .field-group select:focus, .field-group textarea:focus { outline: none; border-color: var(--flame); background: var(--paper); }
.consent { display: flex; gap: 10px; align-items: flex-start; margin: 18px 0; padding: 14px; background: var(--paper-2); border-radius: 11px; font-size: 13px; color: var(--ink-soft); line-height: 1.5; }
.consent input { margin-top: 2px; width: 18px; height: 18px; accent-color: var(--flame); flex-shrink: 0; }
.form-foot, .reg-foot { font-size: 12px; color: var(--ink-muted); margin-top: 12px; line-height: 1.5; }
.reg-quote-card { background: var(--ink); color: var(--paper); border-radius: 16px; border: 2px solid var(--ink); box-shadow: var(--sh-pop); padding: 26px; }
.reg-quote-inner h3 { color: #fff; }
.reg-quote-inner p { color: rgba(247,242,233,0.8); }
.reg-no-reg { font-size: 13px; color: var(--ink-muted); margin-top: 12px; }
.goshorty-block { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; margin: 16px 0; }
.goshorty-logo { height: 28px; width: auto; }
.success-state { display: none; text-align: center; padding: 30px; background: var(--forest-soft); border: 2px solid var(--forest); border-radius: 14px; }
.success-state.show { display: block; animation: chatIn .3s ease-out; }

/* related links */
.related-links { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px,1fr)); gap: 12px; list-style: none; padding: 0; }
.related-links a { display: block; background: var(--paper); border: 2px solid var(--ink); border-radius: 12px; padding: 15px 17px; font-weight: 600; font-size: 14.5px; color: var(--ink); box-shadow: var(--sh-card); transition: transform .14s, box-shadow .14s; }
.related-links a:hover { transform: translate(-2px,-2px); box-shadow: var(--sh-pop); color: var(--ink); }

/* legacy tool fallbacks (replaced by chat, kept safe) */
.tool-wrapper { max-width: 720px; margin: 0 auto; }
.tool-card { background: var(--paper); border-radius: 20px; border: 2px solid var(--ink); box-shadow: 8px 8px 0 var(--flame); padding: 26px 22px; }
.tool-step { display: none; }
.tool-step.active { display: block; }
.result-header h3 { margin-bottom: 8px; }
.result-cta-row { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 20px; }
.result-honest-bit { background: var(--forest-soft); border-left: 4px solid var(--forest); border-radius: 0 12px 12px 0; padding: 16px 18px; font-size: 14px; color: var(--ink-soft); line-height: 1.5; margin: 18px 0; }

/* sources box (information consistency / agent trust) */
.sources-box { background: var(--forest-soft); border: 2px solid var(--forest); border-radius: 14px; padding: 20px 22px; margin: 36px 0 8px; max-width: 760px; }
.sources-label { font-family: var(--mono); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.14em; color: var(--forest); margin-bottom: 10px; }
.sources-box ul { list-style: none; margin: 0; padding: 0; }
.sources-box li { margin-bottom: 7px; }
.sources-box a { color: var(--forest); font-weight: 600; font-size: 14.5px; text-decoration: underline; }
.sources-box a:hover { color: var(--ink); }

/* cookie consent banner */
.consent-banner { position: fixed; left: 14px; right: 14px; bottom: 14px; z-index: 300; background: var(--ink); color: var(--paper); border: 2px solid var(--flame); border-radius: 16px; padding: 18px 20px; box-shadow: 6px 6px 0 rgba(17,16,14,0.35); max-width: 560px; margin: 0 auto; animation: chatIn .35s ease-out; }
.consent-banner p { font-size: 14px; line-height: 1.5; color: rgba(247,242,233,0.9); margin: 0 0 14px; }
.consent-banner a { color: var(--gold); text-decoration: underline; }
.consent-banner-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.consent-accept { background: var(--flame); color: #fff; border: 2px solid var(--paper); border-radius: 9px; padding: 11px 20px; font-family: var(--body); font-weight: 700; font-size: 14px; cursor: pointer; }
.consent-accept:hover { transform: translate(-1px,-1px); }
.consent-decline { background: transparent; color: var(--paper); border: 2px solid rgba(247,242,233,0.4); border-radius: 9px; padding: 11px 20px; font-family: var(--body); font-weight: 600; font-size: 14px; cursor: pointer; }
.consent-decline:hover { border-color: var(--paper); }


/* ============================================================
   BALANCED LAYOUT — centred content-page heroes and key blocks
   (homepage keeps its split editorial hero, which fills the width)
   ============================================================ */
.hero:has(.breadcrumbs) { text-align: center; }
.hero:has(.breadcrumbs) .container { max-width: 940px; }
.hero:has(.breadcrumbs) .breadcrumbs { display: flex; justify-content: center; }
.hero:has(.breadcrumbs) .page-byline { display: flex; justify-content: center; }
.hero:has(.breadcrumbs) .byline-meta { justify-content: center; }
.hero:has(.breadcrumbs) .definition-block { margin-left: auto; margin-right: auto; text-align: left; }
.hero:has(.breadcrumbs) .lede { margin-left: auto; margin-right: auto; }
.hero:has(.breadcrumbs) .btn-row { justify-content: center; }
.hero:has(.breadcrumbs) .trust-bar { justify-content: center; }
.toc-box { max-width: 880px; margin-left: auto; margin-right: auto; }
.sources-box { margin-left: auto; margin-right: auto; }
.hero:has(.breadcrumbs) .eyebrow { margin-left: auto; margin-right: auto; }


/* ============ GoShorty quote block (partner CTA) ============ */
.gs-quote-card { background: var(--ink); color: var(--paper); border: 2px solid var(--ink); border-radius: 18px; box-shadow: 8px 8px 0 var(--flame); padding: clamp(26px,4vw,40px); max-width: 760px; margin: 0 auto; }
.gs-quote-card .goshorty-logo { height: 34px; width: auto; margin-bottom: 16px; }
.gs-quote-card h2 { color: #fff; font-size: clamp(24px,3vw,32px); margin-bottom: 8px; }
.gs-quote-card > p, .gs-quote-card .gs-line { color: rgba(247,242,233,0.85); font-size: 15.5px; line-height: 1.55; margin-bottom: 18px; }
.gs-reg-row { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 10px; }
.gs-reg-input { flex: 1 1 200px; min-width: 0; background: #FFD307; color: #11100E; border: 2px solid #11100E; border-radius: 10px; padding: 14px 16px; font-family: var(--body); font-weight: 800; font-size: 20px; letter-spacing: 0.08em; text-transform: uppercase; text-align: center; }
.gs-reg-input::placeholder { color: rgba(17,16,14,0.5); }
.gs-reg-input:focus { outline: 3px solid var(--flame); outline-offset: 2px; }
.gs-skip { background: none; border: none; color: var(--gold); font-family: var(--body); font-size: 14px; font-weight: 600; text-decoration: underline; cursor: pointer; padding: 4px 0; }
.gs-skip:hover { color: #fff; }
.gs-trust { font-size: 13px; color: rgba(247,242,233,0.7); margin: 14px 0 6px; }
.gs-disclosure { font-size: 12px; color: rgba(247,242,233,0.55); line-height: 1.5; margin: 0; }
.visually-hidden { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
/* GoShorty at-a-glance facts */
.gs-facts { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px,1fr)); gap: 10px; margin: 20px 0 6px; }
.gs-fact { background: var(--paper); border: 2px solid var(--ink); border-radius: 11px; padding: 13px 15px; font-size: 14px; font-weight: 600; color: var(--ink); box-shadow: var(--sh-card); }


/* WooCommerce compatibility (effect only when WooCommerce active) */
.cgc-shop { max-width: var(--maxw, 1180px); }
.woocommerce a.button,.woocommerce button.button,.woocommerce input.button,.woocommerce #respond input#submit,.woocommerce a.button.alt,.woocommerce button.button.alt,#review_form #submit{background:var(--flame);color:#fff;border:2px solid var(--ink);border-radius:10px;font-family:var(--body);font-weight:700;box-shadow:3px 3px 0 var(--ink);padding:12px 22px;transition:transform .12s,box-shadow .12s;}
.woocommerce a.button:hover,.woocommerce button.button:hover,.woocommerce input.button:hover,.woocommerce #respond input#submit:hover,.woocommerce a.button.alt:hover,.woocommerce button.button.alt:hover,#review_form #submit:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--ink);color:#fff;}
.woocommerce span.onsale{background:var(--forest);color:#fff;border-radius:999px;}
.woocommerce .woocommerce-message,.woocommerce .woocommerce-info{border-top-color:var(--flame);}
.woocommerce ul.products li.product .price{color:var(--ink);font-weight:700;}
.woocommerce .star-rating span{color:var(--flame);}
