/* =========================================================
   VIRTUALLY NEW YOU — "Second Opinion" shared design system
   The site is a lab report, re-read by hand.
   Used by: index, thyroid, hormones, gut, metabolic, peptides, about.
   Concept (bold) + ui-ux-pro-max discipline: flat brand magenta,
   AA contrast, 150-300ms motion, reduced-motion + touch fallbacks.
   ========================================================= */
:root {
  --paper:      oklch(97.4% 0.014 92);
  --paper-deep: oklch(94.6% 0.021 90);
  --ink:        oklch(23% 0.012 80);
  --slate:      oklch(50% 0.032 252);
  --pen:        #C2046C;        /* brand magenta — flat, AA on paper */
  --pen-bright: #D8037D;        /* logo magenta — pencil cursor only */
  --rule:      color-mix(in oklch, var(--ink) 16%, transparent);
  --rule-soft: color-mix(in oklch, var(--ink) 8%, transparent);
  --pen-soft:  color-mix(in oklch, var(--pen) 12%, transparent);
  --mono: "IBM Plex Mono", ui-monospace, monospace;
  --serif: "Fraunces", Georgia, serif;
  --hand: "Caveat", "Segoe Script", cursive;
  --tap: 48px;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
img { display: block; max-width: 100%; height: auto; }
html { scroll-behavior: smooth; }
html.lenis, html.lenis body { height: auto; }
body {
  font-family: var(--mono);
  background: repeating-linear-gradient(180deg, transparent 0 31px, var(--rule-soft) 31px 32px), var(--paper);
  color: var(--ink); font-size: 15px; line-height: 1.7; overflow-x: hidden; -webkit-font-smoothing: antialiased;
}
.wrap { max-width: 880px; margin: 0 auto; padding: 0 5.5vw; }
.wrap-wide { max-width: 1080px; margin: 0 auto; padding: 0 5.5vw; }
a { color: inherit; }
::selection { background: var(--pen-soft); }
a:focus-visible, button:focus-visible, summary:focus-visible { outline: 2px solid var(--pen); outline-offset: 3px; border-radius: 2px; }

/* voices */
.label { font-size: 11px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--slate); }
.hand { font-family: var(--hand); color: var(--pen); font-weight: 600; line-height: 1.15; }
svg.anno { position: absolute; overflow: visible; pointer-events: none; }
svg.anno path { fill: none; stroke: var(--pen); stroke-width: 3.2; stroke-linecap: round; stroke-linejoin: round; vector-effect: non-scaling-stroke; }

/* CTA */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .5rem; min-height: var(--tap);
  font-family: var(--mono); font-size: 14px; font-weight: 600; letter-spacing: 0.03em; text-decoration: none;
  color: var(--paper); background: var(--pen); padding: 0.95rem 1.6rem; border-radius: 4px;
  box-shadow: 3px 3px 0 color-mix(in oklch, var(--ink) 80%, transparent);
  transition: transform 0.18s ease, box-shadow 0.18s ease, background .18s ease;
}
.btn:hover { transform: translate(-1px, -2px); box-shadow: 5px 6px 0 color-mix(in oklch, var(--ink) 80%, transparent); }
.btn:active { transform: translate(1px, 1px); box-shadow: 1px 1px 0 color-mix(in oklch, var(--ink) 80%, transparent); }
.btn .ar { transition: transform .25s ease; } .btn:hover .ar { transform: translateX(3px); }
.cta-note { font-size: 12px; color: var(--slate); max-width: 32ch; line-height: 1.55; }
.reassure { font-size: 12px; color: var(--slate); } .reassure b { color: var(--ink); font-weight: 600; }

/* header */
.site-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 60; display: flex; align-items: center;
  justify-content: space-between; gap: 0.8rem; padding: 0.6rem 4vw;
  background: color-mix(in oklch, var(--paper) 90%, transparent);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); border-bottom: 1px solid var(--rule);
}
.brand { display: inline-flex; align-items: center; gap: 0.55rem; text-decoration: none; color: var(--ink); min-width: 0; }
.brand img { height: 28px; width: auto; }
.brand b { font-family: var(--serif); font-weight: 500; font-size: 1rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.brand b em { font-style: italic; color: var(--pen); }
.hnav { display: none; align-items: center; gap: 1.5rem; }
.hnav a { text-decoration: none; color: var(--slate); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; font-weight: 500; transition: color .18s; }
.hnav a:hover { color: var(--pen); }
.site-header .btn { min-height: 0; padding: 0.55rem 0.9rem; font-size: 12px; box-shadow: 2px 2px 0 color-mix(in oklch, var(--ink) 80%, transparent); white-space: nowrap; }

/* document chrome */
.doc-meta {
  display: flex; flex-wrap: wrap; gap: 0.3rem 1.4rem; justify-content: space-between;
  padding: 1rem 0 0.8rem; border-bottom: 2px solid var(--ink);
  font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--slate);
}
.doc-meta b { color: var(--ink); font-weight: 600; }

/* section heads */
.sec-head { border-bottom: 2px solid var(--ink); padding-bottom: 0.6rem; margin-bottom: 2.2rem; display: flex; justify-content: space-between; align-items: baseline; gap: 1rem; flex-wrap: wrap; }
.sec-head .label b { color: var(--ink); }
.micro { font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--slate); }

/* generic section + prose */
.section { padding: 3.5rem 0; }
.section .label { display: block; margin-bottom: 1rem; }
.h-serif { font-family: var(--serif); font-weight: 350; line-height: 1.14; letter-spacing: 0; }
.section h2 { font-family: var(--serif); font-weight: 350; font-size: clamp(1.7rem, 5.4vw, 2.7rem); line-height: 1.16; letter-spacing: 0; max-width: 24ch; }
.section h2 em { font-style: italic; }
.section h2 .ul { position: relative; display: inline-block; }
.section h2 .ul .ring { left: -2%; right: -2%; bottom: -0.18em; width: 104%; height: 0.34em; }
.prose { max-width: 64ch; margin-top: 1.3rem; }
.prose p { color: color-mix(in oklch, var(--ink) 82%, var(--slate)); font-size: clamp(14px, 1.6vw, 15.5px); margin-bottom: 1rem; }
.prose p:last-child { margin-bottom: 0; }
.after { margin-top: 1.4rem; max-width: 64ch; color: color-mix(in oklch, var(--ink) 82%, var(--slate)); font-size: 14.5px; }

/* spoke hero */
.s-hero { padding: 6.6rem 0 3.5rem; }
.s-hero .eyebrow { font-family: var(--mono); font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--pen); display: inline-flex; gap: .6rem; align-items: center; margin-bottom: 1.4rem; }
.s-hero .eyebrow::before { content: ""; width: 24px; height: 1px; background: var(--pen); }
.s-hero h1 { font-family: var(--mono); font-weight: 600; font-size: clamp(1.9rem, 7vw, 3.5rem); line-height: 1.08; letter-spacing: -0.01em; text-transform: uppercase; max-width: 18ch; }
.s-hero h1 .q { color: var(--slate); }
.s-hero h1 .circled { position: relative; display: inline-block; padding: 0 0.06em; }
.s-hero h1 .circled .ring { inset: -16% -8% -20% -8%; width: 116%; height: 136%; }
.s-hero h1 .accent { font-family: var(--hand); text-transform: none; color: var(--pen); font-weight: 700; font-size: 1.15em; letter-spacing: 0; }
.s-hero .intro { margin-top: 1.8rem; max-width: 60ch; font-size: clamp(14.5px, 1.8vw, 16.5px); color: color-mix(in oklch, var(--ink) 82%, var(--slate)); line-height: 1.7; }
.s-hero .cta-row { margin-top: 2.4rem; display: flex; align-items: center; gap: 1.1rem; flex-wrap: wrap; }
.hero-scrawl { font-size: clamp(1.9rem, 7vw, 3.3rem); transform: rotate(-2.2deg); margin: 1.3rem 0 0 0.1em; max-width: 18ch; }
.hero-scrawl .w { display: inline-block; white-space: pre; }
.stamp-wrap { position: relative; margin-top: 1.4rem; min-height: 7rem; }
#stamper { position: absolute; left: 14px; top: -5.6rem; z-index: 6; pointer-events: none; opacity: 0; }
.stamp { position: absolute; left: 4px; top: 0.8rem; transform: rotate(-9deg); border: 3px double #C5283D; color: #C5283D; text-align: center; font-size: clamp(14px, 3.4vw, 20px); font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; padding: 0.55em 1em; border-radius: 3px; opacity: 0.94; background: color-mix(in oklch, var(--paper) 55%, transparent); }
.stamp small { display: block; font-size: 0.6em; letter-spacing: 0.24em; opacity: 0.85; font-weight: 600; }

/* lab panel (home) */
.labrows { position: relative; }
.labrow { display: flex; align-items: baseline; gap: 0.6rem; padding: 0.95rem 0; border-bottom: 1px solid var(--rule-soft); font-size: clamp(13px, 3.4vw, 15.5px); }
.labrow .test { font-weight: 500; white-space: nowrap; }
.labrow .dots { flex: 1; border-bottom: 2px dotted var(--rule); transform: translateY(-4px); min-width: 1.2rem; }
.labrow .val { font-weight: 600; white-space: nowrap; }
.labrow .flag { position: relative; font-size: 0.72em; letter-spacing: 0.12em; color: var(--slate); white-space: nowrap; padding: 0 0.3em; }
.labrow.human .test, .labrow.human .val { font-style: italic; }
.labrow.human .flag { color: var(--pen); font-weight: 600; }
.rownote { padding: 0.15rem 0 0.7rem; border-bottom: 1px solid var(--rule-soft); text-align: right; }
.rownote .hand { font-size: clamp(1.35rem, 5.4vw, 1.8rem); display: inline-block; transform: rotate(-1.6deg); }
.pattern-note { margin-top: 2.6rem; text-align: center; position: relative; }
.pattern-note .hand { font-size: clamp(1.9rem, 8vw, 3rem); display: inline-block; transform: rotate(-2deg); }

/* marker list (spoke) — "what a fuller picture looks at" */
.marker-list { list-style: none; max-width: 64ch; margin-top: 1.6rem; }
.marker-list li { position: relative; padding: 0.95rem 0 0.95rem 0; border-bottom: 1px solid var(--rule-soft); display: flex; gap: 0.7rem; align-items: baseline; font-size: clamp(14px, 1.6vw, 15.5px); color: color-mix(in oklch, var(--ink) 82%, var(--slate)); }
.marker-list li::before { content: "+"; color: var(--pen); font-weight: 600; flex: none; }
.marker-list b { color: var(--ink); font-weight: 600; }

/* symptom checklist (spoke) — annotated intake */
.sym-list { list-style: none; max-width: 60ch; margin-top: 1.6rem; }
.sym-list li { position: relative; padding: 0.7rem 0 0.7rem 2rem; border-bottom: 1px solid var(--rule-soft); color: color-mix(in oklch, var(--ink) 82%, var(--slate)); font-size: clamp(14px, 1.6vw, 15.5px); }
.sym-list li::before { content: ""; position: absolute; left: 0; top: 0.95rem; width: 16px; height: 16px; border: 1.5px solid var(--pen); border-radius: 3px; }
.sym-list li::after { content: ""; position: absolute; left: 4px; top: 1.15rem; width: 9px; height: 5px; border-left: 2px solid var(--pen); border-bottom: 2px solid var(--pen); transform: rotate(-45deg); }

/* steps / procedure */
.steps { margin-top: 0.4rem; }
.step { position: relative; display: grid; grid-template-columns: auto 1fr; gap: 1rem 1.2rem; padding: 2.1rem 0; border-bottom: 1px solid var(--rule-soft); }
.step-check { position: relative; width: 2rem; height: 2rem; border: 2px solid var(--ink); border-radius: 3px; margin-top: 0.35rem; background: color-mix(in oklch, var(--paper) 70%, transparent); }
.step-check svg { inset: -25% -30% -10% -10%; width: 140%; height: 135%; }
.step h3 { font-family: var(--serif); font-weight: 500; font-size: clamp(1.35rem, 5.2vw, 1.95rem); line-height: 1.18; margin: 0.2rem 0 0.55rem; }
.step .label { display: block; }
.step p { color: color-mix(in oklch, var(--ink) 78%, var(--slate)); font-size: 14.5px; max-width: 52ch; }
.step .hand { font-size: clamp(1.3rem, 5vw, 1.65rem); display: inline-block; transform: rotate(-1.8deg); margin-top: 0.7rem; }
.step .ilink { display: inline-flex; align-items: center; gap: 0.4rem; margin-top: 0.8rem; font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--pen); text-decoration: none; font-weight: 600; }
.step .ilink .ar { transition: transform .25s ease; } .step .ilink:hover .ar { transform: translateX(4px); }

/* intake (home self-check) */
.intake-sub { margin-bottom: 1.8rem; max-width: 56ch; }
.checks { display: grid; gap: 0; }
.check { display: flex; align-items: center; gap: 0.9rem; width: 100%; text-align: left; min-height: 58px; padding: 0.85rem 0.2rem; cursor: pointer; background: transparent; border: 0; border-bottom: 1px solid var(--rule-soft); font-family: var(--mono); font-size: clamp(13.5px, 3.6vw, 15.5px); color: var(--ink); -webkit-tap-highlight-color: transparent; transition: color 0.2s ease; }
.check:hover { color: var(--pen); }
.cbox { position: relative; width: 26px; height: 26px; flex: none; border: 2px solid var(--ink); border-radius: 3px; background: color-mix(in oklch, var(--paper) 70%, transparent); }
.cbox svg { position: absolute; inset: -22% -26% -12% -14%; width: 142%; height: 138%; overflow: visible; }
.cbox svg path { fill: none; stroke: var(--pen); stroke-width: 3.4; stroke-linecap: round; stroke-linejoin: round; opacity: 0; }
.check[aria-pressed="true"] { color: var(--pen); }
.check[aria-pressed="true"] .cbox { background: var(--pen); border-color: var(--pen); }
.check[aria-pressed="true"] .cbox svg path { opacity: 1; stroke: #fff; }
.ctext { position: relative; }
.ctext .anno { position: absolute; left: 0; right: 0; bottom: -0.16em; width: 100%; height: 0.46em; overflow: visible; }
.ctext .uline { opacity: 0; transition: opacity .15s ease; }
.check[aria-pressed="true"] .ctext .uline { opacity: 1; }
.intake-result { margin-top: 1.8rem; display: flex; flex-direction: column; align-items: flex-start; gap: 1.1rem; }
.intake-result .hand { font-size: clamp(1.5rem, 6vw, 2.1rem); transform: rotate(-1.6deg); min-height: 1.5em; }

/* thesis (home) */
.thesis h2 { font-family: var(--serif); font-weight: 350; font-size: clamp(2rem, 8vw, 4rem); line-height: 1.14; max-width: 22ch; }
.thesis h2 .ul { position: relative; display: inline-block; }
.thesis h2 .ul .ring { left: -2%; right: -2%; bottom: -0.22em; width: 104%; height: 0.34em; }
.thesis h2 em { font-style: italic; }
.thesis .aside { margin-top: 2rem; max-width: 54ch; color: var(--slate); font-size: 14px; }

/* clinician */
.clinician-grid { display: grid; gap: 2.6rem; }
.photo-card { position: relative; justify-self: center; width: min(330px, 82vw); background: var(--paper-deep); border: 1px solid var(--rule); padding: 0.85rem 0.85rem 1rem; transform: rotate(-1.8deg); box-shadow: 0 18px 40px -26px color-mix(in oklch, var(--ink) 55%, transparent); }
.photo-card img { display: block; width: 100%; aspect-ratio: 4 / 4.4; object-fit: cover; object-position: center top; background: color-mix(in oklch, var(--slate) 16%, var(--paper)); }
.photo-card figcaption { padding-top: 0.7rem; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--slate); text-align: center; }
.clip { position: absolute; top: -14px; left: 50%; transform: translateX(-50%) rotate(2deg); width: 92px; height: 26px; background: color-mix(in oklch, var(--slate) 28%, var(--paper)); border: 1px solid var(--rule); }
.clinician-text .label { display: block; margin-bottom: 1rem; }
.clinician-text .pull { font-family: var(--serif); font-weight: 350; font-size: clamp(1.6rem, 6.6vw, 2.5rem); line-height: 1.22; max-width: 24ch; margin-bottom: 1.3rem; }
.clinician-text .pull em { font-style: italic; }
.clinician-text p { font-size: 14.5px; color: color-mix(in oklch, var(--ink) 78%, var(--slate)); max-width: 54ch; margin-bottom: 0.9rem; }
.creds { margin-top: 1.4rem; font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--slate); line-height: 1.9; border-top: 1px solid var(--rule); padding-top: 1rem; }
.creds b { color: var(--ink); font-weight: 600; }
.sig { margin-top: 1.3rem; display: flex; flex-direction: column; gap: 0.15rem; }
.sig .hand { font-size: 2rem; transform: rotate(-2deg); width: fit-content; }
.sig .label b { color: var(--ink); }

/* related / margin note */
.margin-note { margin-top: 1rem; padding: 1.6rem 1.7rem; border: 1px solid var(--rule); border-left: 3px solid var(--pen); background: color-mix(in oklch, var(--paper-deep) 60%, var(--paper)); max-width: 64ch; font-size: 14.5px; color: color-mix(in oklch, var(--ink) 82%, var(--slate)); }
.margin-note a { color: var(--pen); text-decoration: none; font-weight: 600; border-bottom: 1px solid var(--pen-soft); }
.margin-note a:hover { border-bottom-color: var(--pen); }

/* chart index (conditions) */
.ix { display: flex; align-items: baseline; gap: 0.7rem; padding: 1rem 0; border-bottom: 1px solid var(--rule-soft); font-size: clamp(13.5px, 3.6vw, 16px); text-decoration: none; color: inherit; transition: padding-left 0.2s ease, color 0.2s ease; }
.ix:hover { padding-left: 0.55rem; color: var(--pen); }
.ix .nm { font-weight: 500; }
.ix .dots { flex: 1; border-bottom: 2px dotted var(--rule); transform: translateY(-4px); transition: border-color .2s; }
.ix:hover .dots { border-bottom-color: var(--pen-soft); }
.ix .pg { color: var(--slate); font-size: 0.85em; transition: transform .2s ease; }
.ix:hover .pg { transform: translateX(4px); color: var(--pen); }
.ix-note { padding: 0.9rem 0 0; font-size: 11.5px; color: var(--slate); }

/* addenda (FAQ) */
.qa details { border-bottom: 1px solid var(--rule-soft); }
.qa summary { list-style: none; cursor: pointer; padding: 1.2rem 0; display: flex; justify-content: space-between; gap: 1rem; align-items: center; font-weight: 500; font-size: clamp(14px, 3.6vw, 16px); }
.qa summary::-webkit-details-marker { display: none; }
.qa summary::after { content: "+"; font-family: var(--mono); color: var(--pen); font-size: 1.4rem; line-height: 1; transition: transform 0.3s ease; }
.qa details[open] summary::after { transform: rotate(45deg); }
.qa details p { color: color-mix(in oklch, var(--ink) 78%, var(--slate)); font-size: 14px; padding-bottom: 1.3rem; max-width: 64ch; }

/* final CTA */
.next-step { padding: 5.5rem 0 7rem; text-align: center; position: relative; }
.next-step .label { display: block; margin-bottom: 1.4rem; }
.next-step h2 { font-family: var(--serif); font-weight: 350; font-size: clamp(2rem, 7.5vw, 3.6rem); line-height: 1.12; max-width: 18ch; margin: 0 auto 1rem; }
.next-step h2 em { font-style: italic; }
.next-step .hand { font-size: clamp(1.5rem, 6vw, 2.1rem); display: inline-block; transform: rotate(-2deg); margin-bottom: 1.4rem; }
.arrow-holder { position: relative; height: 64px; max-width: 220px; margin: 0 auto; }
.arrow-holder svg { inset: 0; width: 100%; height: 100%; }
.next-step .cta-note { margin: 1.4rem auto 0; }

/* footer */
.site-footer { border-top: 2px solid var(--ink); padding: 2.4rem 0 3.2rem; }
.eor { display: flex; align-items: center; gap: 1rem; color: var(--slate); font-size: 10.5px; letter-spacing: 0.3em; text-transform: uppercase; margin-bottom: 2rem; }
.eor::before, .eor::after { content: ""; flex: 1; border-top: 1px solid var(--rule); }
.foot-cols { display: grid; gap: 1.6rem; font-size: 12px; color: var(--slate); line-height: 1.8; }
.foot-cols b { color: var(--ink); font-weight: 600; }
.foot-brand { display: flex; align-items: center; gap: 0.6rem; margin-bottom: 0.4rem; }
.foot-brand img { height: 24px; width: auto; }
.foot-links { margin-top: 1rem; }
.foot-links a { color: var(--slate); text-decoration: none; display: inline-block; margin-right: 1rem; }
.foot-links a:hover { color: var(--pen); }

.rv { opacity: 1; }

/* pencil cursor */
#pencil { position: fixed; left: 0; top: 0; z-index: 9999; pointer-events: none; opacity: 0; transform-origin: 3px 27.75px; transition: opacity 0.25s ease; will-change: transform; }
.ink-stamp { position: fixed; z-index: 9998; pointer-events: none; width: 30px; height: 30px; margin: -22px 0 0 -4px; overflow: visible; }
.ink-stamp path { fill: none; stroke: var(--pen); stroke-width: 3; stroke-linecap: round; stroke-linejoin: round; }
html.cursor-on * { cursor: none !important; }

/* desktop */
@media (min-width: 760px) {
  body { font-size: 16px; }
  .hnav { display: flex; }
  .s-hero { padding-top: 8rem; }
  .clinician-grid { grid-template-columns: minmax(0, 340px) 1fr; align-items: center; gap: 4rem; }
  .photo-card { transform: rotate(-2.4deg); }
  .rownote { text-align: left; padding-left: 56%; }
  .foot-cols { grid-template-columns: 1.4fr 1fr 1fr; gap: 2rem 4rem; }
}
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } .btn { transition: none; } }

/* ====== warm, conversion-first hero (homepage + spokes) ====== */
.whero { padding: clamp(2.4rem, 5vw, 4.6rem) 0 clamp(2.6rem, 5vw, 4rem); }
.whero-grid { display: grid; gap: clamp(2.2rem, 5vw, 3rem); align-items: center; }
.whero-eyebrow { font-family: var(--mono); font-size: 12px; letter-spacing: .14em; text-transform: uppercase; color: var(--pen); display: inline-flex; align-items: center; gap: .55rem; margin-bottom: 1.4rem; }
.whero-eyebrow .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--pen); flex: none; }
.whero h1 { font-family: var(--serif); font-weight: 400; font-size: clamp(2.1rem, 4.6vw, 3.5rem); line-height: 1.1; letter-spacing: -.015em; color: var(--ink); max-width: 17ch; }
.whero h1 .mark { position: relative; white-space: nowrap; }
.whero h1 .mark svg { position: absolute; left: -2%; right: -2%; bottom: -.1em; width: 104%; height: .34em; overflow: visible; }
.whero h1 em { font-style: italic; color: var(--pen); }
.whero-sub { margin-top: 1.5rem; font-family: var(--mono); font-size: clamp(15px, 1.7vw, 17px); line-height: 1.65; color: color-mix(in oklch, var(--ink) 80%, var(--slate)); max-width: 48ch; }
.whero-sub b { color: var(--ink); font-weight: 600; }
.whero-cta { margin-top: 2rem; display: flex; align-items: center; gap: 1.1rem 1.3rem; flex-wrap: wrap; }
.whero-cta .btn { font-size: 16px; padding: 1.05rem 1.9rem; min-height: 56px; }
.whero-reassure { font-family: var(--mono); font-size: 12px; letter-spacing: .03em; color: var(--slate); }
.whero-reassure b { color: var(--ink); font-weight: 600; }
.whero-photo { position: relative; justify-self: center; width: min(420px, 88vw); }
.whero-photo img { width: 100%; aspect-ratio: 4 / 4.5; object-fit: cover; object-position: center top; border-radius: 14px; border: 1px solid var(--rule); background: var(--paper-deep); box-shadow: 0 30px 64px -36px color-mix(in oklch, var(--ink) 60%, transparent); }
.whero-badge { position: absolute; left: 14px; bottom: 14px; display: inline-flex; align-items: center; gap: .5rem; background: color-mix(in oklch, var(--paper) 90%, transparent); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); border: 1px solid var(--rule); border-radius: 100px; padding: .52rem .95rem; font-family: var(--mono); font-size: 12px; font-weight: 600; color: var(--ink); }
.whero-badge svg { width: 15px; height: 15px; color: var(--pen); flex: none; }
@media (min-width: 860px) { .whero-grid { grid-template-columns: 1.08fr .92fr; gap: 4rem; } }

.trustbar { border-top: 1px solid var(--ink); border-bottom: 1px solid var(--ink); background: var(--paper-deep); }
.trustbar .row { display: flex; flex-wrap: wrap; gap: .85rem 2rem; align-items: center; justify-content: center; max-width: 1080px; margin: 0 auto; padding: 1rem clamp(20px, 5vw, 56px); }
.trustbar .tb { display: inline-flex; align-items: center; gap: .5rem; font-family: var(--mono); font-size: 11.5px; letter-spacing: .05em; text-transform: uppercase; font-weight: 600; color: var(--ink); }
.trustbar .tb svg { width: 15px; height: 15px; color: var(--pen); flex: none; }

.panel-stampwrap { text-align: center; margin-top: 2.2rem; }
.panel-stamp { display: inline-block; transform: rotate(-5deg); border: 3px double #C5283D; color: #C5283D; text-align: center; font-family: var(--mono); font-size: clamp(14px, 2.4vw, 19px); font-weight: 700; letter-spacing: .16em; text-transform: uppercase; padding: .5em 1em; border-radius: 3px; background: color-mix(in oklch, var(--paper) 55%, transparent); }
.panel-stamp small { display: block; font-size: .58em; letter-spacing: .22em; opacity: .85; font-weight: 600; }
