:root{--font-sora:"Sora",sans-serif;--font-inter:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--brand-primary:#1a56db;--brand-secondary:#0ea5e9;--brand-glow:rgba(26,86,219,.25);--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-tertiary:#334155;--bg-glass:rgba(30,41,59,.8);--bg-elevated:#1e293b;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--success-bg:rgba(16,185,129,.12);--danger-bg:rgba(239,68,68,.12);--warning-bg:rgba(245,158,11,.12);--info:#0ea5e9;--info-bg:rgba(14,165,233,.12);--purple-bg:rgba(139,92,246,.12);--card:#1e293b;--card-hover:#263548;--border:#334155;--border-light:#1e293b;--input-bg:#0f172a;--input-border:#334155;--hover-row:rgba(30,41,59,.5);--sidebar-bg:#0b1120;--sidebar-hover:rgba(26,86,219,.08);--sidebar-active:rgba(26,86,219,.15);--shadow-xs:0 1px 2px rgba(0,0,0,.2);--shadow-sm:0 1px 3px rgba(0,0,0,.25);--shadow-md:0 4px 8px rgba(0,0,0,.3);--shadow-lg:0 10px 20px rgba(0,0,0,.35);--shadow-xl:0 20px 40px rgba(0,0,0,.4);--shadow-glow:0 0 20px var(--brand-glow);--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--transition:200ms ease-in-out;--transition-fast:150ms ease-in-out;--modal-bg:#1e293b;--confirm-bg:#1e293b}[data-theme=light]{--bg-primary:#f0f2f5;--bg-secondary:#fff;--bg-tertiary:#f1f5f9;--bg-glass:hsla(0,0%,100%,.85);--bg-elevated:#fff;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--card:#fff;--card-hover:#f8fafc;--border:#e2e8f0;--border-light:#f1f5f9;--input-bg:#fff;--input-border:#cbd5e1;--hover-row:#f8fafc;--sidebar-bg:#0b1120;--modal-bg:#fff;--confirm-bg:#fff;--shadow-xs:0 1px 2px rgba(0,0,0,.04);--shadow-sm:0 1px 3px rgba(0,0,0,.06);--shadow-md:0 4px 6px rgba(0,0,0,.07);--shadow-lg:0 10px 15px rgba(0,0,0,.08);--shadow-xl:0 20px 25px rgba(0,0,0,.08);--success-bg:rgba(16,185,129,.08);--danger-bg:rgba(239,68,68,.08);--warning-bg:rgba(245,158,11,.08);--info-bg:rgba(14,165,233,.08);--purple-bg:rgba(139,92,246,.08)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--primary:#1a56db;--primary-hover:#1447b8;--primary-light:rgba(26,86,219,.08);--primary-glow:rgba(26,86,219,.25);--success:#10b981;--success-light:rgba(16,185,129,.08);--warning:#f59e0b;--warning-light:rgba(245,158,11,.08);--danger:#ef4444;--danger-light:rgba(239,68,68,.08);--purple:#8b5cf6;--purple-light:rgba(139,92,246,.08);--bg:#f0f2f5;--bg-elevated:#fff;--card:#fff;--card-hover:#fafbfc;--border:#e5e7eb;--border-light:#f3f4f6;--text:#111827;--text-secondary:#6b7280;--text-muted:#9ca3af;--sidebar-bg:#0c1222;--sidebar-surface:#131b2e;--sidebar-hover:rgba(59,130,246,.06);--sidebar-active:rgba(59,130,246,.12);--sidebar-text:#8b95a5;--sidebar-text-active:#fff;--sidebar-border:hsla(0,0%,100%,.04);--radius:10px;--radius-lg:14px;--radius-xl:18px;--shadow-xs:0 1px 2px rgba(0,0,0,.04);--shadow-sm:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.03);--shadow-md:0 4px 6px -1px rgba(0,0,0,.07),0 2px 4px -2px rgba(0,0,0,.04);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.08),0 4px 6px -4px rgba(0,0,0,.03);--shadow-xl:0 20px 25px -5px rgba(0,0,0,.08),0 8px 10px -6px rgba(0,0,0,.03);--input-bg:#fff;--input-border:#d1d5db;--input-focus:var(--primary);--modal-bg:#fff;--confirm-bg:#fff;--hover-row:#f9fafb;--bg-gray:#f1f5f9;--tr:all 0.2s cubic-bezier(0.4,0,0.2,1);--tr-fast:all 0.15s cubic-bezier(0.4,0,0.2,1)}[data-theme=dark]{--bg:#080d19;--bg-elevated:#0f1729;--card:#131b2e;--card-hover:#182240;--border:#1e293b;--border-light:#1a2332;--text:#e8edf5;--text-secondary:#8b95a5;--text-muted:#5b6577;--sidebar-bg:#060a14;--sidebar-surface:#0a1020;--primary-light:rgba(26,86,219,.12);--success-light:rgba(16,185,129,.12);--warning-light:rgba(245,158,11,.12);--danger-light:rgba(239,68,68,.12);--purple-light:rgba(139,92,246,.12);--input-bg:#0f1729;--input-border:#1e293b;--modal-bg:#131b2e;--confirm-bg:#131b2e;--hover-row:#182240;--bg-gray:#1a2332;--shadow-xs:0 1px 2px rgba(0,0,0,.15);--shadow-sm:0 1px 3px rgba(0,0,0,.2);--shadow-md:0 4px 6px rgba(0,0,0,.2);--shadow-lg:0 10px 15px rgba(0,0,0,.3);--shadow-xl:0 20px 25px rgba(0,0,0,.35)}[data-theme=dark] .badge-success{background:rgba(16,185,129,.15);color:#34d399}[data-theme=dark] .badge-warning{background:rgba(245,158,11,.15);color:#fbbf24}[data-theme=dark] .badge-danger{background:rgba(239,68,68,.15);color:#f87171}[data-theme=dark] .badge-info{background:rgba(26,86,219,.15);color:#60a5fa}[data-theme=dark] .badge-purple{background:rgba(139,92,246,.15);color:#a78bfa}[data-theme=dark] .badge-default{background:hsla(220,9%,46%,.15);color:#9ca3af}[data-theme=dark] tbody tr:hover{background:var(--hover-row)}[data-theme=dark] .btn-icon{background:var(--card);border-color:var(--border);color:var(--text-secondary)}[data-theme=dark] .form-input,[data-theme=dark] .form-select,[data-theme=dark] .form-textarea{background:var(--input-bg);color:var(--text);border-color:var(--input-border)}[data-theme=dark] .form-chip{background:var(--input-bg);color:var(--text-secondary);border-color:var(--border)}[data-theme=dark] .modal-content{background:var(--modal-bg)}[data-theme=dark] .confirm-box{background:var(--confirm-bg)}[data-theme=dark] .login-card{background:var(--card);color:var(--text)}[data-theme=dark] .login-card input{background:var(--input-bg);color:var(--text);border-color:var(--border)}[data-theme=dark] .export-card{background:var(--card);border-color:var(--border)}[data-theme=dark] .toast{background:var(--card);color:var(--text)}[data-theme=dark] .company-card{background:var(--card);border-color:var(--border)}[data-theme=dark] .kpi-card .kpi-icon{opacity:.9}[data-theme=dark] code{background:var(--input-bg);color:var(--text)}body{font-family:var(--font-inter),-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.loading,.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg)}.loading-inner{display:flex;flex-direction:column;align-items:center;gap:16px;color:var(--text-muted);font-weight:500}.spinner,.spinner-ring{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.app-layout{display:flex;min-height:100vh}.sidebar{width:264px;background:var(--sidebar-bg);color:var(--sidebar-text);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:50;overflow-y:auto;overflow-x:hidden;border-right:1px solid var(--sidebar-border)}.sidebar::-webkit-scrollbar{width:3px}.sidebar::-webkit-scrollbar-thumb{background:hsla(0,0%,100%,.06);border-radius:3px}.sidebar-logo{padding:24px 20px 20px;gap:14px;border-bottom:1px solid var(--sidebar-border)}.logo-icon,.sidebar-logo{display:flex;align-items:center}.logo-icon{width:42px;height:42px;justify-content:center;flex-shrink:0}.logo-icon img{width:42px;height:42px;object-fit:contain;filter:brightness(1.1)}.sidebar-logo h2{font-size:15px;font-weight:800;font-family:var(--font-sora),sans-serif;letter-spacing:-.02em;line-height:1.2;color:#fff}.sidebar-logo small{font-size:10px;color:var(--sidebar-text);display:block;margin-top:2px;font-weight:500;opacity:.6}.nav-section{padding:16px 12px 4px}.nav-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.6px;color:rgba(139,149,165,.4);padding:0 10px 10px}.nav-item{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:8px;color:var(--sidebar-text);text-decoration:none;font-size:13px;font-weight:500;transition:var(--tr-fast);cursor:pointer;background:none;border:none;width:100%;margin-bottom:1px;position:relative}.nav-item:hover{background:var(--sidebar-hover);color:#c8d0dc}.nav-item.active{background:var(--sidebar-active);color:var(--primary);font-weight:600}.nav-item.active:before{content:"";position:absolute;left:-12px;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--primary);border-radius:0 3px 3px 0}.nav-item i{width:18px;text-align:center;font-size:13px;opacity:.7}.nav-item.active i{opacity:1}.nav-badge{background:var(--danger);color:#fff;font-size:10px;font-weight:700;padding:1px 7px;border-radius:10px;margin-left:auto;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.main-wrapper{margin-left:264px;flex:1 1;display:flex;flex-direction:column;min-height:100vh}.topbar{justify-content:space-between;padding:12px 36px;background:var(--card);border-bottom:1px solid var(--border);position:-webkit-sticky;position:sticky;top:0;z-index:40;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.topbar,.topbar-left{display:flex;align-items:center}.topbar-left{gap:12px}.topbar-greeting{font-size:13px;color:var(--text-secondary)}.topbar-greeting strong{color:var(--text)}.topbar-right{display:flex;align-items:center;gap:12px}.topbar-clock{gap:8px;font-size:12px;color:var(--text-muted);padding:6px 12px;border-radius:8px}.topbar-clock,.topbar-user{display:flex;align-items:center;background:var(--bg)}.topbar-user{gap:10px;padding:5px 12px 5px 5px;border-radius:10px;border:1px solid var(--border)}.topbar-user-avatar{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-weight:700;flex-shrink:0}.topbar-user-info{line-height:1.3}.topbar-user-name{font-size:12px;font-weight:700;color:var(--text)}.topbar-user-role{font-size:10px;color:var(--text-muted)}.main-content{flex:1 1;padding:28px 36px;background:var(--bg)}.page-header{justify-content:space-between;margin-bottom:28px}.page-header,.page-title{display:flex;align-items:center}.page-title{font-size:22px;font-weight:800;font-family:var(--font-sora),sans-serif;color:var(--text);letter-spacing:-.03em;gap:10px}.page-title i{color:var(--primary);font-size:20px;opacity:.8}.page-actions{display:flex;align-items:center;gap:8px}.success{color:var(--success)}.danger{color:var(--danger)}.warning{color:var(--warning)}.info{color:var(--primary)}.section-card{background:var(--card);border-radius:var(--radius-lg);border:1px solid var(--border);padding:24px;margin-bottom:20px;transition:var(--tr);overflow-x:auto}.section-card::-webkit-scrollbar{height:5px}.section-card::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.section-header h3{font-size:15px;font-weight:700;letter-spacing:-.01em}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));grid-gap:16px;gap:16px;margin-bottom:24px}.kpi-card{background:var(--card);border-radius:var(--radius-lg);border:1px solid var(--border);padding:20px 22px;display:flex;align-items:center;gap:16px;transition:var(--tr)}.kpi-card:after{content:"";position:absolute;top:0;left:0;width:3px;height:100%;border-radius:0 3px 3px 0}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.kpi-card.blue:after{background:var(--primary)}.kpi-card.green:after{background:var(--success)}.kpi-card.orange:after{background:var(--warning)}.kpi-card.red:after{background:var(--danger)}.kpi-card.purple:after{background:var(--purple)}.kpi-icon{width:44px;height:44px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.kpi-card.blue .kpi-icon{background:var(--primary-light);color:var(--primary)}.kpi-card.green .kpi-icon{background:var(--success-light);color:var(--success)}.kpi-card.orange .kpi-icon{background:var(--warning-light);color:var(--warning)}.kpi-card.red .kpi-icon{background:var(--danger-light);color:var(--danger)}.kpi-card.purple .kpi-icon{background:var(--purple-light);color:var(--purple)}.kpi-val{font-size:24px;font-weight:800;line-height:1;letter-spacing:-.03em;font-family:JetBrains Mono,monospace}.kpi-label{font-size:12px;color:var(--text-muted);margin-top:4px;font-weight:500}table{width:100%;border-collapse:collapse}thead th{text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);padding:12px 16px;border-bottom:1px solid var(--border);white-space:nowrap;background:transparent}tbody td{padding:13px 16px;border-bottom:1px solid var(--border-light);font-size:13px;vertical-align:middle}tbody tr{transition:background .12s}tbody tr:hover{background:var(--hover-row)}tbody tr:last-child td{border-bottom:none}.empty-row{text-align:center;padding:52px!important;color:var(--text-muted);font-style:italic}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap;gap:4px;letter-spacing:.01em}.badge-success{background:var(--success-light);color:var(--success)}.badge-warning{background:var(--warning-light);color:var(--warning)}.badge-danger{background:var(--danger-light);color:var(--danger)}.badge-info{background:var(--primary-light);color:var(--primary)}.badge-purple{background:var(--purple-light);color:var(--purple)}.badge-default{background:hsla(220,9%,46%,.08);color:#6b7280}.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:8px;font-size:13px;font-weight:600;border:none;cursor:pointer;transition:var(--tr);font-family:inherit;letter-spacing:-.01em}.btn:active{transform:scale(.97)}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 1px 2px rgba(26,86,219,.2)}.btn-primary:hover{background:var(--primary-hover);box-shadow:0 4px 12px rgba(26,86,219,.25)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#059669}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn-outline{background:transparent;border:1.5px solid var(--border);color:var(--text-secondary)}.btn-outline:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.btn-sm{padding:6px 12px;font-size:12px;border-radius:6px}.btn-icon{width:34px;height:34px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;border:1px solid var(--border);background:var(--card);cursor:pointer;color:var(--text-secondary);transition:var(--tr)}.btn-icon:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.btn-group{display:flex;gap:6px}.avatar{width:38px;height:38px;border-radius:10px;object-fit:cover;border:2px solid var(--border);background:var(--bg);flex-shrink:0}.avatar-sm{width:28px;height:28px;border-radius:8px}.avatar-lg{width:52px;height:52px;border-radius:12px}.user-cell{display:flex;align-items:center;gap:10px}.user-name{font-weight:600;color:var(--text)}.user-sub{font-size:11px;color:var(--text-muted)}.form-group{margin-bottom:16px}.form-label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px;letter-spacing:.01em}.form-input,.form-select,.form-textarea{width:100%;padding:10px 14px;border:1.5px solid var(--input-border);border-radius:8px;font-size:13px;color:var(--text);background:var(--input-bg);transition:var(--tr);font-family:inherit}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.form-textarea{min-height:80px;resize:vertical}.form-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:14px;gap:14px}.form-chip-row{display:flex;gap:6px;flex-wrap:wrap}.form-chip{padding:7px 16px;border-radius:20px;font-size:12px;font-weight:600;border:1.5px solid var(--border);background:var(--card);cursor:pointer;transition:var(--tr);-webkit-user-select:none;-moz-user-select:none;user-select:none}.form-chip:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-1px)}.form-chip.active{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 2px 8px rgba(26,86,219,.25)}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:100;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s;pointer-events:auto}.modal-content{background:var(--modal-bg);border-radius:var(--radius-xl);width:560px;max-width:95vw;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl),0 0 0 1px rgba(0,0,0,.05);animation:modalSlide .25s cubic-bezier(.16,1,.3,1);pointer-events:auto;border:1px solid var(--border)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:22px 26px;border-bottom:1px solid var(--border)}.modal-header h3{font-size:16px;font-weight:700;letter-spacing:-.02em}.modal-close{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:8px;border:none;background:transparent;cursor:pointer;font-size:18px;color:var(--text-muted);transition:var(--tr)}.modal-close:hover{background:var(--bg);color:var(--text)}.modal-body{padding:26px}.modal-footer{padding:16px 26px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}.modal-wide{width:720px;max-width:95vw}@keyframes modalSlide{0%{transform:translateY(12px) scale(.98);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.toast-container{position:fixed;top:20px;right:20px;z-index:200;display:flex;flex-direction:column;gap:10px}.toast{display:flex;align-items:center;gap:10px;padding:14px 20px;border-radius:var(--radius);background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow-lg);animation:toastSlide .3s cubic-bezier(.16,1,.3,1);min-width:320px;max-width:440px}.toast-success{border-left:3px solid var(--success)}.toast-error{border-left:3px solid var(--danger)}.toast-info{border-left:3px solid var(--primary)}.toast-warning{border-left:3px solid var(--warning)}.toast-icon{font-size:16px;flex-shrink:0}.toast-success .toast-icon{color:var(--success)}.toast-error .toast-icon{color:var(--danger)}.toast-info .toast-icon{color:var(--primary)}.toast-warning .toast-icon{color:var(--warning)}.toast-msg{flex:1 1;font-size:13px;font-weight:500;line-height:1.4}.toast-close{cursor:pointer;color:var(--text-muted);border:none;background:none;font-size:16px;padding:4px;transition:var(--tr)}.toast-close:hover{color:var(--text)}@keyframes toastSlide{0%{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:16px;gap:16px}.company-card{background:var(--card);border-radius:var(--radius-lg);padding:22px;border:1px solid var(--border);transition:var(--tr);cursor:pointer}.company-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.company-card h4{font-size:15px;font-weight:700;margin-bottom:4px}.company-stats{display:flex;gap:10px;margin-top:10px;align-items:center;flex-wrap:wrap}.muted{color:var(--text-muted);font-size:12px}.filters-row{display:flex;align-items:center;gap:10px;margin-bottom:18px;flex-wrap:wrap;padding-bottom:4px}.filters-row input,.filters-row select{padding:8px 14px;border:1.5px solid var(--border);border-radius:8px;font-size:13px;transition:var(--tr);background:var(--card);color:var(--text);font-family:inherit}.filters-row input:focus,.filters-row select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.search-box{position:relative}.search-box input{padding-left:36px;width:260px}.search-box i{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:13px}.export-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));grid-gap:16px;gap:16px;margin-top:16px}.export-card{background:var(--card);border-radius:var(--radius-lg);padding:22px;border:1px solid var(--border);text-align:center;transition:var(--tr)}.export-card:hover{border-color:var(--primary);box-shadow:var(--shadow-sm)}.export-card h4{margin-bottom:14px;font-weight:700}.export-btns{gap:8px}.export-btns,.login-page{display:flex;justify-content:center}.login-page{min-height:100vh;align-items:center;background:var(--sidebar-bg);position:relative;overflow:hidden}.login-page:before{width:800px;height:800px;background:radial-gradient(circle,rgba(59,130,246,.06),transparent 70%);top:-300px;right:-300px}.login-page:after,.login-page:before{content:"";position:absolute;border-radius:50%;pointer-events:none}.login-page:after{width:600px;height:600px;background:radial-gradient(circle,rgba(139,92,246,.04),transparent 70%);bottom:-200px;left:-200px}.login-card{background:#fff;padding:48px 44px;border-radius:var(--radius-xl);width:400px;text-align:center;box-shadow:var(--shadow-xl);position:relative;z-index:1;border:1px solid hsla(0,0%,100%,.06)}.login-logo{margin-bottom:10px}.login-logo img{width:80px;height:80px;object-fit:contain}.login-card h2{font-size:20px;font-weight:800;font-family:var(--font-sora),sans-serif;margin-bottom:4px;letter-spacing:-.03em}.login-sub{color:var(--text-muted);font-size:13px;margin-bottom:32px}.login-card form{display:flex;flex-direction:column;gap:12px}.login-card input{padding:12px 16px;border:1.5px solid var(--border);border-radius:8px;font-size:14px;transition:var(--tr);font-family:inherit}.login-card input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.login-card button{padding:12px;background:var(--primary);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer;transition:var(--tr);font-family:inherit}.login-card button:hover{background:var(--primary-hover);box-shadow:0 4px 14px rgba(26,86,219,.3);transform:translateY(-1px)}.login-error{color:var(--danger);font-size:12px;font-weight:600;padding:8px;background:var(--danger-light);border-radius:6px}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:6px;flex-shrink:0}.status-dot.on_duty{background:var(--success);box-shadow:0 0 6px rgba(16,185,129,.4)}.status-dot.patroli{background:var(--primary);box-shadow:0 0 6px rgba(59,130,246,.4)}.status-dot.break{background:var(--warning)}.status-dot.off_duty{background:var(--text-muted)}.status-dot.active{background:var(--success);box-shadow:0 0 6px rgba(16,185,129,.4)}.status-dot.inactive{background:var(--text-muted)}.detail-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:14px;gap:14px}.detail-item{padding:10px 0}.detail-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.detail-value{font-size:14px;font-weight:500;margin-top:3px}.foto-gallery{display:flex;gap:8px;flex-wrap:wrap}.foto-thumb{width:52px;height:52px;border-radius:8px;object-fit:cover;border:2px solid var(--border);cursor:pointer;transition:var(--tr)}.foto-thumb:hover{border-color:var(--primary);transform:scale(1.06)}.confirm-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:150;display:flex;align-items:center;justify-content:center}.confirm-box{background:var(--confirm-bg);border-radius:var(--radius-xl);padding:36px;width:420px;text-align:center;box-shadow:var(--shadow-xl);animation:modalSlide .25s cubic-bezier(.16,1,.3,1);border:1px solid var(--border)}.confirm-box h4{font-size:17px;margin-bottom:8px;font-weight:700}.confirm-box p{color:var(--text-secondary);font-size:13px;margin-bottom:24px;line-height:1.5}.confirm-btns{display:flex;gap:8px;justify-content:center}.bar-chart{display:flex;align-items:flex-end;gap:8px;height:180px;padding:16px 0}.bar-col{flex:1 1;display:flex;flex-direction:column;align-items:center;gap:4px}.bar-val{font-size:11px;font-weight:700;color:var(--text);font-family:JetBrains Mono,monospace}.bar-fill{width:100%;border-radius:6px 6px 0 0;min-height:4px;transition:height .5s cubic-bezier(.16,1,.3,1);background:var(--primary)}.bar-label{font-size:10px;color:var(--text-muted);font-weight:500}.topbar-controls{display:flex;align-items:center;gap:10px}.lang-toggle,.theme-toggle{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:8px;border:1.5px solid var(--border);background:var(--card);cursor:pointer;font-size:12px;font-weight:600;color:var(--text-secondary);transition:var(--tr);font-family:inherit}.lang-toggle:hover,.theme-toggle:hover{border-color:var(--primary);color:var(--primary)}.lang-toggle .lang-active{background:var(--primary);color:#fff;padding:2px 8px;border-radius:4px}.lang-toggle .lang-inactive{padding:2px 8px;opacity:.5}@media (min-width:1440px){.main-content{padding:32px 48px;max-width:1600px}.kpi-grid{grid-template-columns:repeat(6,1fr)}.section-card{padding:28px}table{font-size:14px}}@media (max-width:1200px){table{font-size:12px}thead th{font-size:10px}tbody td{padding:10px 12px}.main-content{padding:22px 26px}}@media (max-width:1024px){.sidebar{width:240px}.main-wrapper{margin-left:240px}.main-content{padding:20px 22px}.kpi-grid{grid-template-columns:repeat(3,1fr)}.page-title{font-size:20px}.card-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}}@media (max-width:900px){.sidebar{width:220px}.main-wrapper{margin-left:220px}.main-content{padding:18px 20px}.topbar{padding:10px 20px}.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.sidebar{display:none}.main-wrapper{margin-left:0}.main-content{padding:16px}.topbar{padding:10px 16px}.topbar-clock,.topbar-greeting{display:none}.form-row{grid-template-columns:1fr}.kpi-grid{grid-template-columns:1fr 1fr}.page-title{font-size:18px}.login-card{width:90vw;padding:32px 24px}}@media (max-width:480px){.kpi-grid{grid-template-columns:1fr}.filters-row{flex-direction:column;align-items:stretch}.search-box input{width:100%}}@media (max-width:375px){.main-content{padding:12px}.page-title{font-size:16px}.login-card{width:95vw;padding:24px 16px}.login-card h2{font-size:18px}.section-card{padding:12px}table{font-size:11px}thead th{font-size:9px}tbody td,thead th{padding:8px 6px}.kpi-card{padding:12px}.kpi-val{font-size:20px}.kpi-label{font-size:10px}.topbar{padding:8px 12px}.filters-row{gap:6px}.btn{padding:8px 12px;font-size:12px}}h1,h2,h3,h4,h5,h6{font-family:var(--font-sora),sans-serif}.kpi-val{font-family:var(--font-sora),monospace}.panic-banner{position:fixed;top:0;left:0;right:0;z-index:9999;background:linear-gradient(135deg,#7f1d1d,#ef4444);color:#fff;padding:12px 24px;display:flex;align-items:center;justify-content:center;gap:12px;font-weight:700;animation:slideDown .3s ease,flashBorder 2s infinite}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}@keyframes flashBorder{0%,to{box-shadow:0 2px 10px rgba(239,68,68,.5)}50%{box-shadow:0 2px 20px rgba(239,68,68,.9)}}.kpi-card{position:relative;overflow:hidden}.kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--brand-primary),var(--brand-secondary));border-radius:var(--radius-lg) var(--radius-lg) 0 0}.kpi-card:hover{border-color:var(--brand-primary);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.badge-live{animation:badgePulse 2s infinite}@keyframes badgePulse{0%,to{opacity:1;box-shadow:0 0 0 0 rgba(239,68,68,.4)}50%{opacity:.8;box-shadow:0 0 0 6px rgba(239,68,68,0)}}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-secondary) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-md)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.slide-panel-overlay{left:0;background:rgba(0,0,0,.5);z-index:1000;animation:fadeIn .2s ease}.slide-panel,.slide-panel-overlay{position:fixed;top:0;right:0;bottom:0}.slide-panel{width:480px;max-width:90vw;background:var(--bg-secondary);z-index:1001;box-shadow:var(--shadow-xl);overflow-y:auto;animation:slideInRight .3s ease;padding:24px}@keyframes slideInRight{0%{transform:translateX(100%)}to{transform:translateX(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.slide-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--border)}.slide-panel-header h3{margin:0}.slide-panel-close{background:none;border:none;color:var(--text-secondary);font-size:20px;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm)}.slide-panel-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;padding:6px 10px;border-radius:var(--radius-sm);transition:var(--transition)}.btn-ghost:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-sm{padding:6px 10px;font-size:13px}