/* ═══════════════════════════════════════════════════════════════
   Cytognosis — Site extensions
   New sections + shared page primitives layered on landing/styles.css.
   Reuses the same tokens, type, motion, and component language.
   ═══════════════════════════════════════════════════════════════ */

/* ── shared section subhead used on inner pages ─────────────── */
.page-hero { padding: 96px 0 64px; position: relative; overflow: hidden; }
.page-hero .container { position: relative; z-index: 1; }
.page-hero .glow { position: absolute; top: -180px; right: -120px; width: 560px; height: 560px;
  background: radial-gradient(circle, rgba(110,91,209,0.12) 0%, transparent 66%); pointer-events: none; z-index: 0; }
.page-hero-inner { max-width: 740px; }
.page-title { font-family: var(--f-display); font-size: clamp(2.4rem, 4.4vw, 3.5rem); font-weight: 500;
  letter-spacing: -0.032em; line-height: 1.06; color: var(--ink); text-wrap: balance; }
.page-title .serif { font-weight: 400; }
.page-lead { font-size: 18.5px; color: var(--ink-2); line-height: 1.62; margin-top: 22px; max-width: 60ch; }
.breadcrumb { display: flex; align-items: center; gap: 8px; font-family: var(--f-mono); font-size: 11px;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--faint); margin-bottom: 22px; }
.breadcrumb a { color: var(--violet-strong); }
.breadcrumb a:hover { text-decoration: underline; }

/* small section CTA link */
.section-cta { display: inline-flex; align-items: center; gap: 9px; margin-top: 38px;
  font-size: 15px; font-weight: 500; color: var(--violet); }
.section-cta .arr { transition: transform 250ms var(--ease); }
.section-cta:hover .arr { transform: translateX(4px); }

/* reusable two-column content split */
.split-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }

/* origin CTA inline */
.origin-actions { margin-top: 30px; display: flex; gap: 12px; flex-wrap: wrap; }

/* ═══════════════ SCIENTIFIC FOUNDATION ═══════════════ */
.foundation { background: var(--bg-soft); }
.found-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start; }
.found-tags { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 30px; }
.found-tag { display: inline-flex; align-items: center; gap: 9px; padding: 11px 16px; background: var(--surface);
  border: 1px solid var(--hair); border-radius: 9999px; font-size: 13.5px; font-weight: 500; color: var(--ink-2);
  transition: transform 280ms var(--ease), border-color 280ms, box-shadow 280ms; }
.found-tag:hover { transform: translateY(-2px); border-color: rgba(110,91,209,0.28); box-shadow: 0 10px 26px -14px rgba(81,69,168,0.3); }
.found-tag .ft-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--violet); flex-shrink: 0; }
.found-tag:nth-child(3n) .ft-dot { background: var(--azure); }
.found-tag:nth-child(3n+1) .ft-dot { background: var(--teal); }

.validation-card { background: var(--surface); border: 1px solid var(--hair); border-radius: 18px; padding: 32px 32px 26px;
  box-shadow: 0 22px 54px -28px rgba(81,69,168,0.26); }
.validation-card .vc-head { display: flex; align-items: center; gap: 11px; margin-bottom: 6px; }
.validation-card .vc-kicker { font-family: var(--f-mono); font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--violet); }
.validation-card h3 { font-family: var(--f-display); font-size: 21px; font-weight: 500; letter-spacing: -0.02em; color: var(--ink); margin-bottom: 18px; }
.vc-list { display: flex; flex-direction: column; gap: 2px; }
.vc-item { display: flex; align-items: flex-start; gap: 13px; padding: 13px 0; border-top: 1px solid var(--hair-soft); }
.vc-item:first-child { border-top: none; }
.vc-check { width: 20px; height: 20px; border-radius: 6px; background: rgba(91,191,188,0.14); flex-shrink: 0; display: flex; align-items: center; justify-content: center; margin-top: 1px; }
.vc-text strong { display: block; font-size: 14.5px; font-weight: 600; color: var(--ink); margin-bottom: 2px; }
.vc-text span { font-size: 13px; color: var(--muted); line-height: 1.5; }

/* ═══════════════ TEAM ═══════════════ */
.team { background: var(--bg); }
.team-group-label { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--faint); margin: 0 0 22px; display: flex; align-items: center; gap: 12px; }
.team-group-label::after { content: ''; flex: 1; height: 1px; background: var(--hair); }
.team-group + .team-group { margin-top: 56px; }
.team-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.team-grid.three { grid-template-columns: repeat(3, 1fr); }
.member { background: var(--surface); border: 1px solid var(--hair); border-radius: 16px; padding: 24px 22px 22px;
  transition: transform 320ms var(--ease), box-shadow 320ms var(--ease), border-color 320ms; }
.member:hover { transform: translateY(-4px); box-shadow: 0 22px 50px -22px rgba(81,69,168,0.28); border-color: rgba(110,91,209,0.2); }
.member-avatar { width: 56px; height: 56px; border-radius: 14px; display: flex; align-items: center; justify-content: center;
  font-family: var(--f-display); font-size: 18px; font-weight: 600; color: #fff; margin-bottom: 18px; letter-spacing: -0.01em;
  background: linear-gradient(135deg, #6E5BD1, #5145A8); overflow: hidden; }
.member-avatar img { width: 100%; height: 100%; object-fit: cover; }
.member:nth-child(4n+2) .member-avatar { background: linear-gradient(135deg, #3B7DD6, #5145A8); }
.member:nth-child(4n+3) .member-avatar { background: linear-gradient(135deg, #5BBFBC, #3B7DD6); }
.member:nth-child(4n) .member-avatar { background: linear-gradient(135deg, #8C7BD8, #6E5BD1); }
.member-name { font-family: var(--f-display); font-size: 17px; font-weight: 500; color: var(--ink); letter-spacing: -0.01em; }
.member-role { font-size: 13px; color: var(--violet); margin-top: 3px; font-weight: 500; }
.member-bio { font-size: 13px; color: var(--muted); line-height: 1.56; margin-top: 12px; }
.member-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 14px; }
.member-tags span { font-family: var(--f-mono); font-size: 9.5px; letter-spacing: 0.04em; text-transform: uppercase;
  color: var(--faint); background: rgba(81,69,168,0.06); border-radius: 6px; padding: 4px 8px; }

/* featured founder card */
.member-featured { display: flex; flex-direction: row; align-items: flex-start; gap: 28px; }
.member-avatar-lg { width: 100px; height: 100px; border-radius: 18px; flex-shrink: 0; }
.member-main { flex: 1; min-width: 0; }
.member-featured .member-name { font-size: 20px; }
.member-featured .member-role { font-size: 14px; }
.member-featured .member-bio { max-width: 68ch; }

/* member avatar — larger for real photos */
.member-avatar { width: 68px; height: 68px; border-radius: 15px; }
.member-avatar img { width: 100%; height: 100%; object-fit: cover; border-radius: inherit; }

/* member links row */
.member-links { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 14px; }
.member-link { display: inline-flex; align-items: center; gap: 5px; padding: 6px 11px; font-size: 12px; font-weight: 500;
  color: var(--violet); background: rgba(110,91,209,0.07); border-radius: 9999px; border: 1px solid rgba(110,91,209,0.14);
  transition: background 220ms, border-color 220ms; }
.member-link:hover { background: rgba(110,91,209,0.13); border-color: rgba(110,91,209,0.28); }
.member-link svg { flex-shrink: 0; }

@media (max-width: 720px) {
  .member-featured { flex-direction: column; gap: 16px; }
  .member-avatar-lg { width: 80px; height: 80px; }
}

/* dynamic state placeholders */
.state-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.skeleton-card { background: var(--surface); border: 1px solid var(--hair); border-radius: 16px; padding: 24px 22px; }
.sk-line { height: 12px; border-radius: 6px; background: linear-gradient(90deg, rgba(81,69,168,0.07), rgba(81,69,168,0.13), rgba(81,69,168,0.07));
  background-size: 200% 100%; animation: skshimmer 1.4s ease-in-out infinite; margin-bottom: 10px; }
.sk-avatar { width: 56px; height: 56px; border-radius: 14px; background: rgba(81,69,168,0.08); margin-bottom: 18px; }
@keyframes skshimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }
@media (prefers-reduced-motion: reduce){ .sk-line { animation: none; } }
.empty-state { text-align: center; padding: 56px 24px; background: var(--bg-soft); border: 1px dashed var(--hair); border-radius: 16px; }
.empty-state .es-title { font-family: var(--f-display); font-size: 18px; font-weight: 500; color: var(--ink); margin-bottom: 8px; }
.empty-state .es-body { font-size: 14.5px; color: var(--muted); max-width: 44ch; margin: 0 auto; line-height: 1.6; }

/* ═══════════════ ROADMAP TIMELINE ═══════════════ */
.roadmap { background: var(--bg-section); }
.roadmap-note { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em; color: var(--faint);
  display: inline-flex; align-items: center; gap: 8px; margin-top: 16px; }
.roadmap-note .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--coral); }
.timeline { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin-top: 8px; position: relative; }
.timeline::before { content: ''; position: absolute; top: 17px; left: 6%; right: 6%; height: 2px;
  background: linear-gradient(90deg, var(--violet), var(--azure), rgba(91,191,188,0.6)); border-radius: 2px; z-index: 0; }
.phase { position: relative; z-index: 1; }
.phase-node { width: 34px; height: 34px; border-radius: 50%; background: var(--surface); border: 2px solid var(--violet);
  display: flex; align-items: center; justify-content: center; font-family: var(--f-mono); font-size: 12px; font-weight: 600;
  color: var(--violet); margin-bottom: 22px; box-shadow: 0 0 0 6px var(--bg-section); }
.phase:nth-child(2) .phase-node { border-color: var(--azure); color: var(--azure); }
.phase:nth-child(3) .phase-node { border-color: var(--teal); color: #3a9b98; }
.phase-card { background: var(--bg-soft); border: 1px solid var(--hair); border-radius: 16px; padding: 26px 26px 24px;
  transition: transform 320ms var(--ease), box-shadow 320ms var(--ease); height: 100%; }
.phase-card:hover { transform: translateY(-4px); box-shadow: 0 22px 50px -24px rgba(81,69,168,0.26); }
.phase-tag { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--faint); }
.phase-title { font-family: var(--f-display); font-size: 20px; font-weight: 500; color: var(--ink); letter-spacing: -0.02em; margin: 6px 0 16px; }
.phase-list { list-style: none; display: flex; flex-direction: column; gap: 11px; }
.phase-list li { display: flex; align-items: flex-start; gap: 10px; font-size: 14px; color: var(--muted); line-height: 1.5; }
.phase-list li::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--violet-300); margin-top: 7px; flex-shrink: 0; }
.phase-status { display: inline-flex; align-items: center; gap: 7px; margin-top: 18px; font-family: var(--f-mono);
  font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--violet); padding: 6px 11px;
  background: rgba(110,91,209,0.08); border-radius: 9999px; }

/* ═══════════════ HELIX STRATEGY (DARK) ═══════════════ */
.helix { background: var(--night); overflow: hidden; }
.helix::before { content: ''; position: absolute; bottom: -10%; left: -5%; width: 55%; height: 90%;
  background: radial-gradient(ellipse at 30% 70%, rgba(59,125,214,0.16) 0%, transparent 62%); pointer-events: none; }
.helix-grid { position: relative; z-index: 1; display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 60px; align-items: center; }
.helix-statement { font-family: var(--f-serif); font-size: clamp(1.25rem, 2.1vw, 1.6rem); font-weight: 300; line-height: 1.55;
  color: var(--on-night-1); margin-top: 22px; max-width: 54ch; }
.helix-statement em { font-style: italic; color: var(--violet-300); }
.helix-points { display: flex; flex-direction: column; gap: 12px; margin-top: 30px; }
.helix-point { display: flex; align-items: flex-start; gap: 14px; padding: 18px 20px; background: rgba(255,255,255,0.03);
  border: 1px solid rgba(180,166,232,0.13); border-radius: 13px; }
.helix-point .hp-num { font-family: var(--f-mono); font-size: 11px; color: var(--violet-300); flex-shrink: 0; margin-top: 2px; }
.helix-point .hp-body { font-size: 14px; color: var(--on-night-2); line-height: 1.56; }
.helix-point .hp-body b { color: var(--on-night-1); font-weight: 600; }
.helix-visual { position: relative; }
.helix-svg-box { background: rgba(255,255,255,0.025); border: 1px solid rgba(180,166,232,0.16); border-radius: 20px;
  padding: 16px; box-shadow: 0 30px 80px -30px rgba(0,0,0,0.5); }
.helix-svg-box svg { width: 100%; height: auto; display: block; }
.helix-caption { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--on-night-3); text-align: center; margin-top: 14px; }

/* ═══════════════ GET INVOLVED ═══════════════ */
.involved { background: var(--bg); }
.pathways { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.pathway { display: flex; flex-direction: column; background: var(--surface); border: 1px solid var(--hair); border-radius: 18px;
  padding: 28px 26px 26px; transition: transform 340ms var(--ease), box-shadow 340ms var(--ease), border-color 340ms; }
.pathway:hover { transform: translateY(-5px); box-shadow: 0 28px 60px -26px rgba(81,69,168,0.3); border-color: rgba(110,91,209,0.22); }
.pathway-ico { width: 46px; height: 46px; border-radius: 13px; display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, rgba(110,91,209,0.13), rgba(59,125,214,0.1)); margin-bottom: 20px; }
.pathway-title { font-family: var(--f-display); font-size: 19px; font-weight: 500; color: var(--ink); letter-spacing: -0.02em; margin-bottom: 10px; }
.pathway-body { font-size: 14px; color: var(--muted); line-height: 1.6; flex: 1; }
.pathway-meta { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.05em; text-transform: uppercase; color: var(--faint);
  margin-top: 14px; line-height: 1.7; }
.pathway-cta { display: inline-flex; align-items: center; gap: 8px; margin-top: 20px; font-size: 14px; font-weight: 500; color: var(--violet); }
.pathway-cta .arr { transition: transform 250ms var(--ease); }
.pathway:hover .pathway-cta .arr { transform: translateX(4px); }

/* ═══════════════ BLOG ═══════════════ */
.blog { background: var(--bg-soft); }
.blog-layout { display: grid; grid-template-columns: 1.35fr 1fr; gap: 28px; align-items: stretch; }
.post-featured { display: flex; flex-direction: column; background: var(--surface); border: 1px solid var(--hair);
  border-radius: 20px; overflow: hidden; transition: transform 340ms var(--ease), box-shadow 340ms var(--ease); }
.post-featured:hover { transform: translateY(-4px); box-shadow: 0 30px 64px -28px rgba(81,69,168,0.3); }
.post-featured .pf-cover { aspect-ratio: 16 / 8; position: relative; overflow: hidden; background: linear-gradient(150deg, #EAE6FA, #E6EEFB); }
.post-featured .pf-cover img { width: 100%; height: 100%; object-fit: cover; }
.post-featured .pf-body { padding: 30px 32px 32px; flex: 1; display: flex; flex-direction: column; }
.post-meta { display: flex; align-items: center; gap: 10px; font-family: var(--f-mono); font-size: 10.5px;
  letter-spacing: 0.05em; text-transform: uppercase; color: var(--faint); margin-bottom: 14px; flex-wrap: wrap; }
.post-meta .tag { color: var(--violet); }
.post-meta .sep { width: 3px; height: 3px; border-radius: 50%; background: var(--faint); }
.post-featured h3 { font-family: var(--f-display); font-size: clamp(1.4rem, 2.2vw, 1.85rem); font-weight: 500;
  letter-spacing: -0.02em; line-height: 1.18; color: var(--ink); margin-bottom: 14px; text-wrap: balance; }
.post-featured .pf-excerpt { font-size: 15px; color: var(--muted); line-height: 1.62; flex: 1; }
.post-read { display: inline-flex; align-items: center; gap: 9px; margin-top: 22px; font-size: 14.5px; font-weight: 500; color: var(--violet); }
.post-read .arr { transition: transform 250ms var(--ease); }
.post-featured:hover .post-read .arr { transform: translateX(4px); }
.post-list { display: flex; flex-direction: column; gap: 16px; }
.post-mini { background: var(--surface); border: 1px solid var(--hair); border-radius: 16px; padding: 22px 24px;
  transition: transform 300ms var(--ease), box-shadow 300ms var(--ease), border-color 300ms; flex: 1; display: flex; flex-direction: column; justify-content: center; }
.post-mini:hover { transform: translateY(-3px); box-shadow: 0 18px 44px -20px rgba(81,69,168,0.26); border-color: rgba(110,91,209,0.2); }
.post-mini h4 { font-family: var(--f-display); font-size: 17px; font-weight: 500; letter-spacing: -0.01em; line-height: 1.28; color: var(--ink); margin-bottom: 10px; }
.post-mini .pm-excerpt { font-size: 13.5px; color: var(--muted); line-height: 1.55; }

/* ── article pages ─────────────────────────────────────────── */
.article-shell { background: var(--bg); }
.article-wrap { max-width: 680px; margin: 0 auto; }
.article-kicker { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--violet); margin-bottom: 18px; }
.article-title { font-family: var(--f-display); font-size: clamp(2.2rem, 4.2vw, 3.4rem); font-weight: 500; line-height: 1.06; letter-spacing: -0.032em; color: var(--ink); text-wrap: balance; }
.article-dek { font-size: 19px; line-height: 1.62; color: var(--ink-2); margin-top: 22px; max-width: 62ch; }
.article-meta-row { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 24px; font-family: var(--f-mono); font-size: 10.5px; letter-spacing: 0.05em; text-transform: uppercase; color: var(--faint); }
.article-cover { margin: 42px 0 0; border-radius: 18px; overflow: hidden; border: 1px solid var(--hair); background: var(--bg-soft); }
.article-cover img { width: 100%; aspect-ratio: 16 / 7; object-fit: cover; }
.article-body { padding-top: 56px; }
.article-body h2 { font-family: var(--f-display); font-size: clamp(1.45rem, 2.4vw, 2rem); font-weight: 500; letter-spacing: -0.02em; line-height: 1.2; color: var(--ink); margin: 44px 0 14px; }
.article-body p { font-size: 17px; color: var(--ink-2); line-height: 1.78; margin-bottom: 20px; }
.article-body ul { margin: 10px 0 26px; padding-left: 22px; }
.article-body li { font-size: 16px; color: var(--ink-2); line-height: 1.7; margin-bottom: 10px; }
.article-callout { margin: 34px 0; padding: 24px 26px; border-radius: 16px; background: var(--bg-soft); border: 1px solid var(--hair); font-family: var(--f-serif); font-size: 20px; line-height: 1.55; color: var(--violet-deep); }
.article-next { margin-top: 56px; padding-top: 28px; border-top: 1px solid var(--hair); display: flex; justify-content: space-between; gap: 18px; flex-wrap: wrap; }
.article-next a { color: var(--violet-strong); font-weight: 500; }

/* ═══════════════ CONTACT / FAQ ═══════════════ */
.contact { background: var(--bg); }
.contact-layout { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: 56px; align-items: start; }
.connect-list { display: flex; flex-direction: column; gap: 4px; margin-top: 8px; }
.connect-item { display: flex; align-items: flex-start; gap: 15px; padding: 18px 0; border-top: 1px solid var(--hair-soft); }
.connect-item:first-child { border-top: none; }
.connect-ico { width: 40px; height: 40px; border-radius: 11px; background: rgba(110,91,209,0.09); flex-shrink: 0;
  display: flex; align-items: center; justify-content: center; }
.connect-text .ct-label { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--faint); margin-bottom: 3px; }
.connect-text .ct-value { font-size: 15px; color: var(--ink); font-weight: 500; }
.connect-text .ct-value a:hover { color: var(--violet); }
.quick-links { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 26px; }
.quick-link { display: inline-flex; align-items: center; gap: 8px; padding: 9px 15px; background: var(--bg-soft);
  border: 1px solid var(--hair); border-radius: 9999px; font-size: 13px; font-weight: 500; color: var(--ink-2); transition: all 240ms var(--ease); }
.quick-link:hover { border-color: rgba(110,91,209,0.3); color: var(--violet); transform: translateY(-1px); }

/* ── FORMS ──────────────────────────────────────────────────── */
.form-card { background: var(--surface); border: 1px solid var(--hair); border-radius: 20px; padding: 34px 36px 32px;
  box-shadow: 0 24px 60px -30px rgba(81,69,168,0.28); }
.form { display: flex; flex-direction: column; gap: 18px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.form-row.three { grid-template-columns: 1fr 1fr 1fr; }
.field { display: flex; flex-direction: column; gap: 7px; }
.field label { font-size: 13px; font-weight: 600; color: var(--ink-2); }
.field label .req { color: var(--coral); margin-left: 2px; }
.field .hint { font-size: 12px; color: var(--muted); font-weight: 400; }
.field input, .field select, .field textarea {
  font-family: var(--f-body); font-size: 16px; color: var(--ink); background: var(--bg-soft);
  border: 1.5px solid var(--hair); border-radius: 10px; padding: 12px 14px; width: 100%;
  transition: border-color 220ms, background 220ms, box-shadow 220ms; min-height: 46px; }
.field textarea { min-height: 128px; resize: vertical; line-height: 1.55; }
.field select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'%3E%3Cpath d='M3 5l4 4 4-4' stroke='%236F7178' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 14px center; padding-right: 40px; cursor: pointer; }
.field input:focus, .field select:focus, .field textarea:focus {
  outline: none; border-color: var(--violet); background: var(--surface); box-shadow: 0 0 0 3px rgba(110,91,209,0.13); }
.field input::placeholder, .field textarea::placeholder { color: var(--faint); }
.field.invalid input, .field.invalid select, .field.invalid textarea { border-color: var(--coral); background: rgba(242,99,85,0.04); }
.field-error { font-size: 12px; color: var(--coral); display: none; align-items: center; gap: 6px; }
.field.invalid .field-error { display: flex; }

.checkbox-field { display: flex; align-items: flex-start; gap: 11px; cursor: pointer; }
.checkbox-field input { width: 18px; height: 18px; min-height: 0; flex-shrink: 0; margin-top: 2px; accent-color: var(--violet); cursor: pointer; }
.checkbox-field .cb-label { font-size: 13.5px; color: var(--muted); line-height: 1.5; }
.checkbox-field .cb-label strong { color: var(--ink-2); font-weight: 600; }

.honeypot { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; opacity: 0; }
.form-actions { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; margin-top: 6px; }
.form-privacy { font-size: 12px; color: var(--muted); line-height: 1.5; max-width: 44ch; }
.form-success { display: none; align-items: flex-start; gap: 13px; padding: 18px 20px; background: rgba(91,191,188,0.1);
  border: 1px solid rgba(91,191,188,0.34); border-radius: 13px; margin-bottom: 4px; }
.form-success.show { display: flex; }
.form-success .fs-ico { width: 24px; height: 24px; flex-shrink: 0; }
.form-success .fs-text strong { display: block; font-size: 14.5px; color: #2f8c89; margin-bottom: 2px; }
.form-success .fs-text span { font-size: 13px; color: var(--muted); line-height: 1.5; }

.field-group-title { font-family: var(--f-mono); font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--violet); margin: 8px 0 -4px; display: flex; align-items: center; gap: 10px; }
.field-group-title::after { content: ''; flex: 1; height: 1px; background: var(--hair-soft); }

/* ── FAQ ────────────────────────────────────────────────────── */
.faq { background: var(--bg-section); }
.faq-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.faq-card { background: var(--bg-soft); border: 1px solid var(--hair); border-radius: 16px; padding: 26px 26px 24px; }
.faq-q { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 13px; }
.faq-q .q-mark { font-family: var(--f-display); font-size: 15px; font-weight: 600; color: var(--violet); flex-shrink: 0;
  width: 26px; height: 26px; border-radius: 8px; background: rgba(110,91,209,0.1); display: flex; align-items: center; justify-content: center; }
.faq-q h3 { font-family: var(--f-display); font-size: 16px; font-weight: 500; color: var(--ink); line-height: 1.3; letter-spacing: -0.01em; }
.faq-a { font-size: 14px; color: var(--muted); line-height: 1.62; }
.faq-a a { color: var(--violet-strong); font-weight: 500; }
.faq-a a:hover { text-decoration: underline; }

/* ── disclaimer band ────────────────────────────────────────── */
.disclaimer-band { background: var(--bg-soft); border-top: 1px solid var(--hair-soft); }
.disclaimer-band .container { padding-top: 30px; padding-bottom: 30px; display: flex; align-items: center; gap: 14px; justify-content: center; flex-wrap: wrap; }
.disclaimer-band .db-ico { width: 18px; height: 18px; flex-shrink: 0; }
.disclaimer-band p { font-size: 13.5px; color: var(--muted); line-height: 1.55; text-align: center; max-width: 80ch; }

/* warning callout (stories / sensitive) */
.callout { display: flex; align-items: flex-start; gap: 13px; padding: 18px 20px; border-radius: 13px;
  background: rgba(242,99,85,0.08); border: 1px solid rgba(242,99,85,0.28); }
.callout .co-ico { flex-shrink: 0; margin-top: 1px; }
.callout p { font-size: 13.5px; color: var(--ink-2); line-height: 1.55; }
.callout p strong { font-weight: 600; }

/* ═══════════════ EXPANDED FOOTER ═══════════════ */
.footer-cols.four { display: grid; grid-template-columns: repeat(4, auto); gap: 56px; }
.footer-disclaimer { font-size: 12px; color: rgba(255,255,255,0.34); line-height: 1.55; max-width: 70ch; margin-top: 14px; }

/* ═══════════════ RESPONSIVE ═══════════════ */
@media (max-width: 1000px) {
  .found-layout, .helix-grid, .contact-layout, .blog-layout, .split-grid { grid-template-columns: 1fr; gap: 44px; }
  .team-grid, .team-grid.three, .state-row { grid-template-columns: repeat(2, 1fr); }
  .pathways { grid-template-columns: repeat(2, 1fr); }
  .faq-grid { grid-template-columns: 1fr; }
  .timeline { grid-template-columns: 1fr; gap: 18px; }
  .timeline::before { display: none; }
  .phase-node { box-shadow: none; }
  .footer-cols.four { grid-template-columns: repeat(2, 1fr); gap: 32px; }
}
@media (max-width: 720px) {
  .form-row, .form-row.three { grid-template-columns: 1fr; }
  .team-grid, .team-grid.three, .state-row, .pathways { grid-template-columns: 1fr; }
  .page-hero { padding: 64px 0 48px; }
}

/* ── Accessibility controls (footer): Reading mode + Reduce motion ──
   Rendered by React (A11yControls.jsx) on the landing page and injected
   by landing/site.js on static pages; one style block serves both. */
.a11y-controls {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin: 26px 0 0;
  padding-top: 22px;
  border-top: 1px solid var(--hair, rgba(255, 255, 255, 0.1));
}
.a11y-controls-label {
  font-family: var(--f-mono);
  font-size: 10.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--on-night-3, #7c7a9c);
  margin-right: 4px;
}
.a11y-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--f-body);
  font-size: 13px;
  line-height: 1;
  color: var(--on-night-2, #adaac8);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 999px;
  padding: 9px 14px;
  min-height: 44px;
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease),
    color var(--dur-fast) var(--ease);
}
.a11y-toggle:hover {
  border-color: var(--violet-300);
  color: var(--on-night-1, #f0eef8);
}
.a11y-toggle[aria-pressed='true'] {
  background: rgba(202, 160, 240, 0.16);
  border-color: var(--violet-300);
  color: var(--on-night-1, #f0eef8);
}
.a11y-toggle-ico {
  display: inline-flex;
  width: 15px;
  height: 15px;
}
.a11y-toggle-state {
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  opacity: 0.85;
  padding: 2px 7px;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.07);
}
.a11y-toggle[aria-pressed='true'] .a11y-toggle-state {
  background: rgba(202, 160, 240, 0.24);
  opacity: 1;
}
@media (max-width: 560px) {
  .a11y-controls {
    width: 100%;
  }
}
