:root{--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-tertiary:#f1f5f9;--bg-sidebar:#0f172a;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--text-inverse:#f8fafc;--accent-primary:#2563eb;--accent-secondary:#3b82f6;--accent-light:#eff6ff;--accent-gradient:linear-gradient(135deg,#2563eb,#3b82f6);--border-color:#e2e8f0;--border-light:#f1f5f9;--success:#059669;--success-light:#ecfdf5;--warning:#d97706;--warning-light:#fffbeb;--danger:#dc2626;--danger-light:#fef2f2;--info:#0891b2;--info-light:#ecfeff;--shadow-sm:0 1px 2px #0f172a0a;--shadow-md:0 4px 6px -1px #0f172a14,0 2px 4px -2px #0f172a0a;--shadow-lg:0 10px 15px -3px #0f172a14,0 4px 6px -4px #0f172a0a;--shadow-xl:0 20px 25px -5px #0f172a1a,0 8px 10px -6px #0f172a0a;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--sidebar-width:240px;--header-height:64px;--floating-player-height:80px;--transition-fast:0.15s cubic-bezier(0.4,0,0.2,1);--transition-normal:0.25s cubic-bezier(0.4,0,0.2,1);--transition-slow:0.4s cubic-bezier(0.4,0,0.2,1)}[data-theme=dark]{--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-tertiary:#334155;--bg-sidebar:#0f172a;--text-primary:#f1f5f9;--text-secondary:#cbd5e1;--text-muted:#64748b;--text-inverse:#0f172a;--accent-primary:#3b82f6;--accent-secondary:#60a5fa;--accent-light:#1e3a5f;--border-color:#334155;--border-light:#1e293b;--success-light:#064e3b;--warning-light:#451a03;--danger-light:#450a0a;--info-light:#164e63;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 24px #00000080}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background:#f8fafc;background:var(--bg-primary);color:#0f172a;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;overflow-x:hidden}.app.has-floating-player{padding-bottom:80px;padding-bottom:var(--floating-player-height)}.app.has-floating-player .content{padding-bottom:104px;padding-bottom:calc(var(--floating-player-height) + 24px)}.app{background:#f8fafc;background:var(--bg-primary);display:flex;min-height:100vh}.sidebar{background:#0f172a;background:var(--bg-sidebar);display:flex;flex-direction:column;height:100vh;left:0;position:fixed;top:0;transition:transform .25s cubic-bezier(.4,0,.2,1);transition:transform var(--transition-normal);width:240px;width:var(--sidebar-width);z-index:100}.sidebar-brand{border-bottom:1px solid #ffffff0f;gap:12px;padding:20px}.brand-icon,.sidebar-brand{align-items:center;display:flex}.brand-icon{background:linear-gradient(135deg,#2563eb,#3b82f6);background:var(--accent-gradient);border-radius:12px;border-radius:var(--radius-md);color:#fff;flex-shrink:0;height:38px;justify-content:center;width:38px}.brand-icon svg{height:18px;width:18px}.brand-text{color:#f8fafc;color:var(--text-inverse);font-size:1rem;font-weight:600;letter-spacing:-.01em}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:2px;padding:12px}.nav-item{align-items:center;background:#0000;border:none;border-radius:12px;border-radius:var(--radius-md);color:#ffffff80;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:10px;padding:11px 14px;text-align:left;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast);width:100%}.nav-item:hover{background:#ffffff0d;color:#ffffffd9}.nav-item.active{background:linear-gradient(135deg,#2563eb,#3b82f6);background:var(--accent-gradient);box-shadow:0 2px 8px #8b5a2b40;color:#fff}.nav-icon{align-items:center;display:flex;justify-content:center}.nav-icon,.nav-icon svg{height:18px;width:18px}.sidebar-footer{border-top:1px solid #ffffff0f;padding:12px}.theme-btn{align-items:center;background:#ffffff08;border:none;border-radius:12px;border-radius:var(--radius-md);color:#ffffff80;cursor:pointer;display:flex;font-size:.8125rem;gap:10px;padding:10px 14px;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast);width:100%}.theme-btn:hover{background:#ffffff0f;color:#ffffffd9}.theme-btn svg{height:16px;width:16px}.overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;bottom:0;display:none;left:0;position:fixed;right:0;top:0;z-index:99}.main{background:#f8fafc;background:var(--bg-primary);display:flex;flex:1 1;flex-direction:column;margin-left:240px;margin-left:var(--sidebar-width);min-height:100vh}.header{background:#fff;background:var(--bg-secondary);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);display:flex;gap:16px;height:64px;height:var(--header-height);padding:0 24px;position:-webkit-sticky;position:sticky;top:0;z-index:50}.header,.menu-btn{align-items:center}.menu-btn{background:#0000;border:none;border-radius:12px;border-radius:var(--radius-md);color:#0f172a;color:var(--text-primary);cursor:pointer;display:none;height:40px;justify-content:center;width:40px}.menu-btn svg{height:22px;width:22px}.header-title{flex:1 1}.header-title h1{color:#0f172a;color:var(--text-primary);font-size:1.25rem;font-weight:600;letter-spacing:-.01em}.header-title span{color:#94a3b8;color:var(--text-muted);font-size:.8125rem;font-weight:400}.theme-btn-mobile{align-items:center;background:#fff;background:var(--bg-secondary);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--radius-md);color:#475569;color:var(--text-secondary);cursor:pointer;display:none;height:38px;justify-content:center;width:38px}.theme-btn-mobile svg{height:18px;width:18px}.content{flex:1 1;padding:24px}.stats-cards{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:20px}.stat-card{align-items:center;background:#fff;background:var(--bg-secondary);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);display:flex;gap:14px;padding:18px;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast)}.stat-card:hover{box-shadow:0 4px 6px -1px #0f172a14,0 2px 4px -2px #0f172a0a;box-shadow:var(--shadow-md)}.stat-icon{align-items:center;background:#f1f5f9;background:var(--bg-tertiary);border-radius:12px;border-radius:var(--radius-md);color:#475569;color:var(--text-secondary);display:flex;flex-shrink:0;height:44px;justify-content:center;width:44px}.stat-icon svg{height:20px;width:20px}.stat-card.accent .stat-icon{background:#eff6ff;background:var(--accent-light);color:#2563eb;color:var(--accent-primary)}.stat-card.success .stat-icon{background:#ecfdf5;background:var(--success-light);color:#059669;color:var(--success)}.stat-card.warning .stat-icon{background:#fffbeb;background:var(--warning-light);color:#d97706;color:var(--warning)}.stat-card.danger .stat-icon{background:#fef2f2;background:var(--danger-light);color:#dc2626;color:var(--danger)}.stat-content{display:flex;flex:1 1;flex-direction:column}.stat-value{color:#0f172a;color:var(--text-primary);font-size:1.5rem;font-weight:700;line-height:1.2}.stat-label{color:#94a3b8;color:var(--text-muted);font-size:.75rem;font-weight:500;margin-top:2px}.filters-bar{align-items:center;border-radius:16px;border-radius:var(--radius-lg);display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px;padding:14px 18px}.filter-select,.filters-bar{background:#fff;background:var(--bg-secondary);border:1px solid #e2e8f0;border:1px solid var(--border-color)}.filter-select{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%238A8580' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;border-radius:12px;border-radius:var(--radius-md);color:#0f172a;color:var(--text-primary);cursor:pointer;font-size:.8125rem;font-weight:500;min-width:140px;padding:9px 32px 9px 12px;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast)}.filter-select:focus,.filter-select:hover{border-color:#2563eb;border-color:var(--accent-primary);outline:none}.filter-range{align-items:center;display:flex;gap:6px}.filter-range input{background:#fff;background:var(--bg-secondary);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--radius-md);color:#0f172a;color:var(--text-primary);font-size:.8125rem;padding:9px 10px;text-align:center;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast);width:60px}.filter-range input:focus{border-color:#2563eb;border-color:var(--accent-primary);outline:none}.filter-range span{color:#94a3b8;color:var(--text-muted);font-size:.8125rem}.filter-checkbox{align-items:center;background:#fff;background:var(--bg-secondary);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--radius-md);color:#475569;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.8125rem;font-weight:500;gap:8px;padding:9px 14px;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast);-webkit-user-select:none;user-select:none}.filter-checkbox:hover{border-color:#2563eb;border-color:var(--accent-primary)}.filter-checkbox:has(input:checked){background:#eff6ff;background:var(--accent-light);border-color:#2563eb;border-color:var(--accent-primary);color:#2563eb;color:var(--accent-primary)}.filter-checkbox input{display:none}.filter-checkbox .checkmark{align-items:center;border:2px solid #e2e8f0;border:2px solid var(--border-color);border-radius:4px;display:flex;flex-shrink:0;height:16px;justify-content:center;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast);width:16px}.filter-checkbox input:checked+.checkmark{background:#2563eb;background:var(--accent-primary);border-color:#2563eb;border-color:var(--accent-primary)}.filter-checkbox input:checked+.checkmark:after{border:solid #fff;border-width:0 2px 2px 0;content:"";height:8px;margin-bottom:2px;transform:rotate(45deg);width:4px}.section-recordings,.section-reports,.section-stats{animation:fadeIn .3s ease}.recordings-list-container{background:#fff;background:var(--bg-secondary);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);overflow:hidden}.recordings-list-container h3{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);color:#0f172a;color:var(--text-primary);font-size:.9375rem;font-weight:600;margin:0;padding:14px 18px}.recordings-list{display:flex;flex-direction:column}.recording-row{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);cursor:pointer;display:flex;gap:14px;padding:14px 18px;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast)}.recording-row:last-child{border-bottom:none}.recording-row:hover{background:#f1f5f9;background:var(--bg-tertiary)}.recording-row.needs-review{border-left:3px solid #d97706;border-left:3px solid var(--warning);padding-left:15px}.recording-icon{align-items:center;background:#f1f5f9;background:var(--bg-tertiary);border-radius:12px;border-radius:var(--radius-md);color:#94a3b8;color:var(--text-muted);display:flex;flex-shrink:0;height:38px;justify-content:center;width:38px}.recording-icon svg{height:18px;width:18px}.recording-info{flex:1 1;min-width:0}.recording-title{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:3px}.agent-tag{background:#eff6ff;background:var(--accent-light);border-radius:8px;border-radius:var(--radius-sm);color:#2563eb;color:var(--accent-primary);font-size:.8125rem;font-weight:700;letter-spacing:-.01em;padding:4px 10px;text-transform:capitalize}.recording-datetime{color:#0f172a;color:var(--text-primary);font-size:.875rem;font-weight:500}.recording-meta{align-items:center;color:#94a3b8;color:var(--text-muted);display:flex;font-size:.75rem;gap:10px}.recording-meta span{align-items:center;display:flex;gap:4px}.recording-meta svg{height:12px;width:12px}.recording-duration{align-items:center;color:#94a3b8;color:var(--text-muted);display:inline-flex;font-size:.75rem;font-weight:400;gap:4px}.recording-duration svg{height:12px;width:12px}.recording-summary{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#475569;color:var(--text-secondary);display:-webkit-box;font-size:.8125rem;line-height:1.4;margin-top:4px;overflow:hidden;text-overflow:ellipsis}.recording-score{flex-shrink:0}.score-badge{align-items:center;border-radius:12px;border-radius:var(--radius-md);display:inline-flex;font-size:.875rem;font-weight:700;justify-content:center;min-width:40px;padding:5px 10px}.score-badge.high{background:#ecfdf5;background:var(--success-light);color:#059669;color:var(--success)}.score-badge.medium{background:#fffbeb;background:var(--warning-light);color:#d97706;color:var(--warning)}.score-badge.low{background:#fef2f2;background:var(--danger-light);color:#dc2626;color:var(--danger)}.score-badge.pending{background:#f1f5f9;background:var(--bg-tertiary);color:#94a3b8;color:var(--text-muted)}.review-flag{color:#d97706;color:var(--warning);flex-shrink:0}.review-flag svg{height:18px;width:18px}.recording-action{align-items:center;color:#94a3b8;color:var(--text-muted);display:flex;flex-shrink:0;height:32px;justify-content:center;margin-left:8px;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast);width:32px}.recording-action svg{height:18px;width:18px}.recording-row:hover .recording-action{color:#2563eb;color:var(--accent-primary);transform:translateX(3px)}.recording-play-btn{align-items:center;background:#eff6ff;background:var(--accent-light);border:none;border-radius:50%;color:#2563eb;color:var(--accent-primary);cursor:pointer;display:flex;flex-shrink:0;height:36px;justify-content:center;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast);width:36px}.recording-play-btn svg{height:14px;width:14px}.recording-play-btn:hover{background:#2563eb;background:var(--accent-primary);color:#fff;transform:scale(1.1)}.stats-section{margin-top:24px}.stats-section h3{color:#0f172a;color:var(--text-primary);font-size:1rem;font-weight:600;margin-bottom:14px}.stats-section h3 .subtitle{color:#94a3b8;color:var(--text-muted);font-size:.8125rem;font-weight:400;margin-left:8px}.agents-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.agent-card{align-items:center;background:#fff;background:var(--bg-secondary);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);cursor:pointer;display:flex;gap:14px;padding:16px;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast)}.agent-card:hover{box-shadow:0 4px 6px -1px #0f172a14,0 2px 4px -2px #0f172a0a;box-shadow:var(--shadow-md)}.agent-avatar{align-items:center;background:linear-gradient(135deg,#2563eb,#3b82f6);background:var(--accent-gradient);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:1rem;font-weight:600;height:42px;justify-content:center;width:42px}.agent-info{flex:1 1;min-width:0}.agent-info h4{color:#0f172a;color:var(--text-primary);font-size:1.125rem;font-weight:700;letter-spacing:-.01em;margin:0 0 4px;text-transform:capitalize}.agent-stats{color:#94a3b8;color:var(--text-muted);font-size:.75rem}.agent-stats .flagged{color:#d97706;color:var(--warning)}.agent-score{border-radius:12px;border-radius:var(--radius-md);flex-shrink:0;font-size:1rem;font-weight:700;min-width:40px;padding:6px 10px;text-align:center}.agent-score.high{background:#ecfdf5;background:var(--success-light);color:#059669;color:var(--success)}.agent-score.medium{background:#fffbeb;background:var(--warning-light);color:#d97706;color:var(--warning)}.agent-score.low{background:#fef2f2;background:var(--danger-light);color:#dc2626;color:var(--danger)}.daily-table{background:#fff;background:var(--bg-secondary);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);overflow:hidden}.daily-table table{border-collapse:collapse;width:100%}.daily-table th{background:#f1f5f9;background:var(--bg-tertiary);color:#94a3b8;color:var(--text-muted);font-size:.6875rem;font-weight:600;letter-spacing:.04em;text-align:left;text-transform:uppercase}.daily-table td,.daily-table th{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);padding:12px 16px}.daily-table td{color:#0f172a;color:var(--text-primary);font-size:.875rem}.daily-table tr:last-child td{border-bottom:none}.daily-table tr:hover td{background:#f1f5f9;background:var(--bg-tertiary)}.score-pill{border-radius:8px;border-radius:var(--radius-sm);display:inline-block;font-size:.8125rem;font-weight:600;padding:3px 8px}.score-pill.high{background:#ecfdf5;background:var(--success-light);color:#059669;color:var(--success)}.score-pill.medium{background:#fffbeb;background:var(--warning-light);color:#d97706;color:var(--warning)}.score-pill.low{background:#fef2f2;background:var(--danger-light);color:#dc2626;color:var(--danger)}.empty-state{padding:50px 30px;text-align:center}.empty-state.small{padding:30px 16px}.empty-icon{color:#94a3b8;color:var(--text-muted);height:56px;margin:0 auto 14px;opacity:.4;width:56px}.empty-icon svg{height:100%;width:100%}.empty-state h4{color:#0f172a;color:var(--text-primary);font-size:1rem;font-weight:600;margin-bottom:6px}.empty-state p,.loading-state{color:#94a3b8;color:var(--text-muted);font-size:.875rem}.loading-state{align-items:center;display:flex;flex-direction:column;gap:14px;justify-content:center;padding:50px}.spinner{animation:spin .8s linear infinite;border:2px solid #e2e8f0;border-top-color:#2563eb;border:2px solid var(--border-color);border-radius:50%;border-top-color:var(--accent-primary);height:32px;width:32px}@keyframes spin{to{transform:rotate(1turn)}}.coming-soon{background:#fff;background:var(--bg-secondary);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);padding:80px 40px;text-align:center}.coming-soon-icon{color:#2563eb;color:var(--accent-primary);height:80px;margin:0 auto 24px;opacity:.5;width:80px}.coming-soon-icon svg{height:100%;width:100%}.coming-soon h3{color:#0f172a;color:var(--text-primary);font-size:1.5rem;font-weight:700;margin-bottom:12px}.coming-soon p{color:#94a3b8;color:var(--text-muted);font-size:1rem;margin-bottom:8px}.coming-soon ul{list-style:none;margin-top:20px}.coming-soon li{color:#475569;color:var(--text-secondary);font-size:.9375rem;padding:8px 0}.coming-soon li:before{color:#2563eb;color:var(--accent-primary);content:"•";margin-right:8px}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal{animation:modalIn .3s ease;background:#fff;background:var(--bg-secondary);border-radius:24px;border-radius:var(--radius-xl);display:flex;flex-direction:column;max-height:90vh;max-width:900px;overflow:hidden;position:relative;width:100%}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-close{align-items:center;background:#fff;background:var(--bg-secondary);border:none;border-radius:12px;border-radius:var(--radius-md);color:#94a3b8;color:var(--text-muted);cursor:pointer;display:flex;height:36px;justify-content:center;position:absolute;right:16px;top:16px;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast);width:36px;z-index:10}.modal-close svg{height:20px;width:20px}.modal-close:hover{background:#fef2f2;background:var(--danger-light);color:#dc2626;color:var(--danger)}.modal-header{align-items:flex-start;background:#f1f5f9;background:var(--bg-tertiary);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);display:flex;gap:20px;justify-content:space-between;padding:24px 28px}.modal-header-info h2{color:#0f172a;color:var(--text-primary);font-size:1.25rem;font-weight:700;margin-bottom:8px}.modal-header-meta{display:flex;flex-wrap:wrap;gap:12px}.modal-header-meta .meta-item{align-items:center;color:#475569;color:var(--text-secondary);display:flex;font-size:.875rem;gap:6px}.modal-header-meta .meta-item svg{color:#94a3b8;color:var(--text-muted);height:16px;width:16px}.modal-header-meta .meta-item.agent{color:#2563eb;color:var(--accent-primary)}.modal-header-score{align-items:center;border-radius:12px;border-radius:var(--radius-md);display:flex;flex-direction:column;flex-shrink:0;justify-content:center;padding:12px 20px}.modal-header-score.high{background:#ecfdf5;background:var(--success-light);color:#059669;color:var(--success)}.modal-header-score.medium{background:#fffbeb;background:var(--warning-light);color:#d97706;color:var(--warning)}.modal-header-score.low{background:#fef2f2;background:var(--danger-light);color:#dc2626;color:var(--danger)}.modal-header-score .score-number{font-size:2rem;font-weight:700;line-height:1}.modal-header-score .score-label{font-size:.6875rem;letter-spacing:.04em;margin-top:2px;text-transform:uppercase}.modal-player{background:#f1f5f9;background:var(--bg-tertiary);padding:20px 28px}.modal-player,.modal-review-actions{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color)}.modal-review-actions{align-items:center;background:#fffbeb;background:var(--warning-light);display:flex;gap:12px;padding:16px 28px}.review-label{color:#475569;color:var(--text-secondary);font-size:.875rem;font-weight:500;margin-right:auto}.review-btn{font-size:.875rem;padding:8px 16px}.review-btn svg{height:16px;width:16px}.review-btn.approve:hover{background:#047857}.review-btn.training:hover{background:#0369a1}.review-btn.reject:hover{background:#b91c1c}.modal-tabs{background:#fff;background:var(--bg-secondary);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);display:flex;gap:4px;padding:0 28px}.modal-tab{background:none;border:none;color:#94a3b8;color:var(--text-muted);cursor:pointer;font-size:.875rem;font-weight:500;padding:14px 20px;position:relative;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast)}.modal-tab:hover{color:#0f172a;color:var(--text-primary)}.modal-tab.active{color:#2563eb;color:var(--accent-primary)}.modal-tab.active:after{background:#2563eb;background:var(--accent-primary);bottom:-1px;content:"";height:2px;left:0;position:absolute;right:0}.modal-content{flex:1 1;overflow-y:auto;padding:24px 28px}.audio-player{display:flex;flex-direction:column;gap:16px}.audio-player-controls{gap:12px}.audio-btn,.audio-player-controls{align-items:center;display:flex;justify-content:center}.audio-btn{border:none;border-radius:50%;cursor:pointer;position:relative;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast)}.audio-btn.play{background:linear-gradient(135deg,#2563eb,#3b82f6);background:var(--accent-gradient);box-shadow:0 4px 12px #92400e4d;color:#fff;height:56px;width:56px}.audio-btn.play svg{height:24px;width:24px}.audio-btn.play:hover{transform:scale(1.05)}.audio-btn.skip{background:#f1f5f9;background:var(--bg-tertiary);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--radius-md);color:#475569;color:var(--text-secondary);height:38px;width:38px}.audio-btn.skip .skip-text{font-size:.75rem;font-weight:600}.audio-btn.skip:hover{border-color:#2563eb;border-color:var(--accent-primary)}.audio-btn.skip:hover,.audio-btn.speed{color:#2563eb;color:var(--accent-primary)}.audio-btn.speed{background:#eff6ff;background:var(--accent-light);border-radius:12px;border-radius:var(--radius-md);font-size:.8125rem;font-weight:700;height:44px;width:44px}.audio-btn.speed:hover{background:#2563eb;background:var(--accent-primary);color:#fff}.audio-player-progress{align-items:center;display:flex;gap:12px}.time-current,.time-duration{color:#94a3b8;color:var(--text-muted);font-size:.8125rem;font-weight:500;min-width:36px}.progress-track{background:#e2e8f0;background:var(--border-color);border-radius:3px;cursor:pointer;flex:1 1;height:6px;overflow:visible;position:relative}.progress-fill{background:linear-gradient(135deg,#2563eb,#3b82f6);background:var(--accent-gradient);border-radius:3px;height:100%;transition:width .1s}.utterance-marker{border-radius:2px;height:10px;opacity:.6;position:absolute;top:-2px;width:3px}.utterance-marker.speaker-A{background:#2563eb;background:var(--accent-primary)}.utterance-marker.speaker-B{background:#059669;background:var(--success)}.floating-player{align-items:center;animation:slideUpPlayer .3s ease;background:#fff;background:var(--bg-secondary);border-top:1px solid #e2e8f0;border-top:1px solid var(--border-color);bottom:0;box-shadow:0 -4px 20px #0f172a26;display:flex;gap:20px;height:80px;height:var(--floating-player-height);left:240px;left:var(--sidebar-width);padding:0 24px;position:fixed;right:0;transform:translateZ(0);will-change:transform;z-index:1000}@keyframes slideUpPlayer{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.floating-player-info{align-items:center;display:flex;gap:14px;max-width:280px;min-width:200px}.floating-player-avatar{align-items:center;background:linear-gradient(135deg,#2563eb,#3b82f6);background:var(--accent-gradient);border-radius:12px;border-radius:var(--radius-md);color:#fff;display:flex;flex-shrink:0;font-size:1.125rem;font-weight:700;height:48px;justify-content:center;width:48px}.floating-player-details{flex:1 1;min-width:0}.floating-player-agent{color:#0f172a;color:var(--text-primary);font-size:1rem;font-weight:700;margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;text-transform:capitalize;white-space:nowrap}.floating-player-meta{align-items:center;color:#94a3b8;color:var(--text-muted);display:flex;font-size:.75rem;gap:8px}.floating-player-meta svg{height:12px;width:12px}.floating-player-controls,.floating-player-progress{align-items:center;display:flex;gap:12px}.floating-player-progress{flex:1 1;max-width:600px}.floating-player-progress .progress-track{background:#f1f5f9;background:var(--bg-tertiary);border-radius:4px;cursor:pointer;flex:1 1;height:8px;position:relative;transition:height .15s ease}.floating-player-progress .progress-track:hover{height:10px}.floating-player-progress .progress-fill{background:linear-gradient(135deg,#2563eb,#3b82f6);background:var(--accent-gradient);border-radius:4px;height:100%;position:relative}.floating-player-progress .progress-fill:after{background:#2563eb;background:var(--accent-primary);border-radius:50%;box-shadow:0 2px 6px #2563eb66;content:"";height:12px;opacity:0;position:absolute;right:-6px;top:50%;transform:translateY(-50%);transition:opacity .15s ease;width:12px}.floating-player-progress .progress-track:hover .progress-fill:after{opacity:1}.floating-player-time{color:#94a3b8;color:var(--text-muted);font-size:.8125rem;font-weight:500;min-width:80px;text-align:center}.floating-player-actions{align-items:center;display:flex;gap:8px}.floating-player-close{align-items:center;background:#fff;background:var(--bg-secondary);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--radius-md);color:#94a3b8;color:var(--text-muted);cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast);width:36px}.floating-player-close:hover{background:#fef2f2;background:var(--danger-light);border-color:#dc2626;border-color:var(--danger);color:#dc2626;color:var(--danger)}.floating-player-close svg{height:18px;width:18px}@media (max-width:768px){.floating-player{gap:12px;height:72px;left:0;padding:0 16px}.floating-player-info{max-width:140px;min-width:120px}.floating-player-avatar{font-size:.875rem;height:40px;width:40px}.floating-player-agent{font-size:.875rem}.floating-player-meta{display:none}.floating-player-progress{max-width:none}.floating-player-time{display:none}}.transcript-viewer{max-height:400px;overflow-y:auto}.transcript-empty{color:#94a3b8;color:var(--text-muted);padding:40px;text-align:center}.utterance{border-left:3px solid #0000;border-radius:12px;border-radius:var(--radius-md);cursor:pointer;margin-bottom:10px;padding:14px;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast)}.utterance.active,.utterance:hover{background:#f1f5f9;background:var(--bg-tertiary)}.utterance.active{box-shadow:0 1px 2px #0f172a0a;box-shadow:var(--shadow-sm)}.utterance.speaker-A{border-left-color:#2563eb;border-left-color:var(--accent-primary)}.utterance.speaker-B{border-left-color:#059669;border-left-color:var(--success)}.utterance-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.speaker-badge{border-radius:8px;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;padding:4px 10px}.speaker-badge.speaker-A{background:#eff6ff;background:var(--accent-light);color:#2563eb;color:var(--accent-primary)}.speaker-badge.speaker-B{background:#ecfdf5;background:var(--success-light);color:#059669;color:var(--success)}.utterance-time{color:#94a3b8;color:var(--text-muted);font-size:.75rem}.utterance-text{color:#0f172a;color:var(--text-primary);font-size:.9375rem;line-height:1.6;margin:0}.quality-report{display:flex;flex-direction:column;gap:24px}.quality-empty{color:#94a3b8;color:var(--text-muted);padding:40px}.quality-empty,.score-main{text-align:center}.score-circle-wrapper{height:120px;margin:0 auto 16px;position:relative;width:120px}.score-circle{height:100%;transform:rotate(-90deg);width:100%}.score-circle-bg{fill:none;stroke:#e2e8f0;stroke:var(--border-color);stroke-width:3}.score-circle-fill{fill:none;stroke-width:3;stroke-linecap:round;transition:stroke-dasharray .5s ease}.score-circle-wrapper .score-value{align-items:center;display:flex;flex-direction:column;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.score-circle-wrapper .score-number{color:#0f172a;color:var(--text-primary);font-size:2rem;font-weight:700;line-height:1}.score-circle-wrapper .score-max{color:#94a3b8;color:var(--text-muted);font-size:.875rem}.score-justification{color:#475569;color:var(--text-secondary);font-size:.9375rem;line-height:1.5;margin:0 auto;max-width:400px}.detailed-scores{gap:12px}.detailed-scores,.score-item{display:flex;flex-direction:column}.score-item{gap:6px}.score-item-header{display:flex;font-size:.8125rem;justify-content:space-between}.score-item-header span:first-child{color:#475569;color:var(--text-secondary)}.score-item-value{color:#0f172a;color:var(--text-primary);font-weight:600}.score-item-bar{background:#e2e8f0;background:var(--border-color);border-radius:2px;height:4px;overflow:hidden}.score-item-fill{border-radius:2px;height:100%;transition:width .3s}.report-section{border-radius:12px;border-radius:var(--radius-md);padding:16px}.report-section h4{align-items:center;display:flex;font-size:.875rem;font-weight:600;gap:8px;margin-bottom:12px}.report-section h4 svg{height:16px;width:16px}.report-section ul{display:flex;flex-direction:column;gap:8px;list-style:none}.report-section li{font-size:.875rem;line-height:1.5;padding-left:16px;position:relative}.report-section li:before{content:"•";left:0;position:absolute}.report-section.strengths{background:#ecfdf5;background:var(--success-light)}.report-section.strengths h4,.report-section.strengths li{color:#059669;color:var(--success)}.report-section.improvements{background:#fffbeb;background:var(--warning-light)}.report-section.improvements h4,.report-section.improvements li{color:#d97706;color:var(--warning)}.report-section.risks{background:#fef2f2;background:var(--danger-light)}.report-section.risks h4,.report-section.risks li{color:#dc2626;color:var(--danger)}.report-section.recommendations{background:#f1f5f9;background:var(--bg-tertiary)}.report-section.recommendations h4{color:#0f172a;color:var(--text-primary)}.report-section.recommendations li{color:#475569;color:var(--text-secondary)}.recording-info{display:flex;flex-direction:column;gap:24px}.info-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}.info-item{display:flex;flex-direction:column;gap:4px}.info-label{color:#94a3b8;color:var(--text-muted);font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.info-value{font-size:.9375rem;word-break:break-all}.info-summary h4,.info-value{color:#0f172a;color:var(--text-primary)}.info-summary h4{font-size:.875rem;font-weight:600;margin-bottom:8px}.info-summary p{color:#475569;color:var(--text-secondary);font-size:.9375rem;line-height:1.6}@media (max-width:1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.sidebar{box-shadow:0 20px 25px -5px #0f172a1a,0 8px 10px -6px #0f172a0a;box-shadow:var(--shadow-xl);transform:translateX(-100%);width:280px}.sidebar.open{transform:translateX(0)}.sidebar-overlay{display:block}.main-content{margin-left:0}.menu-toggle,.theme-toggle-mobile{display:flex}.main-header{padding:0 16px}.main-body{padding:16px}.header-info h1{font-size:1.25rem}.header-subtitle{display:none}.stats-grid{gap:12px;grid-template-columns:1fr}.stats-card{padding:16px}.stats-card-value{font-size:1.5rem}.filters-bar{align-items:stretch;flex-direction:column;padding:16px}.filters-left,.filters-right{width:100%}.filters-right{flex-wrap:wrap}.filter-group{flex:1 1;min-width:calc(50% - 6px)}.filter-select{min-width:0;width:100%}.filter-checkbox{justify-content:center;width:100%}.recording-row{flex-wrap:wrap;gap:12px}.recording-row-main{width:100%}.recording-row-score{margin-left:54px}.agents-grid{grid-template-columns:1fr}.modal{border-radius:0;max-height:100vh}.modal-header{flex-direction:column;gap:16px;padding:20px}.modal-header-meta{gap:8px}.modal-header-score{align-self:flex-start}.modal-player{padding:16px}.modal-review-actions{flex-wrap:wrap;padding:16px}.review-label{margin-bottom:8px;width:100%}.review-btn{flex:1 1;justify-content:center}.modal-tabs{padding:0 16px}.modal-tab{font-size:.8125rem;padding:12px 16px}.modal-content{padding:16px}.info-grid{grid-template-columns:1fr}.audio-player-controls{gap:8px}.audio-btn.play{height:48px;width:48px}.audio-btn.play svg{height:20px;width:20px}.audio-btn.skip{height:36px;width:36px}.audio-btn.speed{font-size:.75rem;height:40px;width:40px}}.recording-detail{animation:fadeIn .3s ease}.detail-header{background:#fff;background:var(--bg-secondary);border-radius:16px;border-radius:var(--radius-lg);display:flex;gap:16px;margin-bottom:16px;padding:16px 20px}.back-btn,.detail-header{align-items:center;border:1px solid #e2e8f0;border:1px solid var(--border-color)}.back-btn{background:#f1f5f9;background:var(--bg-tertiary);border-radius:12px;border-radius:var(--radius-md);color:#475569;color:var(--text-secondary);cursor:pointer;display:inline-flex;font-size:.8125rem;font-weight:500;gap:8px;padding:8px 14px;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast)}.back-btn:hover{background:#f8fafc;background:var(--bg-primary);color:#0f172a;color:var(--text-primary)}.back-btn svg{height:16px;width:16px}.detail-meta{align-items:center;display:flex;flex:1 1;flex-wrap:wrap;gap:16px}.detail-meta .meta-item{align-items:center;color:#475569;color:var(--text-secondary);display:flex;font-size:.8125rem;gap:6px}.detail-meta .meta-item svg{color:#94a3b8;color:var(--text-muted);height:14px;width:14px}.detail-meta .meta-item.agent{color:#2563eb;color:var(--accent-primary);font-weight:500}.detail-score{border-radius:12px;border-radius:var(--radius-md);font-size:.9375rem;font-weight:700;padding:8px 16px}.detail-score.high{background:#ecfdf5;background:var(--success-light);color:#059669;color:var(--success)}.detail-score.medium{background:#fffbeb;background:var(--warning-light);color:#d97706;color:var(--warning)}.detail-score.low{background:#fef2f2;background:var(--danger-light);color:#dc2626;color:var(--danger)}.detail-player{background:#fff;background:var(--bg-secondary);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);margin-bottom:16px;padding:16px 20px}.detail-review{align-items:center;background:#fffbeb;background:var(--warning-light);border:1px solid #d97706;border:1px solid var(--warning);border-radius:16px;border-radius:var(--radius-lg);display:flex;gap:14px;margin-bottom:16px;padding:14px 20px}.detail-review .review-label{color:#0f172a;color:var(--text-primary);flex:1 1;font-size:.875rem;font-weight:500}.review-buttons{display:flex;gap:8px}.review-btn{align-items:center;border:none;border-radius:12px;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-size:.8125rem;font-weight:600;gap:6px;padding:7px 14px;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast)}.review-btn svg{height:14px;width:14px}.review-btn.approve{background:#059669;background:var(--success);color:#fff}.review-btn.approve:hover{filter:brightness(.9)}.review-btn.training{background:#0891b2;background:var(--info);color:#fff}.review-btn.training:hover{filter:brightness(.9)}.review-btn.reject{background:#dc2626;background:var(--danger);color:#fff}.review-btn.reject:hover{filter:brightness(.9)}.detail-content{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 380px}.detail-column{background:#fff;background:var(--bg-secondary);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);overflow:hidden}.column-header{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:14px 18px}.column-header h3{color:#0f172a;color:var(--text-primary);font-size:.9375rem;font-weight:600;margin:0}.column-header .confidence{color:#94a3b8;color:var(--text-muted);font-size:.75rem}.transcript-col .transcript-viewer{max-height:600px;padding:14px}.quality-col{display:flex;flex-direction:column}.quality-col .quality-compact{flex:1 1;padding:18px}.detail-summary{background:#f1f5f9;background:var(--bg-tertiary);border-top:1px solid #e2e8f0;border-top:1px solid var(--border-color);padding:16px 18px}.detail-summary h4{color:#0f172a;color:var(--text-primary);font-size:.8125rem;font-weight:600;margin:0 0 8px}.detail-summary p{color:#475569;color:var(--text-secondary);font-size:.8125rem;line-height:1.5;margin:0}.quality-compact{display:flex;flex-direction:column;gap:18px}.quality-score-main{background:#f1f5f9;background:var(--bg-tertiary);border-radius:12px;border-radius:var(--radius-md);padding:16px;text-align:center}.quality-score-main .score-big{font-size:3rem;font-weight:700;line-height:1}.quality-score-main .score-label{color:#94a3b8;color:var(--text-muted);font-size:.75rem;margin-top:4px}.quality-bars{gap:10px}.quality-bars,.score-bar-item{display:flex;flex-direction:column}.score-bar-item{gap:4px}.score-bar-header{align-items:center;display:flex;justify-content:space-between}.score-bar-label{color:#475569;color:var(--text-secondary);font-size:.75rem}.score-bar-value{color:#0f172a;color:var(--text-primary);font-size:.75rem;font-weight:600}.score-bar-track{background:#e2e8f0;background:var(--border-color);border-radius:3px;height:6px;overflow:hidden}.score-bar-fill{border-radius:3px;height:100%;transition:width .4s ease}.quality-feedback{display:flex;flex-direction:column;gap:12px}.feedback-section{border-radius:12px;border-radius:var(--radius-md);padding:12px 14px}.feedback-section.good{background:#ecfdf5;background:var(--success-light)}.feedback-section.improve{background:#fffbeb;background:var(--warning-light)}.feedback-section h5{font-size:.75rem;font-weight:600;margin:0 0 8px}.feedback-section.good h5{color:#059669;color:var(--success)}.feedback-section.improve h5{color:#d97706;color:var(--warning)}.feedback-section ul{list-style:none;margin:0;padding:0}.feedback-section li{font-size:.75rem;line-height:1.5;margin-bottom:4px;padding-left:14px;position:relative}.feedback-section li:before{content:"•";left:0;position:absolute}.feedback-section.good li{color:#059669;color:var(--success)}.feedback-section.improve li{color:#d97706;color:var(--warning)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn .3s ease}.animate-slide-up{animation:slideUp .4s ease}@media (max-width:1024px){.detail-content{grid-template-columns:1fr}.quality-col{order:-1}}@media (max-width:768px){.detail-header{align-items:stretch;flex-direction:column;gap:12px}.detail-meta{justify-content:center}.detail-score{align-self:center}.detail-review{flex-direction:column;text-align:center}.review-buttons{justify-content:center;width:100%}.stats-cards{grid-template-columns:repeat(2,1fr)}.sidebar{box-shadow:0 20px 25px -5px #0f172a1a,0 8px 10px -6px #0f172a0a;box-shadow:var(--shadow-xl);transform:translateX(-100%);width:280px}.sidebar.open{transform:translateX(0)}.overlay{display:block}.main{margin-left:0}.menu-btn,.theme-btn-mobile{display:flex}.header{padding:0 16px}.content{padding:16px}}@media (max-width:480px){.stats-cards{grid-template-columns:1fr}.filters-bar{align-items:stretch;flex-direction:column}.filter-checkbox,.filter-select{width:100%}}
/*# sourceMappingURL=main.e7abfe8c.css.map*/