/* ============================================================================
 * Interviewer Studio — brand skin (Aurora / Daylight / Papyrus)
 *
 * Loaded AFTER interviewer.css. Everything is scoped to body.intv-app so no
 * other product (Book RAG, GrowthCanvas) is affected.
 *
 * Theme slots are re-skinned so all existing component rules keep working:
 *   - Aurora   = theme-dark   (deep-space dark, violet -> cyan)
 *   - Daylight = theme-default (bright, violet -> cyan)
 *   - Papyrus  = theme-papyrus (warm paper, clay accent, serif display)
 * ============================================================================ */

/* ---------- AURORA (dark slot) ---------- */
body.theme-dark.intv-app {
  --bg-color: #070611;
  --containerbackground: #13112a;
  --bg-footer-color: transparent;
  --text-color: #ECEBFF;
  --text-color-inv: #ffffff;
  --accent-color: #8B5CF6;
  --accent-color-dark: #6d4ddb;
  --border-color: rgba(255, 255, 255, 0.10);
  --header-bg: rgba(10, 9, 24, 0.72);
  --placeholder-color: #8a86b0;
  --bg-secondary: rgba(255, 255, 255, 0.04);
  --bg-tertiary: rgba(255, 255, 255, 0.06);
  --bg-hover: rgba(255, 255, 255, 0.07);

  --intv-app-bg: #070611;
  --intv-app-bg-2: #0d0b1c;
  --intv-surface: #13112a;
  --intv-surface-2: #0f0d22;
  --intv-surface-3: #1b1838;
  --intv-text: #ECEBFF;
  --intv-muted: #A6A2CE;
  --intv-faint: #6f6b96;
  --intv-line: rgba(255, 255, 255, 0.10);
  --intv-line-soft: rgba(255, 255, 255, 0.06);
  --intv-accent: #8B5CF6;
  --intv-accent-hover: #a78bfa;
  --intv-accent-soft: rgba(139, 92, 246, 0.16);
  --intv-success: #34D399;
  --intv-warning: #FBBF24;
  --intv-danger: #FB7185;

  --intv-studio-ink: #ECEBFF;
  --intv-studio-muted: #A6A2CE;
  --intv-studio-line: rgba(255, 255, 255, 0.10);
  --intv-studio-surface: #13112a;
  --intv-studio-soft: #070611;
  --intv-studio-teal: #22D3EE;
  --intv-studio-coral: #8B5CF6;

  --intv-grad: linear-gradient(135deg, #8B5CF6 0%, #6366F1 45%, #22D3EE 100%);
  --intv-glow: 0 10px 30px -10px rgba(99, 102, 241, 0.85);
  background: var(--intv-app-bg);
  color: var(--intv-text);
}
body.theme-dark.intv-app .intv-app-body {
  background: linear-gradient(180deg, #0b0920 0%, #070611 100%);
}

/* ---------- DAYLIGHT (default/light slot) ---------- */
body.theme-default.intv-app {
  --bg-color: #F5F4FB;
  --containerbackground: #ffffff;
  --bg-footer-color: transparent;
  --text-color: #191634;
  --text-color-inv: #ffffff;
  --accent-color: #6D5CF6;
  --accent-color-dark: #5546e0;
  --border-color: rgba(26, 20, 60, 0.12);
  --header-bg: rgba(245, 244, 251, 0.82);
  --placeholder-color: #8c88ac;
  --bg-secondary: #f3f1fb;
  --bg-tertiary: #ecebf6;
  --bg-hover: #eceaf7;

  --intv-app-bg: #F5F4FB;
  --intv-app-bg-2: #ecebf6;
  --intv-surface: #ffffff;
  --intv-surface-2: #f7f6fd;
  --intv-surface-3: #eeecf8;
  --intv-text: #191634;
  --intv-muted: #5A5680;
  --intv-faint: #8C88AC;
  --intv-line: rgba(26, 20, 60, 0.12);
  --intv-line-soft: rgba(26, 20, 60, 0.07);
  --intv-accent: #6D5CF6;
  --intv-accent-hover: #5546e0;
  --intv-accent-soft: rgba(109, 92, 246, 0.10);
  --intv-success: #0E8C57;
  --intv-warning: #B45309;
  --intv-danger: #E24B4A;

  --intv-studio-ink: #191634;
  --intv-studio-muted: #5A5680;
  --intv-studio-line: rgba(26, 20, 60, 0.12);
  --intv-studio-surface: #ffffff;
  --intv-studio-soft: #F5F4FB;
  --intv-studio-teal: #0E7490;
  --intv-studio-coral: #6D5CF6;

  --intv-grad: linear-gradient(135deg, #8B5CF6 0%, #6366F1 45%, #22D3EE 100%);
  --intv-glow: 0 10px 30px -12px rgba(99, 102, 241, 0.45);
  background: var(--intv-app-bg);
  color: var(--intv-text);
}
body.theme-default.intv-app .intv-app-body {
  background: linear-gradient(180deg, #fbfbff 0%, #F5F4FB 100%);
}

/* ---------- PAPYRUS (new paper theme) ---------- */
body.theme-papyrus.intv-app {
  --bg-color: #F7F4EC;
  --containerbackground: #FFFDF9;
  --bg-footer-color: transparent;
  --text-color: #26211A;
  --text-color-inv: #ffffff;
  --accent-color: #C15F3C;
  --accent-color-dark: #A8492A;
  --border-color: rgba(31, 27, 22, 0.13);
  --header-bg: rgba(243, 239, 228, 0.86);
  --placeholder-color: #9A8F7C;
  --bg-secondary: #F5F1E7;
  --bg-tertiary: #EFE9DD;
  --bg-hover: #efe9dc;

  --intv-app-bg: #F7F4EC;
  --intv-app-bg-2: #efe9dd;
  --intv-surface: #FFFDF9;
  --intv-surface-2: #FBF8F1;
  --intv-surface-3: #F3EEE2;
  --intv-text: #26211A;
  --intv-muted: #6E6456;
  --intv-faint: #9A8F7C;
  --intv-line: rgba(31, 27, 22, 0.13);
  --intv-line-soft: rgba(31, 27, 22, 0.07);
  --intv-accent: #C15F3C;
  --intv-accent-hover: #A8492A;
  --intv-accent-soft: rgba(193, 95, 60, 0.10);
  --intv-success: #4E7A4A;
  --intv-warning: #9A7A1E;
  --intv-danger: #C0654A;

  --intv-studio-ink: #26211A;
  --intv-studio-muted: #6E6456;
  --intv-studio-line: rgba(31, 27, 22, 0.13);
  --intv-studio-surface: #FFFDF9;
  --intv-studio-soft: #F7F4EC;
  --intv-studio-teal: #4F6D67;
  --intv-studio-coral: #C15F3C;

  --intv-grad: linear-gradient(135deg, #D5926B 0%, #C5744E 100%);
  --intv-glow: 0 8px 22px -14px rgba(168, 73, 42, 0.40);
  background: var(--intv-app-bg);
  color: var(--intv-text);
}
body.theme-papyrus.intv-app .intv-app-body {
  background: linear-gradient(180deg, #FBF8F1 0%, #F7F4EC 100%);
}

/* ============================================================================
 * Shared brand treatments — read the per-theme tokens above so they adapt.
 * Scoped with body.intv-app prefix to win over base component rules.
 * ============================================================================ */

body.intv-app {
  font-family: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}

body.intv-app .intv-brand-title,
body.intv-app .intv-hero-title,
body.intv-app .intv-hero-eyebrow,
body.intv-app .intv-steps-title,
body.intv-app .intv-feature-title,
body.intv-app .intv-step h3,
body.intv-app .intv-analysis-title,
body.intv-app .intv-persona-preview-head h2 {
  font-family: 'Sora', 'Inter', system-ui, sans-serif;
  letter-spacing: -0.01em;
}

/* gradient brand mark + glow */
body.intv-app .intv-brand-mark {
  background: var(--intv-grad);
  color: #fff;
  border: none;
  box-shadow: var(--intv-glow);
}
body.intv-app .intv-brand-mark svg { stroke: #fff; }

/* primary buttons carry the signature gradient */
body.intv-app .intv-btn-primary,
body.intv-app .qa-btn-primary,
body.intv-app .tpl-btn-primary {
  background: var(--intv-grad);
  border: none;
  color: #fff;
  box-shadow: var(--intv-glow);
}
body.intv-app .intv-btn-primary:hover,
body.intv-app .qa-btn-primary:hover,
body.intv-app .tpl-btn-primary:hover {
  filter: brightness(1.07);
  background: var(--intv-grad);
}

/* hero accents */
body.intv-app .intv-hero-eyebrow { color: var(--intv-accent); }
body.theme-dark.intv-app .intv-hero-title,
body.theme-default.intv-app .intv-hero-title {
  background: var(--intv-grad);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* step numbers + waveform pick up the accent/gradient */
body.intv-app .intv-step-num {
  background: var(--intv-grad);
  color: #fff;
  border: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  min-width: 42px;
  height: 42px;
  border-radius: 12px;
  margin-bottom: 12px;
}
body.intv-app .intv-wave-preview span,
body.intv-app .intv-preview-live { color: var(--intv-accent); }

/* ---------- Papyrus: warm paper display + flat (no glow) ---------- */
body.theme-papyrus.intv-app .intv-brand-title,
body.theme-papyrus.intv-app .intv-hero-title,
body.theme-papyrus.intv-app .intv-steps-title,
body.theme-papyrus.intv-app .intv-feature-title,
body.theme-papyrus.intv-app .intv-step h3,
body.theme-papyrus.intv-app .intv-analysis-title,
body.theme-papyrus.intv-app .intv-persona-preview-head h2 {
  font-family: 'Sora', 'Inter', system-ui, -apple-system, Segoe UI, sans-serif;
  letter-spacing: 0;
}
body.theme-papyrus.intv-app .intv-hero-title { color: var(--intv-text); }

/* ============================================================================
 * FULL SCREEN REDESIGN — concept layout applied to the live DOM.
 * Uses existing .intv-* classes; reads per-theme tokens above.
 * ============================================================================ */

/* ---- App shell: glass topnav + command-center sidebar ---- */
body.intv-app .intv-topnav {
  background: color-mix(in srgb, var(--intv-surface) 72%, transparent) !important;
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border-bottom: 1px solid var(--intv-line) !important;
}
body.intv-app .intv-brand-title {
  font-weight: 700;
  font-size: 17px;
}
body.intv-app .intv-brand-tag { color: var(--intv-faint) !important; }

body.intv-app .intv-sidebar {
  background: color-mix(in srgb, var(--intv-surface) 55%, transparent) !important;
  border-right: 1px solid var(--intv-line) !important;
}
body.intv-app .intv-sidebar-link {
  border-radius: 11px !important;
  font-weight: 500;
  color: var(--intv-muted) !important;
  transition: background .15s, color .15s;
}
body.intv-app .intv-sidebar-link:hover {
  background: var(--intv-surface-3) !important;
  color: var(--intv-text) !important;
}
body.intv-app .intv-sidebar-link.active,
body.intv-app .intv-sidebar-link[aria-current="page"] {
  background: var(--intv-accent-soft) !important;
  color: var(--intv-text) !important;
  border: 1px solid color-mix(in srgb, var(--intv-accent) 35%, transparent) !important;
}
body.intv-app .intv-sidebar-eyebrow { color: var(--intv-faint) !important; letter-spacing: .12em; }

/* ---- Generic framed panels ---- */
body.intv-app .intv-card {
  background: var(--intv-surface) !important;
  border: 1px solid var(--intv-line) !important;
  border-radius: 18px !important;
  box-shadow: 0 18px 50px -28px rgba(0,0,0,.45) !important;
}
body.intv-app .intv-card-title { font-weight: 600; letter-spacing: -.01em; }

/* ---- Landing hero ---- */
body.intv-app .intv-hero-studio,
body.intv-app .intv-hero {
  gap: 40px;
  align-items: center;
}
body.intv-app .intv-hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 6px 13px;
  border-radius: 999px;
  background: var(--intv-accent-soft);
  border: 1px solid color-mix(in srgb, var(--intv-accent) 30%, transparent);
  font-size: 12px;
  letter-spacing: .04em;
  text-transform: none;
}
body.intv-app .intv-hero-title {
  font-size: clamp(34px, 4.6vw, 54px) !important;
  line-height: 1.05 !important;
  font-weight: 700 !important;
}
body.intv-app .intv-hero-subtitle {
  font-size: 17px !important;
  color: var(--intv-muted) !important;
  max-width: 520px;
}

/* ---- Voice orb (front page centrepiece) ---- */
body.intv-app .intv-hero-orbwrap {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 400px;
}
body.intv-app .intv-orb-stage { position: relative; width: 320px; height: 320px; }
body.intv-app .intv-orb-rings span {
  position: absolute; inset: 0; border-radius: 50%;
  border: 1px solid var(--intv-line);
  animation: intv-spin 24s linear infinite;
}
body.intv-app .intv-orb-rings span:nth-child(2) { inset: 32px; border-color: color-mix(in srgb, var(--intv-accent) 30%, transparent); animation-duration: 17s; animation-direction: reverse; }
body.intv-app .intv-orb-rings span:nth-child(3) { inset: 70px; border-color: color-mix(in srgb, var(--intv-studio-teal) 30%, transparent); animation-duration: 30s; }
body.intv-app .intv-orb {
  position: absolute; inset: 100px; border-radius: 50%;
  background: var(--intv-grad);
  box-shadow: var(--intv-glow), inset 0 0 40px rgba(255,255,255,.25);
  display: grid; place-items: center;
}
body.intv-app .intv-orb-wave { display: flex; align-items: center; gap: 5px; height: 44px; }
body.intv-app .intv-orb-wave i { width: 5px; border-radius: 3px; background: rgba(255,255,255,.92); animation: intv-eq 1.1s ease-in-out infinite; }
body.intv-app .intv-orb-wave i:nth-child(1){height:18px}
body.intv-app .intv-orb-wave i:nth-child(2){height:38px;animation-delay:.15s}
body.intv-app .intv-orb-wave i:nth-child(3){height:26px;animation-delay:.3s}
body.intv-app .intv-orb-wave i:nth-child(4){height:46px;animation-delay:.1s}
body.intv-app .intv-orb-wave i:nth-child(5){height:22px;animation-delay:.25s}
body.intv-app .intv-orb-wave i:nth-child(6){height:34px;animation-delay:.05s}
body.intv-app .intv-orb-floatcard {
  position: absolute; right: -6px; bottom: 6px; width: 270px; z-index: 2;
  background: color-mix(in srgb, var(--intv-surface) 86%, transparent) !important;
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--intv-line) !important;
  border-radius: 16px !important;
  box-shadow: 0 18px 50px -22px rgba(0,0,0,.6) !important;
  animation: intv-bob 5s ease-in-out infinite;
}
@keyframes intv-spin { to { transform: rotate(360deg); } }
@keyframes intv-eq { 0%,100%{transform:scaleY(.5)} 50%{transform:scaleY(1)} }
@keyframes intv-bob { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }

/* ---- Feature + steps cards ---- */
body.intv-app .intv-feature,
body.intv-app .intv-step {
  background: var(--intv-surface) !important;
  border: 1px solid var(--intv-line) !important;
  border-radius: 18px !important;
  padding: 22px !important;
  transition: transform .2s, border-color .2s;
}
body.intv-app .intv-feature:hover,
body.intv-app .intv-step:hover {
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--intv-accent) 35%, transparent) !important;
}
body.intv-app .intv-feature-title { font-size: 16px; font-weight: 600; }
body.intv-app .intv-feature-desc { color: var(--intv-muted) !important; }

/* ---- Run start + live interview surfaces ---- */
body.intv-app .intv-run-summary { display: flex; gap: 12px; flex-wrap: wrap; }
body.intv-app .intv-run-summary > div {
  flex: 1; min-width: 130px;
  background: var(--intv-surface-2) !important;
  border: 1px solid var(--intv-line-soft) !important;
  border-radius: 14px !important;
  padding: 14px 16px !important;
}
body.intv-app .intv-run-summary span { color: var(--intv-muted) !important; font-size: 12px; }
body.intv-app .intv-run-summary strong { display: block; margin-top: 4px; font-size: 18px; }

body.intv-app .intv-mode-cards { display: grid; grid-template-columns: repeat(auto-fit,minmax(180px,1fr)); gap: 12px; }
body.intv-app .intv-mode-card {
  background: var(--intv-surface-2) !important;
  border: 1px solid var(--intv-line) !important;
  border-radius: 16px !important;
  padding: 16px 18px !important;
  text-align: left;
  transition: border-color .2s, transform .1s;
}
body.intv-app .intv-mode-card:hover { transform: translateY(-2px); border-color: color-mix(in srgb, var(--intv-accent) 40%, transparent) !important; }
body.intv-app .intv-mode-card.is-disabled,
body.intv-app .intv-mode-card:disabled {
  opacity: .56;
  cursor: not-allowed;
  filter: grayscale(.16);
}
body.intv-app .intv-mode-card.is-disabled:hover,
body.intv-app .intv-mode-card:disabled:hover {
  transform: none;
  border-color: var(--intv-line) !important;
  background: var(--intv-surface-2) !important;
}
body.intv-app .intv-mode-card.selected {
  border-color: transparent !important;
  background:
    linear-gradient(var(--intv-surface-2), var(--intv-surface-2)) padding-box,
    var(--intv-grad) border-box !important;
  border: 1.5px solid transparent !important;
  box-shadow: var(--intv-glow) !important;
}
body.intv-app .intv-mode-card-title { font-weight: 600; }
body.intv-app .intv-mode-card-desc { color: var(--intv-muted) !important; font-size: 13px; }
body.intv-app .intv-mode-card-badge {
  background: var(--intv-accent-soft) !important;
  color: var(--intv-accent) !important;
  border-radius: 999px; font-size: 11px; font-weight: 600; padding: 3px 10px;
}
body.intv-app .intv-mode-badge-muted {
  background: color-mix(in srgb, var(--intv-muted) 14%, transparent) !important;
  color: var(--intv-muted) !important;
}

/* ---- Forms ---- */
body.intv-app .intv-input,
body.intv-app .intv-app input[type="text"],
body.intv-app .intv-app input[type="email"] {
  background: var(--intv-surface-2) !important;
  border: 1px solid var(--intv-line) !important;
  border-radius: 11px !important;
  color: var(--intv-text) !important;
}
body.intv-app .intv-input:focus {
  outline: none !important;
  border-color: var(--intv-accent) !important;
  box-shadow: 0 0 0 3px var(--intv-accent-soft) !important;
}
body.intv-app .intv-form-label { color: var(--intv-muted) !important; font-size: 13px; }

/* ---- Persona badge + gallery ---- */
body.intv-app .intv-persona-badge {
  background: var(--intv-surface-2) !important;
  border: 1px solid var(--intv-line) !important;
  border-radius: 14px !important;
}
body.intv-app .intv-persona-mini-card {
  background: var(--intv-surface) !important;
  border: 1px solid var(--intv-line) !important;
  border-radius: 18px !important;
  transition: transform .2s, border-color .2s;
}
body.intv-app .intv-persona-mini-card:hover {
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--intv-accent) 35%, transparent) !important;
}
body.intv-app .intv-persona-mini-role { color: var(--intv-accent) !important; font-weight: 600; }
body.intv-app .intv-persona-mini-desc { color: var(--intv-muted) !important; }

/* ---- Analysis: metric cards + clean table ---- */
body.intv-app .intv-analysis-title { font-size: 24px; font-weight: 700; }
body.intv-app .intv-analysis-sub { color: var(--intv-muted) !important; }
body.intv-app .intv-stats-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(160px,1fr)); gap: 14px; }
body.intv-app .intv-stats-grid > * {
  display: flex;
  flex-direction: column;
  background: var(--intv-surface) !important;
  border: 1px solid var(--intv-line) !important;
  border-radius: 16px !important;
  padding: 18px !important;
}
body.intv-app .intv-stat-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  margin-top: auto;
  align-self: flex-end;
  padding: 7px 11px;
  border-radius: 9px;
  border: 1px solid var(--intv-line);
  background: var(--intv-surface-2);
  color: var(--intv-accent);
  font: inherit;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
}
body.intv-app .intv-stat-action:hover,
body.intv-app .intv-stat-action:focus-visible {
  border-color: var(--intv-accent);
  outline: none;
}
body.intv-app .intv-analysis-table-wrap {
  background: var(--intv-surface) !important;
  border: 1px solid var(--intv-line) !important;
  border-radius: 18px !important;
  overflow: hidden;
}
body.intv-app .intv-analysis-table th {
  color: var(--intv-faint) !important;
  font-weight: 600; font-size: 12px; text-transform: uppercase; letter-spacing: .06em;
  border-bottom: 1px solid var(--intv-line) !important;
}
body.intv-app .intv-analysis-table td { border-bottom: 1px solid var(--intv-line-soft) !important; }
body.intv-app .intv-analysis-table tr.is-selected-set td { background: var(--intv-accent-soft) !important; }
body.intv-app .intv-analysis-table tr:hover td { background: var(--intv-surface-2) !important; }
body.intv-app .intv-analysis-table tr.is-selected-set:hover td { background: var(--intv-accent-soft) !important; }

/* ---- Secondary buttons: subtle glass ---- */
body.intv-app .intv-btn:not(.intv-btn-primary) {
  background: var(--intv-surface-2) !important;
  border: 1px solid var(--intv-line) !important;
  color: var(--intv-text) !important;
  border-radius: 12px !important;
}
body.intv-app .intv-btn:not(.intv-btn-primary):hover {
  border-color: var(--intv-accent) !important;
  background: var(--intv-surface-3) !important;
}

/* ---- Papyrus: soften glows, flatten orb for the calm paper look ---- */
body.theme-papyrus.intv-app .intv-orb { box-shadow: 0 12px 34px -16px rgba(168,73,42,.4); }
body.theme-papyrus.intv-app .intv-mode-card.selected { box-shadow: none !important; }

@media (max-width: 900px) {
  body.intv-app .intv-hero-orbwrap { min-height: 300px; }
  body.intv-app .intv-orb-stage { transform: scale(.82); }
  body.intv-app .intv-orb-floatcard { right: 0; }
}

/* ============================================================================
 * Persistent command-center sidebar on desktop (concept app shell).
 * Below 1024px the original slide-in drawer behaviour is kept.
 * ============================================================================ */
@media (min-width: 1024px) {
  body.intv-app .intv-nav-burger { display: none !important; }
  body.intv-app .intv-sidebar-backdrop { display: none !important; }
  body.intv-app .intv-sidebar {
    transform: none !important;
    top: 63px !important;
    height: calc(100vh - 63px) !important;
    width: 248px !important;
    background: var(--intv-surface) !important;
    border-right: 1px solid var(--intv-line) !important;
    box-shadow: none !important;
    padding: 18px 14px !important;
  }
  body.intv-app .intv-container {
    margin-left: 248px !important;
    margin-right: auto !important;
    max-width: 1120px;
  }
}

/* ============================================================================
 * Landing hero: clean voice-orb centrepiece + floating glass chips.
 * ============================================================================ */
body.intv-app .intv-hero-orbwrap { min-height: 420px; }
body.intv-app .intv-orb-stage { width: 360px; height: 360px; }
body.intv-app .intv-orb { inset: 116px; }
body.intv-app .intv-orb-floatcard { display: none !important; }
body.intv-app .intv-orb-chip {
  position: absolute;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 9px 13px; border-radius: 999px;
  font-size: 13px; font-weight: 500; white-space: nowrap;
  color: var(--intv-text);
  background: color-mix(in srgb, var(--intv-surface) 88%, transparent);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--intv-line);
  box-shadow: 0 16px 44px -22px rgba(0,0,0,.6);
  animation: intv-bob 5s ease-in-out infinite;
}
body.intv-app .intv-orb-chip-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--intv-success); box-shadow: 0 0 10px var(--intv-success);
}
body.intv-app .intv-orb-chip-ic {
  display: inline-grid; place-items: center; width: 18px; height: 18px;
  border-radius: 6px; background: var(--intv-accent-soft); color: var(--intv-accent); font-size: 11px;
}
body.intv-app .intv-orb-chip-1 { top: 12px; left: -16px; animation-delay: 0s; }
body.intv-app .intv-orb-chip-2 { bottom: 58px; right: -22px; animation-delay: 1.3s; }
body.intv-app .intv-orb-chip-3 { bottom: -4px; left: 28px; animation-delay: .7s; }
@media (max-width: 900px) {
  body.intv-app .intv-orb-stage { transform: scale(.8); }
  body.intv-app .intv-orb-chip-2 { right: 0; }
}

/* ============================================================================
 * Landing: concept feature grid (6) + how-it-works (4) + section heads.
 * ============================================================================ */
body.intv-app .intv-section-head { max-width: 680px; margin: 50px 0 22px; }
body.intv-app .intv-section-head .intv-kicker {
  display: inline-block; font-size: 12px; letter-spacing: .14em;
  text-transform: uppercase; color: var(--intv-accent); font-weight: 600; margin-bottom: 10px;
}
body.intv-app .intv-section-head .intv-steps-title { margin: 0; font-size: 28px; line-height: 1.15; }
body.intv-app .intv-section-sub { color: var(--intv-muted); font-size: 16px; margin-top: 8px; }

body.intv-app .intv-feature-grid-6 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
body.intv-app .intv-feature-ic {
  display: inline-grid; place-items: center; width: 46px; height: 46px;
  border-radius: 13px; margin-bottom: 14px;
  background: var(--intv-accent-soft); border: 1px solid var(--intv-line); color: var(--intv-accent);
}
body.intv-app .intv-feature-ic svg { width: 22px; height: 22px; }

body.intv-app .intv-steps-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }

@media (max-width: 900px) {
  body.intv-app .intv-feature-grid-6 { grid-template-columns: 1fr 1fr; }
  body.intv-app .intv-steps-grid-4 { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
  body.intv-app .intv-feature-grid-6, body.intv-app .intv-steps-grid-4 { grid-template-columns: 1fr; }
}

/* ============================================================================
 * Insights: real completion donut + interviews-by-set bars.
 * ============================================================================ */
body.intv-app .intv-an-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 16px; margin-top: 18px; }
body.intv-app .intv-tbars { display: flex; flex-direction: column; gap: 12px; }
body.intv-app .intv-tbar-row { display: flex; align-items: center; gap: 12px; }
body.intv-app .intv-tbar-name { width: 150px; font-size: 13px; color: var(--intv-text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
body.intv-app .intv-tbar-track { flex: 1; height: 9px; border-radius: 6px; background: var(--intv-surface-3); overflow: hidden; }
body.intv-app .intv-tbar-track > span { display: block; height: 100%; border-radius: 6px; background: var(--intv-grad); }
body.intv-app .intv-tbar-val { width: 34px; text-align: right; font-size: 13px; color: var(--intv-muted); }
body.intv-app .intv-an-donut-card { display: flex; flex-direction: column; align-items: center; }
body.intv-app .intv-donut { width: 150px; height: 150px; border-radius: 50%; display: grid; place-items: center; margin: 8px 0 14px; }
body.intv-app .intv-donut-hole { width: 104px; height: 104px; border-radius: 50%; background: var(--intv-surface); display: grid; place-items: center; text-align: center; }
body.intv-app .intv-donut-hole b { font-family: 'Sora','Inter',sans-serif; font-size: 24px; display: block; line-height: 1.1; }
body.intv-app .intv-donut-hole span { font-size: 11px; color: var(--intv-faint); }
body.intv-app .intv-legend { display: flex; flex-direction: column; gap: 8px; width: 100%; }
body.intv-app .intv-legend div { display: flex; align-items: center; gap: 9px; font-size: 13px; color: var(--intv-muted); }
body.intv-app .intv-legend i { width: 11px; height: 11px; border-radius: 3px; }
@media (max-width: 900px) { body.intv-app .intv-an-grid { grid-template-columns: 1fr; } }

/* ============================================================================
 * Insights: on-demand AI synthesis panel (real /brief data).
 * ============================================================================ */
body.intv-app .intv-synth-head { display: flex; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap; margin-bottom: 14px; }
body.intv-app .intv-synth-controls { display: flex; align-items: center; gap: 10px; }
body.intv-app #ana-synth-set { min-width: 220px; height: 36px; }
body.intv-app .intv-synth-meta { font-size: 13px; color: var(--intv-faint); margin-bottom: 12px; }
body.intv-app .intv-synth-charts { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 14px; margin-bottom: 18px; }
body.intv-app .intv-synth-brief { font-size: 14px; color: var(--intv-muted); line-height: 1.7; }
body.intv-app .intv-synth-brief h1, body.intv-app .intv-synth-brief h2, body.intv-app .intv-synth-brief h3 { font-family: 'Sora','Inter',sans-serif; color: var(--intv-text); margin: 16px 0 8px; }
body.intv-app .intv-synth-brief h2 { font-size: 17px; }
body.intv-app .intv-synth-brief h3 { font-size: 15px; }
body.intv-app .intv-synth-brief ul, body.intv-app .intv-synth-brief ol { padding-left: 20px; margin: 8px 0; }
body.intv-app .intv-synth-brief li { margin: 4px 0; }
body.intv-app .intv-synth-brief strong { color: var(--intv-text); }

/* ============================================================================
 * Dashboard (signed-in Home) — real data.
 * ============================================================================ */
body.intv-app .intv-dash-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; flex-wrap: wrap; margin-bottom: 18px; }
body.intv-app .intv-dashboard-empty {
  max-width: 760px;
  margin: 12px auto 0;
  padding: 30px 24px;
}
body.intv-app .intv-drow { display: flex; align-items: center; gap: 12px; padding: 12px 0; border-bottom: 1px solid var(--intv-line-soft); }
body.intv-app .intv-drow:last-child { border-bottom: none; }
body.intv-app .intv-drow .ic { width: 36px; height: 36px; border-radius: 10px; display: grid; place-items: center; flex: none; background: var(--intv-accent-soft); color: var(--intv-accent); }
body.intv-app .intv-drow .t { flex: 1; min-width: 0; }
body.intv-app .intv-drow .t b { font-size: 14px; display: block; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
body.intv-app .intv-drow .t small { color: var(--intv-faint); font-size: 12px; }
body.intv-app .intv-drow-link {
  display: block;
  max-width: 100%;
  border: 0;
  padding: 0;
  background: transparent;
  color: var(--intv-text);
  font: inherit;
  font-size: 14px;
  font-weight: 700;
  text-align: left;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  cursor: pointer;
}
body.intv-app .intv-drow-link:hover,
body.intv-app .intv-drow-link:focus-visible {
  color: var(--intv-accent);
  text-decoration: underline;
  outline: none;
}
body.intv-app .intv-weekbars { display: flex; align-items: flex-end; gap: 8px; height: 120px; padding-top: 8px; }
body.intv-app .intv-weekbars .wb { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 6px; height: 100%; justify-content: flex-end; }
body.intv-app .intv-weekbars .wb i { width: 100%; border-radius: 6px 6px 3px 3px; background: var(--intv-grad); min-height: 3px; display: block; }
body.intv-app .intv-weekbars .wb span { font-size: 10px; color: var(--intv-faint); }
body.intv-app .intv-quick { display: flex; flex-direction: column; gap: 8px; }
body.intv-app .intv-quick button { display: flex; align-items: center; justify-content: space-between; width: 100%; padding: 11px 14px; border-radius: 11px; border: 1px solid var(--intv-line); background: var(--intv-surface-2); color: var(--intv-text); font-size: 14px; cursor: pointer; transition: border-color .15s; }
body.intv-app .intv-quick button:hover { border-color: var(--intv-accent); }

/* ============================================================================
 * Interview Set builder (wizard) polish.
 * ============================================================================ */
body.intv-app .intv-q-num { background: var(--intv-grad) !important; color: #fff !important; font-weight: 700; }
body.intv-app .intv-question-editor { margin-bottom: 12px; transition: border-color .15s; }
body.intv-app .intv-question-editor:focus-within { border-color: color-mix(in srgb, var(--intv-accent) 45%, transparent) !important; }
body.intv-app .intv-q-question-input {
  background: var(--intv-surface-2); border: 1px solid var(--intv-line);
  border-radius: 10px; color: var(--intv-text); font-size: 15px; padding: 10px 12px; width: 100%;
}
body.intv-app .intv-q-question-input:focus { outline: none; border-color: var(--intv-accent); box-shadow: 0 0 0 3px var(--intv-accent-soft); }
body.intv-app .intv-q-type-select, body.intv-app .intv-q-category-input {
  background: var(--intv-surface-2); border: 1px solid var(--intv-line); border-radius: 9px; color: var(--intv-text);
}
body.intv-app .intv-q-tool {
  display: inline-grid; place-items: center; width: 32px; height: 32px; border-radius: 9px;
  background: var(--intv-surface-2); border: 1px solid var(--intv-line); color: var(--intv-muted); cursor: pointer; transition: .15s;
}
body.intv-app .intv-q-tool:hover { border-color: var(--intv-accent); color: var(--intv-text); }
body.intv-app .intv-q-tool.is-danger:hover { border-color: var(--intv-danger); color: var(--intv-danger); }
body.intv-app .intv-questions-add {
  display: flex; align-items: center; justify-content: center; gap: 8px; width: 100%;
  padding: 12px; border: 1px dashed var(--intv-line); border-radius: 12px; background: transparent;
  color: var(--intv-muted); font-weight: 500; cursor: pointer; transition: .15s;
}
body.intv-app .intv-questions-add:hover { border-color: var(--intv-accent); color: var(--intv-text); background: var(--intv-accent-soft); }

body.intv-app .intv-start-methods {
  background: color-mix(in srgb, var(--intv-surface-2) 82%, transparent);
  border-color: var(--intv-line);
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 5%, transparent);
}
body.intv-app .intv-start-choice {
  background: var(--intv-surface);
  border-color: var(--intv-line-soft);
  color: var(--intv-text);
}
body.intv-app .intv-start-choice:hover {
  border-color: color-mix(in srgb, var(--intv-accent) 38%, transparent);
  background: var(--intv-surface-3);
}
body.intv-app .intv-start-choice.selected {
  background: color-mix(in srgb, var(--intv-accent) 10%, var(--intv-surface));
  border-color: color-mix(in srgb, var(--intv-accent) 48%, transparent);
  box-shadow: 0 10px 24px -20px var(--intv-accent);
}
body.intv-app .intv-start-choice-check {
  border-color: var(--intv-line);
  background: var(--intv-surface-2);
}
body.intv-app .intv-start-choice.selected .intv-start-choice-check {
  border-color: var(--intv-accent);
}
body.intv-app .intv-start-choice-icon {
  color: var(--intv-accent);
  background: var(--intv-accent-soft);
}
body.intv-app .intv-start-choice-desc { color: var(--intv-muted); }

/* Persona selector cards */
body.intv-app .intv-psel-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px; }
body.intv-app .intv-psel-card {
  background: var(--intv-surface) !important; border: 1px solid var(--intv-line) !important; border-radius: 16px !important;
  transition: transform .18s, border-color .18s;
}
body.intv-app .intv-psel-card:hover { transform: translateY(-3px); border-color: color-mix(in srgb, var(--intv-accent) 40%, transparent) !important; }
body.intv-app .intv-psel-card.selected, body.intv-app .intv-psel-card[aria-pressed="true"], body.intv-app .intv-psel-card.is-primary {
  border-color: transparent !important;
  box-shadow: 0 0 0 1.5px var(--intv-accent), var(--intv-glow) !important;
}
body.intv-app .intv-psel-role { color: var(--intv-accent) !important; font-weight: 600; }

/* ============================================================================
 * Live interview (respondent view) — voice call bar + listen stage.
 * ============================================================================ */
body.intv-app .intv-call-stage { box-sizing: border-box; border: 1px solid var(--intv-line); border-radius: 18px; background: var(--intv-surface); padding: 16px; }
body.intv-app .ivc-bar {
  background: radial-gradient(60% 130% at 16% -10%, var(--intv-accent-soft), transparent 60%), var(--intv-surface-2);
  border: 1px solid var(--intv-line); border-radius: 18px; padding: 14px 16px; gap: 14px;
}
body.intv-app .ivc-avatar {
  width: 48px; height: 48px; border-radius: 50%; background: var(--intv-grad); color: #fff;
  display: grid; place-items: center; font-family: 'Sora','Inter',sans-serif; font-weight: 700;
  box-shadow: var(--intv-glow); position: relative; flex: none;
}
body.intv-app .ivc-avatar::after {
  content: ""; position: absolute; inset: -7px; border-radius: 50%;
  border: 1px solid color-mix(in srgb, var(--intv-accent) 45%, transparent);
  animation: intv-callpulse 2.4s ease-out infinite;
}
body.intv-app .ivc-name { font-family: 'Sora','Inter',sans-serif; font-weight: 600; color: var(--intv-text); }
body.intv-app .ivc-status { color: var(--intv-muted); }
body.intv-app .ivc-state-dot { background: var(--intv-success); box-shadow: 0 0 10px var(--intv-success); }
body.intv-app .ivc-timer { color: var(--intv-muted); font-variant-numeric: tabular-nums; }
body.intv-app .ivc-btn {
  width: 46px; height: 46px; border-radius: 50%; display: grid; place-items: center;
  background: var(--intv-surface); border: 1px solid var(--intv-line); color: var(--intv-text); cursor: pointer; transition: .15s;
}
body.intv-app .ivc-btn:hover { border-color: var(--intv-accent); }
body.intv-app .ivc-mute { background: var(--intv-grad); border: none; color: #fff; box-shadow: var(--intv-glow); }
body.intv-app .ivc-mute.ivc-muted { background: var(--intv-surface); color: var(--intv-muted); box-shadow: none; }
body.intv-app .ivc-end {
  background: color-mix(in srgb, var(--intv-danger) 16%, transparent);
  border-color: color-mix(in srgb, var(--intv-danger) 40%, transparent); color: var(--intv-danger);
}
body.intv-app .ivc-caption {
  margin-top: 12px; background: var(--intv-surface-2); border: 1px solid var(--intv-line);
  border-radius: 16px; padding: 14px 18px; font-size: 15px; color: var(--intv-text);
}
body.intv-app .ivc-caption-who { color: var(--intv-accent); font-size: 11px; text-transform: uppercase; letter-spacing: .08em; display: block; margin-bottom: 4px; }
@keyframes intv-callpulse { 0% { transform: scale(.9); opacity: .8 } 100% { transform: scale(1.35); opacity: 0 } }

/* ============================================================================
 * Interview Sets list — stop persona marquee + polish sets table.
 * ============================================================================ */
body.intv-app .intv-persona-mini-row.is-animated { animation: none !important; transform: none !important; }
body.intv-app .intv-persona-mini-card[aria-hidden="true"] { display: none !important; }
body.intv-app .intv-persona-mini-viewport { overflow-x: auto; -webkit-overflow-scrolling: touch; }
body.intv-app .intv-persona-mini-row { gap: 14px; }

body.intv-app .intv-sets-table thead th {
  text-transform: uppercase; letter-spacing: .06em; font-size: 12px;
  color: var(--intv-faint) !important; font-weight: 600; border-bottom: 1px solid var(--intv-line);
}
body.intv-app .intv-sets-table td { border-bottom: 1px solid var(--intv-line-soft); }
body.intv-app .intv-sets-table tbody tr:hover td { background: var(--intv-surface-2); }
body.intv-app .intv-set-title { font-weight: 600; }
body.intv-app .intv-set-sub { color: var(--intv-faint); }
body.intv-app .intv-set-thumb { border-radius: 10px; }
body.intv-app .intv-sets-card { border-radius: var(--border-radius-lg, 18px); }

/* Personas row: full-opacity wrap (no marquee fade-mask / scrollbar) */
body.intv-app .intv-persona-mini-viewport { overflow: visible !important; -webkit-mask-image: none !important; mask-image: none !important; }
body.intv-app .intv-persona-mini-row { flex-wrap: wrap !important; }
body.intv-app .intv-persona-mini-card { opacity: 1 !important; }

/* ============================================================================
 * Live interview — orb STAGE structure (voice call restructured to a stage).
 * ============================================================================ */
body.intv-app .ivc-stage {
  --ivc-wave-color: #ffffff;
  box-sizing: border-box;
  position: relative;
  width: 100%;
  max-width: 100%;
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  padding: 30px 20px 26px; text-align: center;
  background: radial-gradient(60% 55% at 50% 30%, var(--intv-accent-soft), transparent 70%), var(--intv-surface);
  border: 1px solid var(--intv-line); border-radius: 20px;
}
body.intv-app .ivc-orb {
  width: 140px; height: 140px; border-radius: 50%; background: var(--intv-grad);
  box-shadow: var(--intv-glow); display: grid; place-items: center; position: relative;
  pointer-events: none;
}
body.intv-app .ivc-orb::before {
  content: ""; position: absolute; inset: -12px; border-radius: 50%;
  border: 1px solid color-mix(in srgb, var(--intv-accent) 40%, transparent);
  animation: intv-callpulse 2.4s ease-out infinite;
  pointer-events: none;
}
body.intv-app .ivc-orb .ivc-wave { display: block; width: 96px; height: 36px; }
body.intv-app .ivc-stage .ivc-name { font-family: 'Sora','Inter',sans-serif; font-size: 17px; font-weight: 600; color: var(--intv-text); margin: 0; }
body.intv-app .ivc-stage .ivc-status { display: inline-flex; align-items: center; gap: 8px; color: var(--intv-muted); font-size: 13px; }
body.intv-app .ivc-stage .ivc-timer { color: var(--intv-faint); font-variant-numeric: tabular-nums; font-size: 13px; }
body.intv-app .ivc-controls {
  display: flex; gap: 12px; margin-top: 6px;
  position: relative; z-index: 80; pointer-events: auto;
}
body.intv-app .ivc-controls .ivc-btn {
  position: relative; z-index: 81; pointer-events: auto; touch-action: manipulation;
}
body.intv-app .ivc-stage ~ .ivc-caption { margin-top: 14px; max-width: 540px; margin-left: auto; margin-right: auto; }

body.is-public-token.intv-app .ivc-stage {
  gap: 8px;
  padding: 18px 16px 16px;
  border-radius: 16px;
}
body.is-public-token.intv-app .ivc-orb {
  width: 96px;
  height: 96px;
}
body.is-public-token.intv-app .ivc-orb::before {
  inset: -8px;
}
body.is-public-token.intv-app .ivc-orb .ivc-wave {
  width: 76px;
  height: 30px;
}
body.is-public-token.intv-app .ivc-stage .ivc-name {
  font-size: 15px;
}
body.is-public-token.intv-app .ivc-stage .ivc-status,
body.is-public-token.intv-app .ivc-stage .ivc-timer {
  font-size: 12px;
}
body.is-public-token.intv-app .ivc-controls {
  gap: 8px;
  margin-top: 2px;
}
body.is-public-token.intv-app .ivc-controls .ivc-btn {
  width: 40px;
  height: 40px;
}
body.is-public-token.intv-app .ivc-controls .ivc-btn svg {
  width: 18px;
  height: 18px;
}

body.intv-app .intv-presentation-run-card .ivc-stage {
  gap: 8px;
  padding: 18px 16px 16px;
  border-radius: 16px;
}
body.intv-app .intv-presentation-run-card .ivc-orb {
  width: 96px;
  height: 96px;
}
body.intv-app .intv-presentation-run-card .ivc-orb::before {
  inset: -8px;
}
body.intv-app .intv-presentation-run-card .ivc-orb .ivc-wave {
  width: 76px;
  height: 30px;
}
body.intv-app .intv-presentation-run-card .ivc-stage .ivc-name {
  font-size: 15px;
}
body.intv-app .intv-presentation-run-card .ivc-stage .ivc-status,
body.intv-app .intv-presentation-run-card .ivc-stage .ivc-timer {
  font-size: 12px;
}
body.intv-app .intv-presentation-run-card .ivc-controls {
  gap: 8px;
  margin-top: 2px;
}
body.intv-app .intv-presentation-run-card .ivc-controls .ivc-btn {
  width: 44px;
  height: 44px;
}
body.intv-app .intv-presentation-run-card .ivc-speaking-tip {
  max-width: min(560px, 100%);
  margin-top: 6px;
  font-size: 12px;
}

@media (max-width: 760px) {
  body.intv-app .intv-presentation-run-card .intv-live-session-shell-presentation {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  body.intv-app .intv-presentation-run-card .intv-live-side {
    display: none;
  }
  body.intv-app .intv-presentation-run-card .intv-call-stage {
    margin-bottom: 10px;
    padding: 12px;
  }
  body.intv-app .intv-presentation-run-card .ivc-stage {
    padding: 14px 12px 12px;
  }
  body.is-public-token.intv-app .ivc-stage {
    padding: 14px 12px 12px;
  }
  body.intv-app .intv-presentation-run-card .ivc-orb {
    width: 76px;
    height: 76px;
  }
  body.is-public-token.intv-app .ivc-orb {
    width: 76px;
    height: 76px;
  }
  body.intv-app .intv-presentation-run-card .ivc-orb .ivc-wave {
    width: 58px;
    height: 26px;
  }
  body.is-public-token.intv-app .ivc-orb .ivc-wave {
    width: 58px;
    height: 26px;
  }
  body.intv-app .intv-presentation-run-card .ivc-speaking-tip {
    display: none;
  }
  body.is-public-token.intv-app .ivc-controls {
    gap: 6px;
  }
  body.is-public-token.intv-app .ivc-controls .ivc-btn {
    width: 38px;
    height: 38px;
  }
}

/* ============================================================================
 * Builder — Questions step split layout (questions + interviewer/settings rail).
 * ============================================================================ */
body.intv-app .intv-builder-split { display: grid; grid-template-columns: minmax(0,1fr) 300px; gap: 18px; align-items: start; }
body.intv-app .intv-builder-rail { display: flex; flex-direction: column; gap: 14px; position: sticky; top: 80px; }
body.intv-app .intv-rail-card { padding: 16px; }
body.intv-app .intv-rail-title { font-size: 12px; text-transform: uppercase; letter-spacing: .08em; color: var(--intv-faint); font-weight: 600; margin-bottom: 12px; }
body.intv-app .intv-rail-row { display: flex; justify-content: space-between; align-items: center; gap: 10px; padding: 6px 0; font-size: 13px; color: var(--intv-muted); }
body.intv-app .intv-rail-row b { color: var(--intv-text); font-weight: 600; max-width: 60%; text-align: right; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
body.intv-app .intv-rail-note { display: flex; gap: 10px; font-size: 13px; color: var(--intv-muted); line-height: 1.5; }
body.intv-app .intv-rail-orb { width: 22px; height: 22px; border-radius: 50%; background: var(--intv-grad); flex: none; box-shadow: var(--intv-glow); }
body.intv-app .intv-rail-tips { margin: 0; padding-left: 18px; font-size: 13px; color: var(--intv-muted); display: flex; flex-direction: column; gap: 6px; }
body.intv-app .intv-builder-ai-draft {
  background: var(--intv-surface) !important;
  border-color: var(--intv-line) !important;
  overflow: hidden;
}
body.intv-app .intv-builder-ai-draft > summary {
  color: var(--intv-text) !important;
  font-size: 15px;
  padding: 14px 18px;
}
body.intv-app .intv-builder-ai-draft .intv-advanced-body {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 0 20px 20px;
}
body.intv-app .intv-builder-ai-draft-sub {
  margin: 0 !important;
  color: var(--intv-muted) !important;
  font-size: 14px;
  line-height: 1.5;
}
body.intv-app .intv-builder-ai-draft-goal {
  box-sizing: border-box;
  width: 100%;
  min-height: 112px;
  padding: 12px 14px;
  resize: vertical;
  border: 1px solid var(--intv-line);
  border-radius: 12px;
  background: var(--intv-surface-2);
  color: var(--intv-text);
  font: inherit;
  font-size: 14px;
  line-height: 1.5;
}
body.intv-app .intv-builder-ai-draft-goal:focus {
  outline: none;
  border-color: var(--intv-accent);
  box-shadow: 0 0 0 3px var(--intv-accent-soft);
}
body.intv-app .intv-builder-ai-draft-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) max-content;
  gap: 10px;
  margin-top: 0;
}
body.intv-app .intv-builder-ai-draft-row .intv-input {
  min-width: 0;
  min-height: 48px;
}
body.intv-app .intv-builder-ai-draft-row .intv-btn {
  min-height: 48px;
  white-space: nowrap;
}
@media (max-width: 1100px) {
  body.intv-app .intv-builder-split { grid-template-columns: 1fr; }
  body.intv-app .intv-builder-rail { position: static; flex-direction: row; flex-wrap: wrap; }
  body.intv-app .intv-builder-rail .intv-rail-card { flex: 1 1 220px; }
}
@media (max-width: 700px) {
  body.intv-app .intv-builder-ai-draft-row { grid-template-columns: 1fr; }
  body.intv-app .intv-builder-ai-draft-row .intv-btn { width: 100%; }
}

/* ---- Fix: sidebar border-box width vs content offset (no overlap) ---- */
@media (min-width: 1024px) {
  body.intv-app .intv-sidebar { box-sizing: border-box !important; width: 252px !important; }
  body.intv-app .intv-container { margin-left: 268px !important; }
}
/* Builder rail form fields */
body.intv-app .intv-rail-label { display: block; font-size: 12px; color: var(--intv-muted); margin: 0 0 6px; }
body.intv-app .intv-rail-card textarea { width: 100%; font-size: 13px; }
body.intv-app .intv-rail-card .intv-field-hint { font-size: 11px; color: var(--intv-faint); margin-top: 4px; }

body.intv-app .intv-email-feedback-card {
  margin: 16px 0;
  padding: 16px;
  border: 1px solid var(--intv-line);
  border-radius: 14px;
  background: var(--intv-surface-2);
}
body.intv-app .intv-email-feedback-card textarea {
  width: 100%;
  box-sizing: border-box;
  margin-top: 12px;
}

/* ============================================================================
 * Interview Sets — sets list is the focus; personas become a compact strip below.
 * ============================================================================ */
body.intv-app .intv-persona-carousel-shell { margin-top: 26px; padding-top: 20px; border-top: 1px solid var(--intv-line); }
body.intv-app .intv-persona-carousel-head { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin-bottom: 14px; }
body.intv-app .intv-persona-carousel-head h2 { font-size: 12px !important; text-transform: uppercase; letter-spacing: .08em; color: var(--intv-faint) !important; font-weight: 600; margin: 0; }
body.intv-app .intv-persona-carousel-head p { display: none; }
body.intv-app .intv-persona-mini-viewport { overflow: visible !important; -webkit-mask-image: none !important; mask-image: none !important; }
body.intv-app .intv-persona-mini-row { flex-wrap: wrap !important; gap: 8px !important; animation: none !important; transform: none !important; }
body.intv-app .intv-persona-mini-card {
  flex-direction: row !important; align-items: center !important;
  width: auto !important; min-width: 0 !important; max-width: none !important;
  padding: 7px 15px 7px 7px !important; gap: 10px !important;
  border-radius: 999px !important; opacity: 1 !important;
  background: var(--intv-surface) !important; border: 1px solid var(--intv-line) !important;
}
body.intv-app .intv-persona-mini-card:hover { transform: none !important; border-color: color-mix(in srgb, var(--intv-accent) 40%, transparent) !important; }
body.intv-app .intv-persona-mini-card .intv-persona-mini-role,
body.intv-app .intv-persona-mini-card .intv-persona-mini-desc { display: none !important; }
body.intv-app .intv-persona-mini-card[aria-hidden="true"] { display: none !important; }
body.intv-app .intv-persona-mini-avatar { width: 28px !important; height: 28px !important; flex: none; }
body.intv-app .intv-persona-mini-name { font-size: 13px !important; margin: 0 !important; }

/* Force persona strip chips to be compact pills (override base mini-card sizing) */
body.intv-app .intv-persona-mini-row { display: flex !important; flex-wrap: wrap !important; justify-content: flex-start !important; gap: 8px !important; }
body.intv-app .intv-persona-mini-card {
  display: inline-flex !important; flex-direction: row !important; align-items: center !important;
  width: auto !important; height: auto !important; min-height: 0 !important; min-width: 0 !important; max-width: none !important;
  flex: 0 0 auto !important; aspect-ratio: auto !important;
  padding: 6px 16px 6px 6px !important; gap: 10px !important; border-radius: 999px !important;
}
body.intv-app .intv-persona-mini-card > * { margin: 0 !important; }
body.intv-app .intv-persona-mini-name { align-self: center !important; }

/* ---- Drawer/header repair: keep the app header left-aligned and the sidebar off-canvas until opened. ---- */
body.intv-app .intv-topnav-inner {
  max-width: none !important;
  margin: 0 !important;
}

body.is-signed-in.intv-app .intv-nav-burger {
  display: inline-flex !important;
}

body.intv-app .intv-sidebar {
  position: fixed !important;
  inset: 0 auto 0 0 !important;
  top: 0 !important;
  width: min(320px, calc(100vw - 34px)) !important;
  height: 100dvh !important;
  z-index: 90 !important;
  transform: translateX(-105%) !important;
  transition: transform .26s ease, box-shadow .26s ease !important;
  border-right: 1px solid var(--intv-line) !important;
  border-radius: 0 14px 14px 0 !important;
  box-shadow: none !important;
  padding: 18px 14px !important;
}

body.is-signed-in.intv-sidebar-open .intv-sidebar {
  transform: translateX(0) !important;
  box-shadow: 24px 0 70px rgba(15, 23, 42, .22) !important;
}

body.intv-app .intv-sidebar-backdrop {
  display: block !important;
}

body.intv-app:not(.intv-sidebar-open) .intv-sidebar-backdrop,
body.intv-app .intv-sidebar-backdrop[hidden] {
  display: none !important;
}

body.intv-app .intv-app-body .intv-container {
  margin-left: auto !important;
  margin-right: auto !important;
}
