/* =========================================================
   2x3x10x — Component & layout styles
   ========================================================= */

/* ---------- Layout primitives ---------- */
.container {
  width: 100%;
  max-width: var(--content-wide);
  margin-inline: auto;
  padding-inline: clamp(1.25rem, 4vw, 2.5rem);
}

.container-narrow { max-width: var(--content-narrow); }
.container-default { max-width: var(--content-default); }

section {
  padding-block: clamp(var(--space-16), 9vw, var(--space-32));
}

/* ---------- Eyebrow / labels ---------- */
.eyebrow {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-primary);
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
}

.eyebrow::before {
  content: '';
  width: 1.5rem;
  height: 1px;
  background: var(--color-primary);
  display: inline-block;
}

.eyebrow.no-rule::before { display: none; }

/* ---------- Typography helpers ---------- */
.display {
  font-family: var(--font-display);
  font-weight: 500;
  line-height: 1.02;
  letter-spacing: -0.02em;
}

.display em {
  font-style: italic;
  color: var(--color-primary);
  font-weight: 400;
}

.lede {
  font-size: var(--text-lg);
  line-height: 1.55;
  color: var(--color-text-muted);
  max-width: 60ch;
}

.muted { color: var(--color-text-muted); }
.faint { color: var(--color-text-faint); }
.center { text-align: center; }

/* ---------- Header ---------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: color-mix(in oklab, var(--color-bg) 92%, transparent);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid transparent;
  transition: border-color var(--transition-interactive), background var(--transition-interactive);
}

.site-header.scrolled {
  border-bottom-color: var(--color-divider);
}

.header-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
  padding-block: var(--space-4);
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: 1.125rem;
  letter-spacing: 0.02em;
}

.brand svg { width: 32px; height: 32px; color: var(--color-text); }

.brand-text { font-weight: 500; }
.brand-text em { font-style: italic; color: var(--color-primary); font-weight: 400; }

.nav-primary {
  display: flex;
  align-items: center;
  gap: clamp(1rem, 2vw, 2rem);
}

.nav-primary a {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  letter-spacing: 0.01em;
  position: relative;
}

.nav-primary a:hover,
.nav-primary a.active {
  color: var(--color-text);
}

.nav-primary a.active::after {
  content: '';
  position: absolute;
  left: 0; right: 0;
  bottom: -6px;
  height: 1px;
  background: var(--color-primary);
}

.theme-toggle {
  width: 36px; height: 36px;
  border-radius: var(--radius-full);
  color: var(--color-text-muted);
  display: inline-grid;
  place-items: center;
  border: 1px solid var(--color-border);
}
.theme-toggle:hover { color: var(--color-text); border-color: var(--color-text-muted); }

.nav-toggle {
  display: none;
  width: 40px; height: 40px;
  border-radius: var(--radius-full);
  border: 1px solid var(--color-border);
  color: var(--color-text);
}

@media (max-width: 880px) {
  .nav-primary { display: none; }
  .nav-toggle { display: inline-grid; place-items: center; }
  .nav-primary.open {
    display: flex;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    flex-direction: column;
    background: var(--color-bg);
    border-bottom: 1px solid var(--color-divider);
    padding: var(--space-6);
    gap: var(--space-4);
    align-items: flex-start;
  }
  .nav-primary.open a { font-size: var(--text-base); }
}

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  padding: 0.875rem 1.5rem;
  font-size: var(--text-sm);
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  white-space: nowrap;
}

.btn-primary {
  background: var(--color-text);
  color: var(--color-text-inverse);
}
.btn-primary:hover {
  background: var(--color-primary);
  color: var(--color-text-inverse);
}

[data-theme='dark'] .btn-primary {
  background: var(--color-primary);
  color: var(--color-text-inverse);
}
[data-theme='dark'] .btn-primary:hover {
  background: var(--color-primary-hover);
}

.btn-ghost {
  background: transparent;
  border-color: var(--color-border);
  color: var(--color-text);
}
.btn-ghost:hover {
  border-color: var(--color-text);
}

.btn-link {
  padding: 0;
  border: none;
  color: var(--color-primary);
  font-size: var(--text-sm);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
}
.btn-link::after {
  content: '→';
  transition: transform var(--transition-interactive);
}
.btn-link:hover::after { transform: translateX(4px); }

.cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin-top: var(--space-8);
}

/* ---------- Hero ---------- */
.hero {
  position: relative;
  padding-block: clamp(var(--space-20), 12vw, var(--space-32));
  border-bottom: 1px solid var(--color-divider);
  overflow: hidden;
}

.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: clamp(2rem, 6vw, 5rem);
  align-items: center;
}

@media (min-width: 960px) {
  .hero-grid {
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  }
}

.hero h1 {
  font-size: var(--text-hero);
  line-height: 0.98;
  letter-spacing: -0.025em;
  margin-top: var(--space-6);
}

.hero h1 em {
  font-style: italic;
  color: var(--color-primary);
  font-weight: 400;
}

.hero-lede {
  margin-top: var(--space-8);
  font-size: var(--text-lg);
  color: var(--color-text-muted);
  max-width: 56ch;
  line-height: 1.55;
}

.hero-meta {
  display: flex;
  gap: var(--space-8);
  margin-top: var(--space-12);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-divider);
  flex-wrap: wrap;
}

.hero-meta dt {
  font-size: var(--text-xs);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-text-faint);
  margin-bottom: var(--space-2);
}
.hero-meta dd {
  font-family: var(--font-display);
  font-size: var(--text-lg);
}

.hero-figure {
  position: relative;
  aspect-ratio: 1 / 1.06;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--color-surface-2);
  box-shadow: var(--shadow-lg);
}

.hero-figure svg { width: 100%; height: 100%; }

.hero-figure-caption {
  position: absolute;
  bottom: var(--space-4);
  left: var(--space-4);
  right: var(--space-4);
  font-size: var(--text-xs);
  color: var(--color-text-inverse);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  opacity: 0.85;
}

/* ---------- Methodology cards ---------- */
.methodology-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 260px), 1fr));
  gap: clamp(1rem, 2vw, 1.5rem);
  margin-top: var(--space-12);
}

.method-card {
  position: relative;
  padding: var(--space-8);
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-md);
  min-height: 280px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: transform var(--transition-interactive), border-color var(--transition-interactive);
}

.method-card:hover {
  border-color: var(--color-primary);
  transform: translateY(-2px);
}

.method-card .method-num {
  font-family: var(--font-display);
  font-size: 2.25rem;
  color: var(--color-primary);
  font-style: italic;
}

.method-card h3 {
  font-size: var(--text-lg);
  margin-top: var(--space-6);
}

.method-card p {
  margin-top: var(--space-3);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

/* ---------- Pull quote ---------- */
.pullquote {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 1.2rem + 1.8vw, 2.5rem);
  font-style: italic;
  line-height: 1.25;
  color: var(--color-text);
  max-width: 28ch;
  letter-spacing: -0.01em;
}

.pullquote-attr {
  margin-top: var(--space-6);
  font-size: var(--text-xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}

/* ---------- Two column editorial ---------- */
.two-col {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: clamp(2rem, 6vw, 5rem);
  align-items: start;
}
@media (min-width: 880px) {
  .two-col { grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr); }
  .two-col.flip { grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr); }
}

.two-col h2 {
  font-size: var(--text-2xl);
  line-height: 1.05;
}

.two-col .lede {
  margin-top: var(--space-6);
}

.col-rule {
  border-top: 1px solid var(--color-divider);
  padding-top: var(--space-8);
}

/* ---------- Editorial figure ---------- */
.editorial-figure {
  aspect-ratio: 4 / 5;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--color-surface-2);
  position: relative;
  box-shadow: var(--shadow-md);
}
.editorial-figure svg { width: 100%; height: 100%; }

/* ---------- Stats strip ---------- */
.stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr));
  gap: var(--space-8);
  padding-block: var(--space-12);
  border-block: 1px solid var(--color-divider);
}

.stat .stat-num {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 1.6rem + 3vw, 4rem);
  color: var(--color-primary);
  line-height: 1;
}
.stat .stat-label {
  margin-top: var(--space-3);
  font-size: var(--text-xs);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}

/* ---------- CTA block ---------- */
.cta-block {
  position: relative;
  background: var(--color-text);
  color: var(--color-text-inverse);
  border-radius: var(--radius-md);
  padding: clamp(2rem, 5vw, 4rem);
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--space-8);
  align-items: end;
  overflow: hidden;
}
@media (min-width: 880px) {
  .cta-block { grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr); }
}

[data-theme='dark'] .cta-block {
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
}

.cta-block h2 {
  color: var(--color-text-inverse);
  font-size: var(--text-2xl);
  line-height: 1.05;
}
[data-theme='dark'] .cta-block h2 { color: var(--color-text); }

.cta-block p {
  color: color-mix(in oklab, var(--color-text-inverse) 75%, transparent);
  font-size: var(--text-base);
  margin-top: var(--space-6);
  max-width: 50ch;
}
[data-theme='dark'] .cta-block p { color: var(--color-text-muted); }

.cta-block .btn-primary {
  background: var(--color-primary);
  color: var(--color-text-inverse);
}
.cta-block .btn-primary:hover {
  background: var(--color-primary-hover);
}

/* ---------- Footer ---------- */
.site-footer {
  border-top: 1px solid var(--color-divider);
  padding-block: var(--space-16) var(--space-8);
  background: var(--color-surface);
}

.footer-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) repeat(2, minmax(0, 1fr));
  gap: var(--space-12);
}
@media (max-width: 720px) {
  .footer-grid { grid-template-columns: 1fr; }
}

.footer-brand-block p {
  margin-top: var(--space-4);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}

.footer-col h4 {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-text-faint);
  font-weight: 500;
  margin-bottom: var(--space-4);
}

.footer-col ul { list-style: none; display: grid; gap: var(--space-3); }
.footer-col a {
  color: var(--color-text);
  font-size: var(--text-sm);
}
.footer-col a:hover { color: var(--color-primary); }

.footer-meta {
  margin-top: var(--space-12);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-divider);
  display: flex;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
  font-size: var(--text-xs);
  color: var(--color-text-faint);
  letter-spacing: 0.06em;
}

/* ---------- Page hero (interior) ---------- */
.page-hero {
  border-bottom: 1px solid var(--color-divider);
  padding-block: clamp(var(--space-16), 10vw, var(--space-24));
}

.page-hero h1 {
  font-size: var(--text-3xl);
  line-height: 1.02;
  max-width: 22ch;
}
.page-hero h1 em {
  font-style: italic;
  color: var(--color-primary);
  font-weight: 400;
}

.page-hero .lede {
  margin-top: var(--space-8);
  max-width: 62ch;
}

/* ---------- Methodology long ---------- */
.method-step {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: clamp(2rem, 5vw, 4rem);
  padding-block: clamp(var(--space-12), 6vw, var(--space-20));
  border-bottom: 1px solid var(--color-divider);
}
@media (min-width: 880px) {
  .method-step { grid-template-columns: minmax(0, 0.7fr) minmax(0, 1.3fr); }
}
.method-step:last-of-type { border-bottom: none; }

.method-step-num {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(3rem, 2rem + 4vw, 6rem);
  color: var(--color-primary);
  line-height: 1;
}

.method-step h2 {
  font-size: var(--text-2xl);
  line-height: 1.05;
  margin-bottom: var(--space-6);
}

.method-step .lede {
  font-size: var(--text-lg);
  color: var(--color-text);
  max-width: none;
}

.method-step ul {
  margin-top: var(--space-8);
  display: grid;
  gap: var(--space-4);
  list-style: none;
}
.method-step ul li {
  padding-left: var(--space-6);
  position: relative;
  color: var(--color-text-muted);
  font-size: var(--text-base);
  max-width: 60ch;
}
.method-step ul li::before {
  content: '';
  position: absolute;
  left: 0; top: 0.7em;
  width: 0.875rem;
  height: 1px;
  background: var(--color-primary);
}

/* ---------- Wisdoms book layout ---------- */
.book-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: clamp(2rem, 6vw, 5rem);
  align-items: center;
}
@media (min-width: 880px) {
  .book-hero { grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); }
}

.book-cover {
  aspect-ratio: 2 / 3;
  background: linear-gradient(155deg, var(--color-surface-offset), var(--color-surface-2));
  border-radius: 4px;
  box-shadow:
    var(--shadow-lg),
    -8px 0 0 -2px color-mix(in oklab, var(--color-primary) 35%, transparent),
    -8px 0 0 -1px var(--color-divider);
  position: relative;
  overflow: hidden;
  max-width: 420px;
  margin-inline: auto;
}

.book-cover svg { width: 100%; height: 100%; }

.book-chapters {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr));
  gap: var(--space-6);
  margin-top: var(--space-12);
}

.chapter-card {
  padding: var(--space-6);
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-md);
}
.chapter-card .ch-num {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--color-primary);
  font-size: var(--text-lg);
}
.chapter-card h3 {
  font-size: var(--text-base);
  margin-top: var(--space-3);
}
.chapter-card p {
  margin-top: var(--space-3);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}

/* Excerpt block */
.excerpt {
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-md);
  padding: clamp(2rem, 5vw, 4rem);
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-style: italic;
  line-height: 1.55;
  color: var(--color-text);
  max-width: 56ch;
  margin-inline: auto;
  position: relative;
}

.excerpt::before {
  content: '“';
  font-family: var(--font-display);
  font-size: 5rem;
  position: absolute;
  top: var(--space-2);
  left: var(--space-4);
  color: var(--color-primary);
  opacity: 0.3;
  line-height: 1;
}

/* ---------- Work With Me / Programs ---------- */
.program-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 300px), 1fr));
  gap: clamp(1rem, 2vw, 2rem);
  margin-top: var(--space-12);
}

.program-card {
  padding: clamp(1.75rem, 3vw, 2.5rem);
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  position: relative;
}

.program-card.feature {
  background: var(--color-text);
  color: var(--color-text-inverse);
  border-color: var(--color-text);
}
[data-theme='dark'] .program-card.feature {
  background: var(--color-surface-2);
  border-color: var(--color-primary);
  color: var(--color-text);
}

.program-card.feature h3,
.program-card.feature .program-price {
  color: var(--color-text-inverse);
}
[data-theme='dark'] .program-card.feature h3,
[data-theme='dark'] .program-card.feature .program-price {
  color: var(--color-text);
}

.program-card .program-tag {
  font-size: var(--text-xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-primary);
}

.program-card h3 {
  font-size: var(--text-xl);
}

.program-card .program-price {
  font-family: var(--font-display);
  font-size: var(--text-lg);
}

.program-card ul {
  list-style: none;
  display: grid;
  gap: var(--space-3);
  font-size: var(--text-sm);
}
.program-card ul li {
  padding-left: var(--space-6);
  position: relative;
  color: inherit;
  opacity: 0.85;
}
.program-card ul li::before {
  content: '—';
  position: absolute;
  left: 0;
  color: var(--color-primary);
}

.program-card .btn {
  margin-top: auto;
}

.program-card.feature .btn-ghost {
  color: var(--color-text-inverse);
  border-color: color-mix(in oklab, var(--color-text-inverse) 35%, transparent);
}
[data-theme='dark'] .program-card.feature .btn-ghost {
  color: var(--color-text);
  border-color: var(--color-border);
}

/* ---------- Forms ---------- */
.form-shell {
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-md);
  padding: clamp(2rem, 5vw, 3.5rem);
}

.form-shell legend {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  margin-bottom: var(--space-2);
}

.form-shell .form-help {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  margin-bottom: var(--space-8);
}

.form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr));
  gap: var(--space-6);
}

.field { display: grid; gap: var(--space-2); }
.field.full { grid-column: 1 / -1; }

.field label {
  font-size: var(--text-xs);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}

.field input,
.field textarea,
.field select {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 0.875rem 1rem;
  font-size: var(--text-base);
  color: var(--color-text);
  font-family: var(--font-body);
}

.field textarea {
  min-height: 8rem;
  resize: vertical;
}

.field input:focus,
.field textarea:focus,
.field select:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px var(--color-primary-highlight);
}

.field-radio-group {
  display: grid;
  gap: var(--space-2);
}

.field-radio {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  background: var(--color-bg);
}
.field-radio input { margin-top: 0.25rem; accent-color: var(--color-primary); }
.field-radio:hover { border-color: var(--color-text-muted); }
.field-radio input:checked + span {
  color: var(--color-text);
  font-weight: 500;
}
.field-radio:has(input:checked) {
  border-color: var(--color-primary);
  background: var(--color-primary-highlight);
}

.form-actions {
  display: flex;
  align-items: center;
  gap: var(--space-6);
  margin-top: var(--space-10);
  flex-wrap: wrap;
}

.form-success {
  display: none;
  padding: var(--space-6);
  background: var(--color-primary-highlight);
  border: 1px solid var(--color-primary);
  border-radius: var(--radius-md);
  color: var(--color-text);
}

.form-success.is-visible { display: block; }
.form-success h3 {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  margin-bottom: var(--space-2);
}

.form-fieldset + .form-fieldset { margin-top: var(--space-12); }
.form-fieldset h3 {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  margin-bottom: var(--space-2);
}
.form-fieldset .form-fieldset-help {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  margin-bottom: var(--space-6);
}

/* ---------- Sequence / list ---------- */
.sequence {
  display: grid;
  gap: var(--space-8);
  margin-top: var(--space-12);
}

.sequence-item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: var(--space-6);
  padding-bottom: var(--space-8);
  border-bottom: 1px solid var(--color-divider);
}
.sequence-item:last-child { border-bottom: none; }

.sequence-item .seq-day {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--color-primary);
  font-size: var(--text-lg);
  min-width: 4.5rem;
}

.sequence-item h3 {
  font-size: var(--text-lg);
  margin-bottom: var(--space-2);
}

.sequence-item p {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}

/* ---------- Assessment ---------- */
.assessment-step {
  display: none;
}
.assessment-step.active {
  display: block;
}

.assessment-progress {
  display: flex;
  gap: var(--space-2);
  margin-bottom: var(--space-8);
}
.assessment-progress span {
  height: 2px;
  flex: 1;
  background: var(--color-divider);
  border-radius: var(--radius-full);
}
.assessment-progress span.done {
  background: var(--color-primary);
}

.assessment-question h3 {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  margin-bottom: var(--space-6);
  max-width: 28ch;
}

.scale-row {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
}
.scale-row label {
  cursor: pointer;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: var(--space-4) var(--space-6);
  background: var(--color-bg);
  font-family: var(--font-display);
  font-size: var(--text-lg);
  min-width: 3.5rem;
  text-align: center;
}
.scale-row label:hover { border-color: var(--color-text-muted); }
.scale-row input { position: absolute; opacity: 0; pointer-events: none; }
.scale-row label:has(input:checked) {
  background: var(--color-primary);
  color: var(--color-text-inverse);
  border-color: var(--color-primary);
}

.assessment-actions {
  display: flex;
  justify-content: space-between;
  margin-top: var(--space-10);
  gap: var(--space-4);
  flex-wrap: wrap;
}

.assessment-result {
  display: none;
}
.assessment-result.is-visible { display: block; }

.score-display {
  font-family: var(--font-display);
  font-size: clamp(3rem, 2rem + 4vw, 5rem);
  color: var(--color-primary);
  line-height: 1;
}

/* ---------- About ---------- */
.about-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: clamp(2rem, 5vw, 4rem);
}
@media (min-width: 880px) {
  .about-hero { grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr); }
}

.about-portrait {
  aspect-ratio: 4 / 5;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--color-surface-2);
  box-shadow: var(--shadow-md);
}
.about-portrait svg { width: 100%; height: 100%; }

.principles-list {
  display: grid;
  gap: var(--space-6);
  margin-top: var(--space-12);
  list-style: none;
}
.principles-list li {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: var(--space-6);
  padding: var(--space-6);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-md);
  background: var(--color-surface);
}
.principles-list .p-num {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--color-primary);
  font-size: var(--text-xl);
  line-height: 1;
}
.principles-list h3 {
  font-size: var(--text-base);
  font-family: var(--font-body);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-bottom: var(--space-2);
}
.principles-list p {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}

/* ---------- Resource path / Lead magnet ---------- */
.lead-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--space-8);
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-md);
  padding: clamp(2rem, 5vw, 3rem);
}
@media (min-width: 720px) {
  .lead-row { grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr); align-items: center; }
}

.lead-row h3 {
  font-size: var(--text-xl);
  margin-bottom: var(--space-3);
}

.lead-row p {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}

.inline-form {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
}
.inline-form input {
  flex: 1 1 200px;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 0.875rem 1rem;
  font-size: var(--text-sm);
  color: var(--color-text);
}
.inline-form input:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px var(--color-primary-highlight);
}

/* ---------- Misc helpers ---------- */
.divider-rule {
  height: 1px;
  background: var(--color-divider);
  border: none;
  margin-block: var(--space-12);
}

.tag {
  display: inline-flex;
  font-size: var(--text-xs);
  padding: 0.25rem 0.625rem;
  background: var(--color-primary-highlight);
  color: var(--color-primary);
  border-radius: var(--radius-full);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

/* Background ornamental rule */
.ornament-rule {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-4);
  color: var(--color-primary);
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-lg);
}
.ornament-rule::before,
.ornament-rule::after {
  content: '';
  flex: 0 1 6rem;
  height: 1px;
  background: var(--color-primary);
  opacity: 0.5;
}

/* Mobile spacing adjustments */
@media (max-width: 640px) {
  .hero { padding-block: var(--space-16); }
  .hero-meta { gap: var(--space-6); }
}
