/* ============================================================
   AdvisorLab — marketing site stylesheet
   Light, blue-trust design tuned for storm-restoration roofers.
   Three visual directions are selectable via [data-theme] on <html>:
     trust  (default) — clean professional blue
     saas            — bold modern, ink-forward
     rugged          — steel + warm storm tones
   Headline face via [data-font]: archivo | saira | grotesk
   ============================================================ */

/* ---------- Fonts ---------- */
@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@400;500;600;700;800;900&family=Hanken+Grotesk:wght@400;500;600;700&family=DM+Mono:wght@400;500&family=Saira+Condensed:wght@500;600;700;800&family=Space+Grotesk:wght@500;600;700&display=swap');

/* ---------- Theme tokens ---------- */
:root,
:root[data-theme="trust"] {
  --bg:        oklch(0.985 0.005 240);
  --bg-2:      oklch(0.965 0.007 245);
  --bg-ink:    oklch(0.24 0.03 256);   /* dark band */
  --surface:   #ffffff;
  --border:    oklch(0.905 0.009 248);
  --border-2:  oklch(0.85 0.012 248);

  --ink:       oklch(0.23 0.022 256);
  --ink-2:     oklch(0.44 0.02 256);
  --ink-3:     oklch(0.57 0.016 256);
  --on-dark:   oklch(0.97 0.006 245);
  --on-dark-2: oklch(0.75 0.012 248);

  --brand:        oklch(0.52 0.155 256);
  --brand-strong: oklch(0.42 0.15 258);
  --brand-tint:   oklch(0.955 0.028 256);
  --brand-line:   oklch(0.88 0.05 256);

  --accent:    oklch(0.72 0.155 62);   /* amber — brand nod, energy */
  --accent-tint: oklch(0.95 0.04 70);
  --alert:     oklch(0.575 0.2 25);    /* storm red */
  --alert-tint: oklch(0.955 0.035 28);
  --good:      oklch(0.6 0.12 156);

  --display: 'Archivo', system-ui, sans-serif;
  --body:    'Hanken Grotesk', system-ui, sans-serif;
  --mono:    'DM Mono', ui-monospace, monospace;

  --display-tracking: -0.02em;
  --display-weight: 800;
}

:root[data-theme="saas"] {
  --bg:        oklch(0.99 0.003 250);
  --bg-2:      oklch(0.96 0.005 250);
  --bg-ink:    oklch(0.18 0.02 258);
  --surface:   #ffffff;
  --border:    oklch(0.9 0.006 250);
  --border-2:  oklch(0.84 0.008 250);

  --ink:       oklch(0.17 0.015 258);
  --ink-2:     oklch(0.4 0.014 258);
  --ink-3:     oklch(0.55 0.012 258);
  --on-dark:   oklch(0.98 0.004 250);
  --on-dark-2: oklch(0.72 0.01 250);

  --brand:        oklch(0.48 0.17 262);
  --brand-strong: oklch(0.36 0.16 264);
  --brand-tint:   oklch(0.95 0.03 262);
  --brand-line:   oklch(0.86 0.06 262);

  --accent:    oklch(0.7 0.17 152);    /* electric green */
  --accent-tint: oklch(0.95 0.05 152);
  --alert:     oklch(0.58 0.2 25);
  --alert-tint: oklch(0.955 0.035 28);
  --good:      oklch(0.62 0.13 152);

  --display-tracking: -0.035em;
  --display-weight: 800;
}

:root[data-theme="rugged"] {
  --bg:        oklch(0.975 0.006 80);
  --bg-2:      oklch(0.95 0.009 78);
  --bg-ink:    oklch(0.26 0.018 250);
  --surface:   #ffffff;
  --border:    oklch(0.89 0.012 80);
  --border-2:  oklch(0.82 0.016 78);

  --ink:       oklch(0.26 0.02 70);
  --ink-2:     oklch(0.45 0.018 70);
  --ink-3:     oklch(0.58 0.015 72);
  --on-dark:   oklch(0.96 0.008 80);
  --on-dark-2: oklch(0.74 0.014 78);

  --brand:        oklch(0.5 0.09 245);  /* steel blue */
  --brand-strong: oklch(0.4 0.085 248);
  --brand-tint:   oklch(0.94 0.02 245);
  --brand-line:   oklch(0.86 0.035 245);

  --accent:    oklch(0.64 0.17 45);     /* burnt orange */
  --accent-tint: oklch(0.94 0.045 55);
  --alert:     oklch(0.55 0.2 28);
  --alert-tint: oklch(0.95 0.04 32);
  --good:      oklch(0.58 0.12 150);

  --display-tracking: -0.01em;
  --display-weight: 800;
}

:root[data-font="saira"]   { --display: 'Saira Condensed', system-ui, sans-serif; --display-tracking: 0.005em; --display-weight: 700; }
:root[data-font="grotesk"] { --display: 'Space Grotesk', system-ui, sans-serif;  --display-tracking: -0.025em; --display-weight: 700; }

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--body);
  background: var(--bg);
  color: var(--ink);
  line-height: 1.55;
  font-size: 18px;
  letter-spacing: 0.002em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }

/* ---------- Layout ---------- */
.wrap { width: min(1180px, 92vw); margin-inline: auto; }
.section { padding: clamp(64px, 9vw, 132px) 0; }
.section--tight { padding: clamp(48px, 6vw, 88px) 0; }

/* ---------- Type ---------- */
h1, h2, h3, h4 {
  font-family: var(--display);
  font-weight: var(--display-weight);
  letter-spacing: var(--display-tracking);
  line-height: 1.02;
  color: var(--ink);
  text-wrap: balance;
}
.eyebrow {
  font-family: var(--mono);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brand);
  display: inline-flex;
  align-items: center;
  gap: 9px;
}
.eyebrow::before {
  content: "";
  width: 22px; height: 2px;
  background: var(--brand);
  display: inline-block;
}
.lede { font-size: clamp(18px, 2vw, 21px); color: var(--ink-2); line-height: 1.5; text-wrap: pretty; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--body);
  font-weight: 600;
  font-size: 16px;
  padding: 15px 26px;
  border-radius: 11px;
  border: 1px solid transparent;
  transition: transform .15s ease, box-shadow .2s ease, background .2s ease;
  white-space: nowrap;
}
.btn--primary {
  background: var(--brand);
  color: #fff;
  box-shadow: 0 1px 2px oklch(0.42 0.15 258 / .25), 0 8px 22px oklch(0.42 0.15 258 / .22);
}
.btn--primary:hover { background: var(--brand-strong); transform: translateY(-1px); box-shadow: 0 2px 4px oklch(0.42 0.15 258 / .3), 0 14px 30px oklch(0.42 0.15 258 / .28); }
.btn--ghost { background: var(--surface); color: var(--ink); border-color: var(--border-2); }
.btn--ghost:hover { border-color: var(--ink-3); transform: translateY(-1px); }
.btn--lg { padding: 17px 30px; font-size: 17px; }
.btn--block { width: 100%; justify-content: center; }
.btn .arrow { transition: transform .18s ease; }
.btn:hover .arrow { transform: translateX(3px); }

/* ---------- Header ---------- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: oklch(0.985 0.005 240 / 0.82);
  backdrop-filter: saturate(1.4) blur(14px);
  border-bottom: 1px solid var(--border);
}
.nav { display: flex; align-items: center; justify-content: space-between; height: 72px; gap: 24px; }
.brand { display: flex; align-items: center; gap: 11px; font-family: var(--display); font-weight: 800; font-size: 21px; letter-spacing: -0.02em; color: var(--ink); }
.brand .logomark {
  width: 30px; height: 30px; border-radius: 8px;
  background: linear-gradient(145deg, var(--brand), var(--brand-strong));
  display: grid; place-items: center;
  color: #fff; font-family: var(--mono); font-size: 15px; font-weight: 500;
  box-shadow: inset 0 1px 0 oklch(1 0 0 / .3);
}
.brand .logomark::after { content: "A"; }
.brand-logo { height: 30px; width: auto; display: block; }
@media (max-width: 480px) { .brand-logo { height: 26px; } }
.nav-links { display: flex; align-items: center; gap: 30px; }
.nav-links a { font-size: 15px; color: var(--ink-2); font-weight: 500; transition: color .15s; }
.nav-links a:hover { color: var(--ink); }
.nav-cta { display: flex; align-items: center; gap: 14px; }
.nav-tel { font-family: var(--mono); font-size: 14px; color: var(--ink-2); }
@media (max-width: 860px) { .nav-links { display: none; } .nav-tel { display: none; } }

/* ---------- Hero ---------- */
.hero { position: relative; overflow: hidden; padding-top: clamp(48px, 7vw, 96px); padding-bottom: clamp(56px, 8vw, 110px); }
.hero::before {
  content: ""; position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(60% 70% at 88% 8%, var(--brand-tint), transparent 60%),
    radial-gradient(50% 60% at 5% 90%, var(--accent-tint), transparent 55%);
  opacity: .8;
}
.hero .wrap { position: relative; z-index: 1; }
.hero-grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(32px, 5vw, 72px); align-items: center; }
@media (max-width: 760px) { .hero-grid { grid-template-columns: 1fr; } .hero h1 { font-size: clamp(34px, 9vw, 52px); } .hero .lede { max-width: 52ch; } }
:root[data-hero="center"] .hero-grid { grid-template-columns: 1fr; max-width: 820px; margin-inline: auto; text-align: center; }
:root[data-hero="center"] .hero-visual { display: none; }
:root[data-hero="center"] .hero-cta, :root[data-hero="center"] .hero-trust { justify-content: center; }
:root[data-hero="center"] .eyebrow { justify-content: center; }

.hero h1 { font-size: clamp(40px, 6.4vw, 74px); }
.hero h1 .hl { color: var(--brand); }
.hero .lede { margin-top: 22px; max-width: 33ch; }
:root[data-hero="center"] .hero .lede { max-width: 52ch; margin-inline: auto; }
.hero-cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 32px; }
.hero-trust { display: flex; flex-wrap: wrap; gap: 10px 22px; margin-top: 30px; }
.hero-trust span { display: inline-flex; align-items: center; gap: 8px; font-size: 14.5px; color: var(--ink-2); font-weight: 500; }
.hero-trust .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--good); }

/* ---------- Hero live-feed visual ---------- */
.feed {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 20px;
  box-shadow: 0 1px 0 oklch(1 0 0 / .8) inset, 0 30px 60px -30px oklch(0.42 0.1 258 / .35), 0 10px 24px -16px oklch(0.42 0.1 258 / .3);
  padding: 18px;
  display: grid;
  gap: 12px;
}
.feed-head { display: flex; align-items: center; justify-content: space-between; padding: 4px 6px 10px; border-bottom: 1px solid var(--border); }
.feed-head .live { display: inline-flex; align-items: center; gap: 8px; font-family: var(--mono); font-size: 12px; letter-spacing: 0.06em; color: var(--ink-2); text-transform: uppercase; }
.feed-head .live .pulse { width: 8px; height: 8px; border-radius: 50%; background: var(--alert); box-shadow: 0 0 0 0 oklch(0.575 0.2 25 / .5); animation: pulse 2s infinite; }
@keyframes pulse { 0% { box-shadow: 0 0 0 0 oklch(0.575 0.2 25 / .5); } 70% { box-shadow: 0 0 0 9px oklch(0.575 0.2 25 / 0); } 100% { box-shadow: 0 0 0 0 oklch(0.575 0.2 25 / 0); } }
.feed-head .clock { font-family: var(--mono); font-size: 13px; color: var(--ink-3); }

.alert-card { background: var(--alert-tint); border: 1px solid oklch(0.575 0.2 25 / .25); border-radius: 13px; padding: 14px 15px; }
.alert-card .row { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.alert-card .tag { font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--alert); font-weight: 500; }
.alert-card .loc { font-family: var(--display); font-weight: 700; font-size: 19px; letter-spacing: -0.01em; margin-top: 7px; }
.alert-card .meta { display: flex; gap: 16px; margin-top: 8px; }
.alert-card .meta b { font-family: var(--mono); font-weight: 500; font-size: 13px; color: var(--ink); }
.alert-card .meta small { display: block; font-size: 11px; color: var(--ink-3); margin-top: 1px; }

.flow-arrow { display: grid; place-items: center; gap: 3px; color: var(--ink-3); }
.flow-arrow .t { font-family: var(--mono); font-size: 11px; letter-spacing: 0.05em; }
.flow-arrow .a { font-size: 16px; line-height: 1; color: var(--brand); }

.sms-bubble { background: var(--brand); color: #fff; border-radius: 14px 14px 14px 4px; padding: 13px 15px; max-width: 88%; box-shadow: 0 6px 16px -8px oklch(0.42 0.15 258 / .5); }
.sms-bubble .from { font-family: var(--mono); font-size: 11px; opacity: .8; letter-spacing: 0.04em; margin-bottom: 4px; }
.sms-bubble p { font-size: 14px; line-height: 1.45; }
.sms-meta { display: flex; align-items: center; gap: 7px; font-family: var(--mono); font-size: 11.5px; color: var(--good); padding-left: 4px; }
.sms-meta .check { width: 15px; height: 15px; border-radius: 50%; background: var(--good); color: #fff; display: grid; place-items: center; font-size: 9px; }

/* ---------- Logos / trust strip ---------- */
.strip { border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); background: var(--bg-2); }
.strip .wrap { display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap; padding: 22px 0; }
.strip .label { font-family: var(--mono); font-size: 12.5px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-3); }
.strip .items { display: flex; gap: 28px; flex-wrap: wrap; }
.strip .items span { font-family: var(--display); font-weight: 700; font-size: 16px; color: var(--ink-2); letter-spacing: -0.01em; opacity: .72; }

/* ---------- Section heading ---------- */
.sec-head { max-width: 760px; }
.sec-head h2 { font-size: clamp(30px, 4.4vw, 50px); margin-top: 16px; }
.sec-head .lede { margin-top: 18px; }
.sec-head--center { margin-inline: auto; text-align: center; }
.sec-head--center .eyebrow { justify-content: center; }

/* ---------- How it works ---------- */
.steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin-top: 54px; counter-reset: step; }
.step { position: relative; background: var(--surface); border: 1px solid var(--border); border-radius: 16px; padding: 26px 22px; }
.step::before {
  counter-increment: step; content: counter(step, decimal-leading-zero);
  font-family: var(--mono); font-size: 13px; color: var(--brand); font-weight: 500;
}
.step h3 { font-size: 20px; margin-top: 14px; line-height: 1.12; }
.step p { font-size: 15px; color: var(--ink-2); margin-top: 9px; line-height: 1.5; }
.step .t { font-family: var(--mono); font-size: 12px; color: var(--accent); margin-top: 14px; font-weight: 500; }
.step--accent { background: var(--bg-ink); border-color: transparent; }
.step--accent::before { color: var(--accent); }
.step--accent h3 { color: var(--on-dark); }
.step--accent p { color: var(--on-dark-2); }
@media (max-width: 980px) { .steps { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .steps { grid-template-columns: 1fr; } }

/* ---------- How it works: two tracks ---------- */
.track { margin-top: 44px; }
.track + .track { margin-top: 48px; }
.track-head { display: flex; align-items: center; gap: 16px; margin-bottom: 20px; }
.track-ic { width: 50px; height: 50px; flex: none; border-radius: 13px; background: var(--brand-tint); border: 1px solid var(--brand-line); color: var(--brand); display: grid; place-items: center; }
.track-ic svg { width: 25px; height: 25px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.track-name { font-family: var(--display); font-weight: var(--display-weight); font-size: 26px; letter-spacing: var(--display-tracking); line-height: 1; }
.track-trigger { font-family: var(--mono); font-size: 12.5px; color: var(--ink-3); margin-top: 6px; }
.track-tag { margin-left: auto; font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--accent); border: 1px solid var(--accent); border-radius: 999px; padding: 6px 13px; white-space: nowrap; }
.track-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; counter-reset: step; }
@media (max-width: 760px) { .track-steps { grid-template-columns: 1fr; } .track-tag { display: none; } }

/* ---------- Feature / agents grid ---------- */
.features { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 52px; }
.feature { background: var(--surface); border: 1px solid var(--border); border-radius: 16px; padding: 28px 24px; transition: border-color .2s, transform .2s, box-shadow .2s; }
.feature:hover { border-color: var(--brand-line); transform: translateY(-2px); box-shadow: 0 18px 40px -28px oklch(0.42 0.12 258 / .4); }
.feature .ic { width: 46px; height: 46px; border-radius: 12px; background: var(--brand-tint); color: var(--brand); display: grid; place-items: center; border: 1px solid var(--brand-line); }
.feature .ic svg { width: 23px; height: 23px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.feature h3 { font-size: 21px; margin-top: 18px; }
.feature p { font-size: 15.5px; color: var(--ink-2); margin-top: 10px; line-height: 1.52; }
@media (max-width: 940px) { .features { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .features { grid-template-columns: 1fr; } }

/* ---------- Proof / stats band ---------- */
.proof { background: var(--bg-ink); color: var(--on-dark); }
.proof .sec-head h2 { color: var(--on-dark); }
.proof .eyebrow { color: oklch(0.78 0.1 256); }
.proof .eyebrow::before { background: oklch(0.78 0.1 256); }
.proof .lede { color: var(--on-dark-2); }
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; margin-top: 52px; }
.stat { border-top: 2px solid oklch(1 0 0 / .14); padding-top: 22px; }
.stat .n { font-family: var(--display); font-weight: var(--display-weight); font-size: clamp(38px, 5vw, 56px); letter-spacing: -0.03em; line-height: 1; color: var(--on-dark); }
.stat .n .u { color: var(--accent); }
.stat .l { font-size: 14.5px; color: var(--on-dark-2); margin-top: 12px; line-height: 1.4; }
@media (max-width: 820px) { .stats { grid-template-columns: repeat(2, 1fr); gap: 28px 24px; } }
@media (max-width: 460px) { .stats { grid-template-columns: 1fr; } }

/* ---------- Product peek ---------- */
.peek-grid { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(28px, 4vw, 56px); align-items: center; }
.peek ul { list-style: none; margin-top: 24px; display: grid; gap: 14px; }
.peek li { display: flex; gap: 12px; font-size: 16px; color: var(--ink-2); }
.peek li .ck { flex: none; width: 22px; height: 22px; border-radius: 6px; background: var(--brand-tint); color: var(--brand); display: grid; place-items: center; font-size: 12px; margin-top: 2px; border: 1px solid var(--brand-line); }
.peek li b { color: var(--ink); font-weight: 600; }
@media (max-width: 860px) { .peek-grid { grid-template-columns: 1fr; } }

/* ---------- Contact / opt-in ---------- */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px, 4vw, 60px); align-items: start; }
.contact-info .lede { margin-top: 18px; max-width: 44ch; }
.contact-list { margin-top: 30px; display: grid; gap: 2px; }
.contact-list a, .contact-list div { display: flex; align-items: center; gap: 14px; padding: 15px 0; border-bottom: 1px solid var(--border); font-size: 16px; color: var(--ink); }
.contact-list .k { font-family: var(--mono); font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-3); width: 84px; flex: none; }
.contact-list a:hover { color: var(--brand); }

.form-card { background: var(--surface); border: 1px solid var(--border); border-radius: 18px; padding: clamp(24px, 3vw, 34px); box-shadow: 0 24px 60px -40px oklch(0.42 0.1 258 / .4); }
.form-card h3 { font-size: 24px; }
.form-card .sub { font-size: 15px; color: var(--ink-2); margin-top: 8px; }
.field { margin-top: 16px; }
.field label { display: block; font-size: 13px; font-weight: 600; color: var(--ink-2); margin-bottom: 7px; }
.field input, .field select, .field textarea {
  width: 100%; font-family: var(--body); font-size: 16px; color: var(--ink);
  background: var(--bg); border: 1px solid var(--border-2); border-radius: 10px;
  padding: 13px 14px; transition: border-color .15s, box-shadow .15s;
}
.field input:focus, .field select:focus, .field textarea:focus {
  outline: none; border-color: var(--brand); box-shadow: 0 0 0 3px var(--brand-tint);
}
.field--row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.consent { display: flex; gap: 11px; margin-top: 18px; padding: 14px; background: var(--bg-2); border: 1px solid var(--border); border-radius: 11px; }
.consent input { flex: none; width: 19px; height: 19px; margin-top: 2px; accent-color: var(--brand); }
.consent label { font-size: 12.5px; line-height: 1.5; color: var(--ink-2); }
.consent a { color: var(--brand); text-decoration: underline; text-underline-offset: 2px; }
.form-card .btn { margin-top: 18px; }
.form-fine { font-size: 11.5px; color: var(--ink-3); margin-top: 14px; line-height: 1.5; }
@media (max-width: 820px) { .contact-grid { grid-template-columns: 1fr; } }

/* ---------- Footer ---------- */
.site-footer { background: var(--bg-ink); color: var(--on-dark-2); padding: 56px 0 30px; }
.footer-top { display: flex; justify-content: space-between; gap: 30px; flex-wrap: wrap; padding-bottom: 34px; border-bottom: 1px solid oklch(1 0 0 / .1); }
.footer-brand { max-width: 320px; }
.footer-brand .brand { color: var(--on-dark); }
.footer-brand p { font-size: 14.5px; margin-top: 14px; line-height: 1.55; }
.footer-cols { display: flex; gap: 56px; flex-wrap: wrap; }
.footer-col h4 { font-family: var(--mono); font-weight: 500; font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--on-dark); }
.footer-col a, .footer-col span { display: block; font-size: 14.5px; color: var(--on-dark-2); margin-top: 12px; transition: color .15s; }
.footer-col a:hover { color: var(--on-dark); }
.footer-bottom { display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; padding-top: 24px; font-size: 13px; color: var(--on-dark-2); }
.footer-bottom .legal { display: flex; gap: 22px; flex-wrap: wrap; }
.footer-bottom a:hover { color: var(--on-dark); }

/* ---------- Legal pages ---------- */
.legal-hero { background: var(--bg-2); border-bottom: 1px solid var(--border); padding: clamp(56px, 8vw, 96px) 0 clamp(36px, 5vw, 56px); }
.legal-hero h1 { font-size: clamp(34px, 5vw, 56px); }
.legal-hero .meta { font-family: var(--mono); font-size: 13px; color: var(--ink-3); margin-top: 16px; }
.legal-body { padding: clamp(40px, 6vw, 72px) 0 clamp(60px, 8vw, 100px); }
.legal-body .wrap { max-width: 800px; }
.legal-body h2 { font-size: clamp(22px, 3vw, 28px); margin-top: 44px; }
.legal-body h2:first-child { margin-top: 0; }
.legal-body h3 { font-size: 18px; margin-top: 26px; }
.legal-body p, .legal-body li { font-size: 16px; color: var(--ink-2); line-height: 1.62; margin-top: 14px; }
.legal-body ul, .legal-body ol { padding-left: 22px; margin-top: 8px; }
.legal-body li { margin-top: 8px; }
.legal-body strong { color: var(--ink); font-weight: 600; }
.legal-body a { color: var(--brand); text-decoration: underline; text-underline-offset: 2px; }
.legal-callout { background: var(--brand-tint); border: 1px solid var(--brand-line); border-radius: 13px; padding: 20px 22px; margin-top: 22px; }
.legal-callout p { color: var(--ink); margin-top: 0; }
.legal-callout p + p { margin-top: 12px; }
.toc { background: var(--surface); border: 1px solid var(--border); border-radius: 13px; padding: 22px 24px; margin-top: 8px; }
.toc h4 { font-family: var(--mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-3); font-weight: 500; }
.toc ol { columns: 2; column-gap: 36px; margin-top: 12px; padding-left: 18px; }
.toc li { font-size: 14.5px; margin-top: 7px; color: var(--brand); }
@media (max-width: 560px) { .toc ol { columns: 1; } }

/* ---------- Weekly report preview ---------- */
.report {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 20px;
  box-shadow: 0 1px 0 oklch(1 0 0 / .8) inset, 0 30px 60px -34px oklch(0.42 0.1 258 / .35), 0 10px 24px -16px oklch(0.42 0.1 258 / .28);
  padding: 20px;
  display: grid;
  gap: 15px;
}
.report-head { display: flex; align-items: center; justify-content: space-between; }
.report-head .live { display: inline-flex; align-items: center; gap: 9px; font-family: var(--mono); font-size: 12px; letter-spacing: 0.05em; text-transform: uppercase; color: var(--ink-2); }
.report-head .env { width: 24px; height: 24px; border-radius: 7px; background: var(--brand-tint); color: var(--brand); display: grid; place-items: center; font-size: 12px; border: 1px solid var(--brand-line); }
.report-head .clock { font-family: var(--mono); font-size: 11px; color: var(--ink-3); }
.report-subject { font-family: var(--display); font-weight: 700; font-size: 18px; letter-spacing: var(--display-tracking); padding-bottom: 15px; border-bottom: 1px solid var(--border); }
.report-roi { display: flex; align-items: center; gap: 18px; background: var(--bg-ink); border-radius: 14px; padding: 18px 20px; }
.report-roi .roi-n { font-family: var(--display); font-weight: var(--display-weight); font-size: clamp(40px, 6vw, 50px); line-height: .9; letter-spacing: -0.03em; color: var(--accent); }
.report-roi .roi-l { font-size: 13px; color: var(--on-dark-2); line-height: 1.45; }
.report-roi .roi-l b { color: var(--on-dark); font-weight: 600; }
.report-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--border); border: 1px solid var(--border); border-radius: 12px; overflow: hidden; }
.report-grid > div { background: var(--surface); padding: 14px 13px; }
.report-grid b { font-family: var(--display); font-weight: 700; font-size: 23px; letter-spacing: -0.02em; display: block; color: var(--ink); }
.report-grid small { font-size: 11px; color: var(--ink-3); margin-top: 3px; display: block; line-height: 1.3; }

/* ---------- Reveal animation (progressive) ---------- */
@media (prefers-reduced-motion: no-preference) {
  .reveal { opacity: 0; transform: translateY(18px); transition: opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
  .reveal.in { opacity: 1; transform: none; }
}

/* ---------- Tweaks mount ---------- */
#tweaks-root { position: fixed; z-index: 9999; }
