/* =========================================================================
   Product hero mocks for Mission508, Station508, Sentinel508.
   Extends the marketing-kit .hero__mock / .mock__* / .issue / .issue__badge
   primitives. Visual language stays consistent with Rover508's ExtensionMock.
   ========================================================================= */

/* --- shared: status dot pulse ------------------------------------------ */
.mock__status-dot--pulse {
  animation: sentinel-pulse 1.8s ease-in-out infinite;
}
@keyframes sentinel-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(0, 196, 161, 0.55); }
  50%      { box-shadow: 0 0 0 6px rgba(0, 196, 161, 0.00); }
}

/* =========================================================================
   MISSION508. agent team card (standalone white card, matches Rover508 style)
   ========================================================================= */
.mission-team {
  width: 100%;
  max-width: 540px;
  background: #fff;
  color: var(--on-parch);
  border-radius: 20px;
  box-shadow:
    0 40px 100px rgba(0, 0, 0, 0.22),
    0 0 0 1px rgba(0, 0, 0, 0.06);
  padding: 28px;
  font-family: var(--font-sans);
  margin: 0;
  display: flex; flex-direction: column; gap: 18px;
}

.mission-team__header {
  display: flex; justify-content: space-between; align-items: center;
}
.mission-team__label {
  font-family: var(--font-mono); font-size: 11px; font-weight: 700;
  letter-spacing: var(--tracking-wide); text-transform: uppercase;
  color: rgba(8, 15, 28, 0.45);
}
.mission-team__status {
  font-family: var(--font-mono); font-size: 11px;
  color: var(--arc-teal-text);
  display: inline-flex; align-items: center; gap: 7px;
}
.mission-team__pulse {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--arc-teal);
  animation: mission-pulse 1.4s ease-in-out infinite;
}
@keyframes mission-pulse {
  0%, 100% { opacity: 1;   transform: scale(1); }
  50%      { opacity: 0.35; transform: scale(0.7); }
}

.mission-team__ticket {
  background: #F5F4F2;
  border: 1px solid #E5E4E0;
  border-left: 3px solid var(--arc-teal);
  border-radius: 8px;
  padding: 12px 14px;
  display: flex; flex-direction: column; gap: 3px;
}
.mission-team__ticket-id {
  font-family: var(--font-mono); font-size: 10.5px;
  color: rgba(8, 15, 28, 0.45); letter-spacing: var(--tracking-wide); text-transform: uppercase;
}
.mission-team__ticket-title {
  font-size: 14px; font-weight: 600; color: var(--on-parch);
}
.mission-team__ticket-trace {
  font-family: var(--font-mono); font-size: 11px;
  color: rgba(8, 15, 28, 0.55);
}

.mission-team__flow {
  display: flex; flex-direction: column; gap: 8px;
  position: relative;
}
.agent-row {
  display: grid;
  grid-template-columns: 40px 1fr auto;
  gap: 12px; align-items: center;
  padding: 11px 14px;
  border-radius: 10px;
  border: 1px solid #EBEAE6;
  background: #FBFAF7;
  position: relative; z-index: 1;
}
.agent-row--running { border-color: rgba(0,196,161,0.35); background: rgba(0,196,161,0.04); }
.agent-row--review  { border-color: rgba(220, 148, 54, 0.35); background: rgba(220, 148, 54, 0.04); }
.agent-row--merged  { border-color: #E5E4E0; background: #FBFAF7; opacity: 0.88; }

.agent-row__chip {
  width: 40px; height: 40px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-mono); font-size: 11px; font-weight: 700;
  letter-spacing: var(--tracking-mono);
}
.agent-row__chip--teal  {
  background: rgba(0, 196, 161, 0.14);
  color: var(--arc-teal-text);
  border: 1px solid rgba(0, 196, 161, 0.35);
}
.agent-row__chip--amber {
  background: rgba(220, 148, 54, 0.14);
  color: #B07018;
  border: 1px solid rgba(220, 148, 54, 0.35);
}

.agent-row__body { min-width: 0; }
.agent-row__role {
  font-size: 12.5px; font-weight: 600; color: var(--on-parch);
}
.agent-row__task {
  font-size: 12px; color: rgba(8, 15, 28, 0.55);
  margin-top: 2px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

.agent-row__state {
  font-family: var(--font-mono); font-size: 10px; font-weight: 500;
  letter-spacing: var(--tracking-wide); text-transform: uppercase;
  padding: 4px 8px; border-radius: 4px;
  display: inline-flex; align-items: center; gap: 6px;
  white-space: nowrap;
}
.agent-row__state--running {
  background: rgba(0, 196, 161, 0.14); color: var(--arc-teal-text);
  border: 1px solid rgba(0, 196, 161, 0.35);
}
.agent-row__state--review {
  background: rgba(220, 148, 54, 0.14); color: #B07018;
  border: 1px solid rgba(220, 148, 54, 0.35);
}
.agent-row__state--merged {
  background: rgba(8, 15, 28, 0.05); color: rgba(8, 15, 28, 0.55);
  border: 1px solid #E5E4E0;
}

.agent-row__spinner {
  width: 7px; height: 7px; border-radius: 50%;
  background: transparent;
  border: 1.5px solid var(--arc-teal);
  border-top-color: transparent;
  animation: mission-spin 0.9s linear infinite;
}
@keyframes mission-spin { to { transform: rotate(360deg); } }

.mission-team__flow::before {
  content: '';
  position: absolute;
  left: 33px; top: 40px; bottom: 40px;
  width: 1px;
  background: linear-gradient(to bottom, rgba(0,196,161,0.4), rgba(0,196,161,0.1));
  pointer-events: none;
  z-index: 0;
}

.mission-team__footer {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 12px;
  border-top: 1px solid #EBEAE6;
  font-family: var(--font-mono); font-size: 10.5px;
}
.mission-team__footer-text { color: rgba(8, 15, 28, 0.45); }
.mission-team__footer-link { color: var(--arc-teal-text); font-weight: 500; }

@media (max-width: 640px) {
  .mission-team { padding: 20px; }
  .agent-row { grid-template-columns: 32px 1fr auto; gap: 10px; padding: 10px; }
  .agent-row__chip { width: 32px; height: 32px; font-size: 10px; }
}

/* =========================================================================
   MISSION508 — merged-PR outcome card (hero)
   ========================================================================= */
.mission-pr {
  width: 100%;
  max-width: 540px;
  background: #fff;
  color: var(--on-parch);
  border-radius: 20px;
  box-shadow: 0 40px 100px rgba(0,0,0,0.22), 0 0 0 1px rgba(0,0,0,0.06);
  padding: 32px;
  font-family: var(--font-sans);
  display: flex; flex-direction: column; gap: 18px;
}
.mission-pr__head {
  display: flex; justify-content: space-between; align-items: center;
}
.mission-pr__repo {
  font-family: var(--font-mono); font-size: 11.5px;
  letter-spacing: var(--tracking-mono);
  color: rgba(8,15,28,0.55);
}
.mission-pr__merged-chip {
  display: inline-flex; align-items: center; gap: 7px;
  background: rgba(0, 196, 161, 0.14); color: var(--arc-teal-text);
  border: 1px solid rgba(0, 196, 161, 0.38);
  padding: 4px 10px; border-radius: 999px;
  font-family: var(--font-mono); font-size: 10.5px; font-weight: 600;
  letter-spacing: var(--tracking-mono-loose); text-transform: uppercase;
}
.mission-pr__title {
  font-size: 19px; font-weight: 600; color: var(--on-parch);
  line-height: 1.45; letter-spacing: 0.005em;
  word-spacing: 0.02em;
}
.mission-pr__meta {
  display: flex; flex-wrap: wrap; align-items: center; gap: 10px;
  font-family: var(--font-mono); font-size: 11.5px; color: rgba(8,15,28,0.55);
  line-height: 1.6; letter-spacing: var(--tracking-mono);
}
.mission-pr__num { color: rgba(8,15,28,0.45); }
.mission-pr__branch {
  background: #F5F4F2; border: 1px solid #E5E4E0;
  padding: 2px 7px; border-radius: 4px;
}
.mission-pr__branch--base { color: var(--arc-teal-text); border-color: rgba(0,196,161,0.35); }
.mission-pr__arrow { color: rgba(8,15,28,0.35); }

.mission-pr__diff {
  display: flex; align-items: center; gap: 14px;
  font-family: var(--font-mono); font-size: 12px; line-height: 1.6;
  letter-spacing: var(--tracking-mono);
  padding: 10px 14px; background: #F5F4F2;
  border: 1px solid #E5E4E0; border-radius: 8px;
}
.mission-pr__diff-plus  { color: #1a8f4a; font-weight: 600; }
.mission-pr__diff-minus { color: #c14141; font-weight: 600; }
.mission-pr__diff-files { color: rgba(8,15,28,0.5); margin-left: auto; }

.mission-pr__section-label {
  font-family: var(--font-mono); font-size: 10.5px; font-weight: 700;
  letter-spacing: var(--tracking-wider); text-transform: uppercase;
  color: rgba(8,15,28,0.45); margin-top: 6px; line-height: 1.6;
}
.mission-pr__agents { display: flex; flex-direction: column; gap: 8px; }
.mission-pr__agent {
  display: grid; grid-template-columns: 32px 1fr auto;
  gap: 12px; align-items: center;
  padding: 10px 14px;
  background: #FBFAF7; border: 1px solid #EBEAE6; border-radius: 8px;
  line-height: 1.5;
}
.mission-pr__avatar {
  width: 32px; height: 32px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-mono); font-size: 10.5px; font-weight: 700;
  letter-spacing: var(--tracking-mono);
}
.mission-pr__avatar--teal  { background: rgba(0,196,161,0.14); color: var(--arc-teal-text); border: 1px solid rgba(0,196,161,0.35); }
.mission-pr__avatar--amber { background: rgba(220,148,54,0.14); color: #B07018;        border: 1px solid rgba(220,148,54,0.35); }

.mission-pr__agent-body { font-size: 13px; color: rgba(8,15,28,0.7); min-width: 0; line-height: 1.55; letter-spacing: 0.005em; }
.mission-pr__agent-role { font-weight: 600; color: var(--on-parch); letter-spacing: 0.01em; }
.mission-pr__agent-time {
  font-family: var(--font-mono); font-size: 10.5px;
  letter-spacing: var(--tracking-mono);
  color: rgba(8,15,28,0.45);
}

.mission-pr__checks {
  display: flex; flex-direction: column; gap: 6px;
  padding: 12px 14px; background: #FBFAF7;
  border: 1px solid #EBEAE6; border-radius: 8px;
}
.mission-pr__check {
  display: grid; grid-template-columns: 14px 1fr auto;
  gap: 10px; align-items: center;
  font-size: 12.5px; line-height: 1.55; color: var(--on-parch);
  letter-spacing: 0.005em;
}
.mission-pr__check-mark { color: var(--arc-teal-text); display: inline-flex; }
.mission-pr__check-label { color: var(--on-parch); }
.mission-pr__check-note  { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: var(--tracking-mono); color: rgba(8,15,28,0.5); }

.mission-pr__footer {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 14px; border-top: 1px solid #EBEAE6;
  font-family: var(--font-mono); font-size: 11px; line-height: 1.6;
  letter-spacing: var(--tracking-mono);
}
.mission-pr__footer-text { color: rgba(8,15,28,0.45); }
.mission-pr__footer-link { color: var(--arc-teal-text); font-weight: 500; }

@media (max-width: 640px) {
  .mission-pr { padding: 20px; gap: 10px; }
  .mission-pr__title { font-size: 16px; }
}

/* =========================================================================
   MISSION508 — agent handoff flow diagram (steps section)
   ========================================================================= */
.steps__visual { width: 100%; }

.mission-flow {
  display: grid;
  grid-template-columns: 1fr 60px 1fr 60px 1fr;
  gap: 8px;
  align-items: stretch;
  width: 100%;
}
.mission-flow__node {
  background: #fff;
  border: 1px solid #EBEAE6;
  border-radius: 14px;
  padding: 18px 16px;
  box-shadow: 0 8px 24px -12px rgba(0,0,0,0.12);
  display: flex; flex-direction: column; gap: 8px;
}
.mission-flow__node--pr {
  background: #FBFAF7;
  border-style: dashed;
}
.mission-flow__avatar {
  width: 36px; height: 36px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-mono); font-size: 11px; font-weight: 700;
  letter-spacing: var(--tracking-mono);
}
.mission-flow__avatar--teal  { background: rgba(0,196,161,0.14); color: var(--arc-teal-text); border: 1px solid rgba(0,196,161,0.35); }
.mission-flow__avatar--amber { background: rgba(220,148,54,0.14); color: #B07018;        border: 1px solid rgba(220,148,54,0.35); }

.mission-flow__pr-chip {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(0, 196, 161, 0.14); color: var(--arc-teal-text);
  border: 1px solid rgba(0, 196, 161, 0.38);
  padding: 4px 9px; border-radius: 999px;
  font-family: var(--font-mono); font-size: 10.5px; font-weight: 600;
  letter-spacing: var(--tracking-wide); text-transform: uppercase;
  align-self: flex-start;
}

.mission-flow__node-role {
  font-size: 14px; font-weight: 600; color: var(--on-parch);
}
.mission-flow__node-task {
  font-size: 12.5px; line-height: 1.45;
  color: rgba(8,15,28,0.6);
}
.mission-flow__node-state {
  font-family: var(--font-mono); font-size: 10px; font-weight: 500;
  letter-spacing: var(--tracking-wide); text-transform: uppercase;
  padding: 4px 8px; border-radius: 4px;
  display: inline-flex; align-items: center; gap: 6px;
  align-self: flex-start; margin-top: auto;
}
.mission-flow__node-state--teal   { background: rgba(0,196,161,0.14); color: var(--arc-teal-text); border: 1px solid rgba(0,196,161,0.35); }
.mission-flow__node-state--muted  { background: rgba(8,15,28,0.05); color: rgba(8,15,28,0.55); border: 1px solid #E5E4E0; }
.mission-flow__node-state--merged { background: rgba(0,196,161,0.14); color: var(--arc-teal-text); border: 1px solid rgba(0,196,161,0.38); }

.mission-flow__arrow {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  color: rgba(8,15,28,0.35);
}
.mission-flow__arrow svg { width: 100%; height: 20px; }
.mission-flow__arrow-label {
  font-family: var(--font-mono); font-size: 9.5px;
  letter-spacing: var(--tracking-wide); text-transform: uppercase;
  color: rgba(8,15,28,0.45);
  margin-bottom: 4px; text-align: center;
}

@media (max-width: 900px) {
  .mission-flow {
    grid-template-columns: 1fr;
    gap: 4px;
  }
  .mission-flow__arrow {
    transform: rotate(90deg);
    height: 40px;
  }
}

/* =========================================================================
   Legacy MISSION508 task queue styles (unused, kept for back-compat)
   ========================================================================= */
.mission-mock__tasks .task {
  transition: background .25s;
}
.mission-mock__tasks .task--running {
  background: rgba(0, 196, 161, 0.05);
  border-color: var(--teal-border);
}

.task__badge {
  font-family: var(--font-mono); font-size: 9.5px; font-weight: 500;
  padding: 2px 7px; border-radius: 3px;
  white-space: nowrap; flex-shrink: 0; margin-top: 1px;
  letter-spacing: var(--tracking-mono); text-transform: uppercase;
  display: inline-flex; align-items: center; gap: 6px;
}
.task__badge--running {
  background: rgba(0, 196, 161, 0.14);
  color: var(--arc-teal-text);
  border: 1px solid var(--teal-border);
}
.task__badge--review {
  background: rgba(240, 237, 232, 0.07);
  color: var(--parchment);
  border: 1px solid rgba(240, 237, 232, 0.14);
}
.task__badge--queued {
  background: rgba(240, 237, 232, 0.03);
  color: var(--muted-void);
  border: 1px solid rgba(240, 237, 232, 0.08);
}

.task__spinner {
  width: 7px; height: 7px; border-radius: 50%;
  background: transparent;
  border: 1.5px solid var(--arc-teal);
  border-top-color: transparent;
  animation: task-spin 0.9s linear infinite;
}
@keyframes task-spin { to { transform: rotate(360deg); } }

.task__agent {
  font-family: var(--font-mono); font-size: 10px;
  color: var(--arc-teal-text); margin-left: 8px;
  padding: 1px 6px; border-radius: 3px;
  background: rgba(0, 196, 161, 0.08);
  border: 1px solid var(--teal-border);
}

/* =========================================================================
   STATION508. VPAT document preview
   ========================================================================= */
.station-mock__doc {
  padding: 16px;
  background:
    linear-gradient(180deg, rgba(240, 237, 232, 0.02), rgba(240, 237, 232, 0.01));
}
.station-mock__page {
  position: relative;
  background: #FBFAF7;
  color: var(--on-parch);
  border-radius: var(--r-md);
  padding: 22px 22px 26px;
  border: 1px solid rgba(240, 237, 232, 0.08);
  box-shadow: 0 18px 32px -18px rgba(0, 0, 0, 0.45);
  overflow: hidden;
}
.station-mock__doctitle {
  font-family: var(--font-display);
  font-size: 18px; line-height: 1.2;
  color: var(--on-parch);
  letter-spacing: -0.01em;
  margin-bottom: 3px;
}
.station-mock__docsub {
  font-family: var(--font-mono); font-size: 10px;
  color: var(--muted-parch); letter-spacing: var(--tracking-wide); text-transform: uppercase;
  padding-bottom: 12px; margin-bottom: 12px;
  border-bottom: 1px solid var(--parchment-300);
}
.station-mock__meta {
  display: grid; grid-template-columns: minmax(110px, auto) 1fr; gap: 6px 20px;
  margin: 0 0 16px;
  font-family: var(--font-mono); font-size: 10.5px;
}
.station-mock__meta dt { color: var(--muted-parch); letter-spacing: var(--tracking-wide); text-transform: uppercase; white-space: nowrap; }
.station-mock__meta dd { margin: 0; color: var(--on-parch); }

.station-mock__thead {
  display: grid; grid-template-columns: 56px 1fr 88px;
  gap: 16px;
  padding: 8px 0;
  font-family: var(--font-mono); font-size: 9.5px;
  color: var(--muted-parch); letter-spacing: var(--tracking-wide); text-transform: uppercase;
  border-bottom: 1px solid var(--parchment-300);
}
.station-mock__tbody { display: flex; flex-direction: column; }
.station-mock__row {
  display: grid; grid-template-columns: 56px 1fr 88px;
  gap: 16px; align-items: center;
  padding: 8px 0;
  border-bottom: 1px dashed rgba(17, 30, 53, 0.08);
  font-size: 11.5px;
}
.station-mock__row:last-child { border-bottom: none; }
.station-mock__crit {
  font-family: var(--font-mono); font-size: 11px;
  color: var(--arc-teal-text); font-weight: 500;
}
.station-mock__desc { color: var(--on-parch); letter-spacing: 0.02em; }
.station-mock__conf {
  font-family: var(--font-mono); font-size: 9.5px;
  letter-spacing: var(--tracking-wide); text-transform: uppercase;
  padding: 2px 6px; border-radius: 3px;
  text-align: center;
}
.station-mock__conf--supports {
  color: var(--arc-teal-text);
  background: rgba(0, 196, 161, 0.10);
  border: 1px solid rgba(0, 196, 161, 0.32);
}
.station-mock__conf--partial {
  color: var(--arc-teal-text);
  background: rgba(0, 196, 161, 0.05);
  border: 1px solid rgba(0, 196, 161, 0.22);
  opacity: 0.82;
}
.station-mock__conf--no {
  color: var(--risk-orange-text);
  background: rgba(217, 119, 6, 0.08);
  border: 1px solid rgba(217, 119, 6, 0.28);
}

/* Stamp watermark */
.station-mock__stamp {
  position: absolute;
  right: 18px; bottom: 16px;
  width: 78px; height: 78px;
  display: grid; place-items: center;
  opacity: 0.18;
  transform: rotate(-8deg);
  pointer-events: none;
}
.station-mock__stamp-ring {
  position: absolute; inset: 0;
  border: 2px solid var(--arc-teal);
  border-radius: 50%;
}
.station-mock__stamp-ring::before {
  content: '';
  position: absolute; inset: 4px;
  border: 1px dashed var(--arc-teal);
  border-radius: 50%;
}
.station-mock__stamp-text {
  position: relative;
  font-family: var(--font-mono); font-size: 7.5px;
  color: var(--arc-teal); letter-spacing: var(--tracking-wide);
  text-align: center; line-height: 1.1;
  max-width: 56px;
}

/* =========================================================================
   SENTINEL508. monitoring dashboard
   ========================================================================= */
.sentinel-mock__chart {
  padding: 14px 16px 10px;
  border-bottom: 1px solid rgba(240, 237, 232, 0.06);
}
.sentinel-mock__chart-head {
  display: flex; align-items: center; justify-content: space-between;
  font-family: var(--font-mono); font-size: 10px;
  color: var(--muted-void); letter-spacing: var(--tracking-wide); text-transform: uppercase;
  margin-bottom: 10px;
}
.sentinel-mock__bars {
  display: grid;
  grid-template-columns: repeat(24, 1fr);
  gap: 3px;
  align-items: end;
  height: 72px;
  padding-bottom: 6px;
  border-bottom: 1px solid rgba(240, 237, 232, 0.06);
}
.sentinel-mock__bar {
  display: block;
  min-height: 6px;
  background: linear-gradient(180deg, var(--arc-teal), rgba(0, 196, 161, 0.35));
  border-radius: 2px 2px 0 0;
  opacity: 0.85;
  transition: opacity .2s;
}
.sentinel-mock__bar:hover { opacity: 1; }
.sentinel-mock__bar--flag {
  background: linear-gradient(180deg, var(--ember), rgba(217, 119, 6, 0.4));
  opacity: 1;
}
.sentinel-mock__chart-axis {
  font-family: var(--font-mono); font-size: 9.5px;
  color: var(--muted-void); letter-spacing: var(--tracking-wide);
}
.sentinel-mock__chart-axis--bottom {
  display: flex; justify-content: space-between;
  margin-top: 6px;
}

.sentinel-mock__alerts { gap: 6px; }

/* --- Responsive ---- */
@media (max-width: 900px) {
  .station-mock__thead { grid-template-columns: 48px 1fr 76px; gap: 12px; font-size: 9px; }
  .station-mock__row   { grid-template-columns: 48px 1fr 76px; gap: 12px; font-size: 11px; }
  .station-mock__meta  { grid-template-columns: minmax(96px, auto) 1fr; }
  .sentinel-mock__bars { height: 56px; }
}
