/* ════════════════════════════════════════════════════════════════
   Speaker Verification — Design System & Component Library
   ════════════════════════════════════════════════════════════════ */

/* ── Reset ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ── Design Tokens ── */
:root {
    /* Backgrounds — layered depth */
    --bg-base: #0c0f14;
    --bg-surface: #141820;
    --bg-elevated: #1a2030;
    --bg-overlay: #222838;
    --bg-inset: #0a0d12;

    /* Legacy aliases (keep for any leftover references) */
    --bg: var(--bg-base);
    --bg-card: var(--bg-surface);
    --bg-hover: var(--bg-elevated);

    /* Borders */
    --border: #252d3a;
    --border-strong: #3a4452;

    /* Text hierarchy */
    --text-primary: #e8ecf2;
    --text-body: #c8cdd5;
    --text-muted: #6b7688;
    --text-faint: #4a5468;
    --text: var(--text-primary);

    /* Accent */
    --accent: #5b9cf5;
    --accent-hover: #7bb3ff;
    --accent-muted: rgba(91, 156, 245, 0.12);

    /* Semantic */
    --green: #3fb950;
    --green-muted: rgba(63, 185, 80, 0.12);
    --red: #f85149;
    --red-muted: rgba(248, 81, 73, 0.12);
    --yellow: #d29922;
    --yellow-muted: rgba(210, 153, 34, 0.12);
    --orange: #db6d28;
    --orange-muted: rgba(219, 109, 40, 0.12);
    --purple: #bc8cff;
    --purple-muted: rgba(188, 140, 255, 0.12);
    --teal: #2dd4bf;
    --teal-muted: rgba(45, 212, 191, 0.12);

    /* Typography scale (1.2 ratio) */
    --text-xs: 0.694rem;    /* ~11.1px */
    --text-sm: 0.833rem;    /* ~13.3px */
    --text-base: 1rem;      /* 16px */
    --text-md: 1.2rem;      /* ~19.2px */
    --text-lg: 1.44rem;     /* ~23px */
    --text-xl: 1.728rem;    /* ~27.6px */
    --text-2xl: 2.074rem;   /* ~33.2px */

    /* Font families */
    --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --font-mono: 'JetBrains Mono', 'SF Mono', 'Fira Code', monospace;

    /* Spacing (4px base) */
    --space-1: 4px;
    --space-2: 8px;
    --space-3: 12px;
    --space-4: 16px;
    --space-5: 20px;
    --space-6: 24px;
    --space-7: 32px;
    --space-8: 40px;
    --space-9: 48px;
    --space-10: 64px;

    /* Radii */
    --radius: 8px;
    --radius-sm: 6px;
    --radius-lg: 12px;
    --radius-xl: 16px;
    --radius-full: 9999px;

    /* Elevation */
    --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.3), 0 1px 2px rgba(0, 0, 0, 0.2);
    --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.35), 0 2px 4px rgba(0, 0, 0, 0.25);
    --shadow-lg: 0 12px 36px rgba(0, 0, 0, 0.45), 0 4px 12px rgba(0, 0, 0, 0.3);

    /* Motion */
    --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
    --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
    --duration-fast: 150ms;
    --duration-normal: 250ms;
    --duration-slow: 400ms;
}

/* ── Keyframes ── */
@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes slideUp {
    from { opacity: 0; transform: translateY(12px); }
    to { opacity: 1; transform: translateY(0); }
}

@keyframes slideDown {
    from { opacity: 0; transform: translateY(-12px); }
    to { opacity: 1; transform: translateY(0); }
}

@keyframes pulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.04); }
}

@keyframes progressFill {
    from { width: 0%; }
}

@keyframes shimmer {
    0% { background-position: -200% 0; }
    100% { background-position: 200% 0; }
}

@keyframes skeleton-pulse {
    0% { opacity: 0.15; }
    50% { opacity: 0.3; }
    100% { opacity: 0.15; }
}

@keyframes toastIn {
    from { opacity: 0; transform: translateY(-16px); }
    to { opacity: 1; transform: translateY(0); }
}

@keyframes ringGlow {
    0%, 100% { filter: drop-shadow(0 0 4px rgba(63, 185, 80, 0.3)); }
    50% { filter: drop-shadow(0 0 10px rgba(63, 185, 80, 0.5)); }
}

/* ── Base Styles ── */
body {
    font-family: var(--font-sans);
    background: var(--bg-base);
    color: var(--text-body);
    line-height: 1.6;
    padding-bottom: 80px;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

::selection {
    background: rgba(91, 156, 245, 0.3);
    color: var(--text-primary);
}

a {
    color: var(--accent);
    text-decoration: none;
    transition: color var(--duration-fast) var(--ease-out);
}
a:hover {
    color: var(--accent-hover);
    text-decoration: underline;
    text-underline-offset: 2px;
}

/* ── Topbar ── */
.topbar {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    padding: var(--space-3) var(--space-6);
    background: rgba(20, 24, 32, 0.82);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-bottom: 1px solid rgba(37, 45, 58, 0.5);
    box-shadow: var(--shadow-md);
    position: sticky;
    top: 0;
    z-index: 100;
}

.logo {
    font-weight: 700;
    font-size: var(--text-base);
    color: var(--text-primary);
    letter-spacing: -0.01em;
    white-space: nowrap;
}
.logo:hover { text-decoration: none; color: var(--text-primary); }

.slug-badge {
    background: var(--accent);
    color: var(--bg-base);
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-full);
    font-size: var(--text-xs);
    font-weight: 600;
    letter-spacing: 0.02em;
    white-space: nowrap;
}
.slug-badge:hover { text-decoration: none; color: var(--bg-base); opacity: 0.9; }

.nav-links {
    margin-left: auto;
    display: flex;
    gap: var(--space-1);
    align-items: center;
}
.nav-links > a:not(.btn):not(.slug-badge) {
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-sm);
    font-size: var(--text-sm);
    color: var(--text-muted);
    font-weight: 500;
    transition: all var(--duration-fast) var(--ease-out);
}
.nav-links > a:not(.btn):not(.slug-badge):hover {
    background: var(--bg-elevated);
    color: var(--text-primary);
    text-decoration: none;
}

.user-badge {
    color: var(--text-muted);
    font-size: var(--text-sm);
    border-left: 1px solid var(--border);
    padding-left: var(--space-3);
    margin-left: var(--space-2);
    font-weight: 500;
}

/* ── Container ── */
.container {
    max-width: 1100px;
    margin: 0 auto;
    padding: var(--space-6);
}

/* ── Buttons ── */
.btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-4);
    border: none;
    border-radius: var(--radius);
    background: var(--bg-elevated);
    color: var(--text-body);
    cursor: pointer;
    font-family: var(--font-sans);
    font-size: var(--text-sm);
    font-weight: 500;
    transition: all var(--duration-fast) var(--ease-out);
    white-space: nowrap;
    text-decoration: none;
}
.btn:hover {
    background: var(--bg-overlay);
    color: var(--text-primary);
    transform: translateY(-1px);
    box-shadow: var(--shadow-sm);
    text-decoration: none;
}
.btn:active { transform: translateY(0); box-shadow: none; }

.btn-xs { padding: 2px var(--space-2); font-size: var(--text-xs); border-radius: var(--radius-sm); }
.btn-sm { padding: var(--space-1) var(--space-3); font-size: var(--text-xs); }
.btn-lg { padding: var(--space-3) var(--space-6); font-size: var(--text-base); }

.btn-primary {
    background: var(--accent);
    color: var(--bg-base);
    font-weight: 600;
}
.btn-primary:hover { background: var(--accent-hover); color: var(--bg-base); }

.btn-correct {
    background: var(--green);
    color: var(--bg-base);
    font-size: var(--text-base);
    padding: var(--space-3) var(--space-6);
    border-radius: var(--radius-lg);
    font-weight: 600;
}
.btn-correct:hover { background: #4cc95f; color: var(--bg-base); }

.btn-incorrect {
    background: var(--red);
    color: #fff;
    font-size: var(--text-base);
    padding: var(--space-3) var(--space-6);
    border-radius: var(--radius-lg);
    font-weight: 600;
}
.btn-incorrect:hover { background: #f96d66; }

.btn-ad-voice {
    background: var(--orange);
    color: var(--bg-base);
    font-size: var(--text-base);
    padding: var(--space-3) var(--space-6);
    border-radius: var(--radius-lg);
    font-weight: 600;
}
.btn-ad-voice:hover { background: #e88040; color: var(--bg-base); }

.btn-clip-voice {
    background: var(--teal);
    color: var(--bg-base);
    font-size: var(--text-base);
    padding: var(--space-3) var(--space-6);
    border-radius: var(--radius-lg);
    font-weight: 600;
}
.btn-clip-voice:hover { background: #4ee0cf; color: var(--bg-base); }
.btn-clip-voice.btn-sm { font-size: var(--text-xs); padding: var(--space-1) var(--space-3); border-radius: var(--radius); }

.btn-skip {
    background: var(--bg-overlay);
    color: var(--text-body);
    font-size: var(--text-base);
    padding: var(--space-3) var(--space-6);
    border-radius: var(--radius-lg);
}
.btn-skip:hover { background: var(--border-strong); }

.btn-assign-name {
    background: var(--purple);
    color: var(--bg-base);
    font-size: var(--text-base);
    padding: var(--space-3) var(--space-6);
    border-radius: var(--radius-lg);
    font-weight: 600;
}
.btn-assign-name:hover { background: #cda3ff; color: var(--bg-base); }

.btn.active { background: var(--accent); color: var(--bg-base); }
.btn-clip-voice.active { background: var(--teal); color: var(--bg-base); }
.btn:disabled { opacity: 0.4; cursor: not-allowed; transform: none; box-shadow: none; }

.shortcut {
    display: inline-block;
    background: rgba(0, 0, 0, 0.25);
    padding: 1px 6px;
    border-radius: var(--radius-sm);
    font-size: var(--text-xs);
    font-weight: 700;
    font-family: var(--font-mono);
}

kbd {
    display: inline-block;
    padding: 2px 7px;
    background: var(--bg-inset);
    border: 1px solid var(--border);
    border-bottom-width: 2px;
    border-radius: var(--radius-sm);
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    color: var(--text-muted);
    line-height: 1.4;
}

/* ── Stats Grid ── */
.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: var(--space-3);
    margin: var(--space-5) 0;
}
.stat-card {
    background: var(--bg-surface);
    border: none;
    border-top: 3px solid var(--border);
    border-radius: var(--radius);
    padding: var(--space-4);
    text-align: center;
    box-shadow: var(--shadow-sm);
    transition: transform var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out);
}
.stat-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}
.stat-number { font-size: 1.75rem; font-weight: 700; color: var(--text-primary); }
.stat-label { font-size: var(--text-xs); color: var(--text-muted); margin-top: var(--space-1); text-transform: uppercase; letter-spacing: 0.05em; font-weight: 500; }
.stat-verified .stat-number { color: var(--green); }
.stat-verified { border-top-color: var(--green); }
.stat-remaining .stat-number { color: var(--yellow); }
.stat-remaining { border-top-color: var(--yellow); }

/* ── Progress Bar ── */
.progress-bar-container {
    background: var(--bg-inset);
    border: none;
    border-radius: var(--radius-full);
    height: 32px;
    position: relative;
    overflow: hidden;
    margin: var(--space-4) 0;
}
.progress-bar {
    height: 100%;
    background: linear-gradient(90deg, var(--green), #4cc95f);
    border-radius: var(--radius-full);
    transition: width 0.5s var(--ease-out);
    background-size: 200% 100%;
    animation: shimmer 3s linear infinite;
}
.progress-text {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--text-primary);
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
}

/* ── Tier Cards ── */
.section { margin: var(--space-6) 0; }
.tier-grid { display: flex; gap: var(--space-3); flex-wrap: wrap; }
.tier-card {
    background: var(--bg-surface);
    border: none;
    border-radius: var(--radius);
    padding: var(--space-3) var(--space-4);
    display: flex;
    align-items: center;
    gap: var(--space-3);
    flex: 1;
    min-width: 160px;
    box-shadow: var(--shadow-sm);
    transition: transform var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out);
}
.tier-card:hover { transform: translateY(-1px); box-shadow: var(--shadow-md); }
.tier-letter { font-size: var(--text-lg); font-weight: 800; }
.tier-counts { font-size: var(--text-sm); color: var(--text-muted); }
.tier-remaining { font-weight: 700; color: var(--text-primary); }

/* Tier colors */
.tier-X .tier-letter, .tier-badge.tier-X { color: var(--red); }
.tier-D .tier-letter, .tier-badge.tier-D { color: var(--orange); }
.tier-C .tier-letter, .tier-badge.tier-C { color: var(--yellow); }
.tier-B .tier-letter, .tier-badge.tier-B { color: var(--accent); }
.tier-A .tier-letter, .tier-badge.tier-A { color: var(--green); }

/* ── Tier Badge ── */
.tier-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: var(--radius-sm);
    font-weight: 800;
    font-size: var(--text-sm);
    border: 2px solid currentColor;
    flex-shrink: 0;
}
.tier-badge.tier-X { background: var(--red-muted); }
.tier-badge.tier-D { background: var(--orange-muted); }
.tier-badge.tier-C { background: var(--yellow-muted); }
.tier-badge.tier-B { background: var(--accent-muted); }
.tier-badge.tier-A { background: var(--green-muted); }

.tier-badge.large {
    width: 44px;
    height: 44px;
    font-size: var(--text-md);
    border-radius: var(--radius);
}
.tier-badge.large.tier-X { box-shadow: 0 0 16px var(--red-muted), 0 0 4px var(--red-muted); }
.tier-badge.large.tier-D { box-shadow: 0 0 16px var(--orange-muted), 0 0 4px var(--orange-muted); }
.tier-badge.large.tier-C { box-shadow: 0 0 16px var(--yellow-muted), 0 0 4px var(--yellow-muted); }
.tier-badge.large.tier-B { box-shadow: 0 0 16px var(--accent-muted), 0 0 4px var(--accent-muted); }
.tier-badge.large.tier-A { box-shadow: 0 0 16px var(--green-muted), 0 0 4px var(--green-muted); }

.tier-badge.small { width: 22px; height: 22px; font-size: var(--text-xs); }

.tier-mini {
    padding: 2px var(--space-2);
    border-radius: var(--radius-sm);
    font-size: var(--text-xs);
    font-weight: 600;
    border: 1px solid currentColor;
}
.tier-mini.tier-X { background: var(--red-muted); }
.tier-mini.tier-D { background: var(--orange-muted); }
.tier-mini.tier-C { background: var(--yellow-muted); }
.tier-mini.tier-B { background: var(--accent-muted); }
.tier-mini.tier-A { background: var(--green-muted); }

/* ── Queue ── */
.queue-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-3); }
.filter-bar { display: flex; gap: var(--space-2); margin-bottom: var(--space-3); flex-wrap: wrap; align-items: center; }
.cluster-list { display: flex; flex-direction: column; gap: 2px; }

.cluster-row {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
    background: var(--bg-surface);
    border: none;
    border-radius: var(--radius);
    color: var(--text-body);
    transition: all var(--duration-fast) var(--ease-out);
}
.cluster-row:hover {
    background: var(--bg-elevated);
    text-decoration: none;
    color: var(--text-primary);
    transform: translateX(2px);
}
.cluster-name { font-weight: 600; flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--text-primary); }
.cluster-meta { font-size: var(--text-sm); color: var(--text-muted); white-space: nowrap; }
.cluster-scores { font-size: var(--text-xs); color: var(--text-faint); font-family: var(--font-mono); white-space: nowrap; }

.pagination { display: flex; gap: var(--space-3); align-items: center; justify-content: center; margin-top: var(--space-4); }
.loading { text-align: center; padding: var(--space-8); color: var(--text-muted); }
.empty-state { text-align: center; padding: var(--space-8); color: var(--text-muted); font-style: italic; }

/* ── Review Page ── */
.review-header { margin-bottom: var(--space-6); animation: fadeIn var(--duration-normal) var(--ease-out); }
.back-link { font-size: var(--text-sm); color: var(--text-muted); font-weight: 500; }
.back-link:hover { color: var(--accent); }
.review-title-row { display: flex; align-items: center; gap: var(--space-3); margin: var(--space-2) 0; }
.review-title-row h1 { font-size: var(--text-xl); color: var(--text-primary); letter-spacing: -0.02em; }
.review-meta { font-size: var(--text-sm); color: var(--text-muted); margin-bottom: var(--space-2); }

.score-summary { display: flex; gap: var(--space-2); margin: var(--space-2) 0; flex-wrap: wrap; }
.score-pill {
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-full);
    font-size: var(--text-xs);
    font-weight: 600;
    border: none;
    font-family: var(--font-mono);
}
.score-pill.score-high { background: var(--green-muted); color: var(--green); }
.score-pill.score-medium { background: var(--yellow-muted); color: var(--yellow); }
.score-pill.score-low { background: var(--red-muted); color: var(--red); }

.tier-breakdown { display: flex; gap: var(--space-2); margin: var(--space-2) 0; }

/* ── Episode Cards ── */
.episodes-container { display: flex; flex-direction: column; gap: var(--space-5); margin-bottom: var(--space-6); }
.episode-card {
    background: var(--bg-surface);
    border: none;
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    transition: box-shadow var(--duration-fast) var(--ease-out);
    animation: slideUp var(--duration-normal) var(--ease-out) both;
}
.episode-card:hover { box-shadow: var(--shadow-md); }
.episode-header {
    padding: var(--space-4);
    border-bottom: 1px solid var(--border);
}
.episode-header h3 { font-size: var(--text-sm); margin-bottom: var(--space-1); color: var(--text-primary); font-weight: 600; }
.episode-meta { display: flex; gap: var(--space-3); align-items: center; font-size: var(--text-sm); color: var(--text-muted); flex-wrap: wrap; }
.speaker-label {
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    background: var(--bg-inset);
    padding: 1px var(--space-2);
    border-radius: var(--radius-sm);
    color: var(--text-muted);
}

.excerpts { padding: var(--space-3) var(--space-4); display: flex; flex-direction: column; gap: var(--space-4); }
.excerpt { display: flex; gap: var(--space-3); align-items: flex-start; }
.excerpt-play {
    flex-shrink: 0;
    width: 90px;
    font-family: var(--font-mono);
    font-size: var(--text-xs);
}
.excerpt-lines { flex: 1; }

.transcript-line {
    display: flex;
    gap: var(--space-2);
    padding: 3px 0;
    font-size: var(--text-sm);
    line-height: 1.6;
}
.target-speaker {
    background: var(--accent-muted);
    border-left: 3px solid var(--accent);
    padding-left: var(--space-2);
    margin-left: -11px;
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}
.other-speaker { color: var(--text-muted); }
.line-time { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--text-faint); flex-shrink: 0; width: 56px; }
.line-speaker { font-weight: 600; font-size: var(--text-xs); flex-shrink: 0; width: 90px; color: var(--text-muted); }
.line-text { flex: 1; }

/* ── Verdict Panel ── */
.verdict-panel {
    background: var(--bg-surface);
    border: none;
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    position: sticky;
    bottom: var(--space-4);
    z-index: 50;
    box-shadow: var(--shadow-lg);
    transition: bottom 0.2s var(--ease-out);
}
body.audio-visible .verdict-panel { bottom: 76px; }
.verdict-panel h3 { margin-bottom: var(--space-2); color: var(--text-primary); }
.propagation-preview {
    font-size: var(--text-sm);
    color: var(--text-muted);
    margin-bottom: var(--space-3);
    padding: var(--space-3);
    background: var(--bg-inset);
    border-radius: var(--radius);
    border-left: 3px solid var(--accent);
}
.propagation-preview strong { color: var(--text-primary); }
.verdict-buttons { display: flex; gap: var(--space-3); flex-wrap: wrap; }

.incorrect-form {
    margin-top: var(--space-3);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}
.incorrect-form label { font-size: var(--text-sm); color: var(--text-muted); }
.incorrect-form input {
    padding: var(--space-2) var(--space-3);
    background: var(--bg-inset);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    color: var(--text-primary);
    font-size: var(--text-sm);
    font-family: var(--font-sans);
    transition: all var(--duration-fast) var(--ease-out);
}
.incorrect-form input:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--accent-muted);
}

.hidden { display: none !important; }

/* ── Undo Banner ── */
.undo-banner {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
    background: var(--bg-elevated);
    border: 1px solid var(--yellow);
    border-left: 4px solid var(--yellow);
    border-radius: var(--radius);
    margin-bottom: var(--space-4);
    font-size: var(--text-sm);
    box-shadow: var(--shadow-md);
    animation: toastIn var(--duration-normal) var(--ease-out);
}
.undo-banner span { flex: 1; color: var(--text-body); }

.keyboard-help {
    margin-top: var(--space-4);
    padding: var(--space-3) var(--space-4);
    font-size: var(--text-xs);
    color: var(--text-faint);
    text-align: center;
    background: var(--bg-inset);
    border-radius: var(--radius);
    line-height: 2;
}
.keyboard-help strong { color: var(--text-muted); }

/* ── Audio Bar ── */
.audio-bar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: rgba(20, 24, 32, 0.88);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-top: none;
    box-shadow: 0 -4px 16px rgba(0, 0, 0, 0.35), 0 -1px 4px rgba(0, 0, 0, 0.25);
    padding: var(--space-3) var(--space-6);
    z-index: 200;
    animation: slideUp var(--duration-normal) var(--ease-out);
}
.audio-bar-inner { max-width: 1100px; margin: 0 auto; display: flex; align-items: center; gap: var(--space-4); }
.audio-ep-title { font-size: var(--text-sm); color: var(--text-muted); flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-weight: 500; }
.audio-controls { display: flex; align-items: center; gap: var(--space-2); }
#audio-time { font-size: var(--text-xs); font-family: var(--font-mono); color: var(--text-faint); min-width: 90px; text-align: center; }

/* ── Search ── */
.search-input {
    background: var(--bg-inset);
    border: 1px solid var(--border);
    color: var(--text-primary);
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius);
    font-size: var(--text-sm);
    font-family: var(--font-sans);
    width: 200px;
    margin-left: auto;
    transition: all var(--duration-fast) var(--ease-out);
}
.search-input:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--accent-muted);
    width: 260px;
}
.search-input::placeholder { color: var(--text-faint); }

.cluster-row.verified { opacity: 0.4; }
.cluster-row.verified:hover { opacity: 0.65; }

/* ── Episode Context ── */
.episode-context {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-2);
    margin-top: var(--space-2);
    font-size: var(--text-xs);
}
.context-label { color: var(--text-faint); }
.context-speaker {
    background: var(--bg-inset);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 2px var(--space-2);
    color: var(--text-muted);
    font-size: var(--text-xs);
}
.context-speaker.is-host {
    border-color: var(--accent);
    color: var(--accent);
    background: var(--accent-muted);
}
.context-speaker small { opacity: 0.6; }

/* ── Clip Voice ── */
.clip-badge {
    display: inline-block;
    padding: 2px var(--space-2);
    border-radius: var(--radius-full);
    font-size: var(--text-xs);
    font-weight: 600;
    background: var(--teal-muted);
    color: var(--teal);
    border: none;
}
.clip-info {
    display: flex;
    gap: var(--space-2);
    margin: var(--space-2) 0;
}

/* ── Full Transcript Panel ── */
.btn-transcript {
    font-size: var(--text-xs);
    padding: var(--space-1) var(--space-3);
    margin-left: auto;
}

.full-transcript {
    border-top: 1px solid var(--border);
    max-height: 500px;
    overflow-y: auto;
    padding: 0 var(--space-4) var(--space-4);
}

.transcript-search {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-3) 0;
    position: sticky;
    top: 0;
    background: var(--bg-surface);
    z-index: 10;
}
.transcript-search input {
    background: var(--bg-inset);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    color: var(--text-primary);
    padding: var(--space-1) var(--space-3);
    font-size: var(--text-sm);
    font-family: var(--font-sans);
    flex: 1;
    max-width: 300px;
    transition: all var(--duration-fast) var(--ease-out);
}
.transcript-search input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-muted); }
.search-count { font-size: var(--text-xs); color: var(--text-muted); white-space: nowrap; font-family: var(--font-mono); }
.search-nav-btn {
    background: var(--bg-elevated);
    border: none;
    border-radius: var(--radius-sm);
    color: var(--text-muted);
    cursor: pointer;
    padding: 2px var(--space-2);
    font-size: var(--text-sm);
    transition: all var(--duration-fast) var(--ease-out);
}
.search-nav-btn:hover { background: var(--bg-overlay); color: var(--text-primary); }

.turn-chunk {
    padding: var(--space-2) var(--space-3);
    margin: var(--space-1) 0;
    border-left: 3px solid transparent;
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
    transition: background var(--duration-fast) var(--ease-out);
}
.turn-chunk.target {
    border-left-color: var(--accent);
    background: var(--accent-muted);
}
.chunk-header {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    margin-bottom: 2px;
}
.chunk-speaker { font-weight: 700; font-size: var(--text-xs); color: var(--text-primary); }
.chunk-time {
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    color: var(--accent);
    cursor: pointer;
    transition: color var(--duration-fast) var(--ease-out);
}
.chunk-time:hover { color: var(--accent-hover); text-decoration: underline; }
.chunk-text { font-size: var(--text-sm); line-height: 1.6; color: var(--text-body); }
.chunk-text .chunk-line { margin: 1px 0; }

.full-transcript mark {
    background: rgba(210, 153, 34, 0.35);
    color: var(--text-primary);
    border-radius: 2px;
    padding: 0 2px;
}
.full-transcript mark.search-current {
    background: var(--yellow);
    color: var(--bg-base);
}

/* ── Episode Timeline ── */
.timeline-page-title { font-size: var(--text-lg); margin: var(--space-2) 0 var(--space-1); color: var(--text-primary); letter-spacing: -0.01em; }

.speaker-legend {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    margin: var(--space-3) 0;
    padding: var(--space-3) var(--space-4);
    background: var(--bg-surface);
    border-radius: var(--radius);
    box-shadow: var(--shadow-sm);
}
.legend-item {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--text-sm);
    padding: var(--space-1) var(--space-3);
    background: var(--bg-elevated);
    border-radius: var(--radius-full);
}
.legend-swatch {
    display: inline-block;
    width: 12px;
    height: 12px;
    border-radius: var(--radius-full);
    flex-shrink: 0;
}
.legend-name { font-weight: 600; color: var(--text-primary); font-size: var(--text-xs); }
.legend-role { color: var(--text-faint); font-size: var(--text-xs); }

.timeline-controls {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    margin: var(--space-2) 0;
}
.zoom-label {
    font-size: var(--text-sm);
    font-weight: 600;
    font-family: var(--font-mono);
    min-width: 36px;
    text-align: center;
    color: var(--text-muted);
}

.timeline-viewport {
    overflow-x: auto;
    overflow-y: hidden;
    border: none;
    border-radius: var(--radius-lg);
    background: var(--bg-surface);
    margin: var(--space-2) 0 var(--space-4);
    position: relative;
    box-shadow: var(--shadow-sm);
}
.timeline-bar-container {
    position: relative;
    height: 84px;
    min-width: 100%;
}
.timeline-bar {
    position: absolute;
    top: 8px;
    left: 0;
    right: 0;
    height: 48px;
    background: var(--bg-inset);
    border-radius: var(--radius);
}
.timeline-chunk {
    position: absolute;
    top: 0;
    height: 100%;
    border-radius: 3px;
    cursor: pointer;
    opacity: 0.85;
    transition: all var(--duration-fast) var(--ease-out);
}
.timeline-chunk:hover {
    opacity: 1;
    box-shadow: 0 0 8px rgba(255, 255, 255, 0.1);
    transform: scaleY(1.05);
}
.timeline-chunk.active {
    opacity: 1;
    outline: 2px solid var(--text-primary);
    outline-offset: 1px;
    z-index: 5;
}

.timeline-playhead {
    position: absolute;
    top: 2px;
    width: 3px;
    height: 54px;
    background: var(--red);
    z-index: 10;
    pointer-events: none;
    display: none;
    border-radius: 2px;
    box-shadow: 0 0 6px var(--red-muted);
}

.timeline-axis {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 22px;
}
.axis-tick {
    position: absolute;
    top: 0;
    width: 1px;
    height: 6px;
    background: var(--border-strong);
}
.axis-label {
    position: absolute;
    top: 7px;
    left: -20px;
    width: 40px;
    text-align: center;
    font-size: 10px;
    color: var(--text-faint);
    font-family: var(--font-mono);
}

/* Transcript panel with speaker dots */
.timeline-transcript-panel {
    max-height: 600px;
    overflow-y: auto;
    border: none;
    border-radius: var(--radius-lg);
    background: var(--bg-surface);
    padding: var(--space-3) var(--space-4);
    box-shadow: var(--shadow-sm);
}
.timeline-transcript-panel .tl-turn {
    padding: var(--space-2) var(--space-3);
    margin: var(--space-1) 0;
    border-left: 3px solid transparent;
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
    transition: all var(--duration-fast) var(--ease-out);
}
.timeline-transcript-panel .tl-turn.timeline-active {
    background: var(--accent-muted);
    border-left-color: var(--accent);
}
.speaker-dot {
    display: inline-block;
    width: 10px;
    height: 10px;
    border-radius: var(--radius-full);
    flex-shrink: 0;
}

/* ── Speaker Tag Popup ── */
.speaker-tag-popup {
    position: fixed;
    z-index: 300;
    background: var(--bg-elevated);
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-lg);
    padding: var(--space-3) var(--space-4);
    min-width: 260px;
    max-width: 320px;
    box-shadow: var(--shadow-lg);
    animation: slideUp var(--duration-fast) var(--ease-out);
}
.tag-popup-header {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    margin-bottom: var(--space-2);
}
.tag-popup-label {
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    background: var(--bg-inset);
    padding: 2px var(--space-2);
    border-radius: var(--radius-sm);
    color: var(--text-muted);
}
.tag-popup-role {
    font-size: var(--text-xs);
    color: var(--text-faint);
}
.tag-popup-close {
    margin-left: auto;
    background: none;
    border: none;
    color: var(--text-faint);
    font-size: 18px;
    cursor: pointer;
    padding: 0 var(--space-1);
    line-height: 1;
    transition: color var(--duration-fast) var(--ease-out);
}
.tag-popup-close:hover { color: var(--text-primary); }
.tag-popup-current {
    font-size: var(--text-sm);
    color: var(--text-muted);
    margin-bottom: var(--space-2);
}
.tag-popup-current strong { color: var(--text-primary); }
.tag-popup-form { margin-bottom: var(--space-3); }
.tag-popup-input {
    width: 100%;
    padding: var(--space-2) var(--space-3);
    background: var(--bg-inset);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    color: var(--text-primary);
    font-size: var(--text-sm);
    font-family: var(--font-sans);
    transition: all var(--duration-fast) var(--ease-out);
}
.tag-popup-input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-muted); }
.tag-popup-actions { display: flex; gap: var(--space-2); }
.tag-popup-actions .btn-ad-voice { font-size: var(--text-xs); padding: var(--space-1) var(--space-3); border-radius: var(--radius); }
.tag-popup-actions .btn-skip {
    background: var(--bg-overlay);
    color: var(--text-body);
    font-size: var(--text-xs);
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius);
}
.tag-popup-status {
    font-size: var(--text-xs);
    margin-top: var(--space-2);
    min-height: 16px;
}
.tag-popup-status.tag-success { color: var(--green); }
.tag-popup-status.tag-error { color: var(--red); }

.tl-tag-trigger { cursor: pointer; }
.tl-tag-trigger:hover { opacity: 0.8; }

/* ── Episode List ── */
.episode-list-controls {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    margin-bottom: var(--space-4);
    flex-wrap: wrap;
}
.ep-filter-label {
    font-size: var(--text-sm);
    color: var(--text-muted);
    display: flex;
    align-items: center;
    gap: var(--space-2);
    cursor: pointer;
    white-space: nowrap;
}
.ep-filter-label input { cursor: pointer; accent-color: var(--accent); }

.episode-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--text-sm);
}
.episode-table thead th {
    text-align: left;
    padding: var(--space-2) var(--space-3);
    border-bottom: 2px solid var(--border-strong);
    color: var(--text-faint);
    font-size: var(--text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    position: sticky;
    top: 48px;
    background: var(--bg-base);
    z-index: 10;
}
.episode-table tbody tr {
    border-bottom: none;
    transition: background var(--duration-fast) var(--ease-out);
}
.episode-table tbody tr:nth-child(even) { background: rgba(20, 24, 32, 0.5); }
.episode-table tbody tr:hover { background: var(--bg-elevated); }
.episode-table td { padding: var(--space-2) var(--space-3); }

.ep-col-num { width: 50px; color: var(--text-faint); font-family: var(--font-mono); font-size: var(--text-xs); }
.ep-col-title { min-width: 200px; }
.ep-col-title a { font-weight: 500; color: var(--text-body); }
.ep-col-title a:hover { color: var(--accent); }
.ep-col-date { width: 100px; color: var(--text-faint); font-size: var(--text-xs); white-space: nowrap; }
.ep-col-speakers { width: 70px; text-align: center; }
.ep-col-unid { width: 90px; text-align: center; }
.ep-col-pct { width: 140px; }

.unid-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 24px;
    height: 22px;
    padding: 0 var(--space-2);
    border-radius: var(--radius-full);
    background: var(--red-muted);
    color: var(--red);
    font-weight: 700;
    font-size: var(--text-xs);
}

.pct-bar-container {
    position: relative;
    height: 22px;
    background: var(--bg-inset);
    border-radius: var(--radius-sm);
    overflow: hidden;
}
.pct-bar {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    background: linear-gradient(90deg, rgba(248, 81, 73, 0.2), rgba(248, 81, 73, 0.35));
    border-radius: var(--radius-sm);
    min-width: 2px;
}
.pct-text {
    position: relative;
    z-index: 1;
    font-size: var(--text-xs);
    font-weight: 600;
    line-height: 22px;
    padding: 0 var(--space-2);
    font-family: var(--font-mono);
}

.text-muted { color: var(--text-muted); }

/* ── Podcast Selector ── */
.podcast-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--space-4);
    margin-top: var(--space-5);
}
.podcast-card {
    display: block;
    background: var(--bg-surface);
    border: none;
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    color: var(--text-body);
    box-shadow: var(--shadow-sm);
    transition: all var(--duration-normal) var(--ease-out);
}
.podcast-card:hover {
    background: var(--bg-elevated);
    transform: translateY(-3px);
    box-shadow: var(--shadow-md);
    text-decoration: none;
    color: var(--text-primary);
}
.podcast-name {
    font-size: var(--text-md);
    font-weight: 700;
    margin-bottom: var(--space-1);
    color: var(--text-primary);
    letter-spacing: -0.01em;
}
.podcast-slug {
    font-size: var(--text-sm);
    color: var(--text-faint);
    font-family: var(--font-mono);
    margin-bottom: var(--space-3);
}
.podcast-stats {
    font-size: var(--text-sm);
    color: var(--text-muted);
}

/* Podcast selector search filter */
.selector-search {
    margin-top: var(--space-5);
    position: relative;
}
.selector-search input {
    width: 100%;
    padding: var(--space-3) var(--space-4);
    padding-left: var(--space-8);
    background: var(--bg-inset);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    color: var(--text-primary);
    font-size: var(--text-base);
    font-family: var(--font-sans);
    transition: all var(--duration-fast) var(--ease-out);
}
.selector-search input:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--accent-muted);
}
.selector-search input::placeholder { color: var(--text-faint); }
.selector-search::before {
    content: '⌕';
    position: absolute;
    left: var(--space-4);
    top: 50%;
    transform: translateY(-50%);
    color: var(--text-faint);
    font-size: var(--text-md);
    pointer-events: none;
}

/* ── Error Banner ── */
.error-banner {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
    background: var(--bg-elevated);
    border: 1px solid var(--red);
    border-left: 4px solid var(--red);
    border-radius: var(--radius);
    margin-bottom: var(--space-4);
    font-size: var(--text-sm);
    color: var(--red);
    box-shadow: var(--shadow-md);
    animation: toastIn var(--duration-normal) var(--ease-out);
}
.error-banner .btn { color: var(--text-body); }

/* ── Audio Seekbar ── */
.audio-seekbar {
    flex: 1;
    height: 8px;
    background: var(--bg-inset);
    border-radius: var(--radius-full);
    cursor: pointer;
    position: relative;
    min-width: 80px;
    transition: height var(--duration-fast) var(--ease-out);
}
.audio-seekbar:hover { height: 10px; }
.audio-seekbar-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--accent), var(--accent-hover));
    border-radius: var(--radius-full);
    pointer-events: none;
    width: 0%;
    transition: width 0.1s linear;
    position: relative;
}
.audio-seekbar-fill::after {
    content: '';
    position: absolute;
    right: -5px;
    top: 50%;
    transform: translateY(-50%);
    width: 12px;
    height: 12px;
    background: var(--accent-hover);
    border-radius: var(--radius-full);
    box-shadow: 0 0 6px rgba(91, 156, 245, 0.4);
    opacity: 0;
    transition: opacity var(--duration-fast) var(--ease-out);
}
.audio-seekbar:hover .audio-seekbar-fill::after { opacity: 1; }

.audio-close {
    background: none;
    border: none;
    color: var(--text-faint);
    font-size: 18px;
    cursor: pointer;
    padding: 0 var(--space-2);
    line-height: 1;
    transition: color var(--duration-fast) var(--ease-out);
}
.audio-close:hover { color: var(--text-primary); }

/* ── Active Excerpt Highlight ── */
.excerpt.active-excerpt {
    background: var(--accent-muted);
    border-radius: var(--radius);
    outline: 1px solid rgba(91, 156, 245, 0.25);
    padding: var(--space-2);
    margin: -4px -8px;
}

/* ── Loading Skeletons ── */
.skeleton {
    background: var(--bg-elevated);
    border-radius: var(--radius);
    animation: skeleton-pulse 1.5s ease-in-out infinite;
}
.skeleton-row { height: 48px; margin-bottom: var(--space-1); }
.skeleton-card { height: 180px; margin-bottom: var(--space-4); }

/* ── Styled Confirm Dialog ── */
.confirm-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.55);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    z-index: 500;
    display: flex;
    align-items: center;
    justify-content: center;
    animation: fadeIn var(--duration-fast) var(--ease-out);
}
.confirm-dialog {
    background: var(--bg-elevated);
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-xl);
    padding: var(--space-6);
    max-width: 420px;
    width: 90%;
    box-shadow: var(--shadow-lg);
    animation: slideUp var(--duration-normal) var(--ease-out);
}
.confirm-dialog h3 { margin-bottom: var(--space-3); color: var(--text-primary); font-size: var(--text-md); }
.confirm-dialog p { color: var(--text-muted); margin-bottom: var(--space-4); font-size: var(--text-sm); line-height: 1.6; }
.confirm-actions { display: flex; gap: var(--space-3); justify-content: flex-end; }

/* ── Completion State ── */
.completion-state {
    text-align: center;
    padding: var(--space-8) var(--space-5);
    background: var(--bg-surface);
    border: 1px solid var(--green);
    border-radius: var(--radius-lg);
    margin-bottom: var(--space-5);
    box-shadow: 0 0 24px var(--green-muted);
    animation: slideUp var(--duration-normal) var(--ease-out);
}
.completion-state h2 { color: var(--green); margin-bottom: var(--space-2); font-size: var(--text-lg); }
.completion-state p { color: var(--text-muted); }

/* ── Batch Actions ── */
.batch-actions {
    display: flex;
    gap: var(--space-2);
    flex-wrap: wrap;
    align-items: center;
    margin-bottom: var(--space-3);
}
.batch-actions .batch-label {
    font-size: var(--text-sm);
    color: var(--text-faint);
    margin-right: var(--space-1);
    font-weight: 500;
}

/* ── Quick Assign Banner (Dashboard) ── */
.quick-assign-banner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    padding: var(--space-4) var(--space-5);
    background: linear-gradient(135deg, rgba(188, 140, 255, 0.08), rgba(91, 156, 245, 0.06));
    border: 1px solid rgba(188, 140, 255, 0.25);
    border-radius: var(--radius-lg);
    margin-bottom: var(--space-4);
    animation: slideUp var(--duration-normal) var(--ease-out);
}
.qa-banner-text {
    font-size: var(--text-sm);
    color: var(--text-body);
}
.qa-banner-text strong { color: var(--purple); }

/* ── Quick Assign Page ── */
.qa-page { max-width: 600px; margin: 0 auto; }
.qa-header { margin-bottom: var(--space-5); }
.qa-header h1 { font-size: var(--text-lg); margin: var(--space-2) 0 var(--space-1); color: var(--text-primary); }
.qa-subtitle { font-size: var(--text-sm); color: var(--text-muted); }

.qa-progress { margin-bottom: var(--space-4); }
.qa-progress-bar {
    height: 6px;
    background: var(--bg-inset);
    border-radius: var(--radius-full);
    overflow: hidden;
    margin-top: var(--space-2);
}
.qa-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--green), #4cc95f);
    border-radius: var(--radius-full);
    transition: width 0.3s var(--ease-out);
}
#qa-progress-text {
    font-size: var(--text-sm);
    color: var(--text-muted);
    font-family: var(--font-mono);
}

.qa-card-container { min-height: 240px; }

.qa-card {
    background: var(--bg-surface);
    border: none;
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-md);
    animation: slideUp var(--duration-normal) var(--ease-out);
}
.qa-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-3) var(--space-4);
    border-bottom: 1px solid var(--border);
    font-size: var(--text-sm);
    color: var(--text-muted);
}
.qa-cluster-id { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--text-faint); }
.qa-ep-count { font-size: var(--text-sm); }

.qa-card-body {
    padding: var(--space-7) var(--space-4);
    text-align: center;
}
.qa-question {
    font-size: var(--text-md);
    margin-bottom: var(--space-2);
    color: var(--text-body);
}
.qa-suggested-name {
    color: var(--accent);
    font-size: var(--text-2xl);
    font-weight: 700;
    letter-spacing: -0.02em;
}
.qa-confidence {
    font-size: var(--text-sm);
    color: var(--text-faint);
    font-family: var(--font-mono);
}
.qa-multi-name-warning {
    background: var(--yellow-muted);
    border: 1px solid rgba(210, 153, 34, 0.3);
    border-radius: var(--radius);
    padding: var(--space-3);
    margin-bottom: var(--space-3);
    font-size: var(--text-sm);
    color: var(--yellow);
}

.qa-excerpt-area {
    text-align: center;
    padding: var(--space-2) var(--space-4) var(--space-4);
}
.qa-play-btn { font-size: var(--text-sm); }

.qa-verdict-row {
    display: flex;
    gap: var(--space-3);
    padding: var(--space-4);
    border-top: 1px solid var(--border);
    justify-content: center;
}
.qa-btn { flex: 1; justify-content: center; font-size: var(--text-base); padding: var(--space-3) var(--space-4); }

.qa-name-input {
    padding: var(--space-3) var(--space-4) var(--space-4);
    border-top: 1px solid var(--border);
}
.qa-name-input label {
    font-size: var(--text-sm);
    color: var(--text-muted);
    display: block;
    margin-bottom: var(--space-2);
}
.qa-name-input input {
    width: 100%;
    padding: var(--space-2) var(--space-3);
    background: var(--bg-inset);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    color: var(--text-primary);
    font-size: var(--text-sm);
    font-family: var(--font-sans);
    margin-bottom: var(--space-2);
    transition: all var(--duration-fast) var(--ease-out);
}
.qa-name-input input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-muted); }
.qa-name-actions {
    display: flex;
    align-items: center;
    gap: var(--space-3);
}
.qa-deep-review {
    font-size: var(--text-sm);
    color: var(--text-muted);
}

/* ── Two-Panel Review Layout ── */
.review-two-panel {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: var(--space-5);
    margin-bottom: var(--space-6);
}
.review-evidence-panel {
    overflow-y: auto;
    max-height: calc(100vh - 200px);
}
.review-decision-panel {
    position: sticky;
    top: 72px;
    align-self: start;
    max-height: calc(100vh - 100px);
    overflow-y: auto;
    background: var(--bg-surface);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    box-shadow: var(--shadow-md);
}

/* Member checkboxes */
.member-checkbox-row {
    display: flex;
    align-items: flex-start;
    gap: var(--space-2);
    padding: var(--space-1) 0;
}
.member-checkbox {
    margin-top: var(--space-1);
    cursor: pointer;
    width: 16px;
    height: 16px;
    accent-color: var(--accent);
}
.selection-summary {
    font-size: var(--text-sm);
    color: var(--yellow);
    padding: var(--space-2) var(--space-3);
    background: var(--yellow-muted);
    border-radius: var(--radius);
    margin-bottom: var(--space-2);
    border-left: 3px solid var(--yellow);
}
.selection-actions { display: flex; gap: var(--space-2); margin-bottom: var(--space-2); }

/* Suggested name chips in decision panel */
.suggested-names-section { margin-bottom: var(--space-3); }
.suggested-names-section h4 {
    font-size: var(--text-xs);
    color: var(--text-faint);
    margin-bottom: var(--space-2);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 600;
}
.suggested-name-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    padding: var(--space-1) var(--space-3);
    background: var(--purple-muted);
    border: none;
    border-radius: var(--radius-full);
    color: var(--purple);
    cursor: pointer;
    font-size: var(--text-sm);
    font-family: var(--font-sans);
    margin: 2px 4px 2px 0;
    transition: all var(--duration-fast) var(--ease-out);
    font-weight: 500;
}
.suggested-name-btn:hover {
    background: rgba(188, 140, 255, 0.22);
    transform: translateY(-1px);
}
.suggested-name-btn .sn-count {
    font-size: var(--text-xs);
    opacity: 0.6;
    font-family: var(--font-mono);
}

/* Mini timeline bar */
.mini-timeline {
    height: 8px;
    background: var(--bg-inset);
    border-radius: var(--radius-full);
    overflow: hidden;
    position: relative;
    margin: var(--space-2) 0;
}
.mini-timeline-chunk {
    position: absolute;
    top: 0;
    height: 100%;
    border-radius: 2px;
    opacity: 0.7;
}

/* ── Triage Page ── */
.triage-controls {
    display: flex;
    gap: 0;
    flex-wrap: wrap;
    align-items: center;
    margin-bottom: var(--space-3);
    background: var(--bg-surface);
    border-radius: var(--radius);
    overflow: hidden;
    width: fit-content;
}
.triage-controls .btn {
    border-radius: 0;
    border: none;
    background: var(--bg-surface);
    color: var(--text-muted);
    font-weight: 500;
    padding: var(--space-2) var(--space-4);
}
.triage-controls .btn:hover { background: var(--bg-elevated); color: var(--text-primary); transform: none; box-shadow: none; }
.triage-controls .btn.active { background: var(--accent); color: var(--bg-base); }
.triage-controls .btn:first-child { border-radius: var(--radius) 0 0 var(--radius); }
.triage-controls .btn:last-child { border-radius: 0 var(--radius) var(--radius) 0; }

.triage-bulk-bar {
    display: flex;
    gap: var(--space-2);
    align-items: center;
    padding: var(--space-3) var(--space-4);
    background: var(--bg-surface);
    border: none;
    border-radius: var(--radius);
    margin-bottom: var(--space-3);
    box-shadow: var(--shadow-sm);
    animation: slideUp var(--duration-fast) var(--ease-out);
}
.triage-bulk-bar .bulk-count {
    font-size: var(--text-sm);
    color: var(--text-muted);
    margin-right: auto;
    font-weight: 500;
}

.triage-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--text-sm);
}
.triage-table thead th {
    text-align: left;
    padding: var(--space-2) var(--space-3);
    border-bottom: 2px solid var(--border-strong);
    color: var(--text-faint);
    font-size: var(--text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    position: sticky;
    top: 48px;
    background: var(--bg-base);
    z-index: 10;
}
.triage-table tbody tr {
    border-bottom: none;
    transition: background var(--duration-fast) var(--ease-out), opacity 0.3s var(--ease-out);
}
.triage-table tbody tr:nth-child(even) { background: rgba(20, 24, 32, 0.5); }
.triage-table tbody tr:hover { background: var(--bg-elevated); }
.triage-table td { padding: var(--space-2) var(--space-3); vertical-align: middle; }
.triage-table td input[type="checkbox"] { accent-color: var(--accent); cursor: pointer; }

.triage-row.verified { opacity: 0.35; }
.triage-row.verified td { text-decoration: line-through; text-decoration-color: var(--text-faint); }

.triage-name { font-weight: 600; max-width: 200px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--text-primary); }
.triage-inline-play {
    background: var(--bg-elevated);
    border: none;
    border-radius: var(--radius-sm);
    color: var(--text-muted);
    cursor: pointer;
    padding: var(--space-1) var(--space-2);
    font-size: var(--text-xs);
    transition: all var(--duration-fast) var(--ease-out);
}
.triage-inline-play:hover { background: var(--accent-muted); color: var(--accent); }
.triage-actions { display: flex; gap: var(--space-1); }
.triage-actions .btn { font-size: var(--text-xs); padding: 3px var(--space-2); }

/* Suggestion hint in queue rows */
.suggestion-hint {
    font-size: var(--text-xs);
    color: var(--purple);
    margin-left: var(--space-2);
    white-space: nowrap;
    opacity: 0.8;
}

/* ── Hero Section (Dashboard) ── */
.hero-section {
    display: flex;
    align-items: center;
    gap: var(--space-6);
    padding: var(--space-6);
    background: linear-gradient(135deg, var(--bg-surface), var(--bg-elevated));
    border: none;
    border-radius: var(--radius-xl);
    margin-bottom: var(--space-5);
    box-shadow: var(--shadow-md);
    animation: slideUp var(--duration-slow) var(--ease-out);
}
.hero-cta { flex: 1; }
.hero-cta h2 { font-size: var(--text-md); margin-bottom: var(--space-2); color: var(--text-primary); letter-spacing: -0.01em; }
.hero-cta p { color: var(--text-muted); font-size: var(--text-sm); margin-bottom: var(--space-4); }

.progress-ring-container {
    flex-shrink: 0;
    width: 120px;
    height: 120px;
    position: relative;
    animation: ringGlow 3s ease-in-out infinite;
}
.progress-ring-container svg { width: 100%; height: 100%; }
.progress-ring-text {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: var(--text-md);
    font-weight: 700;
    color: var(--text-primary);
}

/* Sort toggle */
.sort-toggle {
    display: inline-flex;
    border: none;
    border-radius: var(--radius);
    overflow: hidden;
    background: var(--bg-surface);
}
.sort-toggle button {
    background: var(--bg-surface);
    border: none;
    color: var(--text-muted);
    padding: var(--space-1) var(--space-3);
    font-size: var(--text-xs);
    font-family: var(--font-sans);
    cursor: pointer;
    transition: all var(--duration-fast) var(--ease-out);
    font-weight: 500;
}
.sort-toggle button:hover { background: var(--bg-elevated); color: var(--text-primary); }
.sort-toggle button.active { background: var(--accent); color: var(--bg-base); }

/* Collapsible sections */
.collapsible-header {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    cursor: pointer;
    user-select: none;
    padding: var(--space-2) 0;
    transition: color var(--duration-fast) var(--ease-out);
}
.collapsible-header:hover { color: var(--text-primary); }
.collapsible-header h2 { font-size: var(--text-base); color: var(--text-primary); font-weight: 600; }
.collapsible-arrow {
    transition: transform 0.2s var(--ease-out);
    font-size: var(--text-xs);
    color: var(--text-faint);
}
.collapsible-header.collapsed .collapsible-arrow { transform: rotate(-90deg); }
.collapsible-content { overflow: hidden; transition: max-height 0.3s var(--ease-out); }
.collapsible-content.collapsed { max-height: 0 !important; overflow: hidden; }

/* ── Session stats (nav bar) ── */
.session-stats {
    font-size: var(--text-xs);
    color: var(--green);
    font-weight: 600;
    white-space: nowrap;
    font-family: var(--font-mono);
}

/* ── Triage feedback indicators ── */
.triage-status-ok { color: var(--green); font-size: var(--text-xs); font-weight: 600; }
.triage-status-err { color: var(--red); font-size: var(--text-xs); font-weight: 600; }
.triage-session-count { color: var(--green); font-weight: 600; }
.triage-page-actions { display: flex; gap: var(--space-2); margin-bottom: var(--space-3); }

/* ── Split indicator ── */
.verdict-buttons button small { font-size: 10px; opacity: 0.8; }

/* ── Login Page ── */
.login-wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100vh;
    background: var(--bg-base);
    position: relative;
    overflow: hidden;
}
.login-wrapper::before {
    content: '';
    position: absolute;
    top: 30%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 600px;
    height: 600px;
    background: radial-gradient(circle, rgba(91, 156, 245, 0.08) 0%, transparent 70%);
    pointer-events: none;
}
.login-card {
    background: var(--bg-surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-xl);
    padding: var(--space-8);
    width: 100%;
    max-width: 380px;
    box-shadow: var(--shadow-lg);
    animation: slideUp var(--duration-slow) var(--ease-out);
    position: relative;
}
.login-card h1 {
    font-size: var(--text-md);
    margin-bottom: var(--space-6);
    text-align: center;
    color: var(--text-primary);
    letter-spacing: -0.01em;
}
.login-card label {
    display: block;
    font-size: var(--text-sm);
    color: var(--text-muted);
    margin-bottom: var(--space-1);
    font-weight: 500;
}
.login-card input[type="text"],
.login-card input[type="password"] {
    width: 100%;
    padding: var(--space-3) var(--space-4);
    background: var(--bg-inset);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    color: var(--text-primary);
    font-size: var(--text-sm);
    font-family: var(--font-sans);
    margin-bottom: var(--space-4);
    transition: all var(--duration-fast) var(--ease-out);
}
.login-card input:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--accent-muted);
}
.login-card .btn {
    width: 100%;
    justify-content: center;
    padding: var(--space-3);
    font-size: var(--text-sm);
    font-weight: 600;
}
.login-error {
    background: var(--red-muted);
    border: 1px solid rgba(248, 81, 73, 0.3);
    color: var(--red);
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius);
    font-size: var(--text-sm);
    margin-bottom: var(--space-4);
}

/* ── Responsive ── */
@media (max-width: 900px) {
    .review-two-panel {
        grid-template-columns: 1fr;
    }
    .review-decision-panel {
        position: static;
        max-height: none;
        border-radius: var(--radius-lg);
        box-shadow: var(--shadow-lg);
        margin-top: var(--space-4);
    }
    .review-evidence-panel {
        max-height: none;
    }
}

@media (max-width: 600px) {
    .hero-section {
        flex-direction: column;
        text-align: center;
        gap: var(--space-4);
        padding: var(--space-4);
    }
    .progress-ring-container {
        width: 80px;
        height: 80px;
    }
    .progress-ring-text {
        font-size: var(--text-sm);
    }
    .topbar {
        flex-wrap: wrap;
        gap: var(--space-2);
        padding: var(--space-2) var(--space-3);
    }
    .nav-links {
        flex-wrap: wrap;
        gap: var(--space-1);
        width: 100%;
        justify-content: center;
    }
    .container {
        padding: var(--space-3);
    }
    .filter-bar {
        flex-wrap: wrap;
    }
    .qa-page {
        max-width: 100%;
    }
    .review-title-row h1 {
        font-size: var(--text-md);
    }
    .audio-bar {
        padding: var(--space-2) var(--space-3);
    }
    .audio-bar-inner {
        gap: var(--space-2);
    }
    .audio-ep-title {
        display: none;
    }
    /* Triage: card-ish layout */
    .triage-table thead { display: none; }
    .triage-table, .triage-table tbody, .triage-table tr, .triage-table td {
        display: block;
    }
    .triage-table tr {
        background: var(--bg-surface);
        border-radius: var(--radius);
        padding: var(--space-3);
        margin-bottom: var(--space-2);
        box-shadow: var(--shadow-sm);
    }
    .triage-table td {
        padding: var(--space-1) 0;
        text-align: left;
    }
    .triage-table td::before {
        content: attr(data-label);
        display: inline-block;
        font-size: var(--text-xs);
        color: var(--text-faint);
        text-transform: uppercase;
        margin-right: var(--space-2);
        min-width: 60px;
    }
    .triage-actions {
        justify-content: flex-start;
        margin-top: var(--space-2);
    }
    .verdict-buttons {
        flex-direction: column;
    }
    .verdict-buttons .btn {
        width: 100%;
        justify-content: center;
    }
}

/* ── Scrollbar Styling ── */
::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}
::-webkit-scrollbar-track {
    background: var(--bg-inset);
}
::-webkit-scrollbar-thumb {
    background: var(--border-strong);
    border-radius: var(--radius-full);
}
::-webkit-scrollbar-thumb:hover {
    background: var(--text-faint);
}

/* ── Focus visible for accessibility ── */
:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
}
button:focus:not(:focus-visible),
a:focus:not(:focus-visible),
input:focus:not(:focus-visible) {
    outline: none;
}
