.sidebar{width:220px;min-height:100vh;background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:20px 12px;flex-shrink:0;position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar-logo{display:flex;align-items:center;justify-content:center;padding:4px 8px 20px;border-bottom:1px solid var(--border);margin-bottom:16px}.sidebar-logo-img{max-width:100%;max-height:52px;object-fit:contain}html:not([data-theme=light]) .sidebar-logo-light{display:none}html[data-theme=light] .sidebar-logo-dark{display:none}.logo-mark{width:34px;height:34px;background:var(--accent-dim);border:1px solid rgba(91,138,240,.3);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0}.logo-text{font-size:16px;font-weight:600;color:var(--text-primary);letter-spacing:-.2px}.sidebar-nav{margin-bottom:4px}.sidebar-clients{flex:1;display:flex;flex-direction:column;min-height:0}.clients-label{margin-top:12px}.sidebar-search-wrap{display:flex;align-items:center;gap:7px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:0 10px;margin-bottom:6px;color:var(--text-muted);transition:border-color .15s}.sidebar-search-wrap:focus-within{border-color:var(--accent)}.sidebar-search{flex:1;background:none;border:none;outline:none;color:var(--text-primary);font-size:12.5px;font-family:var(--font-sans);padding:7px 0}.sidebar-search::placeholder{color:var(--text-muted)}.sidebar-search-clear{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;line-height:1;padding:0;display:flex;align-items:center}.sidebar-search-clear:hover{color:var(--text-primary)}.sidebar-clients-list{flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.module-item{gap:10px}.module-icon{width:22px;height:22px;border-radius:6px;background:var(--bg-elevated);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-muted);flex-shrink:0;transition:all .15s}.nav-item.active .module-icon{background:var(--accent-dim);border-color:#5b8af04d;color:var(--accent)}.nav-section-label{font-size:11px;font-weight:600;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;padding:0 8px;margin-bottom:6px}.nav-item{display:flex;align-items:center;gap:9px;width:100%;padding:8px 10px;background:none;border:none;border-radius:var(--radius-md);color:var(--text-secondary);font-size:13.5px;cursor:pointer;transition:background .15s,color .15s;text-align:left;animation:fadeInUp .3s ease both}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--accent-dim);color:var(--accent)}.nav-item-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;background:var(--accent)}.nav-item-dot.all{background:var(--text-muted)}.nav-item.active .nav-item-dot.all{background:var(--accent)}.nav-item-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-empty{font-size:12px;color:var(--text-muted);padding:8px 10px;font-style:italic}.sidebar-footer{padding-top:16px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding-left:8px;padding-right:8px}.sidebar-footer-text{font-size:11px;color:var(--text-muted)}.sidebar-footer-version{font-size:11px;color:var(--text-muted);font-family:var(--font-mono)}.sidebar-close-btn{display:none;position:absolute;top:14px;right:14px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-muted);width:30px;height:30px;font-size:18px;line-height:1;cursor:pointer;align-items:center;justify-content:center}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:149;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}@media (max-width: 768px){.sidebar{position:fixed;top:0;left:0;bottom:0;z-index:150;transform:translate(-100%);transition:transform .28s cubic-bezier(.4,0,.2,1);min-height:100dvh;box-shadow:var(--shadow-lg)}.sidebar--open{transform:translate(0)}.sidebar-backdrop{display:block}.sidebar-close-btn{display:flex}.sidebar-logo{padding-right:44px}}.filters-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;margin-bottom:16px;box-shadow:var(--shadow-sm);animation:fadeInUp .4s .1s ease both}.filters-grid{display:grid;grid-template-columns:2fr repeat(5,1fr);gap:10px;margin-bottom:12px}.field{display:flex;flex-direction:column;gap:5px}.field-label{font-size:10.5px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em}.input-wrap{position:relative;display:flex;align-items:center}.input-wrap svg{position:absolute;left:10px;color:var(--text-muted);pointer-events:none}.input-wrap .field-input{padding-left:32px}.field-input{height:36px;width:100%;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-primary);font-size:13px;padding:0 11px;font-family:var(--font-sans);transition:border-color .15s,box-shadow .15s,background .15s;-moz-appearance:none;appearance:none;-webkit-appearance:none}.field-input:focus{outline:none;border-color:var(--accent);background:var(--bg-surface);box-shadow:0 0 0 3px var(--accent-dim)}.field-input::placeholder{color:var(--text-muted)}.field-input::-webkit-calendar-picker-indicator{opacity:.5;cursor:pointer;filter:var(--picker-filter, none)}[data-theme=dark] .field-input::-webkit-calendar-picker-indicator{filter:invert(.6)}.filters-actions{display:flex;justify-content:flex-end;gap:8px;padding-top:2px}.btn-clear{height:36px;padding:0 16px;background:none;border:1px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-secondary);font-size:13px;cursor:pointer;font-family:var(--font-sans);font-weight:500;transition:all .15s}.btn-clear:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-strong)}.btn-export{height:36px;padding:0 14px;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;font-family:var(--font-sans);display:flex;align-items:center;gap:6px;text-decoration:none;transition:all .15s}.btn-export:hover{background:var(--bg-hover);color:var(--green);border-color:#34d07a59}.btn-search{height:36px;padding:0 20px;background:var(--accent);border:none;border-radius:var(--radius-md);color:#fff;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--font-sans);display:flex;align-items:center;gap:7px;transition:opacity .15s,transform .1s,box-shadow .15s;box-shadow:0 2px 8px var(--accent-glow)}.btn-search:hover:not(:disabled){opacity:.9;box-shadow:0 4px 14px var(--accent-glow)}.btn-search:active{transform:scale(.98)}.btn-search:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}@media (max-width: 900px){.filters-grid{grid-template-columns:1fr 1fr 1fr}}@media (max-width: 600px){.filters-grid{grid-template-columns:1fr 1fr}.filters-actions{justify-content:stretch}.filters-actions .btn-clear,.filters-actions .btn-export,.filters-actions .btn-search{flex:1;justify-content:center}}@media (max-width: 380px){.filters-grid{grid-template-columns:1fr}}.table-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);animation:fadeInUp .4s .15s ease both}.table-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);background:var(--bg-elevated)}.table-title{font-size:13.5px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:10px}.count-badge{font-size:11px;font-weight:600;background:var(--accent-dim);color:var(--accent);padding:2px 9px;border-radius:20px;font-variant-numeric:tabular-nums;border:1px solid var(--accent-glow)}.inline-spinner{width:15px;height:15px;border:2px solid var(--border-strong);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 20px;gap:12px;color:var(--text-muted);font-size:13.5px}.spinner{width:26px;height:26px;border:2.5px solid var(--border-strong);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.empty-state svg{color:var(--text-muted);margin-bottom:4px;opacity:.5}.empty-state p{font-size:15px;color:var(--text-secondary);font-weight:600}.empty-state span{font-size:12.5px;color:var(--text-muted)}.table-scroll{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13px}thead th{padding:9px 14px;text-align:left;font-size:10.5px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;background:var(--bg-elevated);border-bottom:1px solid var(--border-strong);white-space:nowrap;-webkit-user-select:none;user-select:none}.rec-row{border-bottom:1px solid var(--border);transition:background .1s;animation:fadeIn .2s ease both}.rec-row:last-child{border-bottom:none}.rec-row:hover{background:var(--bg-hover)}.rec-row.current,.rec-row.playing{background:var(--accent-dim)}.rec-row.playing td{color:var(--text-primary)}td{padding:10px 14px;vertical-align:middle;white-space:nowrap}.phone-num{font-family:var(--font-mono);font-size:12.5px;font-weight:500;color:var(--text-primary)}.phone-num.secondary{color:var(--text-secondary)}.client-tag{display:inline-block;font-size:11px;font-weight:500;background:var(--bg-active);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:2px 8px;color:var(--text-secondary);max-width:130px;overflow:hidden;text-overflow:ellipsis}.date-val{font-size:12.5px;color:var(--text-primary);font-variant-numeric:tabular-nums;font-weight:500}.time-val{font-family:var(--font-mono);font-size:12px;color:var(--text-secondary);font-variant-numeric:tabular-nums}.size-val{font-size:12px;color:var(--text-muted);font-variant-numeric:tabular-nums}.badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px;letter-spacing:.01em}.badge-in{background:var(--green-dim);color:var(--green);border:1px solid transparent}.badge-out{background:var(--accent-dim);color:var(--accent);border:1px solid transparent}.badge-unknown{background:var(--bg-active);color:var(--text-muted);border:1px solid var(--border)}.row-actions{display:flex;align-items:center;justify-content:flex-end;gap:5px}.action-btn{width:30px;height:30px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;text-decoration:none}.action-btn:hover{border-color:var(--border-strong);color:var(--text-primary);background:var(--bg-hover)}.action-btn.play:hover{background:var(--accent-dim);border-color:var(--accent-glow);color:var(--accent)}.action-btn.play.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 0 0 3px var(--accent-dim)}.action-btn.download:hover{background:var(--green-dim);border-color:#34d39940;color:var(--green)}[data-theme=light] .action-btn.download:hover{border-color:#05966940}.action-btn:disabled{opacity:.2;cursor:not-allowed;pointer-events:none}.table-mobile{display:none}.table-desktop{display:block}.rec-cards{display:flex;flex-direction:column}.rec-card{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:7px;animation:fadeIn .2s ease both;transition:background .1s}.rec-card:last-child{border-bottom:none}.rec-card:hover{background:var(--bg-hover)}.rec-card.current,.rec-card.playing{background:var(--accent-dim)}.rec-card-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.rec-card-phones{display:flex;align-items:center;gap:6px;min-width:0;flex-wrap:wrap}.rec-card-arrow{color:var(--text-muted);font-size:12px;flex-shrink:0}.rec-card-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.rec-card-dt{font-size:12px;color:var(--text-muted);font-variant-numeric:tabular-nums}.rec-card-dur{font-size:12px;font-family:var(--font-mono);color:var(--text-secondary)}.rec-card-actions{display:flex;gap:6px}@media (max-width: 640px){.table-mobile{display:flex}.table-desktop{display:none}}.table-pagination{display:flex;align-items:center;justify-content:space-between;padding:11px 16px;border-top:1px solid var(--border);background:var(--bg-elevated)}.page-info{font-size:12px;color:var(--text-muted)}.page-buttons{display:flex;align-items:center;gap:3px}.page-btn{height:28px;padding:0 10px;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:12px;cursor:pointer;font-family:var(--font-sans);transition:all .12s}.page-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-strong)}.page-btn.num.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.page-btn:disabled{opacity:.3;cursor:not-allowed}.player-bar{position:fixed;bottom:0;left:0;right:0;z-index:100;background:var(--player-bg, rgba(19, 21, 28, .92));backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid var(--border-strong);animation:slideUp .3s ease both}.player-inner{display:grid;grid-template-columns:1fr 2fr 1fr;align-items:center;gap:20px;padding:12px 24px;max-width:1400px;margin:0 auto}.player-info{display:flex;align-items:center;gap:12px;min-width:0}.player-play-state{width:36px;height:36px;border-radius:50%;background:var(--accent-dim);border:1px solid rgba(91,138,240,.25);display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0}.player-track{min-width:0}.player-num{font-family:var(--font-mono);font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-num-arrow{color:var(--text-muted);font-weight:400}.player-meta{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}.wave-bars{display:flex;align-items:center;gap:2px;height:16px}.wave-bars span{display:block;width:3px;background:var(--accent);border-radius:2px;animation:wave 1s ease-in-out infinite}.wave-bars span:nth-child(1){animation-delay:0s;height:6px}.wave-bars span:nth-child(2){animation-delay:.15s;height:12px}.wave-bars span:nth-child(3){animation-delay:.3s;height:9px}.wave-bars span:nth-child(4){animation-delay:.45s;height:14px}@keyframes wave{0%,to{transform:scaleY(1)}50%{transform:scaleY(.35)}}.player-center{display:flex;flex-direction:column;align-items:center;gap:8px}.player-controls{display:flex;align-items:center;gap:12px}.ctrl-btn{position:relative;width:32px;height:32px;background:none;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.ctrl-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-strong)}.ctrl-label{position:absolute;bottom:-1px;right:2px;font-size:8px;font-weight:600;color:currentColor;pointer-events:none;line-height:1}.ctrl-main{width:42px;height:42px;border-radius:50%;background:var(--accent);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .1s,opacity .15s;flex-shrink:0}.ctrl-main:hover{opacity:.88}.ctrl-main:active{transform:scale(.95)}.ctrl-main.loading{opacity:.6;cursor:wait}.ctrl-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.player-progress-row{display:flex;align-items:center;gap:10px;width:100%}.progress-track{flex:1;height:4px;position:relative;cursor:pointer;padding:8px 0;margin:-8px 0}.progress-bg{position:absolute;top:50%;transform:translateY(-50%);left:0;right:0;height:3px;background:var(--bg-active);border-radius:2px}.progress-fill{position:absolute;top:50%;transform:translateY(-50%);left:0;height:3px;background:var(--accent);border-radius:2px;transition:width .1s linear;pointer-events:none}.progress-thumb{position:absolute;top:50%;transform:translate(-50%,-50%);width:12px;height:12px;background:#fff;border-radius:50%;box-shadow:0 0 0 2px var(--accent);transition:left .1s linear;pointer-events:none;opacity:0}.progress-track:hover .progress-thumb{opacity:1}.time-label{font-size:11px;color:var(--text-muted);font-variant-numeric:tabular-nums;font-family:var(--font-mono);min-width:32px}.time-label.right{text-align:right}.player-right{display:flex;align-items:center;justify-content:flex-end;gap:16px}.volume-wrap{display:flex;align-items:center;gap:8px;color:var(--text-muted)}.volume-slider{width:80px;height:3px;-moz-appearance:none;appearance:none;-webkit-appearance:none;background:var(--bg-active);border-radius:2px;outline:none;cursor:pointer}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:var(--accent);cursor:pointer}.speed-wrap{display:flex;align-items:center;gap:3px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:2px}.speed-btn{height:26px;padding:0 7px;background:none;border:none;border-radius:calc(var(--radius-md) - 2px);color:var(--text-muted);font-size:11px;font-weight:600;font-family:var(--font-mono);cursor:pointer;transition:all .12s;white-space:nowrap}.speed-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.speed-btn.active{background:var(--accent);color:#fff}.player-download-btn{display:flex;align-items:center;gap:6px;height:32px;padding:0 14px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:12px;font-weight:500;text-decoration:none;cursor:pointer;transition:all .15s;font-family:var(--font-sans)}.player-download-btn:hover{background:var(--green-dim);border-color:#3ecf8e4d;color:var(--green)}.player-close-btn{width:32px;height:32px;background:none;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.player-close-btn:hover{background:#ef44441f;border-color:#ef444459;color:#ef4444}@media (max-width: 768px){.player-inner{grid-template-columns:1fr auto;grid-template-rows:auto auto;padding:10px 14px;gap:8px}.player-info{grid-column:1;grid-row:1}.player-close-btn-wrap{grid-column:2;grid-row:1;display:flex;align-items:center}.player-center{grid-column:1 / -1;grid-row:2}.player-right,.volume-wrap,.player-download-btn{display:none}}@media (max-width: 480px){.speed-wrap{display:none}}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:16px;animation:fadeInUp .4s .05s ease both}.stat-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px;display:flex;align-items:center;gap:13px;box-shadow:var(--shadow-sm);transition:border-color .2s,box-shadow .2s,transform .15s}.stat-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-icon{width:38px;height:38px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-accent .stat-icon{background:var(--accent-dim);color:var(--accent)}.stat-amber .stat-icon{background:var(--amber-dim);color:var(--amber)}.stat-value{font-size:22px;font-weight:700;line-height:1;font-variant-numeric:tabular-nums;letter-spacing:-.5px}.stat-accent .stat-value{color:var(--accent)}.stat-green .stat-value{color:var(--green)}.stat-amber .stat-value{color:var(--amber)}.stat-label{font-size:11.5px;color:var(--text-muted);margin-top:3px;font-weight:500}.login-bg{min-height:100vh;min-height:100svh;display:flex;align-items:center;justify-content:center;background:var(--bg-base);background-image:radial-gradient(ellipse at 50% 0%,var(--accent-dim) 0%,transparent 65%);position:relative;padding:20px 16px}.login-theme-toggle{position:absolute;top:16px;right:16px;background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-secondary);width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.login-theme-toggle:hover{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--accent)}.login-card{background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:18px;padding:40px 36px;width:100%;max-width:380px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;align-items:center}.login-logo-img-wrap{margin-bottom:20px}.login-logo-img{max-height:64px;max-width:220px;object-fit:contain}html:not([data-theme=light]) .login-logo-light{display:none}html[data-theme=light] .login-logo-dark{display:none}.login-title{font-size:1.2rem;font-weight:700;color:var(--text-primary);margin:0 0 6px;text-align:center;letter-spacing:-.3px}.login-subtitle{font-size:.82rem;color:var(--text-muted);margin:0 0 28px;text-align:center}.login-form{width:100%;display:flex;flex-direction:column;gap:16px}.login-field{display:flex;flex-direction:column;gap:6px}.login-field label{font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em}.login-field input{background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius-md);padding:10px 14px;color:var(--text-primary);font-size:.9rem;outline:none;transition:border-color .15s,box-shadow .15s,background .15s;font-family:inherit}.login-field input::placeholder{color:var(--text-muted)}.login-field input:focus{border-color:var(--accent);background:var(--bg-surface);box-shadow:0 0 0 3px var(--accent-dim)}.login-field input:disabled{opacity:.5}.login-error{background:var(--red-dim);border:1px solid rgba(248,113,113,.25);border-radius:var(--radius-md);color:var(--red);font-size:.82rem;padding:10px 14px;text-align:center}[data-theme=light] .login-error{border-color:#dc262640}.login-btn{background:var(--accent);color:#fff;border:none;border-radius:var(--radius-md);padding:11px;font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .15s,box-shadow .15s,transform .1s;margin-top:4px;display:flex;align-items:center;justify-content:center;min-height:42px;box-shadow:0 2px 10px var(--accent-glow)}.login-btn:hover:not(:disabled){opacity:.9;box-shadow:0 4px 16px var(--accent-glow)}.login-btn:active:not(:disabled){transform:scale(.98)}.login-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.login-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@media (max-width: 480px){.login-card{padding:28px 20px;border-radius:14px;max-width:100%}.login-field input{font-size:16px;padding:11px 12px}.login-btn{font-size:16px;min-height:46px}}.ext-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin-bottom:20px;animation:fadeInUp .35s ease both}.stat-card{display:flex;align-items:center;gap:14px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;transition:transform .15s}.stat-card:hover{transform:translateY(-2px)}.stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-blue .stat-icon{background:var(--accent-dim);color:var(--accent)}.stat-green .stat-icon{background:var(--green-dim);color:var(--green)}.stat-red .stat-icon{background:var(--red-dim);color:var(--red)}.stat-yellow .stat-icon{background:#fbbf241f;color:#fbbf24}.stat-value{font-size:22px;font-weight:700;color:var(--text-primary);line-height:1.1}.stat-label{font-size:11.5px;color:var(--text-muted);margin-top:2px}.ext-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:18px;flex-wrap:wrap;animation:fadeInUp .4s ease both}.ext-search-wrap{display:flex;align-items:center;gap:8px;flex:1;min-width:200px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:0 12px;color:var(--text-muted);transition:border-color .15s}.ext-search-wrap:focus-within{border-color:var(--accent)}.ext-search{flex:1;background:none;border:none;outline:none;color:var(--text-primary);font-size:13px;font-family:var(--font-sans);padding:9px 0}.ext-search::placeholder{color:var(--text-muted)}.ext-search-clear{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:17px;padding:0;line-height:1}.ext-search-clear:hover{color:var(--text-primary)}.ext-filter-btns{display:flex;gap:4px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:3px}.ext-filter-btn{padding:5px 13px;background:none;border:none;border-radius:calc(var(--radius-md) - 2px);color:var(--text-muted);font-size:12.5px;font-weight:500;cursor:pointer;transition:all .12s}.ext-filter-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.ext-filter-btn.active{background:var(--accent);color:#fff}.ext-refresh-btn{display:flex;align-items:center;gap:7px;height:36px;padding:0 13px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-muted);font-size:11.5px;cursor:pointer;transition:all .15s;white-space:nowrap}.ext-refresh-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-strong)}.ext-refresh-label{font-family:var(--font-mono);font-size:11px}.ext-error{background:var(--red-dim);border:1px solid rgba(248,113,113,.25);border-radius:var(--radius-md);color:var(--red);padding:12px 16px;margin-bottom:16px;font-size:13px}.ext-loading,.ext-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px 0;color:var(--text-muted);font-size:13px}.ext-spinner{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.ext-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px;animation:fadeInUp .4s ease both}.ext-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:transform .15s,box-shadow .15s}.ext-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000026}.ext-card.online{border-color:#34d07a59;border-left:3px solid var(--green)}.ext-card.offline{border-left:3px solid var(--border-strong);opacity:.72}[data-theme=light] .ext-card.online{border-color:#0596694d;border-left-color:#059669;background:#f0fdf8}[data-theme=light] .ext-card.offline{background:#f8fafc;border-left-color:#cbd5e1;opacity:.78}.ext-card-header{display:flex;align-items:center;gap:10px;padding:14px 16px 10px;border-bottom:1px solid var(--border)}.ext-avatar{width:36px;height:36px;border-radius:10px;background:var(--accent-dim);border:1px solid rgba(91,138,240,.2);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--accent);font-family:var(--font-mono);flex-shrink:0}.ext-card.offline .ext-avatar{background:var(--bg-elevated);border-color:var(--border);color:var(--text-muted)}[data-theme=light] .ext-card.online .ext-avatar{background:#d1fae5;border-color:#6ee7b7;color:#065f46}[data-theme=light] .ext-card.offline .ext-avatar{background:#f1f5f9;border-color:#e2e8f0;color:#94a3b8}.ext-card-name{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.ext-ramal-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.ext-alias-badge{font-size:13px;font-weight:700;color:var(--accent);font-family:var(--font-mono);background:var(--accent-dim);padding:1px 7px;border-radius:5px;white-space:nowrap}.ext-account{font-size:11px;color:var(--text-muted);font-family:var(--font-mono);white-space:nowrap}.ext-cid-name{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:500;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ext-status-badge{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px;flex-shrink:0}.ext-status-badge.online{background:var(--green-dim);color:var(--green);border:1px solid rgba(52,208,122,.25)}.ext-status-badge.offline{background:var(--bg-elevated);color:var(--text-muted);border:1px solid var(--border)}[data-theme=light] .ext-status-badge.online{background:#dcfce7;color:#15803d;border-color:#86efac}[data-theme=light] .ext-status-badge.offline{background:#f1f5f9;color:#64748b;border-color:#cbd5e1}.ext-status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.ext-status-badge.online .ext-status-dot{background:var(--green);animation:pulse-green 2s ease-in-out infinite}.ext-status-badge.offline .ext-status-dot{background:var(--text-muted)}[data-theme=light] .ext-status-badge.online .ext-status-dot{background:#16a34a}[data-theme=light] .ext-status-badge.offline .ext-status-dot{background:#94a3b8}@keyframes pulse-green{0%,to{opacity:1}50%{opacity:.4}}.ext-card-body{padding:10px 16px 14px;display:flex;flex-direction:column;gap:6px}.info-row{display:flex;align-items:center;gap:8px}.info-icon{color:var(--text-muted);width:14px;flex-shrink:0;display:flex;align-items:center}.info-label{font-size:11px;color:var(--text-muted);min-width:72px;flex-shrink:0}.info-value{font-size:12.5px;color:var(--text-secondary);min-width:0}.info-value.mono{font-family:var(--font-mono);font-size:12px}.info-value.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.latency-val{font-family:var(--font-mono);font-size:12px;font-weight:600}.latency-val.good{color:var(--green)}.latency-val.ok{color:#f59e0b}.latency-val.bad{color:var(--red)}[data-theme=light] .latency-val.good{color:#16a34a}[data-theme=light] .latency-val.ok{color:#d97706}[data-theme=light] .latency-val.bad{color:#dc2626}@media (max-width: 640px){.ext-grid{grid-template-columns:1fr}.ext-stats{grid-template-columns:repeat(2,1fr)}.ext-toolbar{gap:6px}.ext-refresh-label{display:none}}.dash-wrap{display:flex;flex-direction:column;gap:20px;animation:fadeInUp .35s ease both}.dash-filters{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap}.dash-filter-group{display:flex;flex-direction:column;gap:5px}.dash-filter-group label{font-size:.72rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em}.dash-filter-group input[type=date]{background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-primary);padding:7px 10px;font-size:.85rem;font-family:inherit;outline:none;transition:border-color .15s,box-shadow .15s}.dash-filter-group input[type=date]:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.dash-presets{display:flex;gap:4px;align-self:flex-end}.dash-preset-btn{height:34px;padding:0 10px;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.78rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .13s}.dash-preset-btn:hover{background:var(--accent-dim);color:var(--accent);border-color:var(--accent)}.dash-filter-btn{background:var(--accent);color:#fff;border:none;border-radius:var(--radius-md);padding:7px 18px;font-size:.85rem;font-weight:600;cursor:pointer;height:34px;display:flex;align-items:center;gap:6px;transition:opacity .15s}.dash-filter-btn:hover:not(:disabled){opacity:.88}.dash-filter-btn:disabled{opacity:.5;cursor:not-allowed}.dash-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}.dash-error{background:var(--red-dim);border:1px solid rgba(248,113,113,.25);border-radius:var(--radius-md);color:var(--red);font-size:.83rem;padding:10px 14px}.dash-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px}.dash-stat-card{background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--radius-lg);padding:18px 20px;display:flex;align-items:center;gap:14px;transition:box-shadow .2s}.dash-stat-card:hover{box-shadow:var(--shadow-md)}.dash-stat-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.dash-stat-accent .dash-stat-icon{background:var(--accent-dim);color:var(--accent)}.dash-stat-green .dash-stat-icon{background:var(--green-dim);color:var(--green)}.dash-stat-amber .dash-stat-icon{background:var(--amber-dim);color:var(--amber)}.dash-stat-purple .dash-stat-icon{background:#a78bfa24;color:#a78bfa}.dash-stat-value{font-size:1.45rem;font-weight:700;color:var(--text-primary);letter-spacing:-.5px;line-height:1.1}.dash-stat-label{font-size:.73rem;color:var(--text-muted);margin-top:3px}.dash-stat-sub{font-size:.73rem;color:var(--text-secondary);margin-top:2px}.dash-charts{display:grid;grid-template-columns:1fr 1fr;gap:14px}@media (max-width: 900px){.dash-charts{grid-template-columns:1fr}}@media (max-width: 600px){.dash-filters{gap:8px}.dash-presets{flex-wrap:wrap}.dash-cards{grid-template-columns:1fr 1fr}}.dash-chart-card{background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--radius-lg);padding:18px 20px}.dash-chart-title{font-size:.78rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:14px}.dash-chart-empty{font-size:.83rem;color:var(--text-muted);text-align:center;padding:24px 0}.bar-chart{width:100%}.bar-chart-inner{position:relative;padding-left:32px}.bar-chart-grid{position:absolute;top:0;right:0;bottom:24px;left:32px;pointer-events:none}.bar-grid-line{position:absolute;left:0;right:0;border-top:1px dashed var(--border);height:0}.bar-grid-label{position:absolute;left:-30px;top:-8px;font-size:.62rem;color:var(--text-muted);white-space:nowrap}.bar-chart-bars{display:flex;align-items:flex-end;gap:2px;height:140px;padding-bottom:24px;position:relative}.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;position:relative;cursor:default;min-width:0}.bar-value-tip{position:absolute;top:-16px;font-size:.6rem;color:var(--text-muted);white-space:nowrap;opacity:0;transition:opacity .1s;pointer-events:none}.bar-col:hover .bar-value-tip{opacity:1}.bar-fill{width:100%;min-height:2px;background:var(--accent);border-radius:3px 3px 0 0;transition:height .4s cubic-bezier(.4,0,.2,1);opacity:.8}.bar-col:hover .bar-fill{opacity:1;background:var(--accent-hover)}.bar-label{position:absolute;bottom:-20px;font-size:.62rem;color:var(--text-muted);white-space:nowrap;transform:translate(-50%) rotate(-35deg);transform-origin:top center;left:50%}.bar-label--hidden{visibility:hidden}.dash-tops{display:grid;grid-template-columns:1fr 1fr;gap:14px}@media (max-width: 900px){.dash-tops{grid-template-columns:1fr}}@media (max-width: 600px){.dash-tops{grid-template-columns:1fr}}.dash-top-card{background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--radius-lg);padding:18px 20px}.dash-top-table{width:100%;border-collapse:collapse;font-size:.82rem}.dash-top-table th{text-align:left;font-size:.7rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;padding:0 8px 10px 0;border-bottom:1px solid var(--border)}.dash-top-table td{padding:7px 8px 7px 0;color:var(--text-secondary);border-bottom:1px solid var(--border);vertical-align:middle}.dash-top-table tr:last-child td{border-bottom:none}.dash-top-rank{color:var(--text-muted);font-size:.75rem;width:22px}.dash-top-number{font-family:var(--font-mono);color:var(--text-primary)!important;font-size:.8rem}.dash-top-bar-wrap{display:flex;align-items:center;gap:8px}.dash-top-bar{height:5px;background:var(--accent);border-radius:3px;opacity:.6;min-width:4px;flex-shrink:0;max-width:80px}.dash-top-mins{color:var(--text-muted);font-size:.78rem;text-align:right}.active-wrap{display:flex;flex-direction:column;gap:16px;animation:fadeInUp .35s ease both}.active-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}.active-count-badge{display:flex;align-items:center;gap:8px;font-size:.88rem;font-weight:600;color:var(--text-primary)}.active-dot{width:8px;height:8px;border-radius:50%;background:var(--text-muted);flex-shrink:0}.active-dot--live{background:var(--green);animation:pulse 1.8s ease-in-out infinite}.active-refresh-info{display:flex;align-items:center;gap:8px;font-size:.75rem;color:var(--text-muted)}.active-reload-btn{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,color .15s}.active-reload-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--accent)}.active-reload-btn:disabled{opacity:.4;cursor:not-allowed}.active-error{background:var(--red-dim);border:1px solid rgba(248,113,113,.25);border-radius:var(--radius-md);color:var(--red);font-size:.83rem;padding:10px 14px}.active-empty{background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--radius-lg);padding:48px 24px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-muted)}.active-empty p{font-size:.88rem}.active-table-wrap{background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--radius-lg);overflow:hidden;overflow-x:auto;-webkit-overflow-scrolling:touch}.active-table{width:100%;border-collapse:collapse;font-size:.84rem}.active-table th{text-align:left;font-size:.7rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;padding:11px 16px;background:var(--bg-elevated);border-bottom:1px solid var(--border-strong)}.active-table td{padding:12px 16px;color:var(--text-secondary);border-bottom:1px solid var(--border);vertical-align:middle}.active-table tbody tr:last-child td{border-bottom:none}.active-table tbody tr{animation:fadeInUp .25s ease both;transition:background .12s}.active-table tbody tr:hover{background:var(--bg-hover)}.active-channel{font-family:var(--font-mono);font-size:.76rem;color:var(--text-muted)!important;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.active-party{display:flex;flex-direction:column;gap:2px}.active-num{font-family:var(--font-mono);font-size:.84rem;color:var(--text-primary)}.active-name{font-size:.72rem;color:var(--text-muted)}.active-duration{font-family:var(--font-mono);font-size:.88rem;font-weight:600;color:var(--green);background:var(--green-dim);border-radius:var(--radius-sm);padding:2px 8px;white-space:nowrap}.active-app{font-size:.78rem;color:var(--text-muted)!important}@media (max-width: 640px){.active-table th:nth-child(1),.active-table td:nth-child(1),.active-table th:nth-child(5),.active-table td:nth-child(5){display:none}}.fin-wrap{display:flex;flex-direction:column;gap:16px;animation:fadeInUp .35s ease both}.fin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px}.fin-stat-card{display:flex;align-items:center;gap:14px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;transition:transform .15s}.fin-stat-card:hover{transform:translateY(-2px)}.fin-stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.fin-stat-blue .fin-stat-icon{background:var(--accent-dim);color:var(--accent)}.fin-stat-amber .fin-stat-icon{background:var(--amber-dim);color:var(--amber)}.fin-stat-red .fin-stat-icon{background:var(--red-dim);color:var(--red)}.fin-stat-green .fin-stat-icon{background:var(--green-dim);color:var(--green)}.fin-stat-value{font-size:22px;font-weight:700;color:var(--text-primary);line-height:1.1}.fin-stat-label{font-size:11.5px;color:var(--text-muted);margin-top:2px}.fin-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.fin-filter-btns{display:flex;gap:4px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:3px;flex-wrap:wrap}.fin-filter-btn{padding:5px 13px;background:none;border:none;border-radius:calc(var(--radius-md) - 2px);color:var(--text-muted);font-size:12.5px;font-weight:500;cursor:pointer;transition:all .12s;font-family:var(--font-sans)}.fin-filter-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.fin-filter-btn.active{background:var(--accent);color:#fff}.fin-refresh-btn{display:flex;align-items:center;gap:7px;height:36px;padding:0 13px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-muted);font-size:11.5px;cursor:pointer;transition:all .15s;white-space:nowrap;font-family:var(--font-sans)}.fin-refresh-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-strong)}.fin-refresh-btn:disabled{opacity:.5;cursor:not-allowed}.fin-refresh-label{font-family:var(--font-mono);font-size:11px}.fin-error{background:var(--red-dim);border:1px solid rgba(248,113,113,.25);border-radius:var(--radius-md);color:var(--red);padding:12px 16px;font-size:13px}.fin-warning{background:var(--amber-dim);border:1px solid rgba(250,204,21,.3);border-radius:var(--radius-md);color:var(--amber);padding:12px 16px;font-size:13px}[data-theme=light] .fin-warning{color:#92400e;background:#fef3c7;border-color:#fde68a}.fin-loading,.fin-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px 0;color:var(--text-muted);font-size:13px}.fin-spinner{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.fin-spinner-sm{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.fin-table-wrap{background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--radius-lg);overflow:hidden;overflow-x:auto;-webkit-overflow-scrolling:touch}.fin-table{width:100%;border-collapse:collapse;font-size:.84rem}.fin-table th{text-align:left;font-size:.7rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;padding:11px 16px;background:var(--bg-elevated);border-bottom:1px solid var(--border-strong);white-space:nowrap}.fin-table td{padding:12px 16px;border-bottom:1px solid var(--border);vertical-align:middle}.fin-table tbody tr:last-child td{border-bottom:none}.fin-table tbody tr{transition:background .12s}.fin-table tbody tr:hover{background:var(--bg-hover)}.fin-id{font-family:var(--font-mono);font-size:.78rem;color:var(--text-muted);white-space:nowrap}.fin-desc{max-width:220px}.fin-desc-text{color:var(--text-primary);font-size:.85rem;display:block}.fin-client-name{font-size:.72rem;color:var(--text-muted);margin-top:2px;display:block}.fin-due{font-family:var(--font-mono);font-size:.82rem;color:var(--text-secondary);white-space:nowrap}.fin-due--overdue{color:var(--red);font-weight:600}[data-theme=light] .fin-due--overdue{color:#dc2626}.fin-amount{font-family:var(--font-mono);font-size:.9rem;font-weight:700;color:var(--text-primary);white-space:nowrap}.fin-status{display:inline-flex;align-items:center;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}.status-open{background:var(--amber-dim);color:var(--amber);border:1px solid rgba(250,204,21,.3)}.status-overdue{background:var(--red-dim);color:var(--red);border:1px solid rgba(248,113,113,.3)}.status-paid{background:var(--green-dim);color:var(--green);border:1px solid rgba(52,208,122,.3)}.status-pending{background:var(--accent-dim);color:var(--accent);border:1px solid rgba(74,108,247,.3)}.status-canceled{background:var(--bg-elevated);color:var(--text-muted);border:1px solid var(--border)}[data-theme=light] .status-open{color:#92400e;background:#fef3c7;border-color:#fde68a}[data-theme=light] .status-overdue{color:#dc2626;background:#fee2e2;border-color:#fca5a5}[data-theme=light] .status-paid{color:#15803d;background:#dcfce7;border-color:#86efac}[data-theme=light] .status-pending{color:#1d4ed8;background:#dbeafe;border-color:#93c5fd}.fin-actions{display:flex;gap:6px;align-items:center}.fin-btn{display:inline-flex;align-items:center;gap:5px;height:30px;padding:0 10px;border-radius:var(--radius-sm);font-size:11.5px;font-weight:600;cursor:pointer;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-secondary);text-decoration:none;transition:all .13s;font-family:var(--font-sans);white-space:nowrap}.fin-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-strong)}.fin-btn-pay{background:var(--accent-dim);color:var(--accent);border-color:#4a6cf74d}.fin-btn-pay:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.fin-btn-boleto{background:var(--amber-dim);color:var(--amber);border-color:#facc154d}.fin-btn-boleto:hover{background:var(--amber);color:#000;border-color:var(--amber)}.fin-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:300;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .15s ease}.fin-modal{background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:460px;max-height:90vh;overflow-y:auto;animation:slideUp .22s ease}.fin-modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 14px;border-bottom:1px solid var(--border)}.fin-modal-title{font-size:15px;font-weight:700;color:var(--text-primary)}.fin-modal-close{background:none;border:none;font-size:22px;color:var(--text-muted);cursor:pointer;line-height:1;padding:0 4px;transition:color .13s}.fin-modal-close:hover{color:var(--text-primary)}.fin-modal-invoice-info{padding:14px 20px;background:var(--bg-elevated);border-bottom:1px solid var(--border)}.fin-modal-inv-row{display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:13px;color:var(--text-secondary)}.fin-modal-amount{font-family:var(--font-mono);font-size:18px;font-weight:700;color:var(--text-primary)}.fin-modal-due{font-size:11.5px;color:var(--text-muted);margin-top:4px}.fin-modal-portador{font-size:11.5px;color:var(--text-muted);margin-top:2px}.fin-barcode-wrap{margin:14px 20px 0;background:var(--bg-elevated);border-radius:var(--radius-md);padding:12px;display:flex;flex-direction:column;gap:8px;align-items:center}.fin-barcode-label{font-size:10.5px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em}.fin-barcode-value{font-family:var(--font-mono);font-size:10px;color:var(--text-secondary);word-break:break-all;text-align:center;line-height:1.5}.fin-method-label{padding:16px 20px 10px;font-size:11.5px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em}.fin-methods{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:0 20px 16px}.fin-method-btn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:14px 10px;background:var(--bg-elevated);border:2px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all .13s;font-family:var(--font-sans)}.fin-method-btn:hover{background:var(--bg-hover);border-color:var(--border-strong);color:var(--text-primary)}.fin-method-btn.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.fin-method-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center}.fin-method-label-text{font-size:12px;font-weight:600}.fin-modal-error{margin:0 20px 12px;background:var(--red-dim);border:1px solid rgba(248,113,113,.25);border-radius:var(--radius-md);color:var(--red);font-size:12.5px;padding:10px 14px}.fin-pay-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:calc(100% - 40px);margin:0 20px 20px;height:44px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;box-shadow:0 2px 10px var(--accent-glow);transition:opacity .15s;font-family:var(--font-sans)}.fin-pay-btn:hover:not(:disabled){opacity:.88}.fin-pay-btn:disabled{opacity:.5;cursor:not-allowed}.fin-pay-btn--full{margin-top:16px}.fin-pix-panel{display:flex;flex-direction:column;align-items:center;gap:14px;padding:20px}.fin-pix-title{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:700;color:var(--text-primary)}.fin-pix-qr{width:180px;height:180px;border-radius:var(--radius-md);border:4px solid var(--bg-elevated)}.fin-pix-code-wrap{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%;background:var(--bg-elevated);border-radius:var(--radius-md);padding:12px}.fin-pix-code{font-family:var(--font-mono);font-size:10.5px;color:var(--text-muted);word-break:break-all;text-align:center}.fin-pix-copy{background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);padding:6px 16px;font-size:12px;font-weight:600;cursor:pointer;font-family:var(--font-sans);transition:opacity .13s}.fin-pix-copy:hover{opacity:.85}.fin-pix-expiry{font-size:12px;color:var(--text-muted);text-align:center}.fin-pix-done{width:100%;height:40px;background:var(--green-dim);color:var(--green);border:1px solid rgba(52,208,122,.3);border-radius:var(--radius-md);font-size:13px;font-weight:600;cursor:pointer;font-family:var(--font-sans);transition:all .13s}.fin-pix-done:hover{background:var(--green);color:#fff}[data-theme=light] .fin-pix-done{color:#15803d}[data-theme=light] .fin-pix-done:hover{color:#fff}.fin-boleto-panel{display:flex;flex-direction:column;align-items:center;gap:14px;padding:28px 20px;color:var(--text-muted)}.fin-boleto-panel p{font-size:14px;color:var(--text-primary)}.fin-boleto-btn{display:flex;align-items:center;gap:8px;background:var(--amber-dim);color:var(--amber);border:1px solid rgba(250,204,21,.3);border-radius:var(--radius-md);padding:10px 22px;font-size:13px;font-weight:600;text-decoration:none;transition:all .13s}.fin-boleto-btn:hover{background:var(--amber);color:#000}[data-theme=light] .fin-boleto-btn{color:#92400e}.fin-boleto-done{background:none;border:1px solid var(--border-strong);border-radius:var(--radius-md);padding:8px 20px;color:var(--text-muted);cursor:pointer;font-size:13px;font-family:var(--font-sans);transition:all .13s}.fin-boleto-done:hover{background:var(--bg-hover);color:var(--text-primary)}.fin-detail-grid{padding:16px 20px;display:flex;flex-direction:column;gap:8px;border-bottom:1px solid var(--border)}.fin-detail-row{display:flex;justify-content:space-between;align-items:center;gap:12px}.fin-detail-label{font-size:12px;color:var(--text-muted);min-width:90px;flex-shrink:0}.fin-detail-value{font-size:13px;color:var(--text-secondary);text-align:right}.fin-detail-value.bold{font-size:16px;font-weight:700;color:var(--text-primary);font-family:var(--font-mono)}.fin-detail-items{padding:14px 20px}.fin-detail-items-title{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:8px}.fin-detail-item{display:flex;justify-content:space-between;font-size:12.5px;color:var(--text-secondary);padding:5px 0;border-bottom:1px solid var(--border)}.fin-detail-item:last-child{border-bottom:none}@media (max-width: 640px){.fin-stats,.fin-methods{grid-template-columns:1fr 1fr}.fin-table th:nth-child(1),.fin-table td:nth-child(1){display:none}.fin-table th:nth-child(6),.fin-table td:nth-child(6){width:1%;white-space:nowrap}}@media (max-width: 400px){.fin-stats{grid-template-columns:1fr}}.toast-stack{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:8px;z-index:9999;pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:10px 14px 10px 12px;border-radius:var(--radius-md);border:1px solid;font-size:.83rem;font-weight:500;background:var(--bg-surface);box-shadow:var(--shadow-lg);pointer-events:all;animation:slideInRight .25s cubic-bezier(.4,0,.2,1) both;max-width:320px}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.toast--offline{color:var(--red);border-color:#f871714d;background:var(--bg-surface)}.toast--online{color:var(--green);border-color:#34d07a4d}.toast-icon{flex-shrink:0}.toast-msg{flex:1;color:var(--text-primary)}.toast-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1rem;line-height:1;padding:0 2px;flex-shrink:0}.toast-close:hover{color:var(--text-primary)}.app-layout{display:flex;min-height:100vh;background:var(--bg-base)}.main-area{flex:1;min-width:0;padding:24px 28px 120px;overflow-y:auto;background:var(--bg-base)}.module-content{position:relative}.module-progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:200;background:linear-gradient(90deg,var(--accent) 0%,rgba(91,138,240,.4) 50%,var(--accent) 100%);background-size:200% 100%;animation:progressSlide 1.2s ease-in-out infinite}@keyframes progressSlide{0%{background-position:200% 0}to{background-position:-200% 0}}.module-loading .table-card{opacity:.55;pointer-events:none;transition:opacity .2s}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;animation:fadeInUp .4s ease both}.header-left{display:flex;align-items:center;gap:14px}.header-icon{width:42px;height:42px;background:var(--accent-dim);border:1px solid var(--accent-glow);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0}.page-title{font-size:20px;font-weight:700;color:var(--text-primary);letter-spacing:-.4px;line-height:1.2}.page-subtitle{font-size:12.5px;color:var(--text-muted);margin-top:2px}.header-right{display:flex;align-items:center;gap:6px}.live-badge{display:flex;align-items:center;gap:6px;background:var(--green-dim);border:1px solid rgba(52,211,153,.2);border-radius:20px;padding:4px 10px 4px 8px;margin-right:4px}[data-theme=light] .live-badge{border-color:#05966933}.live-dot{width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulse 2.2s ease-in-out infinite;flex-shrink:0}.live-label{font-size:11.5px;color:var(--green);font-weight:500;letter-spacing:.01em}.header-user-chip{display:flex;align-items:center;gap:7px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:20px;padding:4px 10px 4px 8px;font-size:12px;color:var(--text-secondary)}.header-user-avatar{width:20px;height:20px;border-radius:50%;background:var(--accent-dim);border:1px solid var(--accent-glow);display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:9px;font-weight:700;flex-shrink:0;text-transform:uppercase}.theme-toggle{width:34px;height:34px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.theme-toggle:hover{background:var(--bg-hover);color:var(--amber);border-color:var(--border-strong)}.logout-btn{width:34px;height:34px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.logout-btn:hover{background:var(--red-dim);color:var(--red);border-color:#f8717140}[data-theme=light] .logout-btn:hover{border-color:#dc262640}.error-banner{background:var(--red-dim);border:1px solid rgba(248,113,113,.2);border-radius:var(--radius-md);padding:12px 16px;color:var(--red);font-size:13px;margin-bottom:16px;display:flex;align-items:center;gap:8px}.hamburger-btn{display:none;align-items:center;justify-content:center;width:36px;height:36px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;flex-shrink:0;transition:background .15s,color .15s}.hamburger-btn:hover{background:var(--bg-hover);color:var(--text-primary)}@media (max-width: 768px){.app-layout{display:block;min-height:100vh;min-height:100svh}.main-area{padding:14px 14px 140px;overflow-y:visible;overflow:visible;min-height:0}.hamburger-btn{display:flex}.page-header{flex-wrap:wrap;gap:10px}.header-right{flex-wrap:wrap;gap:6px}}@media (max-width: 400px){.header-user-chip,.live-badge{display:none}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-base: #0B1120;--bg-surface: #141C2E;--bg-elevated: #1C2640;--bg-hover: #1E2A48;--bg-active: #243256;--border: #1E293B;--border-strong: #2A3A52;--text-primary: #F5F7FA;--text-secondary:#8896AB;--text-muted: #5A6A80;--accent: #4A6CF7;--accent-hover: #7C9AFF;--accent-dim: #1A2654;--accent-glow: rgba(74,108,247,.3);--green: #34D07A;--green-dim: rgba(52,208,122,.14);--red: #F87171;--red-dim: rgba(248,113,113,.14);--amber: #FACC15;--amber-dim: rgba(250,204,21,.14);--radius-sm: 6px;--radius-md: 9px;--radius-lg: 13px;--radius-xl: 18px;--font-sans: "Inter", "DM Sans", system-ui, sans-serif;--font-mono: "JetBrains Mono", "DM Mono", monospace;--shadow-sm: 0 1px 3px rgba(0,0,0,.5);--shadow-md: 0 4px 20px rgba(0,0,0,.6);--shadow-lg: 0 10px 40px rgba(0,0,0,.7);--sidebar-width: 224px}[data-theme=light]{--bg-base: #F5F7FA;--bg-surface: #FFFFFF;--bg-elevated: #F1F5F9;--bg-hover: #E8ECF5;--bg-active: #DDE3F0;--border: #E8ECF1;--border-strong: #D0D7E3;--text-primary: #0F172A;--text-secondary:#475569;--text-muted: #64748B;--accent: #4A6CF7;--accent-hover: #2845B3;--accent-dim: #E8EEFF;--accent-glow: rgba(74,108,247,.2);--green: #22C55E;--green-dim: rgba(34,197,94,.12);--red: #EF4444;--red-dim: rgba(239,68,68,.12);--amber: #EAB308;--amber-dim: rgba(234,179,8,.12);--shadow-sm: 0 1px 4px rgba(15,23,42,.07);--shadow-md: 0 4px 20px rgba(15,23,42,.1);--shadow-lg: 0 10px 40px rgba(15,23,42,.13);--player-bg: rgba(255,255,255,.96)}body,.sidebar,.table-card,.filters-card,.stat-card,.player-bar,.login-card,.field-input,.page-btn,.action-btn,.nav-item,thead th,.rec-row{transition:background-color .22s ease,border-color .22s ease,color .18s ease,box-shadow .22s ease}html,body{height:100%;font-family:var(--font-sans);background:var(--bg-base);color:var(--text-primary);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100%;display:flex;flex-direction:column}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}input,select,button,textarea{font-family:var(--font-sans)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes wave{0%,to{transform:scaleY(1)}50%{transform:scaleY(.3)}}
