/* Call Goblin — refined editorial direction */
:root {
  --cream: #F2EFE6;
  --cream-2: #ECE7D8;
  --paper: #FBF9F2;
  --ink: #0E120F;
  --ink-2: #1A1F1B;
  --ink-3: #404742;
  --mute: #6B736C;
  --line: #DCD5C2;
  --line-2: #E6E1D2;
  --emerald: #1B6E3A;
  --emerald-2: #145129;
  --lime: #5BE05B;
  --lime-soft: #E6FAD6;
  --tangerine: #E26B2C;
  --tangerine-soft: #FBE3CC;
  --danger: #B53A2B;
  --shadow-soft: 0 1px 0 rgba(14, 18, 15, .04), 0 12px 30px -18px rgba(14, 18, 15, .18);
  --shadow-card: 0 1px 0 rgba(14, 18, 15, .06), 0 30px 60px -32px rgba(14, 18, 15, .28);
  --radius-sm: 10px;
  --radius: 18px;
  --radius-lg: 28px;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: 'Geist', ui-sans-serif, system-ui, sans-serif;
  background: var(--cream);
  color: var(--ink);
  font-size: 15px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-feature-settings: "ss01", "cv11";
}
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: none; background: none; padding: 0; color: inherit; }
input, textarea, select { font: inherit; color: inherit; }
::selection { background: var(--lime); color: var(--ink); }

.serif { font-family: 'Instrument Serif', 'Times New Roman', serif; font-weight: 400; letter-spacing: -0.01em; }
.mono { font-family: 'JetBrains Mono', ui-monospace, monospace; font-feature-settings: "ss02"; }

/* ───── shell ───── */
.shell {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 28px;
}

/* ───── top bar ───── */
.topbar {
  position: sticky; top: 0; z-index: 30;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 20px;
  padding: 18px 0;
  background: linear-gradient(180deg, var(--cream) 70%, rgba(242,239,230,0) 100%);
}
.brand { display: inline-flex; align-items: center; gap: 12px; }
.brand-mark {
  width: 44px; height: 44px;
  display: grid; place-items: center;
  overflow: visible;
}
.brand-mark img {
  width: 100%; height: 100%;
  object-fit: contain;
  display: block;
}
.brand-name { display: flex; flex-direction: column; line-height: 1; }
.brand-name b { font-weight: 600; font-size: 17px; letter-spacing: -0.01em; text-transform: none; white-space: nowrap; }
.brand-name > span { font-size: 11px; color: var(--mute); margin-top: 4px; letter-spacing: 0.04em; text-transform: uppercase; white-space: nowrap; }

.nav { display: flex; justify-content: center; gap: 18px; }
.nav button { font-size: 13.5px; color: var(--ink-3); font-weight: 500; padding: 6px 0; position: relative; white-space: nowrap; }
.nav button:hover { color: var(--ink); }
.nav button.active { color: var(--ink); }
.nav button.active::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -6px;
  height: 2px; background: var(--lime); border-radius: 2px;
}

.top-actions { display: flex; gap: 8px; align-items: center; }
.status-chip {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 11px 6px 9px;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 999px;
  font-size: 11.5px;
  font-weight: 500;
  color: var(--ink-3);
  white-space: nowrap;
}
.dot { width: 7px; height: 7px; border-radius: 50%; background: var(--emerald); box-shadow: 0 0 0 3px rgba(27,110,58,.18); }
.dot.live { background: var(--lime); box-shadow: 0 0 0 3px rgba(91,224,91,.25); animation: pulse 1.6s ease-in-out infinite; }
@keyframes pulse { 0%,100% { opacity: 1 } 50% { opacity: .55 } }

/* ───── buttons ───── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 11px 16px;
  border-radius: 999px;
  font-weight: 500; font-size: 13.5px;
  background: var(--paper);
  border: 1px solid var(--line);
  color: var(--ink);
  transition: transform .15s, background .15s, border-color .15s, box-shadow .15s;
  white-space: nowrap;
}
.btn:hover { background: #fff; border-color: #c8c2af; }
.btn.primary { background: var(--ink); color: var(--cream); border-color: var(--ink); }
.btn.primary:hover { background: var(--ink-2); transform: translateY(-1px); box-shadow: 0 12px 24px -10px rgba(14,18,15,.4); }
.btn.lime { background: var(--lime); color: var(--ink); border-color: var(--lime); }
.btn.lime:hover { background: #6fec6f; transform: translateY(-1px); box-shadow: 0 12px 24px -10px rgba(91,224,91,.6); }
.btn.large { padding: 14px 22px; font-size: 14.5px; border-radius: 999px; }
.btn.ghost { background: transparent; border-color: var(--line); }
.btn.icon-only { width: 38px; height: 38px; padding: 0; border-radius: 50%; }
.btn .arrow { font-family: 'Instrument Serif', serif; font-size: 19px; line-height: 1; }

/* ───── hero ───── */
.hero {
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 36px;
  padding: 28px 0 56px;
  align-items: start;
}
.eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 11.5px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--emerald);
  white-space: nowrap;
}
.eyebrow .bar { width: 28px; height: 1px; background: var(--emerald); }
.headline {
  font-family: 'Instrument Serif', serif;
  font-weight: 400;
  font-size: clamp(48px, 6.4vw, 96px);
  line-height: 1.05;
  letter-spacing: -0.022em;
  margin: 20px 0 0;
  color: var(--ink);
}
.headline em { padding-bottom: .08em; }
.headline em { font-style: italic; color: var(--emerald); }
.headline .strike { position: relative; display: inline-block; }
.headline .strike::after {
  content: ""; position: absolute; left: -2%; right: -2%; top: 56%;
  height: 3px; background: var(--tangerine); transform: rotate(-2deg); opacity: .92;
}
.hero-sub {
  font-size: 16px; line-height: 1.55; max-width: 520px;
  color: var(--ink-3); margin: 48px 0 0;
}
.hero-cta { display: flex; gap: 12px; margin-top: 32px; flex-wrap: wrap; }
.hero-meta {
  margin-top: 28px;
  display: flex; gap: 28px; flex-wrap: wrap;
  font-size: 12px; color: var(--mute);
}
.hero-meta b { color: var(--ink); font-weight: 600; }

/* ───── mission radar ───── */
.radar {
  position: relative;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 26px 22px 22px;
  box-shadow: var(--shadow-card);
  display: flex; flex-direction: column;
  min-height: 540px;
}
.radar::before {
  content: ""; position: absolute; inset: -1px;
  border-radius: var(--radius-lg);
  background: linear-gradient(140deg, transparent 40%, rgba(91,224,91,.15) 60%, transparent 80%);
  pointer-events: none;
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  padding: 1px;
}
.radar-header { display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.radar-call {
  display: flex; align-items: center; gap: 12px;
  min-width: 0; flex: 1;
}
.radar-call-avatar {
  width: 38px; height: 38px; border-radius: 50%;
  background: var(--emerald); color: var(--cream);
  display: grid; place-items: center;
  font-family: 'Instrument Serif', serif; font-size: 18px;
}
.radar-call h4 { margin: 0; font-size: 13.5px; font-weight: 600; letter-spacing: -0.005em; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.radar-call p { margin: 2px 0 0; font-size: 11.5px; color: var(--mute); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.radar-call > div { min-width: 0; }
.radar-time {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; color: var(--ink-3); letter-spacing: 0.02em;
  white-space: nowrap; flex-shrink: 0;
}

.radar-mission {
  margin-top: 18px;
  padding: 14px 16px;
  background: var(--cream);
  border-radius: var(--radius);
  border: 1px solid var(--line-2);
}
.radar-mission-label {
  font-size: 10.5px; letter-spacing: .12em; text-transform: uppercase;
  color: var(--mute); font-weight: 600;
}
.radar-mission h3 {
  font-family: 'Instrument Serif', serif;
  font-weight: 400;
  font-size: 22px; line-height: 1.2;
  margin: 6px 0 12px;
  letter-spacing: -0.01em;
}
.radar-mission p { margin: 0; font-size: 13px; color: var(--ink-3); }

.transcript {
  margin-top: 16px;
  flex: 1;
  display: flex; flex-direction: column; gap: 10px;
  overflow: hidden;
  position: relative;
}
.transcript::after {
  content: ""; position: absolute; left: 0; right: 0; top: 0; height: 22px;
  background: linear-gradient(180deg, var(--paper), transparent);
  pointer-events: none;
}
.t-row {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 10px;
  font-size: 13px;
}
.t-row.new {
  animation: fadeUp .45s ease forwards;
}
@keyframes fadeUp { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.t-time { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--mute); padding-top: 2px; }
.t-content { color: var(--ink-2); }
.t-content .speaker { font-size: 10.5px; font-weight: 600; text-transform: uppercase; letter-spacing: .08em; color: var(--mute); margin-right: 8px; }
.t-content .speaker.agent { color: var(--emerald); }
.t-content .speaker.them { color: var(--tangerine); }
.t-content .speaker.system { color: var(--ink); }
.t-tag {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--lime-soft);
  border: 1px solid #c4ec9c;
  color: var(--emerald-2);
  font-size: 11px; font-weight: 600;
  padding: 4px 8px; border-radius: 999px; margin-top: 6px;
}
.t-tag.warn { background: var(--tangerine-soft); border-color: #f0c194; color: #8a3f15; }
.t-tag.ask {
  background: #fff; border-color: var(--line);
  color: var(--ink);
}
.ask-card {
  margin-top: 4px;
  border: 1px solid var(--ink);
  border-radius: 14px;
  padding: 12px 14px;
  background: var(--paper);
  box-shadow: 0 6px 14px -8px rgba(14,18,15,.25);
}
.ask-card h5 { margin: 0; font-size: 13px; font-weight: 600; }
.ask-card .small { font-size: 11.5px; color: var(--mute); margin: 4px 0 10px; }
.ask-card-actions { display: flex; gap: 8px; }
.ask-card .btn { padding: 7px 12px; font-size: 12.5px; }

.radar-footer {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px dashed var(--line);
}
.wave {
  display: inline-flex; align-items: center; gap: 3px; height: 22px;
}
.wave span {
  width: 2.5px; height: 6px; background: var(--emerald);
  border-radius: 2px; animation: wave 1.2s ease-in-out infinite;
}
@keyframes wave { 0%,100%{ height: 4px } 50%{ height: 18px } }
.wave span:nth-child(1) { animation-delay: 0s }
.wave span:nth-child(2) { animation-delay: .1s }
.wave span:nth-child(3) { animation-delay: .2s }
.wave span:nth-child(4) { animation-delay: .3s }
.wave span:nth-child(5) { animation-delay: .4s }
.wave span:nth-child(6) { animation-delay: .5s }
.wave span:nth-child(7) { animation-delay: .6s }
.wave span:nth-child(8) { animation-delay: .7s }
.wave span:nth-child(9) { animation-delay: .8s }
.wave span:nth-child(10) { animation-delay: .9s }
.wave span:nth-child(11) { animation-delay: 1s }
.wave span:nth-child(12) { animation-delay: 1.1s }

.radar-controls { display: inline-flex; gap: 6px; align-items: center; }
.scrub-btn {
  width: 30px; height: 30px; border-radius: 50%;
  border: 1px solid var(--line); background: var(--paper);
  display: grid; place-items: center; font-size: 12px;
}
.scrub-btn:hover { background: #fff; }

.radar-tabs {
  position: absolute; top: -16px; left: 24px;
  display: inline-flex; gap: 2px;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 999px; padding: 3px;
  font-size: 11px;
  box-shadow: var(--shadow-soft);
}
.radar-tabs button {
  padding: 5px 11px; border-radius: 999px;
  color: var(--ink-3); font-weight: 500;
  white-space: nowrap;
}
.radar-tabs button.active { background: var(--ink); color: var(--cream); }

/* mission tree visualization */
.tree {
  margin-top: 16px; flex: 1;
  display: flex; flex-direction: column; gap: 6px;
  font-family: 'JetBrains Mono', monospace; font-size: 12px;
}
.tree-row {
  display: grid; grid-template-columns: auto 1fr auto; gap: 10px; align-items: center;
  padding: 8px 10px; border-radius: 10px;
  color: var(--ink-3);
}
.tree-row.done { background: rgba(27,110,58,.06); color: var(--emerald-2); }
.tree-row.active { background: var(--ink); color: var(--lime); }
.tree-row.queued { color: var(--mute); }
.tree-num {
  font-size: 10px; opacity: .7;
}
.tree-row .pill {
  font-size: 10px; padding: 2px 7px; border-radius: 999px;
  background: rgba(0,0,0,.06);
}
.tree-row.active .pill { background: rgba(91,224,91,.15); color: var(--lime); }
.tree-row.done .pill { background: rgba(27,110,58,.12); color: var(--emerald-2); }

/* ───── section ───── */
.section { padding: 80px 0; }
.section-head { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 36px; gap: 40px; }
.section-head h2 {
  font-family: 'Instrument Serif', serif; font-weight: 400;
  font-size: clamp(36px, 4.6vw, 60px); line-height: 1.02; margin: 8px 0 0;
  letter-spacing: -0.02em;
  max-width: 720px;
}
.section-head h2 em { font-style: italic; color: var(--emerald); }
.section-head p { color: var(--ink-3); max-width: 360px; margin: 0; font-size: 14px; }

/* how it works */
.steps {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  position: relative;
}
.step-card {
  position: relative;
  padding: 28px 24px 28px;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  display: flex; flex-direction: column;
  min-height: 320px;
  overflow: hidden;
}
.step-card.dark { background: var(--ink); color: var(--cream); border-color: var(--ink); }
.step-card .num {
  font-family: 'Instrument Serif', serif; font-style: italic;
  font-size: 56px; line-height: 1; color: var(--emerald);
  letter-spacing: -0.03em;
}
.step-card.dark .num { color: var(--lime); }
.step-card h3 {
  font-family: 'Instrument Serif', serif; font-weight: 400;
  font-size: 26px; line-height: 1.1; letter-spacing: -0.01em;
  margin: 16px 0 8px;
}
.step-card p { font-size: 13.5px; color: var(--ink-3); margin: 0; }
.step-card.dark p { color: rgba(242,239,230,.7); }
.step-card .step-visual { margin-top: auto; padding-top: 20px; }

/* mini intake illustration in step 1 */
.intake-chip {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--cream); border: 1px solid var(--line);
  border-radius: 999px; padding: 6px 11px;
  font-size: 11.5px; font-weight: 500;
  margin: 0 6px 6px 0;
}
.intake-chip.active { background: var(--ink); color: var(--lime); border-color: var(--ink); }

/* boundaries dial */
.dial {
  display: grid; gap: 6px;
}
.dial-row {
  display: grid; grid-template-columns: 1fr auto; gap: 8px; align-items: center;
  font-size: 12px;
}
.dial-track {
  position: relative;
  background: rgba(242,239,230,.12);
  border-radius: 999px; height: 6px;
}
.dial-track.light { background: rgba(14,18,15,.08); }
.dial-fill {
  position: absolute; left: 0; top: 0; bottom: 0;
  border-radius: 999px;
  background: var(--lime);
}
.dial-fill.gate { background: var(--tangerine); }

/* proof envelope */
.proof {
  background: var(--cream);
  border: 1px solid var(--line-2);
  border-radius: 14px;
  padding: 12px 14px;
}
.proof-row { display: flex; justify-content: space-between; font-size: 11.5px; color: var(--ink-3); padding: 4px 0; }
.proof-row b { color: var(--ink); font-weight: 600; }

/* ───── trust pillars ───── */
.pillars {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
  border: 1px solid var(--line); border-radius: var(--radius);
  overflow: hidden;
  background: var(--paper);
}
.pillar {
  padding: 32px 28px;
  border-right: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 14px;
}
.pillar:last-child { border-right: none; }
.pillar-head {
  display: flex; align-items: center; gap: 12px;
}
.pillar-tag {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px; letter-spacing: 0.08em; text-transform: uppercase;
  padding: 4px 9px; border-radius: 999px;
  background: var(--lime-soft); color: var(--emerald-2);
  border: 1px solid #c4ec9c;
  white-space: nowrap;
}
.pillar-tag.warn { background: var(--tangerine-soft); color: #8a3f15; border-color: #f0c194; }
.pillar-tag.never { background: #2a1c1c; color: #ffb8a8; border-color: transparent; }
.pillar h3 {
  font-family: 'Instrument Serif', serif; font-weight: 400;
  font-size: 24px; letter-spacing: -0.01em; margin: 0 0 4px; line-height: 1.15;
}
.pillar ul { list-style: none; padding: 0; margin: 6px 0 0; display: grid; gap: 12px; }
.pillar li {
  font-size: 13.5px; color: var(--ink-3);
  padding-left: 18px; position: relative;
}
.pillar li::before {
  content: ""; position: absolute; left: 0; top: 8px;
  width: 8px; height: 8px;
  border: 1px solid var(--ink-3);
  border-radius: 2px;
}
.pillar.allow li::before { background: var(--lime); border-color: var(--emerald-2); }
.pillar.ask li::before { background: var(--tangerine); border-color: #8a3f15; border-radius: 50%; }
.pillar.never li::before { background: transparent; border-style: dashed; }

/* ───── pricing ───── */
.price-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px;
}
.price-card {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 28px 24px;
  display: flex; flex-direction: column;
  position: relative;
}
.price-card.featured { background: var(--ink); color: var(--cream); border-color: var(--ink); }
.price-card .tier {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--mute);
}
.price-card.featured .tier { color: var(--lime); }
.price-card h3 {
  font-family: 'Instrument Serif', serif; font-weight: 400;
  font-size: 30px; letter-spacing: -0.015em; margin: 8px 0 0;
}
.price-amount {
  display: flex; align-items: flex-end; gap: 4px;
  margin: 20px 0 4px;
  font-family: 'Instrument Serif', serif; letter-spacing: -0.02em;
  line-height: 1;
}
.price-amount .n { font-size: 52px; line-height: .9; }
.price-amount .per { font-size: 13px; color: var(--mute); font-family: 'Geist', sans-serif; font-weight: 500; padding-bottom: 6px; white-space: nowrap; }
.price-card.featured .per { color: rgba(242,239,230,.6); }
.price-card .minutes { font-size: 12.5px; color: var(--ink-3); }
.price-card.featured .minutes { color: rgba(242,239,230,.75); }
.price-card ul {
  list-style: none; padding: 0; margin: 20px 0; display: grid; gap: 10px;
  border-top: 1px solid var(--line); padding-top: 18px;
}
.price-card.featured ul { border-top-color: rgba(242,239,230,.18); }
.price-card li { font-size: 13px; color: var(--ink-3); display: flex; gap: 8px; }
.price-card.featured li { color: rgba(242,239,230,.85); }
.price-card li::before { content: "→"; color: var(--emerald); font-family: 'Geist', sans-serif; font-weight: 600; flex-shrink: 0; }
.price-card.featured li::before { color: var(--lime); }
.price-card .btn { margin-top: auto; }

.billing-toggle {
  display: inline-flex; padding: 4px; background: var(--paper); border: 1px solid var(--line);
  border-radius: 999px; font-size: 12.5px;
}
.billing-toggle button { padding: 7px 14px; border-radius: 999px; color: var(--ink-3); font-weight: 500; }
.billing-toggle button.active { background: var(--ink); color: var(--cream); }
.save-tag {
  margin-left: 6px; padding: 2px 7px; border-radius: 999px;
  background: var(--lime); color: var(--ink);
  font-size: 10px; font-weight: 600;
}

.featured-tag {
  position: absolute; top: 18px; right: 18px;
  background: var(--lime); color: var(--ink);
  font-family: 'JetBrains Mono', monospace;
  font-size: 9.5px; letter-spacing: 0.08em;
  padding: 4px 8px; border-radius: 999px;
  white-space: nowrap;
}

/* ───── dashboard view ───── */
.dash-shell {
  display: grid; grid-template-columns: 200px 1fr;
  gap: 18px;
  padding: 24px 0;
}
.dash-side {
  background: var(--paper); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 18px;
  position: sticky; top: 90px; height: fit-content;
}
.dash-side-section {
  font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--mute); margin: 18px 0 6px;
}
.dash-side-item {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 10px; border-radius: 10px;
  font-size: 13.5px; color: var(--ink-3);
  width: 100%;
}
.dash-side-item:hover { background: var(--cream-2); color: var(--ink); }
.dash-side-item.active { background: var(--ink); color: var(--cream); }
.dash-side-item .num { margin-left: auto; font-size: 11px; opacity: .7; }

.dash-main { display: grid; gap: 18px; }
.dash-stat-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.stat {
  background: var(--paper); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 14px;
}
.stat-label { font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--mute); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.stat-value { font-family: 'Instrument Serif', serif; font-size: 30px; letter-spacing: -0.01em; margin-top: 6px; line-height: 1; white-space: nowrap; }
.stat-helper { font-size: 11px; color: var(--ink-3); margin-top: 6px; line-height: 1.4; }
.stat-spark { margin-top: 12px; height: 28px; }

.dash-cols { display: grid; grid-template-columns: 1fr; gap: 18px; align-items: start; }
@media (min-width: 1100px) {
  .dash-cols { grid-template-columns: 1.4fr 1fr; }
}

.panel {
  background: var(--paper); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 22px;
}
.panel-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; }
.panel-head h3 {
  font-family: 'Instrument Serif', serif; font-weight: 400; font-size: 24px;
  letter-spacing: -0.01em; margin: 0;
}
.panel-head .sub { font-size: 12px; color: var(--mute); }

.mission-row {
  display: grid; grid-template-columns: auto 1fr auto;
  grid-template-rows: auto auto;
  gap: 4px 12px;
  align-items: center;
  padding: 14px 0;
  border-top: 1px solid var(--line-2);
  cursor: pointer;
}
.mission-status { grid-row: span 2; }
.mission-info { grid-row: span 2; }
.mission-tag { justify-self: end; }
.mission-row:first-of-type { border-top: 1px solid var(--line); }
.mission-row:hover { background: var(--cream); margin: 0 -8px; padding-left: 8px; padding-right: 8px; border-radius: 12px; border-top-color: transparent; }
.mission-row + .mission-row:hover { border-top-color: transparent; }
.mission-status {
  width: 8px; height: 8px; border-radius: 50%; background: var(--mute);
}
.mission-status.live { background: var(--lime); box-shadow: 0 0 0 4px rgba(91,224,91,.2); animation: pulse 1.6s ease-in-out infinite; }
.mission-status.done { background: var(--emerald); }
.mission-status.ask { background: var(--tangerine); }
.mission-status.queue { background: var(--mute); }
.mission-info h4 { margin: 0; font-size: 14.5px; font-weight: 500; letter-spacing: -0.005em; }
.mission-info p { margin: 2px 0 0; font-size: 12px; color: var(--mute); }
.mission-tag {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px; padding: 3px 8px; border-radius: 999px;
  background: var(--cream); border: 1px solid var(--line); color: var(--ink-3);
}
.mission-tag.live { background: var(--ink); color: var(--lime); border-color: var(--ink); }
.mission-tag.ask { background: var(--tangerine-soft); color: #8a3f15; border-color: #f0c194; }
.mission-tag.done { background: var(--lime-soft); color: var(--emerald-2); border-color: #c4ec9c; }
.mission-time { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--mute); }

/* approvals queue */
.approval {
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 14px 16px;
  background: var(--cream);
  margin-bottom: 12px;
}
.approval-head { display: flex; justify-content: space-between; gap: 12px; }
.approval-head h4 { margin: 0; font-size: 14px; font-weight: 500; }
.approval-head .from { font-size: 11px; color: var(--mute); }
.approval-quote {
  font-family: 'Instrument Serif', serif; font-style: italic;
  font-size: 17px; line-height: 1.3; margin: 10px 0;
  letter-spacing: -0.005em;
  color: var(--ink);
}
.approval-meta { font-size: 11px; color: var(--mute); display: flex; gap: 14px; }
.approval-actions { display: flex; gap: 8px; margin-top: 12px; }
.approval-actions .btn { padding: 8px 13px; font-size: 12.5px; }

/* wizard */
.wizard {
  background: var(--paper); border: 1px solid var(--line);
  border-radius: var(--radius-lg); padding: 28px;
  max-width: 880px; margin: 0 auto;
}
.wiz-stepper { display: flex; gap: 4px; margin-bottom: 28px; }
.wiz-step {
  flex: 1; padding: 10px 14px;
  border-radius: 12px;
  background: var(--cream);
  border: 1px solid var(--line);
  display: flex; align-items: center; gap: 10px;
  font-size: 12.5px; color: var(--ink-3);
}
.wiz-step.active { background: var(--ink); color: var(--cream); border-color: var(--ink); }
.wiz-step.done { background: var(--lime-soft); color: var(--emerald-2); border-color: #c4ec9c; }
.wiz-step .stepnum {
  font-family: 'JetBrains Mono', monospace; font-size: 10.5px;
  width: 18px; height: 18px; border-radius: 50%; background: var(--paper);
  display: grid; place-items: center; color: var(--ink-3);
  border: 1px solid var(--line);
}
.wiz-step.active .stepnum { background: var(--lime); color: var(--ink); border-color: var(--lime); }
.wiz-step.done .stepnum { background: var(--emerald); color: var(--cream); border-color: var(--emerald); }
.wiz-body { min-height: 340px; }
.wiz-title { font-family: 'Instrument Serif', serif; font-weight: 400; font-size: 36px; letter-spacing: -0.015em; margin: 0; }
.wiz-sub { font-size: 14px; color: var(--ink-3); margin: 8px 0 24px; }

.field { display: grid; gap: 6px; margin-bottom: 16px; }
.field label { font-size: 12px; font-weight: 500; color: var(--ink-3); }
.field .req { color: var(--tangerine); }
.field input, .field textarea, .field select {
  width: 100%; padding: 12px 14px;
  background: var(--paper); border: 1px solid var(--line);
  border-radius: 12px;
  font-size: 14px;
  outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.field input:focus, .field textarea:focus, .field select:focus {
  border-color: var(--ink); box-shadow: 0 0 0 4px rgba(14,18,15,.06);
}
.field textarea { min-height: 96px; resize: vertical; font-family: inherit; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }

.scenario-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px;
}
.scenario {
  background: var(--paper); border: 1px solid var(--line);
  border-radius: 14px; padding: 14px;
  text-align: left;
  display: flex; flex-direction: column; gap: 6px;
  transition: border-color .15s, background .15s;
}
.scenario:hover { border-color: var(--ink-3); }
.scenario.active { border-color: var(--ink); background: var(--ink); color: var(--cream); }
.scenario .emoji-like {
  width: 28px; height: 28px; border-radius: 8px;
  background: var(--lime-soft); border: 1px solid #c4ec9c;
  display: grid; place-items: center;
  font-family: 'Instrument Serif', serif; font-style: italic; color: var(--emerald-2);
  font-size: 16px;
}
.scenario.active .emoji-like { background: var(--ink-2); border-color: var(--ink-2); color: var(--lime); }
.scenario h5 { margin: 4px 0 0; font-size: 13.5px; font-weight: 500; letter-spacing: -0.005em; }
.scenario p { margin: 0; font-size: 11.5px; color: var(--mute); line-height: 1.4; }
.scenario.active p { color: rgba(242,239,230,.7); }

.toggle-list { display: grid; gap: 8px; }
.toggle-item {
  display: grid; grid-template-columns: 1fr auto; gap: 10px;
  align-items: center;
  padding: 12px 14px;
  background: var(--paper); border: 1px solid var(--line);
  border-radius: 12px;
}
.toggle-item h5 { margin: 0; font-size: 13px; font-weight: 500; }
.toggle-item p { margin: 2px 0 0; font-size: 11.5px; color: var(--mute); }
.toggle {
  width: 36px; height: 20px; border-radius: 999px;
  background: var(--line); position: relative;
  transition: background .2s;
}
.toggle::after {
  content: ""; position: absolute; top: 2px; left: 2px;
  width: 16px; height: 16px; border-radius: 50%; background: var(--paper);
  transition: transform .2s;
  box-shadow: 0 1px 3px rgba(0,0,0,.2);
}
.toggle.on { background: var(--ink); }
.toggle.on::after { transform: translateX(16px); background: var(--lime); }
.toggle.gate.on { background: var(--tangerine); }

.review {
  background: var(--cream); border: 1px solid var(--line-2);
  border-radius: 14px; padding: 18px;
}
.review-row { display: grid; grid-template-columns: 160px 1fr; gap: 14px; padding: 10px 0; border-top: 1px dashed var(--line); font-size: 13px; }
.review-row:first-of-type { border-top: none; }
.review-row .lab { color: var(--mute); font-size: 12px; }

.wiz-footer {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 24px; padding-top: 20px; border-top: 1px solid var(--line-2);
}
.wiz-footer .left { font-size: 12px; color: var(--mute); }

/* ───── footer ───── */
.foot {
  padding: 80px 0 48px;
  border-top: 1px solid var(--line);
  margin-top: 60px;
}
.foot-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 36px; }
.foot h5 { font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--mute); margin: 0 0 14px; font-weight: 600; }
.foot ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; font-size: 13.5px; color: var(--ink-3); }
.foot ul a:hover { color: var(--ink); }
.foot-bottom { display: flex; justify-content: space-between; margin-top: 48px; font-size: 12px; color: var(--mute); }

.foot-headline {
  font-family: 'Instrument Serif', serif;
  font-weight: 400;
  font-size: 64px; line-height: .98;
  letter-spacing: -0.02em;
  margin: 0 0 24px;
  max-width: 580px;
}
.foot-headline em { font-style: italic; color: var(--emerald); }

/* ───── utilities & responsive ───── */
.divider { height: 1px; background: var(--line); margin: 0 -36px; }

@media (max-width: 860px) {
  .hero { grid-template-columns: 1fr; gap: 28px; }
  .steps, .pillars, .price-grid, .dash-stat-row { grid-template-columns: 1fr 1fr; }
  .dash-shell { grid-template-columns: 1fr; }
  .dash-cols { grid-template-columns: 1fr; }
  .foot-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 640px) {
  .price-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .compare-summary {
    margin-bottom: 14px;
  }
  .price-card {
    padding: 22px 18px;
    border-radius: 16px;
    gap: 10px;
  }
  .price-card h3 {
    font-size: 28px;
    margin: 0;
  }
  .price-amount {
    margin: 0;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 6px;
  }
  .price-amount .n {
    font-size: 46px;
  }
  .price-amount .per {
    padding-bottom: 0;
  }
  .price-card ul {
    margin: 0;
    padding-top: 14px;
    gap: 8px;
  }
  .price-card .btn {
    width: 100%;
    margin-top: 4px;
  }
}

/* ───── onboarding ───── */
.onb {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 20px;
  padding: 28px 0 60px;
  align-items: start;
  min-height: 720px;
}
.onb-stage {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 30px 32px 26px;
  min-height: 640px;
  display: flex; flex-direction: column;
  position: relative;
}
.onb-progress {
  display: flex; gap: 6px; margin-bottom: 6px;
}
.onb-progress-pip {
  flex: 1; height: 3px; border-radius: 999px;
  background: var(--line-2);
  position: relative; overflow: hidden;
}
.onb-progress-pip.done { background: var(--emerald); }
.onb-progress-pip.active::after {
  content: ""; position: absolute; inset: 0; border-radius: 999px;
  background: var(--emerald);
  animation: onb-fill .6s ease forwards;
}
@keyframes onb-fill { from { transform: translateX(-100%); } to { transform: translateX(0); } }

.onb-step-label {
  display: flex; justify-content: space-between; align-items: center;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--mute);
  margin: 14px 0 6px;
  white-space: nowrap;
}
.onb-step-label b { color: var(--emerald); font-weight: 600; }

.onb-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  margin-top: 18px;
  font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--mute); font-weight: 600;
}
.onb-eyebrow .bar { width: 18px; height: 1px; background: var(--mute); }

.onb-title {
  font-family: 'Instrument Serif', serif; font-weight: 400;
  font-size: clamp(36px, 4.4vw, 56px);
  line-height: 1.12;
  letter-spacing: -0.02em;
  margin: 14px 0 0;
  max-width: 620px;
}
.onb-title em { font-style: italic; color: var(--emerald); padding-bottom: .1em; }
.onb-sub {
  font-size: 14.5px; line-height: 1.55;
  color: var(--ink-3);
  max-width: 560px;
  margin: 44px 0 0;
}

.onb-body { flex: 1; margin-top: 26px; }

/* huge text input — calligraphic */
.onb-big-input {
  width: 100%;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--line);
  font-family: 'Instrument Serif', serif;
  font-size: 44px;
  letter-spacing: -0.015em;
  padding: 14px 4px 16px;
  outline: none;
  color: var(--ink);
  transition: border-color .2s;
}
.onb-big-input:focus { border-color: var(--emerald); }
.onb-big-input::placeholder { color: var(--line); font-style: italic; }
.onb-big-input.small { font-size: 28px; padding: 10px 4px 12px; }

.onb-input-help {
  font-size: 11.5px; color: var(--mute); margin-top: 8px;
  font-family: 'JetBrains Mono', monospace; letter-spacing: 0.04em;
}

/* preference areas grid */
.areas-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px;
}
@media (min-width: 1100px) {
  .areas-grid { grid-template-columns: repeat(3, 1fr); }
}
.area-card {
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 16px 14px;
  text-align: left;
  display: flex; flex-direction: column; gap: 6px;
  position: relative;
  transition: border-color .15s, background .15s, transform .15s;
  cursor: pointer;
}
.area-card:hover { border-color: var(--ink-3); transform: translateY(-1px); }
.area-card.on {
  border-color: var(--ink);
  background: var(--ink);
  color: var(--cream);
}
.area-card.on .area-glyph { background: var(--lime); color: var(--ink); border-color: var(--lime); }
.area-card.on .area-desc { color: rgba(242,239,230,.7); }
.area-card.on .area-check {
  opacity: 1;
}
.area-glyph {
  width: 30px; height: 30px; border-radius: 8px;
  background: var(--paper); border: 1px solid var(--line);
  display: grid; place-items: center;
  font-family: 'Instrument Serif', serif; font-style: italic;
  color: var(--emerald); font-size: 18px;
  line-height: 1;
}
.area-card h5 { margin: 8px 0 0; font-size: 14px; font-weight: 500; letter-spacing: -0.005em; }
.area-desc { font-size: 11.5px; color: var(--mute); line-height: 1.4; margin: 0; }
.area-check {
  position: absolute; top: 12px; right: 12px;
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--lime); color: var(--ink);
  display: grid; place-items: center;
  font-size: 11px;
  opacity: 0;
  transition: opacity .15s;
}

/* form rows for contact step */
.onb-form { display: grid; gap: 18px; max-width: 580px; }
.onb-row { display: grid; gap: 6px; }
.onb-row label { font-size: 11.5px; color: var(--mute); font-weight: 500; letter-spacing: 0.02em; }
.onb-row input, .onb-row select {
  width: 100%;
  padding: 14px 16px;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: var(--cream);
  font-size: 15px;
  outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.onb-row input:focus, .onb-row select:focus {
  border-color: var(--ink); box-shadow: 0 0 0 4px rgba(14,18,15,.06);
}
.onb-row-two { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }

.jurisdiction-pick { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.jurisdiction-card {
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 14px 16px;
  background: var(--cream);
  text-align: left;
  cursor: pointer;
}
.jurisdiction-card.on { border-color: var(--ink); background: var(--ink); color: var(--cream); }
.jurisdiction-card .lab { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: .1em; color: var(--mute); text-transform: uppercase; }
.jurisdiction-card.on .lab { color: var(--lime); }
.jurisdiction-card h6 { margin: 4px 0 4px; font-size: 14px; font-weight: 500; letter-spacing: -0.005em; }
.jurisdiction-card p { margin: 0; font-size: 12px; color: var(--mute); line-height: 1.4; }
.jurisdiction-card.on p { color: rgba(242,239,230,.7); }

/* facts cards (conditional reveals) */
.facts-stack { display: grid; gap: 14px; }
.fact-card {
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 18px 20px;
  animation: factReveal .35s ease both;
}
@keyframes factReveal { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
.fact-card-head { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.fact-glyph {
  width: 28px; height: 28px; border-radius: 8px;
  background: var(--lime-soft); border: 1px solid #c4ec9c;
  display: grid; place-items: center;
  font-family: 'Instrument Serif', serif; font-style: italic; color: var(--emerald-2);
}
.fact-card-head h5 { margin: 0; font-size: 13.5px; font-weight: 500; letter-spacing: -0.005em; }
.fact-card-head .tag {
  margin-left: auto;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; color: var(--mute); letter-spacing: .08em; text-transform: uppercase;
}
.fact-fields { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.fact-fields .full { grid-column: 1 / -1; }

/* dispatch step suggested mission */
.suggest-mission {
  background: var(--ink); color: var(--cream);
  border-radius: 20px;
  padding: 28px 30px;
  margin-top: 8px;
  position: relative;
  overflow: hidden;
}
.suggest-mission::before {
  content: "";
  position: absolute;
  right: -40px; top: -40px;
  width: 240px; height: 240px;
  background: radial-gradient(circle at center, var(--lime), transparent 65%);
  opacity: .14;
}
.suggest-mission .lab {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--lime);
}
.suggest-mission h3 {
  font-family: 'Instrument Serif', serif; font-weight: 400;
  font-size: 32px; letter-spacing: -0.01em; line-height: 1.1;
  margin: 10px 0 6px;
}
.suggest-mission p { color: rgba(242,239,230,.75); font-size: 13.5px; margin: 0 0 18px; }
.suggest-mission .pill-row { display: flex; gap: 6px; flex-wrap: wrap; margin: 14px 0; }
.suggest-mission .pill-row span {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px; letter-spacing: .08em;
  padding: 4px 9px; border-radius: 999px;
  background: rgba(242,239,230,.08);
  color: rgba(242,239,230,.9);
  border: 1px solid rgba(242,239,230,.14);
}
.suggest-mission .pill-row span.gate { background: rgba(226,107,44,.15); color: #f0c194; border-color: rgba(240,193,148,.3); }

.onb-foot {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 22px; margin-top: 22px;
  border-top: 1px solid var(--line-2);
}
.onb-foot .left { font-size: 11.5px; color: var(--mute); font-family: 'JetBrains Mono', monospace; letter-spacing: 0.04em; }
.onb-foot .actions { display: flex; gap: 10px; }

/* ───── Goblin sidebar (right rail) ───── */
.goblin-rail {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 26px;
  position: sticky; top: 96px;
  display: flex; flex-direction: column;
  gap: 18px;
  overflow: hidden;
}
.goblin-rail-head {
  display: flex; align-items: center; gap: 12px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--line-2);
}
.goblin-rail-head .mark {
  width: 40px; height: 40px;
  display: grid; place-items: center;
}
.goblin-rail-head .mark img { width: 100%; height: 100%; object-fit: contain; }
.goblin-rail-head .who { display: flex; flex-direction: column; line-height: 1.2; }
.goblin-rail-head b { font-size: 13.5px; font-weight: 500; }
.goblin-rail-head span {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; color: var(--emerald); letter-spacing: .08em; text-transform: uppercase;
  display: inline-flex; align-items: center; gap: 6px; margin-top: 4px;
}
.goblin-rail-head span::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--lime); box-shadow: 0 0 0 3px rgba(91,224,91,.25);
  animation: pulse 1.6s ease-in-out infinite;
}

.goblin-says {
  background: var(--cream);
  border: 1px solid var(--line-2);
  border-radius: 16px;
  padding: 16px 18px;
  position: relative;
}
.goblin-says::before {
  content: "";
  position: absolute;
  left: 20px; top: -7px;
  width: 12px; height: 12px;
  background: var(--cream);
  border-left: 1px solid var(--line-2);
  border-top: 1px solid var(--line-2);
  transform: rotate(45deg);
}
.goblin-says p {
  margin: 0;
  font-family: 'Instrument Serif', serif;
  font-size: 18px; line-height: 1.35;
  letter-spacing: -0.005em;
  color: var(--ink);
}
.goblin-says p em { color: var(--emerald); font-style: italic; padding-bottom: .06em; }
.goblin-says .meta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; color: var(--mute);
  letter-spacing: .08em; text-transform: uppercase;
  margin-top: 18px;
  padding-top: 12px;
  border-top: 1px dashed var(--line);
}

/* profile preview card */
.profile-preview {
  background: var(--cream);
  border: 1px solid var(--line-2);
  border-radius: 16px;
  padding: 16px 18px;
  font-size: 13px;
}
.profile-preview-head {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: .12em; text-transform: uppercase;
  color: var(--mute);
  margin-bottom: 10px;
}
.profile-row {
  display: grid; grid-template-columns: 90px 1fr; gap: 12px;
  padding: 6px 0;
  border-top: 1px dashed var(--line);
  font-size: 12.5px;
  color: var(--ink-2);
}
.profile-row:first-of-type { border-top: none; }
.profile-row .k { color: var(--mute); font-size: 11px; letter-spacing: 0.04em; }
.profile-row .v { font-weight: 500; }
.profile-row .v.empty { color: var(--mute); font-style: italic; font-weight: 400; }

.profile-areas { display: flex; gap: 4px; flex-wrap: wrap; }
.profile-area-chip {
  font-size: 10.5px;
  padding: 3px 8px; border-radius: 999px;
  background: var(--lime-soft); color: var(--emerald-2);
  border: 1px solid #c4ec9c;
  font-weight: 500;
}

/* signature step */
.sig-pad {
  background: var(--cream);
  border: 1px dashed var(--line);
  border-radius: 16px;
  padding: 36px 26px;
  text-align: center;
}
.sig-pad .glyph {
  font-family: 'Instrument Serif', serif; font-style: italic;
  font-size: 64px; color: var(--emerald);
  line-height: 1;
}
.sig-pad .who-said {
  font-family: 'Instrument Serif', serif;
  font-size: 17px; letter-spacing: -0.005em;
  margin-top: 12px;
}

.toggle-pill {
  display: inline-flex; align-items: center;
  padding: 4px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--cream);
  margin: 14px 0 4px;
}
.toggle-pill button {
  padding: 7px 12px;
  font-size: 11.5px; font-weight: 500;
  color: var(--ink-3);
  border-radius: 999px;
  white-space: nowrap;
}
.toggle-pill button.on {
  background: var(--ink); color: var(--cream);
}

@media (max-width: 860px) {
  .onb { grid-template-columns: 1fr; }
  .goblin-rail { position: static; }
  .areas-grid { grid-template-columns: 1fr 1fr; }
}

/* ───── Mission detail ───── */
.mdet { padding: 24px 0 60px; }
.mdet-header {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 18px;
  align-items: center;
  padding: 18px 24px;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  margin-bottom: 18px;
}
.mdet-back {
  width: 38px; height: 38px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: var(--cream);
  display: grid; place-items: center;
  font-size: 14px;
}
.mdet-back:hover { background: #fff; }
.mdet-title { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.mdet-title h2 {
  margin: 0;
  font-family: 'Instrument Serif', serif; font-weight: 400;
  font-size: 32px; letter-spacing: -0.01em; line-height: 1.05;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.mdet-title .meta {
  display: flex; gap: 12px; align-items: center;
  font-size: 12px; color: var(--mute);
}
.mdet-title .meta b { color: var(--ink); font-weight: 600; }
.mdet-title .meta .id { font-family: 'JetBrains Mono', monospace; letter-spacing: 0.04em; }

.mdet-status {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase;
  padding: 6px 11px; border-radius: 999px;
  background: var(--lime-soft); color: var(--emerald-2);
  border: 1px solid #c4ec9c;
  white-space: nowrap;
  display: inline-flex; align-items: center; gap: 6px;
}
.mdet-status.live { background: var(--ink); color: var(--lime); border-color: var(--ink); }
.mdet-status.ask { background: var(--tangerine-soft); color: #8a3f15; border-color: #f0c194; }

.mdet-grid {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 14px;
  align-items: start;
}
.mdet-main {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 6px;
  min-height: 540px;
  display: flex; flex-direction: column;
}
.mdet-tabs {
  display: flex; gap: 2px;
  padding: 6px;
  background: var(--cream);
  border-radius: 12px;
}
.mdet-tabs button {
  padding: 9px 14px;
  border-radius: 8px;
  font-size: 13px;
  color: var(--ink-3);
  font-weight: 500;
}
.mdet-tabs button.active { background: var(--paper); color: var(--ink); box-shadow: 0 1px 2px rgba(14,18,15,.06); }

.mdet-body { padding: 22px 24px; flex: 1; }

/* mission detail transcript */
.mdet-transcript {
  display: grid; gap: 16px;
}
.mdet-trow {
  display: grid; grid-template-columns: 80px 1fr; gap: 16px;
}
.mdet-trow .t-time { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--mute); padding-top: 4px; }
.mdet-trow .t-content {
  font-size: 14px; line-height: 1.5;
  padding: 12px 16px;
  background: var(--cream);
  border-radius: 14px;
  position: relative;
}
.mdet-trow.them .t-content { background: var(--cream); }
.mdet-trow.agent .t-content { background: #f1faec; border: 1px solid rgba(91,224,91,.2); }
.mdet-trow.system .t-content { background: transparent; padding: 4px 0; color: var(--mute); font-size: 12px; font-family: 'JetBrains Mono', monospace; }
.mdet-trow .speaker {
  display: block;
  font-size: 10.5px; font-weight: 600; text-transform: uppercase; letter-spacing: .08em;
  color: var(--mute);
  margin-bottom: 6px;
}
.mdet-trow.agent .speaker { color: var(--emerald); }
.mdet-trow.them .speaker { color: var(--tangerine); }
.mdet-trow .annot {
  margin-top: 8px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px; color: var(--mute);
  letter-spacing: 0.04em;
  display: inline-flex; align-items: center; gap: 6px;
}
.mdet-trow .annot::before { content: ""; width: 14px; height: 1px; background: var(--mute); }

/* timeline */
.mtimeline {
  display: grid; gap: 0;
  padding: 8px 0;
}
.mtl-event {
  display: grid; grid-template-columns: 100px auto 1fr; gap: 16px;
  padding: 14px 0;
  position: relative;
}
.mtl-event + .mtl-event::before {
  content: ""; position: absolute;
  left: 116px; top: -14px; bottom: 50%;
  width: 1px; background: var(--line);
}
.mtl-event::after {
  content: ""; position: absolute;
  left: 116px; top: 50%; bottom: -14px;
  width: 1px; background: var(--line);
}
.mtl-event:last-child::after { display: none; }
.mtl-time {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; color: var(--mute);
  padding-top: 4px;
  text-align: right;
}
.mtl-dot {
  width: 12px; height: 12px; border-radius: 50%;
  background: var(--cream); border: 2px solid var(--line);
  margin-top: 6px;
  z-index: 1;
  justify-self: center;
}
.mtl-event.done .mtl-dot { background: var(--emerald); border-color: var(--emerald); }
.mtl-event.gate .mtl-dot { background: var(--tangerine); border-color: var(--tangerine); }
.mtl-event.live .mtl-dot { background: var(--lime); border-color: var(--emerald); box-shadow: 0 0 0 4px rgba(91,224,91,.2); animation: pulse 1.6s ease-in-out infinite; }
.mtl-info h5 { margin: 0; font-size: 14px; font-weight: 500; letter-spacing: -0.005em; }
.mtl-info p { margin: 4px 0 0; font-size: 12.5px; color: var(--ink-3); line-height: 1.5; }
.mtl-info .extra {
  margin-top: 6px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; color: var(--mute);
  letter-spacing: 0.04em;
}

/* playbook */
.playbook { display: grid; gap: 14px; }
.playbook-block {
  background: var(--cream);
  border: 1px solid var(--line-2);
  border-radius: 14px;
  padding: 18px 20px;
}
.playbook-block h4 {
  margin: 0 0 10px;
  font-family: 'Instrument Serif', serif; font-weight: 400;
  font-size: 22px; letter-spacing: -0.005em;
}
.playbook-block h4 em { font-style: italic; color: var(--emerald); }
.playbook-block ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.playbook-block li {
  font-size: 13px; color: var(--ink-3);
  padding-left: 18px; position: relative;
  line-height: 1.45;
}
.playbook-block li::before {
  content: ""; position: absolute; left: 0; top: 8px;
  width: 8px; height: 8px;
  border: 1px solid var(--ink-3);
  border-radius: 2px;
}
.playbook-block.allow li::before { background: var(--lime); border-color: var(--emerald-2); }
.playbook-block.gate li::before { background: var(--tangerine); border-color: #8a3f15; border-radius: 50%; }
.playbook-block.never li::before { background: transparent; border-style: dashed; }

/* receipt */
.receipt {
  border: 1px solid var(--line);
  background: var(--cream);
  border-radius: 16px;
  padding: 28px 28px 24px;
  position: relative;
  overflow: hidden;
}
.receipt::before, .receipt::after {
  content: "";
  position: absolute;
  height: 14px;
  left: -7px; right: -7px;
  background-image: radial-gradient(circle at 7px 7px, transparent 6px, var(--paper) 6.5px);
  background-size: 14px 14px;
  background-position: 0 0;
}
.receipt::before { top: -7px; }
.receipt::after { bottom: -7px; transform: rotate(180deg); }
.receipt-head {
  display: flex; justify-content: space-between; align-items: flex-start;
  padding-bottom: 14px; border-bottom: 1px dashed var(--line);
  margin-bottom: 14px;
}
.receipt-head h3 {
  margin: 0;
  font-family: 'Instrument Serif', serif; font-weight: 400;
  font-size: 26px; letter-spacing: -0.01em; line-height: 1.1;
}
.receipt-head .stamp {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--emerald);
  padding: 5px 9px; border-radius: 999px;
  background: var(--lime-soft); border: 1px solid #c4ec9c;
}
.receipt-row {
  display: grid; grid-template-columns: 140px 1fr;
  gap: 14px;
  padding: 10px 0;
  border-bottom: 1px dashed var(--line);
  font-size: 13.5px;
}
.receipt-row:last-of-type { border-bottom: none; }
.receipt-row .k { color: var(--mute); font-size: 12px; }
.receipt-row .v { color: var(--ink); font-weight: 500; }
.receipt-row .v.mono { font-family: 'JetBrains Mono', monospace; font-weight: 400; }
.receipt-quote {
  margin: 18px 0 4px;
  padding: 16px 18px;
  background: var(--paper); border: 1px solid var(--line-2); border-radius: 14px;
}
.receipt-quote p {
  margin: 0;
  font-family: 'Instrument Serif', serif; font-style: italic;
  font-size: 19px; line-height: 1.3; letter-spacing: -0.005em;
}
.receipt-quote .who {
  margin-top: 8px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px; color: var(--mute); letter-spacing: 0.04em;
}

/* sidebar info card */
.mdet-side { display: grid; gap: 14px; position: sticky; top: 90px; }
.mdet-card {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 18px 20px;
}
.mdet-card h4 {
  margin: 0 0 10px;
  font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--mute); font-family: 'JetBrains Mono', monospace; font-weight: 600;
}
.mdet-card .row {
  display: grid; grid-template-columns: 90px 1fr; gap: 10px;
  padding: 6px 0; font-size: 12.5px;
  border-top: 1px dashed var(--line);
}
.mdet-card .row:first-of-type { border-top: none; }
.mdet-card .row .k { color: var(--mute); font-size: 11.5px; }
.mdet-card .row .v { color: var(--ink); font-weight: 500; }
.mdet-card .actions { display: flex; flex-direction: column; gap: 6px; }
.mdet-card .actions .btn { width: 100%; padding: 9px 12px; font-size: 12.5px; }

/* ───── Live call cockpit ───── */
.cockpit {
  background: #0a0c0a;
  color: var(--cream);
  border-radius: var(--radius-lg);
  margin: 24px 0;
  padding: 0;
  overflow: hidden;
  position: relative;
  min-height: 720px;
  font-feature-settings: "ss01";
}
.cockpit-glow {
  position: absolute;
  top: -120px; left: -120px;
  width: 400px; height: 400px;
  background: radial-gradient(circle, var(--lime), transparent 60%);
  opacity: .08; pointer-events: none;
}
.cockpit-grid-bg {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(91,224,91,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(91,224,91,.04) 1px, transparent 1px);
  background-size: 28px 28px;
  pointer-events: none;
  mask-image: linear-gradient(180deg, #000, transparent 80%);
  -webkit-mask-image: linear-gradient(180deg, #000, transparent 80%);
}

.cockpit-header {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 20px;
  align-items: center;
  padding: 18px 26px;
  border-bottom: 1px solid rgba(242,239,230,.08);
  position: relative; z-index: 1;
}
.cockpit-back {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase;
  color: rgba(242,239,230,.55);
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(242,239,230,.12);
}
.cockpit-back:hover { color: var(--cream); border-color: rgba(242,239,230,.3); }
.cockpit-title { display: flex; flex-direction: column; gap: 4px; align-items: center; }
.cockpit-title h3 {
  margin: 0;
  font-family: 'Instrument Serif', serif; font-weight: 400;
  font-size: 22px; letter-spacing: -0.005em;
}
.cockpit-title .sub {
  display: flex; gap: 14px; align-items: center;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; color: rgba(242,239,230,.55); letter-spacing: 0.04em;
}
.cockpit-title .sub b { color: var(--lime); font-weight: 500; }
.cockpit-live {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--lime);
  padding: 7px 12px;
  border: 1px solid rgba(91,224,91,.3);
  background: rgba(91,224,91,.06);
  border-radius: 999px;
}
.cockpit-live .red {
  width: 8px; height: 8px; border-radius: 50%; background: #ff5a3c;
  box-shadow: 0 0 0 4px rgba(255,90,60,.2);
  animation: pulse 1.6s ease-in-out infinite;
}

.cockpit-stage {
  display: grid;
  grid-template-columns: 280px 1fr 280px;
  gap: 0;
  position: relative; z-index: 1;
  min-height: 600px;
}

/* left column: agent panel + vitals */
.cockpit-side {
  padding: 22px 22px 22px 26px;
  border-right: 1px solid rgba(242,239,230,.08);
  display: flex; flex-direction: column; gap: 18px;
}
.cockpit-side.right { border-right: none; border-left: 1px solid rgba(242,239,230,.08); padding: 22px 26px 22px 22px; }

.cockpit-section-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  color: rgba(242,239,230,.4);
  margin-bottom: 10px;
  display: flex; align-items: center; gap: 8px;
}
.cockpit-section-label::after {
  content: ""; flex: 1; height: 1px; background: rgba(242,239,230,.08);
}

.cockpit-agent {
  background: rgba(242,239,230,.04);
  border: 1px solid rgba(242,239,230,.08);
  border-radius: 14px;
  padding: 16px;
  text-align: center;
}
.cockpit-agent-avatar {
  width: 80px; height: 80px;
  border-radius: 50%;
  background: rgba(91,224,91,.1);
  border: 1px solid rgba(91,224,91,.2);
  margin: 0 auto 14px;
  display: grid; place-items: center;
  position: relative;
}
.cockpit-agent-avatar img { width: 60px; height: 60px; object-fit: contain; filter: brightness(1.1); }
.cockpit-agent-avatar::before, .cockpit-agent-avatar::after {
  content: ""; position: absolute;
  border-radius: 50%;
  border: 1px solid rgba(91,224,91,.18);
  animation: cockpit-ping 2.4s ease-out infinite;
}
.cockpit-agent-avatar::before { inset: -8px; }
.cockpit-agent-avatar::after { inset: -16px; animation-delay: 0.6s; }
@keyframes cockpit-ping {
  0% { opacity: 1; transform: scale(0.85); }
  100% { opacity: 0; transform: scale(1.15); }
}
.cockpit-agent h4 {
  margin: 0;
  font-family: 'Instrument Serif', serif; font-weight: 400;
  font-size: 19px; letter-spacing: -0.005em;
}
.cockpit-agent .role {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; color: var(--lime); letter-spacing: 0.1em; text-transform: uppercase;
  margin-top: 4px;
}
.cockpit-agent .status {
  margin-top: 12px;
  padding: 8px 10px;
  background: rgba(91,224,91,.06);
  border: 1px solid rgba(91,224,91,.18);
  border-radius: 8px;
  font-size: 11.5px;
  color: rgba(242,239,230,.8);
  line-height: 1.4;
}

.vitals { display: grid; gap: 10px; }
.vital {
  display: grid; grid-template-columns: 1fr auto; gap: 10px;
  align-items: center;
  font-size: 12px;
}
.vital .label { color: rgba(242,239,230,.5); font-family: 'JetBrains Mono', monospace; font-size: 10.5px; letter-spacing: 0.06em; text-transform: uppercase; }
.vital .val { font-family: 'JetBrains Mono', monospace; color: var(--cream); font-size: 12.5px; }
.vital .val.good { color: var(--lime); }
.vital .val.warn { color: #ffb061; }
.vital .bar {
  grid-column: 1 / -1; height: 3px;
  background: rgba(242,239,230,.06);
  border-radius: 999px; overflow: hidden;
}
.vital .bar > span {
  display: block; height: 100%;
  background: var(--lime);
  border-radius: 999px;
  transition: width .4s;
}
.vital .bar.warn > span { background: #ffb061; }

/* center: live transcript */
.cockpit-main {
  padding: 22px 26px;
  display: flex; flex-direction: column;
  min-height: 600px;
}
.cockpit-channel {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 18px;
}
.cockpit-channel .name {
  font-family: 'Instrument Serif', serif; font-size: 19px;
}
.cockpit-channel .name em { font-style: italic; color: var(--lime); }
.cockpit-channel .num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; color: rgba(242,239,230,.5);
  letter-spacing: 0.06em;
}

.cockpit-trans { flex: 1; display: flex; flex-direction: column; gap: 12px; overflow: hidden; }
.cockpit-line {
  display: grid; grid-template-columns: 56px 1fr;
  gap: 12px; font-size: 13.5px;
  line-height: 1.5;
  opacity: 1;
  animation: ctrans-in .4s ease;
}
@keyframes ctrans-in { from { opacity: 0; transform: translateX(-4px); } to { opacity: 1; transform: none; } }
.cockpit-line .t { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: rgba(242,239,230,.4); padding-top: 4px; }
.cockpit-line .c { color: rgba(242,239,230,.92); }
.cockpit-line .c .who {
  display: inline-block;
  font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em;
  margin-right: 8px;
  padding: 2px 7px; border-radius: 999px;
}
.cockpit-line.agent .c .who { background: rgba(91,224,91,.12); color: var(--lime); }
.cockpit-line.them .c .who { background: rgba(255,176,97,.12); color: #ffb061; }
.cockpit-line.system .c { color: rgba(242,239,230,.45); font-family: 'JetBrains Mono', monospace; font-size: 11.5px; }
.cockpit-line.system .c .who { background: rgba(242,239,230,.08); color: rgba(242,239,230,.55); }

.cockpit-typing {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 11px; color: rgba(91,224,91,.8);
  font-family: 'JetBrains Mono', monospace; letter-spacing: 0.04em;
  margin-top: 6px;
}
.cockpit-typing span {
  display: inline-block; width: 4px; height: 4px; border-radius: 50%;
  background: var(--lime); animation: ctyp 1.2s ease-in-out infinite;
}
.cockpit-typing span:nth-child(2) { animation-delay: .2s }
.cockpit-typing span:nth-child(3) { animation-delay: .4s }
@keyframes ctyp { 0%,80%,100% { opacity: .25; transform: translateY(0); } 40% { opacity: 1; transform: translateY(-3px); } }

/* approval gate dialog inside cockpit */
.cockpit-gate {
  margin-top: 18px;
  padding: 20px 22px;
  border: 1px solid rgba(255,176,97,.3);
  background: linear-gradient(180deg, rgba(255,176,97,.08), rgba(255,176,97,.02));
  border-radius: 16px;
  animation: gate-in .35s ease;
}
@keyframes gate-in { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
.cockpit-gate .gate-lab {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase;
  color: #ffb061;
}
.cockpit-gate .gate-lab::before {
  content: "⚑"; font-family: 'Instrument Serif', serif; font-style: italic;
}
.cockpit-gate h4 {
  margin: 8px 0 6px;
  font-family: 'Instrument Serif', serif; font-weight: 400;
  font-size: 22px; letter-spacing: -0.005em; line-height: 1.2;
  color: var(--cream);
}
.cockpit-gate p { margin: 0; font-size: 13px; color: rgba(242,239,230,.7); line-height: 1.5; }
.cockpit-gate .gate-actions { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 14px; }
.cockpit-gate .gate-actions .btn { padding: 9px 14px; font-size: 12.5px; }

/* right column: IVR tree + tools */
.ivr-tree { display: flex; flex-direction: column; gap: 4px; font-family: 'JetBrains Mono', monospace; font-size: 11.5px; }
.ivr-node {
  display: grid; grid-template-columns: 18px 1fr;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 8px;
  color: rgba(242,239,230,.5);
  align-items: center;
}
.ivr-node.done { background: rgba(91,224,91,.06); color: var(--lime); }
.ivr-node.active { background: rgba(91,224,91,.12); color: var(--lime); border: 1px solid rgba(91,224,91,.25); }
.ivr-node .key {
  display: inline-grid; place-items: center;
  width: 18px; height: 18px;
  border: 1px solid rgba(242,239,230,.18);
  border-radius: 4px;
  font-size: 10px;
  color: rgba(242,239,230,.7);
}
.ivr-node.done .key, .ivr-node.active .key { border-color: var(--lime); color: var(--lime); }
.ivr-node .sub {
  font-size: 9.5px; color: rgba(242,239,230,.35);
  letter-spacing: 0.04em; margin-top: 1px;
}

.cockpit-controls {
  display: grid; grid-template-columns: 1fr 1fr; gap: 6px;
}
.cockpit-controls .btn {
  background: rgba(242,239,230,.06);
  border: 1px solid rgba(242,239,230,.12);
  color: var(--cream);
  font-size: 11.5px;
  padding: 10px 8px;
}
.cockpit-controls .btn:hover { background: rgba(242,239,230,.12); }
.cockpit-controls .btn.danger {
  background: rgba(255,90,60,.08); border-color: rgba(255,90,60,.3); color: #ff8e74;
}
.cockpit-controls .btn.danger:hover { background: rgba(255,90,60,.16); }
.cockpit-controls .btn.full { grid-column: 1 / -1; }

/* sentiment bubble */
.sentiment-bubble {
  background: rgba(242,239,230,.04);
  border: 1px solid rgba(242,239,230,.08);
  border-radius: 14px;
  padding: 14px;
  font-size: 12px;
}
.sentiment-row {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 6px;
}
.sentiment-row .label { color: rgba(242,239,230,.5); font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; }
.sentiment-row .val { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--cream); }
.sentiment-bar {
  height: 3px; background: rgba(242,239,230,.06);
  border-radius: 999px; position: relative;
}
.sentiment-bar > span {
  position: absolute; top: 0; bottom: 0;
  width: 3px; background: var(--lime); border-radius: 999px;
  transition: left .5s;
}
.sentiment-scale {
  display: flex; justify-content: space-between;
  margin-top: 6px;
  font-family: 'JetBrains Mono', monospace; font-size: 9.5px; color: rgba(242,239,230,.35); letter-spacing: 0.04em;
}

.cockpit-wave {
  margin-top: 14px;
  display: flex; align-items: end; gap: 2px;
  height: 28px;
}
.cockpit-wave span {
  width: 2px; background: var(--lime); opacity: .8;
  border-radius: 1px;
  animation: cwave 1.2s ease-in-out infinite;
}
@keyframes cwave { 0%, 100% { height: 4px } 50% { height: 22px } }

@media (max-width: 860px) {
  .cockpit-stage { grid-template-columns: 1fr; }
  .cockpit-side, .cockpit-side.right { border: none; border-bottom: 1px solid rgba(242,239,230,.08); }
  .mdet-grid { grid-template-columns: 1fr; }
}

/* ───── iOS / mobile screens ───── */
.ios-screen {
  width: 100%; height: 100%;
  background: var(--cream);
  color: var(--ink);
  font-family: 'Geist', ui-sans-serif, system-ui, sans-serif;
  font-size: 15px;
  display: flex; flex-direction: column;
  position: relative;
  overflow: hidden;
  padding-top: 50px; /* clear iOS status bar */
}
.ios-screen.dark { background: #0a0c0a; color: #F2EFE6; }

.ios-top {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px 8px;
}
.ios-top .brand {
  display: inline-flex; align-items: center; gap: 8px;
}
.ios-top .brand img { width: 28px; height: 28px; object-fit: contain; }
.ios-top .brand b { font-size: 14px; font-weight: 600; letter-spacing: -0.005em; }
.ios-top .right {
  display: inline-flex; gap: 8px; align-items: center;
}
.ios-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 10px;
  font-size: 11.5px; font-weight: 500;
  border-radius: 999px;
  background: var(--paper); border: 1px solid var(--line);
  color: var(--ink-3);
  white-space: nowrap;
}
.ios-pill.live { background: var(--ink); color: var(--lime); border-color: var(--ink); }
.ios-pill .dot {
  width: 6px; height: 6px; border-radius: 50%; background: var(--lime);
  box-shadow: 0 0 0 3px rgba(91,224,91,.22);
}

.ios-greeting {
  padding: 14px 22px 4px;
}
.ios-greeting .eyebrow {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--mute);
}
.ios-greeting h1 {
  margin: 6px 0 0;
  font-family: 'Instrument Serif', serif; font-weight: 400;
  font-size: 34px; line-height: 1.08;
  letter-spacing: -0.015em;
}
.ios-greeting h1 em { font-style: italic; color: var(--emerald); padding-bottom: .1em; }
.ios-greeting p { margin: 24px 0 0; font-size: 13px; color: var(--ink-3); line-height: 1.5; }

.ios-section-head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 20px 22px 8px;
}
.ios-section-head .lab {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--mute);
  white-space: nowrap;
}
.ios-section-head .more { font-size: 12px; color: var(--emerald); font-weight: 500; }

.ios-cards { padding: 4px 18px; display: flex; flex-direction: column; gap: 10px; }
.ios-card {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 16px;
  display: flex; flex-direction: column; gap: 8px;
}
.ios-card.ink { background: var(--ink); color: var(--cream); border-color: var(--ink); }
.ios-card.warn {
  background: linear-gradient(180deg, #fff7eb, #fef0d8);
  border-color: #f0c194;
}

.ios-card-row {
  display: flex; align-items: center; justify-content: space-between;
  gap: 10px;
}
.ios-card-meta {
  display: inline-flex; gap: 8px; align-items: center;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px; color: var(--mute); letter-spacing: 0.04em;
  white-space: nowrap;
  min-width: 0; flex-wrap: wrap;
}
.ios-card.ink .ios-card-meta { color: rgba(242,239,230,.5); }
.ios-card-tag {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.08em;
  padding: 3px 8px; border-radius: 999px;
  background: var(--cream); border: 1px solid var(--line); color: var(--ink-3);
  white-space: nowrap;
}
.ios-card-tag.live { background: var(--ink); color: var(--lime); border-color: var(--ink); }
.ios-card-tag.ask { background: #fef0d8; color: #8a3f15; border-color: #f0c194; }
.ios-card-tag.done { background: var(--lime-soft); color: var(--emerald-2); border-color: #c4ec9c; }

.ios-card h3 {
  margin: 0 0 4px;
  font-family: 'Instrument Serif', serif; font-weight: 400;
  font-size: 22px; letter-spacing: -0.005em; line-height: 1.2;
}
.ios-card h3 em { padding-bottom: .08em; }
.ios-card.ink h3 em { font-style: italic; color: var(--lime); }
.ios-card .who { font-size: 12.5px; color: var(--mute); }
.ios-card.ink .who { color: rgba(242,239,230,.6); }

.ios-card-actions {
  display: flex; gap: 8px;
  margin-top: 4px;
}
.ios-btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 6px;
  padding: 10px 14px;
  border-radius: 999px;
  font-size: 13px; font-weight: 500;
  background: var(--paper); border: 1px solid var(--line);
  color: var(--ink);
  flex: 1;
  text-align: center;
  white-space: nowrap;
}
.ios-btn.ink { background: var(--ink); color: var(--cream); border-color: var(--ink); }
.ios-btn.lime { background: var(--lime); color: var(--ink); border-color: var(--lime); }
.ios-btn.subtle { background: transparent; border-color: rgba(242,239,230,.18); color: var(--cream); }

/* mini transcript on home card */
.ios-mini-transcript {
  background: var(--cream); border-radius: 12px;
  padding: 12px 14px;
  font-size: 12.5px;
  display: grid; gap: 6px;
}
.ios-mini-transcript .line {
  display: grid; grid-template-columns: auto 1fr;
  gap: 8px;
  line-height: 1.45;
  align-items: baseline;
}
.ios-mini-transcript .line .t { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--mute); }
.ios-mini-transcript .line .who { font-size: 9.5px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; margin-right: 5px; }
.ios-mini-transcript .line.agent .who { color: var(--emerald); }
.ios-mini-transcript .line.them .who { color: var(--tangerine); }
.ios-mini-transcript .live-tail {
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  color: var(--emerald); padding-top: 4px;
  display: inline-flex; gap: 4px; align-items: center;
}
.ios-mini-transcript .live-tail::before {
  content: ""; width: 5px; height: 5px; border-radius: 50%;
  background: var(--lime); box-shadow: 0 0 0 3px rgba(91,224,91,.22);
}

/* tab bar */
.ios-tabbar {
  position: absolute; bottom: 24px; left: 14px; right: 14px;
  background: rgba(251, 249, 242, .82);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: 8px;
  display: grid; grid-template-columns: repeat(5, 1fr);
  gap: 2px;
  box-shadow: 0 12px 30px -10px rgba(14,18,15,.15);
}
.ios-tabbar.dark {
  background: rgba(20,22,18,.82);
  border-color: rgba(242,239,230,.12);
}
.ios-tab {
  display: flex; flex-direction: column; align-items: center; gap: 2px;
  padding: 8px 4px;
  border-radius: 14px;
  font-size: 10px;
  color: var(--mute);
  font-weight: 500;
  letter-spacing: 0.02em;
}
.ios-tab.active { color: var(--ink); background: var(--paper); }
.ios-tabbar.dark .ios-tab.active { color: var(--lime); background: rgba(91,224,91,.08); }
.ios-tab .glyph {
  font-family: 'Instrument Serif', serif; font-style: italic;
  font-size: 19px; line-height: 1; margin-bottom: 1px;
}
.ios-tab .badge {
  position: absolute;
  margin-left: 12px; margin-top: -4px;
  width: 14px; height: 14px; border-radius: 50%;
  background: var(--tangerine); color: #fff;
  font-size: 9px; font-weight: 600;
  display: grid; place-items: center;
}

.ios-scroll {
  flex: 1; overflow-y: auto;
  padding-bottom: 110px;
}

/* approval gate full-screen mobile */
.ios-gate {
  flex: 1;
  display: flex; flex-direction: column;
  background: linear-gradient(180deg, #fff7eb 0%, var(--cream) 100%);
  padding: 18px 22px 30px;
}
.ios-gate-top {
  padding: 18px 0 22px;
  display: flex; justify-content: space-between; align-items: center;
}
.ios-gate-top .who-from {
  display: flex; align-items: center; gap: 10px;
}
.ios-gate-top .who-from img { width: 38px; height: 38px; object-fit: contain; }
.ios-gate-top .who-from .name { font-size: 13px; font-weight: 600; }
.ios-gate-top .who-from .sub { font-size: 11px; color: var(--mute); font-family: 'JetBrains Mono', monospace; }
.ios-gate-eyebrow {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
  color: #8a3f15;
  display: inline-flex; gap: 8px; align-items: center;
}
.ios-gate-eyebrow .pulse {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--tangerine);
  box-shadow: 0 0 0 4px rgba(226,107,44,.22);
  animation: pulse 1.6s ease-in-out infinite;
}
.ios-gate h2 {
  margin: 18px 0 0;
  font-family: 'Instrument Serif', serif; font-weight: 400;
  font-size: 36px; line-height: 1.08; letter-spacing: -0.02em;
}
.ios-gate h2 em { font-style: italic; color: #8a3f15; padding-bottom: .1em; }
.ios-gate p { margin: 28px 0 0; font-size: 14px; line-height: 1.55; color: var(--ink-3); }

.ios-gate-context {
  margin-top: 22px;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 16px 18px;
}
.ios-gate-context .ctxlab {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--mute);
  margin-bottom: 10px;
}
.ios-gate-context .quote {
  font-family: 'Instrument Serif', serif; font-style: italic;
  font-size: 16px; line-height: 1.4;
  color: var(--ink);
}
.ios-gate-context .who-said {
  margin-top: 8px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; color: var(--mute);
}

.ios-gate-actions { margin-top: auto; display: flex; flex-direction: column; gap: 8px; }
.ios-gate-actions .ios-btn {
  padding: 14px 14px;
  font-size: 14px; font-weight: 500;
}

/* live cockpit mobile */
.ios-cockpit {
  flex: 1;
  background: #0a0c0a; color: #F2EFE6;
  display: flex; flex-direction: column;
}
.ios-cockpit-top {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 18px 10px;
  border-bottom: 1px solid rgba(242,239,230,.08);
}
.ios-cockpit-top .who img { width: 32px; height: 32px; }
.ios-cockpit-top .who { display: flex; align-items: center; gap: 10px; }
.ios-cockpit-top .who h4 { margin: 0; font-size: 13px; font-weight: 600; }
.ios-cockpit-top .who p { margin: 0; font-family: 'JetBrains Mono', monospace; font-size: 10.5px; color: rgba(242,239,230,.5); letter-spacing: 0.04em; }
.ios-cockpit-top .timer {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; color: var(--lime); letter-spacing: 0.08em; text-transform: uppercase;
  padding: 5px 9px;
  background: rgba(91,224,91,.08);
  border: 1px solid rgba(91,224,91,.2);
  border-radius: 999px;
}
.ios-cockpit-top .timer .red {
  width: 6px; height: 6px; border-radius: 50%; background: #ff5a3c;
  box-shadow: 0 0 0 3px rgba(255,90,60,.22);
}

.ios-cockpit-banner {
  padding: 16px 18px;
  font-family: 'Instrument Serif', serif;
  font-size: 22px; line-height: 1.2; letter-spacing: -0.005em;
}
.ios-cockpit-banner em { font-style: italic; color: var(--lime); }

.ios-cockpit-trans { flex: 1; padding: 4px 18px 20px; display: flex; flex-direction: column; gap: 10px; overflow-y: auto; }
.ios-cockpit-line {
  display: grid; grid-template-columns: 44px 1fr;
  gap: 10px;
  font-size: 13px;
  line-height: 1.45;
}
.ios-cockpit-line .t { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: rgba(242,239,230,.4); padding-top: 3px; }
.ios-cockpit-line .c .who {
  font-size: 9.5px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em;
  padding: 2px 6px; border-radius: 999px; margin-right: 6px;
}
.ios-cockpit-line.agent .c .who { background: rgba(91,224,91,.12); color: var(--lime); }
.ios-cockpit-line.them .c .who { background: rgba(255,176,97,.12); color: #ffb061; }
.ios-cockpit-line.system .c { color: rgba(242,239,230,.45); font-family: 'JetBrains Mono', monospace; font-size: 11px; }
.ios-cockpit-line.system .c .who { background: rgba(242,239,230,.08); color: rgba(242,239,230,.55); }

.ios-cockpit-vitals {
  margin: 4px 18px 12px;
  padding: 12px 14px;
  background: rgba(242,239,230,.04);
  border: 1px solid rgba(242,239,230,.08);
  border-radius: 14px;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px;
}
.ios-cockpit-vital { text-align: left; }
.ios-cockpit-vital .lab {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px; letter-spacing: 0.08em; text-transform: uppercase;
  color: rgba(242,239,230,.45);
}
.ios-cockpit-vital .val {
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px; color: var(--cream); margin-top: 3px;
}
.ios-cockpit-vital .val.good { color: var(--lime); }

.ios-cockpit-controls {
  padding: 0 18px;
  display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px;
  margin-bottom: 90px;
}
.ios-cockpit-controls .ios-btn {
  padding: 12px 6px; font-size: 12px;
  background: rgba(242,239,230,.06);
  border-color: rgba(242,239,230,.12);
  color: var(--cream);
}
.ios-cockpit-controls .ios-btn.danger {
  background: rgba(255,90,60,.1);
  border-color: rgba(255,90,60,.3);
  color: #ff8e74;
}

/* mission detail mobile (resolved receipt) */
.ios-mdet { padding: 8px 18px 110px; flex: 1; overflow-y: auto; }
.ios-mdet-back {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 13px; color: var(--emerald);
  padding: 8px 0;
}
.ios-receipt {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: 22px 22px 8px;
  position: relative;
  overflow: hidden;
  margin-top: 12px;
}
.ios-receipt .stamp {
  position: absolute; top: 22px; right: 22px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--emerald);
  padding: 4px 8px; border-radius: 999px;
  background: var(--lime-soft); border: 1px solid #c4ec9c;
}
.ios-receipt .outcome {
  font-family: 'Instrument Serif', serif;
  font-size: 30px; line-height: 1.05; letter-spacing: -0.01em;
  max-width: 80%; margin: 8px 0 18px;
}
.ios-receipt .outcome em { font-style: italic; color: var(--emerald); }
.ios-receipt .grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 14px 18px;
  padding: 16px 0;
  border-top: 1px dashed var(--line);
}
.ios-receipt .grid .item .k {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9.5px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--mute);
}
.ios-receipt .grid .item .v {
  margin-top: 4px;
  font-size: 13px; font-weight: 500;
}
.ios-receipt .grid .item .v.mono { font-family: 'JetBrains Mono', monospace; font-weight: 400; }
.ios-receipt .quote {
  margin: 0 -22px;
  padding: 18px 22px;
  background: var(--cream);
  border-top: 1px dashed var(--line);
  border-bottom-left-radius: 22px; border-bottom-right-radius: 22px;
}
.ios-receipt .quote p {
  margin: 0;
  font-family: 'Instrument Serif', serif; font-style: italic;
  font-size: 17px; line-height: 1.35;
}
.ios-receipt .quote .who-said {
  margin-top: 8px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; color: var(--mute); letter-spacing: 0.04em;
}
.ios-receipt-actions {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-top: 14px;
}

/* brief composer (mobile) */
.ios-brief {
  flex: 1; padding: 8px 22px 110px; overflow-y: auto;
}
.ios-brief-step {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--mute);
  margin: 8px 0 6px;
}
.ios-brief h1 {
  margin: 0;
  font-family: 'Instrument Serif', serif; font-weight: 400;
  font-size: 30px; line-height: 1.1; letter-spacing: -0.015em;
}
.ios-brief h1 em { font-style: italic; color: var(--emerald); padding-bottom: .1em; }
.ios-brief p.sub { margin: 22px 0 0; font-size: 13px; color: var(--ink-3); line-height: 1.5; }
.ios-brief .progress {
  display: flex; gap: 4px; margin-top: 18px;
}
.ios-brief .progress span {
  flex: 1; height: 3px; border-radius: 999px;
  background: var(--line-2);
}
.ios-brief .progress span.done { background: var(--emerald); }
.ios-brief .progress span.active { background: var(--lime); }

.ios-scenarios {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 8px; margin-top: 20px;
}
.ios-scenario {
  background: var(--paper); border: 1px solid var(--line);
  border-radius: 16px;
  padding: 14px;
  display: flex; flex-direction: column; gap: 6px;
  text-align: left;
}
.ios-scenario.on { background: var(--ink); color: var(--cream); border-color: var(--ink); }
.ios-scenario .icon {
  width: 28px; height: 28px; border-radius: 8px;
  background: var(--lime-soft); color: var(--emerald-2);
  border: 1px solid #c4ec9c;
  display: grid; place-items: center;
  font-family: 'Instrument Serif', serif; font-style: italic;
  font-size: 15px;
}
.ios-scenario.on .icon { background: rgba(91,224,91,.12); border-color: rgba(91,224,91,.25); color: var(--lime); }
.ios-scenario h5 { margin: 4px 0 0; font-size: 13px; font-weight: 500; }
.ios-scenario p { margin: 0; font-size: 11px; color: var(--mute); line-height: 1.4; }
.ios-scenario.on p { color: rgba(242,239,230,.65); }

.ios-brief-footer {
  position: absolute; bottom: 90px; left: 14px; right: 14px;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 10px;
  display: flex; gap: 8px;
  box-shadow: 0 12px 30px -10px rgba(14,18,15,.15);
}

/* onboarding mobile */
.ios-onb {
  flex: 1; padding: 8px 22px 100px; overflow-y: auto;
}
.ios-onb-eyebrow {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--emerald);
  margin: 8px 0 0;
}
.ios-onb h1 {
  margin: 8px 0 0;
  font-family: 'Instrument Serif', serif; font-weight: 400;
  font-size: 32px; line-height: 1.1; letter-spacing: -0.015em;
}
.ios-onb h1 em { font-style: italic; color: var(--emerald); padding-bottom: .1em; }
.ios-onb .sub { margin: 26px 0 0; font-size: 13.5px; color: var(--ink-3); line-height: 1.55; }

.ios-onb-input {
  width: 100%;
  margin-top: 30px;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--line);
  font-family: 'Instrument Serif', serif;
  font-size: 32px;
  letter-spacing: -0.015em;
  padding: 12px 0;
  outline: none;
  color: var(--ink);
}
.ios-onb-input::placeholder { color: var(--line); font-style: italic; }

.ios-onb-areas {
  margin-top: 24px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
}

.ios-goblin-says {
  margin-top: 28px;
  background: var(--paper);
  border: 1px solid var(--line-2);
  border-radius: 16px;
  padding: 14px 16px;
  position: relative;
}
.ios-goblin-says::before {
  content: ""; position: absolute;
  left: 18px; top: -6px;
  width: 10px; height: 10px;
  background: var(--paper);
  border-left: 1px solid var(--line-2);
  border-top: 1px solid var(--line-2);
  transform: rotate(45deg);
}
.ios-goblin-says .head {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 8px;
}
.ios-goblin-says .head img { width: 22px; height: 22px; }
.ios-goblin-says .head b {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9.5px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--mute); font-weight: 600;
}
.ios-goblin-says p {
  margin: 0;
  font-family: 'Instrument Serif', serif;
  font-size: 16px; line-height: 1.35; letter-spacing: -0.005em;
}
.ios-goblin-says p em { font-style: italic; color: var(--emerald); padding-bottom: .06em; }

.ios-pinned-cta {
  position: absolute; bottom: 26px; left: 14px; right: 14px;
}
.ios-pinned-cta .ios-btn { width: 100%; padding: 14px; font-size: 14px; }

/* ───── Calendar view ───── */
.cal { padding: 24px 0 60px; }
.cal-head {
  display: grid; grid-template-columns: auto 1fr auto auto; gap: 18px;
  align-items: center;
  padding: 14px 20px;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  margin-bottom: 18px;
}
.cal-back {
  width: 36px; height: 36px; border-radius: 999px;
  border: 1px solid var(--line); background: var(--cream);
  display: grid; place-items: center;
  font-size: 14px;
}
.cal-back:hover { background: #fff; }
.cal-title { display: flex; flex-direction: column; min-width: 0; }
.cal-title h2 {
  margin: 0;
  font-family: 'Instrument Serif', serif; font-weight: 400;
  font-size: 28px; letter-spacing: -0.01em; line-height: 1;
}
.cal-title .meta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; color: var(--mute);
  margin-top: 6px; letter-spacing: 0.06em;
}

.cal-view-toggle {
  display: inline-flex; padding: 3px;
  background: var(--cream); border: 1px solid var(--line);
  border-radius: 999px; font-size: 12px;
}
.cal-view-toggle button {
  padding: 7px 12px; border-radius: 999px;
  color: var(--ink-3); font-weight: 500;
}
.cal-view-toggle button.active { background: var(--ink); color: var(--cream); }

.cal-nav { display: inline-flex; gap: 4px; align-items: center; font-family: 'JetBrains Mono', monospace; font-size: 12px; }
.cal-nav button {
  width: 30px; height: 30px; border-radius: 999px;
  border: 1px solid var(--line); background: var(--cream);
  display: grid; place-items: center;
  font-size: 13px;
}
.cal-nav button:hover { background: #fff; }
.cal-nav .today {
  width: auto; padding: 0 12px; font-family: 'Geist', sans-serif;
  font-size: 12px; font-weight: 500;
}

.cal-grid {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 18px; align-items: start;
}

/* WEEK VIEW */
.weekview {
  background: var(--paper); border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 0;
  overflow: hidden;
}
.weekview-header {
  display: grid;
  grid-template-columns: 64px repeat(7, 1fr);
  border-bottom: 1px solid var(--line);
  background: var(--cream);
}
.weekview-corner {}
.weekview-day {
  padding: 12px 8px;
  text-align: center;
  border-left: 1px solid var(--line-2);
  font-size: 11px;
  color: var(--mute);
  font-family: 'JetBrains Mono', monospace; letter-spacing: 0.06em;
  text-transform: uppercase;
}
.weekview-day .dnum {
  font-family: 'Instrument Serif', serif;
  font-size: 22px; line-height: 1;
  color: var(--ink);
  text-transform: none; letter-spacing: -0.01em;
  margin-top: 4px;
  font-weight: 400;
}
.weekview-day.today {
  background: var(--ink); color: var(--lime);
}
.weekview-day.today .dnum { color: var(--lime); }
.weekview-day .pip {
  width: 4px; height: 4px; border-radius: 50%;
  background: var(--lime);
  display: inline-block; margin-top: 4px;
}

.weekview-body {
  display: grid;
  grid-template-columns: 64px repeat(7, 1fr);
  position: relative;
  min-height: 600px;
}
.weekview-hours {
  display: flex; flex-direction: column;
  border-right: 1px solid var(--line);
}
.weekview-hour {
  height: 56px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; color: var(--mute);
  letter-spacing: 0.04em;
  padding: 6px 8px;
  text-align: right;
  border-top: 1px dashed var(--line-2);
}
.weekview-hour:first-child { border-top: none; }
.weekview-col {
  border-left: 1px solid var(--line-2);
  position: relative;
}
.weekview-col::before {
  content: ""; position: absolute; inset: 0;
  background-image: repeating-linear-gradient(180deg, transparent 0, transparent 55px, var(--line-2) 55px, var(--line-2) 56px);
  pointer-events: none;
}
.weekview-col.weekend { background: rgba(14,18,15,.015); }
.weekview-col.today {
  background: linear-gradient(180deg, rgba(91,224,91,.05), transparent 80px);
}
.weekview-col.today::after {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: var(--lime);
}

.cal-event {
  position: absolute;
  left: 3px; right: 3px;
  border-radius: 8px;
  padding: 6px 8px;
  font-size: 11px;
  line-height: 1.25;
  border: 1px solid;
  z-index: 2;
  cursor: pointer;
  display: flex; flex-direction: column; gap: 2px;
  overflow: hidden;
}
.cal-event .lab {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px; letter-spacing: 0.06em;
  opacity: .8;
}
.cal-event .title {
  font-weight: 500; font-size: 11.5px; letter-spacing: -0.005em;
}
.cal-event .who {
  font-size: 10px;
  opacity: .65;
}

.cal-event.confirmed {
  background: var(--lime-soft);
  border-color: #c4ec9c;
  color: var(--emerald-2);
}
.cal-event.live {
  background: var(--ink);
  border-color: var(--ink);
  color: var(--lime);
  box-shadow: 0 8px 18px -8px rgba(14,18,15,.4), 0 0 0 2px rgba(91,224,91,.25);
  z-index: 3;
}
.cal-event.live .live-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--lime);
  box-shadow: 0 0 0 3px rgba(91,224,91,.25);
  animation: pulse 1.6s ease-in-out infinite;
  display: inline-block; margin-right: 4px;
}
.cal-event.pending {
  background: var(--tangerine-soft);
  border-color: #f0c194;
  color: #8a3f15;
  background-image: repeating-linear-gradient(135deg, transparent 0, transparent 6px, rgba(138,63,21,.06) 6px, rgba(138,63,21,.06) 8px);
}
.cal-event.scheduled {
  background: var(--cream);
  border-color: var(--line);
  color: var(--ink-3);
  border-style: dashed;
}
.cal-event.ghost {
  background: transparent;
  border: 1px dashed rgba(14,18,15,.18);
  color: var(--mute);
}
.cal-event.ghost .title { font-weight: 400; }

.cal-event:hover { transform: translateY(-1px); box-shadow: var(--shadow-soft); }

/* now-line marker */
.now-line {
  position: absolute; left: 0; right: 0;
  height: 1px;
  background: var(--tangerine);
  z-index: 4;
  pointer-events: none;
}
.now-line::before {
  content: "";
  position: absolute;
  left: -5px; top: -4px;
  width: 9px; height: 9px;
  border-radius: 50%; background: var(--tangerine);
  box-shadow: 0 0 0 3px rgba(226,107,44,.22);
}
.now-line .now-label {
  position: absolute;
  left: -54px; top: -7px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; color: var(--tangerine);
  background: var(--paper); padding: 1px 5px; border-radius: 4px;
  letter-spacing: 0.04em; font-weight: 500;
}

/* MONTH VIEW */
.monthview {
  background: var(--paper); border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 0;
  overflow: hidden;
}
.month-header {
  display: grid; grid-template-columns: repeat(7, 1fr);
  background: var(--cream);
  border-bottom: 1px solid var(--line);
}
.month-header .dow {
  padding: 12px 10px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--mute);
  border-left: 1px solid var(--line-2);
}
.month-header .dow:first-child { border-left: none; }
.month-grid {
  display: grid; grid-template-columns: repeat(7, 1fr);
  grid-auto-rows: minmax(96px, 1fr);
}
.month-cell {
  border-left: 1px solid var(--line-2);
  border-top: 1px solid var(--line-2);
  padding: 8px;
  display: flex; flex-direction: column; gap: 4px;
  min-width: 0;
}
.month-cell.othermonth { background: rgba(14,18,15,.02); }
.month-cell.othermonth .dnum { color: var(--mute); }
.month-cell.today {
  background: rgba(91,224,91,.03);
}
.month-cell.today .dnum {
  background: var(--lime);
  color: var(--ink);
  border-radius: 999px;
  padding: 2px 9px;
  font-weight: 500;
}
.month-cell .dnum {
  font-family: 'Instrument Serif', serif;
  font-size: 16px; letter-spacing: -0.005em;
  align-self: flex-start;
  padding: 1px 6px;
}
.month-event {
  font-size: 10.5px; line-height: 1.3;
  padding: 3px 6px; border-radius: 4px;
  border: 1px solid;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  cursor: pointer;
}
.month-event.confirmed { background: var(--lime-soft); border-color: #c4ec9c; color: var(--emerald-2); }
.month-event.live { background: var(--ink); border-color: var(--ink); color: var(--lime); font-weight: 500; }
.month-event.pending { background: var(--tangerine-soft); border-color: #f0c194; color: #8a3f15; }
.month-event.scheduled { background: var(--cream); border-color: var(--line); color: var(--ink-3); }
.month-event.ghost { background: transparent; border: 1px dashed rgba(14,18,15,.15); color: var(--mute); }
.month-event-more { font-size: 10px; color: var(--mute); padding: 2px 6px; }

/* AGENDA VIEW */
.agenda { padding: 8px 4px; }
.agenda-day {
  display: grid; grid-template-columns: 100px 1fr;
  gap: 20px;
  padding: 16px 0;
  border-top: 1px solid var(--line-2);
}
.agenda-day:first-child { border-top: none; }
.agenda-day .day-label {
  font-family: 'Instrument Serif', serif;
}
.agenda-day .day-label .dow {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--mute);
}
.agenda-day .day-label .dnum {
  font-size: 30px; line-height: 1; letter-spacing: -0.01em;
  margin-top: 4px;
}
.agenda-day .day-label.today .dnum { color: var(--emerald); }
.agenda-day .events { display: flex; flex-direction: column; gap: 8px; }
.agenda-row {
  display: grid; grid-template-columns: 56px 1fr auto;
  gap: 12px; align-items: center;
  padding: 10px 14px;
  border-radius: 14px;
  background: var(--cream);
  border: 1px solid var(--line-2);
  cursor: pointer;
}
.agenda-row .time { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--mute); }
.agenda-row .info h5 { margin: 0; font-size: 13.5px; font-weight: 500; letter-spacing: -0.005em; }
.agenda-row .info p { margin: 2px 0 0; font-size: 11.5px; color: var(--mute); }
.agenda-row .tag {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.06em;
  padding: 3px 7px; border-radius: 999px;
  background: var(--paper); border: 1px solid var(--line);
}
.agenda-row.confirmed .tag { background: var(--lime-soft); color: var(--emerald-2); border-color: #c4ec9c; }
.agenda-row.live .tag { background: var(--ink); color: var(--lime); border-color: var(--ink); }
.agenda-row.pending .tag { background: var(--tangerine-soft); color: #8a3f15; border-color: #f0c194; }

/* Calendar side panel */
.cal-side { display: grid; gap: 14px; position: sticky; top: 90px; }
.cal-side-card {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 16px 18px;
}
.cal-side-card h4 {
  margin: 0 0 12px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--mute); font-weight: 600;
}
.cal-source {
  display: grid; grid-template-columns: 28px 1fr auto;
  gap: 10px; align-items: center;
  padding: 10px 0;
  border-top: 1px dashed var(--line);
}
.cal-source:first-of-type { border-top: none; padding-top: 0; }
.cal-source .ico {
  width: 28px; height: 28px;
  display: grid; place-items: center;
  border-radius: 8px;
  font-family: 'Instrument Serif', serif; font-style: italic;
  font-size: 17px;
  background: var(--cream); border: 1px solid var(--line); color: var(--ink-3);
}
.cal-source.connected .ico { background: var(--lime-soft); border-color: #c4ec9c; color: var(--emerald-2); }
.cal-source .info { min-width: 0; }
.cal-source .info h5 { margin: 0; font-size: 13px; font-weight: 500; letter-spacing: -0.005em; }
.cal-source .info p {
  margin: 1px 0 0;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px; color: var(--mute); letter-spacing: 0.04em;
}
.cal-source-action {
  font-size: 11px; color: var(--emerald); font-weight: 500;
  white-space: nowrap;
}
.cal-source.connected .cal-source-action { color: var(--mute); }

.cal-legend { display: grid; gap: 6px; }
.cal-legend-row {
  display: grid; grid-template-columns: 16px 1fr;
  gap: 10px; align-items: center;
  font-size: 12px; color: var(--ink-3);
}
.cal-legend-swatch {
  width: 14px; height: 14px; border-radius: 4px;
  border: 1px solid;
}
.cal-legend-swatch.confirmed { background: var(--lime-soft); border-color: #c4ec9c; }
.cal-legend-swatch.live { background: var(--ink); border-color: var(--ink); }
.cal-legend-swatch.pending { background: var(--tangerine-soft); border-color: #f0c194; background-image: repeating-linear-gradient(135deg, transparent 0, transparent 4px, rgba(138,63,21,.12) 4px, rgba(138,63,21,.12) 5px); }
.cal-legend-swatch.scheduled { background: var(--cream); border-color: var(--line); border-style: dashed; }
.cal-legend-swatch.ghost { background: transparent; border-style: dashed; }

/* Availability picker (compact, for wizard) */
.avail-picker {
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--cream);
  padding: 16px;
  margin-top: 12px;
}
.avail-picker .picker-head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 14px;
}
.avail-picker .picker-head h5 {
  margin: 0;
  font-family: 'Instrument Serif', serif; font-weight: 400;
  font-size: 18px; letter-spacing: -0.005em;
}
.avail-picker .picker-head .nav {
  display: inline-flex; gap: 4px;
}
.avail-picker .picker-head .nav button {
  width: 24px; height: 24px;
  border-radius: 999px;
  background: var(--paper); border: 1px solid var(--line);
  font-size: 11px;
}
.avail-week { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; margin-bottom: 12px; }
.avail-day-pick {
  text-align: center;
  padding: 8px 4px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: var(--paper);
  cursor: pointer;
}
.avail-day-pick.on { background: var(--ink); color: var(--cream); border-color: var(--ink); }
.avail-day-pick.disabled { opacity: .35; cursor: not-allowed; }
.avail-day-pick .dow {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9.5px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--mute);
  margin-bottom: 2px;
}
.avail-day-pick.on .dow { color: rgba(242,239,230,.6); }
.avail-day-pick .num {
  font-family: 'Instrument Serif', serif;
  font-size: 19px; line-height: 1; letter-spacing: -0.005em;
}

.avail-windows { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; }
.avail-slot {
  padding: 10px 8px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--paper);
  font-size: 12px;
  cursor: pointer;
  text-align: center;
}
.avail-slot.on { background: var(--lime); color: var(--ink); border-color: var(--lime); }
.avail-slot.disabled { opacity: .35; }
.avail-slot .name { font-weight: 500; }
.avail-slot .hours {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; color: var(--mute);
  margin-top: 2px;
}
.avail-slot.on .hours { color: rgba(14,18,15,.6); }

/* Booking confirmation card (.ics-style) */
.ics-card {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 20px;
  display: grid;
  grid-template-columns: 80px 1fr auto;
  gap: 18px;
  align-items: center;
  margin-top: 16px;
}
.ics-date {
  text-align: center;
  padding: 8px 4px;
  border-radius: 12px;
  background: var(--cream);
  border: 1px solid var(--line);
  position: relative;
}
.ics-date .month {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--tangerine);
  padding: 4px 8px;
  border-bottom: 1px solid var(--line-2);
  margin: -8px -4px 6px;
}
.ics-date .day {
  font-family: 'Instrument Serif', serif;
  font-size: 38px; line-height: 1; letter-spacing: -0.02em;
}
.ics-date .dow {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9.5px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--mute);
  margin-top: 4px;
}
.ics-info h4 {
  margin: 0;
  font-family: 'Instrument Serif', serif; font-weight: 400;
  font-size: 22px; letter-spacing: -0.005em; line-height: 1.2;
}
.ics-info .meta {
  display: flex; gap: 16px; align-items: center; flex-wrap: wrap;
  margin-top: 8px;
  font-size: 12px; color: var(--ink-3);
}
.ics-info .meta b { color: var(--ink); font-weight: 500; }
.ics-info .meta .pip {
  width: 5px; height: 5px; border-radius: 50%; background: var(--mute);
}
.ics-actions { display: flex; flex-direction: column; gap: 6px; }
.ics-actions .btn { padding: 8px 14px; font-size: 12px; }

/* day-detail flyout (just clicked event) */
.day-flyout {
  position: absolute; z-index: 6;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 14px 16px;
  width: 240px;
  box-shadow: var(--shadow-card);
}
.day-flyout::before {
  content: ""; position: absolute;
  left: -7px; top: 18px;
  width: 12px; height: 12px;
  background: var(--paper);
  border-left: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  transform: rotate(45deg);
}
.day-flyout h5 { margin: 0; font-size: 13px; font-weight: 500; letter-spacing: -0.005em; }
.day-flyout .when {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px; color: var(--mute);
  margin: 4px 0 8px; letter-spacing: 0.04em;
}
.day-flyout p { margin: 0 0 10px; font-size: 12px; color: var(--ink-3); line-height: 1.45; }

@media (max-width: 1024px) {
  .cal-grid { grid-template-columns: 1fr; }
  .cal-side { position: static; grid-template-columns: 1fr 1fr; }
}

/* Final micro-spacing parity sweep */
.topbar {
  padding-top: 12px;
  padding-bottom: 12px;
}

.topbar .nav,
.topbar .nav-links {
  gap: 16px;
}

.topbar .top-actions,
.topbar .account-actions {
  gap: 9px;
}

.hero {
  gap: 26px;
}

.hero-card {
  padding: 22px;
  border-radius: 26px;
}

.hero-card h3 {
  margin-top: 12px;
  margin-bottom: 12px;
}

.radar-transcript {
  margin-top: 14px;
}

.detail-tabs {
  gap: 8px;
  margin-top: 8px;
  margin-bottom: 12px;
}

.detail-tab {
  padding: 6px 10px;
  border-radius: 10px;
  font-size: 11.5px;
}

.mission-detail-card #detailPane {
  line-height: 1.5;
}

.foot {
  padding-top: 86px;
}

.foot-grid {
  column-gap: 42px;
}

.foot-bottom {
  margin-top: 52px;
}
@media (max-width: 640px) {
  .shell {
    padding: 0 12px;
  }

  .topbar {
    grid-template-columns: 1fr;
    gap: 10px;
    padding: 10px 0 12px;
  }

  .topbar .nav,
  .topbar .nav-links {
    display: none;
  }

  .topbar .top-actions,
  .topbar .account-actions {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: center;
    gap: 8px;
  }

  .topbar #servicePill,
  .topbar .status-chip {
    grid-column: 1 / -1;
    width: 100%;
    justify-content: center;
    text-align: center;
    white-space: normal;
    pointer-events: none;
  }

  .topbar #openLogin,
  .topbar #openSignup,
  .topbar #logoutButton {
    width: 100%;
    min-width: 0;
  }

  .hero {
    gap: 18px;
    padding: 12px 0 28px;
  }

  .headline {
    margin-top: 12px;
  }

  .hero-sub {
    margin-top: 24px;
  }

  .hero-cta {
    margin-top: 20px;
    gap: 10px;
  }

  .hero-meta {
    margin-top: 18px;
    gap: 14px;
  }

  .radar {
    min-height: 0;
    padding: 20px 16px 16px;
  }

  .section {
    padding: 48px 0;
  }

  .section-head {
    margin-bottom: 18px;
    gap: 14px;
  }

  .dash-shell {
    gap: 12px;
    padding: 16px 0;
  }

  .dash-card {
    padding: 14px;
  }

  .wizard-shell {
    padding: 18px;
    border-radius: 20px;
  }

  .wiz-stepper {
    margin-bottom: 16px;
  }

  .field {
    margin-bottom: 12px;
  }

  .field input,
  .field textarea,
  .field select {
    padding: 10px 12px;
  }
}
