/* =============================================================
   BLACK VELAR Agency — section styles
   proof · problem · traffic · approach · niches · cases
   before/after · voices · confidentiality · process(mountain)
   stack · team · faq · form
   ============================================================= */

/* =============================================================
   PROOF / NUMBERS
   ============================================================= */
.proof { border-top: 1px solid var(--border-hair); }
.proof-grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.proof-cell { padding: var(--space-8) var(--space-8) var(--space-6) var(--space-8); border-left: 1px solid var(--border-hair); }
.proof-cell:first-child { border-left: none; padding-left: 0; }
.proof-num {
  font-family: var(--font-display); font-weight: 700;
  font-size: var(--fz-display-md); line-height: 0.96;
  letter-spacing: -0.02em; margin-bottom: var(--space-4);
  background: var(--gradient-fire); -webkit-background-clip: text; background-clip: text; color: transparent;
}
.proof-num .suffix { -webkit-text-fill-color: transparent; }
.proof-label {
  font-family: var(--font-mono); font-size: var(--fz-small);
  letter-spacing: 0.04em; text-transform: uppercase;
  color: var(--text-secondary); max-width: 24ch; line-height: var(--lh-snug);
}

/* =============================================================
   PROBLEM (warm)
   ============================================================= */
.problem { background: var(--bg-elevated); }
.problem-head h2 { font-size: var(--fz-display-lg); margin-bottom: var(--space-8); }
.problem-head h2 .accent { color: var(--accent-warm); }
.problem-head .lead { max-width: 64ch; }
.problem-list { margin-top: clamp(48px, 8vh, 88px); display: grid; gap: 0; }
.problem-grid { margin-top: clamp(48px, 8vh, 88px); display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-4); }
.fail-card { background: var(--bg-paper); border: 1px solid var(--border-hair); padding: var(--space-8); display: flex; flex-direction: column; gap: var(--space-4); transition: border-color var(--dur-base) var(--ease-out-quart), transform var(--dur-base) var(--ease-out-quart); }
.fail-card:hover { border-color: rgba(230, 57, 70, 0.55); transform: translateY(-3px) rotate(-0.6deg); }
.fail-card .fail-tag { align-self: flex-start; margin-bottom: var(--space-2); }
.fail-h { font-family: var(--font-display); font-weight: 700; font-size: var(--fz-h4); text-transform: uppercase; letter-spacing: -0.03em; line-height: var(--lh-snug); color: var(--text-primary); }
.fail-card .fail-text { color: var(--text-secondary); line-height: var(--lh-normal); max-width: none; }
.fail-row { display: grid; grid-template-columns: auto 1fr; gap: var(--space-8); align-items: baseline; padding-block: var(--space-6); border-top: 1px solid var(--border-hair); transition: background var(--dur-base); }
.fail-row:last-child { border-bottom: 1px solid var(--border-hair); }
.fail-row:hover { background: rgba(255, 91, 46, 0.05); }
.fail-tag { font-family: var(--font-mono); font-size: var(--fz-micro); letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent-warm); border: 1px solid rgba(255, 91, 46, 0.4); padding: 5px 9px; white-space: nowrap; align-self: start; }
.fail-text { max-width: 72ch; line-height: var(--lh-normal); }
.fail-text strong { color: var(--text-primary); font-weight: 600; }
.fail-text .muted { color: var(--text-secondary); }

.diag-divider { height: 0; border: none; border-top: 1px solid var(--border-hair); transform: skewY(-1.4deg); transform-origin: left; }

/* =============================================================
   TRAFFIC SOURCES (2 cards — Meta featured + Google)
   ============================================================= */
.source-grid { display: grid; grid-template-columns: 1.35fr 1fr; gap: var(--space-4); }
.source-card { background: var(--bg-elevated); border: 1px solid var(--border-hair); padding: var(--space-12); display: flex; flex-direction: column; gap: var(--space-6); min-height: 420px; transition: border-color var(--dur-base) var(--ease-out-quart), transform var(--dur-base) var(--ease-out-quart); }
.source-card:hover { border-color: var(--border-acid); transform: translateY(-4px); }
.source-tag { font-family: var(--font-mono); font-size: var(--fz-micro); letter-spacing: 0.14em; text-transform: uppercase; align-self: flex-start; padding: 6px 10px; border: 1px solid var(--border-strong); white-space: nowrap; }
.source-tag.main   { color: var(--accent-acid); border-color: var(--border-acid); }
.source-tag.intent { color: #6FA8FF; border-color: rgba(111, 168, 255, 0.4); }
.source-card h3 { font-family: var(--font-display); font-weight: 700; font-size: var(--fz-h3); text-transform: uppercase; letter-spacing: -0.03em; line-height: var(--lh-snug); }
.source-logo { width: 64px; height: 64px; display: grid; place-items: center; }
.source-logo svg { width: 100%; height: 100%; }
.source-logo.meta { color: #6F95C9; }
.source-logo.google { color: #B8BAC0; }
.source-sub { font-family: var(--font-mono); font-size: var(--fz-small); letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-secondary); margin-top: calc(var(--space-4) * -1); }
.source-card p { color: var(--text-secondary); line-height: var(--lh-loose); max-width: 52ch; }
.source-foot { margin-top: auto; display: flex; align-items: flex-end; justify-content: flex-end; gap: var(--space-4); padding-top: var(--space-6); border-top: 1px solid var(--border-hair); }
.source-metric { font-family: var(--font-display); font-weight: 700; font-size: var(--fz-display-sm); line-height: 1; letter-spacing: -0.02em; color: var(--accent-acid); transition: transform var(--dur-base) var(--ease-out-quart); }
.source-card:hover .source-metric { transform: scale(1.05); transform-origin: left bottom; }
.source-metric small { display: block; font-family: var(--font-mono); font-size: var(--fz-micro); letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-secondary); margin-top: var(--space-2); }
.source-link { font-family: var(--font-mono); font-size: var(--fz-micro); letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-secondary); display: inline-flex; gap: var(--space-2); white-space: nowrap; transition: color var(--dur-fast); }
.source-link:hover { color: var(--accent-acid); }

/* =============================================================
   APPROACH
   ============================================================= */
.approach-head h2 { font-size: var(--fz-display-md); margin-bottom: var(--space-6); }
.approach-head h2 strong { color: var(--accent-acid); font-weight: 700; }
.approach-grid { margin-top: clamp(48px, 8vh, 88px); display: grid; grid-template-columns: repeat(2, 1fr); gap: 0; }
.approach-card { padding: var(--space-12) var(--space-8); border-top: 1px solid var(--border-strong); border-right: 1px solid var(--border-hair); transition: background var(--dur-base); }
.approach-card:nth-child(2n) { border-right: none; }
.approach-card:hover { background: var(--bg-elevated); }
.approach-num { font-family: var(--font-display); font-weight: 700; font-size: var(--fz-display-md); line-height: 1; color: var(--text-muted); letter-spacing: -0.02em; margin-bottom: var(--space-6); }
.approach-card h3 { font-family: var(--font-display); font-weight: 700; font-size: var(--fz-h3); text-transform: uppercase; letter-spacing: -0.03em; margin-bottom: var(--space-4); }
.approach-card p { color: var(--text-secondary); line-height: var(--lh-loose); max-width: 52ch; }
.approach-card p strong { color: var(--text-primary); font-weight: 600; }

/* =============================================================
   NICHES
   ============================================================= */
.niches-head h2 { font-size: var(--fz-display-md); margin-bottom: var(--space-6); }
.niches { padding-bottom: clamp(48px, 6.5vh, 96px); }
.chips { display: flex; flex-wrap: wrap; gap: var(--space-3); margin-top: clamp(40px, 6vh, 72px); max-width: 1040px; }
.chip { font-family: var(--font-mono); font-size: var(--fz-small); letter-spacing: 0.04em; text-transform: uppercase; color: var(--text-secondary); border: 1px solid var(--border-strong); padding: 12px 20px; border-radius: 0; transition: color var(--dur-fast), border-color var(--dur-fast), background var(--dur-fast); }
.chip:hover, .chip.active { color: var(--accent-acid); border-color: var(--accent-acid); }
.chip.active { background: rgba(255, 91, 46, 0.06); }
.chip-hint { margin-top: var(--space-8); min-height: 28px; font-family: var(--font-mono); font-size: var(--fz-small); color: var(--accent-acid); letter-spacing: 0.02em; opacity: 0; transform: translateY(6px); transition: opacity var(--dur-base), transform var(--dur-base); }
.chip-hint.show { opacity: 1; transform: translateY(0); }

/* =============================================================
   CASES — bento (8, featured HR)
   ============================================================= */
.cases-head-h2 { font-size: var(--fz-display-md); max-width: 20ch; }
.cases-grid { margin-top: clamp(48px, 8vh, 88px); display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-4); }
.case-card { background: var(--bg-elevated); border: 1px solid var(--border-hair); padding: var(--space-8); display: flex; flex-direction: column; min-height: 280px; transition: border-color var(--dur-base) var(--ease-out-quart), transform var(--dur-base) var(--ease-out-quart), background var(--dur-base); }
.case-card:hover { border-color: var(--border-acid); transform: translateY(-4px); }
.case-card.featured { grid-column: span 2; background: var(--bg-paper); }
.case-top { display: flex; justify-content: space-between; align-items: center; gap: var(--space-4); margin-bottom: var(--space-8); }
.case-status { font-family: var(--font-mono); font-size: var(--fz-micro); letter-spacing: 0.1em; color: var(--accent-acid); display: inline-flex; align-items: center; gap: 6px; text-transform: uppercase; }
.case-status .dot { width: 6px; height: 6px; background: var(--accent-acid); border-radius: 50%; }
.case-name { font-family: var(--font-display); font-weight: 700; font-size: var(--fz-h3); text-transform: uppercase; letter-spacing: -0.03em; line-height: var(--lh-snug); margin-bottom: var(--space-2); }
.case-desc { color: var(--text-secondary); font-size: var(--fz-small); line-height: var(--lh-normal); }
.case-metric { margin-top: auto; padding-top: var(--space-6); }
.case-metric .big { font-family: var(--font-display); font-weight: 700; font-size: var(--fz-display-sm); line-height: 1; letter-spacing: -0.02em; color: var(--accent-acid); }
.case-card.featured .case-metric .big { font-size: var(--fz-display-md); }
.case-metric .cap { color: var(--text-secondary); font-size: var(--fz-small); margin-top: var(--space-2); }
.case-meta { display: grid; grid-template-rows: 0fr; transition: grid-template-rows var(--dur-base) var(--ease-out-quart), margin-top var(--dur-base) var(--ease-out-quart), opacity var(--dur-base); opacity: 0; margin-top: 0; }
.case-card:hover .case-meta { grid-template-rows: 1fr; opacity: 1; margin-top: var(--space-6); }
.case-meta-inner { overflow: hidden; border-top: 1px solid var(--border-hair); padding-top: var(--space-4); display: grid; gap: var(--space-2); }
.case-card.featured .case-meta-inner { grid-template-columns: 1fr 1fr; gap: var(--space-2) var(--space-8); }
.case-meta-row { display: flex; justify-content: space-between; gap: var(--space-4); font-family: var(--font-mono); font-size: var(--fz-micro); letter-spacing: 0.04em; }
.case-meta-row .k { color: var(--text-muted); text-transform: uppercase; }
.case-meta-row .v { color: var(--text-primary); text-align: right; }

/* =============================================================
   BEFORE / AFTER (THE PIVOT)
   ============================================================= */
.pivot-head h2 { font-size: var(--fz-display-md); max-width: 20ch; margin-bottom: var(--space-6); }

/* loud metric + restored compact two-column table (rev.4) */
.pivot-compact { margin-top: clamp(48px, 7vh, 80px); }
.pivot-loud2 { margin-top: clamp(48px, 7vh, 80px); display: flex; align-items: center; justify-content: center; gap: clamp(20px, 4vw, 56px); font-family: var(--font-display); font-weight: 700; letter-spacing: -0.04em; line-height: 0.9; }
.pivot-loud2 .pl-before { font-size: clamp(56px, 11vw, 130px); color: var(--text-muted); text-decoration: line-through; text-decoration-thickness: 4px; text-decoration-color: rgba(230,57,70,0.6); }
.pivot-loud2 .pl-arrow { font-size: clamp(40px, 7vw, 86px); color: var(--accent-orange); font-family: var(--font-body); font-weight: 700; }
.pivot-loud2 .pl-after { font-size: clamp(56px, 11vw, 130px); background: var(--gradient-fire); -webkit-background-clip: text; background-clip: text; color: transparent; }
.pivot-loud-cap { text-align: center; font-family: var(--font-mono); font-size: var(--fz-small); letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-secondary); margin-top: var(--space-6); }

.pivot-table { margin-top: clamp(40px, 6vh, 64px); display: grid; grid-template-columns: 1fr 1fr; border: 1px solid var(--border-hair); }
.pside { padding: clamp(24px, 3vw, 36px); }
.pside.before { background: var(--bg-elevated); }
.pside.after { background: var(--bg-paper); border-left: 1px solid var(--border-hair); }
.pside-head { font-family: var(--font-display); font-weight: 700; font-size: var(--fz-h3); text-transform: uppercase; letter-spacing: -0.03em; margin-bottom: var(--space-6); }
.pside.before .pside-head { color: var(--text-muted); }
.pside.after .pside-head { color: var(--accent-orange); }
.prow { display: grid; grid-template-columns: 1fr auto; gap: var(--space-4); align-items: baseline; padding-block: var(--space-3); border-top: 1px solid var(--border-hair); }
.prow:first-of-type { border-top: none; }
.prow .pk { font-size: var(--fz-small); color: var(--text-secondary); }
.prow .pv { font-family: var(--font-display); font-weight: 700; font-size: 26px; line-height: 1; letter-spacing: -0.03em; text-align: right; color: var(--text-secondary); }
.prow .pv.hot { color: var(--accent-orange); }
.pside-quote { margin-top: var(--space-8); font-family: var(--font-mono); font-size: var(--fz-small); line-height: var(--lh-loose); color: var(--text-secondary); border-left: 2px solid var(--border-strong); padding-left: var(--space-4); }
.pside.after .pside-quote { border-left-color: var(--accent-orange); color: var(--text-primary); }
.pivot-summary { margin-top: clamp(44px, 6vh, 72px); display: flex; align-items: center; justify-content: center; gap: clamp(16px, 3vw, 36px); flex-wrap: wrap; }
.psum { display: flex; flex-direction: column; align-items: center; gap: var(--space-2); }
.psum-v { font-family: var(--font-display); font-weight: 700; font-size: clamp(40px, 6vw, 64px); line-height: 1; letter-spacing: -0.03em; background: var(--gradient-fire); -webkit-background-clip: text; background-clip: text; color: transparent; }
.psum-k { font-family: var(--font-mono); font-size: var(--fz-micro); letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-secondary); }
.psum-sep { font-family: var(--font-display); font-size: clamp(28px, 4vw, 44px); line-height: 1; color: var(--text-muted); align-self: flex-start; margin-top: clamp(4px, 1vw, 10px); }

/* =============================================================
   VOICES / REVIEWS
   ============================================================= */
/* =============================================================
   VOICES / REVIEWS
   ============================================================= */
.voices-head h2 { font-size: var(--fz-display-md); }
.voices-head h2 .accent { color: var(--accent-orange); }
.rail { display: flex; gap: var(--space-4); margin-top: clamp(48px, 7vh, 80px); overflow-x: auto; padding-bottom: var(--space-4); scroll-snap-type: x mandatory; scrollbar-width: thin; scrollbar-color: var(--border-strong) transparent; -webkit-overflow-scrolling: touch; }
.rail::-webkit-scrollbar { height: 6px; }
.rail::-webkit-scrollbar-thumb { background: var(--border-strong); }
.voice { flex: 0 0 282px; scroll-snap-align: start; }
.voice-card { border: 1px solid var(--border-hair); border-radius: 14px; overflow: hidden; background: var(--bg-elevated); transition: border-color var(--dur-base) var(--ease-out-quart); }
.voice:hover .voice-card { border-color: var(--border-acid); }
.voice-shot { position: relative; height: 392px; background:
  radial-gradient(120% 90% at 80% -10%, rgba(255,91,46,0.16), transparent 60%), var(--bg-deep); }
.voice-shot image-slot { width: 100%; height: 100%; }
.voice-check { position: absolute; top: 14px; right: 14px; width: 26px; height: 26px; border-radius: 50%; background: var(--accent-orange); display: grid; place-items: center; pointer-events: none; z-index: 2; }
.voice-check svg { width: 14px; height: 14px; color: #fff; }
.voice-foot { padding: var(--space-6); display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); border-top: 1px solid var(--border-hair); }
.voice-code { font-family: var(--font-display); font-weight: 700; font-size: var(--fz-h4); text-transform: uppercase; letter-spacing: -0.03em; }
.voice-geo { font-family: var(--font-mono); font-size: var(--fz-small); letter-spacing: 0.06em; color: var(--text-secondary); white-space: nowrap; }

/* Telegram screenshots — every card identical size; screenshots fit via contain (no crop) */
.rail { --voice-h: clamp(400px, 54vh, 480px); --voice-w: 290px; align-items: stretch; }
.voice--shot { flex: 0 0 var(--voice-w); }
.voice--shot .voice-card { height: 100%; }
.voice--shot .voice-shot { height: var(--voice-h); width: 100%; background: #0b0b0d; }
.voice--shot .voice-shot img { width: 100%; height: 100%; object-fit: contain; display: block; }

/* Locked teaser cards — real, blurred Telegram screenshot behind a frosted veil */
.voice--locked { flex: 0 0 var(--voice-w); }
.voice--locked .voice-card { height: 100%; }
.voice--locked .voice-shot { height: var(--voice-h); width: 100%; overflow: hidden; background: #0b0b0d; }
.lock-shot { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: blur(11px) brightness(0.72) saturate(0.9); transform: scale(1.18); }
.lock-veil { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--space-3); padding: var(--space-6); text-align: center; background: radial-gradient(circle at 50% 42%, rgba(10,10,12,0.3), rgba(10,10,12,0.74)); }
.lock-ic { width: 50px; height: 50px; border-radius: 50%; border: 1px solid var(--border-acid); display: grid; place-items: center; color: var(--accent-orange); background: rgba(255,91,46,0.06); }
.lock-ic svg { width: 22px; height: 22px; }
.lock-cap { font-family: var(--font-mono); font-size: var(--fz-micro); letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-primary); max-width: 16ch; line-height: 1.5; }
.rail-hint { font-family: var(--font-mono); font-size: var(--fz-micro); letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-muted); margin-top: var(--space-6); display: inline-flex; gap: var(--space-2); }

/* =============================================================
   CONFIDENTIALITY (grid bg)
   ============================================================= */
.confid { background:
  linear-gradient(to right, rgba(244,244,242,0.03) 1px, transparent 1px),
  linear-gradient(to bottom, rgba(244,244,242,0.03) 1px, transparent 1px),
  var(--bg-deep);
  background-size: 64px 64px, 64px 64px, auto; }
.confid-head h2 { font-size: var(--fz-display-md); max-width: 22ch; margin-bottom: var(--space-6); }
.confid-grid { margin-top: clamp(48px, 8vh, 88px); display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-8) var(--space-12); }
.confid-block .lock { width: 24px; height: 24px; color: var(--accent-acid); margin-bottom: var(--space-4); }
.confid-block h3 { font-family: var(--font-display); font-weight: 700; font-size: var(--fz-h4); text-transform: uppercase; letter-spacing: -0.03em; margin-bottom: var(--space-3); line-height: var(--lh-snug); }
.confid-block p { color: var(--text-secondary); line-height: var(--lh-normal); max-width: 32ch; }
.confid-foot { margin-top: clamp(48px, 8vh, 80px); display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: var(--space-8); padding-top: var(--space-8); border-top: 1px solid var(--border-hair); }
.confid-foot p { color: var(--text-secondary); max-width: 60ch; line-height: var(--lh-normal); }
.nda-link { font-family: var(--font-mono); font-size: var(--fz-small); letter-spacing: 0.08em; text-transform: uppercase; color: var(--accent-acid); border: 1px solid var(--border-acid); padding: 14px 22px; display: inline-flex; gap: var(--space-3); white-space: nowrap; transition: background var(--dur-fast), color var(--dur-fast); }
.nda-link:hover { background: var(--accent-acid); color: var(--text-inverse); }

/* =============================================================
   PROCESS — the climb (mountain)
   ============================================================= */
.process { background: var(--bg-elevated); overflow: hidden; }
.process-head { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--space-8); flex-wrap: wrap; }
.process-title { font-family: var(--font-display); font-weight: 700; font-size: var(--fz-display-lg); text-transform: uppercase; letter-spacing: -0.03em; line-height: 0.9;
  color: var(--text-primary); -webkit-text-stroke: 0; -webkit-text-fill-color: var(--text-primary); }
.process-head .lead { max-width: 38ch; }

.climb-stage { position: relative; margin-top: clamp(40px, 7vh, 80px); height: clamp(360px, 46vw, 560px); }
.climb-mountain { position: absolute; inset: auto 0 0 0; width: 100%; height: 72%; }
.climb-mountain svg { width: 100%; height: 100%; }
.climb-step { position: absolute; transform: translate(-50%, -50%); z-index: 2; width: 132px; text-align: center; }
.climb-dot { width: 46px; height: 46px; margin: 0 auto var(--space-3); border-radius: 50%; background: var(--accent-mint); color: #06231D; display: grid; place-items: center; box-shadow: 0 0 0 6px rgba(78,204,183,0.14); }
.climb-dot svg { width: 22px; height: 22px; }
.climb-n { font-family: var(--font-mono); font-size: var(--fz-micro); letter-spacing: 0.1em; color: var(--accent-mint); margin-bottom: var(--space-2); }
.climb-name { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-primary); line-height: 1.25; }
.climb-day { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-muted); margin-top: 4px; }
.climb-drop { position: absolute; left: 50%; top: calc(50% + 26px); width: 0; height: clamp(28px, 5vh, 56px); border-left: 1px dashed rgba(78,204,183,0.5); transform: translateX(-0.5px); z-index: 1; }

/* arc coordinates */
.cs-01 { left: 7%;  top: 80%; }
.cs-02 { left: 20%; top: 62%; }
.cs-03 { left: 34%; top: 42%; }
.cs-04 { left: 49%; top: 18%; }
.cs-05 { left: 63%; top: 38%; }
.cs-06 { left: 75%; top: 56%; }
.cs-07 { left: 87%; top: 70%; }
.cs-08 { left: 96%; top: 82%; }

.js .climb-dot { opacity: 0; transform: scale(0.4) translateY(-18px); }
.climb-stage.lit .climb-dot { animation: dotIn var(--dur-base) var(--ease-out-expo) forwards; }
@keyframes dotIn { to { opacity: 1; transform: scale(1) translateY(0); } }

/* mobile vertical fallback */
.climb-list { display: none; }

/* =============================================================
   STACK / TOOLS
   ============================================================= */
.stack-head-h2 { font-size: var(--fz-display-md); }
.stack-grid { margin-top: clamp(48px, 8vh, 80px); display: grid; grid-template-columns: repeat(2, 1fr); gap: 0 var(--space-16); }
.stack-row { display: grid; grid-template-columns: 28px 1fr; gap: var(--space-4); align-items: baseline; padding-block: var(--space-6); border-top: 1px solid var(--border-hair); }
.stack-row .idx { font-family: var(--font-mono); font-size: var(--fz-micro); color: var(--text-muted); }
.stack-row .label { line-height: var(--lh-normal); }
.stack-row .label strong { color: var(--text-primary); font-weight: 600; display: block; margin-bottom: 2px; }
.stack-row .label span { color: var(--text-secondary); font-size: var(--fz-small); }

/* =============================================================
   TEAM — operators (gradient initial cards)
   ============================================================= */
.team-head-h2 { font-size: var(--fz-display-md); max-width: 18ch; }
.team-sub { margin-top: var(--space-6); }
.op-rail { display: flex; gap: var(--space-6); margin-top: clamp(48px, 7vh, 80px); margin-inline: -12px; overflow-x: auto; padding: 12px 12px var(--space-4); scroll-snap-type: x mandatory; scrollbar-width: thin; scrollbar-color: var(--border-strong) transparent; }
.op-rail::-webkit-scrollbar { height: 6px; }
.op-rail::-webkit-scrollbar-thumb { background: var(--border-strong); }
.op { flex: 0 0 280px; scroll-snap-align: start; }
.op-card { box-sizing: border-box; height: 320px; border-radius: 16px; position: relative; overflow: hidden; display: flex; align-items: flex-end; justify-content: center; border: 2px solid transparent; background: radial-gradient(85% 75% at 50% 38%, #1A1A1C 0%, #0F0F11 100%); background-clip: padding-box; transition: border-color var(--dur-base) var(--ease-out-quart), transform var(--dur-base) var(--ease-out-quart); }
.op-sil { position: relative; z-index: 1; width: auto; height: 85%; display: block; }
/* Founder card — lion portrait */
.op-card--lion { align-items: flex-end; background: radial-gradient(72% 62% at 50% 40%, #2A2422 0%, #1A1616 44%, #0E0D0E 100%); }
/* Operator cards — animal portraits on a light orange gradient */
.op-card--animal { align-items: flex-end; background: radial-gradient(78% 66% at 50% 38%, #43250F 0%, #2B1A12 42%, #120D0C 100%); }
.op:hover .op-card--animal .op-glow { background: radial-gradient(58% 58% at 50% 42%, rgba(255,91,46,0.42) 0%, rgba(255,91,46,0.16) 44%, transparent 72%); }
.op-photo { position: relative; z-index: 1; height: 99%; width: auto; max-width: 102%; object-fit: contain; object-position: bottom center; display: block; filter: brightness(1.14) contrast(1.04) drop-shadow(0 8px 22px rgba(0,0,0,0.6)); }
.op-glow { position: absolute; z-index: 0; left: 50%; top: 42%; width: 92%; height: 72%; transform: translate(-50%, -50%); border-radius: 50%; background: radial-gradient(58% 58% at 50% 42%, rgba(255,91,46,0.28) 0%, rgba(255,91,46,0.10) 44%, transparent 72%); pointer-events: none; }
.op:hover .op-card--lion .op-glow { background: radial-gradient(58% 58% at 50% 42%, rgba(255,91,46,0.40) 0%, rgba(255,91,46,0.14) 44%, transparent 72%); }
.op:hover .op-card { border-color: #FF5B2E; transform: rotate(-1deg); }
.op-info { padding-top: var(--space-6); }
.op-name { font-family: var(--font-display); font-weight: 700; font-size: var(--fz-h4); text-transform: uppercase; letter-spacing: -0.03em; margin-bottom: var(--space-2); }
.op-role { font-family: var(--font-mono); font-size: var(--fz-micro); letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-muted); }

/* =============================================================
   CREATIVES — 9:16 placeholder showcase
   ============================================================= */
.creatives-h2 { font-size: var(--fz-display-md); max-width: 16ch; }
.creatives-h2 .accent { color: var(--accent-orange); }
.cr-rail { display: flex; gap: var(--space-4); margin-top: clamp(40px, 6vh, 72px); overflow-x: auto; padding-bottom: var(--space-4); scroll-snap-type: x mandatory; scrollbar-width: thin; scrollbar-color: var(--border-strong) transparent; }
.cr-rail::-webkit-scrollbar { height: 6px; }
.cr-rail::-webkit-scrollbar-thumb { background: var(--border-strong); }
.cr-card { flex: 0 0 220px; scroll-snap-align: start; aspect-ratio: 9 / 16; border-radius: 14px; overflow: hidden; border: 1px solid var(--border-hair); background: var(--bg-paper); transition: border-color var(--dur-base) var(--ease-out-quart); }
.cr-card:hover { border-color: var(--accent-orange); }
.cr-card img, .cr-card video { width: 100%; height: 100%; object-fit: cover; display: block; }
.cr-ph { width: 100%; height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--space-3); text-align: center; padding: var(--space-4); opacity: 0.36; transition: opacity var(--dur-base) var(--ease-out-quart); }
.cr-card:hover .cr-ph { opacity: 0.6; }
.cr-icon { color: var(--text-secondary); }
.cr-icon svg { width: 32px; height: 32px; }
.cr-cap { font-family: var(--font-mono); font-size: var(--fz-micro); letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-muted); line-height: 1.5; }
.cr-fmt { margin-top: var(--space-2); font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em; color: var(--text-muted); padding-top: var(--space-2); border-top: 1px solid var(--border-hair); }

/* =============================================================
   FAQ
   ============================================================= */
.faq-head-h2 { font-size: var(--fz-display-md); max-width: 22ch; }
.faq-list { margin-top: clamp(48px, 8vh, 80px); }
.faq-item { border-top: 1px solid var(--border-hair); }
.faq-item:last-child { border-bottom: 1px solid var(--border-hair); }
.faq-q { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: var(--space-8); text-align: left; padding-block: var(--space-8); font-family: var(--font-display); font-weight: 700; font-size: var(--fz-h4); text-transform: uppercase; letter-spacing: -0.03em; color: var(--text-primary); transition: color var(--dur-fast); }
.faq-q:hover { color: var(--accent-acid); }
.faq-icon { flex-shrink: 0; width: 22px; height: 22px; position: relative; }
.faq-icon::before, .faq-icon::after { content: ""; position: absolute; background: currentColor; transition: transform var(--dur-base) var(--ease-out-quart), opacity var(--dur-base); }
.faq-icon::before { top: 50%; left: 0; width: 100%; height: 2px; transform: translateY(-50%); }
.faq-icon::after { left: 50%; top: 0; width: 2px; height: 100%; transform: translateX(-50%); }
.faq-item.open .faq-icon::after { transform: translateX(-50%) scaleY(0); opacity: 0; }
.faq-item.open .faq-q { color: var(--accent-acid); }
.faq-a { display: grid; grid-template-rows: 0fr; transition: grid-template-rows var(--dur-base) var(--ease-out-quart); }
.faq-item.open .faq-a { grid-template-rows: 1fr; }
.faq-a-inner { overflow: hidden; }
.faq-a-inner p { color: var(--text-secondary); line-height: var(--lh-loose); max-width: 76ch; padding-bottom: var(--space-8); }
.faq-a-inner p strong { color: var(--text-primary); font-weight: 600; }

/* =============================================================
   CTA FORM (acid bg)
   ============================================================= */
.cta { background: var(--accent-acid); color: var(--text-inverse); }
.cta .mk-left { color: rgba(10,10,11,0.6); }
.cta .mk-left .sl { color: var(--text-inverse); }
.cta .mk-right { color: rgba(10,10,11,0.5); }
.cta-grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(48px, 7vw, 110px); align-items: start; }
.cta h2 { font-family: var(--font-display); font-weight: 700; font-size: var(--fz-display-sm); text-transform: uppercase; line-height: 1.02; letter-spacing: -0.02em; margin-bottom: var(--space-8); }
.cta h2 em { font-style: normal; -webkit-text-stroke: 1px var(--text-inverse); color: transparent; }
.cta-note { font-family: var(--font-mono); font-size: var(--fz-small); color: rgba(10,10,11,0.62); line-height: var(--lh-normal); max-width: 40ch; letter-spacing: 0.02em; }
.form { display: grid; gap: var(--space-6); }
.field { display: grid; gap: var(--space-3); }
.field label { font-family: var(--font-mono); font-size: var(--fz-micro); letter-spacing: 0.1em; text-transform: uppercase; color: rgba(10,10,11,0.66); }
.field label .req { color: var(--accent-warm); }
.field input, .field select { width: 100%; background: transparent; border: none; border-bottom: 1.5px solid rgba(10,10,11,0.3); border-radius: 0; padding: 12px 0; font-family: var(--font-body); font-size: var(--fz-body-lg); color: var(--text-inverse); transition: border-color var(--dur-fast); }
.field input::placeholder { color: rgba(10,10,11,0.42); }
.field input:focus, .field select:focus { outline: none; border-bottom-color: var(--text-inverse); }
.field select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16'%3E%3Cpath d='M4 6l4 4 4-4' stroke='%230A0A0B' stroke-width='1.5' fill='none'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 2px center; cursor: pointer; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-6); }
.form .btn-submit { margin-top: var(--space-4); justify-self: start; background: var(--text-inverse); color: var(--accent-acid); font-family: var(--font-mono); font-size: var(--fz-small); letter-spacing: 0.08em; text-transform: uppercase; padding: 20px 36px; display: inline-flex; gap: var(--space-3); align-items: center; transition: opacity var(--dur-fast), transform var(--dur-fast); }
.form .btn-submit:hover { opacity: 0.86; }
.form .btn-submit:active { transform: scale(0.98); }
.form-success { display: none; font-family: var(--font-mono); font-size: var(--fz-small); color: var(--text-inverse); border: 1px solid rgba(10,10,11,0.3); padding: var(--space-6); line-height: var(--lh-normal); }
.form-success.show { display: block; }

/* =============================================================
   CTA BANDS (violet, mid-scroll reminders)
   ============================================================= */
.cta-band { background: var(--gradient-cta); color: #fff; }
.cta-band-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px, 6vw, 100px); align-items: center; }
.cta-band-h { font-family: var(--font-display); font-weight: 700; font-size: clamp(32px, 4.4vw, 64px); text-transform: uppercase; line-height: 0.98; letter-spacing: -0.02em; }
.cta-band-h em { font-style: normal; color: transparent; -webkit-text-stroke: 1.4px rgba(255,255,255,0.92); }
.cta-band-sub { margin-top: var(--space-8); max-width: 44ch; color: rgba(255,255,255,0.82); line-height: var(--lh-loose); }
.cta-band-people { display: flex; align-items: center; gap: var(--space-4); margin-top: clamp(32px, 4vh, 48px); flex-wrap: wrap; }
.cta-avatars { display: flex; padding-left: 10px; }
.cta-av { width: 44px; height: 44px; border-radius: 50%; margin-left: -10px; border: 2px solid var(--accent-orange-h); display: grid; place-items: center; font-family: var(--font-display); font-weight: 700; font-size: 12px; letter-spacing: 0.02em; color: #fff; }
.cta-av.av1 { background: linear-gradient(135deg, #7D55B5, #33099B); }
.cta-av.av2 { background: linear-gradient(135deg, #4ECCB7, #1C6F62); }
.cta-av.av3 { background: linear-gradient(135deg, #6FA8FF, #2A4F9B); }
.cta-av.av4 { background: linear-gradient(135deg, #FF7A4D, #B8381C); }
.cta-av.more { background: rgba(10,10,11,0.45); font-family: var(--font-mono); font-size: 12px; }
.cta-people-note { font-family: var(--font-mono); font-size: var(--fz-micro); letter-spacing: 0.1em; text-transform: uppercase; color: rgba(255,255,255,0.72); }
.cta-band-form { border: 1px solid rgba(255,255,255,0.32); border-radius: 24px; padding: clamp(26px, 3vw, 42px); display: grid; gap: var(--space-6); background: rgba(255,255,255,0.05); }
.cta-band-field { display: grid; gap: var(--space-2); }
.cta-band-field label { font-family: var(--font-mono); font-size: var(--fz-micro); letter-spacing: 0.1em; text-transform: uppercase; color: rgba(255,255,255,0.7); }
.cta-band-field input { width: 100%; background: transparent; border: none; border-bottom: 1.5px solid rgba(255,255,255,0.38); border-radius: 0; padding: 12px 0; font-family: var(--font-body); font-size: var(--fz-body-lg); color: #fff; transition: border-color var(--dur-fast); }
.cta-band-field input::placeholder { color: rgba(255,255,255,0.45); }
.cta-band-field input:focus { outline: none; border-bottom-color: #fff; }
.cta-pill { margin-top: var(--space-3); justify-self: start; background: #fff; color: var(--text-inverse); border-radius: 999px; padding: 8px 8px 8px 28px; display: inline-flex; align-items: center; gap: var(--space-4); font-family: var(--font-mono); font-size: var(--fz-small); letter-spacing: 0.06em; text-transform: uppercase; transition: transform var(--dur-fast); }
.cta-pill-arrow { width: 42px; height: 42px; border-radius: 50%; background: var(--text-inverse); color: #fff; display: grid; place-items: center; transition: transform var(--dur-base) var(--ease-out-quart); }
.cta-pill-arrow svg { width: 18px; height: 18px; }
.cta-pill:hover .cta-pill-arrow { transform: translate(3px, -3px); }
.cta-pill:active { transform: scale(0.98); }
.cta-band-form.sent { display: flex; align-items: center; justify-content: center; text-align: center; min-height: 200px; }
.cta-band-sent { font-family: var(--font-mono); font-size: var(--fz-small); line-height: var(--lh-loose); color: #fff; }

/* =============================================================
   SECTION RESPONSIVE
   ============================================================= */
@media (max-width: 1024px) {
  .source-grid { grid-template-columns: 1fr; }
  .cta-grid { grid-template-columns: 1fr; }
  .confid-grid { grid-template-columns: repeat(2, 1fr); }
  .cta-band-grid { grid-template-columns: 1fr; gap: clamp(32px, 6vw, 56px); }
}
@media (max-width: 860px) {
  .proof-grid { grid-template-columns: repeat(2, 1fr); }
  .proof-cell:nth-child(3) { border-left: none; padding-left: 0; }
  .problem-grid { grid-template-columns: repeat(2, 1fr); }
  .approach-grid { grid-template-columns: 1fr; }
  .approach-card { border-right: none; }
  .cases-grid { grid-template-columns: repeat(2, 1fr); }
  .case-card.featured { grid-column: span 2; }
  .case-card.featured .case-meta-inner { grid-template-columns: 1fr; }
  .stack-grid { grid-template-columns: 1fr; }
  .pivot-table { grid-template-columns: 1fr; }
  .pside.after { border-left: none; border-top: 1px solid var(--border-hair); }
  /* mountain -> vertical list */
  .climb-stage { display: none; }
  .climb-list { display: grid; gap: 0; margin-top: var(--space-12); }
  .climb-li { display: grid; grid-template-columns: auto 1fr auto; gap: var(--space-6); align-items: center; padding-block: var(--space-6); border-top: 1px solid var(--border-hair); }
  .climb-li:last-child { border-bottom: 1px solid var(--border-hair); }
  .climb-li .li-dot { width: 40px; height: 40px; border-radius: 50%; background: var(--accent-mint); color: #06231D; display: grid; place-items: center; }
  .climb-li .li-dot svg { width: 20px; height: 20px; }
  .climb-li .li-name { font-family: var(--font-mono); font-size: var(--fz-small); letter-spacing: 0.06em; text-transform: uppercase; }
  .climb-li .li-name .n { color: var(--accent-mint); margin-right: var(--space-3); }
  .climb-li .li-day { font-family: var(--font-mono); font-size: var(--fz-micro); color: var(--text-muted); text-transform: uppercase; white-space: nowrap; }
}
@media (max-width: 520px) {
  .cases-grid { grid-template-columns: 1fr; }
  .problem-grid { grid-template-columns: 1fr; }
  .confid-grid { grid-template-columns: 1fr; }
  .case-card.featured { grid-column: span 1; }
  .case-meta { grid-template-rows: 1fr; opacity: 1; margin-top: var(--space-6); }
  .field-row { grid-template-columns: 1fr; }
  .fail-row { grid-template-columns: 1fr; gap: var(--space-3); }
}

/* =============================================================
   FORM — Web3Forms states (loading · error · honeypot)
   ============================================================= */
.hp-field { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; opacity: 0; pointer-events: none; }
.form .btn-submit:disabled, .cta-pill:disabled { opacity: 0.6; cursor: progress; }
.form .btn-submit.loading .btn-arrow { animation: btnPulse 0.9s ease-in-out infinite; }
@keyframes btnPulse { 0%,100% { opacity: 1; transform: translateX(0); } 50% { opacity: 0.4; transform: translateX(4px); } }
.form-error {
  display: none;
  font-family: var(--font-mono);
  font-size: var(--fz-small);
  color: var(--text-inverse);
  background: rgba(10,10,11,0.06);
  border: 1px solid var(--accent-warm);
  border-left-width: 3px;
  padding: var(--space-4) var(--space-6);
  line-height: var(--lh-normal);
}
.form-error.show { display: block; }
.form-error a { text-decoration: underline; font-weight: 600; }
.cta-band-error {
  margin-top: var(--space-4);
  font-family: var(--font-mono);
  font-size: var(--fz-micro);
  line-height: var(--lh-normal);
  color: #fff;
  background: rgba(0,0,0,0.2);
  border-left: 3px solid #fff;
  padding: var(--space-3) var(--space-4);
}
.cta-band-error a { text-decoration: underline; font-weight: 600; }
