@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg-primary: #0f0f1a;--bg-secondary: #161625;--bg-card: #1c1c2e;--bg-hover: #252540;--bg-input: #1e1e32;--border: #2d2d4a;--border-focus: #6366f1;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--accent: #6366f1;--accent-hover: #818cf8;--accent-glow: rgba(99, 102, 241, .2);--green: #10b981;--red: #ef4444;--yellow: #f59e0b;--blue: #3b82f6;--purple: #8b5cf6;--orange: #f97316;--sidebar-width: 260px;--radius: 10px;--radius-sm: 6px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:14px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;min-height:100vh}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:100;transition:transform .3s ease}.sidebar-header{padding:20px;border-bottom:1px solid var(--border)}.sidebar-close{display:none}.logo{display:flex;align-items:center;gap:10px;font-size:1.3rem;font-weight:700;color:var(--accent)}.logo svg{filter:drop-shadow(0 0 8px var(--accent-glow))}.sidebar-nav{flex:1;padding:12px;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--radius-sm);color:var(--text-secondary);transition:all .2s;margin-bottom:2px;font-weight:500;text-decoration:none}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--accent-glow);color:var(--accent)}.badge{background:var(--accent);color:#fff;font-size:.7rem;font-weight:600;padding:2px 7px;border-radius:10px;margin-left:auto}.badge.pulse{animation:pulse-badge 2s infinite}@keyframes pulse-badge{0%,to{box-shadow:0 0 #6366f166}50%{box-shadow:0 0 0 6px #6366f100}}.sidebar-footer{padding:14px 20px;border-top:1px solid var(--border)}.ws-status{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--text-muted);margin-bottom:10px}.user-info{display:flex;align-items:center;justify-content:space-between}.user-name{color:var(--text-secondary);font-size:.85rem;font-weight:500}.main-content{flex:1;margin-left:var(--sidebar-width);min-height:100vh}.page-content{padding:28px;max-width:1400px}.mobile-header{display:none}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at top,#1a1a3e,var(--bg-primary));padding:20px}.auth-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:40px;width:100%;max-width:420px;box-shadow:0 20px 60px #0000004d}.auth-logo{text-align:center;margin-bottom:30px}.auth-logo svg{color:var(--accent);filter:drop-shadow(0 0 12px var(--accent-glow))}.auth-logo h1{font-size:1.5rem;margin-top:10px}.auth-logo p{color:var(--text-muted);margin-top:4px}.auth-footer{text-align:center;margin-top:20px;color:var(--text-muted);font-size:.85rem}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:.8rem;font-weight:500;color:var(--text-secondary);margin-bottom:6px}input,select,textarea{width:100%;background:var(--bg-input);border:1px solid var(--border);color:var(--text-primary);padding:10px 14px;border-radius:var(--radius-sm);font-size:.9rem;font-family:inherit;transition:border-color .2s;outline:none}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}input[type=range]{padding:0;border:none;background:transparent;-webkit-appearance:auto}input[type=range]:focus{box-shadow:none}input[type=checkbox]{width:auto;margin-right:8px;accent-color:var(--accent)}textarea{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.form-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-bottom:20px}.form-section h3{font-size:1rem;margin-bottom:16px;color:var(--accent);padding-bottom:10px;border-bottom:1px solid var(--border)}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}.checkbox-label{display:flex!important;align-items:center;cursor:pointer}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:var(--radius-sm);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid transparent;font-family:inherit;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 16px var(--accent-glow)}.btn-outline{background:transparent;color:var(--text-secondary);border-color:var(--border)}.btn-outline:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary);border-color:var(--text-muted)}.btn-danger{background:#ef44441a;color:var(--red);border-color:#ef44444d}.btn-danger:hover:not(:disabled){background:var(--red);color:#fff}.btn-full{width:100%;justify-content:center}.btn-sm{padding:5px 10px;font-size:.78rem}.btn-icon{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:6px;border-radius:var(--radius-sm);display:inline-flex;align-items:center;transition:all .2s}.btn-icon:hover{background:var(--bg-hover);color:var(--text-primary)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-bottom:20px}.card h3{font-size:1rem;margin-bottom:16px;display:flex;align-items:center;gap:8px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;align-items:center;gap:16px;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0003}.stat-icon{width:48px;height:48px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-value{display:block;font-size:1.4rem;font-weight:700;line-height:1}.stat-label{display:block;color:var(--text-muted);font-size:.78rem;margin-top:4px}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:20px;margin-bottom:24px}.chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px}.chart-card h3{margin-bottom:16px}.chart-container{height:260px}.table-container{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border);margin-bottom:16px}.table{width:100%;border-collapse:collapse;font-size:.85rem}.table th{background:var(--bg-secondary);padding:10px 14px;text-align:left;font-weight:600;color:var(--text-secondary);border-bottom:1px solid var(--border);white-space:nowrap}.table td{padding:10px 14px;border-bottom:1px solid var(--border);color:var(--text-primary);vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:var(--bg-hover)}.table td svg{vertical-align:middle;margin-right:4px}.tag{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:500;background:var(--bg-hover);color:var(--text-secondary);margin-right:4px}.tag-sm{padding:2px 7px;font-size:.68rem}.tag-green{background:#10b98126;color:var(--green)}.tag-red{background:#ef444426;color:var(--red)}.tag-blue{background:#3b82f626;color:var(--blue)}.tag-purple{background:#8b5cf626;color:var(--purple)}.tag-yellow{background:#f59e0b26;color:var(--yellow)}.tag-gray{background:var(--bg-hover);color:var(--text-muted)}.tabs{display:flex;gap:4px;margin-bottom:20px;border-bottom:1px solid var(--border)}.tab{display:flex;align-items:center;gap:6px;padding:10px 18px;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.85rem;font-weight:500;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .2s;font-family:inherit}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.agents-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:18px}.agent-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;transition:transform .2s,box-shadow .2s}.agent-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0003}.agent-card.inactive{opacity:.5}.agent-card-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.agent-icon{width:44px;height:44px;border-radius:var(--radius-sm);background:var(--accent-glow);color:var(--accent);display:flex;align-items:center;justify-content:center}.agent-meta h3{font-size:1rem}.agent-ext{color:var(--text-muted);font-size:.78rem}.agent-meta{flex:1}.agent-desc{color:var(--text-muted);font-size:.82rem;margin-bottom:12px;line-height:1.4}.agent-details{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}.agent-actions{display:flex;gap:8px;padding-top:12px;border-top:1px solid var(--border)}.call-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:18px;margin-bottom:20px}.full-width{grid-column:1 / -1}.detail-list>div{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border);font-size:.85rem}.detail-list>div:last-child{border-bottom:none}.detail-list>div>span:first-child{color:var(--text-muted)}.transcript{max-height:500px;overflow-y:auto}.transcript-turn{padding:12px 16px;margin-bottom:8px;border-radius:var(--radius-sm);border-left:3px solid}.transcript-turn.user{background:#3b82f60f;border-color:var(--blue)}.transcript-turn.assistant{background:#6366f10f;border-color:var(--accent)}.turn-header{display:flex;align-items:center;gap:6px;margin-bottom:6px;font-size:.75rem;color:var(--text-muted)}.turn-role{font-weight:600;text-transform:uppercase;letter-spacing:.5px}.transcript-turn p{color:var(--text-primary);font-size:.85rem;line-height:1.5}.ws-indicator{display:flex;align-items:center;gap:6px;padding:5px 12px;border-radius:20px;font-size:.8rem;font-weight:500}.ws-indicator.connected{background:#10b9811a;color:var(--green)}.ws-indicator.disconnected{background:#ef44441a;color:var(--red)}.live-calls-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:18px;margin-bottom:20px}.live-call-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;position:relative;overflow:hidden}.live-call-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--purple));animation:live-bar 2s infinite}@keyframes live-bar{0%,to{opacity:1}50%{opacity:.5}}.live-call-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.pulse-dot{width:10px;height:10px;border-radius:50%;background:var(--green);animation:pulse 1.5s infinite}@keyframes pulse{0%,to{box-shadow:0 0 #10b98166}50%{box-shadow:0 0 0 8px #10b98100}}.call-info{flex:1}.call-info h3{font-size:.95rem;display:flex;align-items:center;gap:6px}.call-timer{color:var(--text-muted);font-size:.8rem;display:flex;align-items:center;gap:4px}.live-stats{display:flex;gap:16px;font-size:.8rem;color:var(--text-muted);margin-bottom:8px}.live-stats span{display:flex;align-items:center;gap:4px}.live-transcript{background:var(--bg-secondary);padding:10px;border-radius:var(--radius-sm);font-size:.82rem;color:var(--text-secondary)}.events-list{max-height:300px;overflow-y:auto}.event-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);font-size:.8rem}.event-type{font-weight:600;color:var(--accent);min-width:100px}.event-time{color:var(--text-muted);min-width:80px}.event-text{color:var(--text-secondary);flex:1}.filters-bar{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:20px}.filters-bar .form-group{margin-bottom:0;min-width:140px}.pagination{display:flex;align-items:center;justify-content:center;gap:16px;padding:16px 0;color:var(--text-muted);font-size:.85rem}.page-title{font-size:1.6rem;font-weight:700;margin-bottom:24px;background:linear-gradient(135deg,var(--text-primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.page-header .page-title{margin-bottom:0}.loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:60px 20px;color:var(--text-muted)}.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted)}.empty-state svg{margin-bottom:16px;opacity:.3}.empty-state h3{color:var(--text-secondary);margin-bottom:8px}.alert{padding:12px 16px;border-radius:var(--radius-sm);margin-bottom:16px;font-size:.85rem}.alert-error{background:#ef44441a;color:var(--red);border:1px solid rgba(239,68,68,.2)}.text-green{color:var(--green)!important}.text-red{color:var(--red)!important}.text-muted{color:var(--text-muted)!important}.text-sm{font-size:.78rem}.font-mono{font-family:SF Mono,Consolas,monospace}.mt-4{margin-top:20px}.ml-1{margin-left:4px}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-close{display:flex;background:none;border:none;color:var(--text-muted);cursor:pointer;position:absolute;right:16px;top:20px}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:99}.main-content{margin-left:0}.mobile-header{display:flex;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid var(--border);background:var(--bg-secondary)}.mobile-title{font-size:1.1rem;font-weight:700;color:var(--accent)}.page-content{padding:16px}.stats-grid{grid-template-columns:repeat(2,1fr)}.charts-grid,.agents-grid,.form-row{grid-template-columns:1fr}.filters-bar{flex-direction:column}}
