/* ─────────────────────────────────────────────────────────────────
   Ancapex Research — research-v9.css
   Brief implementation. New spine: Hero → training-visual manifesto band
   → Problem → Thesis → Roadmap → Research Artifacts → Workstreams →
   Principles → Work With Us. Removes Wall-St/bull imagery; replaces it
   with a machine-room visual language (loss curve, status badges,
   roadmap ledger, artifact grid). Inherits v6 → v5 … → v3 system.
   ───────────────────────────────────────────────────────────────── */

@import url("research-v6.css");

/* ─────────────  HERO (single column, no bull)  ───────────── */
.hero { padding-top: clamp(96px, 13vh, 150px); padding-bottom: var(--page); }
.hero::before { display: none; }
.hero-grid { grid-template-columns: 1fr; gap: 0; }
.hero-copy { max-width: none; }
.hero h1 { font-size: clamp(36px, 5.4vw, 76px); }
.hero-sub { max-width: 58ch; font-size: clamp(17px, 1.5vw, 21px); margin-bottom: 38px; }
.hero-ctas { gap: 13px; }
@media (max-width: 760px) { .hero { padding-top: 72px; } }

/* wider section titles — use the full column, ~2 lines instead of 3–4 */
.title { max-width: none; }

/* ─────────────  TRAINING-VISUAL MANIFESTO BAND (Fig. 01)  ───────────── */
.tband { position: relative; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); background: var(--bg-2); }
.tband .inner { padding-block: var(--page); }

/* frameless PGP manifesto — v8 editorial typography (no frame, no graph) */
.tband .armor { max-width: 1040px; background: none; border: 0; padding: 0; }
.tband .armor::before { content: none; }
.tband .armor-head { font-family: var(--font-mono); font-size: 11px; font-weight: 500; letter-spacing: 0.14em; text-transform: uppercase; color: var(--acc-ink); opacity: 0.85; }
.tband .armor-body { font-family: var(--font-sans); font-weight: 300; font-size: clamp(21px, 2.5vw, 35px); line-height: 1.32; letter-spacing: -0.03em; color: var(--fg); margin: 22px 0; }
.tband .armor-body + .armor-body { margin-top: 30px; }
.tband .armor-body .anc { color: var(--acc); font-weight: 400; }

/* ─────────────  STATUS BADGES  ───────────── */
.badge { display: inline-flex; align-items: center; gap: 7px; font-family: var(--font-mono); font-size: 10px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; padding: 4px 10px; border: 1px solid var(--line-2); border-radius: var(--radius-pill); color: var(--subtle); white-space: nowrap; }
.badge::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: currentColor; flex: none; }
.badge.now      { color: var(--live);    border-color: rgba(91,227,155,0.4); }
.badge.next     { color: var(--acc);     border-color: var(--acc-line); }
.badge.building { color: var(--amber);   border-color: rgba(230,184,106,0.4); }
.badge.research { color: var(--subtle);  border-color: var(--line-2); }
.badge.target   { color: var(--gold);    border-color: rgba(213,165,36,0.5); }

/* ─────────────  ROADMAP — ledger: phase + deliverables (no badges)  ───────────── */
.roadmap { border-top: 1px solid var(--line-2); }
.phase-head { display: grid; grid-template-columns: 1.18fr 0.82fr; gap: 44px; padding: 13px 0; border-bottom: 1px solid var(--line); }
.ph-k { font-family: var(--font-mono); font-size: 10px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--subtle); }
.ph-k.left { padding-left: 80px; }
.phase { display: grid; grid-template-columns: 1.18fr 0.82fr; gap: 44px; padding: 28px 0; border-bottom: 1px solid var(--line); align-items: start; }
.phase-l { display: grid; grid-template-columns: 56px 1fr; gap: 24px; align-items: start; }
.phase-idx { font-family: var(--font-mono); font-weight: 300; font-size: 30px; line-height: 1; letter-spacing: -0.05em; color: var(--line-3); }
.phase h3 { font-family: var(--font-sans); font-weight: 700; font-size: 21px; line-height: 1.14; letter-spacing: -0.04em; margin: 0 0 9px; }
.phase-l p { font-family: var(--font-sans); font-weight: 300; font-size: 14.5px; line-height: 1.55; color: var(--muted); margin: 0; max-width: 46ch; }
.phase-art { list-style: none; margin: 0; padding: 5px 0 0; display: flex; flex-direction: column; gap: 8px; }
.phase-art li { font-family: var(--font-mono); font-size: 11.5px; line-height: 1.3; letter-spacing: 0.01em; color: var(--subtle); padding-left: 18px; position: relative; }
.phase-art li::before { content: "\203a"; position: absolute; left: 0; color: var(--acc-ink); }
.phase.target h3 { color: var(--gold); }
.phase.target .phase-idx { color: rgba(213,165,36,0.6); }
.phase.target .phase-art li::before { color: var(--gold); }

@media (max-width: 860px) {
  .phase-head { display: none; }
  .phase { grid-template-columns: 1fr; gap: 16px; }
}
@media (max-width: 560px) {
  .phase-l { grid-template-columns: 38px 1fr; gap: 16px; }
  .phase-idx { font-size: 22px; }
  .phase-l p { max-width: none; }
}

/* ─────────────  RESEARCH ARTIFACTS GRID  ───────────── */
.artifact { position: relative; }
.artifact .tag { font-family: var(--font-mono); font-size: 10px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--acc-ink); display: inline-flex; align-items: center; gap: 8px; }
.artifact .tag::before { content: ""; width: 14px; height: 1px; background: var(--acc-line); }
.artifact h3 { font-family: var(--font-sans); font-weight: 700; font-size: 18px; line-height: 1.18; letter-spacing: -0.035em; margin: 0; }
.artifact.failed .tag { color: var(--amber); } .artifact.failed .tag::before { background: rgba(230,184,106,0.5); }

/* ─────────────  CONTACT PATHS  ───────────── */
.paths { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); margin-bottom: 28px; }
.path { background: var(--bg); padding: 26px 24px 24px; display: flex; flex-direction: column; gap: 12px; transition: background var(--dur-base) var(--ease-out); }
.path:hover { background: var(--surf); }
.path .pn { font-family: var(--font-mono); font-size: 11px; font-weight: 600; color: var(--acc-ink); letter-spacing: 0.04em; }
.path h3 { font-family: var(--font-sans); font-weight: 700; font-size: 17px; line-height: 1.18; letter-spacing: -0.035em; margin: 0; }
.path p { font-family: var(--font-sans); font-weight: 300; font-size: 13.5px; line-height: 1.5; color: var(--muted); margin: 0 0 4px; }
.path .pbtn { margin-top: auto; background: none; border: 0; padding: 0; cursor: pointer; font-family: var(--font-mono); font-size: 11.5px; font-weight: 600; letter-spacing: 0.02em; color: var(--acc); text-align: left; display: inline-flex; align-items: center; gap: 8px; }
.path .pbtn::after { content: "→"; transition: transform var(--dur-base) var(--ease-out); }
.path:hover .pbtn::after { transform: translateX(4px); }
@media (max-width: 900px) { .paths { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .paths { grid-template-columns: 1fr; } }

/* contact: full-width form under the paths (no aside) */
.contact-art { display: none; }
.intake { display: block; }
.intake::before { content: none; }
.contact-lede { max-width: 60ch; margin: 0 0 38px; }
.hp { position: absolute; left: -10000px; width: 1px; height: 1px; overflow: hidden; }
.btn[disabled] { cursor: wait; opacity: 0.72; }
.form-error { display: none; margin: 16px 0 0; font-family: var(--font-mono); font-size: 11px; line-height: 1.5; color: var(--amber); }
.form-error.show { display: block; }

/* footer manifesto already removed in v8 markup; keep frameless armor tidy */
.ftr .armor { display: none; }
