@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#08090d;--surface:#111318;--surface2:#1a1d25;--border:#ffffff12;--primary:#3b82f6;--primary-glow:#3b82f640;--success:#22c55e;--danger:#ef4444;--purple:#a78bfa;--text:#f1f5f9;--text-muted:#64748b;--sidebar-w:240px;--radius:12px;--radius-sm:8px;--sidebar-bg:#0d0f14;--shadow:0 4px 24px #0006}[data-theme=light]{--bg:#f0f4f8;--surface:#fff;--surface2:#e8edf3;--border:#00000017;--primary:#2563eb;--primary-glow:#2563eb26;--success:#16a34a;--danger:#dc2626;--purple:#7c3aed;--text:#0f172a;--text-muted:#64748b;--sidebar-bg:#1e293b;--shadow:0 4px 24px #0000001a}body,.sidebar,.card,.stat-card,.nav-item,.modal-overlay,input,button,table,th,td{transition:background .25s,color .2s,border-color .2s,box-shadow .2s}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:Inter,sans-serif}.layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--sidebar-bg);border-right:1px solid var(--border);z-index:100;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-brand{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:24px 20px 20px;display:flex}.brand-icon{color:var(--primary);filter:drop-shadow(0 0 8px var(--primary));font-size:22px}.brand-text{letter-spacing:.5px;color:#fff;font-size:17px;font-weight:700}.sidebar-nav{flex-direction:column;flex:1;gap:4px;padding:16px 12px;display:flex}.nav-item{border-radius:var(--radius-sm);color:var(--text-muted);align-items:center;gap:12px;padding:11px 14px;font-size:14px;font-weight:500;text-decoration:none;transition:all .18s;display:flex}.nav-item:hover{background:var(--surface2);color:var(--text)}.nav-item.active{color:var(--primary);background:#3b82f61f;border:1px solid #3b82f633}.nav-icon{font-size:16px}.sidebar-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 14px;display:flex}.user-info{align-items:center;gap:10px;display:flex}.user-avatar{background:linear-gradient(135deg, var(--primary), var(--purple));border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:flex}.user-name{font-size:13px;font-weight:500}.logout-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px;font-size:18px;transition:color .15s}.logout-btn:hover{color:var(--danger)}.main-content{margin-left:var(--sidebar-w);flex:1;min-height:100vh;overflow-y:auto}.page{max-width:1400px;padding:32px 28px}.page-header{align-items:center;gap:14px;margin-bottom:28px;display:flex}.page-title{font-size:22px;font-weight:700}.page-count{color:var(--text-muted);background:var(--surface2);border-radius:20px;padding:3px 10px;font-size:13px}.live-badge{color:var(--success);background:#22c55e1a;border:1px solid #22c55e40;border-radius:20px;padding:3px 10px;font-size:12px;font-weight:600;animation:2s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.card-title{font-size:14px;font-weight:600}.dot-green{background:var(--success);border-radius:50%;width:8px;height:8px;animation:2s infinite pulse}.stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}@media (width<=1100px){.stats-grid{grid-template-columns:repeat(2,1fr)}}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:16px;padding:22px 20px;transition:border-color .2s,transform .2s;display:flex}.stat-card:hover{border-color:#ffffff24;transform:translateY(-2px)}.stat-icon{font-size:28px}.stat-value{font-size:30px;font-weight:700;line-height:1}.stat-label{color:var(--text-muted);margin-top:4px;font-size:12px}.dashboard-bottom{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (width<=900px){.dashboard-bottom{grid-template-columns:1fr}}.cam-stream{aspect-ratio:1;object-fit:cover;background:#000;width:100%;display:block}.cam-error{min-height:260px;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:10px;font-size:14px;display:flex}.cam-error span{font-size:48px}.recent-list{flex-direction:column;display:flex}.recent-row{border-bottom:1px solid var(--border);cursor:pointer;align-items:center;gap:14px;padding:12px 20px;transition:background .15s;display:flex}.recent-row:last-child{border-bottom:none}.recent-row:hover{background:var(--surface2)}.recent-thumb{background:var(--surface2);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:22px;display:flex;overflow:hidden}.recent-thumb img{object-fit:cover;width:100%;height:100%}.recent-info{flex:1;min-width:0}.plate-number{font-size:15px;font-weight:600;display:block}.recent-time{color:var(--text-muted);font-size:12px}.status-tag{text-transform:uppercase;letter-spacing:.5px;border-radius:20px;padding:3px 9px;font-size:11px;font-weight:700}.tag-authorized{color:var(--success);background:#22c55e1f;border:1px solid #22c55e40}.tag-unknown{color:var(--danger);background:#ef44441f;border:1px solid #ef444440}.plate-badge{background:var(--surface2);border:1px solid var(--border);letter-spacing:1px;border-radius:6px;padding:3px 10px;font-family:Inter,monospace;font-size:13px;font-weight:700}.empty-state{text-align:center;color:var(--text-muted);padding:40px 0;font-size:14px}.data-table{border-collapse:collapse;width:100%}.data-table th{text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);text-align:left;border-bottom:1px solid var(--border);padding:12px 16px;font-size:11px;font-weight:600}.data-table td{vertical-align:middle;padding:12px 16px;font-size:13px}.table-row{border-bottom:1px solid var(--border);transition:background .15s}.table-row:hover{background:var(--surface2)}.table-row:last-child{border-bottom:none}.td-id{color:var(--text-muted);font-size:12px}.td-time{color:var(--text-muted);white-space:nowrap;font-size:12px}.td-notes{text-overflow:ellipsis;white-space:nowrap;max-width:160px;color:var(--text-muted);overflow:hidden}.thumb{object-fit:cover;cursor:pointer;background:var(--surface2);border-radius:6px;width:44px;height:44px;transition:opacity .15s}.thumb:hover{opacity:.8}.no-img{color:var(--text-muted)}.empty-cell{text-align:center;color:var(--text-muted);padding:40px}.conf-bar-wrap{align-items:center;gap:8px;display:flex}.conf-bar{background:linear-gradient(90deg, var(--primary), var(--purple));border-radius:4px;min-width:2px;max-width:80px;height:4px;transition:width .3s}.conf-value{color:var(--text-muted);white-space:nowrap;font-size:12px}.filter-row{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:18px;display:flex}.filter-pill{border:1px solid var(--border);background:var(--surface);color:var(--text-muted);cursor:pointer;border-radius:20px;padding:6px 14px;font-size:13px;transition:all .15s}.filter-pill:hover{border-color:var(--primary);color:var(--text)}.filter-pill.active{color:var(--primary);background:#3b82f61f;border-color:#3b82f64d}.btn-sm{border:1px solid var(--border);background:var(--surface);color:var(--text-muted);cursor:pointer;border-radius:20px;padding:6px 14px;font-size:13px;transition:all .15s}.btn-refresh{margin-left:auto}.btn-refresh:hover{color:var(--primary);border-color:var(--primary)}.pagination{justify-content:center;align-items:center;gap:16px;margin-top:20px;display:flex}.page-btn{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;padding:7px 18px;font-size:13px;transition:all .15s}.page-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.page-btn:disabled{opacity:.35;cursor:default}.page-info{color:var(--text-muted);font-size:13px}.whitelist-grid{grid-template-columns:320px 1fr;align-items:start;gap:20px;display:grid}@media (width<=900px){.whitelist-grid{grid-template-columns:1fr}}.add-form{flex-direction:column;gap:14px;padding:20px;display:flex}.search-input{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);outline:none;padding:6px 12px;font-family:inherit;font-size:13px;transition:border-color .15s}.search-input:focus{border-color:var(--primary)}.btn-delete{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:14px;transition:all .15s}.btn-delete:hover{color:var(--danger);background:#ef44441a}.cam-full-card{border-radius:var(--radius);border:1px solid var(--border);background:#000;min-height:380px;margin-bottom:20px;position:relative;overflow:hidden}.cam-stream-full{object-fit:contain;width:100%;max-height:70vh;display:block}.cam-loading{min-height:380px;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.cam-error-icon{font-size:60px}.cam-error-hint{color:var(--text-muted);font-size:12px}.cam-info{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:10px;padding:16px 20px;display:flex}.cam-info-row{gap:12px;font-size:13px;display:flex}.cam-label{color:var(--text-muted);min-width:100px}.cam-value{color:var(--text);font-family:monospace}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--text-muted);font-size:12px;font-weight:600}.form-group input,.form-group textarea{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);outline:none;padding:10px 12px;font-family:inherit;font-size:14px;transition:border-color .15s}.form-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.btn-primary{background:linear-gradient(135deg, var(--primary), #2563eb);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;padding:11px 22px;font-family:inherit;font-size:14px;font-weight:600;transition:opacity .15s,transform .15s;display:inline-flex}.btn-primary:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:default}.btn-block{width:100%}.alert-error{color:var(--danger);border-radius:var(--radius-sm);background:#ef44441a;border:1px solid #ef444440;padding:10px 14px;font-size:13px}.alert-success{color:var(--success);border-radius:var(--radius-sm);background:#22c55e1a;border:1px solid #22c55e40;padding:10px 14px;font-size:13px}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.7s linear infinite spin;display:inline-block}.spinner-lg{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.loading-state{justify-content:center;align-items:center;padding:60px;display:flex}.modal-overlay{z-index:999;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#000c;justify-content:center;align-items:center;animation:.18s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-img-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);max-width:90vw;max-height:90vh;padding:12px;position:relative}.modal-img{border-radius:8px;max-width:80vw;max-height:80vh;display:block}.modal-close{background:var(--surface2);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;transition:background .15s;display:flex;position:absolute;top:-12px;right:-12px}.modal-close:hover{background:var(--danger)}.login-page{background:radial-gradient(ellipse at 60% 30%, #3b82f61f 0%, transparent 60%), radial-gradient(ellipse at 20% 80%, #a78bfa14 0%, transparent 50%), var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-glow{pointer-events:none;background:radial-gradient(circle,#3b82f626 0%,#0000 70%);border-radius:50%;width:500px;height:500px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.login-card{background:var(--surface);border:1px solid var(--border);z-index:1;border-radius:16px;width:100%;max-width:400px;padding:40px 36px;position:relative;box-shadow:0 24px 80px #00000080}.login-logo{text-align:center;margin-bottom:32px}.login-logo-icon{color:var(--primary);filter:drop-shadow(0 0 16px var(--primary));font-size:42px}.login-title{background:linear-gradient(135deg, #fff, var(--primary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-top:8px;font-size:24px;font-weight:800}.login-subtitle{color:var(--text-muted);margin-top:4px;font-size:13px}.login-form{flex-direction:column;gap:18px;display:flex}.settings-form{flex-direction:column;gap:20px;display:flex}.settings-body{flex-direction:column;gap:16px;padding:20px;display:flex}.settings-section-title{align-items:center;gap:12px;display:flex}.settings-section-icon{background:var(--surface2);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:20px;display:flex}.settings-section-name{font-size:14px;font-weight:600}.settings-section-sub{color:var(--text-muted);margin-top:2px;font-size:12px}.settings-row{flex-wrap:wrap;align-items:flex-start;gap:16px;display:flex}.settings-row .form-group{flex:1;min-width:160px}.settings-hint{border-radius:var(--radius-sm);color:var(--text-muted);background:#3b82f60f;border:1px solid #3b82f626;align-items:flex-start;gap:8px;padding:10px 14px;font-size:12px;line-height:1.6;display:flex}.hint-icon{color:var(--primary);flex-shrink:0;margin-top:1px;font-size:14px}.settings-hint strong{color:var(--text)}.settings-save-bar{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:14px;padding-top:4px;display:flex}.settings-save-bar .alert-success,.settings-save-bar .alert-error{flex:1}.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:8px;padding:10px 18px;font-family:inherit;font-size:13px;font-weight:600;transition:border-color .15s,background .15s;display:inline-flex}.btn-secondary:hover:not(:disabled){border-color:var(--primary);background:#3b82f60f}.btn-secondary:disabled{opacity:.4;cursor:default}.token-toggle{cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:0;font-size:16px;line-height:1;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.token-toggle:hover{color:var(--text)}.chart-card{margin-bottom:20px}.chart-body{padding:16px 20px 8px}.chart-tooltip{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;font-size:13px}.chart-tooltip-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:11px;font-weight:600}.theme-toggle{cursor:pointer;color:#ffffffb3;white-space:nowrap;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:20px;align-items:center;gap:8px;padding:5px 10px;font-family:inherit;font-size:13px;font-weight:500;transition:background .2s,border-color .2s;display:flex}.theme-toggle:hover{color:#fff;background:#ffffff1f}.theme-toggle-icon{font-size:15px;transition:transform .4s}.theme-toggle:hover .theme-toggle-icon{transform:rotate(20deg)}.form-select{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);cursor:pointer;outline:none;width:100%;padding:10px 12px;font-family:inherit;font-size:14px;transition:border-color .15s}.form-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.type-badge{color:var(--purple);white-space:nowrap;background:#a78bfa1f;border:1px solid #a78bfa40;border-radius:20px;padding:2px 8px;font-size:11px;font-weight:600}
