/* ============================================================
   REPORT FEATURE (screen 8)  ·  v4 "THE ISSUED DOCUMENT"
   Clinical summary through to the order CTA. Includes the formulation
   cards and confidence ring, which only ever render inside this screen.

   v4 EVOLUTION: the report now reads as *issued by an intelligent
   system* — a warm-lit header, sections that rise and settle in
   sequence (choreography lives in base.css via .screen.active), and
   every surface a lit card rather than a flat fill. The confidence
   ring and gauge geometry are preserved; only their light changes.
   ============================================================ */
#s8 { background: var(--ink); flex-direction: column; }

.report-header {
  position: relative;
  background: var(--obsidian); color: var(--snow); padding: calc(28px + var(--sat)) 24px 22px;
  border-bottom: 1px solid var(--hairline);
  box-shadow: inset 0 -1px 0 rgba(247,242,230,0.04);
}
.report-header::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(120% 120% at 80% -10%, rgba(196,154,74,.12), transparent 55%);
}
.report-meta { position: relative; display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 16px; }
.report-id { font-family: var(--ff-mono); font-size: 10px; letter-spacing: .08em; color: var(--mist-dim); }
.report-stamp { font-family: var(--ff-mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--gold-bright); font-weight: 600; display: inline-flex; align-items: center; gap: 6px; }
.report-stamp::before { content: ''; width: 5px; height: 5px; border-radius: 50%; background: var(--gold-bright); box-shadow: 0 0 8px rgba(221,184,104,.9); }
.report-title { position: relative; font-family: var(--ff-display); font-size: clamp(24px, 6.4vw, 32px); font-weight: 800; color: var(--snow); line-height: 1.2; letter-spacing: -0.01em; margin-bottom: 8px; }
.report-by { position: relative; font-family: var(--ff-mono); font-size: 10px; letter-spacing: .06em; text-transform: uppercase; color: var(--gold-bright); display: flex; align-items: center; gap: 6px; }
.report-by span { color: var(--gold-bright); font-weight: 600; }

.report-body { flex: 1; overflow-y: auto; -webkit-overflow-scrolling: touch; padding: 4px 22px calc(20px + var(--sab)); background: var(--ink); display: flex; flex-direction: column; gap: 16px; }

.r-section { margin-top: 16px; }
.r-section:first-child { margin-top: 16px; }

.r-block { background: var(--ink-raised); border: 1px solid var(--hairline); border-radius: var(--r-lg); padding: 18px 18px; box-shadow: var(--lift-1); }

.r-block-head { margin-bottom: 14px; }
.r-block-label { font-family: var(--ff-display); font-size: var(--fs-md); font-weight: 800; color: var(--snow); letter-spacing: -0.005em; }
.r-block-sub { font-size: var(--fs-xs); color: var(--mist-dim); margin-top: 3px; }

.diagnosis-opening { font-family: var(--ff-body); font-size: var(--fs-md); font-weight: 500; color: var(--snow); line-height: 1.65; margin-bottom: 16px; }
.diagnosis-opening .hi { font-weight: 800; color: var(--snow); background: var(--gold-soft); border-radius: 3px; padding: 1px 6px; box-shadow: inset 0 0 0 1px rgba(196,154,74,.2); }
.diagnosis-why-failed {
  font-size: var(--fs-sm); color: var(--mist); line-height: 1.75;
  padding: 13px 14px; background: rgba(201,132,122,0.07); border: 1px solid rgba(201,132,122,0.18); border-radius: var(--r-sm);
}
.diagnosis-why-failed strong { color: var(--snow); }

.ing-list { display: flex; flex-direction: column; }
.ing-item { display: flex; gap: 14px; align-items: flex-start; padding: 14px 0; border-top: 1px solid var(--hairline); }
.ing-list .ing-item:first-child { border-top: none; padding-top: 0; }
.ing-code { font-family: var(--ff-mono); font-size: 10.5px; font-weight: 600; color: var(--gold-bright); white-space: nowrap; flex-shrink: 0; margin-top: 2px; min-width: 88px; }
.ing-info { flex: 1; min-width: 0; }
.ing-name { font-size: var(--fs-sm); font-weight: 700; color: var(--snow); margin-bottom: 4px; }
.ing-why  { font-size: var(--fs-xs); color: var(--mist); line-height: 1.55; }
.ing-gap  { font-size: var(--fs-xs); color: var(--gold-bright); margin-top: 4px; font-weight: 500; }

.insight-box { background: var(--grad-gold-soft); border: 1px solid var(--hairline-strong); border-radius: var(--r-lg); padding: 18px; position: relative; box-shadow: var(--edge-light), var(--shadow-1); overflow: hidden; }
.insight-box::before {
  content: '"'; position: absolute; right: 14px; top: 2px; font-family: var(--ff-display);
  font-size: 46px; font-weight: 800; color: var(--gold); opacity: .4; line-height: 1;
}
[dir="ltr"] .insight-box::before { right: auto; left: 14px; }
.insight-label { font-family: var(--ff-mono); font-size: 10px; letter-spacing: .08em; color: var(--gold-bright); font-weight: 600; text-transform: uppercase; margin-bottom: 9px; position: relative; z-index: 1; }
.insight-text { font-size: var(--fs-sm); color: var(--mist); line-height: 1.75; position: relative; z-index: 1; }

.protocol-list { display: flex; flex-direction: column; }
.protocol-row { display: flex; align-items: flex-start; gap: 11px; padding: 9px 0; border-top: 1px solid var(--hairline); }
.protocol-list .protocol-row:first-child { border-top: none; padding-top: 0; }
.protocol-check { font-family: var(--ff-mono); font-size: 13px; color: var(--gold-bright); font-weight: 700; flex-shrink: 0; line-height: 1.5; }
.protocol-text { font-size: var(--fs-sm); color: var(--mist); line-height: 1.55; }

.outcome-timeline { display: flex; flex-direction: column; }
.timeline-row { display: flex; gap: 16px; align-items: flex-start; padding: 11px 0; border-top: 1px solid var(--hairline); }
.outcome-timeline .timeline-row:first-child { border-top: none; padding-top: 0; }
.tl-marker { width: 42px; flex-shrink: 0; }
.tl-days { font-family: var(--ff-mono); font-size: var(--fs-sm); font-weight: 700; color: var(--gold-bright); letter-spacing: .02em; }
.tl-label { font-size: 9px; color: var(--mist-dim); font-family: var(--ff-mono); }
.tl-text { font-size: var(--fs-sm); color: var(--mist); line-height: 1.55; padding-top: 2px; }

.urgency-signal { background: rgba(201,132,122,0.08); border: 1px solid rgba(201,132,122,0.3); border-radius: var(--r-lg); padding: 16px 18px; box-shadow: var(--edge-light), var(--shadow-1); }
.urg-kicker { font-family: var(--ff-mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--rose); font-weight: 700; margin-bottom: 7px; }
.urg-text { font-size: var(--fs-sm); color: var(--mist); line-height: 1.65; }
.urg-text strong { color: var(--rose); }

.dr-card { background: var(--ink-raised); border: 1px solid var(--hairline); border-radius: var(--r-lg); padding: 18px; display: flex; gap: 14px; align-items: flex-start; box-shadow: var(--lift-1); }
.dr-avatar { width: 40px; height: 40px; border-radius: var(--r-md); background: var(--grad-gold-soft); border: 1px solid var(--hairline-strong); color: var(--gold-bright); display: flex; align-items: center; justify-content: center; font-family: var(--ff-latin-display); font-weight: 800; font-size: 16px; flex-shrink: 0; box-shadow: var(--edge-light); }
.dr-info { flex: 1; min-width: 0; }
.dr-name { font-size: var(--fs-base); font-weight: 700; color: var(--snow); margin-bottom: 3px; }
.dr-title { font-size: var(--fs-xs); color: var(--mist-dim); margin-bottom: 9px; }
.dr-note { font-size: var(--fs-sm); color: var(--mist); line-height: 1.65; }
.dr-note::before { content: '"'; }
.dr-note::after  { content: '"'; }

.formulation-list { display: flex; flex-direction: column; gap: 10px; }
.formulation-card { background: var(--ink-raised-2); border: 1px solid var(--hairline); border-radius: var(--r-md); padding: 13px 14px; box-shadow: var(--lift-1); transition: transform .3s var(--ease-out), box-shadow .3s var(--ease-out); }
@media (pointer: fine) { .formulation-card:hover { transform: translateY(-2px); box-shadow: var(--lift-2); } }
.formulation-top { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 5px; }
.formulation-name { font-size: var(--fs-sm); font-weight: 700; color: var(--snow); }
.formulation-when { font-family: var(--ff-mono); font-size: 9px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; color: var(--gold-bright); background: var(--gold-soft); border-radius: var(--r-sm); padding: 3px 7px; flex-shrink: 0; white-space: nowrap; box-shadow: inset 0 0 0 1px rgba(196,154,74,.18); }
.formulation-role { font-size: var(--fs-xs); color: var(--mist); line-height: 1.55; }

.timeline-row { opacity: 0; transform: translateY(8px); animation: faMetricIn .45s var(--ease-out) forwards; }
.timeline-row:nth-child(1) { animation-delay: .05s; }
.timeline-row:nth-child(2) { animation-delay: .15s; }
.timeline-row:nth-child(3) { animation-delay: .25s; }
.timeline-row:nth-child(4) { animation-delay: .35s; }
@media (prefers-reduced-motion: reduce) { .timeline-row { animation: none; opacity: 1; transform: none; } }

.confidence-display { display: flex; align-items: center; gap: 16px; }
.confidence-ring { position: relative; width: 64px; height: 64px; flex-shrink: 0; }
.confidence-ring::before { content: ''; position: absolute; inset: 6px; border-radius: 50%; background: radial-gradient(circle, rgba(221,184,104,.14), transparent 70%); }
.confidence-ring svg { width: 100%; height: 100%; transform: rotate(-90deg); position: relative; }
.confidence-ring-track { fill: none; stroke: var(--hairline-strong); stroke-width: 5; }
.confidence-ring-fill { fill: none; stroke: var(--gold); stroke-width: 5; stroke-linecap: round; filter: drop-shadow(0 0 4px rgba(221,184,104,.5)); }
.confidence-number { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-family: var(--ff-mono); font-size: 15px; font-weight: 700; color: var(--snow); }
.confidence-text { flex: 1; }
.confidence-label { font-size: var(--fs-sm); font-weight: 700; color: var(--snow); margin-bottom: 3px; }
.confidence-note { font-size: var(--fs-xs); color: var(--mist-dim); line-height: 1.55; }

.improvement-stages { display: flex; flex-direction: column; }
.improvement-stage { display: flex; gap: 14px; padding: 12px 0; border-top: 1px solid var(--hairline); }
.improvement-stages .improvement-stage:first-child { border-top: none; padding-top: 0; }
.improvement-stage-marker { width: 8px; height: 8px; border-radius: 50%; background: var(--gold); flex-shrink: 0; margin-top: 6px; box-shadow: 0 0 8px rgba(221,184,104,.6); }
.improvement-stage-label { font-family: var(--ff-mono); font-size: 9.5px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--gold-bright); margin-bottom: 4px; }
.improvement-stage-text { font-size: var(--fs-sm); color: var(--mist); line-height: 1.6; }
.improvement-disclaimer { font-size: 11px; color: var(--mist-dim); line-height: 1.6; margin-top: 14px; padding-top: 12px; border-top: 1px solid var(--hairline); }

.results-cta-section { padding: 6px 0 calc(10px + var(--sab)); }
.results-trust-line { text-align: center; margin-top: 12px; font-size: var(--fs-xs); color: var(--mist-dim); }
.btn-get-protocol { padding: 18px 22px; font-size: var(--fs-md); }
