/* gothurt.com — site.css
   Composed from brand/tokens.css. No frameworks. */

@import url("../../brand/tokens.css");
@import url("https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&family=Inter:wght@400;500;600;700&display=swap");

/* ──────────────────────────────────────────────────────────────
   Reset (light-touch, modern)
   ────────────────────────────────────────────────────────────── */
*,
*::before,
*::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; tab-size: 4; line-height: var(--leading-relaxed); }
body {
  background: var(--color-bg);
  color: var(--color-fg);
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  min-height: 100vh;
  min-height: 100dvh;
  overflow-x: hidden;
}
img, picture, svg, video { display: block; max-width: 100%; height: auto; }
input, button, textarea, select { font: inherit; color: inherit; }
button { background: none; border: none; cursor: pointer; padding: 0; }
ul, ol { padding-inline-start: 1.5rem; }
a { color: var(--color-primary); text-decoration: underline; text-underline-offset: 0.15em; text-decoration-thickness: 0.07em; }
a:hover { color: var(--color-primary-dark); }
a:focus-visible { outline: 3px solid var(--color-accent); outline-offset: 3px; border-radius: var(--radius-sm); }

/* Skip link */
.skip-link {
  position: absolute; top: -100px; left: 8px; z-index: var(--z-toast);
  background: var(--color-primary-dark); color: #fff; padding: 0.5rem 1rem;
  border-radius: var(--radius-md); text-decoration: none;
}
.skip-link:focus { top: 8px; outline: 3px solid var(--color-accent); outline-offset: 2px; }

/* ──────────────────────────────────────────────────────────────
   Typography
   ────────────────────────────────────────────────────────────── */
h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 600;
  line-height: var(--leading-snug);
  color: var(--color-primary-dark);
  text-wrap: balance;
}
h1 { font-size: var(--text-3xl); line-height: var(--leading-tight); letter-spacing: -0.02em; }
h2 { font-size: var(--text-2xl); letter-spacing: -0.01em; }
h3 { font-size: var(--text-xl); }
h4 { font-size: var(--text-lg); }
p { max-width: var(--measure); }
.eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-accent-strong);
  margin-bottom: var(--space-3);
}
.subheading {
  font-size: var(--text-md);
  color: var(--color-fg-muted);
  max-width: var(--measure);
  line-height: var(--leading-relaxed);
}

/* ──────────────────────────────────────────────────────────────
   Layout primitives
   ────────────────────────────────────────────────────────────── */
.container {
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: clamp(1rem, 3vw, 2rem);
}
.container-narrow { max-width: var(--container-narrow); }
.container-text   { max-width: var(--container-text); }

.section {
  padding-block: var(--section-y);
}
.section-alt {
  background: var(--color-bg-alt);
}

.stack > * + * { margin-block-start: var(--space-4); }
.stack-lg > * + * { margin-block-start: var(--space-8); }

.grid { display: grid; gap: var(--space-6); }
.grid-2 { grid-template-columns: 1fr; }
.grid-3 { grid-template-columns: 1fr; }
.grid-4 { grid-template-columns: 1fr; }
@media (min-width: 640px) {
  .grid-2 { grid-template-columns: repeat(2, 1fr); }
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 960px) {
  .grid-3 { grid-template-columns: repeat(3, 1fr); }
  .grid-4 { grid-template-columns: repeat(4, 1fr); }
}

.flex { display: flex; gap: var(--space-4); }
.flex-center { display: flex; align-items: center; justify-content: center; gap: var(--space-3); }
.flex-wrap { flex-wrap: wrap; }

.visually-hidden {
  position: absolute !important; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap; border: 0;
}

/* ──────────────────────────────────────────────────────────────
   Buttons
   ────────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 0.85rem 1.4rem;
  border-radius: var(--radius-md);
  font-weight: 600;
  font-size: var(--text-base);
  text-decoration: none;
  cursor: pointer;
  transition: background var(--dur-quick) var(--ease-out-quint),
              color var(--dur-quick) var(--ease-out-quint),
              transform var(--dur-quick) var(--ease-out-quint),
              box-shadow var(--dur-quick) var(--ease-out-quint);
  white-space: nowrap;
}
.btn-primary {
  background: var(--color-accent-strong);
  color: #fff;
  box-shadow: var(--shadow-sm);
}
.btn-primary:hover { background: var(--color-accent-darker); transform: translateY(-1px); box-shadow: var(--shadow-md); color: #fff; }
.btn-primary:focus-visible { outline: 3px solid var(--color-primary); outline-offset: 3px; }

.btn-secondary {
  background: transparent;
  color: var(--color-primary-dark);
  border: 2px solid var(--color-primary-dark);
}
.btn-secondary:hover { background: var(--color-primary-dark); color: #fff; }

.btn-ghost {
  background: transparent;
  color: var(--color-primary-dark);
  text-decoration: underline;
  text-underline-offset: 0.2em;
  padding: 0.5rem 0.25rem;
}
.btn-ghost:hover { color: var(--color-accent); }

.btn-block { width: 100%; }
.btn-large { padding: 1.1rem 1.8rem; font-size: var(--text-md); }

/* ──────────────────────────────────────────────────────────────
   Header & nav
   ────────────────────────────────────────────────────────────── */
.site-header {
  position: sticky;
  top: 0;
  z-index: var(--z-sticky);
  background: rgba(251, 247, 242, 0.92);
  backdrop-filter: saturate(140%) blur(10px);
  -webkit-backdrop-filter: saturate(140%) blur(10px);
  border-block-end: var(--border-thin);
}
.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding-block: var(--space-3);
}
.site-logo {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  text-decoration: none;
  color: var(--color-primary-dark);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-lg);
  letter-spacing: -0.01em;
}
.site-logo svg { width: 1.75rem; height: 1.75rem; color: var(--color-primary); }
.site-logo:hover { color: var(--color-primary); }

.site-nav {
  display: none;
  gap: var(--space-6);
}
@media (min-width: 800px) {
  .site-nav { display: flex; align-items: center; }
}
.site-nav a {
  color: var(--color-fg);
  text-decoration: none;
  font-weight: 500;
  font-size: var(--text-sm);
  padding-block: var(--space-2);
  border-block-end: 2px solid transparent;
  transition: color var(--dur-quick) var(--ease-out-quint),
              border-color var(--dur-quick) var(--ease-out-quint);
}
.site-nav a:hover { color: var(--color-primary); border-block-end-color: var(--color-accent); }

.header-cta {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
}
.header-phone {
  display: none;
  font-family: var(--font-mono);
  font-weight: 600;
  color: var(--color-primary-dark);
  text-decoration: none;
  font-size: var(--text-sm);
}
@media (min-width: 540px) {
  .header-phone { display: inline-flex; }
}
.header-phone:hover { color: var(--color-accent); }

/* Mobile nav toggle */
.nav-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: var(--radius-md);
  color: var(--color-primary-dark);
}
@media (min-width: 800px) { .nav-toggle { display: none; } }
.mobile-nav {
  display: none;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-4) 0 var(--space-6);
  border-block-start: var(--border-thin);
}
.mobile-nav.open { display: flex; }
.mobile-nav a {
  padding: var(--space-3) var(--space-2);
  color: var(--color-fg);
  text-decoration: none;
  font-weight: 500;
  border-radius: var(--radius-md);
}
.mobile-nav a:hover { background: var(--color-accent-soft); color: var(--color-primary-dark); }

/* ──────────────────────────────────────────────────────────────
   Hero — intake form
   ────────────────────────────────────────────────────────────── */
.hero {
  padding-block: clamp(var(--space-12), 8vw, var(--space-32)) clamp(var(--space-12), 6vw, var(--space-24));
  position: relative;
  overflow: clip;
}
.hero__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-10);
  align-items: center;
}
@media (min-width: 960px) {
  .hero__grid { grid-template-columns: 1.1fr 1fr; gap: var(--space-16); }
}
.hero__copy h1 { margin-block-end: var(--space-5); }
.hero__copy .subheading { margin-block-end: var(--space-6); }

.intake-form {
  background: #fff;
  border-radius: var(--radius-xl);
  padding: clamp(var(--space-5), 3vw, var(--space-8));
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--color-border);
}
.intake-form__heading {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-lg);
  color: var(--color-primary-dark);
  margin-block-end: var(--space-4);
}
.field { display: flex; flex-direction: column; gap: var(--space-2); margin-block-end: var(--space-4); }
.field label { font-weight: 600; font-size: var(--text-sm); color: var(--color-fg); }
.field input,
.field select,
.field textarea {
  width: 100%;
  padding: 0.85rem 1rem;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
  font-size: var(--text-base);
  color: var(--color-fg);
  transition: border-color var(--dur-quick) var(--ease-out-quint),
              box-shadow var(--dur-quick) var(--ease-out-quint);
}
.field textarea { min-height: 8rem; resize: vertical; line-height: var(--leading-relaxed); }
.field input:focus,
.field select:focus,
.field textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: var(--shadow-ring);
}
.field-row { display: grid; gap: var(--space-4); grid-template-columns: 1fr; }
@media (min-width: 560px) { .field-row { grid-template-columns: 1fr 1fr; } }

.privacy-note {
  margin-block-start: var(--space-4);
  font-size: var(--text-xs);
  color: var(--color-fg-muted);
  display: flex;
  gap: var(--space-2);
  align-items: flex-start;
}
.privacy-note::before {
  content: "🔒";
  font-size: var(--text-base);
  line-height: 1;
  filter: grayscale(1) opacity(0.7);
}

.hero__image {
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  aspect-ratio: 4 / 5;
  background: var(--color-bg-alt);
}
@media (min-width: 960px) { .hero__image { aspect-ratio: 5 / 6; } }
.hero__image img { width: 100%; height: 100%; object-fit: cover; }

/* ──────────────────────────────────────────────────────────────
   Trust strip
   ────────────────────────────────────────────────────────────── */
.trust-strip {
  background: var(--color-primary-dark);
  color: #fff;
  padding-block: var(--space-8);
}
.trust-strip__items {
  display: grid;
  gap: var(--space-6);
  grid-template-columns: 1fr;
  text-align: center;
}
@media (min-width: 700px) { .trust-strip__items { grid-template-columns: repeat(3, 1fr); } }
.trust-strip__stat {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 600;
  color: #fff;
  display: block;
}
.trust-strip__label {
  font-size: var(--text-sm);
  color: rgba(255, 255, 255, 0.8);
  margin-block-start: var(--space-2);
  max-width: 30ch;
  margin-inline: auto;
}
.trust-strip__note {
  margin-block-start: var(--space-6);
  text-align: center;
  font-size: var(--text-xs);
  color: rgba(255, 255, 255, 0.65);
}

/* ──────────────────────────────────────────────────────────────
   How it works
   ────────────────────────────────────────────────────────────── */
.how-steps { display: grid; gap: var(--space-8); grid-template-columns: 1fr; }
@media (min-width: 800px) { .how-steps { grid-template-columns: repeat(3, 1fr); gap: var(--space-6); } }
.step-card {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  position: relative;
  overflow: hidden;
}
.step-card__n {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  background: var(--color-accent);
  color: #fff;
  border-radius: var(--radius-pill);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-lg);
  margin-block-end: var(--space-3);
}
.step-card h3 { font-size: var(--text-lg); margin-block-end: var(--space-2); }
.step-card p { color: var(--color-fg-muted); }

/* ──────────────────────────────────────────────────────────────
   Case-types grid (homepage)
   ────────────────────────────────────────────────────────────── */
.cases-grid {
  display: grid;
  gap: var(--space-5);
  grid-template-columns: 1fr;
  margin-block-start: var(--space-8);
}
@media (min-width: 600px) { .cases-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 960px) { .cases-grid { grid-template-columns: repeat(4, 1fr); } }
.case-card {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  text-decoration: none;
  color: var(--color-fg);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: transform var(--dur-quick) var(--ease-out-quint),
              box-shadow var(--dur-quick) var(--ease-out-quint),
              border-color var(--dur-quick) var(--ease-out-quint);
}
.case-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
  border-color: var(--color-accent);
  color: var(--color-fg);
}
.case-card h3 { font-size: var(--text-md); margin: 0; }
.case-card__hook { font-size: var(--text-sm); color: var(--color-fg-muted); }

/* ──────────────────────────────────────────────────────────────
   Value props
   ────────────────────────────────────────────────────────────── */
.value-props { display: grid; gap: var(--space-8); grid-template-columns: 1fr; }
@media (min-width: 800px) { .value-props { grid-template-columns: repeat(3, 1fr); gap: var(--space-6); } }
.value-prop {
  text-align: center;
  padding: var(--space-6);
}
.value-prop h3 { font-size: var(--text-lg); margin-block-end: var(--space-2); }
.value-prop p { color: var(--color-fg-muted); margin-inline: auto; }

/* ──────────────────────────────────────────────────────────────
   Reassurance block
   ────────────────────────────────────────────────────────────── */
.reassurance {
  text-align: center;
  padding-block: clamp(var(--space-10), 6vw, var(--space-16));
}
.reassurance p {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 400;
  font-style: italic;
  color: var(--color-primary-dark);
  max-width: 50ch;
  margin-inline: auto;
  line-height: var(--leading-relaxed);
}

/* ──────────────────────────────────────────────────────────────
   FAQ
   ────────────────────────────────────────────────────────────── */
.faq { max-width: var(--container-narrow); margin-inline: auto; }
.faq dl { margin: 0; }
.faq details {
  border-block-end: 1px solid var(--color-border);
  padding-block: var(--space-4);
}
.faq details[open] { background: transparent; }
.faq summary {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-md);
  cursor: pointer;
  color: var(--color-primary-dark);
  list-style: none;
  display: flex;
  justify-content: space-between;
  gap: var(--space-3);
  align-items: flex-start;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after {
  content: "+";
  font-family: var(--font-mono);
  font-size: 1.5rem;
  line-height: 1;
  color: var(--color-accent);
  transition: transform var(--dur-quick) var(--ease-out-quint);
  flex-shrink: 0;
}
.faq details[open] summary::after { transform: rotate(45deg); }
.faq details > p { margin-block-start: var(--space-3); color: var(--color-fg-muted); }

/* ──────────────────────────────────────────────────────────────
   CTA banner
   ────────────────────────────────────────────────────────────── */
.cta-banner {
  background: var(--color-primary);
  color: #fff;
  border-radius: var(--radius-xl);
  padding: clamp(var(--space-8), 5vw, var(--space-16));
  text-align: center;
}
.cta-banner h2 { color: #fff; margin-block-end: var(--space-3); }
.cta-banner p {
  color: rgba(255, 255, 255, 0.85);
  margin-inline: auto;
  margin-block-end: var(--space-6);
  max-width: 50ch;
}
.cta-banner .btn-primary { background: var(--color-accent-strong); }
.cta-banner .btn-primary:hover { background: var(--color-accent-darker); }
.cta-banner .btn-secondary { color: #fff; border-color: rgba(255, 255, 255, 0.6); }
.cta-banner .btn-secondary:hover { background: #fff; color: var(--color-primary-dark); }
.cta-banner__actions { display: inline-flex; flex-wrap: wrap; gap: var(--space-4); justify-content: center; }

/* ──────────────────────────────────────────────────────────────
   Page hero (non-homepage)
   ────────────────────────────────────────────────────────────── */
.page-hero {
  padding-block: clamp(var(--space-10), 7vw, var(--space-20));
}
.page-hero__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  align-items: center;
}
@media (min-width: 800px) {
  .page-hero__grid { grid-template-columns: 1.4fr 1fr; }
}
.page-hero h1 { margin-block-end: var(--space-4); }
.page-hero__image {
  border-radius: var(--radius-xl);
  overflow: hidden;
  aspect-ratio: 4 / 3;
  background: var(--color-bg-alt);
}
.page-hero__image img { width: 100%; height: 100%; object-fit: cover; }

/* Step detail (how-it-works sub-pages) */
.step-detail {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  align-items: start;
}
@media (min-width: 800px) {
  .step-detail { grid-template-columns: auto 1fr 1fr; gap: var(--space-8); }
}
.step-detail__n {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(3rem, 8vw, 5rem);
  color: var(--color-accent);
  line-height: 1;
}
.step-detail__copy h2 { margin-block-end: var(--space-3); }
.step-detail__copy ul { padding-inline-start: 1.2rem; color: var(--color-fg-muted); }
.step-detail__image { border-radius: var(--radius-lg); overflow: hidden; aspect-ratio: 4 / 3; }
.step-detail__image img { width: 100%; height: 100%; object-fit: cover; }

/* ──────────────────────────────────────────────────────────────
   Case-types detailed list (case-types overview page)
   ────────────────────────────────────────────────────────────── */
.cases-detailed { display: grid; gap: var(--space-8); }
.case-row {
  display: grid;
  gap: var(--space-6);
  grid-template-columns: 1fr;
  padding-block: var(--space-6);
  border-block-end: 1px solid var(--color-border);
}
@media (min-width: 800px) { .case-row { grid-template-columns: 1fr 2fr auto; align-items: center; } }
.case-row__image { border-radius: var(--radius-lg); overflow: hidden; aspect-ratio: 4 / 3; background: var(--color-bg-alt); }
.case-row__image img { width: 100%; height: 100%; object-fit: cover; }
.case-row__copy h3 { font-size: var(--text-lg); margin-block-end: var(--space-2); }
.case-row__copy p { color: var(--color-fg-muted); }

/* Case-type page hero */
.case-hero { padding-block: clamp(var(--space-10), 7vw, var(--space-20)); }
.case-hero__grid { display: grid; grid-template-columns: 1fr; gap: var(--space-8); align-items: center; }
@media (min-width: 960px) { .case-hero__grid { grid-template-columns: 1.1fr 1fr; gap: var(--space-12); } }
.case-hero__image { border-radius: var(--radius-xl); overflow: hidden; aspect-ratio: 4 / 5; background: var(--color-bg-alt); }
.case-hero__image img { width: 100%; height: 100%; object-fit: cover; }

/* ──────────────────────────────────────────────────────────────
   Specifics / list blocks
   ────────────────────────────────────────────────────────────── */
.specifics { background: var(--color-bg-alt); border-radius: var(--radius-xl); padding: clamp(var(--space-6), 4vw, var(--space-10)); }
.specifics h2 { margin-block-end: var(--space-5); }
.specifics ul { padding: 0; list-style: none; display: grid; gap: var(--space-4); }
.specifics li { padding-inline-start: 2rem; position: relative; line-height: var(--leading-relaxed); }
.specifics li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.45em;
  width: 1.1rem;
  height: 1.1rem;
  background: var(--color-accent);
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='currentColor' d='M13.5 4.5L6 12L2.5 8.5L4 7L6 9L12 3L13.5 4.5Z'/></svg>") center / contain no-repeat;
  mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='currentColor' d='M13.5 4.5L6 12L2.5 8.5L4 7L6 9L12 3L13.5 4.5Z'/></svg>") center / contain no-repeat;
}
.specifics__note {
  margin-block-start: var(--space-5);
  font-style: italic;
  color: var(--color-fg-muted);
  font-size: var(--text-sm);
}

.list-block h2 { margin-block-end: var(--space-4); }
.list-block ul { padding-inline-start: 1.5rem; }
.list-block li { margin-block-end: var(--space-2); }
.list-block__note {
  margin-block-start: var(--space-5);
  padding: var(--space-4);
  background: var(--color-accent-soft);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
}

/* ──────────────────────────────────────────────────────────────
   Statute callout
   ────────────────────────────────────────────────────────────── */
.statute-callout {
  background: #fff;
  border: 1.5px solid var(--color-warning);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  position: relative;
}
.statute-callout::before {
  content: "⏱";
  position: absolute;
  top: var(--space-5);
  right: var(--space-5);
  font-size: 1.75rem;
  opacity: 0.7;
}
.statute-callout h2 { font-size: var(--text-lg); color: var(--color-warning); margin-block-end: var(--space-2); }

/* ──────────────────────────────────────────────────────────────
   Process metrics (results page)
   ────────────────────────────────────────────────────────────── */
.process-metrics {
  display: grid;
  gap: var(--space-6);
  grid-template-columns: 1fr;
}
@media (min-width: 700px) { .process-metrics { grid-template-columns: repeat(2, 1fr); } }
.metric-card {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
}
.metric-card__stat {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 600;
  color: var(--color-accent);
  line-height: 1.1;
}
.metric-card__label { margin-block-start: var(--space-3); color: var(--color-fg-muted); }

/* ──────────────────────────────────────────────────────────────
   Principles / What we are not / How we vet
   ────────────────────────────────────────────────────────────── */
.principles { display: grid; gap: var(--space-5); }
@media (min-width: 700px) { .principles { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1080px) { .principles { grid-template-columns: repeat(3, 1fr); } }
.principle-card {
  background: #fff;
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  border: 1px solid var(--color-border);
}
.principle-card h3 { font-size: var(--text-md); margin-block-end: var(--space-2); }
.principle-card p { color: var(--color-fg-muted); }

/* ──────────────────────────────────────────────────────────────
   Contact channels
   ────────────────────────────────────────────────────────────── */
.contact-channels { display: grid; gap: var(--space-5); grid-template-columns: 1fr; }
@media (min-width: 700px) { .contact-channels { grid-template-columns: repeat(3, 1fr); } }
.contact-channel {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.contact-channel__label { font-weight: 600; color: var(--color-primary-dark); }
.contact-channel__value {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--color-fg);
  text-decoration: none;
}
.contact-channel__value:hover { color: var(--color-accent); }
.contact-channel__note { color: var(--color-fg-muted); font-size: var(--text-sm); }

/* ──────────────────────────────────────────────────────────────
   Legal pages (privacy, terms, disclaimer)
   ────────────────────────────────────────────────────────────── */
.legal-hero { padding-block: clamp(var(--space-10), 6vw, var(--space-16)); border-block-end: var(--border-thin); }
.legal-hero__last-updated { color: var(--color-fg-muted); font-size: var(--text-sm); margin-block-start: var(--space-3); }
.legal-text { max-width: var(--container-text); margin-inline: auto; }
.legal-text h2 { font-size: var(--text-lg); margin-block: var(--space-8) var(--space-3); }
.legal-text p + p { margin-block-start: var(--space-3); }

/* ──────────────────────────────────────────────────────────────
   State pages (404, offline)
   ────────────────────────────────────────────────────────────── */
.state-hero { padding-block: var(--space-20); text-align: center; }
.state-hero__icon { width: 6rem; height: 6rem; margin-inline: auto; margin-block-end: var(--space-6); opacity: 0.7; }
.popular-pages { margin-block-start: var(--space-8); }
.popular-pages h2 { font-size: var(--text-lg); margin-block-end: var(--space-4); }
.popular-pages ul { list-style: none; padding: 0; }
.popular-pages li { margin-block-end: var(--space-3); }
.popular-pages a {
  display: inline-block;
  padding: var(--space-3) var(--space-5);
  background: var(--color-accent-soft);
  color: var(--color-primary-dark);
  border-radius: var(--radius-md);
  text-decoration: none;
  font-weight: 500;
}
.popular-pages a:hover { background: var(--color-accent); color: #fff; }

/* ──────────────────────────────────────────────────────────────
   Footer
   ────────────────────────────────────────────────────────────── */
.site-footer {
  background: var(--color-primary-dark);
  color: rgba(255, 255, 255, 0.85);
  padding-block: var(--space-12) var(--space-6);
  margin-block-start: var(--space-20);
}
.site-footer a { color: rgba(255, 255, 255, 0.85); text-decoration: none; }
.site-footer a:hover { color: var(--color-accent); }
.site-footer__grid {
  display: grid;
  gap: var(--space-8);
  grid-template-columns: 1fr;
  margin-block-end: var(--space-8);
}
@media (min-width: 700px) { .site-footer__grid { grid-template-columns: 1.5fr repeat(3, 1fr); } }
.site-footer__heading,
.site-footer h4 {
  color: #fff;
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-block-end: var(--space-3);
  font-family: var(--font-body);
  font-weight: 700;
}
.site-footer ul { list-style: none; padding: 0; }
.site-footer li { margin-block-end: var(--space-2); font-size: var(--text-sm); }
.footer-tagline { font-family: var(--font-display); color: #fff; font-size: var(--text-md); max-width: 30ch; }
.footer-bottom {
  padding-block-start: var(--space-6);
  border-block-start: 1px solid rgba(255, 255, 255, 0.15);
  font-size: var(--text-xs);
  color: rgba(255, 255, 255, 0.65);
  text-align: center;
}
.footer-bottom p + p { margin-block-start: var(--space-2); }

/* ──────────────────────────────────────────────────────────────
   Section heading helper
   ────────────────────────────────────────────────────────────── */
.section-heading { margin-block-end: var(--space-8); }
.section-heading h2 { max-width: 24ch; }
.section-heading .subheading { margin-block-start: var(--space-3); }

/* ──────────────────────────────────────────────────────────────
   Evaluation page — board-deck feel
   ────────────────────────────────────────────────────────────── */
.valuation-headline { padding-block: clamp(var(--space-12), 8vw, var(--space-24)); }
.valuation-headline__big {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 6vw, 5rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.05;
  color: var(--color-primary-dark);
  margin-block: var(--space-3) var(--space-4);
}
.valuation-headline__sub {
  font-size: var(--text-lg);
  color: var(--color-fg-muted);
  margin-block-end: var(--space-3);
}
.valuation-headline__meta {
  font-size: var(--text-xs);
  color: var(--color-fg-muted);
  font-family: var(--font-mono);
}

.valuation-range-cards {
  display: grid;
  gap: var(--space-6);
  grid-template-columns: 1fr;
}
@media (min-width: 800px) {
  .valuation-range-cards { grid-template-columns: repeat(3, 1fr); }
}
.valuation-card {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  border-top: 4px solid var(--color-accent);
}
.valuation-card:nth-child(1) { border-top-color: var(--color-info); }
.valuation-card:nth-child(2) { border-top-color: var(--color-accent); }
.valuation-card:nth-child(3) { border-top-color: var(--color-primary); }
.valuation-card__tier {
  font-size: var(--text-sm);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-fg-muted);
}
.valuation-card__amount {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 700;
  color: var(--color-primary-dark);
  letter-spacing: -0.01em;
}
.valuation-card__rationale {
  color: var(--color-fg-muted);
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
}

.drivers-grid {
  display: grid;
  gap: var(--space-5);
  grid-template-columns: 1fr;
}
@media (min-width: 700px) { .drivers-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1080px) { .drivers-grid { grid-template-columns: repeat(3, 1fr); } }
.driver-card {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
}
.driver-card h3 { font-size: var(--text-md); margin-block-end: var(--space-2); }
.driver-card p { color: var(--color-fg-muted); font-size: var(--text-sm); }

.risks-callout {
  background: #fff;
  border: 1.5px solid var(--color-warning);
  border-radius: var(--radius-lg);
  padding: var(--space-6) var(--space-8);
}
.risks-callout h2 { font-size: var(--text-lg); color: var(--color-warning); margin-block-end: var(--space-3); }
.risks-callout ol { padding-inline-start: 1.5rem; }
.risks-callout li { margin-block: var(--space-3); padding-inline-start: var(--space-2); }

.comparables-note {
  font-size: var(--text-sm);
  color: var(--color-fg-muted);
  font-style: italic;
  margin-block-end: var(--space-5);
  max-width: var(--measure);
}
.comparables-table {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow-x: auto;
}
.comparables-table table { width: 100%; border-collapse: collapse; font-size: var(--text-sm); }
.comparables-table th,
.comparables-table td { padding: var(--space-3) var(--space-4); text-align: left; vertical-align: top; }
.comparables-table thead { background: var(--color-bg-alt); }
.comparables-table th { font-weight: 600; color: var(--color-primary-dark); border-block-end: 2px solid var(--color-border); }
.comparables-table tbody tr + tr td { border-block-start: 1px solid var(--color-border); }
.comparables-table td:nth-child(4) { color: var(--color-fg-muted); font-size: var(--text-xs); }

.monetization-paths {
  display: grid;
  gap: var(--space-5);
  grid-template-columns: 1fr;
}
@media (min-width: 800px) { .monetization-paths { grid-template-columns: repeat(2, 1fr); } }
.monetization-path {
  background: var(--color-accent-soft);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
}
.monetization-path h3 { font-size: var(--text-md); margin-block-end: var(--space-2); color: var(--color-primary-dark); }

.executive-summary h2 { margin-block-end: var(--space-4); }
.executive-summary p {
  margin-block: var(--space-4);
  line-height: var(--leading-relaxed);
  max-width: var(--measure);
}
.executive-summary p:first-of-type { font-size: var(--text-md); }

/* ──────────────────────────────────────────────────────────────
   Print
   ────────────────────────────────────────────────────────────── */
@media print {
  .site-header, .site-footer, .cta-banner, .hero__image, .page-hero__image, .case-hero__image { display: none !important; }
  body { color: #000; background: #fff; }
  a { color: #000; text-decoration: underline; }
}
