:root{--bg:#ecebe6;--surface:#f5f4ef;--surface-2:#faf9f5;--ink:#0e0e0e;--ink-2:#2a2a2a;--muted:#6e6c66;--line:#d9d7d0;--line-2:#c2c0b8;--blue:#0e0e0e;--blue-2:#000000;--blue-3:#2a2a2a;--blue-soft:#e3e1d9;--blue-soft-2:#d6d3c9;--cyan:#0e7490;--cyan-soft:#e0eef2;--red:#c2410c;--red-soft:#f1e0d6;--green:#3f6b3a;--green-soft:#e3ebd9;--amber:#a87b2f;--amber-soft:#efe6d2;--purple:#5b3a8f;--purple-soft:#e6dff0;--shadow-sm:0 1px 0 rgba(14,14,14,.04);--shadow-md:0 2px 0 rgba(14,14,14,.06), 0 6px 18px -8px rgba(14,14,14,.1);--shadow-lg:0 24px 60px -20px rgba(14,14,14,.25);--grad-primary:#0e0e0e;--grad-emerald:#3f6b3a;--grad-rose:#c2410c;--grad-amber:#a87b2f;--grad-surface:#f5f4ef;--font-display:"Inter Tight","Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-body:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif}*{box-sizing:border-box}html,body{margin:0;padding:0;font-family:var(--font-body);background:var(--bg);color:var(--ink);font-size:14px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-feature-settings:"ss01","cv11"}a{color:var(--ink);text-decoration:none}a:hover{text-decoration:underline;text-underline-offset:3px}button{font-family:inherit}h1,h2,h3,h4{font-family:var(--font-display);letter-spacing:-.03em;font-weight:800}h1{letter-spacing:-.045em;font-weight:900}.page-head h1{font-size:34px;font-weight:900;letter-spacing:-.045em}.kpi-value,.cc-stat-v,.rk-value,.cc-eq-tot .n,.cc-donut-center .n,.cc-rev-v{font-family:var(--font-display);font-weight:900;letter-spacing:-.03em}.auth-body{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(1200px 600px at 10% 0%,#ececec 0%,transparent 60%),radial-gradient(900px 500px at 100% 100%,#f5f5f5 0%,transparent 55%),#f4f4f5;padding:24px}.auth-shell-wrap{width:100%;max-width:1040px;display:flex;flex-direction:column;gap:14px}.auth-shell{width:100%;display:grid;grid-template-columns:1.05fr 1fr;background:var(--surface);border:1px solid rgba(15,23,42,.06);border-radius:18px;overflow:hidden;box-shadow:0 20px 50px -20px #0f172a2e,0 6px 14px -10px #0f172a1a}.auth-shell-wrap>.powered-footer{border:1px solid #d6d3c7;border-radius:12px}.auth-hero{position:relative;padding:0;color:#fff;background:linear-gradient(135deg,#0a0a0a,#1f1f1f 55%,#2d2d2d);overflow:hidden}.auth-hero:before{content:"";position:absolute;inset:auto -40px -120px auto;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.12),transparent 70%);pointer-events:none}.auth-hero:after{content:"";position:absolute;top:-80px;right:-80px;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.08),transparent 70%);pointer-events:none}.auth-hero-inner{position:relative;padding:44px 40px;display:flex;flex-direction:column;gap:14px;height:100%;min-height:520px}.brand{display:flex;align-items:center;gap:10px}.brand-mark{width:42px;height:42px;border-radius:10px;background:#fff;color:#0a0a0a;display:grid;place-items:center;font-weight:800;font-size:12px;letter-spacing:.5px;box-shadow:0 8px 20px -8px #0009}.brand-name{font-weight:600;font-size:14px;letter-spacing:.2px;color:#e4e4e7}.auth-hero h1{font-size:32px;margin:24px 0 0;font-weight:700;line-height:1.15;letter-spacing:-.5px;color:#fff}.auth-hero p{color:#d4d4d8;max-width:360px;line-height:1.6;margin:10px 0 0;font-size:14px}.hero-points{list-style:none;padding:0;margin:22px 0 0;display:grid;gap:14px;color:#e4e4e7;font-size:14px}.hero-points li{display:flex;align-items:center;gap:12px}.hero-points li svg{flex-shrink:0;width:34px;height:34px;padding:8px;border-radius:9px;background:#ffffff1f;color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.hero-points li>span{background:transparent;width:auto;height:auto;display:inline;margin:0;border-radius:0;color:#e4e4e7}.hero-footer{margin-top:auto;color:#a1a1aa;font-size:12px;padding-top:30px;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}.card-powered{margin-top:14px;display:flex;align-items:center;justify-content:center;gap:10px;padding:10px 14px;background:#0a0a0a;border:1px solid #0a0a0a;border-radius:10px}.card-powered>span{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#e4e4e7}.card-powered>img{height:44px;width:auto;object-fit:contain;filter:brightness(1.15)}.auth-card{padding:48px 44px;display:flex;flex-direction:column;gap:8px;background:#fff}.auth-card>header h2{margin:0;font-size:24px;font-weight:700;letter-spacing:-.3px;color:#0f172a}.auth-card>header p{color:#64748b;margin:6px 0 0;font-size:13.5px}.auth-card form{display:grid;gap:16px;margin-top:18px}.auth-card label{display:grid;gap:7px;font-size:12.5px;color:#334155;font-weight:600;letter-spacing:.02em}.auth-card .inp-wrap{position:relative;display:flex;align-items:center}.auth-card .inp-wrap .inp-ic{position:absolute;left:12px;color:#94a3b8;pointer-events:none}.auth-card .inp-wrap input{flex:1;background:#f8fafc;border:1px solid #e2e8f0;padding:12px 38px;border-radius:10px;font-size:14px;outline:none;color:#0f172a;transition:border-color .15s,box-shadow .15s,background .15s}.auth-card .inp-wrap input:focus{border-color:#0a0a0a;box-shadow:0 0 0 4px #00000014;background:#fff}.auth-card .inp-eye{position:absolute;right:6px;background:none;border:none;cursor:pointer;font-size:14px;padding:6px 8px;border-radius:6px;color:#64748b}.auth-card .inp-eye:hover{background:#f1f5f9}.auth-submit{padding:13px 16px;border-radius:10px;font-size:14.5px;font-weight:600;background:#0a0a0a;color:#fff;border:none;box-shadow:0 8px 18px -8px #00000073;transition:transform .08s,box-shadow .15s,background .15s;margin-top:4px}.auth-submit:hover:not(:disabled){background:#1f1f1f;transform:translateY(-1px);box-shadow:0 12px 22px -10px #00000080}.auth-submit:disabled{opacity:.7;cursor:not-allowed}.demo-creds{display:flex;align-items:center;gap:10px;background:#f4f4f5;border:1px dashed #d4d4d8;color:#3f3f46;padding:10px 12px;border-radius:10px;font-size:13px;justify-content:center}.demo-tag{font-size:10px;font-weight:700;letter-spacing:.1em;background:#0a0a0a;color:#fff;padding:3px 8px;border-radius:999px}@media (max-width:820px){.auth-shell{grid-template-columns:1fr}.auth-hero-inner{min-height:auto;padding:32px 28px}.auth-card{padding:32px 28px}}.row-between{display:flex;align-items:center;justify-content:space-between;font-size:13px}.checkbox{display:flex;align-items:center;gap:7px;color:var(--ink-2)}.btn-primary{background:var(--blue);border:1px solid var(--blue-2);color:#fff;padding:10px 14px;border-radius:6px;font-weight:600;cursor:pointer;font-size:14px}.btn-primary:hover{background:var(--blue-2)}.btn-ghost{background:#fff;border:1px solid var(--line-2);color:var(--ink-2);padding:7px 12px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500}.btn-ghost:hover{background:#f5f6f8}.hint{color:var(--muted);font-size:12px;text-align:center;margin:0}.error{color:var(--red);font-size:13px;margin:0}.auth-foot{color:var(--muted);font-size:13px;text-align:center;margin-top:14px;border-top:1px solid var(--line);padding-top:14px}.app{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.sidebar{background:#fff;border-right:1px solid var(--line);padding:20px 14px;display:flex;flex-direction:column;gap:18px;position:sticky;top:0;height:100vh;overflow-y:auto}.logo{padding:0 6px 14px;border-bottom:1px solid var(--line)}.brand-logo{display:flex;align-items:center;gap:10px;background:var(--blue);border-radius:8px;padding:10px 12px;border-bottom:none}.brand-logo .brand-mark{width:42px;height:42px;border-radius:6px;background:#fff;color:var(--blue);display:grid;place-items:center;font-weight:800;font-size:13px;letter-spacing:.5px;border-bottom:3px solid var(--red);flex-shrink:0}.brand-logo .brand-name{color:#fff;font-weight:700;font-size:15px;letter-spacing:.2px}.logo-text{font-weight:800;font-size:24px;color:var(--blue);letter-spacing:.5px;display:flex;align-items:center;gap:2px}.logo-arrow{color:#f97316;font-weight:900;margin-left:2px}.logo-tag{color:var(--muted);font-size:10.5px;margin-top:2px;letter-spacing:.3px}.nav-group{display:flex;flex-direction:column;gap:2px}.nav-label{color:var(--muted);font-size:10.5px;font-weight:700;letter-spacing:.8px;padding:6px 10px;display:inline-flex;align-items:center;gap:6px}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;color:var(--ink-2);cursor:pointer;font-size:14px;font-weight:500}.nav-item .ic{width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;color:var(--ink-2)}.nav-item:hover{background:#f5f6f8;color:var(--ink)}.nav-item.active{background:var(--blue);color:#fff}.nav-item.active .ic{color:#fff}.pill{margin-left:auto;background:var(--red);color:#fff;font-size:11px;font-weight:700;border-radius:999px;padding:1px 7px;min-width:20px;text-align:center}.nav-item.active .pill{background:#fff;color:var(--blue)}.side-foot{margin-top:auto;padding-top:14px;border-top:1px solid var(--line)}.app-shell{display:flex;flex-direction:column;min-height:100vh}.powered-footer{width:100%;padding:8px 0;margin-top:0;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:14px;border-top:1px solid #0a0a0a;background:#0a0a0a}.powered-logo{height:44px;width:auto;object-fit:contain;opacity:1;image-rendering:-webkit-optimize-contrast;filter:brightness(1.15)}.powered-footer>span{font-size:12px;color:#e4e4e7;font-weight:700;letter-spacing:.12em;text-transform:uppercase}html{scrollbar-color:#404040 #0a0a0a}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:#0a0a0a}::-webkit-scrollbar-thumb{background:#404040;border-radius:6px;border:2px solid #0a0a0a}::-webkit-scrollbar-thumb:hover{background:#525252}::-webkit-scrollbar-corner{background:#0a0a0a}.user-chip{display:flex;align-items:center;gap:10px;padding:8px;border-radius:6px}.avatar{width:34px;height:34px;border-radius:50%;background:var(--blue);color:#fff;display:grid;place-items:center;font-weight:700;font-size:14px;flex-shrink:0}.avatar.sm{width:30px;height:30px;font-size:13px}.user-name{font-size:13px;font-weight:600;color:var(--ink)}.user-role{color:var(--muted);font-size:11.5px}.main{padding:18px 22px 28px;display:flex;flex-direction:column;gap:16px;min-width:0;background:var(--bg)}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px 16px}.topbar-left{display:flex;align-items:center;gap:14px}.crumbs{font-size:14px;color:var(--ink)}.crumbs .sep{color:var(--muted);margin:0 6px}.topbar-right{display:flex;align-items:center;gap:10px}.icon-btn{background:transparent;border:none;font-size:16px;cursor:pointer;color:var(--ink-2);width:34px;height:34px;border-radius:50%;display:grid;place-items:center;position:relative}.icon-btn:hover{background:#f5f6f8}.bell-dot{position:absolute;top:7px;right:8px;width:7px;height:7px;background:var(--red);border-radius:50%;border:2px solid #fff}.clock{text-align:right}.clock>div:first-child{font-weight:600;font-family:ui-monospace,monospace}.small{font-size:11.5px}.lang-btn{background:#fff;border:1px solid var(--line-2);border-radius:999px;padding:6px 12px;font-size:13px;color:var(--ink-2);cursor:pointer;font-weight:500}.profile{display:flex;align-items:center;gap:8px;border:1px solid var(--line-2);border-radius:999px;padding:3px 12px 3px 3px;cursor:pointer;background:#fff}.profile .user-name{font-size:12.5px;line-height:1.1}.profile .user-role{font-size:11px;line-height:1.1}.page-head{display:flex;align-items:center;justify-content:space-between;gap:16px}.page-head-left{display:flex;align-items:center;gap:14px}.page-icon{width:48px;height:48px;border-radius:10px;background:var(--blue-soft);color:var(--blue);display:grid;place-items:center;font-size:22px}.page-head h1{margin:0;font-size:24px;font-weight:700}.page-head p{margin:2px 0 0;font-size:13.5px}.page-head-right{display:flex;align-items:center;gap:10px}.status-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border-radius:999px;font-size:12px;font-weight:600;background:var(--green-soft);color:var(--green);border:1px solid #c8e9d3}.status-pill.err{background:var(--red-soft);color:var(--red);border-color:#f3cdcd}.status-pill.small{padding:3px 9px;font-size:11px}.kpis{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}.kpi{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px}.kpi-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.kpi-icon{width:34px;height:34px;border-radius:8px;display:grid;place-items:center;font-size:15px}.kpi-icon.b{background:var(--blue-soft);color:var(--blue)}.kpi-icon.g{background:var(--green-soft);color:var(--green)}.kpi-icon.p{background:var(--purple-soft);color:var(--purple)}.kpi-icon.r{background:var(--red-soft);color:var(--red)}.kpi-icon.t{background:var(--cyan-soft);color:var(--cyan)}.kpi-icon.o{background:var(--amber-soft);color:var(--amber)}.kpi-value{font-size:24px;font-weight:700;color:var(--ink);line-height:1.1}.kpi-label{color:var(--muted);font-size:13px;margin-top:4px}.delta{font-size:12px;font-weight:600}.delta.up{color:var(--green)}.delta.down{color:var(--red)}.row{display:grid;gap:14px}.row.row-2-1{grid-template-columns:2fr 1fr}.row.row-1-2{grid-template-columns:1fr 2fr}.card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px 18px}.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.card-title{display:flex;align-items:center;gap:10px}.card-ic{width:32px;height:32px;border-radius:8px;background:var(--blue-soft);color:var(--blue);display:grid;place-items:center;font-size:14px}.card-title h3{margin:0;font-size:15px;font-weight:700}.card-title p{margin:1px 0 0}.card-amt{font-size:22px;font-weight:700}.muted{color:var(--muted)}.tabs{display:flex;gap:4px;background:#f5f6f8;padding:3px;border-radius:999px}.tab{background:transparent;border:none;padding:6px 12px;border-radius:999px;font-size:12.5px;color:var(--ink-2);cursor:pointer;font-weight:500}.tab.active{background:var(--blue);color:#fff}canvas{display:block;width:100%;max-width:100%}#volumeChart{height:280px}#rfidAnprChart,#revenueChart{height:230px}.chart-foot{display:flex;justify-content:space-between;align-items:center;margin-top:8px;font-size:12.5px;color:var(--ink-2)}.legend-sq{display:inline-block;width:11px;height:11px;border-radius:3px;margin-right:6px;vertical-align:middle}.legend-sq.blue{background:var(--blue)}.legend-sq.cyan{background:var(--cyan)}.up{color:var(--green);font-weight:600}.down{color:var(--red);font-weight:600}.legend-inline{display:flex;gap:14px;font-size:12.5px;color:var(--ink-2)}.donut-wrap{position:relative;width:220px;height:220px;margin:6px auto 12px}.donut-center{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;text-align:center;pointer-events:none}.donut-val{font-size:22px;font-weight:700}.donut-lbl{font-size:10px;letter-spacing:1px;color:var(--muted);font-weight:600}.donut-legend{list-style:none;padding:0;margin:0;display:grid;gap:8px}.donut-legend li{display:grid;grid-template-columns:1fr 100px 40px;align-items:center;gap:10px;font-size:13px;color:var(--ink-2)}.donut-legend .lk{display:flex;align-items:center;gap:8px}.donut-legend .lk .d{width:8px;height:8px;border-radius:50%}.donut-legend .bar{height:6px;background:#f0f1f4;border-radius:999px;overflow:hidden}.donut-legend .bar span{display:block;height:100%}.donut-legend .pct{font-weight:600;color:var(--ink);text-align:right}.cam-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:12px 0 16px}.cam-stat{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px 12px}.cam-stat-ic{font-size:18px;color:var(--muted)}.cam-stat.ok .cam-stat-ic{color:var(--green)}.cam-stat.err .cam-stat-ic{color:var(--red)}.cam-stat.warn .cam-stat-ic{color:var(--amber)}.cam-stat-val{font-size:20px;font-weight:700;color:var(--ink)}.uptime-cell{display:flex;align-items:center;gap:8px;min-width:140px}.uptime-bar{display:flex;flex:1;height:8px;border-radius:4px;overflow:hidden;background:var(--line)}.uptime-seg{display:block;height:100%}.uptime-seg.ok{background:var(--green)}.uptime-seg.warn{background:var(--amber)}.uptime-seg.err{background:var(--red)}.equip-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}.equip{background:#fff;border:1px solid var(--line);border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:8px}.equip-head{display:flex;align-items:center;gap:8px}.equip-ic{width:28px;height:28px;border-radius:7px;background:var(--blue-soft);color:var(--blue);display:grid;place-items:center;font-size:13px}.equip-name{font-size:13.5px;font-weight:600}.equip-stat{display:flex;align-items:baseline;justify-content:space-between}.equip-total{font-size:24px;font-weight:700}.equip-stat .muted{font-size:12px}.equip-rows{display:flex;flex-direction:column;gap:4px;font-size:12.5px}.equip-rows div{display:flex;justify-content:space-between;align-items:center}.dot{width:7px;height:7px;border-radius:50%;display:inline-block;margin-right:6px}.dot.ok{background:var(--green)}.dot.err{background:var(--red)}.dot.warn{background:var(--amber)}.equip-bar{height:5px;background:#f0f1f4;border-radius:999px;overflow:hidden;margin-top:2px}.equip-bar span{display:block;height:100%;background:var(--green)}.eticket-list{display:flex;flex-direction:column;gap:10px}.eticket-row{display:grid;grid-template-columns:36px 1fr auto;align-items:center;gap:12px;padding:12px;border-radius:10px;border:1px solid var(--line)}.eticket-row.ok{background:var(--green-soft);border-color:#cfeada}.eticket-row.err{background:var(--red-soft);border-color:#f3cdcd}.eticket-row.warn{background:var(--amber-soft);border-color:#f7e1bb}.et-ic{width:30px;height:30px;border-radius:50%;background:#fff;display:grid;place-items:center;font-weight:700;font-size:14px}.eticket-row.ok .et-ic{color:var(--green)}.eticket-row.err .et-ic{color:var(--red)}.eticket-row.warn .et-ic{color:var(--amber)}.et-title{font-weight:600;font-size:14px}.et-num{text-align:right}.et-num .big{font-size:24px;font-weight:700}.acc-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}.acc{display:flex;align-items:center;gap:10px;padding:12px;border-radius:10px}.acc.blue-bg{background:var(--blue-soft)}.acc.cyan-bg{background:var(--cyan-soft)}.acc-ic{width:34px;height:34px;border-radius:8px;background:#fff;display:grid;place-items:center}.acc-val{font-size:22px;font-weight:700}.lane-status{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.lane-status li{display:flex;align-items:center;justify-content:space-between;padding:11px 12px;border:1px solid var(--line);border-radius:10px;background:#fff}.lane-status .ln-left{display:flex;align-items:center;gap:10px}.lane-status .ln-title{font-weight:600;font-size:13.5px}.lane-status .ln-sub{color:var(--muted);font-size:12px;margin-top:1px}.lane-status .ln-amt{font-weight:700;text-align:right}.lane-status .ln-tag{font-size:11px;color:var(--green);font-weight:600;text-align:right;margin-top:1px}.lane-status li.offline .ln-tag{color:var(--red)}.table{width:100%;border-collapse:collapse;font-size:13px}.table th,.table td{text-align:left;padding:10px;border-bottom:1px solid var(--line)}.table th{color:var(--muted);font-weight:600;font-size:11.5px;background:#fafbfc}.table tbody tr:hover{background:#fafbfc}.tag{display:inline-block;padding:2px 9px;border-radius:6px;font-size:11.5px;font-weight:600}.tag.lhs,.tag.rhs,.tag.mid{background:var(--amber-soft);color:var(--amber)}.tag.healthy{background:var(--green-soft);color:var(--green)}.tag.degraded{background:var(--amber-soft);color:var(--amber)}.tag.critical{background:var(--red-soft);color:var(--red)}.check{width:22px;height:22px;border-radius:50%;display:inline-grid;place-items:center;font-size:12px;font-weight:700}.check.ok{background:var(--green-soft);color:var(--green)}.check.no{background:var(--red-soft);color:var(--red)}.alerts{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.alerts li{display:grid;grid-template-columns:34px 1fr auto;gap:10px;align-items:center;padding:10px;border:1px solid var(--line);border-radius:10px}.al-ic{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;font-weight:700}.al-ic.ok{background:var(--green-soft);color:var(--green)}.al-ic.warn{background:var(--amber-soft);color:var(--amber)}.al-ic.err{background:var(--red-soft);color:var(--red)}.al-title{font-weight:600;font-size:13.5px}.link{color:var(--blue);font-size:13px;font-weight:600}.pager-size{justify-content:space-between}.size-group{display:flex;align-items:center;gap:6px}.size-btn{background:transparent;border:none;width:32px;height:32px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;color:var(--ink-2)}.size-btn:hover{background:#f5f6f8}.size-btn.active{background:var(--blue);color:#fff}.page-nums{display:flex;align-items:center;gap:4px;margin-left:auto}.pg-btn{background:transparent;border:none;width:32px;height:32px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;color:var(--ink-2);display:grid;place-items:center}.pg-btn:hover:not(:disabled){background:#f5f6f8}.pg-btn.active{background:var(--blue);color:#fff}.pg-btn:disabled{opacity:.4;cursor:not-allowed}.row.row-1-1{grid-template-columns:1.5fr 1fr}.preview{background:#fff;border-radius:10px;min-height:280px;display:grid;place-items:center;border:1px dashed var(--line-2)}.preview-empty{text-align:center;color:var(--ink-2)}.prev-warn{width:60px;height:60px;border-radius:14px;background:var(--amber-soft);color:var(--amber);font-size:30px;display:grid;place-items:center;margin:0 auto 12px}.prev-title{font-size:14px;color:var(--ink);margin-bottom:4px;font-weight:500}.preview.has-img{background:#0b1220;border-style:solid;color:#fff;padding:0;overflow:hidden;position:relative}.preview .pv-frame{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#94a8b8,#7c8a98 40%,#525c66)}.preview .pv-frame:before{content:"";position:absolute;left:0;right:0;top:48%;height:2px;background:#5aa9e6;opacity:.7}.preview .pv-frame:after{content:"";position:absolute;left:0;right:0;top:60%;bottom:20%;background:repeating-linear-gradient(90deg,transparent 0,transparent 40px,#fff 40px,#fff 60px);opacity:.18}.preview .pv-tag{position:absolute;top:12px;left:12px;background:var(--red);color:#fff;font-size:11px;font-weight:700;padding:3px 10px;border-radius:4px;letter-spacing:.5px;z-index:2}.preview .pv-bot{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(180deg,transparent,rgba(0,0,0,.75));padding:12px;z-index:2;display:flex;justify-content:space-between;color:#fff;font-size:13px}.preview .pv-plate{font-family:ui-monospace,monospace;font-weight:700;letter-spacing:1px}.brk-list{list-style:none;padding:0;margin:0 0 14px;display:flex;flex-direction:column;gap:10px}.brk-list li{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;font-size:13.5px}.brk-list .brk-bar{height:6px;background:#f0f1f4;border-radius:999px;overflow:hidden}.brk-list .brk-bar span{display:block;height:100%;background:var(--red)}.brk-list .brk-n{font-weight:700;color:var(--ink);min-width:40px;text-align:right}.status-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:8px}.stat-mini{background:#fff;border:1px solid var(--line);border-radius:10px;padding:12px;text-align:center}.stat-mini.amber,.stat-mini.amber-l{border-color:#f6dca0;background:#fff9ec}.stat-mini.green{border-color:#cdebd5;background:#f0faf4}.stat-mini.red{border-color:#f3cdcd;background:#fdf2f2}.mini-ic{width:30px;height:30px;border-radius:50%;background:#fff;display:grid;place-items:center;margin:0 auto 6px;font-weight:700}.stat-mini.amber .mini-ic,.stat-mini.amber-l .mini-ic{color:var(--amber)}.stat-mini.green .mini-ic{color:var(--green)}.stat-mini.red .mini-ic{color:var(--red)}.mini-n{font-size:24px;font-weight:800;color:var(--ink)}.eticket-table tbody td{font-size:13px;padding:14px 10px}.eticket-table tbody tr{cursor:pointer}.eticket-table tbody tr.selected{background:var(--blue-soft)}.vio-type{display:inline-block;padding:3px 11px;border-radius:5px;font-size:12px;font-weight:600}.vio-type.nofastag{background:var(--red-soft);color:var(--red)}.vio-type.speeding{background:var(--amber-soft);color:var(--amber)}.vio-type.wronglane{background:#fffae0;color:#a16207}.vio-type.axleviolation{background:var(--purple-soft);color:var(--purple)}.act-btn{border:none;font-size:12px;font-weight:600;padding:5px 11px;border-radius:5px;cursor:pointer;margin-right:4px}.act-btn.accept{background:var(--green-soft);color:var(--green)}.act-btn.accept:hover{background:#d6eedd}.act-btn.reject{background:var(--red-soft);color:var(--red)}.act-btn.reject:hover{background:#f4d5d5}.act-btn.exempt{background:var(--amber-soft);color:var(--amber)}.act-btn.exempt:hover{background:#f5e0ad}.done-tag{font-size:13px;font-weight:600}.done-tag.accepted{color:var(--green)}.done-tag.rejected{color:var(--red)}.done-tag.exempted{color:var(--amber)}.audit-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.aud-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px 18px}.aud-label{color:var(--muted);font-size:11px;font-weight:700;letter-spacing:.7px}.aud-val{font-size:36px;font-weight:800;margin:8px 0 6px;line-height:1}.aud-val.ink{color:var(--ink)}.aud-val.green{color:var(--green)}.aud-val.red{color:var(--red)}.aud-val.amber{color:var(--amber)}.aud-bar{height:6px;background:#f0f1f4;border-radius:999px;margin-top:8px;overflow:hidden}.aud-bar span{display:block;height:100%;background:var(--blue)}.audit-filter{display:flex;align-items:center;gap:10px;padding:14px 18px}.filter-sel{background:#fff;border:1px solid var(--line-2);padding:9px 12px;border-radius:6px;font-size:13px;color:var(--ink-2);font-family:inherit;outline:none;min-width:140px}.filter-sel:focus{border-color:var(--blue)}.search-box.wide{flex:1;min-width:240px}.audit-table tbody td{font-size:13px;padding:14px 10px;vertical-align:middle}.audit-table .aid{font-family:ui-monospace,monospace;font-size:12.5px;color:var(--ink-2)}.audit-table .vrn{font-family:ui-monospace,monospace;font-weight:700}.audit-table .ref,.audit-table .ts{font-family:ui-monospace,monospace;font-size:12px;color:var(--ink-2)}.audit-table input[type=checkbox]{accent-color:var(--blue);width:14px;height:14px;cursor:pointer}.audit-table .amt{color:var(--ink);font-weight:600}.audit-table .bank{color:var(--ink-2)}.audit-table .retry{background:transparent;border:none;color:var(--blue);font-weight:600;cursor:pointer;font-size:13px;display:inline-flex;align-items:center;gap:4px}.audit-table .retry:hover{text-decoration:underline}.audit-table .view{background:transparent;border:none;color:var(--ink-2);font-weight:500;cursor:pointer;font-size:13px}.audit-table .view:before{content:"● ";color:var(--ink-2);font-size:9px;vertical-align:middle}.audit-table .view:hover{color:var(--blue)}.prog-cell{display:flex;align-items:center;gap:10px}.prog-bar{flex:1;height:8px;background:#f0f1f4;border-radius:999px;overflow:hidden;max-width:90px}.prog-bar span{display:block;height:100%;background:var(--blue);border-radius:999px}.prog-n{font-weight:600;font-size:13px;color:var(--ink)}.fail-pill{display:inline-flex;align-items:center;gap:5px;padding:3px 11px;border-radius:999px;font-size:12px;font-weight:600}.fail-pill.ok{background:var(--green-soft);color:var(--green)}.fail-pill.bad{background:var(--red-soft);color:var(--red)}.tot-row{background:var(--blue-soft)}.tot-row td{border-top:1px solid var(--line);font-weight:700;font-size:13.5px}.tot-label{color:var(--blue);font-weight:800;letter-spacing:.3px}.tot-blue{color:var(--blue);font-weight:700}.tot-red{color:var(--red);font-weight:700}.report-filters{padding:18px 20px}.rf-title{font-size:13px;font-weight:600;color:var(--ink-2);margin-bottom:14px;display:flex;align-items:center;gap:6px}.filters-grid.filters-5{grid-template-columns:repeat(5,1fr)}.rf-foot{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:14px;border-top:1px solid var(--line);gap:12px;flex-wrap:wrap}.shift-group{display:flex;align-items:center;gap:6px}.shift-btn{background:#fff;border:1px solid var(--line-2);color:var(--ink-2);padding:6px 14px;border-radius:6px;font-size:12.5px;cursor:pointer;font-weight:500}.shift-btn:hover{background:#f5f6f8}.shift-btn.active{background:var(--blue);color:#fff;border-color:var(--blue)}.rf-actions{display:flex;gap:8px;align-items:center}.dl-wrap{position:relative}.dl-menu{position:absolute;right:0;top:calc(100% + 4px);background:#fff;border:1px solid var(--line);border-radius:8px;box-shadow:0 6px 20px #00000014;padding:6px;min-width:160px;z-index:5;display:flex;flex-direction:column;gap:2px}.dl-menu button{background:transparent;border:none;text-align:left;padding:8px 12px;font-size:13px;color:var(--ink-2);border-radius:6px;cursor:pointer}.dl-menu button:hover{background:#f5f6f8;color:var(--ink)}.report-empty{padding:60px 20px;text-align:center}.re-ic{width:80px;height:80px;border-radius:18px;background:var(--blue-soft);color:var(--blue);font-size:34px;display:grid;place-items:center;margin:0 auto 14px}.re-title{font-size:20px;font-weight:700;color:var(--ink);margin-bottom:6px}.rep-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}.rep-kpi{background:#fff;border:1px solid var(--line);border-radius:10px;padding:16px 18px}.rk-label{color:var(--muted);font-size:13px;margin-bottom:8px}.rk-value{font-size:28px;font-weight:800;line-height:1.1;margin-bottom:8px}.rk-value.c-k{color:var(--ink)}.rk-value.c-b{color:var(--blue)}.rk-value.c-p{color:var(--purple)}.rk-delta{font-size:12.5px}.rk-delta .up{color:var(--green);font-weight:600}.rep-table-head{display:flex;justify-content:space-between;align-items:center;margin:4px 0 12px}.rep-table-head h3{margin:0;font-size:15px;font-weight:700;color:var(--ink)}.cfg-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}.cfg-tab{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:#fff;border:1px solid var(--line);border-radius:10px;font-size:13.5px;font-weight:600;color:var(--ink-2);cursor:pointer}.cfg-tab:hover{background:#f7f8fa}.cfg-tab.active{border-color:var(--blue);color:var(--blue);box-shadow:0 0 0 1px var(--blue) inset}.cfg-tab-ic{font-size:14px}.lane-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.lane-card{padding:18px 20px}.lane-card.disabled{background:#fafbfc}.lane-card.disabled input,.lane-card.disabled select{background:#f5f6f8;color:var(--muted)}.lane-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.lane-head h3{margin:0;font-size:16px;font-weight:700;color:var(--ink)}.lane-toggle{display:flex;align-items:center;gap:10px}.tg-label{font-size:13px;font-weight:600}.tg-label.on{color:var(--blue)}.tg-label.off{color:var(--muted)}.tgl{width:42px;height:22px;background:#d4d7dd;border:none;border-radius:999px;position:relative;cursor:pointer;padding:0;transition:background .15s}.tgl span{position:absolute;top:2px;left:2px;width:18px;height:18px;background:#fff;border-radius:50%;box-shadow:0 1px 2px #0003;transition:left .15s}.tgl.on{background:var(--blue)}.tgl.on span{left:22px}.lane-form{display:grid;grid-template-columns:1fr 1fr;gap:12px 14px}.lane-field{display:flex;flex-direction:column;gap:6px}.lane-field>span{font-size:11.5px;font-weight:600;color:var(--muted);letter-spacing:.4px}.lane-field input,.lane-field select{padding:9px 12px;border:1px solid var(--line);border-radius:8px;font-size:13.5px;background:#fff;color:var(--ink);width:100%}.cfg-inp{padding:9px 12px;border:1px solid var(--line);border-radius:8px;font-size:13.5px;background:#fff;color:var(--ink);width:100%;outline:none;font-family:inherit}.cfg-inp:focus{border-color:var(--blue);box-shadow:0 0 0 3px #2a4cdb1f}.cfg-inp:disabled{background:#f5f6f8;color:var(--muted)}@media (max-width:900px){.lane-grid{grid-template-columns:1fr}}.status-pill.warn-pill{background:var(--amber-soft);color:var(--amber);border-color:#f3e5a8}.health-card{padding:18px 22px}.health-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.health-head h3{margin:0;font-size:15px;font-weight:700}.health-pct{font-size:22px;font-weight:800;color:var(--amber)}.health-bar{height:8px;background:#f0f1f4;border-radius:999px;overflow:hidden}.health-bar span{display:block;height:100%;background:linear-gradient(90deg,#16a34a,#facc15,#facc15);border-radius:999px}.health-foot{display:flex;justify-content:space-between;margin-top:8px}.nms-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.lane-card{background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden}.lane-card .lane-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px}.lane-card .lane-info{display:flex;align-items:center;gap:12px}.lane-card .lane-ico{width:38px;height:38px;border-radius:9px;display:grid;place-items:center;font-size:14px}.lane-card.ok .lane-head{background:#eafaef}.lane-card.warn .lane-head{background:#fff8e0}.lane-card.err .lane-head{background:#fdecec}.lane-card.ok .lane-ico{background:#cfeada;color:var(--green)}.lane-card.warn .lane-ico{background:#f6e1a4;color:var(--amber)}.lane-card.err .lane-ico{background:#f4cdcd;color:var(--red)}.lane-card h4{margin:0;font-size:17px;font-weight:700}.lane-card .sub{color:var(--ink-2);font-size:12.5px;margin-top:2px}.lane-card .status-x{font-size:13px;font-weight:600}.lane-card.ok .status-x{color:var(--green)}.lane-card.warn .status-x{color:var(--amber)}.lane-card.err .status-x{color:var(--red)}.dev-list{list-style:none;padding:0;margin:0}.dev-row{display:grid;grid-template-columns:14px 1fr auto auto;align-items:center;gap:12px;padding:11px 18px;border-top:1px solid var(--line)}.dev-row:hover{background:#fafbfc}.dev-dot{width:9px;height:9px;border-radius:50%}.dev-dot.ok{background:var(--green)}.dev-dot.warn{background:var(--amber)}.dev-dot.err{background:var(--red)}.dev-name{font-size:13.5px;font-weight:600}.dev-ip{color:var(--muted);font-size:12px;font-family:ui-monospace,monospace}.dev-meta{text-align:right;font-family:ui-monospace,monospace;font-size:12px}.dev-meta .lat{font-weight:700;display:block}.dev-meta .lat.ok{color:var(--green)}.dev-meta .lat.warn{color:var(--amber)}.dev-meta .lat.err{color:var(--red)}.dev-meta .ts{color:var(--muted)}.dev-pill{padding:3px 10px;border-radius:999px;font-size:11.5px;font-weight:600;display:inline-flex;align-items:center;gap:5px}.dev-pill:before{content:"";width:6px;height:6px;border-radius:50%}.dev-pill.ok{background:var(--green-soft);color:var(--green)}.dev-pill.ok:before{background:var(--green)}.dev-pill.warn{background:var(--amber-soft);color:var(--amber)}.dev-pill.warn:before{background:var(--amber)}.dev-pill.err{background:var(--red-soft);color:var(--red)}.dev-pill.err:before{background:var(--red)}.filters-grid.filters-6{grid-template-columns:repeat(6,1fr)}.cnt.eq-anpr{background:#e7f0fb;color:#1d4ed8;border-color:#cfdcf3}.cnt.eq-rfid{background:#efe7fb;color:#7c3aed;border-color:#dccff3}.cnt.eq-lidar{background:#e6f7ed;color:#15803d;border-color:#c6e8d3}.cnt.eq-radar{background:#fdecd9;color:#b45309;border-color:#f5d6a8}.eq-empty{padding:60px 20px;text-align:center;color:var(--muted)}.eq-empty-ic{width:80px;height:80px;border-radius:18px;background:#f1f3f6;color:var(--muted);font-size:34px;display:grid;place-items:center;margin:0 auto 14px}.eq-empty-title{font-size:20px;font-weight:700;color:var(--ink);margin-bottom:6px}.eq-empty .link{font-weight:600}.filters-card{padding:18px 20px}.filters-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:12px}.filters-grid label{display:grid;gap:5px}.filters-grid label>span{font-size:11px;font-weight:700;letter-spacing:.5px;color:var(--muted)}.filters-grid input,.filters-grid select{background:#fff;border:1px solid var(--line-2);padding:9px 11px;border-radius:6px;font-size:13px;outline:none;font-family:inherit;color:var(--ink)}.filters-grid input:focus,.filters-grid select:focus{border-color:var(--blue)}.filters-foot{display:flex;justify-content:space-between;align-items:center;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}.link-btn{background:transparent;border:none;color:var(--ink-2);font-size:13px;cursor:pointer;font-weight:500}.link-btn:hover{color:var(--blue)}.status-counts{display:flex;gap:8px}.cnt{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;padding:5px 11px;border-radius:6px;border:1px solid transparent}.cnt.paid{background:var(--green-soft);color:var(--green);border-color:#cdebd5}.cnt.failed{background:var(--red-soft);color:var(--red);border-color:#f3cdcd}.cnt.pending{background:var(--amber-soft);color:var(--amber);border-color:#f3e5a8}.cnt.exempt{background:#eef0f4;color:var(--ink-2);border-color:#dee1e7}.txn-table tbody td{font-size:13px;padding:14px 10px}.txn-table .txn-id{color:var(--blue);font-weight:600;cursor:pointer;font-family:ui-monospace,monospace;font-size:12.5px}.txn-table .txn-id:hover{text-decoration:underline}.txn-table .dt-main{font-family:ui-monospace,monospace;font-size:12.5px}.txn-table .dt-sub{color:var(--muted);font-size:11.5px;font-family:ui-monospace,monospace}.lane-pill{display:inline-block;padding:3px 12px;background:var(--blue-soft);color:var(--blue);border-radius:4px;font-size:12px;font-weight:600}.txn-table .reg{font-family:ui-monospace,monospace;font-weight:700;letter-spacing:.5px}.txn-table .tag{font-family:ui-monospace,monospace;font-size:12px;color:var(--ink-2)}.spd{font-weight:600}.spd.hi{color:var(--red)}.amt{font-weight:700}.st-pill{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;padding:3px 9px;border-radius:999px}.st-pill:before{content:"";width:6px;height:6px;border-radius:50%}.st-pill.paid{background:var(--green-soft);color:var(--green)}.st-pill.paid:before{background:var(--green)}.st-pill.failed{background:var(--red-soft);color:var(--red)}.st-pill.failed:before{background:var(--red)}.st-pill.pending{background:var(--amber-soft);color:var(--amber)}.st-pill.pending:before{background:var(--amber)}.st-pill.exempted{background:#eef0f4;color:var(--ink-2)}.st-pill.exempted:before{background:var(--muted)}.pager{display:flex;justify-content:flex-end;align-items:center;gap:10px;padding:14px 4px 0;margin-top:6px;border-top:1px solid var(--line)}.live-count{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--ink-2);font-weight:500;margin-right:6px}.live-count .dot{width:8px;height:8px;border-radius:50%}.live-count .dot.ok{background:var(--green)}.live-count .dot.err{background:var(--red)}.cam-grid{display:grid;gap:14px}.cam-grid[data-grid="2"]{grid-template-columns:repeat(2,1fr)}.cam-grid[data-grid="3"]{grid-template-columns:repeat(3,1fr)}.cam-grid[data-grid="4"]{grid-template-columns:repeat(4,1fr)}.cam{position:relative;background:#0b1220;border-radius:12px;overflow:hidden;aspect-ratio:16/9;color:#e5e7eb;border:1px solid #1f2937}.cam .feed{position:absolute;top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center;filter:brightness(.9)}.cam.live .feed{background-image:linear-gradient(180deg,#94a8b8,#7c8a98 40%,#6b7780 55%,#525c66)}.cam.live .feed:before{content:"";position:absolute;left:0;right:0;top:48%;height:2px;background:#5aa9e6;opacity:.7}.cam.live .feed:after{content:"";position:absolute;left:0;right:0;top:60%;bottom:20%;background:repeating-linear-gradient(90deg,transparent 0,transparent 40px,#fff 40px,#fff 60px);opacity:.18}.cam.offline .feed,.cam.nosig .feed{background:#0b1220}.cam .scan{position:absolute;left:0;right:0;top:0;height:2px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.45),transparent);animation:scan 3s linear infinite}@keyframes scan{0%{transform:translateY(0)}to{transform:translateY(100%)}}.cam .tl{position:absolute;top:10px;left:10px;display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;padding:3px 8px;border-radius:4px;letter-spacing:.5px;z-index:2}.cam.live .tl{background:#dc2626;color:#fff}.cam.live .tl:before{content:"";width:6px;height:6px;background:#fff;border-radius:50%;animation:blink 1s infinite}@keyframes blink{50%{opacity:.3}}.cam.offline .tl{background:#374151;color:#9ca3af}.cam.degraded .tl{background:#facc15;color:#7a5300}.cam .fps{position:absolute;top:10px;right:12px;font-size:11px;color:#cbd5e1;z-index:2}.cam .nosig-text{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:#475569;letter-spacing:6px;font-size:13px;font-weight:600}.cam .feed-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;background:#0f172ac7;color:#cbd5e1;font-size:13px;font-weight:600;z-index:2;text-align:center;padding:0 16px}.cam .feed-overlay .sub{font-size:11px;font-weight:500;color:#94a3b8;max-width:90%;word-break:break-all}.cam .feed-overlay.err{color:#fca5a5}.cam .feed-overlay.err .x{width:36px;height:36px;border-radius:50%;border:2px solid #fca5a5;display:grid;place-items:center;color:#fca5a5;font-size:18px}.cam .feed-overlay .spinner{width:28px;height:28px;border:3px solid #334155;border-top-color:#60a5fa;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.cam.offline .center-msg{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:#fca5a5;font-size:13px;font-weight:600;z-index:2}.cam.offline .center-msg .x{width:36px;height:36px;border-radius:50%;border:2px solid #fca5a5;display:grid;place-items:center;color:#fca5a5}.cam.offline .center-msg .sub{color:#94a3b8;font-weight:400;font-size:12px}.cam .info{position:absolute;left:0;right:0;bottom:0;padding:10px 12px;background:linear-gradient(180deg,transparent,rgba(0,0,0,.75));z-index:2}.cam .info .title{font-size:13.5px;font-weight:700;color:#fff;display:flex;justify-content:space-between}.cam .info .lane{font-size:12px;color:#cbd5e1;margin-top:2px;display:flex;justify-content:space-between}.cam .info .read{font-size:11.5px;color:#5aa9e6;margin-top:4px}.cam .expand{position:absolute;top:0;right:0;bottom:0;left:0;display:none;place-items:center;background:#00000040;z-index:1;color:#fff}.cam:hover .expand{display:grid}.cam .expand span{width:42px;height:42px;border-radius:50%;background:#ffffffd9;color:#111;display:grid;place-items:center;font-size:18px;cursor:pointer}.kpis.kpis-4{grid-template-columns:repeat(4,1fr)}.seg-tabs{display:inline-flex;background:#fff;border:1px solid var(--line);border-radius:8px;padding:4px;gap:2px}.seg-tab{background:transparent;border:none;padding:8px 18px;border-radius:6px;font-size:13.5px;color:var(--ink-2);cursor:pointer;font-weight:600}.seg-tab.active{background:var(--blue);color:#fff}.filters{display:flex;gap:10px;align-items:center}.search-box{display:flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--line-2);border-radius:6px;padding:6px 10px;min-width:220px}.search-box input{border:none;outline:none;font-size:13px;width:100%;background:transparent}.search-box span{color:var(--muted);font-size:12px}.select{background:#fff;border:1px solid var(--line-2);border-radius:6px;padding:7px 10px;font-size:13px;color:var(--ink-2);min-width:160px;cursor:pointer}.users-table .user-cell{display:flex;align-items:center;gap:10px}.users-table .uname{font-weight:600;font-size:13.5px;color:var(--ink)}.users-table .uemail{color:var(--muted);font-size:12px}.role-tag{display:inline-block;padding:5px 12px;border-radius:999px;font-size:12px;font-weight:600;border:1px solid transparent}.role-tag.authority{background:#fde8ee;color:#be185d;border-color:#f8c8d8}.role-tag.acquirer{background:#e6f7ed;color:#16a34a;border-color:#cdebd5}.role-tag.si{background:#fff0e0;color:#ea580c;border-color:#fbdab6}.role-tag.field{background:#fffae0;color:#a16207;border-color:#f3e5a8}.role-tag.tmcc{background:#ece6ff;color:#7c3aed;border-color:#d8ccff}.status-cell{display:inline-flex;align-items:center;gap:6px;color:var(--muted);font-size:13px}.status-cell .dot{width:7px;height:7px;border-radius:50%;background:var(--muted)}.status-cell.active .dot{background:var(--green)}.status-cell.active{color:var(--green)}.ta-r{text-align:right}.row-actions{display:inline-flex;gap:4px;justify-content:flex-end}.row-actions button{background:transparent;border:none;color:var(--muted);width:30px;height:30px;border-radius:6px;cursor:pointer;font-size:14px}.row-actions button:hover{background:#f5f6f8;color:var(--blue)}.row-actions .del:hover{color:var(--red)}.av-color{color:#fff}.roles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.role-card{border:1px solid var(--line);border-radius:10px;padding:14px;background:#fafbfc}.role-card h4{margin:0 0 6px;font-size:14px;font-weight:700}.role-card .perm{display:flex;flex-wrap:wrap;gap:5px;margin-top:8px}.role-card .perm span{font-size:11px;background:#fff;border:1px solid var(--line);padding:2px 8px;border-radius:999px;color:var(--ink-2)}.settings-form{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.settings-form label{display:grid;gap:5px;font-size:13px;color:var(--ink-2);font-weight:500}.settings-form input{background:#fff;border:1px solid var(--line-2);padding:9px 11px;border-radius:6px;font-size:13px;outline:none}.settings-form input:focus{border-color:var(--blue)}.settings-form button{grid-column:1/-1;justify-self:start}.modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#10182880;display:grid;place-items:center;z-index:50;padding:20px}.modal[hidden]{display:none}.modal-card{background:#fff;border-radius:12px;width:100%;max-width:480px;box-shadow:0 20px 60px #0003;overflow:hidden}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--line)}.modal-head h3{margin:0;font-size:16px}.modal-body{padding:18px;display:grid;gap:12px}.modal-body label{display:grid;gap:5px;font-size:13px;color:var(--ink-2);font-weight:500}.modal-body input,.modal-body select{background:#fff;border:1px solid var(--line-2);padding:9px 11px;border-radius:6px;font-size:13px;outline:none;font-family:inherit}.modal-foot{display:flex;justify-content:flex-end;gap:8px;margin-top:6px}@media (max-width:1380px){.kpis,.equip-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:980px){.app{grid-template-columns:1fr}.sidebar{position:relative;height:auto}.row.row-2-1,.row.row-1-2{grid-template-columns:1fr}.kpis,.equip-grid{grid-template-columns:repeat(2,1fr)}.acc-row{grid-template-columns:1fr}}.cc-wrap{padding:14px;background:#f5f6f8;min-height:100vh;display:flex;flex-direction:column;gap:14px}.cc-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;gap:14px;flex-wrap:wrap}.cc-h-left{display:flex;align-items:center;gap:14px}.cc-logo{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,#4f6ff0,#7a3df0);display:grid;place-items:center;color:#fff;font-size:22px}.cc-h-left h1{margin:0;font-size:20px;font-weight:800;letter-spacing:.5px;color:var(--ink)}.cc-sub{font-size:11px;color:var(--muted);letter-spacing:1px;font-weight:600;margin-top:2px}.cc-h-center{display:flex;align-items:center;gap:16px}.cc-clock{background:#f5f6f8;border:1px solid var(--line);border-radius:10px;padding:8px 14px;text-align:center;min-width:170px}.cc-time{font-family:ui-monospace,Menlo,monospace;font-size:18px;font-weight:700;color:var(--blue);letter-spacing:1px}.cc-date{font-size:11px;color:var(--muted);font-weight:600;letter-spacing:.5px;margin-top:2px}.cc-weather{display:flex;align-items:center;gap:10px}.cc-wx-ic{font-size:24px}.cc-wx-t{font-size:18px;font-weight:800;color:var(--ink)}.cc-wx-s{font-size:10.5px;color:var(--muted);font-weight:600;letter-spacing:.5px}.cc-h-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.cc-live{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;color:var(--green);letter-spacing:1px}.cc-live i{width:9px;height:9px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px #2bb6732e;display:inline-block}.cc-icon-btn{position:relative;width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:#fff;font-size:16px;cursor:pointer}.cc-icon-btn .cc-dot{position:absolute;top:8px;right:9px;width:8px;height:8px;border-radius:50%;background:var(--red)}.cc-btn{padding:10px 16px;border:none;border-radius:10px;font-weight:700;font-size:12.5px;letter-spacing:.5px;cursor:pointer;color:#fff;display:inline-flex;align-items:center;gap:6px}.cc-btn-green{background:linear-gradient(135deg,#2bb673,#22a05f)}.cc-btn-blue{background:linear-gradient(135deg,#4f6ff0,#3a55cf)}.cc-btn-dark{background:#1b1f29}.cc-stat-row{display:grid;grid-template-columns:repeat(6,1fr) 1.5fr;gap:12px}.cc-stat{display:flex;align-items:center;gap:12px;padding:14px}.cc-stat-ic{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;font-size:16px}.cc-stat-ic.c-b{background:var(--blue-soft);color:var(--blue)}.cc-stat-ic.c-g{background:var(--green-soft);color:var(--green)}.cc-stat-ic.c-p{background:var(--purple-soft);color:var(--purple)}.cc-stat-ic.c-r{background:var(--red-soft);color:var(--red)}.cc-stat-ic.c-t{background:var(--cyan-soft);color:var(--cyan)}.cc-stat-ic.c-o{background:var(--amber-soft);color:var(--amber)}.cc-stat-l{font-size:10.5px;font-weight:700;color:var(--muted);letter-spacing:.6px}.cc-stat-v{font-size:20px;font-weight:800;color:var(--ink);line-height:1.1;margin-top:2px}.cc-eticket{padding:12px 16px;background:linear-gradient(135deg,#eef2ff,#f5f7ff);border:1px solid #d9e0ff}.cc-et-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.cc-et-title{font-size:12px;font-weight:800;color:var(--blue);letter-spacing:.5px}.cc-et-feed{font-size:10px;font-weight:700;color:var(--muted);letter-spacing:.5px}.cc-et-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.cc-et-l{font-size:10px;font-weight:700;color:var(--muted);letter-spacing:.5px}.cc-et-v{font-size:20px;font-weight:800;line-height:1.1;margin-top:2px}.cc-row-2{display:grid;grid-template-columns:1.1fr 1.8fr 1.1fr;gap:14px}.cc-row-3{display:grid;grid-template-columns:1fr 1fr 1.4fr;gap:14px}.cc-chart,.cc-equip-card,.cc-vc,.cc-lane-eq{padding:16px 18px;display:flex;flex-direction:column}.cc-card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:10px}.cc-card-head h3{margin:0;font-size:13px;font-weight:800;color:var(--ink);letter-spacing:.6px}.cc-sub-sm{font-size:10.5px;color:var(--muted);font-weight:600;letter-spacing:.5px;margin-top:2px}.cc-live-sm{display:inline-flex;align-items:center;gap:6px;font-size:10.5px;font-weight:800;color:var(--blue);letter-spacing:.5px;background:var(--blue-soft);padding:4px 10px;border-radius:999px}.cc-live-sm i{width:7px;height:7px;border-radius:50%;background:var(--blue);display:inline-block}.cc-ic-chip{width:30px;height:30px;border-radius:8px;background:var(--blue-soft);color:var(--blue);display:grid;place-items:center;font-size:14px}.cc-legend-sm{display:flex;gap:10px;font-size:11px;font-weight:600;color:var(--ink-2)}.cc-legend-sm i{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:4px;vertical-align:middle}.cc-equip-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}.cc-equip{position:relative;border:1px solid var(--line);border-radius:10px;padding:12px;background:#fff;overflow:hidden}.cc-eq-top{display:flex;justify-content:space-between;align-items:flex-start}.cc-eq-ic{width:32px;height:32px;border-radius:8px;background:#f5f6f8;display:grid;place-items:center;font-size:14px}.cc-eq-tot{text-align:right}.cc-eq-tot .n{font-size:22px;font-weight:800;color:var(--ink);line-height:1}.cc-eq-tot .l{font-size:9.5px;color:var(--muted);font-weight:700;letter-spacing:.5px}.cc-eq-name{font-size:12px;font-weight:800;color:var(--ink);letter-spacing:.5px;margin:8px 0 4px}.cc-eq-st{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:700;letter-spacing:.4px}.cc-eq-st i{width:6px;height:6px;border-radius:50%;display:inline-block}.cc-eq-st.amber{color:var(--amber)}.cc-eq-st.amber i{background:var(--amber)}.cc-eq-st.green{color:var(--green)}.cc-eq-st.green i{background:var(--green)}.cc-eq-ai{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:10px}.cc-eq-ai>div{background:#f5f6f8;border-radius:6px;padding:6px;text-align:center}.cc-eq-ai .n{font-size:14px;font-weight:800;color:var(--ink)}.cc-eq-ai .l{font-size:9px;color:var(--muted);font-weight:700;letter-spacing:.4px}.cc-eq-bar{position:absolute;left:0;top:0;bottom:0;width:4px}.cc-eq-bar.amber{background:var(--amber)}.cc-eq-bar.green{background:var(--green)}.cc-donut-wrap{position:relative;display:grid;place-items:center;margin:6px 0 12px}.cc-donut-center{position:absolute;text-align:center;pointer-events:none}.cc-donut-center .n{font-size:22px;font-weight:800;color:var(--ink)}.cc-donut-center .l{font-size:10px;color:var(--muted);font-weight:700;letter-spacing:.5px}.cc-vc-legend{display:flex;flex-direction:column;gap:6px}.cc-vc-row{display:grid;grid-template-columns:10px 1fr 90px 30px;gap:8px;align-items:center;font-size:11.5px}.cc-vc-dot{width:9px;height:9px;border-radius:50%}.cc-vc-l{color:var(--ink-2);font-weight:600}.cc-vc-bar{display:block;height:6px;background:#f0f1f4;border-radius:999px;overflow:hidden}.cc-vc-bar span{display:block;height:100%;border-radius:999px}.cc-vc-p{text-align:right;font-weight:700;color:var(--ink)}.cc-rev-right{text-align:right}.cc-rev-v{font-size:18px;font-weight:800;color:var(--ink)}.cc-rev-d{font-size:11px;font-weight:700;color:var(--green);background:var(--green-soft);display:inline-block;padding:2px 8px;border-radius:999px;margin-top:2px}.cc-lane-table{width:100%;border-collapse:collapse;font-size:12.5px}.cc-lane-table th{text-align:center;font-size:10.5px;font-weight:800;color:var(--muted);letter-spacing:.5px;padding:8px 6px;border-bottom:1px solid var(--line)}.cc-lane-table th:first-child{text-align:left}.cc-lane-table td{padding:10px 6px;text-align:center;border-bottom:1px solid var(--line)}.cc-lane-table td:first-child{text-align:left}.cc-lane-table tr:last-child td{border-bottom:none}.cc-lane-table .strong{font-weight:700;color:var(--ink)}.cc-mark{display:inline-grid;place-items:center;width:24px;height:24px;border-radius:50%;font-size:12px;font-weight:800}.cc-mark.ok{background:var(--green-soft);color:var(--green)}.cc-mark.no{background:var(--red-soft);color:var(--red)}.cc-pill{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:700}.cc-pill i{width:6px;height:6px;border-radius:50%;display:inline-block}.cc-pill.green{background:var(--green-soft);color:var(--green)}.cc-pill.green i{background:var(--green)}.cc-pill.amber{background:var(--amber-soft);color:var(--amber)}.cc-pill.amber i{background:var(--amber)}.cc-pill.red{background:var(--red-soft);color:var(--red)}.cc-pill.red i{background:var(--red)}.cc-view-all{font-size:11.5px;font-weight:700;color:var(--blue);text-decoration:none}@media (max-width:1400px){.cc-stat-row{grid-template-columns:repeat(3,1fr)}.cc-row-2,.cc-row-3{grid-template-columns:1fr}}body.sidebar-collapsed .app{grid-template-columns:64px 1fr}body.sidebar-collapsed .sidebar{padding:14px 8px;align-items:center}body.sidebar-collapsed .brand-logo{padding:6px;justify-content:center;background:transparent}body.sidebar-collapsed .brand-logo .brand-name{display:none}body.sidebar-collapsed .brand-logo .brand-mark{width:36px;height:36px;font-size:11px}body.sidebar-collapsed .nav-label{display:none}body.sidebar-collapsed .nav-group{width:100%;align-items:center}body.sidebar-collapsed .nav-item{justify-content:center;padding:10px;width:44px;height:44px;gap:0;font-size:0}body.sidebar-collapsed .nav-item .pill{display:none}body.sidebar-collapsed .side-foot{width:100%;display:flex;justify-content:center;padding-top:14px}body.sidebar-collapsed .user-chip>div:not(.avatar){display:none}.notif-wrap{position:relative}.notif-pop{position:absolute;top:calc(100% + 8px);right:0;width:420px;max-height:520px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 12px 32px #0000001f;z-index:50;display:flex;flex-direction:column;overflow:hidden}.notif-head{padding:14px 16px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:flex-start}.notif-title{font-size:16px;font-weight:800;color:var(--ink)}.notif-actions{display:flex;gap:14px;align-items:center;padding-top:4px}.link-blue{background:none;border:none;color:var(--blue);font-weight:700;font-size:13px;cursor:pointer;padding:0}.link-muted{background:none;border:none;color:var(--muted);font-size:13px;cursor:pointer;padding:0}.link-blue:hover,.link-muted:hover{text-decoration:underline}.notif-list{overflow-y:auto;padding:8px;flex:1;display:flex;flex-direction:column;gap:6px}.notif-empty{text-align:center;padding:30px 0}.notif-item{display:flex;gap:10px;padding:12px;background:var(--blue-soft);border-radius:10px}.notif-item.read{background:#fafbfc}.notif-ic{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;flex-shrink:0}.notif-ic.c-r{background:var(--red-soft);color:var(--red)}.notif-ic.c-o{background:var(--amber-soft);color:var(--amber)}.notif-ic.c-g{background:var(--green-soft);color:var(--green)}.notif-body{flex:1;min-width:0}.notif-row{display:flex;align-items:center;gap:8px}.notif-h{font-weight:700;color:var(--blue);font-size:13.5px;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notif-t{font-size:11.5px;color:var(--muted);font-weight:600}.notif-dot{width:7px;height:7px;border-radius:50%;background:var(--blue);flex-shrink:0}.notif-item.read .notif-dot{display:none}.notif-msg{margin-top:4px;font-size:13px;color:var(--ink-2);line-height:1.4}.notif-foot{padding:12px;text-align:center;border-top:1px solid var(--line)}.lang-wrap{position:relative}.lang-pop{position:absolute;top:calc(100% + 8px);right:0;width:300px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 12px 32px #0000001f;z-index:50;overflow:hidden}.lang-head{padding:14px 16px;border-bottom:1px solid var(--line)}.lang-title{font-size:12px;font-weight:800;color:var(--ink);letter-spacing:1px}.lang-list{padding:8px;display:flex;flex-direction:column;gap:2px;max-height:340px;overflow-y:auto}.lang-row{display:flex;align-items:center;gap:12px;width:100%;background:none;border:none;padding:10px 12px;border-radius:8px;cursor:pointer;font-size:14px;color:var(--ink-2);text-align:left}.lang-row:hover{background:#f5f6f8}.lang-row.active{background:var(--blue-soft);color:var(--blue);font-weight:700}.lang-flag{font-size:18px}.lang-name{flex:1}.lang-check{width:22px;height:22px;border-radius:50%;background:var(--blue);color:#fff;display:grid;place-items:center}.prof-wrap{position:relative}.prof-pop{position:absolute;top:calc(100% + 8px);right:0;width:260px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 12px 32px #0000001f;z-index:50;padding:8px;display:flex;flex-direction:column;gap:2px}.prof-head{padding:10px 12px 12px;border-bottom:1px solid var(--line);margin-bottom:6px}.prof-name{font-size:15px;font-weight:800;color:var(--ink)}.prof-row{display:flex;align-items:center;gap:12px;background:none;border:none;padding:10px 12px;border-radius:8px;cursor:pointer;font-size:14px;color:var(--ink-2);text-align:left;font-weight:500}.prof-row:hover{background:#f5f6f8;color:var(--ink)}.prof-row.danger{color:var(--red)}.prof-row.danger:hover{background:var(--red-soft)}.prof-sep{height:1px;background:var(--line);margin:6px 0}body.dark{--bg:#0f1117;--surface:#1a1d27;--ink:#f1f3f8;--ink-2:#c4c9d4;--muted:#8b94a7;--line:#2a2f3d;--line-2:#3a4051;--blue-soft:#1e2a55;--red-soft:#3a1c1c;--green-soft:#16331e;--amber-soft:#3a2810;--purple-soft:#2a1f4a;--cyan-soft:#102a33;background:var(--bg);color:var(--ink)}body.dark .sidebar,body.dark .topbar,body.dark .card,body.dark .notif-pop,body.dark .lang-pop,body.dark .prof-pop,body.dark .dl-menu,body.dark .cc-equip,body.dark .cc-stat,body.dark .cc-eticket,body.dark .lane-card,body.dark .rep-kpi{background:#1a1d27;border-color:var(--line);color:var(--ink)}body.dark .main,body.dark .cc-wrap{background:var(--bg)}body.dark .nav-item:hover,body.dark .prof-row:hover,body.dark .lang-row:hover{background:#252a36}body.dark .nav-item.active,body.dark .shift-btn.active{background:var(--blue);color:#fff}body.dark .profile,body.dark .lang-btn,body.dark .btn-ghost,body.dark .shift-btn,body.dark .cfg-tab,body.dark input,body.dark select,body.dark textarea{background:#252a36;border-color:var(--line-2);color:var(--ink)}body.dark .table th{background:#252a36;color:var(--muted);border-color:var(--line)}body.dark .table td{border-color:var(--line);color:var(--ink-2)}body.dark .icon-btn{color:var(--ink)}body.dark .icon-btn:hover{background:#252a36}body.dark .cc-clock,body.dark .cc-eq-ic,body.dark .cc-eq-ai>div,body.dark .cc-vc-bar{background:#252a36}body.dark .cc-btn-dark{background:#0a0c12}body.dark .tot-row{background:#1e2a55}body.dark .crumbs b,body.dark .kpi-value,body.dark .cc-stat-v,body.dark .cc-et-v,body.dark .lane-head h3,body.dark .rk-value.c-k,body.dark .cc-eq-tot .n,body.dark .cc-eq-ai .n,body.dark .cc-eq-name,body.dark .cc-donut-center .n,body.dark .cc-vc-p,body.dark .cc-rev-v,body.dark .rep-table-head h3,body.dark .cc-card-head h3,body.dark .cc-h-left h1,body.dark .notif-title,body.dark .lang-title,body.dark .prof-name,body.dark .user-name,body.dark .page-head h1,body.dark .nav-item{color:var(--ink)}body.dark .cc-vc-l,body.dark .cc-stat-l,body.dark .cc-et-l,body.dark .cc-eq-tot .l,body.dark .cc-eq-ai .l,body.dark .cc-donut-center .l,body.dark .cc-sub,body.dark .cc-sub-sm,body.dark .cc-wx-s,body.dark .nav-label,body.dark .user-role,body.dark .lane-field>span,body.dark .muted{color:var(--muted)}body.dark .kpi,body.dark .equip,body.dark .aud-card,body.dark .stat-mini,body.dark .lane-status li,body.dark .preview,body.dark .et-ic,body.dark .acc-ic,body.dark .mini-ic,body.dark .filter-sel,body.dark .pg-btn,body.dark .size-btn,body.dark .health-card,body.dark .topbar,body.dark .sidebar,body.dark .modal,body.dark .modal-card,body.dark .dl-menu,body.dark .live-card,body.dark .live-tile,body.dark .et-card,body.dark .acc-card,body.dark .eq-card,body.dark .vio-card,body.dark .audit-row,body.dark .nms-card,body.dark .nms-cell,body.dark .nms-row,body.dark .panel,body.dark .tile,body.dark .stat-card{background:#1a1d27!important;border-color:var(--line)!important;color:var(--ink)}body.dark .table th,body.dark .tabs,body.dark .donut-legend .bar,body.dark .equip-bar,body.dark .brk-list .brk-bar,body.dark .aud-bar,body.dark .progress,body.dark .prog-bar{background:#252a36!important}body.dark .table tbody tr:hover,body.dark .nav-item:hover,body.dark .pg-btn:hover:not(:disabled),body.dark .size-btn:hover,body.dark .btn-ghost:hover,body.dark .icon-btn:hover{background:#252a36!important}body.dark .stat-mini.amber,body.dark .stat-mini.amber-l{background:#3a2810!important;border-color:#5a3a18!important}body.dark .stat-mini.green{background:#16331e!important;border-color:#235a32!important}body.dark .stat-mini.red{background:#3a1c1c!important;border-color:#5a2a2a!important}body.dark .seg-tabs,body.dark .tab{background:#252a36;color:var(--ink-2)}body.dark .tab.active{background:var(--blue);color:#fff}body.dark .auth-body{background:#0f1117}body.dark .auth-card{background:#1a1d27}body.dark .auth-card input{background:#252a36;border-color:var(--line-2);color:var(--ink)}body.dark h1,body.dark h2,body.dark h3,body.dark h4,body.dark h5,body.dark p,body.dark span,body.dark div,body.dark td{color:inherit}body.dark .strong,body.dark .ink,body.dark b{color:var(--ink)}.card{background:var(--grad-surface);box-shadow:var(--shadow-sm);transition:box-shadow .18s ease,transform .18s ease}.card:hover{box-shadow:var(--shadow-md)}.kpi{background:var(--grad-surface);box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease}.kpi:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.kpi-value{letter-spacing:-.02em}.sidebar{box-shadow:1px 0 0 var(--line),inset -1px 0 #fff9}.brand-logo{background:var(--grad-primary);box-shadow:0 6px 16px -6px #4338ca73}.nav-item{transition:background .15s ease,color .15s ease,transform .1s ease}.nav-item:hover{transform:translate(2px)}.nav-item.active{background:var(--grad-primary);box-shadow:0 6px 14px -6px #4338ca8c}.topbar{box-shadow:var(--shadow-sm);-webkit-backdrop-filter:saturate(120%);backdrop-filter:saturate(120%)}.icon-btn{transition:background .15s ease,color .15s ease}.profile{transition:border-color .15s ease,box-shadow .15s ease}.profile:hover{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-soft)}.btn-primary{background:var(--grad-primary);border:none;box-shadow:0 6px 14px -6px #4338ca8c;transition:transform .12s ease,box-shadow .18s ease,filter .15s ease}.btn-primary:hover{background:var(--grad-primary);filter:brightness(1.05);transform:translateY(-1px);box-shadow:0 10px 22px -10px #4338ca99}.btn-primary:active{transform:translateY(0)}.btn-ghost{transition:background .15s ease,border-color .15s ease}.status-pill{font-weight:600;letter-spacing:.2px;-webkit-backdrop-filter:saturate(120%);backdrop-filter:saturate(120%)}.table th{font-weight:700;text-transform:uppercase;letter-spacing:.6px;font-size:11px;color:var(--muted)}.table tbody tr{transition:background .12s ease}.page-icon{background:var(--grad-primary);color:#fff;box-shadow:0 8px 18px -8px #4338ca8c}input,select,textarea{transition:border-color .15s ease,box-shadow .15s ease}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 4px var(--blue-soft)}.notif-pop,.lang-pop,.prof-pop,.dl-menu{box-shadow:var(--shadow-lg);border-radius:14px}.cc-logo{background:var(--grad-primary);box-shadow:0 8px 20px -8px #4338ca8c}.cc-btn-blue{background:var(--grad-primary)}.cc-btn-green{background:var(--grad-emerald)}.cc-btn-dark{background:linear-gradient(135deg,#1f2937,#0b1220)}.cc-stat{transition:transform .18s ease,box-shadow .18s ease}.cc-stat:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.rk-value.c-b{background:linear-gradient(135deg,#6366f1,#4338ca);-webkit-background-clip:text;background-clip:text;color:transparent}.rk-value.c-g{background:var(--grad-emerald);-webkit-background-clip:text;background-clip:text;color:transparent}.rk-value.c-r{background:var(--grad-rose);-webkit-background-clip:text;background-clip:text;color:transparent}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-thumb{background:#cdd2de;border-radius:999px;border:2px solid transparent;background-clip:padding-box}*::-webkit-scrollbar-thumb:hover{background:#a5acbd;background-clip:padding-box;border:2px solid transparent}*::-webkit-scrollbar-track{background:transparent}body.dark{--bg:#0a0e1a;--surface:#121826;--surface-2:#161d2e;--ink:#e8ecf5;--ink-2:#b4bccd;--muted:#7d869a;--line:#222b40;--line-2:#2e3a55;--blue:#818cf8;--blue-2:#6366f1;--blue-3:#a5b4fc;--blue-soft:#1c2348;--blue-soft-2:#252e5a;--red:#fb7185;--red-soft:#3a1c28;--green:#34d399;--green-soft:#0f3326;--amber:#fbbf24;--amber-soft:#3a2810;--purple:#c084fc;--purple-soft:#2a1f4a;--cyan:#22d3ee;--cyan-soft:#0d2b33;--grad-surface:linear-gradient(180deg,#121826 0%,#0f1422 100%);--grad-primary:linear-gradient(135deg,#818cf8 0%,#6366f1 60%,#4338ca 100%);--shadow-sm:0 1px 2px rgba(0,0,0,.4);--shadow-md:0 6px 16px rgba(0,0,0,.5);--shadow-lg:0 24px 56px -16px rgba(0,0,0,.7);background:var(--bg);color:var(--ink)}body.dark .sidebar{box-shadow:1px 0 0 var(--line)}body.dark .table tbody tr:hover{background:#1a2238!important}body.dark .profile:hover{box-shadow:0 0 0 3px #818cf82e}.card,.kpi,.aud-card,.lane-card,.cc-stat,.cc-eticket,.cc-equip,.rep-kpi{background:var(--surface);box-shadow:none;border:1px solid var(--line);border-radius:16px}.card:hover,.kpi:hover,.cc-stat:hover{box-shadow:none;transform:none}.sidebar{background:var(--surface);border-right:1px solid var(--line);box-shadow:none}.brand-logo{background:var(--ink);box-shadow:none;border-radius:14px}.brand-logo .brand-mark{background:var(--surface);color:var(--ink);border-bottom:3px solid var(--red)}.brand-logo .brand-name{color:var(--surface)}.nav-item{border-radius:10px;color:var(--ink-2);font-weight:600}.nav-item:hover{background:var(--blue-soft);transform:none;color:var(--ink)}.nav-item.active{background:var(--ink);color:var(--surface);box-shadow:none}.nav-item.active .ic{color:var(--surface)}.nav-label{color:var(--muted);font-weight:800;letter-spacing:1.2px;text-transform:uppercase}.topbar{background:var(--surface);border:1px solid var(--line);box-shadow:none;border-radius:14px}.profile{background:var(--surface);border:1px solid var(--line-2)}.profile:hover{border-color:var(--ink);box-shadow:none}.lang-btn{background:var(--surface);border:1px solid var(--line-2)}.btn-primary{background:var(--ink);color:var(--surface);border:1px solid var(--ink);box-shadow:none;border-radius:999px;padding:11px 22px;font-weight:700;letter-spacing:.2px}.btn-primary:hover{background:#000;filter:none;transform:none;box-shadow:none}.btn-primary:active{transform:none}.btn-ghost{background:transparent;border:1px solid var(--ink);color:var(--ink);border-radius:999px;padding:10px 18px;font-weight:700}.btn-ghost:hover{background:var(--ink);color:var(--surface)}.page-icon{background:var(--ink);color:var(--surface);box-shadow:none;border-radius:14px}.page-head p{color:var(--muted)}.status-pill{background:var(--green-soft);color:var(--green);border-color:transparent;font-weight:700}.status-pill.err{background:var(--red-soft);color:var(--red)}.table th{background:transparent;color:var(--muted);font-weight:800;letter-spacing:.8px;font-size:11px;text-transform:uppercase;border-bottom:1px solid var(--line)}.table td{border-bottom:1px solid var(--line)}.table tbody tr:hover{background:var(--blue-soft)}.kpi-value{font-size:30px}.kpi-label{color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.6px;font-size:11px}.kpi-icon{border-radius:10px}input,select,textarea{background:var(--surface);border:1px solid var(--line-2);border-radius:10px}input:focus,select:focus,textarea:focus{border-color:var(--ink);box-shadow:0 0 0 3px #0e0e0e14}.notif-pop,.lang-pop,.prof-pop,.dl-menu{background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-lg);border-radius:16px}.tabs{background:var(--blue-soft)}.tab.active{background:var(--ink);color:var(--surface)}.cfg-tab{border-radius:10px}.cfg-tab.active{border-color:var(--ink);color:var(--ink);box-shadow:0 0 0 1px var(--ink) inset}.shift-btn.active{background:var(--ink);border-color:var(--ink);color:var(--surface)}.cc-wrap{background:var(--bg)}.cc-head{background:var(--surface);border:1px solid var(--line);box-shadow:none}.cc-logo{background:var(--ink);box-shadow:none;border-radius:14px}.cc-btn{border-radius:999px;font-weight:700;letter-spacing:.5px}.cc-btn-blue{background:var(--ink)}.cc-btn-green{background:var(--green)}.cc-btn-dark{background:#000}.cc-clock{background:var(--surface-2);border-color:var(--line)}.cc-time{color:var(--ink);font-family:var(--font-display)}.cc-live i{background:var(--green);box-shadow:0 0 0 4px #3f6b3a2e}.cc-eticket{background:var(--blue-soft);border-color:var(--line)}.cc-et-v.g{color:var(--green)}.cc-et-v.r{color:var(--red)}.cc-et-v.o{color:var(--amber)}.rk-value{background:none!important;-webkit-text-fill-color:initial;color:var(--ink)}.rk-value.c-b{color:var(--ink)}.rk-value.c-g{color:var(--green)}.rk-value.c-r{color:var(--red)}.rk-delta .up{color:var(--green);background:var(--green-soft);padding:2px 8px;border-radius:999px;font-weight:700}.cc-h-left h1{font-family:var(--font-display);font-weight:900;letter-spacing:-.04em}.page-head h1{font-size:36px}@media (min-width:1400px){.page-head h1{font-size:42px}}body.dark{--bg:#0c0c0c;--surface:#161616;--surface-2:#1c1c1c;--ink:#f3f1ea;--ink-2:#c8c5bc;--muted:#8b8880;--line:#262626;--line-2:#363636;--blue:#f3f1ea;--blue-2:#ffffff;--blue-3:#c8c5bc;--blue-soft:#1f1f1f;--blue-soft-2:#262626;--red:#f97316;--red-soft:#3a1c0d;--green:#86efac;--green-soft:#13301a;--amber:#fbbf24;--amber-soft:#33260a;--purple:#c084fc;--purple-soft:#241640;--shadow-sm:0 1px 0 rgba(0,0,0,.4);--shadow-md:0 6px 18px rgba(0,0,0,.45);--shadow-lg:0 24px 60px -16px rgba(0,0,0,.75);background:var(--bg);color:var(--ink)}body.dark .brand-logo{background:var(--ink);color:var(--bg)}body.dark .brand-logo .brand-mark{background:var(--bg);color:var(--ink)}body.dark .brand-logo .brand-name{color:var(--bg)}body.dark .nav-item.active{background:var(--ink);color:var(--bg)}body.dark .nav-item.active .ic{color:var(--bg)}body.dark .btn-primary{background:var(--ink);color:var(--bg);border-color:var(--ink)}body.dark .btn-primary:hover{background:#fff}body.dark .btn-ghost{border-color:var(--ink);color:var(--ink)}body.dark .btn-ghost:hover,body.dark .page-icon,body.dark .tab.active,body.dark .shift-btn.active,body.dark .cc-btn-blue{background:var(--ink);color:var(--bg)}.live-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--green);margin-right:6px;box-shadow:0 0 #3f6b3a99;animation:livePulse 1.6s ease-out infinite}@keyframes livePulse{0%{box-shadow:0 0 #3f6b3a8c}70%{box-shadow:0 0 0 10px #3f6b3a00}to{box-shadow:0 0 #3f6b3a00}}.kpi-value{transition:opacity .15s ease}.roles-layout{display:grid;grid-template-columns:minmax(340px,1fr) 1.4fr;gap:16px;align-items:flex-start}.roles-list{display:flex;flex-direction:column;gap:10px;max-height:calc(100vh - 240px);overflow-y:auto;padding-right:4px}.role-row{display:flex;gap:12px;align-items:flex-start;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:14px 16px;cursor:pointer;text-align:left;transition:border-color .15s ease,box-shadow .15s ease}.role-row:hover{border-color:var(--ink-2)}.role-row.active{border-color:var(--ink);box-shadow:0 0 0 1px var(--ink) inset}.role-row-ic{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-size:14px;flex-shrink:0}.role-row-body{flex:1;min-width:0}.role-row-head{display:flex;justify-content:space-between;align-items:baseline;gap:10px}.role-row-name{font-weight:700;color:var(--ink);font-size:14.5px}.role-row-count{font-size:12px;color:var(--muted);background:var(--blue-soft);padding:2px 10px;border-radius:999px;font-weight:600;white-space:nowrap}.role-row-desc{color:var(--muted);font-size:12.5px;margin-top:3px}.role-row.active .role-row-name{color:var(--ink)}.perm-panel{padding:18px 20px;position:sticky;top:18px}.perm-head{padding-bottom:14px;border-bottom:1px solid var(--line);margin-bottom:8px}.perm-head h3{margin:0;font-size:16px;font-weight:800;color:var(--ink)}.perm-list{display:flex;flex-direction:column}.perm-row{display:grid;grid-template-columns:1fr 70px 70px 70px;gap:12px;align-items:center;padding:14px 0;border-bottom:1px solid var(--line)}.perm-row:last-child{border-bottom:none}.perm-row-head{padding:8px 0;border-bottom:1px solid var(--line)}.perm-row-head .perm-col{font-size:11px;font-weight:800;color:var(--muted);letter-spacing:.6px;text-transform:uppercase;text-align:center}.perm-mod{font-weight:700;color:var(--ink);font-size:14px}.perm-col{display:flex;justify-content:center}.perm-box{width:22px;height:22px;border-radius:6px;border:1.5px solid var(--line-2);background:var(--surface);display:grid;place-items:center;cursor:pointer;transition:background .12s ease,border-color .12s ease}.perm-box:hover{border-color:var(--ink-2)}.perm-box.on{background:var(--ink);border-color:var(--ink)}.perm-tick{color:var(--surface);font-size:13px;font-weight:900;line-height:1}.perm-foot{display:flex;justify-content:flex-end;gap:8px;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}@media (max-width:1100px){.roles-layout{grid-template-columns:1fr}.perm-panel{position:static}}.cfg-2col{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:flex-start}.cfg-card{padding:22px 24px}.cfg-card-head{padding-bottom:14px;border-bottom:1px solid var(--line);margin-bottom:16px}.cfg-card-head h3{margin:0;font-size:18px;font-weight:800;color:var(--ink)}.cfg-fields{display:flex;flex-direction:column;gap:12px}.cfg-row{display:grid;grid-template-columns:1fr 200px;gap:14px;align-items:center}.cfg-row-l{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--ink-2);font-weight:500}.cfg-dot{width:22px;height:22px;border-radius:6px;background:var(--blue-soft);display:inline-block;flex-shrink:0}.cfg-row-c{display:flex;justify-content:flex-end}.cfg-row-c input{width:100%;text-align:left}.cfg-row-c .tgl{margin-left:auto}.cfg-save{width:100%;margin-top:18px;border-radius:10px;padding:12px;font-size:14px}@media (max-width:1024px){.cfg-2col{grid-template-columns:1fr}.cfg-row{grid-template-columns:1fr 160px}}.audit-card{padding:0;overflow:hidden}.audit-head{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;border-bottom:1px solid var(--line)}.audit-head h3{margin:0;font-size:16px;font-weight:800;color:var(--ink)}.audit-export{display:inline-flex;align-items:center;gap:6px}.audit-table{margin:0}.audit-table th{padding:14px 22px;background:transparent}.audit-table td{padding:18px 22px;border-bottom:1px solid var(--line);font-size:14px}.audit-table tr:last-child td{border-bottom:none}.audit-table tr:nth-child(2n) td{background:var(--surface-2)}.aud-mod{display:inline-block;padding:4px 14px;border-radius:999px;background:var(--blue-soft);color:var(--blue);font-size:12.5px;font-weight:600}.aud-status{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:999px;font-size:12.5px;font-weight:600}.aud-status.ok{background:var(--green-soft);color:var(--green)}.aud-status.bad{background:var(--red-soft);color:var(--red)}.aud-status i{width:7px;height:7px;border-radius:50%;display:inline-block}.aud-status.ok i{background:var(--green)}.aud-status.bad i{background:var(--red)}.main{isolation:isolate}.topbar{position:sticky;top:0;z-index:9000;background:var(--surface)}.notif-pop,.lang-pop,.prof-pop{z-index:9999}.notif-wrap,.lang-wrap,.prof-wrap{position:relative;z-index:9000}.cam-tr{position:absolute;top:10px;right:10px;display:flex;gap:6px;z-index:3}.cam-tr button{background:#00000073;color:#fff;border:none;width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:13px}.cam-tr button:hover{background:#000000b3}.cam .feed{object-fit:cover}video.feed,img.feed{width:100%;height:100%;display:block;background:#0b1220}.cam-rtsp{display:grid;place-items:center;background:#0b1220;color:#fca5a5;padding:18px;text-align:center}.rtsp-title{font-weight:800;font-size:14px;margin-bottom:6px}.rtsp-sub{font-size:12px;color:#cbd5e1;line-height:1.45;margin-bottom:8px;max-width:90%}.cam-rtsp code{display:inline-block;font-size:10.5px;color:#9aa3b8;background:#ffffff0f;padding:4px 8px;border-radius:6px;max-width:95%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
