/* ═══════════════════════════════════════════════════════════════
   INVENTORY PAGE — page-unique stage content + hero
   ═══════════════════════════════════════════════════════════════
   The act chassis lives in css/de-act.css (.de- classes) — never
   restyle it from here. Everything below is .i- prefixed page
   content: the hero, and the stage visuals inside each beat.
   Load order: style.css → de-act.css → inventory.css.
   ─────────────────────────────────────────────────────────────── */

:root {
  --i-bg: #000;
  --i-panel: #090b0c;
  --i-panel-2: #101415;
  --i-line: rgba(255, 255, 255, 0.09);
  --i-line-strong: rgba(255, 255, 255, 0.18);
  --i-text: #fff;
  --i-mid: rgba(255, 255, 255, 0.72);
  --i-dim: rgba(255, 255, 255, 0.44);
  --i-good: #4ade80;
  --i-good-dim: rgba(74, 222, 128, 0.12);
  --i-bad: #ee3a39;
  --i-bad-dim: rgba(238, 58, 57, 0.12);
  --i-font: 'Inter', sans-serif;
  --i-mono: 'JetBrains Mono', 'SF Mono', Menlo, monospace;
}

.inventory-page {
  background: var(--i-bg);
  color: var(--i-text);
  font-family: var(--i-font);
}

.i-mono {
  font-family: var(--i-mono);
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--i-dim);
}

.i-accent { color: var(--i-good); }

/* window chrome (mirrors marketing's .m-window treatment) */
.i-window {
  border: 1px solid var(--i-line-strong);
  border-radius: 16px;
  background: var(--i-panel);
  box-shadow: 0 30px 90px rgba(0, 0, 0, 0.6);
  overflow: hidden;
}

.i-window-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 14px;
  border-bottom: 1px solid var(--i-line);
  color: var(--i-dim);
  font: 600 0.68rem/1 var(--i-mono);
}

.i-window-bar span {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.2);
}

.i-window-bar em { margin-left: 8px; font-style: normal; }

/* ═══════════════════════════════════════════════════════════════
   HERO — copy left, auto-wiping before/after right
   ═══════════════════════════════════════════════════════════════ */
.i-hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  padding: calc(var(--nav-height, 72px) + 48px) 32px 80px;
  overflow: hidden;
}

.i-hero-bg { position: absolute; inset: 0; pointer-events: none; }

.i-hero-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.035) 1px, transparent 1px);
  background-size: 72px 72px;
  mask-image: radial-gradient(ellipse 90% 70% at 50% 40%, #000 30%, transparent 75%);
}

.i-hero-glow {
  position: absolute;
  top: 12%;
  right: -8%;
  width: 46vw;
  height: 46vw;
  background: radial-gradient(circle, rgba(74, 222, 128, 0.10) 0%, transparent 65%);
  filter: blur(40px);
}

.i-hero-inner {
  position: relative;
  width: min(1200px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(320px, 0.95fr) minmax(0, 1.05fr);
  gap: 56px;
  align-items: center;
}

.i-hero-copy h1 {
  margin: 0 0 20px;
  font-size: clamp(2.3rem, 4.4vw, 3.9rem);
  font-weight: 850;
  letter-spacing: -0.035em;
  line-height: 1.06;
}

.i-hero-copy p {
  margin: 0 0 30px;
  max-width: 34rem;
  font-size: 1.06rem;
  line-height: 1.6;
  color: var(--i-mid);
}

.i-hero-ctas {
  display: flex;
  align-items: center;
  gap: 22px;
  flex-wrap: wrap;
}

.i-hero-more {
  color: var(--i-dim);
  font: 600 0.8rem/1 var(--i-mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration: none;
  transition: color 0.3s ease;
}

.i-hero-more:hover { color: var(--i-text); }

/* before/after auto-wipe card */
.i-wipe {
  position: relative;
  border-radius: 18px;
  overflow: hidden;
  aspect-ratio: 16 / 10;
  border: 1px solid var(--i-line-strong);
  box-shadow: 0 40px 110px rgba(0, 0, 0, 0.65);
  background: #050505;
}

.i-wipe img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.i-wipe-after {
  position: relative;
  z-index: 0;
}

.i-wipe-before {
  position: absolute;
  inset: 0;
  z-index: 2;
  animation: i-wipe-sweep 9s cubic-bezier(0.65, 0, 0.35, 1) 1.2s infinite;
}

.i-wipe-before img {
  position: absolute;
  inset: 0;
  filter: saturate(0.72) contrast(0.9) blur(0.5px);
}

.i-wipe-before::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.08) 0 1px, transparent 1px 10px),
    repeating-linear-gradient(0deg, rgba(255, 255, 255, 0.06) 0 1px, transparent 1px 10px);
  opacity: 0.1;
  mix-blend-mode: screen;
}

@keyframes i-wipe-sweep {
  0%, 8%   { clip-path: inset(0 0 0 0); }
  42%, 64% { clip-path: inset(0 0 0 100%); }
  96%, 100% { clip-path: inset(0 0 0 0); }
}

.i-wipe-tag {
  position: absolute;
  bottom: 14px;
  z-index: 1;
  display: grid;
  gap: 4px;
  max-width: min(260px, calc(50% - 24px));
  padding: 8px 11px;
  border-radius: 7px;
  font-family: var(--i-mono);
  text-transform: uppercase;
  backdrop-filter: blur(8px);
}

.i-wipe-tag b {
  font-size: 0.58rem;
  line-height: 1;
  letter-spacing: 0.14em;
}

.i-wipe-tag small {
  font-size: 0.55rem;
  line-height: 1.1;
  letter-spacing: 0.1em;
  color: rgba(255, 255, 255, 0.62);
}

.i-wipe-tag--before {
  left: 14px;
  background: rgba(0, 0, 0, 0.55);
  border: 1px solid rgba(238, 58, 57, 0.45);
  color: #ff9692;
}

.i-wipe-tag--after {
  right: 14px;
  background: rgba(0, 0, 0, 0.55);
  border: 1px solid rgba(74, 222, 128, 0.45);
  color: var(--i-good);
}

.i-hero-visual-note {
  margin: 14px 4px 0;
  font: 500 0.78rem/1.5 var(--i-mono);
  letter-spacing: 0.04em;
  color: var(--i-dim);
}

.i-hero-visual-note b { color: var(--i-good); font-weight: 600; }

@media (prefers-reduced-motion: reduce) {
  .i-wipe-before { animation: none; clip-path: inset(0 0 0 100%); }
}

/* ═══════════════════════════════════════════════════════════════
   STATIC SECTION · pull / build / publish checklist cards
   ═══════════════════════════════════════════════════════════════ */
.inventory-page .de-includes-grid {
  position: relative;
  isolation: isolate;
}

.inventory-page .de-includes-col {
  position: relative;
  overflow: visible;
  min-height: 300px;
  padding: 24px 22px;
  transition: border-color 0.45s ease, box-shadow 0.45s ease, transform 0.45s ease;
}

.inventory-page .de-includes-col:nth-child(1) {
  border-color: rgba(238, 58, 57, 0.3);
  background:
    radial-gradient(circle at 12% 0%, rgba(238, 58, 57, 0.14), transparent 48%),
    linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.014));
}

.inventory-page .de-includes-col:nth-child(2),
.inventory-page .de-includes-col:nth-child(3) {
  border-color: rgba(74, 222, 128, 0.28);
  background:
    radial-gradient(circle at 16% 0%, rgba(74, 222, 128, 0.15), transparent 48%),
    linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.014));
}

.inventory-page .de-includes.is-visible .de-includes-col:nth-child(2),
.inventory-page .de-includes.is-visible .de-includes-col:nth-child(3) {
  box-shadow: 0 0 52px rgba(74, 222, 128, 0.08) inset, 0 22px 70px rgba(0, 0, 0, 0.28);
}

.inventory-page .de-includes-pillar {
  display: grid;
  gap: 9px;
  margin-bottom: 18px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--de-line);
  color: inherit;
  font: inherit;
  letter-spacing: 0;
}

.inventory-page .de-includes-pillar span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: fit-content;
  color: var(--i-good);
  font: 850 0.62rem/1 var(--i-mono);
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.inventory-page .de-includes-col:nth-child(1) .de-includes-pillar span {
  color: #ff9692;
}

.inventory-page .de-includes-pillar span::before {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: currentColor;
  box-shadow: 0 0 18px currentColor;
}

.inventory-page .de-includes-pillar b {
  color: #fff;
  font-size: clamp(1.18rem, 1.8vw, 1.45rem);
  font-weight: 850;
  line-height: 1.04;
  letter-spacing: -0.03em;
  text-transform: none;
}

.inventory-page .de-includes-col:nth-child(1)::after,
.inventory-page .de-includes-col:nth-child(2)::after {
  content: '';
  position: absolute;
  right: -35px;
  top: 50%;
  z-index: 3;
  width: 47px;
  height: 2px;
  background: linear-gradient(90deg, rgba(255,255,255,0.16), rgba(74,222,128,0.86));
  box-shadow: 0 0 18px rgba(74,222,128,0.22);
  opacity: 0;
  transform: scaleX(0);
  transform-origin: left center;
}

.inventory-page .de-includes-col:nth-child(1)::before,
.inventory-page .de-includes-col:nth-child(2)::before {
  content: '';
  position: absolute;
  right: -39px;
  top: calc(50% - 5px);
  z-index: 4;
  width: 10px;
  height: 10px;
  border-top: 2px solid rgba(74,222,128,0.9);
  border-right: 2px solid rgba(74,222,128,0.9);
  opacity: 0;
  transform: rotate(45deg) scale(0.6);
}

.inventory-page .de-includes.is-visible .de-includes-col:nth-child(1)::after,
.inventory-page .de-includes.is-visible .de-includes-col:nth-child(2)::after {
  animation: i-include-arrow-line 0.62s ease both;
}

.inventory-page .de-includes.is-visible .de-includes-col:nth-child(1)::before,
.inventory-page .de-includes.is-visible .de-includes-col:nth-child(2)::before {
  animation: i-include-arrow-head 0.42s ease both;
}

.inventory-page .de-includes.is-visible .de-includes-col:nth-child(1)::after { animation-delay: 260ms; }
.inventory-page .de-includes.is-visible .de-includes-col:nth-child(1)::before { animation-delay: 720ms; }
.inventory-page .de-includes.is-visible .de-includes-col:nth-child(2)::after { animation-delay: 560ms; }
.inventory-page .de-includes.is-visible .de-includes-col:nth-child(2)::before { animation-delay: 1020ms; }

@keyframes i-include-arrow-line {
  0% { opacity: 0; transform: scaleX(0); }
  100% { opacity: 1; transform: scaleX(1); }
}

@keyframes i-include-arrow-head {
  0% { opacity: 0; transform: rotate(45deg) scale(0.6); }
  100% { opacity: 1; transform: rotate(45deg) scale(1); }
}

@media (max-width: 880px) {
  .inventory-page .de-includes-grid {
    gap: 42px;
  }

  .inventory-page .de-includes-col {
    min-height: auto;
  }

  .inventory-page .de-includes-col:nth-child(1)::after,
  .inventory-page .de-includes-col:nth-child(2)::after {
    right: auto;
    top: auto;
    left: 50%;
    bottom: -24px;
    width: 2px;
    height: 34px;
    transform: scaleY(0);
    transform-origin: top center;
    background: linear-gradient(180deg, rgba(255,255,255,0.16), rgba(74,222,128,0.86));
  }

  .inventory-page .de-includes-col:nth-child(1)::before,
  .inventory-page .de-includes-col:nth-child(2)::before {
    right: auto;
    top: auto;
    left: calc(50% - 5px);
    bottom: -29px;
    transform: rotate(135deg) scale(0.6);
  }

  .inventory-page .de-includes.is-visible .de-includes-col:nth-child(1)::after,
  .inventory-page .de-includes.is-visible .de-includes-col:nth-child(2)::after {
    animation-name: i-include-arrow-line-y;
  }

  .inventory-page .de-includes.is-visible .de-includes-col:nth-child(1)::before,
  .inventory-page .de-includes.is-visible .de-includes-col:nth-child(2)::before {
    animation-name: i-include-arrow-head-y;
  }
}

@keyframes i-include-arrow-line-y {
  0% { opacity: 0; transform: scaleY(0); }
  100% { opacity: 1; transform: scaleY(1); }
}

@keyframes i-include-arrow-head-y {
  0% { opacity: 0; transform: rotate(135deg) scale(0.6); }
  100% { opacity: 1; transform: rotate(135deg) scale(1); }
}

@media (prefers-reduced-motion: reduce) {
  .inventory-page .de-includes.is-visible .de-includes-col:nth-child(1)::after,
  .inventory-page .de-includes.is-visible .de-includes-col:nth-child(2)::after {
    animation: none;
    opacity: 1;
    transform: scaleX(1);
  }

  .inventory-page .de-includes.is-visible .de-includes-col:nth-child(1)::before,
  .inventory-page .de-includes.is-visible .de-includes-col:nth-child(2)::before {
    animation: none;
    opacity: 1;
    transform: rotate(45deg) scale(1);
  }
}

@media (max-width: 880px) and (prefers-reduced-motion: reduce) {
  .inventory-page .de-includes.is-visible .de-includes-col:nth-child(1)::after,
  .inventory-page .de-includes.is-visible .de-includes-col:nth-child(2)::after {
    transform: scaleY(1);
  }

  .inventory-page .de-includes.is-visible .de-includes-col:nth-child(1)::before,
  .inventory-page .de-includes.is-visible .de-includes-col:nth-child(2)::before {
    transform: rotate(135deg) scale(1);
  }
}

/* ═══════════════════════════════════════════════════════════════
   ACT 1 · BEAT 1 — the buried record (65 fields in, 3 out)
   ═══════════════════════════════════════════════════════════════ */
.i-buried {
  display: grid;
  grid-template-columns: 1.15fr auto 0.95fr;
  gap: 16px;
  align-items: center;
  width: min(100%, 720px);
}

.i-buried-rows { padding: 14px 16px; display: grid; gap: 7px; }

.i-buried-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 6px 9px;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.025);
  font: 500 0.7rem/1.2 var(--i-mono);
  opacity: 0.25;
  transition: opacity 0.35s ease, background 0.35s ease;
}

.i-buried-row span { color: var(--i-dim); text-transform: uppercase; letter-spacing: 0.06em; }
.i-buried-row b { color: var(--i-text); font-weight: 600; }
.i-buried-row.is-in { opacity: 1; background: rgba(255, 255, 255, 0.05); }
.i-buried-row--more span { color: var(--i-mid); }

.i-buried-gate {
  display: flex;
  align-items: center;
  justify-content: center;
}

.i-buried-gate span {
  writing-mode: vertical-rl;
  padding: 14px 7px;
  border-radius: 8px;
  border: 1px dashed rgba(238, 58, 57, 0.5);
  background: var(--i-bad-dim);
  color: #ff9692;
  font: 700 0.6rem/1 var(--i-mono);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  opacity: 0;
  transform: scale(0.85);
  transition: opacity 0.4s ease, transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.i-buried-gate.is-in span { opacity: 1; transform: none; }

.i-buried-listing {
  border: 1px solid var(--i-line-strong);
  border-radius: 14px;
  background: var(--i-panel);
  padding: 14px;
  opacity: 0;
  transform: translateX(14px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}

.i-buried-listing.is-in { opacity: 1; transform: none; }

.i-buried-listing img {
  width: 100%;
  border-radius: 8px;
  margin-bottom: 10px;
  filter: saturate(0.55) brightness(0.8);
}

.i-buried-listing h3 {
  margin: 6px 0 10px;
  font-size: 0.98rem;
  font-weight: 700;
  color: var(--i-mid);
}

.i-buried-missing { display: flex; flex-wrap: wrap; gap: 6px; }

.i-buried-missing span {
  padding: 5px 8px;
  border-radius: 6px;
  border: 1px solid rgba(238, 58, 57, 0.4);
  background: var(--i-bad-dim);
  color: #ff9692;
  font: 600 0.6rem/1 var(--i-mono);
  letter-spacing: 0.05em;
  opacity: 0;
  transform: scale(0.8);
  transition: opacity 0.3s ease, transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.i-buried-missing span.is-in { opacity: 1; transform: none; }

/* ═══════════════════════════════════════════════════════════════
   ACT 1 · BEAT 2 — ingestion from 10+ DMSs
   ═══════════════════════════════════════════════════════════════ */
.i-ingest {
  display: flex;
  flex-direction: column;
  gap: 14px;
  width: min(100%, 620px);
}

.i-ingest-sources { display: flex; gap: 10px; justify-content: center; }

.i-ingest-source {
  padding: 9px 14px;
  border-radius: 9px;
  border: 1px solid var(--i-line-strong);
  background: var(--i-panel-2);
  font: 700 0.72rem/1 var(--i-mono);
  letter-spacing: 0.06em;
  color: var(--i-mid);
  opacity: 0;
  transform: translateY(-10px);
  transition: opacity 0.4s ease, transform 0.4s ease, border-color 0.4s ease, color 0.4s ease;
}

.i-ingest-source.is-in { opacity: 1; transform: none; }
.i-ingest-source.is-live { border-color: rgba(74, 222, 128, 0.5); color: var(--i-good); }
.i-ingest-source--more { color: var(--i-dim); }

.i-ingest-stream {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: center;
  min-height: 26px;
}

.i-ingest-stream span {
  padding: 4px 8px;
  border-radius: 5px;
  background: rgba(74, 222, 128, 0.07);
  border: 1px solid rgba(74, 222, 128, 0.2);
  color: rgba(167, 243, 208, 0.85);
  font: 600 0.58rem/1 var(--i-mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0;
  transform: translateY(-8px);
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.i-ingest-stream span.is-in { opacity: 1; transform: none; }

.i-ingest-record { opacity: 0; transform: translateY(12px); transition: opacity 0.5s ease, transform 0.5s ease; }
.i-ingest-record.is-in { opacity: 1; transform: none; }

.i-ingest-record-body {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: 14px;
  align-items: center;
  padding: 14px 16px;
}

.i-ingest-record-body img { width: 100%; border-radius: 8px; }

.i-ingest-record-info { display: flex; flex-direction: column; gap: 8px; }
.i-ingest-record-info > b { font-size: 1.25rem; font-weight: 800; letter-spacing: -0.02em; }

.i-ingest-specs { display: flex; flex-wrap: wrap; gap: 6px; }

.i-ingest-specs span {
  padding: 5px 8px;
  border-radius: 6px;
  border: 1px solid var(--i-line);
  background: rgba(255, 255, 255, 0.03);
  color: var(--i-mid);
  font: 600 0.6rem/1 var(--i-mono);
  opacity: 0;
  transform: scale(0.85);
  transition: opacity 0.3s ease, transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.i-ingest-specs span.is-in { opacity: 1; transform: none; }

.i-ingest-badge {
  margin: 0 16px 14px;
  padding: 9px 12px;
  border-radius: 8px;
  border: 1px solid rgba(74, 222, 128, 0.4);
  background: var(--i-good-dim);
  color: var(--i-good);
  font: 700 0.64rem/1.4 var(--i-mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-align: center;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.4s ease, transform 0.4s ease;
}

.i-ingest-badge.is-in { opacity: 1; transform: none; }

/* ═══════════════════════════════════════════════════════════════
   ACT 1 · BEAT 3 — the photo problem (real lot shots + callouts)
   ═══════════════════════════════════════════════════════════════ */
.i-rawshot {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 16px;
  align-items: stretch;
  width: min(100%, 660px);
}

.i-rawshot figure {
  position: relative;
  margin: 0;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid var(--i-line-strong);
  background: var(--i-panel);
  opacity: 0;
  transform: translateY(14px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}

.i-rawshot figure.is-in { opacity: 1; transform: none; }

.i-rawshot img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  min-height: 240px;
}

.i-rawshot-chip {
  position: absolute;
  left: var(--cx, 10%);
  top: var(--cy, 10%);
  padding: 6px 10px;
  border-radius: 7px;
  background: rgba(10, 4, 4, 0.82);
  border: 1px solid rgba(238, 58, 57, 0.55);
  color: #ff9692;
  font: 700 0.6rem/1 var(--i-mono);
  letter-spacing: 0.07em;
  white-space: nowrap;
  opacity: 0;
  transform: scale(0.8);
  transition: opacity 0.35s ease, transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
  z-index: 2;
}

.i-rawshot-chip.is-in { opacity: 1; transform: none; }

/* ═══════════════════════════════════════════════════════════════
   ACT 1 · BEAT 4 — the proprietary pipeline (inputs → output)
   ═══════════════════════════════════════════════════════════════ */
.i-pipe {
  display: grid;
  grid-template-columns: 0.6fr 0.95fr 1.3fr;
  gap: 14px;
  align-items: center;
  width: min(100%, 720px);
}

.i-pipe-in { display: flex; flex-direction: column; gap: 10px; }

.i-pipe-tile {
  margin: 0;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid var(--i-line-strong);
  background: var(--i-panel);
  opacity: 0;
  transform: translateX(-16px);
  transition: opacity 0.45s ease, transform 0.45s ease, border-color 0.45s ease;
}

.i-pipe-tile.is-in { opacity: 1; transform: none; }
.i-pipe-tile.is-sent { border-color: rgba(74, 222, 128, 0.45); }

.i-pipe-tile img {
  display: block;
  width: 100%;
  height: 64px;
  object-fit: cover;
}

.i-pipe-tile figcaption {
  padding: 5px 8px;
  font: 600 0.54rem/1 var(--i-mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--i-dim);
}

/* the segmentation-mask tile — CSS crop into the node-graph screenshot,
   zoomed to one of the white boat-silhouette mask previews */
.i-pipe-mask {
  display: block;
  height: 64px;
  background: url('../assets/inventory/pipeline-wide.png') no-repeat;
  background-size: 640%;
  background-position: 26.5% 63%;
  filter: contrast(1.15) brightness(1.05);
}

.i-pipe-tile--mask figcaption { color: var(--i-good); }

.i-pipe-core {
  position: relative;
  border-radius: 14px;
  border: 1px solid var(--i-line-strong);
  background: var(--i-panel);
  overflow: hidden;
  min-height: 230px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 10px;
  padding: 14px;
  opacity: 0;
  transform: scale(0.94);
  transition: opacity 0.5s ease, transform 0.5s ease, box-shadow 0.6s ease;
}

.i-pipe-core.is-in { opacity: 1; transform: none; }
.i-pipe-core.is-running { box-shadow: 0 0 50px rgba(74, 222, 128, 0.16) inset, 0 18px 60px rgba(0, 0, 0, 0.5); }

/* the real node graph, deliberately soft-focused: texture, not documentation */
.i-pipe-graph {
  position: absolute;
  inset: 0;
  background: url('../assets/inventory/pipeline-wide.png') center / cover no-repeat;
  filter: blur(3px) brightness(0.6) saturate(0.85);
  opacity: 0.75;
}

.i-pipe-core::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 30%, rgba(0, 0, 0, 0.82) 100%);
}

.i-pipe-core-label {
  position: relative;
  z-index: 2;
  font: 700 0.66rem/1 var(--i-mono);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--i-text);
}

.i-pipe-core-steps {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.i-pipe-core-steps span {
  font: 600 0.6rem/1.3 var(--i-mono);
  letter-spacing: 0.06em;
  color: var(--i-dim);
  transition: color 0.3s ease;
}

.i-pipe-core-steps span::before {
  content: '○ ';
  color: var(--i-dim);
}

.i-pipe-core-steps span.is-in { color: var(--i-good); }
.i-pipe-core-steps span.is-in::before { content: '● '; color: var(--i-good); }

.i-pipe-out {
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid var(--i-line-strong);
  background: #232325; /* matches the dark-studio output's gradient base */
  opacity: 0;
  clip-path: inset(0 100% 0 0);
  transition: opacity 0.2s ease, clip-path 0.9s cubic-bezier(0.65, 0, 0.35, 1), border-color 0.5s ease;
}

.i-pipe-out.is-in {
  opacity: 1;
  clip-path: inset(0 0 0 0);
  border-color: rgba(74, 222, 128, 0.5);
}

.i-pipe-out img { display: block; width: 100%; }

.i-pipe-badge {
  position: absolute;
  right: 10px;
  bottom: 10px;
  padding: 7px 11px;
  border-radius: 8px;
  background: rgba(4, 24, 12, 0.88);
  border: 1px solid rgba(74, 222, 128, 0.55);
  color: var(--i-good);
  font: 700 0.62rem/1 var(--i-mono);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  opacity: 0;
  transform: scale(0.8);
  transition: opacity 0.35s ease, transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.i-pipe-badge.is-in { opacity: 1; transform: none; }

/* ═══════════════════════════════════════════════════════════════
   ACT 1 · BEAT 5 — before/after scrub slider + output thumbs
   ═══════════════════════════════════════════════════════════════ */
.i-ba { width: min(100%, 640px); display: flex; flex-direction: column; gap: 10px; }

.inventory-page.is-image-compare-hover .cursor-glow {
  opacity: 0 !important;
}

.i-ba-frame {
  --ba: 50%;
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid var(--i-line-strong);
  aspect-ratio: 16 / 9;
  background: var(--i-panel);
  cursor: ew-resize;
  touch-action: none;
  user-select: none;
  -webkit-user-select: none;
  -webkit-user-drag: none;
}

.i-ba-frame *,
.i-ba-thumbs,
.i-ba-thumbs * {
  user-select: none;
  -webkit-user-select: none;
  -webkit-user-drag: none;
}

.i-ba-frame img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  pointer-events: none;
}

.i-ba-before {
  position: absolute;
  inset: 0;
  clip-path: inset(0 calc(100% - var(--ba)) 0 0);
}

.i-ba-handle {
  position: absolute;
  top: 0;
  bottom: 0;
  left: var(--ba);
  width: 2px;
  margin-left: -1px;
  background: rgba(255, 255, 255, 0.85);
  box-shadow: 0 0 14px rgba(0, 0, 0, 0.55);
  z-index: 3;
}

.i-ba-handle span {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.72);
  border: 1px solid rgba(255, 255, 255, 0.7);
  backdrop-filter: blur(6px);
}

.i-ba-handle span::before {
  content: '◂ ▸';
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.6rem;
  letter-spacing: 0.08em;
  color: #fff;
}

.i-ba-tag {
  position: absolute;
  top: 12px;
  padding: 6px 10px;
  border-radius: 6px;
  font: 700 0.58rem/1 var(--i-mono);
  letter-spacing: 0.14em;
  backdrop-filter: blur(8px);
  z-index: 2;
}

.i-ba-tag--before {
  left: 12px;
  background: rgba(0, 0, 0, 0.55);
  border: 1px solid rgba(238, 58, 57, 0.45);
  color: #ff9692;
}

.i-ba-tag--after {
  right: 12px;
  background: rgba(0, 0, 0, 0.55);
  border: 1px solid rgba(74, 222, 128, 0.45);
  color: var(--i-good);
}

.i-ba-hint {
  margin: 0;
  text-align: center;
  font: 500 0.7rem/1.4 var(--i-mono);
  letter-spacing: 0.04em;
  color: var(--i-dim);
}

.i-ba-thumbs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}

.i-ba-thumbs figure {
  margin: 0;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid var(--i-line);
  background: var(--i-panel);
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 0.4s ease, transform 0.4s ease;
}

.i-ba-thumbs figure.is-in { opacity: 1; transform: none; }

.i-ba-thumbs img {
  display: block;
  width: 100%;
  height: 58px;
  object-fit: cover;
}

.i-ba-thumbs figcaption {
  padding: 5px 8px;
  font: 600 0.54rem/1 var(--i-mono);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--i-dim);
}

/* ═══════════════════════════════════════════════════════════════
   ACT 1 · BEAT 6 — the sales spine
   ═══════════════════════════════════════════════════════════════ */
.i-spine { width: min(100%, 620px); }

.i-spine-card {
  border: 1px solid var(--i-line-strong);
  border-radius: 16px;
  background: var(--i-panel);
  box-shadow: 0 30px 90px rgba(0, 0, 0, 0.6);
  overflow: hidden;
  opacity: 0;
  transform: translateY(14px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}

.i-spine-card.is-in { opacity: 1; transform: none; }

.i-spine-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 13px 16px;
  border-bottom: 1px solid var(--i-line);
}

.i-spine-top b { font-size: 1.05rem; font-weight: 800; letter-spacing: -0.02em; color: var(--i-good); }

.i-spine-body {
  display: grid;
  grid-template-columns: 0.8fr 1.2fr;
  gap: 16px;
  padding: 16px;
  align-items: start;
}

.i-spine-body > img { width: 100%; border-radius: 10px; }

.i-spine-content { display: flex; flex-direction: column; gap: 10px; }

.i-spine-content h3 {
  margin: 0;
  font-size: 1.02rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  transition: color 0.4s ease;
}

.i-spine-copy {
  margin: 0;
  font-size: 0.86rem;
  line-height: 1.55;
  color: var(--i-mid);
}

.i-spine-fin {
  display: flex;
  align-items: baseline;
  gap: 8px;
  padding: 9px 12px;
  border-radius: 9px;
  border: 1px solid rgba(74, 222, 128, 0.35);
  background: var(--i-good-dim);
}

.i-spine-fin b { font-size: 1.15rem; font-weight: 800; color: var(--i-good); }
.i-spine-fin b i { font-style: normal; font-size: 0.7rem; font-weight: 600; }
.i-spine-fin span { font: 600 0.6rem/1 var(--i-mono); letter-spacing: 0.08em; text-transform: uppercase; color: var(--i-dim); }

.i-spine-faq {
  display: flex;
  flex-direction: column;
  gap: 3px;
  padding: 9px 12px;
  border-radius: 9px;
  border: 1px solid var(--i-line);
  background: rgba(255, 255, 255, 0.025);
}

.i-spine-faq span { font: 700 0.58rem/1 var(--i-mono); letter-spacing: 0.1em; text-transform: uppercase; color: var(--i-dim); }
.i-spine-faq em { font-style: normal; font-size: 0.8rem; color: var(--i-mid); }

.i-spine-content [data-spine-add] {
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 0.4s ease, transform 0.4s ease;
}

.i-spine-content [data-spine-add].is-in { opacity: 1; transform: none; }

.i-spine-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  padding: 0 16px 16px;
}

.i-spine-tags span {
  padding: 6px 10px;
  border-radius: 7px;
  border: 1px solid var(--i-line);
  background: rgba(255, 255, 255, 0.03);
  color: var(--i-dim);
  font: 600 0.6rem/1 var(--i-mono);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  transition: border-color 0.35s ease, color 0.35s ease, background 0.35s ease;
}

.i-spine-tags span.is-in {
  border-color: rgba(74, 222, 128, 0.45);
  background: var(--i-good-dim);
  color: var(--i-good);
}

/* ═══════════════════════════════════════════════════════════════
   ACT 2 · BEATS 1–2 — SERP miss / category page + AI answer win
   ═══════════════════════════════════════════════════════════════ */
.i-serp {
  width: min(100%, 560px);
  border: 1px solid var(--i-line-strong);
  border-radius: 16px;
  background: var(--i-panel);
  box-shadow: 0 30px 90px rgba(0, 0, 0, 0.6);
  overflow: hidden;
}

.i-serp-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 13px 16px;
  border-bottom: 1px solid var(--i-line);
}

.i-serp-bar i {
  display: grid;
  place-items: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.08);
  font: 800 0.8rem/1 var(--i-font);
  font-style: normal;
  color: var(--i-mid);
}

.i-serp-bar span {
  flex: 1;
  padding: 8px 13px;
  border-radius: 99px;
  border: 1px solid var(--i-line);
  background: rgba(255, 255, 255, 0.04);
  font-size: 0.85rem;
  color: var(--i-text);
}

.i-serp-results { padding: 14px 16px; display: grid; gap: 11px; }

.i-serp-result {
  display: flex;
  flex-direction: column;
  gap: 3px;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.35s ease, transform 0.35s ease;
}

.i-serp-result.is-in { opacity: 1; transform: none; }

.i-serp-result span { font: 500 0.62rem/1.2 var(--i-mono); color: var(--i-dim); }
.i-serp-result b { font-size: 0.88rem; font-weight: 600; color: #9ec1ff; }

.i-serp-result--dim { opacity: 0.45 !important; }

.i-serp-result--rich {
  padding: 12px;
  border-radius: 10px;
  border: 1px solid rgba(74, 222, 128, 0.4);
  background: var(--i-good-dim);
}

.i-serp-result--rich span { color: rgba(167, 243, 208, 0.8); }
.i-serp-result--rich b { color: #fff; font-weight: 700; }

.i-serp-rich { display: flex; gap: 7px; margin-top: 7px; }

.i-serp-rich em {
  padding: 4px 8px;
  border-radius: 6px;
  border: 1px solid rgba(74, 222, 128, 0.35);
  background: rgba(0, 0, 0, 0.3);
  color: var(--i-good);
  font: 600 0.62rem/1 var(--i-mono);
  font-style: normal;
  opacity: 0;
  transform: scale(0.85);
  transition: opacity 0.3s ease, transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.i-serp-rich em.is-in { opacity: 1; transform: none; }

.i-serp-you {
  margin: 0 16px 16px;
  padding: 10px 12px;
  border-radius: 9px;
  border: 1px dashed rgba(238, 58, 57, 0.55);
  background: var(--i-bad-dim);
  color: #ff9692;
  font: 700 0.68rem/1 var(--i-mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-align: center;
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 0.45s ease, transform 0.45s ease;
}

.i-serp-you.is-in { opacity: 1; transform: none; }

/* beat 2 composite: compact SERP + AI answer panel side by side */
.i-found {
  display: grid;
  grid-template-columns: 1.02fr 0.98fr;
  gap: 14px;
  align-items: start;
  width: min(100%, 760px);
}

.i-found .i-serp { width: 100%; box-shadow: none; }

.i-geo {
  display: flex;
  flex-direction: column;
  gap: 10px;
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}

.i-geo.is-in { opacity: 1; transform: none; }

.i-geo-q {
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid var(--i-line);
  background: rgba(255, 255, 255, 0.03);
}

.i-geo-q span {
  display: block;
  margin-bottom: 4px;
  font: 700 0.56rem/1 var(--i-mono);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--i-dim);
}

.i-geo-q p { margin: 0; font-size: 0.92rem; font-weight: 600; }

.i-geo-a {
  padding: 13px 14px;
  border-radius: 12px;
  border: 1px solid rgba(74, 222, 128, 0.32);
  background: rgba(74, 222, 128, 0.05);
}

.i-geo-a-head {
  display: flex;
  align-items: center;
  gap: 7px;
  margin-bottom: 8px;
  font: 700 0.62rem/1 var(--i-mono);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(167, 243, 208, 0.9);
}

.i-geo-a-head span {
  padding: 4px 6px;
  border-radius: 5px;
  background: var(--i-good);
  color: #04240f;
  font-weight: 800;
}

.i-geo-a p {
  margin: 0;
  font-size: 0.88rem;
  line-height: 1.5;
  color: var(--i-mid);
  min-height: 4em;
}

.i-geo-a p b {
  color: #fff;
  font-weight: 800;
  background: rgba(74, 222, 128, 0.18);
  padding: 0 5px;
  border-radius: 4px;
}

.i-geo-a p.is-typing::after {
  content: '';
  display: inline-block;
  width: 2px;
  height: 1em;
  margin-left: 2px;
  vertical-align: -2px;
  background: var(--i-good);
  animation: i-geo-caret 0.7s steps(1) infinite;
}

@keyframes i-geo-caret { 50% { opacity: 0; } }

.i-geo-cite {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 9px;
  font: 600 0.62rem/1 var(--i-mono);
  color: var(--i-dim);
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.4s ease, transform 0.4s ease;
}

.i-geo-cite.is-in { opacity: 1; transform: none; }
.i-geo-cite i { font-style: normal; color: var(--i-good); }

/* ═══════════════════════════════════════════════════════════════
   ACT 2 · BEAT 3 — the marketplace grind
   ═══════════════════════════════════════════════════════════════ */
.i-stale {
  display: flex;
  flex-direction: column;
  gap: 11px;
  width: min(100%, 540px);
}

.i-stale-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  padding: 15px 17px;
  border-radius: 12px;
  border: 1px solid var(--i-line-strong);
  background: var(--i-panel);
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 0.4s ease, transform 0.4s ease;
}

.i-stale-row.is-in { opacity: 1; transform: none; }

.i-stale-row b { font-size: 0.95rem; font-weight: 700; }

.i-stale-row span {
  padding: 6px 10px;
  border-radius: 7px;
  border: 1px solid rgba(238, 58, 57, 0.4);
  background: var(--i-bad-dim);
  color: #ff9692;
  font: 600 0.64rem/1 var(--i-mono);
  letter-spacing: 0.04em;
  opacity: 0;
  transform: scale(0.85);
  transition: opacity 0.3s ease, transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.i-stale-row span.is-in { opacity: 1; transform: none; }

.i-stale-cost {
  padding: 13px 16px;
  border-radius: 11px;
  border: 1px dashed rgba(238, 58, 57, 0.5);
  background: rgba(238, 58, 57, 0.06);
  color: var(--i-mid);
  font-size: 0.85rem;
  line-height: 1.5;
  text-align: center;
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 0.45s ease, transform 0.45s ease;
}

.i-stale-cost.is-in { opacity: 1; transform: none; }

/* ═══════════════════════════════════════════════════════════════
   ACT 2 · BEAT 4 — syndication fan-out
   ═══════════════════════════════════════════════════════════════ */
.i-synd {
  display: grid;
  grid-template-columns: 0.95fr 56px 1.05fr;
  gap: 0;
  align-items: center;
  width: min(100%, 680px);
}

.i-synd-unit {
  display: flex;
  flex-direction: column;
  gap: 7px;
  padding: 14px;
  border-radius: 14px;
  border: 1px solid var(--i-line-strong);
  background: var(--i-panel);
  box-shadow: 0 20px 70px rgba(0, 0, 0, 0.55);
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}

.i-synd-unit.is-in { opacity: 1; transform: none; }
.i-synd-unit img { width: 100%; border-radius: 9px; background: #fff; }
.i-synd-unit b { font-size: 0.85rem; font-weight: 700; color: var(--i-good); }

.i-synd-wires {
  position: relative;
  height: 100%;
  min-height: 220px;
}

.i-synd-packet {
  position: absolute;
  left: 6px;
  top: calc(14% + var(--wi, 0) * 24%);
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--i-good);
  box-shadow: 0 0 10px rgba(74, 222, 128, 0.8);
  opacity: 0;
  transition: transform 0.55s cubic-bezier(0.5, 0, 0.6, 1), opacity 0.2s ease;
}

.i-synd-packet:nth-child(1) { --wi: 0; }
.i-synd-packet:nth-child(2) { --wi: 1; }
.i-synd-packet:nth-child(3) { --wi: 2; }
.i-synd-packet:nth-child(4) { --wi: 3; }

.i-synd-packet.is-send { opacity: 1; transform: translateX(42px); }

.i-synd-channels { display: flex; flex-direction: column; gap: 10px; }

.i-synd-channel {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 11px;
  border: 1px solid var(--i-line);
  background: var(--i-panel-2);
  opacity: 0.45;
  transition: opacity 0.4s ease, border-color 0.4s ease;
}

.i-synd-channel b { font-size: 0.85rem; font-weight: 700; }

.i-synd-channel span {
  font: 600 0.58rem/1.3 var(--i-mono);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--i-good);
  opacity: 0;
  transition: opacity 0.35s ease;
}

.i-synd-channel.is-live { opacity: 1; border-color: rgba(74, 222, 128, 0.45); }
.i-synd-channel.is-live span { opacity: 1; }

/* ═══════════════════════════════════════════════════════════════
   ACT 2 · BEAT 5 — unit management dashboard
   ═══════════════════════════════════════════════════════════════ */
.i-dash { width: min(100%, 640px); }

.i-dash-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--i-line);
}

.i-dash-chip {
  padding: 6px 11px;
  border-radius: 99px;
  border: 1px solid var(--i-line);
  background: rgba(255, 255, 255, 0.03);
  color: var(--i-dim);
  font: 600 0.64rem/1 var(--i-mono);
}

.i-dash-chip.is-on { border-color: var(--i-line-strong); color: var(--i-text); background: rgba(255, 255, 255, 0.07); }

.i-dash-bulk {
  margin-left: auto;
  padding: 7px 11px;
  border-radius: 8px;
  border: 1px solid rgba(74, 222, 128, 0.45);
  background: var(--i-good-dim);
  color: var(--i-good);
  font: 600 0.64rem/1 var(--i-mono);
  opacity: 0;
  transform: translateY(-6px);
  transition: opacity 0.4s ease, transform 0.4s ease;
}

.i-dash-bulk.is-in { opacity: 1; transform: none; }
.i-dash-bulk b { font-weight: 800; }

.i-dash-rows { padding: 12px 16px; display: grid; gap: 9px; }

.i-dash-row {
  display: grid;
  grid-template-columns: 16px 1fr auto auto;
  align-items: center;
  gap: 11px;
  padding: 10px 12px;
  border-radius: 9px;
  border: 1px solid var(--i-line);
  background: rgba(255, 255, 255, 0.02);
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.35s ease, transform 0.35s ease;
}

.i-dash-row.is-in { opacity: 1; transform: none; }
.i-dash-row--sold { opacity: 0.55 !important; }

.i-dash-row > i {
  width: 14px;
  height: 14px;
  border-radius: 4px;
  border: 1px solid var(--i-line-strong);
  position: relative;
  transition: background 0.25s ease, border-color 0.25s ease;
}

.i-dash-row > i.is-checked { background: var(--i-good); border-color: var(--i-good); }

.i-dash-row > i.is-checked::after {
  content: '✓';
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-size: 0.55rem;
  font-weight: 900;
  color: #04240f;
}

.i-dash-row b { font-size: 0.82rem; font-weight: 600; }

.i-dash-meta {
  font: 600 0.74rem/1 var(--i-mono);
  color: var(--i-mid);
  transition: color 0.3s ease;
}

.i-dash-status {
  padding: 4px 8px;
  border-radius: 6px;
  font: 600 0.56rem/1.3 var(--i-mono);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-style: normal;
}

.i-dash-status--active { background: var(--i-good-dim); color: var(--i-good); }
.i-dash-status--pending { background: rgba(251, 191, 36, 0.12); color: #fbbf24; }
.i-dash-status--sold { background: rgba(255, 255, 255, 0.06); color: var(--i-dim); }

.i-dash-note {
  margin: 0 16px 14px;
  padding: 9px 12px;
  border-radius: 8px;
  border: 1px solid rgba(74, 222, 128, 0.35);
  background: var(--i-good-dim);
  color: var(--i-good);
  font: 600 0.66rem/1.45 var(--i-mono);
  text-align: center;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.4s ease, transform 0.4s ease;
}

.i-dash-note.is-in { opacity: 1; transform: none; }

/* ═══════════════════════════════════════════════════════════════
   ACT 2 · BEAT 6 — MAP compliance by brand (new boats)
   A below-MAP price gets held before publish, then advertised
   at the brand's floor — red moment inside a good beat.
   ═══════════════════════════════════════════════════════════════ */
.i-map {
  width: min(100%, 560px);
  border: 1px solid var(--i-line-strong);
  border-radius: 16px;
  background: var(--i-panel);
  box-shadow: 0 30px 90px rgba(0, 0, 0, 0.6);
  overflow: hidden;
}

.i-map-unit {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--i-line);
}

.i-map-unit img {
  width: 110px;
  border-radius: 9px;
  background: #fff;
}

.i-map-unit b { display: block; margin-top: 5px; font-size: 0.92rem; font-weight: 700; }

.i-map-rows { padding: 14px 16px 0; display: grid; grid-template-columns: 1fr 1fr; gap: 9px; }

.i-map-row {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 10px 12px;
  border-radius: 9px;
  border: 1px solid var(--i-line);
  background: rgba(255, 255, 255, 0.02);
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.35s ease, transform 0.35s ease;
}

.i-map-row.is-in { opacity: 1; transform: none; }

.i-map-row span {
  font: 600 0.56rem/1 var(--i-mono);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--i-dim);
}

.i-map-row b { font-size: 0.95rem; font-weight: 700; }

.i-map-attempt {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  margin: 12px 16px 0;
  padding: 12px 14px;
  border-radius: 11px;
  border: 1px dashed var(--i-line-strong);
  background: rgba(255, 255, 255, 0.02);
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 0.4s ease, transform 0.4s ease, border-color 0.4s ease, background 0.4s ease;
}

.i-map-attempt.is-in { opacity: 1; transform: none; }

.i-map-attempt.is-blocked {
  border-color: rgba(238, 58, 57, 0.55);
  background: rgba(238, 58, 57, 0.06);
}

.i-map-attempt > span {
  font: 600 0.6rem/1.3 var(--i-mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--i-dim);
}

.i-map-attempt > b {
  font-size: 1.05rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  transition: color 0.3s ease, text-decoration-color 0.3s ease;
}

.i-map-attempt.is-blocked > b {
  color: #ff9692;
  text-decoration: line-through;
  text-decoration-thickness: 2px;
  text-decoration-color: rgba(238, 58, 57, 0.85);
}

.i-map-flag {
  margin-left: auto;
  padding: 6px 10px;
  border-radius: 7px;
  border: 1px solid rgba(238, 58, 57, 0.5);
  background: var(--i-bad-dim);
  color: #ff9692;
  font: 700 0.6rem/1.3 var(--i-mono);
  font-style: normal;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  opacity: 0;
  transform: scale(0.85);
  transition: opacity 0.35s ease, transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.i-map-flag.is-in { opacity: 1; transform: none; }

.i-map-result {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 10px 16px 16px;
  padding: 14px 16px;
  border-radius: 12px;
  border: 1px solid rgba(74, 222, 128, 0.45);
  background: var(--i-good-dim);
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 0.45s ease, transform 0.45s ease;
}

.i-map-result.is-in { opacity: 1; transform: none; }

.i-map-result span {
  font: 700 0.58rem/1.3 var(--i-mono);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--i-dim);
}

.i-map-result b {
  font-size: 1.7rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--i-good);
}

.i-map-result em {
  margin-left: auto;
  font: 600 0.6rem/1.4 var(--i-mono);
  font-style: normal;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--i-good);
  opacity: 0;
  transform: scale(0.85);
  transition: opacity 0.35s ease, transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.i-map-result em.is-in { opacity: 1; transform: none; }

/* ═══════════════════════════════════════════════════════════════
   MOBILE
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 1100px) {
  .i-hero { padding: calc(var(--nav-height, 72px) + 28px) 16px 56px; }

  .i-hero-inner {
    grid-template-columns: 1fr;
    gap: 34px;
  }

  .i-hero-copy h1 { font-size: clamp(2rem, 8vw, 2.7rem); }

  .i-buried { grid-template-columns: 1fr; gap: 10px; width: 100%; }
  .i-buried-gate span { writing-mode: horizontal-tb; padding: 8px 14px; }
  .i-buried-rows { grid-template-columns: 1fr 1fr; }
  .i-buried-row--more { grid-column: span 2; }
  .i-buried-listing img { max-height: 120px; object-fit: cover; }

  .i-rawshot { grid-template-columns: 1fr; width: 100%; }
  .i-rawshot-side { display: none; }
  .i-rawshot img { min-height: 200px; }

  .i-pipe { grid-template-columns: 1fr; width: 100%; gap: 10px; }
  .i-pipe-in { flex-direction: row; }
  .i-pipe-tile { flex: 1; transform: translateY(-12px); }
  .i-pipe-core { min-height: 130px; }
  .i-pipe-out img { max-height: 180px; object-fit: cover; width: 100%; }

  .i-ba { width: 100%; }
  .i-ba-thumbs img { height: 44px; }

  .i-spine { width: 100%; }
  .i-spine-body { grid-template-columns: 1fr; }
  .i-spine-body > img { max-height: 140px; object-fit: cover; }

  .i-found { grid-template-columns: 1fr; width: 100%; }
  .i-found .i-serp .i-serp-results .i-serp-result--dim { display: none; }

  .i-serp { width: 100%; }
  .i-stale { width: 100%; }

  .i-synd { grid-template-columns: 1fr; width: 100%; gap: 12px; }
  .i-synd-wires { display: none; }
  .i-synd-unit { flex-direction: row; align-items: center; }
  .i-synd-unit img { width: 110px; }

  .i-dash { width: 100%; }
  .i-dash-toolbar { flex-wrap: wrap; }
  .i-dash-bulk { margin-left: 0; }

  .i-map { width: 100%; }
}

@media (max-width: 640px) {
  .i-hero { padding-left: 12px; padding-right: 12px; }
  .i-hero-copy p { font-size: 0.96rem; }
  .i-buried-rows { grid-template-columns: 1fr; }
  .i-buried-row--more { grid-column: auto; }
  .i-dash-row { grid-template-columns: 14px 1fr auto; }
  .i-dash-row .i-dash-status { display: none; }
  .i-map-rows { grid-template-columns: 1fr; }
  .i-map-flag { margin-left: 0; }
  .i-map-result { flex-wrap: wrap; }
  .i-map-result em { margin-left: 0; }
}
