@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600;700&family=Outfit:wght@300;400;500;600;700;800&display=swap";*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0a0e1a;--bg-secondary: #111827;--bg-card: #1a2236;--bg-card-hover: #1f2a42;--bg-input: #0f1629;--border: #2a3550;--border-focus: #3b82f6;--text-primary: #e8ecf4;--text-secondary: #8896b3;--text-muted: #5c6a85;--accent-blue: #3b82f6;--accent-cyan: #22d3ee;--accent-green: #34d399;--accent-red: #f87171;--accent-orange: #fb923c;--accent-purple: #a78bfa;--accent-pink: #f472b6;--accent-yellow: #fbbf24;--sidebar-w: 260px;--header-h: 64px;--radius: 12px;--radius-sm: 8px}[data-theme=light]{--bg-primary: #f0f2f5;--bg-secondary: #ffffff;--bg-card: #ffffff;--bg-card-hover: #f8f9fb;--bg-input: #f5f6f8;--border: #d8dde6;--border-focus: #3b82f6;--text-primary: #1a1d26;--text-secondary: #4b5563;--text-muted: #9ca3af;--accent-blue: #2563eb;--accent-cyan: #0891b2;--accent-green: #059669;--accent-red: #dc2626;--accent-orange: #ea580c;--accent-purple: #7c3aed;--accent-pink: #db2777;--accent-yellow: #d97706}html,body,#root{height:100%;overflow:hidden}body{background:var(--bg-primary);color:var(--text-primary);font-family:Outfit,sans-serif;-webkit-font-smoothing:antialiased}.app-layout{display:flex;height:100vh}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;height:100vh;z-index:100;transition:transform .3s ease,width .2s ease,min-width .2s ease}.sidebar-brand{padding:20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px}.sidebar-brand-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--accent-cyan),var(--accent-blue));border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;color:#000;font-family:JetBrains Mono,monospace}.sidebar-brand h1{font-size:16px;font-weight:700;letter-spacing:-.3px}.sidebar-brand span{font-size:11px;color:var(--text-muted)}.sidebar-nav{flex:1;padding:12px;overflow-y:auto}.sidebar-section{font-size:10px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);padding:16px 12px 8px;font-weight:600}.sidebar-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);font-size:14px;font-weight:500;transition:all .15s ease;border:1px solid transparent;margin-bottom:2px}.sidebar-item:hover{background:var(--bg-card);color:var(--text-primary)}.sidebar-item.active{background:#3b82f61f;color:var(--accent-cyan);border-color:#3b82f633}.sidebar-footer{padding:16px;border-top:1px solid var(--border)}.sidebar-user{display:flex;align-items:center;gap:12px;padding:8px}.sidebar-avatar{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--accent-purple),var(--accent-pink));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px}.sidebar-toggle{display:flex;align-items:center;justify-content:center;width:100%;height:36px;margin-top:8px;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:all .15s}.sidebar-toggle:hover{background:var(--bg-card);color:var(--text-primary)}.sidebar.collapsed{width:68px;min-width:68px}.sidebar.collapsed .sidebar-brand{padding:16px;justify-content:center}.sidebar.collapsed .sidebar-nav{padding:8px}.sidebar.collapsed .sidebar-item{justify-content:center;padding:10px}.sidebar.collapsed .sidebar-footer{padding:12px}.sidebar.hidden{width:0!important;min-width:0!important;padding:0!important;border:none!important;overflow:hidden}.sidebar.hidden>*{display:none!important}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.main-header{height:var(--header-h);min-height:var(--header-h);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 28px;background:var(--bg-secondary)}.main-header h2{font-size:18px;font-weight:700}.page-content{flex:1;overflow-y:auto;padding:28px}.live-badge{display:flex;align-items:center;gap:6px;background:#22d3ee1a;border:1px solid rgba(34,211,238,.25);padding:5px 12px;border-radius:20px;font-size:12px;color:var(--accent-cyan);font-weight:600}.live-dot{width:7px;height:7px;background:var(--accent-cyan);border-radius:50%;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow-x:auto;overflow-y:hidden}.card-header{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.card-header h3{font-size:15px;font-weight:700;display:flex;align-items:center;gap:10px}.card-body{padding:22px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:18px;margin-bottom:24px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:22px;transition:all .2s;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.stat-card:nth-child(1):before{background:linear-gradient(90deg,var(--accent-cyan),var(--accent-blue))}.stat-card:nth-child(2):before{background:linear-gradient(90deg,var(--accent-green),var(--accent-cyan))}.stat-card:nth-child(3):before{background:linear-gradient(90deg,var(--accent-purple),var(--accent-pink))}.stat-card:nth-child(4):before{background:linear-gradient(90deg,var(--accent-yellow),var(--accent-orange))}.stat-card:nth-child(5):before{background:linear-gradient(90deg,var(--accent-orange),var(--accent-red))}.stat-card:hover{border-color:#3b82f64d;transform:translateY(-2px)}.stat-label{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;font-weight:600;margin-bottom:8px}.stat-value{font-size:32px;font-weight:800;font-family:JetBrains Mono,monospace;letter-spacing:-1px}.stat-change{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;margin-top:8px;padding:2px 8px;border-radius:12px}.stat-change.up{color:var(--accent-green);background:#34d3991a}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}.table-wrap{overflow:auto;max-height:100%}table{min-width:100%;border-collapse:separate;border-spacing:0}thead{position:sticky;top:0;z-index:10}thead th{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);font-weight:700;padding:10px 14px;text-align:center;background:var(--bg-secondary);border-bottom:2px solid var(--accent-cyan);white-space:nowrap;box-shadow:0 2px 4px #0000000d}thead th:not(:last-child){border-right:1px solid var(--border)}tbody td{padding:10px 14px;font-size:13px;border-bottom:1px solid var(--border);white-space:nowrap;text-align:center;vertical-align:middle}tbody td:not(:last-child){border-right:1px solid var(--border)}tbody tr:nth-child(2n){background:#94a3b81a}tbody tr:nth-child(odd){background:transparent}tbody tr:hover{background:#0ea5e924!important;transition:background .15s}tfoot td{padding:12px 14px;font-size:13px;font-weight:700;white-space:nowrap;border-top:2px solid var(--accent-cyan);background:var(--bg-secondary)}[data-theme=light] tbody tr:nth-child(2n){background:#eef2f7}[data-theme=light] tbody tr:hover{background:#dbeafe!important}.plate-badge{font-family:JetBrains Mono,Courier New,monospace;font-weight:900;font-size:15px;letter-spacing:1.5px;padding:5px 12px 5px 28px;border-radius:5px;display:inline-block;position:relative;text-shadow:none;background:#fff;color:#0f172a;border:1.5px solid #0f172a;box-shadow:0 1px 3px #00000040;line-height:1.2}.plate-badge:before{content:"TR";position:absolute;top:-1.5px;left:-1.5px;bottom:-1.5px;width:20px;background:#1e3a8a;color:#fff;font-size:8px;font-weight:700;letter-spacing:.5px;display:flex;align-items:center;justify-content:center;border-radius:4px 0 0 4px}.plate-badge.plate-parked,.plate-badge.plate-exited,.plate-badge.plate-exiting,.plate-badge.plate-payment_pending,.plate-badge.plate-entry_pending{background:#fff;border-color:#0f172a;color:#0f172a}.plate-badge.plate-unreadable{background:#fef2f2;border-color:#ef4444;color:#991b1b;padding-left:12px}.plate-badge.plate-unreadable:before{display:none}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600}.status-badge:before{content:"";width:6px;height:6px;border-radius:50%}.status-active{color:var(--accent-green);background:#34d3991a}.status-active:before{background:var(--accent-green)}.status-expired{color:var(--accent-red);background:#f871711a}.status-expired:before{background:var(--accent-red)}.status-parked{color:var(--accent-green);background:#22c55e1f}.status-parked:before{background:var(--accent-green)}.status-exited{color:var(--accent-red);background:#ef44441a}.status-exited:before{background:var(--accent-red)}.payment-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:500}.pay-credit{color:var(--accent-purple);background:#a78bfa1a;border:1px solid rgba(167,139,250,.2)}.pay-kent{color:var(--accent-orange);background:#fb923c1a;border:1px solid rgba(251,146,60,.2)}.form-group{margin-bottom:18px}.form-group label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.form-input,.form-select{width:100%;padding:10px 14px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:Outfit,sans-serif;font-size:14px;transition:all .15s;outline:none}.form-select.ss-compact{padding:5px 10px;font-size:12px}.form-input:focus,.form-select:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f626}.form-select option{background:var(--bg-card)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border:none;border-radius:var(--radius-sm);font-family:Outfit,sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s}.btn-primary{background:linear-gradient(135deg,var(--accent-blue),#2563eb);color:#fff}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 16px #3b82f64d}.btn-success{background:linear-gradient(135deg,var(--accent-green),#10b981);color:#fff}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text-secondary)}.btn-outline:hover{border-color:var(--text-secondary);color:var(--text-primary)}.btn-danger{background:#f871711a;border:1px solid rgba(248,113,113,.2);color:var(--accent-red)}.btn-sm{padding:6px 14px;font-size:12px}.search-bar{position:relative;max-width:320px}.search-bar input{width:100%;padding:8px 14px 8px 38px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:Outfit,sans-serif;font-size:13px;outline:none}.search-bar input:focus{border-color:var(--accent-blue)}.search-bar svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted)}.occ-bar{height:8px;background:var(--bg-input);border-radius:4px;overflow:hidden}.occ-fill{height:100%;border-radius:4px;transition:width .8s ease}.branch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:18px}.branch-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:22px;transition:all .2s;cursor:pointer}.branch-card:hover{border-color:#3b82f64d;transform:translateY(-2px)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:520px;max-height:90vh;overflow-y:auto}.modal-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--bg-card);z-index:3}.modal-footer{position:sticky;bottom:0;background:var(--bg-card);z-index:3}.modal-header h3{font-size:17px;font-weight:700}.modal-close{background:none;border:none;color:var(--text-muted);cursor:pointer}.modal-body{padding:24px}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}.scanner-box{background:var(--bg-input);border:2px dashed var(--border);border-radius:var(--radius);padding:40px;text-align:center}.scanner-result{margin-top:20px;padding:16px;background:#22d3ee0d;border:1px solid rgba(34,211,238,.2);border-radius:var(--radius-sm)}.scanner-plate{font-family:JetBrains Mono,monospace;font-size:28px;font-weight:800;color:var(--accent-cyan);letter-spacing:2px}.pay-options{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:18px 0}.pay-option{padding:18px;border:2px solid var(--border);border-radius:var(--radius);text-align:center;cursor:pointer;transition:all .15s}.pay-option:hover{border-color:var(--accent-blue)}.pay-option.selected{border-color:var(--accent-cyan);background:#22d3ee0d}.tabs{display:flex;gap:4px;margin-bottom:20px}.tab{padding:8px 18px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;background:transparent;border:1px solid transparent;color:var(--text-muted);transition:all .15s}.tab:hover{color:var(--text-primary);background:var(--bg-card)}.tab.active{color:var(--accent-cyan);background:#22d3ee14;border-color:#22d3ee33}.alert{padding:14px 18px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:18px;display:flex;align-items:center;gap:10px}.alert-success{background:#34d3991a;border:1px solid rgba(52,211,153,.2);color:var(--accent-green)}.alert-info{background:#3b82f61a;border:1px solid rgba(59,130,246,.2);color:var(--accent-blue)}.alert-warning{background:#fbbf241a;border:1px solid rgba(251,191,36,.2);color:var(--accent-yellow)}.login-page{height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f0f4f8,#dbe4ee,#c8d6e5)}.login-card{background:#fff;border:1px solid #d1d9e6;border-radius:var(--radius);padding:40px;width:100%;max-width:400px;box-shadow:0 8px 32px #0000001a}.login-card h1{font-size:24px;margin-bottom:8px;text-align:center;color:#1a2744}.login-card p{color:#6b7a90;text-align:center;margin-bottom:28px;font-size:14px}.login-card h2{color:#1a3a6e}.login-card label{color:#3a4a5e}.login-card .form-input,.login-card .form-select{background:#f7f9fc;border-color:#d1d9e6;color:#1a2744}.login-card .form-input:focus,.login-card .form-select:focus{border-color:#1a3a6e;background:#fff}.login-card .form-input::placeholder{color:#9ca8b8}.login-card .form-select option{background:#fff;color:#1a2744}.login-card .btn-primary{background:#1a3a6e;border-color:#1a3a6e;color:#fff}.login-card .btn-primary:hover{background:#15305c}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease}.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px}.toast{padding:14px 20px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;display:flex;align-items:center;gap:10px;min-width:300px;animation:fadeIn .3s ease;box-shadow:0 8px 32px #0000004d}.toast-success{background:#065f46;border:1px solid var(--accent-green);color:var(--accent-green)}.toast-error{background:#7f1d1d;border:1px solid var(--accent-red);color:var(--accent-red)}.toast-info{background:#1e3a5f;border:1px solid var(--accent-cyan);color:var(--accent-cyan)}.mobile-menu-btn{display:none;background:none;border:none;color:var(--text-secondary);cursor:pointer}@media(max-width:1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}.grid-2{grid-template-columns:1fr}.sidebar{position:fixed;left:0;top:0;bottom:0;transform:translate(-100%);z-index:200}.sidebar.open{transform:translate(0)}.mobile-menu-btn{display:block}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:199}}@media(max-width:640px){.stats-grid{grid-template-columns:1fr}.page-content{padding:16px}.form-row{grid-template-columns:1fr}}[data-theme=light] .card,[data-theme=light] .stat-card,[data-theme=light] .branch-card{box-shadow:0 1px 3px #00000014,0 1px 2px #0000000f}[data-theme=light] .sidebar{box-shadow:2px 0 8px #0000000f}[data-theme=light] .main-header{box-shadow:0 1px 3px #0000000f}[data-theme=light] .modal{box-shadow:0 20px 60px #00000026}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:6px}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--accent-cyan),#0284c7);border-radius:6px;border:2px solid var(--bg-secondary);min-height:40px}::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#0ea5e9,#0369a1)}::-webkit-scrollbar-thumb:active{background:#0369a1}::-webkit-scrollbar-corner{background:var(--bg-secondary)}*{scrollbar-width:thin;scrollbar-color:var(--accent-cyan) var(--bg-secondary)}.barrier-animation{display:flex;flex-direction:column;align-items:center;padding:32px 0 12px;gap:12px;margin-top:12px;border-top:1px solid var(--border-color)}.barrier-visual{position:relative;width:140px;height:90px}.barrier-base{position:absolute;bottom:0;left:24px;width:32px;height:10px;background:var(--text-secondary);border-radius:2px}.barrier-pole{position:absolute;bottom:10px;left:30px;width:10px;height:50px;background:var(--text-secondary);border-radius:3px 3px 0 0}.barrier-pivot{position:absolute;bottom:56px;left:30px;width:10px;height:10px;background:var(--text-muted);border-radius:50%;z-index:2}.barrier-arm{position:absolute;bottom:58px;left:35px;width:80px;height:6px;background:repeating-linear-gradient(90deg,var(--accent-red) 0px,var(--accent-red) 10px,#fff 10px,#fff 20px);border-radius:3px;transform-origin:0% 50%;transition:transform 1.2s cubic-bezier(.4,0,.2,1),opacity .3s}.barrier-arm.opening,.barrier-arm.open{transform:rotate(-85deg);background:repeating-linear-gradient(90deg,var(--accent-green) 0px,var(--accent-green) 10px,#fff 10px,#fff 20px)}.barrier-arm.closing{transform:rotate(0);background:repeating-linear-gradient(90deg,var(--accent-red) 0px,var(--accent-red) 10px,#fff 10px,#fff 20px)}.barrier-status{font-size:13px;font-weight:600;color:var(--text-secondary);transition:color .5s}.barrier-status.open{color:var(--accent-green)}@keyframes barrierPulse{0%,to{box-shadow:0 0 #22d3ee4d}50%{box-shadow:0 0 12px 4px #22d3ee26}}.barrier-animation.active{animation:barrierPulse 2s infinite;border-radius:var(--radius-sm)}.datatable{display:flex;flex-direction:column;height:100%;min-height:0}.datatable .table-wrap{flex:1;min-height:0}.datatable-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;flex-wrap:wrap}.datatable-toolbar-right{display:flex;align-items:center;gap:10px;margin-left:auto}.datatable-header-content{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.datatable-search{display:flex;align-items:center;gap:6px;background:var(--bg-card-hover);border:1px solid var(--border);border-radius:var(--radius-sm);padding:5px 10px}.datatable-search input{background:transparent;border:none;outline:none;color:var(--text-primary);font-size:13px;width:160px}.datatable-search input::placeholder{color:var(--text-muted)}.datatable-search svg{color:var(--text-muted);flex-shrink:0}.datatable-pagesize{background:var(--bg-card-hover);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:12px;padding:5px 8px;cursor:pointer;outline:none}.datatable-footer{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-top:1px solid var(--border);flex-wrap:wrap;gap:8px}.datatable-info{font-size:12px;color:var(--text-muted)}.datatable-pagination{display:flex;align-items:center;gap:4px}.datatable-pagination button{display:flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 6px;background:var(--bg-card-hover);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:12px;cursor:pointer;transition:all .15s}.datatable-pagination button:hover:not(:disabled){background:var(--accent-cyan);color:#fff;border-color:var(--accent-cyan)}.datatable-pagination button.active{background:var(--accent-cyan);color:#fff;border-color:var(--accent-cyan);font-weight:700}.datatable-pagination button:disabled{opacity:.35;cursor:default}.cc2-root{display:flex;flex-direction:column;height:calc(100vh - var(--header-h) - 16px);overflow:hidden;gap:0}.cc2-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;gap:12px;color:var(--text-muted)}.cc2-spin{animation:cc2spin 1s linear infinite}@keyframes cc2spin{to{transform:rotate(360deg)}}.cc2-header{display:flex;align-items:center;justify-content:space-between;padding:0 0 14px;gap:16px;flex-shrink:0}.cc2-header-left{display:flex;align-items:center;gap:14px}.cc2-title{font-size:18px;font-weight:700;color:var(--text-primary)}.cc2-title-accent{color:var(--accent-cyan)}.cc2-live-badge{display:inline-flex;align-items:center;gap:6px;background:#34d3991f;color:var(--accent-green);font-size:11px;font-weight:600;padding:4px 12px;border-radius:12px}.cc2-live-dot{width:7px;height:7px;border-radius:50%;background:var(--accent-green);animation:cc2pulse 2s infinite}@keyframes cc2pulse{0%,to{opacity:1}50%{opacity:.35}}.cc2-header-right{display:flex;align-items:center;gap:16px}.cc2-clock{font-family:JetBrains Mono,monospace;font-size:13px;color:var(--text-muted)}.cc2-ops-row{display:flex;align-items:center;gap:6px}.cc2-op-chip{display:flex;align-items:center;gap:5px;background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:3px 10px 3px 3px}.cc2-op-avatar{width:22px;height:22px;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;flex-shrink:0}.cc2-op-name{font-size:11px;color:var(--text-secondary);font-weight:500}.cc2-op-dot{width:6px;height:6px;border-radius:50%;background:var(--accent-green);flex-shrink:0}.cc2-stats-row{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;flex-shrink:0;padding-bottom:14px}.cc2-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;position:relative;overflow:hidden;display:flex;align-items:center;gap:12px}.cc2-stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.cc2-stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cc2-stat-label{font-size:11px;color:var(--text-muted)}.cc2-stat-value{font-size:20px;font-weight:700;color:var(--text-primary);font-family:JetBrains Mono,monospace;line-height:1.2}.cc2-stat-sub{font-size:10px;color:var(--text-muted);margin-top:1px}.cc2-stat-blue:before{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.cc2-stat-blue .cc2-stat-icon{background:#3b82f61f;color:#60a5fa}.cc2-stat-green:before{background:linear-gradient(90deg,#22c55e,#4ade80)}.cc2-stat-green .cc2-stat-icon{background:#22c55e1f;color:#4ade80}.cc2-stat-cyan:before{background:linear-gradient(90deg,#06b6d4,#38bdf8)}.cc2-stat-cyan .cc2-stat-icon{background:#06b6d41f;color:#38bdf8}.cc2-stat-yellow:before{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.cc2-stat-yellow .cc2-stat-icon{background:#f59e0b1f;color:#fbbf24}.cc2-stat-purple:before{background:linear-gradient(90deg,#8b5cf6,#a78bfa)}.cc2-stat-purple .cc2-stat-icon{background:#8b5cf61f;color:#a78bfa}.cc2-stat-red:before{background:linear-gradient(90deg,#ef4444,#f87171)}.cc2-stat-red .cc2-stat-icon{background:#ef44441f;color:#f87171}.cc2-main{display:flex;flex:1;gap:14px;overflow:hidden;min-height:0}.cc2-grid-area{flex:1;overflow-y:auto;min-width:0;padding-right:4px}.cc2-grid-header{margin-bottom:10px}.cc2-grid-header h3{font-size:15px;font-weight:600;color:var(--text-secondary);margin:0}.cc2-right-panel{width:340px;min-width:340px;display:flex;flex-direction:column;overflow:hidden}.cc2-branch-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}@media(max-width:1600px){.cc2-branch-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:1200px){.cc2-branch-grid{grid-template-columns:repeat(2,1fr)}}.cc2-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;cursor:pointer;transition:all .2s;position:relative;display:flex;flex-direction:column;gap:10px}.cc2-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0003;filter:brightness(1.05)}.cc2-card.has-alert{border-color:var(--accent-red);animation:cc2alertPulse 1.2s infinite}@keyframes cc2alertPulse{0%,to{box-shadow:0 0 #ef444400;border-color:#ef444459}50%{box-shadow:0 0 14px 4px #ef444459;border-color:#ef4444}}.cc2-card-header{display:flex;align-items:center;justify-content:space-between}.cc2-card-name{font-size:13px;font-weight:600;color:var(--text-primary)}.cc2-card-status-dots{display:flex;align-items:center;gap:6px}.cc2-cam-status{width:8px;height:8px;border-radius:50%;flex-shrink:0}.cc2-cam-status.on{background:var(--accent-green);box-shadow:0 0 6px #22c55e66}.cc2-cam-status.off{background:var(--accent-red)}.cc2-cam-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.cc2-cam-dot.on{background:var(--accent-green)}.cc2-cam-dot.off{background:var(--accent-red)}.cc2-card-alert-tag{display:inline-flex;align-items:center;gap:3px;background:#f871711f;color:var(--accent-red);font-size:10px;font-weight:600;padding:2px 7px;border-radius:8px;animation:cc2alertPulse 2s infinite}.cc2-card-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px}.cc2-card-count{font-size:12px;color:var(--text-secondary);font-family:JetBrains Mono,monospace}.cc2-card-pct{font-weight:700;font-family:JetBrains Mono,monospace;font-size:15px}.cc2-card-progress{height:6px;background:var(--bg-input);border-radius:3px;overflow:hidden}.cc2-card-progress-fill{height:100%;border-radius:3px;transition:width .6s ease}.cc2-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto}.cc2-card-last{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:75%}.cc2-card-last strong{color:var(--text-secondary);font-family:JetBrains Mono,monospace;font-size:11px}.cc2-card-actions{display:flex;gap:4px}.cc2-card-btn{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;padding:5px 7px;border-radius:var(--radius-sm);transition:all .15s;display:flex;align-items:center}.cc2-card-btn:hover{color:var(--accent-cyan);border-color:var(--accent-cyan);background:#38bdf814}.cc2-panel-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;overflow:hidden;flex:1;min-height:0}.cc2-panel-flex{flex:1.2}.cc2-panel-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border);flex-shrink:0}.cc2-panel-header h4{font-size:13px;font-weight:600;color:var(--text-secondary);margin:0}.cc2-panel-badge{background:var(--accent-red);color:#fff;font-size:10px;font-weight:700;padding:1px 7px;border-radius:10px;min-width:18px;text-align:center}.cc2-alert-list{flex:1;overflow-y:auto;padding:4px}.cc2-alert-item{display:flex;align-items:center;gap:10px;padding:5px 10px;margin-bottom:3px;background:var(--bg-secondary);border-radius:var(--radius-sm);border-left:3px solid transparent;min-height:32px}.cc2-alert-critical{border-left-color:var(--accent-red);background:#f871710f}.cc2-alert-warning{border-left-color:var(--accent-orange)}.cc2-alert-icon{width:22px;height:22px;border-radius:5px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cc2-alert-icon.critical{background:#f8717126;color:var(--accent-red)}.cc2-alert-icon.warning{background:#fbbf2426;color:var(--accent-yellow)}.cc2-alert-branch{font-size:12px;font-weight:700;color:var(--accent-red);white-space:nowrap;flex-shrink:0;min-width:110px;overflow:hidden;text-overflow:ellipsis}.cc2-alert-time{font-size:10px;color:var(--text-muted);margin-left:auto;white-space:nowrap;flex-shrink:0}.cc2-alert-type{font-size:11px;color:var(--text-secondary);white-space:nowrap;flex-shrink:0}.cc2-alert-plate{display:inline-block;font-size:11px;font-weight:600;font-family:JetBrains Mono,monospace;letter-spacing:.5px;padding:1px 7px;border-radius:3px;background:#38bdf81f;color:var(--accent-cyan);white-space:nowrap;flex-shrink:0}.cc2-alert-btn{display:inline-flex;align-items:center;gap:3px;padding:3px 9px;border:none;border-radius:4px;font-size:10px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s;flex-shrink:0}.cc2-alert-btn:hover{opacity:.85}.cc2-alert-btn.claim{background:#38bdf826;color:var(--accent-cyan)}.cc2-alert-btn.resolve{background:#34d39926;color:var(--accent-green)}.cc2-alert-btn.retry{background:#fbbf2426;color:var(--accent-yellow, #fbbf24)}.cc2-alert-btn.retry:disabled{opacity:.5;cursor:not-allowed}.cc2-alert-claimed{font-size:10px;color:var(--accent-cyan);font-weight:500}.cc2-resolve-inline{display:flex;gap:3px;flex:1}.cc2-empty-sm{text-align:center;color:var(--text-muted);padding:20px 8px;font-size:12px}.cc2-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:9999}.cc2-modal{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border);border-radius:16px;width:680px;max-width:95vw;max-height:90vh;overflow-y:auto;box-shadow:0 30px 100px #0000004d}.cc2-modal-header{display:flex;align-items:center;justify-content:space-between;padding:22px 28px;border-bottom:1px solid var(--border);background:var(--bg-secondary);border-radius:16px 16px 0 0}.cc2-modal-title{display:flex;align-items:center;gap:10px;font-weight:700;font-size:18px;color:var(--text-primary)}.cc2-modal-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:8px;border-radius:8px}.cc2-modal-close:hover{background:var(--bg-card-hover);color:var(--text-primary)}.cc2-modal-alert-info{padding:20px 28px;background:var(--bg-input);border-bottom:1px solid var(--border)}.cc2-modal-alert-title{font-size:17px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.cc2-modal-alert-meta{display:flex;gap:14px;font-size:14px;color:var(--text-secondary)}.cc2-modal-alert-meta .cc2-mono{color:var(--accent-cyan);font-weight:600}.cc2-modal-msg{padding:12px 28px;font-size:14px;font-weight:600}.cc2-modal-msg-success{background:#22c55e1a;color:var(--accent-green)}.cc2-modal-msg-error{background:#ef44441a;color:var(--accent-red)}.cc2-modal-actions{padding:24px 28px;border-bottom:1px solid var(--border)}.cc2-modal-actions h5{font-size:13px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin:0 0 16px;font-weight:700}.cc2-modal-btn-row{display:flex;gap:12px;flex-wrap:nowrap}.cc2-modal-btn{display:inline-flex;align-items:center;gap:8px;padding:14px 24px;border:none;border-radius:10px;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .15s;flex:1;justify-content:center}.cc2-modal-btn:disabled{opacity:.4;cursor:not-allowed}.cc2-modal-btn:hover:not(:disabled){opacity:.85;transform:translateY(-1px)}.cc2-modal-btn-primary{background:#38bdf826;color:var(--accent-cyan)}.cc2-modal-btn-success{background:#22c55e26;color:var(--accent-green)}.cc2-modal-btn-warning{background:#fbbf2426;color:var(--accent-yellow)}.cc2-modal-btn-danger{background:#ef444426;color:var(--accent-red)}.cc2-modal-btn-resolve{background:#34d39926;color:var(--accent-green);width:100%;justify-content:center;margin-top:12px;padding:14px;flex:unset;font-size:15px}.cc2-modal-btn-secondary{background:#94a3b81f;color:var(--text-secondary)}.cc2-modal-btn-secondary:hover:not(:disabled){background:#94a3b838}.cc2-modal-confirm{padding:16px 28px;background:#ef44440f;border-top:1px solid rgba(239,68,68,.15);border-bottom:1px solid rgba(239,68,68,.15)}.cc2-modal-confirm p{font-size:14px;color:var(--text-primary);margin:0 0 14px;font-weight:500;text-align:center}.cc2-modal-resolve{padding:24px 28px}.cc2-modal-resolve h5{font-size:13px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin:0 0 12px;font-weight:700}.cc2-modal-textarea{width:100%;resize:vertical;min-height:70px;background:var(--bg-input);border:1px solid var(--border);border-radius:10px;color:var(--text-primary);padding:12px 14px;font-size:14px;font-family:inherit;box-sizing:border-box}.cc2-modal-textarea::placeholder{color:var(--text-muted)}.cc2-modal-textarea:focus{outline:none;border-color:var(--border-focus)}.cc2-modal-plate-input{margin-bottom:14px}.cc2-modal-plate-input .cc2-input{width:100%;font-size:18px;letter-spacing:2px;text-transform:uppercase;padding:14px 16px;background:var(--bg-input);border:1px solid var(--border);border-radius:10px;color:var(--text-primary);box-sizing:border-box}.cc2-modal-plate-input .cc2-input:focus{outline:none;border-color:var(--border-focus)}.cc2-modal-plate-input .cc2-input::placeholder{color:var(--text-muted);letter-spacing:normal}.cc2-timeline{flex:1;overflow-y:auto;padding:6px 10px}.cc2-tl-item{display:flex;align-items:flex-start;gap:10px;padding:7px 0;font-size:11px;border-bottom:1px solid rgba(42,53,80,.2)}.cc2-tl-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:4px}.cc2-tl-entry{background:var(--accent-green);box-shadow:0 0 6px #22c55e4d}.cc2-tl-exit{background:var(--accent-blue,#3b82f6);box-shadow:0 0 6px #3b82f64d}.cc2-tl-payment{background:var(--accent-yellow);box-shadow:0 0 6px #f59e0b4d}.cc2-tl-payment-failed,.cc2-tl-barrier-error{background:var(--accent-red);box-shadow:0 0 6px #ef44444d}.cc2-tl-plate-unreadable{background:var(--accent-orange,#f97316);box-shadow:0 0 6px #f973164d}.cc2-tl-content{flex:1;min-width:0}.cc2-tl-text{color:var(--text-primary);font-size:12px;margin-bottom:2px}.cc2-tl-sub{font-size:10px;color:var(--text-muted)}.cc2-tl-type{color:var(--text-secondary)}.cc2-tl-amount{color:var(--accent-yellow);font-family:JetBrains Mono,monospace;font-weight:600}.cc2-tl-time{margin-left:auto;color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:10px;white-space:nowrap}.cc2-detail-header{display:flex;align-items:center;gap:14px;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border)}.cc2-detail-header h3{font-size:17px;font-weight:700;color:var(--text-primary);margin:0}.cc2-detail-occ{display:flex;align-items:center;gap:6px;margin-left:auto;font-size:14px;color:var(--text-secondary);font-family:JetBrains Mono,monospace}.cc2-detail-pct{font-weight:700}.cc2-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.cc2-detail-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px}.cc2-detail-box h4{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text-secondary);margin:0 0 10px}.cc2-barrier-list{display:flex;flex-direction:column;gap:10px}.cc2-gate-group{background:var(--bg-secondary);border-radius:var(--radius-sm);padding:8px}.cc2-gate-header{font-size:12px;font-weight:600;color:var(--text-primary);padding:4px 6px 6px;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:6px}.cc2-barrier-row{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;background:#ffffff08;border-radius:var(--radius-sm)}.cc2-barrier-row+.cc2-barrier-row{margin-top:4px}.cc2-barrier-name{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary)}.cc2-search-row{display:flex;gap:8px;margin-bottom:8px}.cc2-search-results{display:flex;flex-direction:column;gap:5px}.cc2-search-item{display:flex;align-items:center;gap:10px;padding:8px 10px;background:var(--bg-secondary);border-radius:var(--radius-sm);font-size:12px}.cc2-vehicle-list{display:flex;flex-direction:column;gap:5px;max-height:320px;overflow-y:auto}.cc2-vehicle-item{padding:8px 10px;background:var(--bg-secondary);border-radius:var(--radius-sm);border-left:3px solid var(--border)}.cc2-vehicle-item.payment-failed{border-left-color:var(--accent-red);background:#f871710a}.cc2-vehicle-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px}.cc2-vehicle-plate-row{display:flex;align-items:center;gap:6px}.cc2-plate-original,.cc2-vehicle-time{font-size:10px;color:var(--text-muted);font-family:JetBrains Mono,monospace}.cc2-vehicle-bottom{display:flex;align-items:center;justify-content:space-between}.cc2-vehicle-amount{font-size:12px;color:var(--text-secondary);display:flex;align-items:center;gap:6px}.cc2-vehicle-actions{display:flex;gap:4px}.cc2-pay-fail-tag{font-size:9px;font-weight:600;color:var(--accent-red);background:#f871711f;padding:1px 6px;border-radius:4px}.cc2-pay-ok-tag{font-size:9px;font-weight:600;color:var(--accent-green);background:#34d3991f;padding:1px 6px;border-radius:4px}.cc2-plate-edit{display:flex;align-items:center;gap:4px}.cc2-icon-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;border-radius:4px;cursor:pointer;transition:all .15s}.cc2-icon-btn.edit{background:#38bdf81a;color:var(--accent-cyan)}.cc2-icon-btn.edit:hover{background:#38bdf833}.cc2-icon-btn.ok{background:#34d39926;color:var(--accent-green)}.cc2-icon-btn.ok:hover{background:#34d39940}.cc2-icon-btn.cancel{background:#f871711a;color:var(--accent-red)}.cc2-icon-btn.cancel:hover{background:#f8717133}.cc2-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.cc2-modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);width:420px;max-width:90vw;box-shadow:0 20px 60px #0006}.cc2-modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}.cc2-modal-header h4{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--text-primary);margin:0}.cc2-modal-body{padding:16px;display:flex;flex-direction:column;gap:10px}.cc2-modal-info{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text-secondary);background:var(--bg-card);padding:10px 12px;border-radius:var(--radius-sm)}.cc2-modal-loss{color:var(--accent-red);font-weight:600;font-size:13px}.cc2-modal-label{font-size:12px;color:var(--text-muted);font-weight:500;margin-top:4px}.cc2-modal-body textarea{resize:vertical;min-height:50px}.cc2-quick-reasons{display:flex;flex-wrap:wrap;gap:5px}.cc2-quick-reason{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px 10px;font-size:11px;color:var(--text-secondary);cursor:pointer;transition:all .15s;text-align:left}.cc2-quick-reason:hover{border-color:var(--accent-blue);color:var(--accent-blue)}.cc2-quick-reason.active{background:var(--accent-blue);border-color:var(--accent-blue);color:#fff}.cc2-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 16px;border-top:1px solid var(--border)}.cc2-detail-events{display:flex;flex-direction:column;gap:2px}.cc2-msg{padding:8px 14px;border-radius:var(--radius-sm);font-size:12px;margin-bottom:10px}.cc2-msg-success{background:#34d3991a;color:var(--accent-green);border:1px solid rgba(52,211,153,.2)}.cc2-msg-error{background:#f871711a;color:var(--accent-red);border:1px solid rgba(248,113,113,.2)}.cc2-mono{font-family:JetBrains Mono,monospace;font-weight:600;color:var(--text-primary);letter-spacing:.5px;font-size:12px}.cc2-empty{text-align:center;color:var(--text-muted);padding:40px 16px;font-size:13px}.cc2-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;background:var(--bg-card);color:var(--text-primary);font-family:inherit}.cc2-btn:hover{border-color:var(--accent-cyan);color:var(--accent-cyan)}.cc2-btn:disabled{opacity:.5;cursor:default;pointer-events:none}.cc2-btn-sm{padding:4px 10px;font-size:11px}.cc2-btn-primary{background:#38bdf826;color:var(--accent-cyan);border-color:#38bdf84d;font-weight:600}.cc2-btn-primary:hover{background:#38bdf840}.cc2-btn-danger{background:#f8717126;color:#f87171;border-color:#f871714d;font-weight:600}.cc2-btn-danger:hover{background:#f8717140}.cc2-btn-warning{background:#fbbf2426;color:var(--accent-yellow);border-color:#fbbf244d;font-weight:600}.cc2-btn-warning:hover{background:#fbbf2440}.cc2-btn-ghost{background:transparent;border-color:transparent}.cc2-btn-ghost:hover{background:var(--bg-card-hover)}.cc2-plate-display{display:inline-block;padding:10px 20px;background:#22c55e1f;border:2px solid var(--accent-green);border-radius:10px;color:var(--accent-green);font-family:JetBrains Mono,monospace;font-size:24px;font-weight:800;letter-spacing:2px;text-align:center}.page-content:has(.anpr-fullscreen){padding:0}.anpr-fullscreen{display:flex;flex-direction:column;height:calc(100vh - 60px);overflow:hidden}.anpr-topbar{display:flex;align-items:center;padding:8px 12px;border-bottom:1px solid var(--border);background:var(--bg-card);flex-shrink:0}.anpr-main{display:grid;grid-template-columns:380px 1fr;gap:10px;flex:1;min-height:0;padding:10px}.anpr-panels{display:flex;flex-direction:column;gap:10px;overflow-y:auto}.anpr-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.anpr-panel-header{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;font-size:12px;font-weight:700;gap:6px}.anpr-panel-header span{display:flex;align-items:center;gap:6px}.anpr-panel-entry{background:#22c55e14;color:var(--accent-green);border-bottom:2px solid var(--accent-green)}.anpr-panel-exit{background:#ef444414;color:var(--accent-red);border-bottom:2px solid var(--accent-red)}.anpr-panel-body{padding:8px;max-height:calc(50vh - 60px);overflow-y:auto}.anpr-logs{display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;min-height:0}.anpr-logs-scroll{flex:1;overflow-y:auto;min-height:0}@media(max-width:1100px){.anpr-main{grid-template-columns:1fr}.anpr-panels{flex-direction:row}.anpr-panel{flex:1;min-width:0}}.anpr-thumb{position:relative;width:90px;height:56px;border-radius:4px;overflow:hidden;border:1px solid var(--border);cursor:pointer}.anpr-thumb>img{width:100%;height:100%;object-fit:cover;display:block}.anpr-thumb-zoom{display:none;position:fixed;z-index:999;pointer-events:none;border-radius:8px;overflow:hidden;box-shadow:0 12px 40px #00000080;border:2px solid var(--border)}.anpr-thumb-zoom img{width:500px;height:auto;display:block}.anpr-thumb:hover .anpr-thumb-zoom{display:block;top:50%;left:50%;transform:translate(-50%,-50%)}.img-preview-modal{position:relative;overflow:auto;max-width:92vw;max-height:90vh;border-radius:8px;box-shadow:0 20px 60px #0009}.img-preview-modal img{transition:transform .2s ease;transform-origin:center center}.camera-feed{position:relative;background:#0a0e1a;border-radius:var(--radius);overflow:hidden;min-height:160px;display:flex;align-items:center;justify-content:center}.camera-feed-img{width:100%;height:100%;object-fit:cover;display:block}.camera-feed-label{position:absolute;top:8px;left:8px;background:#000000a6;color:#fff;font-size:11px;font-weight:600;padding:3px 10px;border-radius:4px;z-index:1;letter-spacing:.3px}.camera-feed-empty{flex-direction:column;gap:8px;color:var(--text-muted);font-size:12px;border:1px dashed var(--border);background:var(--bg-secondary)}.camera-feed-error{display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--accent-red);font-size:12px}.cc2-modal-wide{width:540px;max-width:94vw;max-height:90vh;display:flex;flex-direction:column}.cc2-modal-wide .cc2-modal-actions{padding:14px 20px}.cc2-modal-wide .cc2-modal-actions h5{margin:0 0 8px;font-size:12px}.cc2-modal-wide .cc2-modal-alert-info{padding:12px 20px 10px}.cc2-modal-scroll{overflow-y:auto;flex:1;min-height:0}.cc2-modal-footer-sticky{border-top:1px solid var(--border);padding:10px 20px;background:var(--bg-secondary);display:flex;flex-direction:column;gap:8px}.cc2-modal-footer-sticky .cc2-modal-btn-row{margin-top:0}.cc2-modal-footer-sticky .cc2-exemption-total{padding:6px 10px}.cc2-toggle-row{display:flex;gap:4px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px;margin-bottom:10px}.cc2-toggle-btn{flex:1;background:transparent;border:none;padding:7px 10px;border-radius:6px;color:var(--text-secondary);font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}.cc2-toggle-btn.active{background:var(--accent-cyan);color:#0b1528}.cc2-toggle-btn:disabled{opacity:.4;cursor:not-allowed}.cc2-quick-time-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.cc2-quick-time{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 8px;color:var(--text-primary);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}.cc2-quick-time:hover:not(:disabled){border-color:var(--accent-cyan)}.cc2-quick-time.selected{border-color:var(--accent-cyan);background:#38bdf81f;color:var(--accent-cyan)}.cc2-quick-time:disabled{opacity:.5;cursor:not-allowed}.cc2-time-inputs{display:grid;grid-template-columns:1fr 1fr;gap:10px}.cc2-time-input-group{display:flex;align-items:center;gap:8px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 12px}.cc2-time-input-group:focus-within{border-color:var(--accent-cyan)}.cc2-time-input{flex:1;background:transparent;border:none;color:var(--text-primary);font-size:16px;font-weight:700;font-family:JetBrains Mono,monospace;text-align:right;outline:none;min-width:0}.cc2-time-input::-webkit-inner-spin-button{opacity:.5}.cc2-time-suffix{font-size:12px;color:var(--text-muted)}.cc2-time-summary{margin-top:8px;padding:8px 12px;background:#38bdf814;border-radius:var(--radius-sm);font-size:12px;color:var(--text-secondary);text-align:center}.cc2-time-summary strong{color:var(--accent-cyan);font-family:JetBrains Mono,monospace}.cc2-modal-msg-info{background:#38bdf81a;color:var(--accent-cyan)}.cc2-exemption-options{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:6px}.cc2-exemption-option{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s}.cc2-exemption-option:hover{border-color:var(--accent-cyan)}.cc2-exemption-option.selected{border-color:var(--accent-cyan);background:#38bdf814}.cc2-exemption-option input[type=radio]{accent-color:var(--accent-cyan)}.cc2-exemption-label{font-size:13px;font-weight:600;color:var(--text-primary)}.cc2-exemption-desc{font-size:11px;color:var(--text-muted);margin-top:2px}.cc2-exemption-total{display:flex;justify-content:space-between;align-items:center;margin-top:14px;padding:10px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;color:var(--text-secondary)}.cc2-exemption-total strong{color:var(--accent-green);font-size:16px;font-family:JetBrains Mono,monospace}.cc2-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:7px 12px;color:var(--text-primary);font-size:12px;font-family:inherit;outline:none;flex:1}.cc2-input:focus{border-color:var(--accent-cyan)}.cc2-input-sm{padding:4px 8px;font-size:11px}@media(max-width:1100px){.cc2-right-panel{width:260px;min-width:260px}.cc2-stats-row{grid-template-columns:repeat(3,1fr)}}@media(max-width:900px){.cc2-right-panel{display:none}.cc2-detail-grid{grid-template-columns:1fr}.cc2-stats-row{grid-template-columns:repeat(2,1fr)}}
