@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@500;700&display=swap";:root{--accent: #06b6d4;--accent-glow: rgba(6, 182, 212, .25);--accent-hover: #0ea5c9;--bg-base: #06080f;--bg-surface: #0d1117;--bg-card: rgba(255, 255, 255, .03);--bg-card-hover: rgba(255, 255, 255, .06);--bg-input: rgba(255, 255, 255, .05);--border: rgba(255, 255, 255, .08);--border-hover: rgba(255, 255, 255, .15);--text: #e2e8f0;--text-secondary: #94a3b8;--text-muted: #64748b;--success: #22c55e;--success-bg: rgba(34, 197, 94, .1);--danger: #ef4444;--danger-bg: rgba(239, 68, 68, .1);--warning: #f59e0b;--warning-bg: rgba(245, 158, 11, .1);--plate-bg: linear-gradient(135deg, #1e3a5f 0%, #0f2942 100%);--radius: 12px;--radius-sm: 8px;--radius-xs: 6px;--shadow: 0 4px 24px rgba(0, 0, 0, .4);--transition: all .25s cubic-bezier(.4, 0, .2, 1)}body{background:var(--bg-base);color:var(--text);min-height:100vh;font-family:Inter,sans-serif;-webkit-font-smoothing:antialiased}.app{max-width:1440px;margin:0 auto;padding:20px 24px;min-height:100vh}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding:16px 24px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.header-left{display:flex;align-items:center;gap:16px}.header-logo{width:44px;height:44px;background:linear-gradient(135deg,var(--accent),#0284c7);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:22px;box-shadow:0 0 20px var(--accent-glow)}.header-title{font-size:20px;font-weight:700;letter-spacing:-.02em}.header-subtitle{font-size:12px;color:var(--text-muted);font-weight:400;margin-top:2px}.status-badge{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:24px;font-size:13px;font-weight:500;border:1px solid var(--border);transition:var(--transition)}.status-badge.online{background:var(--success-bg);border-color:#22c55e33;color:var(--success)}.status-badge.offline{background:var(--danger-bg);border-color:#ef444433;color:var(--danger)}.status-badge.connecting{background:var(--warning-bg);border-color:#f59e0b33;color:var(--warning)}.status-dot{width:8px;height:8px;border-radius:50%;background:currentColor}.status-badge.online .status-dot{animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1;box-shadow:0 0 0 0 currentColor}50%{opacity:.7;box-shadow:0 0 0 4px transparent}}.tabs{display:flex;gap:4px;padding:4px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:24px}.tab{flex:1;padding:12px 16px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition);font-family:Inter,sans-serif;font-size:14px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:8px}.tab:hover:not(.active){color:var(--text-secondary);background:var(--bg-card-hover)}.tab.active{background:var(--accent);color:#fff;box-shadow:0 2px 12px var(--accent-glow)}.tab-badge{background:#fff3;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:700}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow)}.card-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border)}.card-title{font-size:15px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:8px}.grid{display:grid;grid-template-columns:1.5fr 1fr;gap:20px}@media (max-width: 1024px){.grid{grid-template-columns:1fr}}.video-container{position:relative;background:#000;aspect-ratio:16/9;overflow:hidden}.video-container img{width:100%;height:100%;object-fit:contain;transition:opacity .3s}.live-badge{position:absolute;top:14px;left:14px;background:var(--danger);padding:4px 12px;border-radius:var(--radius-xs);font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;animation:live-pulse 1.5s ease-in-out infinite;display:flex;align-items:center;gap:6px}.live-badge:before{content:"";width:6px;height:6px;border-radius:50%;background:#fff}@keyframes live-pulse{0%,to{opacity:1}50%{opacity:.6}}.snapshot-time{position:absolute;bottom:14px;right:14px;background:#000000b3;padding:4px 10px;border-radius:var(--radius-xs);font-size:12px;font-family:JetBrains Mono,monospace;color:var(--text-secondary);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.snapshot-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-muted);font-size:14px}.btn{padding:8px 16px;border:1px solid var(--border);border-radius:var(--radius-xs);cursor:pointer;font-size:13px;font-weight:500;font-family:Inter,sans-serif;transition:var(--transition);display:inline-flex;align-items:center;gap:6px;background:var(--bg-card-hover);color:var(--text)}.btn:hover{border-color:var(--border-hover);background:#ffffff14}.btn-accent{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-accent:hover{background:var(--accent-hover);box-shadow:0 2px 12px var(--accent-glow)}.btn-danger{background:var(--danger-bg);color:var(--danger);border-color:#ef444433}.records-list{max-height:460px;overflow-y:auto}.records-list::-webkit-scrollbar{width:4px}.records-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.record-item{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-bottom:1px solid var(--border);transition:var(--transition);cursor:default}.record-item:hover{background:var(--bg-card-hover)}.record-item:last-child{border-bottom:none}.record-left{display:flex;align-items:center;gap:14px}.record-icon{width:42px;height:42px;background:linear-gradient(135deg,#06b6d426,#06b6d40d);border:1px solid rgba(6,182,212,.2);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:20px}.plate-number{font-family:JetBrains Mono,monospace;font-size:18px;font-weight:700;color:var(--accent);letter-spacing:.05em}.record-meta{font-size:12px;color:var(--text-muted);margin-top:3px}.record-time{font-size:12px;color:var(--text-muted);font-family:JetBrains Mono,monospace;text-align:right}.record-date{font-size:11px;color:var(--text-muted);opacity:.7}.new-event{animation:slide-in .4s cubic-bezier(.4,0,.2,1)}@keyframes slide-in{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.filter-bar{display:flex;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border);flex-wrap:wrap}.filter-input{flex:1;min-width:200px;padding:10px 14px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text);font-family:Inter,sans-serif;font-size:14px;transition:var(--transition)}.filter-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.filter-input::placeholder{color:var(--text-muted)}.events-container{max-height:600px;overflow-y:auto}.events-container::-webkit-scrollbar{width:4px}.events-container::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.empty-state{padding:60px 20px;text-align:center;color:var(--text-muted);font-size:14px}.empty-state-icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-state-text{max-width:300px;margin:0 auto;line-height:1.6}.spinner{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.diag-grid{display:grid;gap:8px;padding:20px}.diag-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-input);border-radius:var(--radius-sm);border:1px solid var(--border);font-size:13px}.diag-status{width:10px;height:10px;border-radius:50%;flex-shrink:0}.diag-status.ok{background:var(--success)}.diag-status.fail{background:var(--danger)}.diag-name{font-weight:500;min-width:140px}.diag-detail{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--text-muted);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stats-bar{display:flex;gap:16px;padding:16px 20px;border-bottom:1px solid var(--border)}.stat-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary)}.stat-value{font-weight:700;color:var(--accent);font-family:JetBrains Mono,monospace}@media (max-width: 768px){.app{padding:12px 12px 80px}.header{flex-direction:column;gap:12px;padding:14px 16px;margin-bottom:16px}.grid{grid-template-columns:1fr}.filter-bar{flex-direction:column}.plate-number{font-size:16px}.stats-bar{flex-direction:column;gap:8px}.tabs{position:fixed;bottom:0;left:0;right:0;margin:0;border-radius:0;border-top:1px solid var(--border);background:#0d1117f2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:100;padding:8px 12px;padding-bottom:calc(8px + env(safe-area-inset-bottom));display:flex;gap:4px;justify-content:space-around}.tab{flex-direction:column;padding:8px 4px;font-size:11px;gap:4px;border-radius:var(--radius-sm)}.tab .tab-badge{position:absolute;top:4px;right:50%;transform:translate(20px)}}.filter-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap;width:100%}.filter-group{display:flex;flex-direction:column;gap:4px;flex:1;min-width:150px}.filter-label{font-size:11px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;animation:fade-in .2s ease-out}.modal-content{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);max-width:100%;max-height:100%;overflow:hidden;box-shadow:0 12px 32px #00000080;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;border-bottom:1px solid var(--border);background:var(--bg-card)}.modal-body{padding:0;background:#000;display:flex;justify-content:center;align-items:center;position:relative;min-height:200px;min-width:300px}.modal-image{max-width:100%;max-height:70vh;object-fit:contain}@keyframes fade-in{0%{opacity:0}to{opacity:1}}
