/* ═══════════════════════════════════════════════════════════════
   HATCH LRI™ — Pilot Flow Styles
═══════════════════════════════════════════════════════════════ */
.pilot-page { background: var(--bg); min-height: 100vh; }
.pilot-main { min-height: calc(100vh - var(--nav-h)); padding-top: var(--nav-h); position: relative; }
.pilot-footer { border-top: 1px solid var(--border); }
.pilot-progress { position: fixed; top: var(--nav-h); left: 0; right: 0; z-index: 90; opacity: 0; pointer-events: none; transition: opacity 0.3s ease; }
.pilot-progress.is-visible { opacity: 1; }
.pilot-progress-track { height: 2px; background: rgba(255,255,255,0.07); }
.pilot-progress-fill { height: 100%; background: linear-gradient(90deg, #74de80, #c8f135); width: 0%; transition: width 0.5s cubic-bezier(0.22,0,0.12,1); }
.pilot-progress-labels { display: flex; justify-content: space-between; max-width: 640px; margin: 0 auto; padding: 8px 0 0; }
.ppl { font-family: var(--font-display); font-size: 0.625rem; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(255,255,255,0.22); transition: color 0.3s ease; flex: 1; text-align: center; }
.ppl.is-active { color: rgba(255,255,255,0.55); }
.ppl.is-done { color: var(--accent); }
.pilot-step { display: none; min-height: calc(100vh - var(--nav-h)); padding: 0 24px 80px; position: relative; overflow: hidden; }
.pilot-step.is-active { display: block; }
.pilot-step--entry, .pilot-step--expand { display: flex; flex-direction: column; align-items: center; justify-content: center; min-height: calc(100vh - var(--nav-h)); padding: 80px 24px; }
.pilot-step--entry { display: none; }
.pilot-step--entry.is-active { display: flex; }
.pilot-step--expand { display: none; }
.pilot-step--expand.is-active { display: flex; }
.pilot-step--context, .pilot-step--signals, .pilot-step--results { padding-top: 72px; }
.pilot-step-inner { max-width: 680px; margin: 0 auto; position: relative; z-index: 2; }
.pilot-results-inner { max-width: 760px; }
.pilot-step.is-active .pilot-step-inner, .pilot-step.is-active .pilot-entry-inner, .pilot-step.is-active .pilot-expand-inner { animation: stepFadeUp 0.45s cubic-bezier(0.22,0,0.12,1) both; }
@keyframes stepFadeUp { from { opacity: 0; transform: translateY(18px); } to { opacity: 1; transform: translateY(0); } }
.pilot-entry-inner { display: flex; flex-direction: column; align-items: center; text-align: center; max-width: 580px; position: relative; z-index: 2; }
.pilot-entry-badge { display: inline-flex; align-items: center; gap: 8px; background: rgba(200,241,53,0.07); border: 1px solid rgba(200,241,53,0.18); border-radius: 100px; padding: 6px 16px; margin-bottom: 36px; }
.peb-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 8px rgba(200,241,53,0.6); flex-shrink: 0; }
.peb-text { font-family: var(--font-display); font-size: 0.6875rem; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(200,241,53,0.80); }
.pilot-entry-title { font-family: var(--font-display); font-size: clamp(2.5rem,5.5vw,4.25rem); font-weight: 800; letter-spacing: -0.042em; line-height: 1.06; color: var(--text); margin-bottom: 22px; }
.pilot-entry-sub { font-family: var(--font-body); font-size: clamp(1rem,1.4vw,1.1875rem); font-weight: 400; color: rgba(255,255,255,0.62); line-height: 1.68; max-width: 44ch; margin-bottom: 28px; }
.pilot-entry-trust { display: inline-flex; align-items: flex-start; gap: 10px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); border-radius: 8px; padding: 12px 18px; margin-bottom: 44px; max-width: 44ch; text-align: left; }
.pet-icon { width: 18px; height: 18px; flex-shrink: 0; margin-top: 1px; color: rgba(200,241,53,0.55); }
.pilot-entry-trust span { font-family: var(--font-body); font-size: 0.875rem; color: rgba(255,255,255,0.52); line-height: 1.58; }
.pilot-entry-cta { display: inline-flex; align-items: center; gap: 10px; background: var(--accent); color: #06060A; font-family: var(--font-display); font-size: 1.0625rem; font-weight: 700; letter-spacing: -0.012em; padding: 0 48px; height: 62px; border: none; border-radius: 6px; cursor: pointer; margin-bottom: 24px; transition: background 0.19s ease-out, transform 0.18s ease-out, box-shadow 0.19s ease-out; }
.pilot-entry-cta:hover { background: #d4f53c; transform: translateY(-2px); box-shadow: 0 12px 30px rgba(255,230,0,0.25); }
.pilot-entry-cta:hover .pilot-entry-arrow { transform: translateX(6px); }
.pilot-entry-arrow { display: inline-block; transition: transform 0.18s ease-out; }
.pilot-entry-meta { display: flex; align-items: center; gap: 8px; font-family: var(--font-body); font-size: 0.8125rem; color: rgba(255,255,255,0.28); }
.pem-dot { color: rgba(255,255,255,0.16); }
.pilot-entry-bg { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
.peb-glow { position: absolute; border-radius: 50%; filter: blur(120px); }
.peb-glow--green { width: 500px; height: 500px; background: rgba(74,222,128,0.07); top: -100px; left: -100px; }
.peb-glow--orange { width: 400px; height: 400px; background: rgba(251,146,60,0.06); top: 20%; right: -80px; }
.peb-glow--blue { width: 400px; height: 400px; background: rgba(130,190,255,0.05); bottom: -60px; left: 30%; }
.pilot-step-header { margin-bottom: 52px; }
.pilot-step-label { display: inline-block; font-family: var(--font-display); font-size: 0.625rem; font-weight: 700; letter-spacing: 0.20em; text-transform: uppercase; color: rgba(200,241,53,0.60); margin-bottom: 14px; }
.pilot-step-title { font-family: var(--font-display); font-size: clamp(1.75rem,3vw,2.5rem); font-weight: 800; letter-spacing: -0.034em; line-height: 1.10; color: var(--text); margin-bottom: 10px; }
.pilot-step-sub { font-family: var(--font-body); font-size: 1rem; color: rgba(255,255,255,0.46); line-height: 1.62; }
.pilot-step-actions { display: flex; align-items: center; gap: 16px; margin-top: 48px; }
.pilot-step-hint { font-family: var(--font-body); font-size: 0.8125rem; color: rgba(255,255,255,0.28); }
.pilot-btn-primary { display: inline-flex; align-items: center; gap: 10px; background: var(--accent); color: #06060A; font-family: var(--font-display); font-size: 0.9375rem; font-weight: 700; letter-spacing: -0.012em; padding: 0 36px; height: 56px; border: none; border-radius: 6px; cursor: pointer; text-decoration: none; transition: background 0.19s ease-out, transform 0.18s ease-out, box-shadow 0.19s ease-out, opacity 0.18s ease; }
.pilot-btn-primary:hover:not(:disabled) { background: #d4f53c; transform: translateY(-2px); box-shadow: 0 12px 30px rgba(255,230,0,0.22); }
.pilot-btn-primary:hover .pilot-btn-arrow { transform: translateX(6px); }
.pilot-btn-primary:disabled { opacity: 0.32; cursor: not-allowed; }
.pilot-btn-arrow { display: inline-block; transition: transform 0.18s ease-out; }
.pilot-btn-secondary { display: inline-flex; align-items: center; gap: 6px; background: transparent; color: rgba(255,255,255,0.38); font-family: var(--font-body); font-size: 0.875rem; font-weight: 500; padding: 0 16px; height: 40px; border: 1px solid rgba(255,255,255,0.10); border-radius: 6px; cursor: pointer; text-decoration: none; transition: border-color 0.18s ease, color 0.18s ease, background 0.18s ease; }
.pilot-btn-secondary:hover { border-color: rgba(255,255,255,0.20); color: rgba(255,255,255,0.62); background: rgba(255,255,255,0.04); }
.pilot-fields { display: flex; flex-direction: column; gap: 40px; }
.pilot-field-label { display: block; font-family: var(--font-display); font-size: 0.6875rem; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(255,255,255,0.38); margin-bottom: 14px; }
.pilot-chip-row { display: flex; flex-wrap: wrap; gap: 8px; }
.pilot-chip { display: inline-flex; align-items: center; height: 40px; padding: 0 18px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.10); border-radius: 6px; font-family: var(--font-body); font-size: 0.875rem; font-weight: 500; color: rgba(255,255,255,0.58); cursor: pointer; transition: background 0.16s ease, border-color 0.16s ease, color 0.16s ease; white-space: nowrap; }
.pilot-chip:hover { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.20); color: rgba(255,255,255,0.82); }
.pilot-chip.is-selected { background: rgba(200,241,53,0.10); border-color: rgba(200,241,53,0.40); color: rgba(200,241,53,0.90); font-weight: 600; }
.pilot-prompts { display: flex; flex-direction: column; gap: 32px; }
.pilot-prompt { background: rgba(255,255,255,0.025); border: 1px solid rgba(255,255,255,0.07); border-radius: var(--r-xl); padding: 28px 32px; transition: border-color 0.2s ease, background 0.2s ease; }
.pilot-prompt.is-answered { border-color: rgba(255,255,255,0.12); background: rgba(255,255,255,0.035); }
.pilot-prompt-meta { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.pilot-prompt-tag { display: inline-block; font-family: var(--font-display); font-size: 0.5625rem; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; padding: 4px 10px; border-radius: 4px; }
.pilot-tag-lsi { background: rgba(74,222,128,0.10); color: rgba(74,222,128,0.80); border: 1px solid rgba(74,222,128,0.18); }
.pilot-tag-lli { background: rgba(251,146,60,0.10); color: rgba(251,146,60,0.80); border: 1px solid rgba(251,146,60,0.18); }
.pilot-tag-cei { background: rgba(130,190,255,0.10); color: rgba(130,190,255,0.80); border: 1px solid rgba(130,190,255,0.18); }
.pilot-prompt-index { font-family: var(--font-display); font-size: 0.6875rem; font-weight: 600; color: rgba(255,255,255,0.18); letter-spacing: 0.06em; }
.pilot-prompt-text { font-family: var(--font-body); font-size: 1rem; font-weight: 400; color: rgba(255,255,255,0.80); line-height: 1.65; margin-bottom: 22px; }
.pilot-scale { display: flex; gap: 6px; flex-wrap: wrap; }
.ps-btn { flex: 1; min-width: 80px; height: 44px; padding: 0 10px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.09); border-radius: 6px; cursor: pointer; transition: background 0.15s ease, border-color 0.15s ease, transform 0.13s ease; }
.ps-btn:hover { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.18); transform: translateY(-1px); }
.ps-label { display: block; font-family: var(--font-body); font-size: 0.75rem; font-weight: 500; color: rgba(255,255,255,0.48); white-space: nowrap; transition: color 0.15s ease; }
.pilot-prompt[data-category="lsi"] .ps-btn.is-selected { background: rgba(74,222,128,0.10); border-color: rgba(74,222,128,0.40); }
.pilot-prompt[data-category="lsi"] .ps-btn.is-selected .ps-label { color: rgba(74,222,128,0.90); font-weight: 600; }
.pilot-prompt[data-category="lli"] .ps-btn.is-selected { background: rgba(251,146,60,0.10); border-color: rgba(251,146,60,0.40); }
.pilot-prompt[data-category="lli"] .ps-btn.is-selected .ps-label { color: rgba(251,146,60,0.90); font-weight: 600; }
.pilot-prompt[data-category="cei"] .ps-btn.is-selected { background: rgba(130,190,255,0.10); border-color: rgba(130,190,255,0.40); }
.pilot-prompt[data-category="cei"] .ps-btn.is-selected .ps-label { color: rgba(130,190,255,0.90); font-weight: 600; }
.pilot-prompts-remaining { font-family: var(--font-body); font-size: 0.8125rem; color: rgba(255,255,255,0.28); margin-top: 8px; text-align: right; }
.pilot-generating { display: flex; flex-direction: column; align-items: center; justify-content: center; min-height: 60vh; gap: 24px; }
.pg-spinner { position: relative; width: 80px; height: 80px; }
.pg-ring { position: absolute; inset: 0; border-radius: 50%; border: 2px solid transparent; animation: pgSpin 1.6s linear infinite; }
.pg-ring--lsi { border-top-color: rgba(74,222,128,0.70); animation-duration: 1.4s; }
.pg-ring--lli { inset: 8px; border-top-color: rgba(251,146,60,0.70); animation-duration: 1.8s; animation-direction: reverse; }
.pg-ring--cei { inset: 16px; border-top-color: rgba(130,190,255,0.70); animation-duration: 2.2s; }
@keyframes pgSpin { to { transform: rotate(360deg); } }
.pg-label { font-family: var(--font-display); font-size: 1.0625rem; font-weight: 600; color: rgba(255,255,255,0.75); letter-spacing: -0.018em; animation: pgPulse 1.6s ease-in-out infinite; }
.pg-sub { font-family: var(--font-body); font-size: 0.875rem; color: rgba(255,255,255,0.30); margin-top: -12px; }
@keyframes pgPulse { 0%, 100% { opacity: 0.5; } 50% { opacity: 1; } }
.pilot-results-content { animation: stepFadeUp 0.5s cubic-bezier(0.22,0,0.12,1) both; }
.pilot-results-header { margin-bottom: 44px; }
.pilot-results-eyebrow { display: inline-block; font-family: var(--font-display); font-size: 0.625rem; font-weight: 700; letter-spacing: 0.20em; text-transform: uppercase; color: rgba(200,241,53,0.60); margin-bottom: 12px; }
.pilot-results-title { font-family: var(--font-display); font-size: clamp(1.75rem,3.2vw,2.75rem); font-weight: 800; letter-spacing: -0.034em; line-height: 1.10; color: var(--text); margin-bottom: 10px; }
.pilot-results-context { font-family: var(--font-body); font-size: 0.9375rem; color: rgba(255,255,255,0.48); line-height: 1.62; }
.pr-score-card { display: flex; align-items: center; justify-content: space-between; gap: 32px; background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.08); border-radius: var(--r-xl); padding: 36px 40px; margin-bottom: 28px; }
.pr-score-left { flex: 1; }
.pr-score-label { display: block; font-family: var(--font-display); font-size: 0.625rem; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(255,255,255,0.30); margin-bottom: 10px; }
.pr-score-display { display: flex; align-items: baseline; gap: 12px; margin-bottom: 10px; }
.pr-score-value { font-family: var(--font-display); font-size: clamp(2.5rem,5vw,4rem); font-weight: 800; letter-spacing: -0.04em; line-height: 1; color: var(--text); }
.pr-score-tier { font-family: var(--font-display); font-size: 0.75rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; padding: 4px 10px; border-radius: 4px; }
.pr-score-tier.tier-low { background: rgba(74,222,128,0.12); color: rgba(74,222,128,0.85); border: 1px solid rgba(74,222,128,0.22); }
.pr-score-tier.tier-mod { background: rgba(251,146,60,0.12); color: rgba(251,146,60,0.85); border: 1px solid rgba(251,146,60,0.22); }
.pr-score-tier.tier-high { background: rgba(200,241,53,0.10); color: rgba(200,241,53,0.85); border: 1px solid rgba(200,241,53,0.22); }
.pr-score-tier.tier-critical { background: rgba(255,80,80,0.10); color: rgba(255,100,100,0.85); border: 1px solid rgba(255,80,80,0.22); }
.pr-score-desc { font-family: var(--font-body); font-size: 0.9375rem; color: rgba(255,255,255,0.58); line-height: 1.62; max-width: 38ch; }
.pr-score-ring-wrap { position: relative; width: 110px; height: 110px; flex-shrink: 0; }
.pr-score-ring { width: 100%; height: 100%; transform: rotate(-90deg); }
.psr-track { fill: none; stroke: rgba(255,255,255,0.06); stroke-width: 6; }
.psr-fill { fill: none; stroke: var(--accent); stroke-width: 6; stroke-linecap: round; stroke-dasharray: 327; stroke-dashoffset: 327; transition: stroke-dashoffset 1.2s cubic-bezier(0.22,0,0.12,1); }
.pr-score-ring-val { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-size: 1.375rem; font-weight: 800; letter-spacing: -0.03em; color: var(--text); }
.pr-signals { display: flex; flex-direction: column; gap: 20px; margin-bottom: 44px; }
.pr-signal { background: rgba(255,255,255,0.025); border: 1px solid rgba(255,255,255,0.07); border-radius: var(--r-lg); padding: 22px 28px; }
.prs-top { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.prs-tag { font-family: var(--font-display); font-size: 0.5625rem; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; padding: 3px 9px; border-radius: 3px; flex-shrink: 0; }
.pr-signal-lsi .prs-tag { background: rgba(74,222,128,0.10); color: rgba(74,222,128,0.80); border: 1px solid rgba(74,222,128,0.18); }
.pr-signal-lli .prs-tag { background: rgba(251,146,60,0.10); color: rgba(251,146,60,0.80); border: 1px solid rgba(251,146,60,0.18); }
.pr-signal-cei .prs-tag { background: rgba(130,190,255,0.10); color: rgba(130,190,255,0.80); border: 1px solid rgba(130,190,255,0.18); }
.prs-name { font-family: var(--font-body); font-size: 0.875rem; font-weight: 500; color: rgba(255,255,255,0.60); flex: 1; }
.prs-val { font-family: var(--font-display); font-size: 1rem; font-weight: 700; color: var(--text); letter-spacing: -0.02em; }
.prs-track { height: 4px; background: rgba(255,255,255,0.07); border-radius: 2px; overflow: hidden; margin-bottom: 12px; }
.prs-fill { height: 100%; border-radius: 2px; width: 0%; transition: width 1.0s cubic-bezier(0.22,0,0.12,1); }
.prs-fill-lsi { background: linear-gradient(90deg, rgba(74,222,128,0.5), rgba(74,222,128,0.9)); }
.prs-fill-lli { background: linear-gradient(90deg, rgba(251,146,60,0.5), rgba(251,146,60,0.9)); }
.prs-fill-cei { background: linear-gradient(90deg, rgba(130,190,255,0.5), rgba(130,190,255,0.9)); }
.prs-insight { font-family: var(--font-body); font-size: 0.875rem; color: rgba(255,255,255,0.52); line-height: 1.60; margin: 0; }
.pr-insights { margin-bottom: 36px; }
.pr-section-title { font-family: var(--font-display); font-size: 0.625rem; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(255,255,255,0.28); margin-bottom: 18px; }
.pr-insight-list { display: flex; flex-direction: column; gap: 12px; }
.pr-insight-item { display: flex; align-items: flex-start; gap: 14px; background: rgba(255,255,255,0.025); border: 1px solid rgba(255,255,255,0.07); border-radius: var(--r-lg); padding: 18px 22px; animation: stepFadeUp 0.4s both; }
.pri-icon { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; margin-top: 5px; }
.pri-icon--warn { background: rgba(251,146,60,0.80); box-shadow: 0 0 8px rgba(251,146,60,0.30); }
.pri-icon--alert { background: rgba(200,241,53,0.80); box-shadow: 0 0 8px rgba(200,241,53,0.30); }
.pri-icon--info { background: rgba(130,190,255,0.80); box-shadow: 0 0 8px rgba(130,190,255,0.30); }
.pri-text { font-family: var(--font-body); font-size: 0.9375rem; color: rgba(255,255,255,0.78); line-height: 1.60; }
.pri-text strong { color: rgba(255,255,255,0.92); font-weight: 600; }
.pr-projection { background: linear-gradient(180deg, rgba(200,241,53,0.04) 0%, transparent 60%); border: 1px solid rgba(200,241,53,0.18); border-radius: var(--r-xl); overflow: hidden; margin-bottom: 36px; position: relative; }
.pr-projection::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 2px; background: linear-gradient(180deg, rgba(200,241,53,0.55), rgba(200,241,53,0.10), transparent); }
.prp-header { display: flex; align-items: center; gap: 10px; padding: 20px 28px 14px; border-bottom: 1px solid rgba(200,241,53,0.10); }
.prp-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 8px rgba(200,241,53,0.5); flex-shrink: 0; }
.prp-label { font-family: var(--font-display); font-size: 0.5625rem; font-weight: 700; letter-spacing: 0.20em; text-transform: uppercase; color: rgba(200,241,53,0.72); }
.prp-body { padding: 22px 28px 24px; display: flex; flex-direction: column; gap: 10px; }
.prp-lead { font-family: var(--font-body); font-size: 0.9375rem; font-weight: 500; color: rgba(255,255,255,0.88); line-height: 1.60; margin: 0; }
.prp-sub { font-family: var(--font-body); font-size: 0.9375rem; color: rgba(255,255,255,0.75); line-height: 1.60; margin: 0; }
.prp-downstream { font-family: var(--font-body); font-size: 0.875rem; color: rgba(255,255,255,0.55); line-height: 1.5; margin: 4px 0 2px; }
.prp-impacts { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.prp-impacts li { font-family: var(--font-body); font-size: 0.875rem; color: rgba(255,255,255,0.78); line-height: 1.55; padding-left: 18px; position: relative; }
.prp-impacts li::before { content: '•'; position: absolute; left: 0; color: rgba(200,241,53,0.50); font-size: 0.875rem; }
.prp-financial { display: flex; flex-direction: column; gap: 4px; background: rgba(200,241,53,0.05); border: 1px solid rgba(200,241,53,0.16); border-radius: var(--r-lg); padding: 16px 18px; margin-top: 6px; }
.prp-fin-label { font-family: var(--font-display); font-size: 0.625rem; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(255,255,255,0.45); }
.prp-fin-value { font-family: var(--font-display); font-size: 1.5rem; font-weight: 800; letter-spacing: -0.028em; color: #c8f135; text-shadow: 0 0 18px rgba(200,241,53,0.35); }
.prp-note { font-family: var(--font-body); font-size: 0.75rem; color: rgba(255,255,255,0.32); line-height: 1.55; margin: 6px 0 0; font-style: italic; }
.prp-live { font-family: var(--font-body); font-size: 0.75rem; font-weight: 500; color: rgba(200,241,53,0.40); line-height: 1.5; margin: 0; }
.pr-delta { margin-bottom: 44px; }
.pr-delta-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; margin-bottom: 12px; }
.pr-delta-item { background: rgba(255,255,255,0.025); border: 1px solid rgba(255,255,255,0.07); border-radius: var(--r-lg); padding: 18px 16px; display: flex; flex-direction: column; gap: 6px; animation: stepFadeUp 0.4s both; }
.pdi-label { font-family: var(--font-display); font-size: 0.5625rem; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(255,255,255,0.28); }
.pdi-change { font-family: var(--font-display); font-size: 1.125rem; font-weight: 700; letter-spacing: -0.024em; }
.pdi-change.up { color: rgba(251,146,60,0.90); }
.pdi-change.down { color: rgba(74,222,128,0.90); }
.pdi-desc { font-family: var(--font-body); font-size: 0.75rem; color: rgba(255,255,255,0.42); line-height: 1.50; }
.pr-delta-note { font-family: var(--font-body); font-size: 0.75rem; color: rgba(255,255,255,0.22); line-height: 1.55; font-style: italic; text-align: center; }
.pilot-results-footer { display: flex; justify-content: center; padding: 12px 0 32px; }
.pilot-expand-inner { display: flex; flex-direction: column; align-items: center; text-align: center; max-width: 880px; position: relative; z-index: 2; }
.pilot-expand-title { font-family: var(--font-display); font-size: clamp(2rem,4vw,3.5rem); font-weight: 800; letter-spacing: -0.042em; line-height: 1.07; color: var(--text); margin-bottom: 18px; margin-top: 20px; }
.pilot-expand-sub { font-family: var(--font-body); font-size: clamp(0.9375rem,1.3vw,1.0625rem); font-weight: 400; color: rgba(255,255,255,0.52); line-height: 1.68; max-width: 52ch; margin-bottom: 56px; }
.pilot-expand-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; width: 100%; margin-bottom: 48px; text-align: left; }
.pilot-expand-card { background: rgba(255,255,255,0.025); border: 1px solid rgba(255,255,255,0.08); border-radius: var(--r-xl); padding: 36px 32px; display: flex; flex-direction: column; gap: 14px; transition: border-color 0.2s ease, background 0.2s ease; }
.pilot-expand-card:hover { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.14); }
.pilot-expand-card--primary { border-color: rgba(200,241,53,0.18); background: rgba(200,241,53,0.03); }
.pilot-expand-card--primary:hover { border-color: rgba(200,241,53,0.28); background: rgba(200,241,53,0.05); }
.pec-eyebrow { font-family: var(--font-display); font-size: 0.5625rem; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(200,241,53,0.55); }
.pec-title { font-family: var(--font-display); font-size: 1.125rem; font-weight: 700; letter-spacing: -0.022em; line-height: 1.22; color: var(--text); }
.pec-body { font-family: var(--font-body); font-size: 0.9rem; color: rgba(255,255,255,0.55); line-height: 1.65; margin: 0; }
.pec-includes { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.pec-includes li { font-family: var(--font-body); font-size: 0.8125rem; color: rgba(255,255,255,0.52); line-height: 1.5; padding-left: 18px; position: relative; }
.pec-includes li::before { content: '✓'; position: absolute; left: 0; color: rgba(200,241,53,0.55); font-size: 0.75rem; top: 1px; }
.pec-cta { margin-top: auto; }
.pec-note { font-family: var(--font-body); font-size: 0.75rem; color: rgba(255,255,255,0.25); margin: 0; line-height: 1.5; }
.pilot-expand-login { display: flex; align-items: center; gap: 10px; }
.pilot-expand-login p { font-family: var(--font-body); font-size: 0.875rem; color: rgba(255,255,255,0.30); margin: 0; }
.pilot-login-link { font-family: var(--font-body); font-size: 0.875rem; font-weight: 500; color: rgba(200,241,53,0.60); text-decoration: none; transition: color 0.18s ease; }
.pilot-login-link:hover { color: rgba(200,241,53,0.90); }
@media (max-width: 768px) {
  .pilot-step--entry, .pilot-step--expand { padding: 60px 20px; }
  .pilot-step--context, .pilot-step--signals, .pilot-step--results { padding: 48px 20px 60px; }
  .pr-score-card { flex-direction: column; align-items: flex-start; padding: 28px 24px; }
  .pr-score-ring-wrap { align-self: flex-end; }
  .pilot-expand-grid { grid-template-columns: 1fr; }
  .pr-delta-grid { grid-template-columns: 1fr 1fr; }
  .pilot-scale { gap: 4px; }
  .ps-btn { min-width: 60px; height: 38px; }
  .ps-label { font-size: 0.6875rem; }
  .pilot-prompt { padding: 22px 20px; }
}
@media (max-width: 480px) {
  .pilot-chip-row { gap: 6px; }
  .pilot-chip { height: 36px; padding: 0 14px; font-size: 0.8125rem; }
  .pr-delta-grid { grid-template-columns: 1fr; }
  .pilot-expand-login { flex-direction: column; gap: 6px; text-align: center; }
}
/* ═══════════════════════════════════════════════════════════════
   EMAIL GATE
═══════════════════════════════════════════════════════════════ */
.pilot-email-gate {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 60vh;
  padding: 40px 0 60px;
  animation: stepFadeUp 0.45s cubic-bezier(0.22, 0, 0.12, 1) both;
}
.peg-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  max-width: 520px;
  width: 100%;
}
.peg-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(200,241,53,0.07);
  border: 1px solid rgba(200,241,53,0.18);
  border-radius: 100px;
  padding: 6px 16px;
  margin-bottom: 28px;
}
.peg-title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 3.5vw, 2.5rem);
  font-weight: 800;
  letter-spacing: -0.034em;
  line-height: 1.12;
  color: var(--text);
  margin-bottom: 14px;
}
.peg-sub {
  font-family: var(--font-body);
  font-size: 1rem;
  color: rgba(255,255,255,0.50);
  line-height: 1.65;
  max-width: 40ch;
  margin-bottom: 36px;
}
.peg-form {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: center;
}
.peg-field-row {
  width: 100%;
  display: flex;
  gap: 10px;
}
.peg-input {
  flex: 1;
  height: 52px;
  padding: 0 18px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 6px;
  font-family: var(--font-body);
  font-size: 0.9375rem;
  color: var(--text);
  outline: none;
  transition: border-color 0.18s ease, background 0.18s ease;
  width: 100%;
}
.peg-input::placeholder { color: rgba(255,255,255,0.28); }
.peg-input:focus {
  border-color: rgba(200,241,53,0.45);
  background: rgba(255,255,255,0.07);
}
.peg-error {
  font-family: var(--font-body);
  font-size: 0.8125rem;
  color: rgba(255,100,100,0.85);
  margin: -4px 0 0;
}
.peg-submit {
  width: 100%;
  height: 58px;
  font-size: 1rem;
  justify-content: center;
  margin-top: 4px;
}
.peg-privacy {
  font-family: var(--font-body);
  font-size: 0.75rem;
  color: rgba(255,255,255,0.24);
  margin-top: 4px;
}

/* ═══════════════════════════════════════════════════════════════
   SIGNAL SCALE BUTTONS (ps-btn)
═══════════════════════════════════════════════════════════════ */
.pilot-scale {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 16px;
}

.ps-btn {
  flex: 1 1 auto;
  min-width: 0;
  padding: 10px 12px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.18s ease, border-color 0.18s ease;
  text-align: center;
  white-space: nowrap;
}

.ps-btn:hover {
  background: rgba(200,241,53,0.08);
  border-color: rgba(200,241,53,0.30);
}

.ps-btn.is-selected {
  background: rgba(200,241,53,0.12);
  border-color: rgba(200,241,53,0.55);
}

.ps-label {
  font-family: var(--font-body);
  font-size: 0.8125rem;
  font-weight: 500;
  color: rgba(255,255,255,0.70);
  line-height: 1;
  display: block;
}

.ps-btn.is-selected .ps-label {
  color: var(--accent);
}

@media (max-width: 768px) {
  .pilot-scale { gap: 6px; }
  .ps-btn { flex: 1 1 calc(33% - 6px); padding: 10px 8px; }
  .ps-label { font-size: 0.75rem; }
}
