/* ============================================================
   .aqc-cinema — Advanced Quoting Cinema
   Four-scene scroll-driven walkthrough that emphasizes the
   ADVANCED-QUOTING differentiator: multi-part CAD assemblies.

   Acts:
     01  Upload     — assembly file lands, geometry tools tick through
     02  Explode    — CAD viewer breaks the assembly into per-part lines
     03  Route      — parts route through machine ops with run rates
     04  Quote      — assembly-level quote with per-part subtotals

   Shares the .scc-* shell vocabulary with fab-quote-cinema.css
   so the cinemas read as sister components, but the *scene art*
   is intentionally different — the fab-sales walkthrough is a
   buyer self-serving on a single DXF; this is an estimator
   working on a 28-part assembly.
   ============================================================ */

/* ---------- Sticky-scroll runway (shared shell) ---------- */
.scc-runway {
  position: relative;
  --scc-runway-vh: 3.6;
  --scc-sticky-top: 96px;
  height: calc(var(--scc-runway-vh) * 100vh);
  margin-top: 1rem;
}
.scc-runway > .aqc-cinema {
  position: sticky;
  top: var(--scc-sticky-top);
}
.scc-figure { display: block; margin-top: 40px; }

/* ---------- Outer panel ---------- */
.aqc-cinema {
  --aqc-mono: ui-monospace, "SFMono-Regular", Menlo, Monaco, Consolas, monospace;
  --aqc-accent: var(--ss-primary-blue);
  --aqc-pop: var(--ss-orange);

  position: relative;
  display: grid;
  grid-template-columns: minmax(260px, 0.82fr) minmax(0, 1.5fr);
  gap: 48px;
  align-items: stretch;
  min-height: 620px;
  font-family: var(--font-sans);
  color: var(--ss-charcoal);
}

/* ---------- LEFT — narrative column ---------- */
.aqc-cinema .scc-narrative {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 1.5rem;
  min-width: 0;
}
.aqc-cinema .scc-pips {
  display: flex; flex-direction: column; gap: 10px;
  margin-top: 4px;
}
.aqc-cinema .scc-pip {
  display: grid; grid-template-columns: 28px 1fr;
  align-items: center; gap: 12px;
  font-family: var(--font-sans);
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ss-smoke);
  transition: color 0.2s ease-out;
}
.aqc-cinema .scc-pip.is-active { color: var(--ss-primary-blue); }
.aqc-cinema .scc-pip.is-past   { color: var(--ss-shadow); }
.aqc-cinema .scc-pip-num { font-variant-numeric: tabular-nums; }
.aqc-cinema .scc-pip-bar {
  display: block; height: 2px;
  background: var(--ss-light-gray);
  border-radius: 1px;
  overflow: hidden;
  position: relative;
}
.aqc-cinema .scc-pip-bar > span {
  display: block; height: 100%;
  width: 0;
  background: var(--ss-primary-blue);
  transition: width 0.2s ease-out;
}
.aqc-cinema .scc-narrative-stack {
  position: relative; flex: 1;
  display: flex; align-items: center;
  min-height: 320px;
}
.aqc-cinema .scc-chapter {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  justify-content: center;
  gap: 14px;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.2s ease-out, transform 0.2s ease-out;
  will-change: opacity, transform;
  pointer-events: none;
}
.aqc-cinema .scc-chapter.is-active {
  opacity: 1; transform: translateY(0);
  pointer-events: auto;
}
.aqc-cinema .scc-chapter-eyebrow {
  font-family: var(--font-sans);
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ss-primary-blue);
}
.aqc-cinema .scc-chapter-title {
  font-family: var(--font-sans);
  font-size: clamp(22px, 1.4rem + 0.8vw, 30px);
  font-weight: 800; line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--ss-dark-navy);
  margin: 0; text-wrap: pretty;
}
.aqc-cinema .scc-chapter-body {
  font-size: 15px; line-height: 1.55;
  color: var(--ss-charcoal);
  margin: 0; max-width: 38ch; text-wrap: pretty;
}
.aqc-cinema .scc-chapter-stat {
  display: flex; flex-direction: column; gap: 2px;
  margin-top: 8px; padding-top: 14px;
  border-top: 1px solid var(--ss-light-gray);
}
.aqc-cinema .scc-chapter-stat-num {
  font-family: var(--font-sans);
  font-size: 24px; font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--ss-dark-navy);
  font-variant-numeric: tabular-nums;
}
.aqc-cinema .scc-chapter-stat-label {
  font-family: var(--font-sans);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ss-shadow);
}
.aqc-cinema .scc-scroll-hint {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--font-sans);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ss-smoke);
}
.aqc-cinema .scc-scroll-hint-line {
  width: 30px; height: 1px;
  background: var(--ss-medium-gray);
}

/* ---------- RIGHT — scene column (white mock card) ---------- */
.aqc-cinema .scc-scenecol {
  position: relative;
  background: #fff;
  border-radius: 14px;
  border: 1px solid rgba(31, 65, 104, 0.10);
  box-shadow:
    0 30px 80px -30px rgba(31, 65, 104, 0.35),
    0 8px 24px rgba(31, 65, 104, 0.08);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  isolation: isolate;
}
.aqc-cinema .scc-chrome {
  background: var(--ss-light-blue);
  padding: 10px 16px;
  display: flex; align-items: center; gap: 10px;
  border-bottom: 1px solid rgba(31, 65, 104, 0.08);
  flex-shrink: 0;
}
.aqc-cinema .scc-chrome-dots { display: inline-flex; gap: 6px; }
.aqc-cinema .scc-chrome-dots > span {
  width: 9px; height: 9px;
  border-radius: 999px;
  background: #C6D0E1;
}
.aqc-cinema .scc-chrome-url {
  background: #fff;
  border-radius: 999px;
  padding: 4px 12px;
  font-family: var(--font-sans);
  font-size: 11px; font-weight: 600;
  color: var(--ss-primary-blue);
  display: inline-flex; align-items: center; gap: 6px;
  max-width: 380px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.aqc-cinema .scc-chrome-url i { font-size: 11px; }

/* Scene frame */
.aqc-cinema .scc-scene-frame {
  position: relative;
  flex: 1;
  min-height: 560px;
}
.aqc-cinema .scc-scene-wrap {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  opacity: 0;
  transition: opacity 0.2s ease-out;
  pointer-events: none;
}
.aqc-cinema .scc-scene-wrap.is-active {
  opacity: 1; pointer-events: auto;
}
.aqc-cinema .scc-scene {
  position: absolute; inset: 0;
  padding: 22px 24px;
  display: flex;
  flex-direction: column;
  min-height: 0;
}

/* ============================================================
   SCENE 1 — Upload (multi-part assembly arrives)
   ============================================================ */
.aqc-upload-head {
  display: flex; flex-direction: column; gap: 6px;
  margin-bottom: 14px;
}
.aqc-upload-crumb {
  display: inline-flex; gap: 6px;
  font-family: var(--font-sans);
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ss-smoke);
}
.aqc-upload-crumb .sep { color: var(--ss-medium-gray); }
.aqc-upload-crumb .now { color: var(--ss-primary-blue); }
.aqc-upload-head h3 {
  font-family: var(--font-sans);
  font-size: 22px; font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--ss-dark-navy);
  margin: 2px 0 0; line-height: 1.15;
}
.aqc-upload-head p {
  margin: 0; font-size: 14px; line-height: 1.5;
  color: var(--ss-charcoal);
}

.aqc-upload-grid {
  flex: 1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr);
  gap: 14px;
  min-height: 0;
}

/* File card (left) */
.aqc-upload-file {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 18px;
  border: 1px dashed var(--ss-primary-blue);
  border-radius: 6px;
  background: var(--ss-pale-blue);
}
.aqc-upload-file-head {
  display: flex; align-items: center; gap: 10px;
}
.aqc-upload-file-icon {
  width: 36px; height: 36px;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 18px;
  color: var(--ss-primary-blue);
  background: #fff;
  border-radius: 5px;
  border: 1px solid rgba(51, 109, 174, 0.25);
}
.aqc-upload-file-info { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.aqc-upload-file-name {
  font-family: var(--aqc-mono);
  font-size: 13px; font-weight: 700;
  color: var(--ss-dark-navy);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.aqc-upload-file-meta {
  font-family: var(--aqc-mono);
  font-size: 10px; color: var(--ss-shadow);
}

.aqc-upload-bar {
  display: block;
  width: 100%; height: 4px;
  background: rgba(51, 109, 174, 0.18);
  border-radius: 2px;
  overflow: hidden;
}
.aqc-upload-bar-fill {
  display: block; width: 100%; height: 100%;
  background: var(--ss-primary-blue);
  transform: scaleX(0);
  transform-origin: left center;
}

.aqc-upload-tags {
  display: flex; flex-wrap: wrap; gap: 5px;
  padding-top: 6px;
  border-top: 1px solid rgba(51, 109, 174, 0.20);
}
.aqc-upload-tags span {
  display: inline-block;
  padding: 2px 7px;
  font-family: var(--aqc-mono);
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--ss-shadow);
  background: #fff;
  border: 1px solid rgba(51, 109, 174, 0.15);
  border-radius: 3px;
}

.aqc-upload-tags-label {
  font-family: var(--font-sans);
  font-size: 9px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ss-shadow);
  margin-top: 4px;
}

/* Geometry-tools status list (right) */
.aqc-upload-steps {
  list-style: none; margin: 0; padding: 14px 16px;
  background: #fff;
  border: 1px solid var(--ss-light-gray);
  border-radius: 6px;
  display: flex; flex-direction: column; gap: 8px;
}
.aqc-upload-steps-head {
  display: flex; align-items: baseline; justify-content: space-between;
  padding-bottom: 8px; margin-bottom: 4px;
  border-bottom: 1px solid var(--ss-light-gray);
  font-family: var(--font-sans);
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ss-shadow);
}
.aqc-upload-steps-head strong {
  color: var(--ss-primary-blue);
  font-weight: 700;
}
.aqc-upload-step {
  display: grid;
  grid-template-columns: 20px 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 7px 8px;
  border-radius: 4px;
  font-family: var(--aqc-mono);
  font-size: 11px;
  color: var(--ss-shadow);
  background: transparent;
  transition: background 0.2s ease-out, color 0.2s ease-out;
}
.aqc-upload-step .check {
  width: 18px; height: 18px;
  border-radius: 999px;
  background: var(--ss-light-gray);
  display: inline-flex; align-items: center; justify-content: center;
  color: transparent;
  font-size: 11px;
  transition: background 0.2s ease-out, color 0.2s ease-out;
}
.aqc-upload-step .step-count {
  font-family: var(--font-sans);
  font-size: 11px; font-weight: 700;
  color: var(--ss-smoke);
  font-variant-numeric: tabular-nums;
}
.aqc-upload-step.is-done {
  background: var(--ss-pale-blue);
  color: var(--ss-dark-navy);
}
.aqc-upload-step.is-done .check {
  background: var(--ss-primary-blue);
  color: #fff;
}
.aqc-upload-step.is-done .step-count {
  color: var(--ss-primary-blue);
}

/* ============================================================
   SCENE 2 — Explode (CAD viewer decomposes assembly)
   ============================================================ */
.aqc-explode {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
}
.aqc-explode-head {
  display: flex; align-items: baseline; justify-content: space-between;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--ss-light-gray);
  margin-bottom: 12px;
  font-family: var(--aqc-mono);
  font-size: 11px;
  color: var(--ss-shadow);
}
.aqc-explode-crumb { color: var(--ss-dark-navy); font-weight: 600; }
.aqc-explode-status {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--ss-primary-blue);
  font-weight: 600;
}
.aqc-blink {
  width: 6px; height: 6px;
  border-radius: 999px;
  background: var(--ss-primary-blue);
  animation: aqc-blink 1.4s ease-in-out infinite;
}
@keyframes aqc-blink {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.25; }
}

.aqc-explode-body {
  flex: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  gap: 12px;
  min-height: 0;
}

/* CAD viewer (left) */
.aqc-explode-viewer {
  position: relative;
  margin: 0;
  display: flex;
  flex-direction: column;
  background:
    repeating-linear-gradient(0deg, rgba(31,65,104,0.05) 0 1px, transparent 1px 22px),
    repeating-linear-gradient(90deg, rgba(31,65,104,0.05) 0 1px, transparent 1px 22px),
    var(--ss-pale-gray);
  border: 1px solid var(--ss-light-gray);
  border-radius: 5px;
  overflow: hidden;
}
.aqc-explode-viewer-cad {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 0;
}
.aqc-explode-viewer-cad svg {
  width: 100%; height: 100%;
  max-height: 100%;
  display: block;
}
.aqc-explode-part-svg { transition: transform 0.35s ease-out, opacity 0.25s ease-out; }
.aqc-explode-tags {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.aqc-explode-corners span {
  position: absolute;
  width: 10px; height: 10px;
  border: 1.5px solid var(--ss-shadow);
}
.aqc-explode-corners span:nth-child(1) { top: 8px; left: 8px; border-right: none; border-bottom: none; }
.aqc-explode-corners span:nth-child(2) { top: 8px; right: 8px; border-left: none; border-bottom: none; }
.aqc-explode-corners span:nth-child(3) { bottom: 8px; left: 8px; border-right: none; border-top: none; }
.aqc-explode-corners span:nth-child(4) { bottom: 8px; right: 8px; border-left: none; border-top: none; }
.aqc-explode-viewer-caption {
  display: flex; justify-content: space-between;
  padding: 8px 12px;
  border-top: 1px solid var(--ss-light-gray);
  background: #fff;
  font-family: var(--aqc-mono);
  font-size: 10px;
  color: var(--ss-shadow);
}

/* Parts list (right) */
.aqc-explode-parts {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-direction: column;
  background: #fff;
  border: 1px solid var(--ss-light-gray);
  border-radius: 5px;
  overflow: hidden;
}
.aqc-explode-parts-head {
  display: grid;
  grid-template-columns: 28px 1fr 56px 36px;
  align-items: baseline;
  gap: 8px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--ss-light-gray);
  font-family: var(--font-sans);
  font-size: 9px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ss-shadow);
}
.aqc-explode-parts-head span:nth-child(4) { text-align: right; }
.aqc-explode-parts-body {
  list-style: none; margin: 0; padding: 4px 0;
  flex: 1;
  display: flex; flex-direction: column;
}
.aqc-explode-parts-body > li {
  display: grid;
  grid-template-columns: 28px 1fr 56px 36px;
  align-items: baseline;
  gap: 8px;
  padding: 6px 14px;
  font-family: var(--aqc-mono);
  font-size: 11px;
  color: var(--ss-charcoal);
  font-variant-numeric: tabular-nums;
  opacity: 0;
  transform: translateX(8px);
  transition: opacity 0.18s ease-out, transform 0.22s ease-out, background 0.18s ease-out;
}
.aqc-explode-parts-body > li.is-on { opacity: 1; transform: translateX(0); }
.aqc-explode-parts-body > li:hover { background: var(--ss-pale-gray); }
.aqc-explode-parts-body .p-id {
  font-family: var(--font-sans);
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--ss-primary-blue);
  background: var(--ss-pale-blue);
  border-radius: 3px;
  padding: 1px 0;
  text-align: center;
}
.aqc-explode-parts-body .p-name { color: var(--ss-dark-navy); font-weight: 600; }
.aqc-explode-parts-body .p-mat { color: var(--ss-shadow); font-size: 10px; }
.aqc-explode-parts-body .p-qty { color: var(--ss-dark-navy); font-weight: 700; text-align: right; }

.aqc-explode-parts-foot {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 10px 14px;
  background: var(--ss-pale-gray);
  border-top: 1px solid var(--ss-light-gray);
  font-family: var(--font-sans);
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ss-shadow);
}
.aqc-explode-parts-foot strong {
  font-family: var(--font-sans);
  font-size: 14px; font-weight: 800;
  letter-spacing: -0.01em; text-transform: none;
  color: var(--ss-primary-blue);
  font-variant-numeric: tabular-nums;
}

/* ============================================================
   SCENE 3 — Route (per-op rates against tech tables)
   ============================================================ */
.aqc-route {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
}
.aqc-route-head {
  display: flex; align-items: baseline; justify-content: space-between;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--ss-light-gray);
  margin-bottom: 12px;
  font-family: var(--aqc-mono);
  font-size: 11px;
  color: var(--ss-shadow);
}
.aqc-route-head-title { color: var(--ss-dark-navy); font-weight: 600; }
.aqc-route-head-stamp {
  color: var(--ss-primary-blue); font-weight: 600;
  display: inline-flex; align-items: center; gap: 6px;
}

/* Mini nest sheets across top */
.aqc-route-sheets {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-bottom: 12px;
}
.aqc-route-sheet {
  background: var(--ss-pale-gray);
  border: 1px solid var(--ss-light-gray);
  border-radius: 5px;
  padding: 8px 10px;
  display: flex; flex-direction: column; gap: 6px;
}
.aqc-route-sheet-head {
  display: flex; justify-content: space-between; align-items: baseline;
  font-family: var(--font-sans);
  font-size: 9px; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ss-shadow);
}
.aqc-route-sheet-head .y { color: var(--ss-primary-blue); }
.aqc-route-sheet-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-template-rows: repeat(2, 1fr);
  gap: 2px;
  height: 36px;
}
.aqc-route-sheet-grid span {
  background: #fff;
  border: 1px solid var(--ss-light-gray);
  border-radius: 1.5px;
  opacity: 0.5;
  transition: opacity 0.2s ease-out, background 0.2s ease-out, border-color 0.2s ease-out;
}
.aqc-route-sheet-grid span.is-on {
  opacity: 1;
  background: var(--ss-pale-blue);
  border-color: var(--ss-primary-blue);
}

/* Routing pipeline (bottom) */
.aqc-route-pipeline-head {
  display: flex; align-items: baseline; justify-content: space-between;
  padding-bottom: 8px;
  margin-bottom: 8px;
  border-bottom: 1px solid var(--ss-light-gray);
  font-family: var(--font-sans);
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ss-shadow);
}

.aqc-route-pipeline {
  flex: 1;
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: 6px;
  min-height: 0;
}
.aqc-route-stage {
  display: grid;
  grid-template-columns: 24px 1.05fr 1.1fr auto auto;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  background: #fff;
  border: 1px solid var(--ss-light-gray);
  border-radius: 5px;
  font-family: var(--aqc-mono);
  font-size: 11px;
  color: var(--ss-charcoal);
  font-variant-numeric: tabular-nums;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity 0.2s ease-out, transform 0.22s ease-out, border-color 0.2s ease-out, background 0.2s ease-out;
}
.aqc-route-stage.is-on {
  opacity: 1; transform: translateY(0);
  border-color: rgba(51, 109, 174, 0.4);
  background: var(--ss-pale-blue);
}
.aqc-route-stage-num {
  font-family: var(--font-sans);
  font-size: 10px; font-weight: 700;
  color: var(--ss-smoke);
  text-align: center;
}
.aqc-route-stage.is-on .aqc-route-stage-num { color: var(--ss-primary-blue); }
.aqc-route-stage-op {
  font-family: var(--font-sans);
  font-size: 13px; font-weight: 700;
  color: var(--ss-dark-navy);
  letter-spacing: -0.01em;
}
.aqc-route-stage-rate {
  color: var(--ss-shadow);
  font-size: 11px;
}
.aqc-route-stage-rate b {
  color: var(--ss-dark-navy);
  font-weight: 700;
}
.aqc-route-stage-basis {
  color: var(--ss-shadow);
  font-size: 10px;
  text-align: right;
}
.aqc-route-stage-amount {
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 13px;
  color: var(--ss-dark-navy);
  text-align: right;
}
.aqc-route-stage.is-on .aqc-route-stage-amount { color: var(--ss-primary-blue); }

.aqc-route-total {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
  align-items: baseline;
  padding: 12px 14px;
  margin-top: 6px;
  background: var(--ss-dark-navy);
  border-radius: 5px;
  color: #fff;
}
.aqc-route-total-label {
  font-family: var(--font-sans);
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: rgba(255,255,255,0.7);
}
.aqc-route-total-num {
  font-family: var(--font-sans);
  font-size: 22px; font-weight: 800;
  letter-spacing: -0.02em;
  color: #fff;
  font-variant-numeric: tabular-nums;
}

/* ============================================================
   SCENE 4 — Quote (assembly quote, per-part BOM)
   ============================================================ */
.aqc-quote {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
}
.aqc-quote-frame {
  position: relative;
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
}
.aqc-quote-brand {
  display: flex; align-items: center; justify-content: space-between;
  padding-bottom: 12px;
  margin-bottom: 12px;
  border-bottom: 1px solid var(--ss-light-gray);
}
.aqc-quote-brand-name {
  font-family: var(--font-sans);
  font-size: 14px; font-weight: 800;
  letter-spacing: -0.005em;
  color: var(--ss-dark-navy);
}
.aqc-quote-live {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-sans);
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ss-orange);
}
.aqc-quote-live .aqc-blink { background: var(--ss-orange); }

.aqc-quote-eyebrow {
  display: block;
  font-family: var(--font-sans);
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ss-shadow);
  margin-bottom: 4px;
}
.aqc-quote-title {
  font-family: var(--font-sans);
  font-size: 22px; font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--ss-dark-navy);
  margin: 0 0 2px;
  line-height: 1.1;
}
.aqc-quote-for {
  margin: 0 0 12px;
  font-family: var(--aqc-mono);
  font-size: 11px;
  color: var(--ss-shadow);
}

.aqc-quote-amount {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 14px;
  align-items: center;
  padding: 12px 16px;
  background: var(--ss-pale-blue);
  border: 1px solid rgba(51, 109, 174, 0.20);
  border-radius: 5px;
  margin-bottom: 12px;
}
.aqc-quote-amount-label {
  display: block;
  font-family: var(--font-sans);
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ss-shadow);
  margin-bottom: 2px;
}
.aqc-quote-amount-num {
  font-family: var(--font-sans);
  font-size: 28px; font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--ss-primary-blue);
  font-variant-numeric: tabular-nums;
}
.aqc-quote-actions {
  display: flex; flex-direction: column; gap: 6px;
}
.aqc-quote-cta {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 5px;
  font-family: var(--font-sans);
  font-size: 12px; font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--ss-primary-blue);
  background: #fff;
  border: 1px solid var(--ss-primary-blue);
  white-space: nowrap;
}
.aqc-quote-cta--primary {
  background: var(--ss-orange);
  color: #fff;
  border-color: var(--ss-orange);
  transition: filter 0.15s ease-out, transform 0.15s ease-out;
}
.aqc-quote-cta--primary.is-press {
  filter: brightness(0.92);
  transform: translateY(1px);
}

/* BOM-style line items (per-part subtotals) */
.aqc-quote-bom {
  list-style: none; margin: 0; padding: 0;
  flex: 1;
  display: flex; flex-direction: column;
  min-height: 0;
}
.aqc-quote-bom-head {
  display: grid;
  grid-template-columns: 28px 1fr 44px 70px;
  align-items: baseline;
  gap: 10px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--ss-light-gray);
  font-family: var(--font-sans);
  font-size: 9px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ss-shadow);
}
.aqc-quote-bom-head span:nth-child(3),
.aqc-quote-bom-head span:nth-child(4) { text-align: right; }
.aqc-quote-bom-row {
  display: grid;
  grid-template-columns: 28px 1fr 44px 70px;
  align-items: baseline;
  gap: 10px;
  padding: 5px 0;
  border-bottom: 1px solid var(--ss-light-gray);
  font-family: var(--aqc-mono);
  font-size: 11px;
  color: var(--ss-charcoal);
  font-variant-numeric: tabular-nums;
}
.aqc-quote-bom-row:last-child { border-bottom: none; }
.aqc-quote-bom-id {
  font-family: var(--font-sans);
  font-size: 10px; font-weight: 700;
  color: var(--ss-primary-blue);
  background: var(--ss-pale-blue);
  border-radius: 3px;
  padding: 1px 0;
  text-align: center;
}
.aqc-quote-bom-name { color: var(--ss-dark-navy); font-weight: 600; }
.aqc-quote-bom-qty { color: var(--ss-shadow); text-align: right; font-size: 10px; }
.aqc-quote-bom-amt { color: var(--ss-dark-navy); font-weight: 700; text-align: right; }

.aqc-quote-note {
  margin: 10px 0 0;
  display: flex; align-items: center; gap: 8px;
  padding: 8px 10px;
  border-radius: 4px;
  background: var(--ss-success-bg, color-mix(in srgb, var(--ss-success-green) 8%, white));
  font-family: var(--font-sans);
  font-size: 11px; font-weight: 600;
  color: var(--ss-success-green);
}
.aqc-quote-note i { font-size: 14px; flex-shrink: 0; }

/* ---------- Responsive ---------- */
@media (max-width: 860px) {
  .scc-runway {
    --scc-runway-vh: 3.8;
    --scc-sticky-top: 84px;
  }
  .aqc-cinema {
    grid-template-columns: 1fr;
    gap: 24px;
    min-height: 0;
  }
  .aqc-cinema .scc-narrative-stack { min-height: 220px; }
  .aqc-cinema .scc-scene-frame { min-height: 580px; }
  .aqc-upload-grid { grid-template-columns: 1fr; }
  .aqc-explode-body { grid-template-columns: 1fr; }
  .aqc-route-sheets { grid-template-columns: 1fr; }
  .aqc-route-stage { grid-template-columns: 24px 1fr auto; gap: 8px; }
  .aqc-route-stage-rate,
  .aqc-route-stage-basis { display: none; }
  .aqc-quote-amount { grid-template-columns: 1fr; }
  .aqc-quote-actions { flex-direction: row; }
  .aqc-quote-actions .aqc-quote-cta { flex: 1; }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
  .aqc-cinema,
  .aqc-cinema * {
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
  }
  .aqc-explode-parts-body > li { opacity: 1 !important; transform: none !important; }
  .aqc-route-stage { opacity: 1 !important; transform: none !important; }
}
