/* ==========================================================================
   Fractal Speaker DB — Studio Edition
   Award-winning visual pass. Same data, same markup hooks, brand-new skin.
   ========================================================================== */

:root {
  /* Type */
  --font-sans: "Inter", "Segoe UI", system-ui, -apple-system, "Helvetica Neue", Arial, sans-serif;
  --font-display: "Space Grotesk", "Inter", "Segoe UI", system-ui, sans-serif;
  --font-mono: "Cascadia Code", "JetBrains Mono", "Consolas", "SFMono-Regular", Menlo, monospace;

  --fs-xs: 11px;
  --fs-sm: 12.5px;
  --fs-base: 14px;
  --fs-md: 15px;
  --fs-lg: 17px;
  --fs-xl: 22px;
  --fs-2xl: 28px;
  --fs-3xl: 36px;

  /* Spacing */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-7: 28px;
  --space-8: 32px;
  --space-10: 40px;

  /* Shape */
  --radius-sm: 9px;
  --radius: 14px;
  --radius-lg: 18px;
  --radius-xl: 24px;
  --radius-full: 999px;

  /* Layout */
  --sidebar-width: 286px;
  --topbar-height: 70px;

  /* Motion */
  --ease: cubic-bezier(0.34, 1.56, 0.64, 1);
  --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
  --t-fast: 120ms var(--ease-out);
  --t: 220ms var(--ease-out);
  --t-slow: 360ms var(--ease-out);
}

/* ---------------------------------------------------------------------
   Theme: Light "Aurora" — warm pearlescent canvas with violet/teal life
   --------------------------------------------------------------------- */
:root,
[data-theme="light"] {
  color-scheme: light;

  --bg-canvas: #f6f5ff;
  --bg-canvas-2: #eef0ff;
  --bg-surface: #ffffff;
  --bg-surface-alt: #f7f7fd;
  --bg-surface-hover: #f1f1fb;
  --bg-elevated: #ffffff;
  --bg-overlay: rgba(28, 23, 64, 0.34);

  --border-subtle: #ededf7;
  --border: #e4e5f1;
  --border-strong: #d2d4e6;

  --text-primary: #14132b;
  --text-secondary: #565a7e;
  --text-muted: #989bb6;
  --text-inverse: #ffffff;

  --accent: #6d5dfd;
  --accent-hover: #5b48f8;
  --accent-active: #4f38ec;
  --accent-soft: #eeeaff;
  --accent-soft-strong: #ddd6ff;
  --accent-contrast: #ffffff;

  --accent-2: #0bb39c;
  --accent-2-soft: #d8f5ef;
  --accent-2-hover: #099683;

  --clr-slate: #8a8da6;
  --clr-slate-soft: #eef0f6;
  --clr-slate-text: #5c5f75;

  --clr-red: #e8264e;
  --clr-red-soft: #fde6ec;
  --clr-red-text: #c0163a;

  --clr-orange: #f0791a;
  --clr-orange-soft: #fef0e0;
  --clr-orange-text: #b1560d;

  --clr-gold: #c9911a;
  --clr-gold-soft: #fbf2d6;
  --clr-gold-text: #8a6110;

  --clr-blue: #316bf0;
  --clr-blue-soft: #e6effe;
  --clr-blue-text: #1c4dba;

  --clr-teal: #0ba87f;
  --clr-teal-soft: #ddf6ee;
  --clr-teal-text: #088463;

  --clr-purple: #9333ea;
  --clr-purple-soft: #f4e9ff;
  --clr-purple-text: #7213c4;

  --shadow-sm: 0 1px 2px rgba(40, 30, 90, 0.06);
  --shadow: 0 6px 18px rgba(56, 40, 120, 0.08), 0 1px 3px rgba(40, 30, 90, 0.05);
  --shadow-lg: 0 22px 48px rgba(56, 40, 120, 0.16), 0 6px 14px rgba(56, 40, 120, 0.07);
  --shadow-xl: 0 34px 70px rgba(40, 30, 90, 0.26);

  --scrollbar-thumb: #d4d5ea;
  --scrollbar-thumb-hover: #b7badb;

  --glow-accent: 0 0 0 4px rgba(109, 93, 253, 0.14);
  --gradient-brand: linear-gradient(135deg, #6d5dfd 0%, #9333ea 48%, #0bb39c 100%);
  --gradient-canvas:
    radial-gradient(1200px 600px at 12% -8%, rgba(109, 93, 253, 0.16), transparent 60%),
    radial-gradient(900px 500px at 100% 0%, rgba(11, 179, 156, 0.14), transparent 55%),
    radial-gradient(700px 500px at 80% 100%, rgba(147, 51, 234, 0.10), transparent 60%);
}

/* ---------------------------------------------------------------------
   Theme: Dark "Nebula" — deep indigo night with luminous accents
   --------------------------------------------------------------------- */
[data-theme="dark"] {
  color-scheme: dark;

  --bg-canvas: #0b0c18;
  --bg-canvas-2: #0f1120;
  --bg-surface: #15182a;
  --bg-surface-alt: #1a1e34;
  --bg-surface-hover: #212644;
  --bg-elevated: #1c2138;
  --bg-overlay: rgba(3, 4, 12, 0.62);

  --border-subtle: #232842;
  --border: #2b3150;
  --border-strong: #3d456e;

  --text-primary: #f1f1ff;
  --text-secondary: #a7abd0;
  --text-muted: #6f749b;

  --accent: #8b7bff;
  --accent-hover: #9d8fff;
  --accent-active: #7a69f5;
  --accent-soft: #221d4a;
  --accent-soft-strong: #2e2760;
  --accent-contrast: #ffffff;

  --accent-2: #2dd4bf;
  --accent-2-soft: #10322e;
  --accent-2-hover: #45e0cc;

  --clr-slate: #8b8fa8;
  --clr-slate-soft: #1c2032;
  --clr-slate-text: #a6aac4;

  --clr-red: #ff5577;
  --clr-red-soft: #3a1622;
  --clr-red-text: #ff9bab;

  --clr-orange: #ffa14a;
  --clr-orange-soft: #3a2510;
  --clr-orange-text: #ffc089;

  --clr-gold: #f0c94a;
  --clr-gold-soft: #34290c;
  --clr-gold-text: #f6dc88;

  --clr-blue: #6b9bf8;
  --clr-blue-soft: #14233f;
  --clr-blue-text: #a4c2fb;

  --clr-teal: #2dd4a8;
  --clr-teal-soft: #0e2e27;
  --clr-teal-text: #7be8c8;

  --clr-purple: #c084fc;
  --clr-purple-soft: #2a1b3d;
  --clr-purple-text: #ddb6ff;

  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.4);
  --shadow: 0 8px 22px rgba(0, 0, 0, 0.5);
  --shadow-lg: 0 24px 50px rgba(0, 0, 0, 0.6);
  --shadow-xl: 0 36px 76px rgba(0, 0, 0, 0.72);

  --scrollbar-thumb: #363c5c;
  --scrollbar-thumb-hover: #4a5278;

  --glow-accent: 0 0 0 4px rgba(139, 123, 255, 0.20);
  --gradient-brand: linear-gradient(135deg, #8b7bff 0%, #c084fc 48%, #2dd4bf 100%);
  --gradient-canvas:
    radial-gradient(1200px 600px at 12% -8%, rgba(139, 123, 255, 0.22), transparent 60%),
    radial-gradient(900px 500px at 100% 0%, rgba(45, 212, 191, 0.16), transparent 55%),
    radial-gradient(700px 500px at 80% 100%, rgba(192, 132, 252, 0.14), transparent 60%);
}

/* Semantic aliases (mapped once, themeable) */
:root {
  --success: var(--clr-teal);
  --success-soft: var(--clr-teal-soft);
  --success-text: var(--clr-teal-text);
  --warning: var(--clr-orange);
  --warning-soft: var(--clr-orange-soft);
  --warning-text: var(--clr-orange-text);
  --danger: var(--clr-red);
  --danger-soft: var(--clr-red-soft);
  --danger-text: var(--clr-red-text);
  --info: var(--clr-blue);
  --info-soft: var(--clr-blue-soft);
  --info-text: var(--clr-blue-text);

  --priority-high: var(--clr-red);
  --priority-medium: var(--clr-teal);
  --priority-low: var(--clr-blue);
}

/* ---------------------------------------------------------------------
   Reset & base
   --------------------------------------------------------------------- */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
  height: 100%;
}

body {
  font-family: var(--font-sans);
  font-size: var(--fs-base);
  line-height: 1.55;
  color: var(--text-primary);
  background: var(--bg-canvas);
  background-image: var(--gradient-canvas);
  background-attachment: fixed;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  font-feature-settings: "cv11", "ss01";
  transition: background-color var(--t), color var(--t);
}

h1, h2, h3, h4, h5, h6 {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 600;
  letter-spacing: -0.015em;
}

p { margin: 0; }

button, input, select, textarea {
  font-family: inherit;
  font-size: inherit;
  color: inherit;
}

button { cursor: pointer; }

a { color: var(--accent); text-decoration: none; }

code {
  font-family: var(--font-mono);
  background: var(--bg-surface-alt);
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
  padding: 1px 6px;
  font-size: 0.9em;
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Scrollbars */
* {
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) transparent;
}
*::-webkit-scrollbar { width: 10px; height: 10px; }
*::-webkit-scrollbar-track { background: transparent; }
*::-webkit-scrollbar-thumb {
  background: var(--scrollbar-thumb);
  border-radius: var(--radius-full);
  border: 2.5px solid transparent;
  background-clip: padding-box;
}
*::-webkit-scrollbar-thumb:hover {
  background: var(--scrollbar-thumb-hover);
  background-clip: padding-box;
}

::selection {
  background: var(--accent-soft-strong);
  color: var(--text-primary);
}

/* ---------------------------------------------------------------------
   App shell / layout
   --------------------------------------------------------------------- */
.app-shell {
  display: flex;
  min-height: 100vh;
}

.sidebar-scrim {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 40;
  background: var(--bg-overlay);
  border: none;
  padding: 0;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.sidebar {
  width: var(--sidebar-width);
  min-width: var(--sidebar-width);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.04), transparent 40%),
    var(--bg-surface);
  border-right: 1px solid var(--border-subtle);
  display: flex;
  flex-direction: column;
  position: sticky;
  top: 0;
  height: 100vh;
  z-index: 41;
  transition: background-color var(--t), border-color var(--t), transform var(--t-slow);
}

.sidebar-brand {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-6) var(--space-5) var(--space-5);
}

.brand-mark {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  flex: none;
  border-radius: var(--radius);
  background: var(--gradient-brand);
  background-size: 160% 160%;
  color: #fff;
  box-shadow: 0 10px 24px rgba(109, 93, 253, 0.38);
  animation: brandShift 9s ease-in-out infinite;
}

@keyframes brandShift {
  0%, 100% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
}

.brand-text {
  display: flex;
  flex-direction: column;
  min-width: 0;
  flex: 1;
}

.brand-title {
  font-family: var(--font-display);
  font-size: 16.5px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--text-primary);
  line-height: 1.15;
  white-space: nowrap;
}

.brand-subtitle {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-top: 3px;
}

.sidebar-close {
  display: none !important;
}

.search-wrap {
  position: relative;
  margin: 0;
}

.search-icon {
  position: absolute;
  left: 13px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-muted);
  pointer-events: none;
  transition: color var(--t);
}

.search-input {
  width: 100%;
  padding: 11px 36px 11px 38px;
  font-size: var(--fs-sm);
  color: var(--text-primary);
  background: var(--bg-surface-alt);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-full);
  outline: none;
  transition: border-color var(--t), box-shadow var(--t), background-color var(--t);
}

.search-input:focus {
  border-color: var(--accent);
  background: var(--bg-surface);
  box-shadow: var(--glow-accent);
}

.search-input:focus + .search-clear,
.search-input:focus ~ .search-icon {
  color: var(--accent);
}

.search-input::placeholder { color: var(--text-muted); }
.search-input::-webkit-search-cancel-button { -webkit-appearance: none; appearance: none; }

.search-clear {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: none;
  border-radius: var(--radius-full);
  background: transparent;
  color: var(--text-muted);
  transition: background-color var(--t), color var(--t);
}

.search-clear:hover {
  background: var(--bg-surface-hover);
  color: var(--text-primary);
}

.sidebar-nav {
  flex: 1;
  overflow-y: auto;
  padding: var(--space-2) var(--space-3) var(--space-4);
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.nav-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  width: 100%;
  padding: 10px 12px;
  border: none;
  background: transparent;
  border-radius: var(--radius);
  color: var(--text-secondary);
  font-size: var(--fs-sm);
  font-weight: 500;
  text-align: left;
  position: relative;
  transition: color var(--t), background-color var(--t), transform var(--t-fast);
}

.nav-item .icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  color: var(--text-muted);
  flex: none;
  transition: color var(--t), transform var(--t);
}

.nav-item:hover {
  color: var(--text-primary);
  background: var(--bg-surface-hover);
}

.nav-item:hover .icon {
  color: var(--accent);
  transform: scale(1.08);
}

.nav-item.active {
  color: var(--accent);
  background: var(--accent-soft);
  font-weight: 600;
}

.nav-item.active .icon { color: var(--accent); }

.nav-item.active::before {
  content: "";
  position: absolute;
  left: -2px;
  top: 50%;
  transform: translateY(-50%);
  width: 4px;
  height: 22px;
  border-radius: var(--radius-full);
  background: var(--gradient-brand);
  box-shadow: 0 0 12px rgba(109, 93, 253, 0.5);
}

.nav-item-label {
  flex: 1;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.nav-item-count {
  font-size: 11px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: var(--radius-full);
  background: var(--bg-surface-alt);
  color: var(--text-muted);
  min-width: 24px;
  text-align: center;
  transition: background-color var(--t), color var(--t);
}

.nav-item.active .nav-item-count {
  background: var(--accent);
  color: var(--accent-contrast);
}

.sidebar-footer {
  padding: var(--space-4) var(--space-5);
  border-top: 1px solid var(--border-subtle);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.main {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
}

.topbar {
  position: sticky;
  top: 0;
  z-index: 30;
  height: var(--topbar-height);
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: var(--space-4);
  padding: 0 var(--space-6);
  background: rgba(255, 255, 255, 0.72);
  backdrop-filter: saturate(180%) blur(16px);
  -webkit-backdrop-filter: saturate(180%) blur(16px);
  border-bottom: 1px solid var(--border-subtle);
  transition: background-color var(--t), border-color var(--t);
}

[data-theme="dark"] .topbar {
  background: rgba(15, 17, 32, 0.66);
}

.topbar-search-wrap {
  justify-self: center;
  width: min(540px, 100%);
  min-width: 0;
}

.topbar-content {
  justify-self: end;
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-3);
  flex-wrap: nowrap;
}

.toolbar-more-wrap .filter-more-panel {
  left: auto;
  right: 0;
}

.toolbar-more-btn.open {
  color: var(--accent);
  border-color: var(--accent-soft-strong);
  background: var(--accent-soft);
}

.active-filter-pill {
  font-size: var(--fs-xs);
  font-weight: 700;
  padding: 4px 10px;
  border-radius: var(--radius-full);
  background: var(--accent-soft);
  color: var(--accent);
  border: 1px solid var(--accent-soft-strong);
}

.main-content {
  flex: 1;
  padding: var(--space-7) var(--space-8) var(--space-10);
  max-width: 1320px;
  width: 100%;
  margin: 0 auto;
  animation: fadeUp 360ms var(--ease-out) both;
}

@keyframes fadeUp {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ---------------------------------------------------------------------
   Buttons
   --------------------------------------------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 9px 15px;
  font-size: var(--fs-sm);
  font-weight: 600;
  border-radius: var(--radius);
  border: 1px solid transparent;
  background: var(--bg-surface-alt);
  color: var(--text-primary);
  white-space: nowrap;
  transition: transform var(--t-fast), background-color var(--t), border-color var(--t), box-shadow var(--t), color var(--t);
}
.btn .icon { color: inherit; }
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }

.btn-primary {
  background: var(--accent);
  color: var(--accent-contrast);
  box-shadow: 0 8px 18px rgba(109, 93, 253, 0.32);
}
.btn-primary:hover {
  background: var(--accent-hover);
  box-shadow: 0 12px 26px rgba(109, 93, 253, 0.42);
}

.btn-secondary {
  background: var(--bg-surface);
  border-color: var(--border);
  color: var(--text-primary);
  box-shadow: var(--shadow-sm);
}
.btn-secondary:hover {
  border-color: var(--border-strong);
  background: var(--bg-surface-hover);
}

.btn-ghost {
  background: transparent;
  color: var(--text-secondary);
}
.btn-ghost:hover {
  background: var(--bg-surface-hover);
  color: var(--text-primary);
}

.btn-danger {
  background: var(--danger);
  color: #fff;
  box-shadow: 0 8px 18px rgba(232, 38, 78, 0.28);
}
.btn-danger:hover {
  background: var(--clr-red-text);
  box-shadow: 0 12px 26px rgba(232, 38, 78, 0.38);
}

.btn-sm {
  padding: 6px 11px;
  font-size: var(--fs-xs);
  border-radius: var(--radius-sm);
  gap: 5px;
}

.btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none !important;
  box-shadow: none !important;
}

.icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: var(--radius);
  border: 1px solid var(--border-subtle);
  background: var(--bg-surface);
  color: var(--text-secondary);
  transition: transform var(--t-fast), background-color var(--t), color var(--t), border-color var(--t);
}
.icon-btn:hover {
  background: var(--bg-surface-hover);
  color: var(--text-primary);
  border-color: var(--border);
  transform: translateY(-1px);
}
.icon-btn.icon-btn-active {
  background: var(--accent-soft);
  color: var(--accent);
  border-color: var(--accent-soft-strong);
}

.icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: none;
  line-height: 0;
}
.icon svg { display: block; }

/* Theme toggle */
.theme-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 4px;
  border-radius: var(--radius-full);
  background: var(--bg-surface-alt);
  border: 1px solid var(--border-subtle);
  cursor: pointer;
}

.theme-toggle-track {
  position: relative;
  width: 46px;
  height: 24px;
  border-radius: var(--radius-full);
  background: var(--bg-surface-hover);
  transition: background-color var(--t);
}

.theme-toggle-thumb {
  position: absolute;
  top: 3px;
  left: 3px;
  width: 18px;
  height: 18px;
  border-radius: var(--radius-full);
  background: var(--gradient-brand);
  box-shadow: 0 2px 6px rgba(109, 93, 253, 0.4);
  transition: transform var(--t), background var(--t);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
}

[data-theme="dark"] .theme-toggle-thumb { transform: translateX(22px); }

.theme-toggle-label {
  font-size: var(--fs-xs);
  font-weight: 600;
  color: var(--text-secondary);
  padding-right: 6px;
}

.footer-status-row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.offline-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--fs-xs);
  font-weight: 600;
  padding: 4px 10px;
  border-radius: var(--radius-full);
  background: var(--warning-soft);
  color: var(--warning-text);
}

.offline-badge::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: var(--radius-full);
  background: var(--warning);
  box-shadow: 0 0 0 0 rgba(240, 121, 26, 0.6);
  animation: pulse 1.8s ease-out infinite;
}

@keyframes pulse {
  0% { box-shadow: 0 0 0 0 rgba(240, 121, 26, 0.55); }
  70% { box-shadow: 0 0 0 7px rgba(240, 121, 26, 0); }
  100% { box-shadow: 0 0 0 0 rgba(240, 121, 26, 0); }
}

.data-status {
  font-size: var(--fs-xs);
  color: var(--text-muted);
  font-weight: 500;
}

.options-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  width: 100%;
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--text-secondary);
  padding: 9px 12px;
  border-radius: var(--radius);
  border: 1px solid var(--border-subtle);
  background: var(--bg-surface);
  transition: color var(--t), border-color var(--t), background-color var(--t), transform var(--t-fast);
}
.options-link:hover,
.options-link.active {
  color: var(--accent);
  border-color: var(--accent-soft-strong);
  background: var(--accent-soft);
  transform: translateY(-1px);
}

/* ---------------------------------------------------------------------
   Loading
   --------------------------------------------------------------------- */
.loading-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-4);
  min-height: 60vh;
  color: var(--text-secondary);
  font-size: var(--fs-md);
  font-weight: 500;
}

.loading-spinner {
  width: 46px;
  height: 46px;
  border-radius: var(--radius-full);
  border: 3px solid var(--border);
  border-top-color: var(--accent);
  border-right-color: var(--accent-2);
  animation: spin 0.85s linear infinite;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

/* ---------------------------------------------------------------------
   Page header
   --------------------------------------------------------------------- */
.page-header {
  margin-bottom: var(--space-7);
}

.page-title-row {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.page-title-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  flex: none;
  border-radius: var(--radius-lg);
  background: var(--gradient-brand);
  color: #fff;
  box-shadow: 0 14px 30px rgba(109, 93, 253, 0.34);
}

.page-title-icon .icon svg { width: 22px; height: 22px; }

.page-title {
  font-size: var(--fs-2xl);
  font-weight: 700;
  letter-spacing: -0.025em;
  color: var(--text-primary);
  line-height: 1.1;
}

.page-desc {
  margin-top: 4px;
  color: var(--text-secondary);
  font-size: var(--fs-md);
  font-weight: 400;
  max-width: 64ch;
}

.section-title {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  font-weight: 600;
  letter-spacing: -0.015em;
  color: var(--text-primary);
}

.dashboard-section { margin-top: var(--space-8); }

/* ---------------------------------------------------------------------
   Stats grid
   --------------------------------------------------------------------- */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: var(--space-4);
}

.stat-card {
  position: relative;
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5);
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  transition: transform var(--t), box-shadow var(--t), border-color var(--t);
}

.stat-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, transparent 60%, rgba(109, 93, 253, 0.06));
  opacity: 0;
  transition: opacity var(--t);
}

.stat-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-lg);
  border-color: var(--border);
}
.stat-card:hover::after { opacity: 1; }

.stat-card-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  flex: none;
  border-radius: var(--radius);
  background: var(--accent-soft);
  color: var(--accent);
}
.stat-card-icon.icon-success { background: var(--success-soft); color: var(--success-text); }
.stat-card-icon.icon-info { background: var(--info-soft); color: var(--info-text); }
.stat-card-icon.icon-warning { background: var(--warning-soft); color: var(--warning-text); }
.stat-card-icon.icon-danger { background: var(--danger-soft); color: var(--danger-text); }
.stat-card-icon.icon-accent2 { background: var(--accent-2-soft); color: var(--accent-2); }

.stat-card-label {
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.stat-card-value {
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  font-weight: 700;
  letter-spacing: -0.03em;
  color: var(--text-primary);
  line-height: 1.05;
  margin-top: 2px;
}

/* ---------------------------------------------------------------------
   Progress overview
   --------------------------------------------------------------------- */
.progress-overview {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--space-4);
  margin-top: var(--space-5);
}

.progress-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  box-shadow: var(--shadow-sm);
  transition: transform var(--t), box-shadow var(--t), border-color var(--t);
}
.progress-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow);
  border-color: var(--border);
}

.progress-card-title {
  font-family: var(--font-display);
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: var(--space-4);
}

.progress-bar-wrap + .progress-bar-wrap { margin-top: var(--space-4); }

.progress-bar-label {
  display: flex;
  justify-content: space-between;
  font-size: var(--fs-xs);
  font-weight: 600;
  color: var(--text-secondary);
  margin-bottom: 6px;
}
.progress-bar-label span:last-child { color: var(--text-muted); font-weight: 500; }

.progress-bar {
  height: 8px;
  border-radius: var(--radius-full);
  background: var(--bg-surface-hover);
  overflow: hidden;
}

.progress-bar-fill {
  height: 100%;
  border-radius: var(--radius-full);
  background: var(--accent);
  transition: width 600ms var(--ease-out);
}
.progress-bar-fill.research { background: linear-gradient(90deg, var(--info), var(--accent)); }
.progress-bar-fill.sourcing { background: linear-gradient(90deg, var(--warning), var(--clr-gold)); }
.progress-bar-fill.capture { background: linear-gradient(90deg, var(--success), var(--accent-2)); }

.family-progress-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-top: var(--space-4);
}

.family-progress-row {
  display: grid;
  grid-template-columns: 1fr auto 220px;
  align-items: center;
  gap: var(--space-4);
}

.family-progress-name {
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--text-primary);
}

.family-progress-pct {
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--text-secondary);
}

/* ---------------------------------------------------------------------
   Filter bar
   --------------------------------------------------------------------- */
.filter-bar {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.filter-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--text-secondary);
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-full);
  transition: color var(--t), background-color var(--t), border-color var(--t), transform var(--t-fast);
}
.filter-chip:hover {
  color: var(--text-primary);
  border-color: var(--border);
  background: var(--bg-surface-hover);
  transform: translateY(-1px);
}
.filter-chip.active {
  color: var(--accent-contrast);
  background: var(--accent);
  border-color: var(--accent);
  box-shadow: 0 6px 14px rgba(109, 93, 253, 0.3);
}

.filter-more-wrap { position: relative; }

.filter-more-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 7px 12px;
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--text-secondary);
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-full);
  transition: color var(--t), background-color var(--t), border-color var(--t);
}
.filter-more-btn:hover,
.filter-more-btn.active {
  color: var(--accent);
  border-color: var(--accent-soft-strong);
  background: var(--accent-soft);
}

.filter-more-panel {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  z-index: 20;
  min-width: 220px;
  padding: var(--space-2);
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
  display: none;
  flex-direction: column;
  gap: 2px;
}
.filter-more-panel.open {
  display: flex;
  animation: fadeUp 180ms var(--ease-out) both;
}

.filter-more-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: 8px 10px;
  border: none;
  background: transparent;
  border-radius: var(--radius-sm);
  color: var(--text-secondary);
  font-size: var(--fs-sm);
  font-weight: 500;
  text-align: left;
  transition: background-color var(--t), color var(--t);
}
.filter-more-item:hover {
  background: var(--bg-surface-hover);
  color: var(--text-primary);
}
.filter-more-item.active {
  background: var(--accent-soft);
  color: var(--accent);
  font-weight: 600;
}

.toolbar-spacer { flex: 1; }

.toolbar-meta {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  color: var(--text-muted);
  font-size: var(--fs-sm);
}

.result-count {
  font-weight: 600;
  color: var(--text-secondary);
}

.edits-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  font-size: var(--fs-xs);
  font-weight: 700;
  border-radius: var(--radius-full);
  background: var(--accent-2-soft);
  color: var(--accent-2);
}

.toolbar-actions {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}

/* ---------------------------------------------------------------------
   Group list (families / volumes)
   --------------------------------------------------------------------- */
.group-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  margin-top: var(--space-5);
}

.group {
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  transition: box-shadow var(--t), border-color var(--t);
}
.group.is-open {
  box-shadow: var(--shadow);
  border-color: var(--border);
}

.group-header {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  width: 100%;
  padding: var(--space-4) var(--space-5);
  border: none;
  background: transparent;
  text-align: left;
  transition: background-color var(--t);
}
.group-header:hover { background: var(--bg-surface-hover); }

.group-chevron {
  display: inline-flex;
  color: var(--text-muted);
  transition: transform var(--t), color var(--t);
}
.group.collapsed .group-chevron { transform: rotate(-90deg); }

.group-signal {
  display: inline-flex;
  gap: 4px;
  padding: 0 var(--space-2);
}

.group-signal-dot {
  width: 7px;
  height: 7px;
  border-radius: var(--radius-full);
  background: var(--border);
}
.group-signal-dot.on-urgent { background: var(--danger); box-shadow: 0 0 6px var(--danger); }
.group-signal-dot.on-have { background: var(--success); box-shadow: 0 0 6px var(--success); }
.group-signal-dot.on-pending { background: var(--warning); box-shadow: 0 0 6px var(--warning); }

.group-name {
  flex: 1;
  font-family: var(--font-display);
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--text-primary);
  letter-spacing: -0.01em;
}

.group-count {
  font-size: var(--fs-xs);
  font-weight: 700;
  padding: 3px 10px;
  border-radius: var(--radius-full);
  background: var(--bg-surface-alt);
  color: var(--text-muted);
}

.group-body-outer {
  display: grid;
  grid-template-rows: 1fr;
  transition: grid-template-rows var(--t-slow);
}
.group.collapsed .group-body-outer { grid-template-rows: 0fr; }

.group-body { overflow: hidden; }
.group.collapsed .group-body { opacity: 0; }
.group-body-inner { padding: 0 var(--space-5) var(--space-5); }

/* ---------------------------------------------------------------------
   Entity cards
   --------------------------------------------------------------------- */
.card-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(380px, 1fr));
  gap: var(--space-4);
}

.entity-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-left: 3px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  transition: transform var(--t), box-shadow var(--t), border-color var(--t);
}
.entity-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-lg);
  border-color: var(--border);
  background: var(--bg-surface-hover);
}
.entity-card.amp-card-priority-high { border-left-color: var(--priority-high); }
.entity-card.amp-card-priority-medium { border-left-color: var(--priority-medium); }
.entity-card.amp-card-priority-low { border-left-color: var(--priority-low); }

.entity-card-header {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: var(--space-3);
  width: 100%;
  padding: var(--space-4) var(--space-5) var(--space-4) var(--space-5);
  padding-right: 40px;
  border: none;
  background: transparent;
  text-align: left;
  position: relative;
  transition: background-color var(--t);
}
.entity-card-header:hover { background: transparent; }

.entity-card-main { width: 100%; min-width: 0; }

.entity-card-title {
  font-family: var(--font-display);
  font-size: var(--fs-md);
  font-weight: 600;
  letter-spacing: -0.015em;
  color: var(--text-primary);
  line-height: 1.25;
  padding-right: 4px;
}

.entity-card-subtitle {
  margin-top: 4px;
  font-size: var(--fs-sm);
  color: var(--text-muted);
  font-weight: 500;
  line-height: 1.4;
}

.entity-card-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  width: 100%;
}

.entity-card-chevron {
  position: absolute;
  top: var(--space-4);
  right: var(--space-4);
  display: inline-flex;
  color: var(--text-muted);
  transition: transform var(--t), color var(--t);
}
.entity-card.collapsed .entity-card-chevron { transform: rotate(-90deg); }

.capture-state-chip {
  display: inline-flex;
  align-items: center;
  font-size: var(--fs-xs);
  font-weight: 700;
  padding: 3px 9px;
  border-radius: var(--radius-full);
  background: var(--bg-surface-alt);
  color: var(--text-muted);
  border: 1px solid var(--border-subtle);
}
.capture-state-chip.is-captured {
  background: var(--success-soft);
  color: var(--success-text);
  border-color: color-mix(in srgb, var(--success) 35%, transparent);
}

.note-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--fs-xs);
  font-weight: 600;
  padding: 3px 9px;
  border-radius: var(--radius-full);
  background: var(--accent-2-soft);
  color: var(--accent-2);
}

.entity-card-body-outer {
  display: grid;
  grid-template-rows: 1fr;
  transition: grid-template-rows var(--t-slow);
}
.entity-card.collapsed .entity-card-body-outer { grid-template-rows: 0fr; }

.entity-card-body { overflow: hidden; }
.entity-card.collapsed .entity-card-body { opacity: 0; }
.entity-card-body-inner {
  padding: 0 var(--space-5) var(--space-5);
  border-top: 1px solid var(--border-subtle);
  margin-top: 0;
  padding-top: var(--space-4);
}

.card-actions-row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-4);
  justify-content: flex-end;
  flex-wrap: wrap;
}

.field-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3) var(--space-5);
  margin-top: var(--space-3);
}
.field-grid.field-grid-wide { grid-template-columns: 1fr; }

.field { display: flex; flex-direction: column; gap: 3px; }

.field-label {
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.field-value {
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--text-primary);
}
.field-value.empty { color: var(--text-muted); font-style: italic; }

.note-block {
  margin-top: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: var(--bg-surface-alt);
  border: 1px solid var(--border-subtle);
  border-left: 3px solid var(--accent-2);
  border-radius: var(--radius);
  font-size: var(--fs-sm);
  color: var(--text-secondary);
}

.card-essentials {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.qf-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2) var(--space-5);
}

.qf {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  padding: 4px 0;
}

.qf-k {
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.qf-v {
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--text-primary);
}

.speaker-block {
  background: var(--bg-surface-alt);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius);
  padding: var(--space-3) var(--space-4);
}

.speaker-block-row {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: 5px 0;
}
.speaker-block-row + .speaker-block-row { border-top: 1px dashed var(--border-subtle); }
.speaker-block-shared-row {
  margin-top: 2px;
}

.speaker-block-label {
  flex: none;
  width: 88px;
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.speaker-block-main {
  flex: 1;
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.speaker-block-name {
  font-size: var(--fs-sm);
  font-weight: 700;
  color: var(--text-primary);
}

.chip-link {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px;
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--accent);
  background: var(--accent-soft);
  border: 1px solid transparent;
  border-radius: var(--radius-full);
  text-decoration: none;
  transition: background-color var(--t), color var(--t), border-color var(--t), transform var(--t-fast);
}
.chip-link:hover {
  background: var(--accent);
  color: var(--accent-contrast);
  transform: translateY(-1px);
}
.chip-link .icon svg { width: 13px; height: 13px; }

.chip-link-muted {
  background: var(--bg-surface);
  border-color: var(--border-subtle);
  color: var(--text-secondary);
}
.chip-link-muted:hover {
  background: var(--accent-soft);
  color: var(--accent);
  border-color: var(--accent-soft-strong);
}

.chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.chip-static {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--text-secondary);
  background: var(--bg-surface-alt);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-full);
}

.stat-cell {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.stat-cell-label {
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.status-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-top: var(--space-3);
  flex-wrap: wrap;
}

.status-row-stats {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.status-row-actions {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.bool-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 11px;
  font-size: var(--fs-xs);
  font-weight: 700;
  border-radius: var(--radius-full);
  border: 1px solid var(--border);
  background: var(--bg-surface);
  color: var(--text-muted);
  transition: background-color var(--t), color var(--t), border-color var(--t), transform var(--t-fast);
}
.bool-chip:hover { transform: translateY(-1px); border-color: var(--border-strong); }
.bool-chip.on {
  background: var(--success-soft);
  color: var(--success-text);
  border-color: transparent;
}
.bool-chip.on:hover {
  background: var(--success);
  color: #fff;
}

.badge-empty {
  display: inline-flex;
  padding: 3px 9px;
  font-size: var(--fs-xs);
  font-weight: 600;
  border-radius: var(--radius-full);
  background: var(--clr-slate-soft);
  color: var(--clr-slate-text);
}
.badge-empty::before { content: "—"; margin-right: 4px; opacity: 0.7; }

.badge-source-none { background: var(--clr-slate-soft); color: var(--clr-slate-text); }
.badge-source-locating { background: var(--clr-orange-soft); color: var(--clr-orange-text); }
.badge-source-owned { background: var(--clr-teal-soft); color: var(--clr-teal-text); }
.badge-source-use-alt { background: var(--clr-gold-soft); color: var(--clr-gold-text); }

.note-block-empty {
  border-left-color: var(--border-strong);
  color: var(--text-muted);
  font-style: italic;
}

/* ---------------------------------------------------------------------
   Editable fields
   --------------------------------------------------------------------- */
.ef {
  display: inline-flex;
  align-items: baseline;
  gap: 5px;
  padding: 2px 7px;
  margin: -2px -7px;
  border-radius: var(--radius-sm);
  border: 1px dashed transparent;
  cursor: text;
  position: relative;
  transition: background-color var(--t), border-color var(--t);
}
.ef.qf:hover,
.ef.status-row-ef:hover {
  background: var(--accent-soft);
  border-color: var(--accent-soft-strong);
}

.ef-pencil {
  display: inline-flex;
  align-items: center;
  color: var(--accent);
  opacity: 0;
  transform: translateX(-3px);
  transition: opacity var(--t), transform var(--t);
}
.ef-pencil .icon svg { width: 12px; height: 12px; }
.ef:hover .ef-pencil,
.ef:focus-visible .ef-pencil {
  opacity: 1;
  transform: translateX(0);
}

.ef-empty {
  color: var(--text-muted);
  font-style: italic;
  font-weight: 400;
}

.ef-pencil-btn {
  display: inline-flex;
  border: none;
  background: transparent;
  color: var(--accent);
  padding: 2px;
  border-radius: var(--radius-sm);
  transition: background-color var(--t);
}
.ef-pencil-btn:hover { background: var(--accent-soft); }

.ef-input,
.ef-select {
  font-size: inherit;
  font-weight: inherit;
  color: var(--text-primary);
  background: var(--bg-surface);
  border: 1px solid var(--accent);
  border-radius: var(--radius-sm);
  padding: 4px 8px;
  outline: none;
  box-shadow: var(--glow-accent);
  width: 100%;
}

.ef-textarea {
  font-family: inherit;
  font-size: inherit;
  color: var(--text-primary);
  background: var(--bg-surface);
  border: 1px solid var(--accent);
  border-radius: var(--radius);
  padding: 8px 10px;
  outline: none;
  box-shadow: var(--glow-accent);
  width: 100%;
  resize: vertical;
  min-height: 60px;
}

.ef.ef-active {
  background: transparent;
  border-color: transparent;
  box-shadow: none;
  padding: 0;
  margin: 0;
}
.ef.ef-active .ef-pencil { opacity: 0; }

.note-block .ef { display: block; padding: 2px 0; border: none; }
.note-block .ef:hover { background: transparent; }
.note-block .ef .ef-pencil { position: absolute; right: 0; top: 2px; }
.note-block .ef.ef-active { background: transparent; border: none; box-shadow: none; }

/* Card "more" toggle */
.refs-block {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-top: var(--space-3);
}

.card-more-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: var(--space-4);
  padding: 6px 12px;
  font-size: var(--fs-xs);
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: var(--text-secondary);
  background: var(--bg-surface-alt);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-full);
  transition: background-color var(--t), color var(--t), border-color var(--t);
}
.card-more-toggle:hover {
  color: var(--accent);
  border-color: var(--accent-soft-strong);
  background: var(--accent-soft);
}
.card-more-toggle .icon { transition: transform var(--t); }
.card-more-toggle[aria-expanded="true"] .icon { transform: rotate(180deg); }

.card-more-outer {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows var(--t-slow);
}
.card-more-outer.open { grid-template-rows: 1fr; }
.card-more-body { overflow: hidden; }
.card-more-inner {
  padding-top: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.detail-block-label {
  display: block;
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 4px;
}

.edit-label {
  font-size: var(--fs-xs);
  font-weight: 600;
  color: var(--text-muted);
  margin-bottom: 4px;
  display: block;
}

.edit-input,
.edit-select,
.edit-textarea {
  width: 100%;
  font-size: var(--fs-sm);
  color: var(--text-primary);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 8px 10px;
  outline: none;
  transition: border-color var(--t), box-shadow var(--t);
}
.edit-input:focus,
.edit-select:focus,
.edit-textarea:focus {
  border-color: var(--accent);
  box-shadow: var(--glow-accent);
}
.edit-textarea { resize: vertical; min-height: 72px; font-family: inherit; }

/* Segmented control */
.seg-control {
  display: inline-flex;
  padding: 3px;
  background: var(--bg-surface-alt);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-full);
  gap: 2px;
}

.seg-btn {
  padding: 5px 12px;
  font-size: var(--fs-xs);
  font-weight: 600;
  border: none;
  background: transparent;
  color: var(--text-secondary);
  border-radius: var(--radius-full);
  transition: background-color var(--t), color var(--t);
}
.seg-btn:last-child { margin-right: 0; }
.seg-btn:hover { color: var(--text-primary); }
.seg-btn.active {
  background: var(--accent);
  color: var(--accent-contrast);
  box-shadow: 0 4px 10px rgba(109, 93, 253, 0.3);
}
.seg-btn.active.seg-btn-danger { background: var(--danger); }
.seg-btn.active.seg-btn-success { background: var(--success); }
.seg-btn.active.seg-btn-warning { background: var(--warning); }

/* ---------------------------------------------------------------------
   Tag editor
   --------------------------------------------------------------------- */
.tag-editor {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.tag-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 6px 4px 10px;
  font-size: var(--fs-xs);
  font-weight: 600;
  background: var(--accent-soft);
  color: var(--accent);
  border-radius: var(--radius-full);
  border: 1px solid var(--accent-soft-strong);
  transition: background-color var(--t), color var(--t);
}
.tag-chip:hover { background: var(--accent-soft-strong); }

.tag-chip-text {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: inherit;
  text-decoration: none;
}
.tag-chip-text .icon svg { width: 11px; height: 11px; }

.tag-chip-remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border: none;
  border-radius: var(--radius-full);
  background: transparent;
  color: inherit;
  opacity: 0.65;
  transition: background-color var(--t), color var(--t), opacity var(--t);
}
.tag-chip-remove:hover {
  background: var(--danger);
  color: #fff;
  opacity: 1;
}

.tag-add-row {
  display: flex;
  gap: var(--space-2);
}

.tag-add-input {
  flex: 1;
  padding: 7px 11px;
  font-size: var(--fs-sm);
  color: var(--text-primary);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  outline: none;
  transition: border-color var(--t), box-shadow var(--t);
}
.tag-add-input:focus {
  border-color: var(--accent);
  box-shadow: var(--glow-accent);
}

/* Tag presets (cab types) */
.tag-preset-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.tag-preset-btn {
  padding: 5px 11px;
  font-size: var(--fs-xs);
  font-weight: 600;
  color: var(--text-secondary);
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-full);
  transition: color var(--t), background-color var(--t), border-color var(--t), transform var(--t-fast);
}
.tag-preset-btn:hover {
  color: var(--accent);
  border-color: var(--accent-soft-strong);
  background: var(--accent-soft);
  transform: translateY(-1px);
}
.tag-preset-btn.active {
  color: var(--accent-contrast);
  background: var(--accent);
  border-color: var(--accent);
}

.cab-editor-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  margin-top: var(--space-3);
}

/* ---------------------------------------------------------------------
   Speaker tiles
   --------------------------------------------------------------------- */
.tile-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: var(--space-4);
  margin-top: var(--space-5);
}

.speaker-tile {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-5);
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  text-align: left;
  position: relative;
  overflow: hidden;
  transition: transform var(--t), box-shadow var(--t), border-color var(--t);
}
.speaker-tile::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--gradient-brand);
  opacity: 0;
  transition: opacity var(--t);
}
.speaker-tile:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: var(--accent-soft-strong);
}
.speaker-tile:hover::before { opacity: 1; }

.speaker-tile-top {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.speaker-priority-dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  flex: none;
}
.speaker-priority-dot.priority-high { background: var(--priority-high); box-shadow: 0 0 8px var(--priority-high); }
.speaker-priority-dot.priority-medium { background: var(--priority-medium); box-shadow: 0 0 8px var(--priority-medium); }
.speaker-priority-dot.priority-low { background: var(--priority-low); box-shadow: 0 0 8px var(--priority-low); }

.speaker-tile-name {
  font-family: var(--font-display);
  font-size: var(--fs-md);
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--text-primary);
  flex: 1;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.speaker-tile-specs {
  font-size: var(--fs-sm);
  color: var(--text-secondary);
  font-weight: 500;
}

.speaker-tile-used {
  font-size: var(--fs-xs);
  font-weight: 600;
  color: var(--text-muted);
  margin-top: 2px;
}

/* ---------------------------------------------------------------------
   Detail card (speaker)
   --------------------------------------------------------------------- */
.detail-back-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--text-secondary);
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-full);
  transition: color var(--t), background-color var(--t), border-color var(--t), transform var(--t-fast);
}
.detail-back-btn:hover {
  color: var(--accent);
  border-color: var(--accent-soft-strong);
  background: var(--accent-soft);
  transform: translateX(-2px);
}

.detail-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow);
  padding: var(--space-7);
  margin-top: var(--space-5);
}

.ef-title {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--text-primary);
}
.ef-title .ef-pencil .icon svg { width: 16px; height: 16px; }

.detail-used-by {
  margin-top: var(--space-6);
}

.simple-list {
  list-style: none;
  margin: var(--space-3) 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.simple-list-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: 10px var(--space-4);
  background: var(--bg-surface-alt);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius);
  transition: background-color var(--t), border-color var(--t), transform var(--t-fast);
}
.simple-list-item:hover {
  background: var(--bg-surface-hover);
  border-color: var(--border);
  transform: translateX(2px);
}

.simple-list-link {
  background: none;
  border: none;
  padding: 0;
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--accent);
  cursor: pointer;
}
.simple-list-link:hover { color: var(--accent-hover); text-decoration: underline; }

.simple-list-tag {
  margin-left: auto;
  font-size: var(--fs-xs);
  font-weight: 600;
  padding: 3px 9px;
  border-radius: var(--radius-full);
  background: var(--accent-soft);
  color: var(--accent);
}

/* ---------------------------------------------------------------------
   Capture queue
   --------------------------------------------------------------------- */
.queue-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-top: var(--space-5);
}

.queue-group {
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  transition: border-color var(--t), box-shadow var(--t), background-color var(--t);
}
.queue-group.queue-group-active {
  border-color: var(--accent);
  box-shadow: 0 0 0 1px var(--accent), var(--shadow);
}
.queue-group.queue-drag-over {
  border-color: var(--accent-2);
  background: var(--accent-2-soft);
}
.queue-group.queue-dragging { opacity: 0.55; }

.queue-item-row {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.queue-drag-handle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  flex: none;
  border: none;
  background: transparent;
  color: var(--text-muted);
  border-radius: var(--radius-sm);
  cursor: grab;
  transition: background-color var(--t), color var(--t);
}
.queue-drag-handle:hover { background: var(--bg-surface-hover); color: var(--text-primary); }

.queue-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  transition: background-color var(--t);
}

.queue-chevron {
  display: inline-flex;
  color: var(--text-muted);
  transition: transform var(--t);
}
.queue-group.collapsed .queue-chevron { transform: rotate(-90deg); }

.queue-rank-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  flex: none;
  font-family: var(--font-display);
  font-size: var(--fs-sm);
  font-weight: 700;
  border-radius: var(--radius);
  background: var(--bg-surface-alt);
  color: var(--text-muted);
  border: 1px solid var(--border-subtle);
}
.queue-group-active .queue-rank-badge {
  background: var(--gradient-brand);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 6px 14px rgba(109, 93, 253, 0.34);
}

.queue-info {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex: 1;
  min-width: 0;
}

.queue-name {
  font-family: var(--font-display);
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--text-primary);
  letter-spacing: -0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.active-label {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: var(--fs-xs);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 3px 9px;
  border-radius: var(--radius-full);
  background: var(--success-soft);
  color: var(--success-text);
}

.queue-detail {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex: none;
}

.queue-stats {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.queue-amp-count {
  font-family: var(--font-display);
  font-size: var(--fs-md);
  font-weight: 700;
  color: var(--text-primary);
}

.queue-amp-label {
  font-size: var(--fs-xs);
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.queue-body-outer {
  display: grid;
  grid-template-rows: 1fr;
  transition: grid-template-rows var(--t-slow);
}
.queue-group.collapsed .queue-body-outer { grid-template-rows: 0fr; }
.queue-body { overflow: hidden; }
.queue-group.collapsed .queue-body { opacity: 0; }
.queue-body-inner {
  padding: 0 var(--space-5) var(--space-5);
  border-top: 1px solid var(--border-subtle);
  padding-top: var(--space-4);
}

.queue-complete-badge {
  background: var(--success-soft);
  color: var(--success);
  border: 1px solid color-mix(in srgb, var(--success) 35%, transparent);
  font-weight: 700;
}

.queue-body-actions-top {
  margin-top: 0;
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--border-subtle);
}

.queue-body-actions {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
  margin-top: var(--space-3);
}

.queue-mic-header {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-2);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text-muted);
}
.queue-mic-header .section-title {
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: var(--fs-xs);
  color: var(--text-primary);
}

.queue-mic-progress {
  margin-left: auto;
  font-size: var(--fs-xs);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--accent-2);
  background: var(--accent-2-soft);
  padding: 3px 10px;
  border-radius: var(--radius-full);
}

.queue-mic-bar {
  margin: var(--space-3) 0;
}

.mic-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.mic-row {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: 8px var(--space-3);
  border-radius: var(--radius-sm);
  transition: background-color var(--t);
}
.mic-row:hover { background: var(--bg-surface-hover); }

.mic-row-success {
  background: var(--success-soft);
}
.mic-row-success:hover { background: var(--clr-teal-soft); }

.mic-name {
  flex: 1;
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--text-secondary);
}
.mic-row-success .mic-name { color: var(--success-text); }

.mic-lock-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px;
  font-size: var(--fs-xs);
  font-weight: 600;
  border-radius: var(--radius-full);
  border: 1px solid var(--border-subtle);
  background: var(--bg-surface);
  color: var(--text-muted);
  transition: background-color var(--t), color var(--t), border-color var(--t);
}
.mic-lock-btn:hover {
  color: var(--accent);
  border-color: var(--accent-soft-strong);
  background: var(--accent-soft);
}

/* ---------------------------------------------------------------------
   Toasts
   --------------------------------------------------------------------- */
.toast-root {
  position: fixed;
  bottom: var(--space-6);
  right: var(--space-6);
  z-index: 100;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  pointer-events: none;
}

.toast {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 12px 16px;
  min-width: 240px;
  max-width: 380px;
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--text-primary);
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
  pointer-events: auto;
  animation: toastIn 280ms var(--ease-out) both;
}
.toast.toast-leaving {
  animation: toastOut 280ms var(--ease-out) forwards;
}
.toast .icon { color: var(--accent); }
.toast.toast-info .icon { color: var(--info); }
.toast.toast-warning .icon { color: var(--warning); }

@keyframes toastIn {
  from { opacity: 0; transform: translateY(12px) scale(0.96); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes toastOut {
  to { opacity: 0; transform: translateY(12px) scale(0.96); }
}

/* ---------------------------------------------------------------------
   Empty states
   --------------------------------------------------------------------- */
.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: var(--space-3);
  padding: var(--space-10) var(--space-6);
  background: var(--bg-surface);
  border: 1px dashed var(--border-strong);
  border-radius: var(--radius-xl);
  margin-top: var(--space-5);
}

.empty-state-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 60px;
  height: 60px;
  border-radius: var(--radius-full);
  background: var(--accent-soft);
  color: var(--accent);
}
.empty-state-icon .icon svg { width: 26px; height: 26px; }

.empty-state-title {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  font-weight: 600;
  color: var(--text-primary);
}

.empty-state-desc {
  font-size: var(--fs-sm);
  color: var(--text-secondary);
  max-width: 48ch;
}

.empty-inline {
  font-size: var(--fs-sm);
  color: var(--text-muted);
  font-style: italic;
}

/* ---------------------------------------------------------------------
   Badges
   --------------------------------------------------------------------- */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 10px;
  font-size: var(--fs-xs);
  font-weight: 700;
  letter-spacing: 0.01em;
  border-radius: var(--radius-full);
  white-space: nowrap;
}
.badge::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: var(--radius-full);
  background: currentColor;
  opacity: 0.85;
}

.badge-status-unknown, .badge-confidence-unknown { background: var(--clr-slate-soft); color: var(--clr-slate-text); }
.badge-status-need-research { background: var(--clr-red-soft); color: var(--clr-red-text); }
.badge-status-need-source { background: var(--clr-orange-soft); color: var(--clr-orange-text); }
.badge-status-located { background: var(--clr-gold-soft); color: var(--clr-gold-text); }
.badge-status-shared-speaker { background: var(--clr-blue-soft); color: var(--clr-blue-text); }
.badge-status-captured { background: var(--clr-teal-soft); color: var(--clr-teal-text); }
.badge-status-verified { background: var(--clr-purple-soft); color: var(--clr-purple-text); }

.badge-confidence-confirmed { background: var(--clr-teal-soft); color: var(--clr-teal-text); }
.badge-confidence-strong-evidence { background: var(--clr-blue-soft); color: var(--clr-blue-text); }
.badge-confidence-likely { background: var(--clr-gold-soft); color: var(--clr-gold-text); }
.badge-confidence-estimated { background: var(--clr-orange-soft); color: var(--clr-orange-text); }

.badge-priority-high { background: var(--clr-red-soft); color: var(--clr-red-text); }
.badge-priority-medium { background: var(--clr-teal-soft); color: var(--clr-teal-text); }
.badge-priority-low { background: var(--clr-blue-soft); color: var(--clr-blue-text); }

.amp-meta-empty {
  font-size: var(--fs-xs);
  color: var(--text-muted);
  font-style: italic;
}

/* ---------------------------------------------------------------------
   Options page
   --------------------------------------------------------------------- */
.options-content {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  margin-top: var(--space-5);
  max-width: 720px;
}

.options-section {
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
  padding: var(--space-6);
}

.options-section-title {
  font-size: var(--fs-lg);
  margin-bottom: var(--space-2);
}

.options-section-desc {
  font-size: var(--fs-sm);
  color: var(--text-secondary);
  line-height: 1.6;
  margin-bottom: var(--space-4);
}

.options-field-label {
  display: block;
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 6px;
  margin-top: var(--space-3);
}
.options-field-label:first-of-type { margin-top: 0; }

.options-input {
  width: 100%;
  padding: 10px 12px;
  font-size: var(--fs-sm);
  color: var(--text-primary);
  background: var(--bg-surface-alt);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius);
  outline: none;
  transition: border-color var(--t), box-shadow var(--t);
}
.options-input:focus {
  border-color: var(--accent);
  box-shadow: var(--glow-accent);
}

.legend-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--space-3);
  margin-top: var(--space-4);
}

.legend-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: 8px 12px;
  background: var(--bg-surface-alt);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--text-secondary);
}

.legend-dot {
  width: 10px;
  height: 10px;
  border-radius: var(--radius-full);
  flex: none;
}

.status-legend {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-4);
}

/* ---------------------------------------------------------------------
   Data table
   --------------------------------------------------------------------- */
.table-wrap {
  margin-top: var(--space-5);
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: auto;
}

.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-sm);
}

.data-table th {
  text-align: left;
  padding: 12px var(--space-4);
  font-size: var(--fs-xs);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text-muted);
  background: var(--bg-surface-alt);
  border-bottom: 1px solid var(--border-subtle);
  white-space: nowrap;
  position: sticky;
  top: 0;
}

.data-table td {
  padding: 12px var(--space-4);
  color: var(--text-primary);
  border-bottom: 1px solid var(--border-subtle);
}

.data-table tbody tr:last-child td { border-bottom: none; }

.data-table tr.row-link { cursor: pointer; transition: background-color var(--t); }
.data-table tr.row-link:hover { background: var(--bg-surface-hover); }
.data-table tr.row-link:hover td:first-child {
  color: var(--accent);
  font-weight: 700;
}

/* ==========================================================================
   Card focus modal
   ========================================================================== */
body.modal-open {
  overflow: hidden;
}

.card-modal-root {
  position: fixed;
  inset: 0;
  z-index: 80;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-6);
  pointer-events: none;
}

.card-modal-root .card-modal-backdrop,
.card-modal-root .card-modal-stage,
.card-modal-root .card-modal-close {
  pointer-events: auto;
}

.card-modal-backdrop {
  position: absolute;
  inset: 0;
  background: var(--bg-overlay);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  opacity: 0;
  transition: opacity var(--t-slow);
}

.card-modal-root.open .card-modal-backdrop { opacity: 1; }
.card-modal-root.leaving .card-modal-backdrop { opacity: 0; transition-duration: 200ms; }

.card-modal-stage {
  position: relative;
  width: min(900px, 100%);
  max-height: calc(100vh - var(--space-10));
  display: flex;
  align-items: flex-start;
  justify-content: center;
  opacity: 0;
  transform: translateY(20px) scale(0.95);
  transition: opacity var(--t-slow), transform var(--t-slow);
}

.card-modal-root.open .card-modal-stage {
  opacity: 1;
  transform: translateY(0) scale(1);
}
.card-modal-root.leaving .card-modal-stage {
  opacity: 0;
  transform: translateY(10px) scale(0.97);
  transition-duration: 200ms;
}

.card-modal-card {
  width: 100%;
  max-height: calc(100vh - var(--space-10));
  overflow: auto;
  scrollbar-width: thin;
}

.card-modal-card .entity-card {
  width: 100%;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
  border-left-width: 4px;
}
/* No hover-lift / bg shift inside the modal — it shouldn't "breathe" as the
   cursor moves on and off the card. */
.card-modal-card .entity-card:hover {
  transform: none;
  box-shadow: var(--shadow-xl);
  border-color: var(--border-subtle);
  background: var(--bg-surface);
}
.card-modal-card .entity-card-header:hover {
  background: transparent;
}
/* Full-cell hover for modal quick-fact fields instead of a tiny inline pill. */
.card-modal-card .qf {
  border-radius: var(--radius-sm);
  transition: background-color var(--t);
}
.card-modal-card .qf:hover {
  background: var(--bg-surface-alt);
}
.card-modal-card .qf .ef:hover {
  background: transparent;
}

.card-modal-card .entity-card-header {
  flex-direction: row;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-6) var(--space-7);
  padding-right: var(--space-7);
  border-bottom: 1px solid var(--border-subtle);
}

.card-modal-card .entity-card-main {
  flex: 1;
  min-width: 0;
  width: auto;
}

.card-modal-card .entity-card-meta {
  width: auto;
  flex: none;
  margin-left: auto;
  align-self: center;
}

.card-modal-card .entity-card-chevron {
  position: static;
  order: 10;
  margin-left: 4px;
  align-self: center;
}

.card-modal-card .entity-card-title { font-size: var(--fs-lg); }
.card-modal-card .entity-card-subtitle { font-size: var(--fs-sm); }

.card-modal-card .entity-card-body-inner {
  padding: var(--space-6) var(--space-7) var(--space-7);
}

.card-modal-card .qf-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-3) var(--space-5);
}
.card-modal-card .qf {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 4px;
  padding: 8px 0;
}
.card-modal-card .qf-k { width: auto; }
.card-modal-card .qf-v { font-size: var(--fs-md); }

.card-modal-card .speaker-block { padding: var(--space-4) var(--space-5); }

.card-modal-card .status-row {
  margin-top: var(--space-5);
  padding-top: var(--space-4);
  border-top: 1px solid var(--border-subtle);
}

.card-modal-close {
  position: absolute;
  top: -14px;
  right: -14px;
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-full);
  border: 1px solid var(--border);
  background: var(--bg-elevated);
  color: var(--text-secondary);
  box-shadow: var(--shadow);
  transition: transform var(--t-fast), background-color var(--t), color var(--t), border-color var(--t);
  z-index: 2;
}
.card-modal-close:hover {
  transform: rotate(90deg) scale(1.05);
  color: var(--danger);
  border-color: var(--danger);
}

/* ==========================================================================
   Selection inputs — glowing double-border "boxes" (see reference)
   ========================================================================== */
.select-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
  width: 100%;
}

.select-chevron {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  pointer-events: none;
  transition: transform var(--t), color var(--t);
}
.select-chevron .icon svg { width: 14px; height: 14px; }
.select-wrap:hover .select-chevron { color: var(--accent-hover); }

.edit-select,
.ef-select {
  width: 100%;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding: 9px 34px 9px 12px;
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--text-primary);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  outline: none;
  cursor: pointer;
  transition: border-color var(--t), box-shadow var(--t), background-color var(--t);
}

.edit-select:hover,
.ef-select:hover {
  border-color: var(--accent);
  box-shadow: 0 0 14px rgba(109, 93, 253, 0.18);
}

.edit-select:focus,
.ef-select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(109, 93, 253, 0.16), 0 0 18px rgba(109, 93, 253, 0.22);
}

[data-theme="dark"] .edit-select,
[data-theme="dark"] .ef-select {
  background: var(--bg-surface-alt);
  border-color: var(--border);
}
[data-theme="dark"] .edit-select:hover,
[data-theme="dark"] .ef-select:hover {
  border-color: var(--accent);
  box-shadow: 0 0 18px rgba(139, 123, 255, 0.32);
}
[data-theme="dark"] .edit-select:focus,
[data-theme="dark"] .ef-select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(139, 123, 255, 0.24), 0 0 22px rgba(139, 123, 255, 0.4);
}

/* ef-inline selects sit inside a tight editable chip — keep them compact */
.ef .select-wrap { display: inline-flex; }
.ef .edit-select { padding: 4px 28px 4px 10px; }

/* ==========================================================================
   Capture queue — richer, less gray, clearer states
   ========================================================================== */
.queue-group {
  position: relative;
  border-radius: var(--radius-lg);
  background:
    linear-gradient(180deg, rgba(109, 93, 253, 0.03), transparent 80px),
    var(--bg-surface);
}

.queue-group::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--gradient-brand);
  opacity: 0;
  transition: opacity var(--t);
}
.queue-group:hover::before { opacity: 0.35; }

.queue-group-active {
  border-color: var(--accent-soft-strong);
  background:
    linear-gradient(180deg, rgba(109, 93, 253, 0.07), transparent 120px),
    var(--bg-surface);
  box-shadow: 0 0 0 1px var(--accent-soft-strong), var(--shadow);
}
.queue-group-active::before { opacity: 1; }

.queue-item {
  padding: var(--space-4) var(--space-5);
  background: transparent;
  border: none;
  border-radius: 0;
  width: 100%;
}
.queue-item-row {
  align-items: stretch;
  border-radius: var(--radius-lg);
  transition: background-color var(--t);
}
.queue-item-row:hover {
  background: var(--bg-surface-hover);
}

.queue-name {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.queue-detail {
  margin-top: 4px;
  font-size: var(--fs-xs);
  font-weight: 500;
  color: var(--text-muted);
  letter-spacing: 0.01em;
}

.queue-amp-count {
  font-size: var(--fs-lg);
}

.queue-mic-bar { margin: var(--space-3) 0; }
.queue-mic-bar .progress-bar {
  height: 8px;
  border-radius: 2px;
  background: var(--bg-surface-alt);
  box-shadow: inset 0 0 0 1px var(--border-subtle);
}
.queue-mic-bar .progress-bar-fill {
  border-radius: 2px;
}
.queue-mic-bar .progress-bar-label {
  font-weight: 700;
  color: var(--text-secondary);
  margin-bottom: 8px;
}
.queue-mic-bar .progress-bar-label span:first-child { color: var(--text-muted); font-weight: 600; }
.queue-mic-bar .progress-bar-label span:last-child { color: var(--accent-2); font-weight: 700; }

.queue-body-actions { margin-top: var(--space-2); }

/* Mic checklist rows */
.mic-list {
  margin-top: var(--space-3);
  padding: var(--space-2);
  background: var(--bg-surface-alt);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius);
  gap: 2px;
}

.mic-row {
  padding: 8px 12px;
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
}

.mic-row-success {
  background: var(--success-soft);
  border-color: transparent;
}
.mic-row-success::after {
  content: "";
}

.mic-row-success .mic-name {
  color: var(--success-text);
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.mic-row-success .mic-name::before {
  content: "✓";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: var(--radius-full);
  background: var(--success);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
}

.mic-lock-btn {
  border-color: transparent;
  background: var(--success-soft);
  color: var(--success-text);
}
.mic-lock-btn:hover {
  background: var(--success);
  color: #fff;
  border-color: transparent;
}

/* Planned / Next / Success segmented buttons inside mic rows */
.mic-row .seg-control { background: var(--bg-surface); }
.mic-row .seg-btn { padding: 4px 11px; }

/* ---------------------------------------------------------------------
   Mic Locker
   --------------------------------------------------------------------- */
.mic-locker-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
  margin: var(--space-5) 0 var(--space-6);
  padding: var(--space-4) var(--space-5);
  background: var(--accent-soft);
  border: 1px solid var(--accent-soft-strong);
  border-radius: var(--radius-lg);
}
.mic-locker-count {
  font-size: var(--fs-sm);
  font-weight: 700;
  color: var(--accent);
}
.mic-locker-hint {
  font-size: var(--fs-sm);
  color: var(--text-secondary);
}

.mic-locker-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: var(--space-5);
}

.mic-locker-section {
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}
.mic-locker-cat {
  margin: 0;
  padding: var(--space-4) var(--space-5);
  font-size: var(--fs-xs);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
  background: var(--bg-surface-alt);
  border-bottom: 1px solid var(--border-subtle);
}
.mic-locker-list {
  display: flex;
  flex-direction: column;
}

.mic-locker-row {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  width: 100%;
  padding: 12px var(--space-4);
  border: none;
  border-bottom: 1px solid var(--border-subtle);
  background: transparent;
  text-align: left;
  transition: background-color var(--t), box-shadow var(--t);
}
.mic-locker-row:last-child { border-bottom: none; }
.mic-locker-row:hover { background: var(--bg-surface-hover); }
.mic-locker-row.active {
  background: var(--success-soft);
}
.mic-locker-row.active:hover {
  background: color-mix(in srgb, var(--success-soft) 80%, var(--bg-surface-hover));
}

.mic-locker-check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  flex: none;
  border-radius: var(--radius-sm);
  border: 2px solid var(--border-strong);
  background: var(--bg-surface);
  color: var(--success);
  transition: border-color var(--t), background-color var(--t), color var(--t);
}
.mic-locker-row.active .mic-locker-check {
  border-color: var(--success);
  background: var(--success);
  color: #fff;
}

.mic-locker-info {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.mic-locker-name {
  font-size: var(--fs-sm);
  font-weight: 700;
  color: var(--text-primary);
}
.mic-locker-tag {
  font-size: var(--fs-xs);
  color: var(--text-secondary);
  line-height: 1.45;
}

.mic-locker-state {
  flex: none;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 4px 8px;
  border-radius: var(--radius-full);
  background: var(--bg-surface-alt);
  color: var(--text-muted);
}
.mic-locker-row.active .mic-locker-state {
  background: var(--success);
  color: #fff;
}

.mic-list-empty {
  padding: var(--space-5);
  font-size: var(--fs-sm);
  color: var(--text-secondary);
  text-align: center;
  background: var(--bg-surface-alt);
  border-radius: var(--radius);
  border: 1px dashed var(--border-strong);
}

/* ==========================================================================
   User identity + Activity log
   ========================================================================== */
.user-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: none;
  border-radius: var(--radius-full);
  color: #fff;
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1;
  user-select: none;
}

.user-chip {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  width: 100%;
  padding: 8px 10px;
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius);
  background: var(--bg-surface-alt);
  text-align: left;
  transition: background-color var(--t), border-color var(--t), transform var(--t-fast);
}
.user-chip:hover {
  background: var(--bg-surface-hover);
  border-color: var(--border);
  transform: translateY(-1px);
}

.user-chip-text {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.user-chip-name {
  font-size: var(--fs-sm);
  font-weight: 700;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.user-chip-sub {
  font-size: 10.5px;
  font-weight: 500;
  color: var(--text-muted);
}

.nav-item-count.unread {
  background: var(--gradient-brand);
  color: #fff;
  box-shadow: 0 4px 10px rgba(109, 93, 253, 0.34);
}

/* --- Name prompt modal --- */
.name-prompt-root {
  position: fixed;
  inset: 0;
  z-index: 90;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-6);
  pointer-events: none;
}
.name-prompt-root > * { pointer-events: auto; }

.name-prompt-backdrop {
  position: absolute;
  inset: 0;
  background: var(--bg-overlay);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  opacity: 0;
  transition: opacity var(--t-slow);
}
.name-prompt-root.open .name-prompt-backdrop { opacity: 1; }

.name-prompt-card {
  position: relative;
  width: min(440px, 100%);
  padding: var(--space-7);
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
  opacity: 0;
  transform: translateY(16px) scale(0.96);
  transition: opacity var(--t-slow), transform var(--t-slow);
}
.name-prompt-root.open .name-prompt-card {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.name-prompt-head {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: var(--space-5);
}
.name-prompt-title {
  font-size: var(--fs-lg);
  font-weight: 700;
  color: var(--text-primary);
}
.name-prompt-sub {
  margin-top: 3px;
  font-size: var(--fs-sm);
  color: var(--text-secondary);
}

.name-prompt-label {
  display: block;
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 6px;
}
.name-prompt-input {
  width: 100%;
  padding: 11px 14px;
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--text-primary);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  outline: none;
  transition: border-color var(--t), box-shadow var(--t);
}
.name-prompt-input:focus {
  border-color: var(--accent);
  box-shadow: var(--glow-accent);
}

.name-prompt-actions {
  display: flex;
  justify-content: flex-end;
  gap: var(--space-2);
  margin-top: var(--space-5);
}

/* --- Activity view --- */
.activity-toolbar {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin: var(--space-5) 0 var(--space-5);
  flex-wrap: wrap;
}
.activity-filters {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}
.activity-filter-chip {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 5px 12px 5px 5px;
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--text-secondary);
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-full);
  transition: color var(--t), background-color var(--t), border-color var(--t), transform var(--t-fast);
}
.activity-filter-chip:hover {
  transform: translateY(-1px);
  border-color: var(--border);
  background: var(--bg-surface-hover);
}
.activity-filter-chip.active {
  color: var(--accent-contrast);
  background: var(--accent);
  border-color: var(--accent);
}
.activity-filter-clear {
  padding: 5px 12px;
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--text-muted);
  background: transparent;
  border: 1px dashed var(--border-strong);
  border-radius: var(--radius-full);
}
.activity-filter-clear:hover { color: var(--text-primary); }

.activity-meta {
  margin-left: auto;
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--text-muted);
}

.activity-timeline {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}
.activity-group { display: flex; flex-direction: column; gap: var(--space-2); }
.activity-day {
  font-size: var(--fs-xs);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
  padding: 0 4px;
}

.activity-rows {
  display: flex;
  flex-direction: column;
  gap: 6px;
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.activity-row {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: 12px var(--space-4);
  border: none;
  background: transparent;
  text-align: left;
  width: 100%;
  transition: background-color var(--t);
  border-bottom: 1px solid var(--border-subtle);
}
.activity-row:last-child { border-bottom: none; }
.activity-row:hover { background: var(--bg-surface-hover); }
.activity-row.unread {
  background: var(--accent-soft);
}
.activity-row.unread:hover { background: var(--accent-soft-strong); }

.activity-row-main { flex: 1; min-width: 0; }
.activity-row-top {
  display: flex;
  align-items: center;
  gap: 7px;
  flex-wrap: wrap;
  font-size: var(--fs-sm);
}
.activity-who {
  font-weight: 700;
  color: var(--text-primary);
}
.activity-action {
  font-weight: 600;
  color: var(--text-secondary);
}
.act-old {
  font-size: var(--fs-xs);
  font-weight: 600;
  color: var(--text-muted);
  padding: 2px 7px;
  border-radius: var(--radius-full);
  background: var(--bg-surface-alt);
  border: 1px solid var(--border-subtle);
}
.act-arrow { color: var(--text-muted); font-size: var(--fs-xs); }
.act-new {
  font-size: var(--fs-xs);
  font-weight: 700;
  color: var(--accent-2);
  padding: 2px 7px;
  border-radius: var(--radius-full);
  background: var(--accent-2-soft);
}
.activity-row-bottom {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: 3px;
  font-size: var(--fs-xs);
  color: var(--text-muted);
}
.activity-entity {
  font-weight: 600;
  color: var(--text-secondary);
}
.activity-entity::before { content: "on "; color: var(--text-muted); font-weight: 500; }
.activity-time { margin-left: auto; }
.activity-go {
  color: var(--text-muted);
  transition: color var(--t), transform var(--t);
}
.activity-row:hover .activity-go { color: var(--accent); transform: translateX(2px); }

/* --- Edited-by hint on cards --- */
.edited-by-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 2px 9px 2px 3px;
  font-size: var(--fs-xs);
  font-weight: 700;
  color: var(--text-secondary);
  background: var(--accent-soft);
  border: 1px solid var(--accent-soft-strong);
  border-radius: var(--radius-full);
  transition: transform var(--t-fast);
}
.edited-by-chip:hover { transform: translateY(-1px); }

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width: 900px) {
  .app-shell { flex-direction: column; }
  .sidebar {
    position: relative;
    width: 100%;
    min-width: 0;
    height: auto;
    transform: none;
    border-right: none;
    border-bottom: 1px solid var(--border-subtle);
  }
  .topbar {
    grid-template-columns: 1fr auto;
    gap: var(--space-2);
    padding: 0 var(--space-4);
  }
  .topbar-search-wrap { width: 100%; }
  .main-content { padding: var(--space-5) var(--space-5) var(--space-8); }
  .field-grid { grid-template-columns: 1fr 1fr; }
  .card-list { grid-template-columns: 1fr; }
  .card-modal-root { padding: var(--space-3); }
  .card-modal-card .qf-row { grid-template-columns: 1fr 1fr; }
  .card-modal-close { top: 4px; right: 4px; }
}

@media (max-width: 560px) {
  :root { --fs-2xl: 24px; }
  .field-grid { grid-template-columns: 1fr; }
  .family-progress-row {
    grid-template-columns: 1fr;
    gap: 4px;
  }
  .queue-stats { display: none; }
  .cab-editor-grid { grid-template-columns: 1fr; }
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
  }
}
