.alarm-warning-card[data-v-de463654]{border-color:var(--accent-red)!important}.login-page[data-v-8c838243]{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.bg-grid[data-v-8c838243]{background-image:linear-gradient(#00e5c80a 1px,#0000 1px),linear-gradient(90deg,#00e5c80a 1px,#0000 1px);background-size:40px 40px;animation:20s linear infinite grid-move-8c838243;position:absolute;inset:0}@keyframes grid-move-8c838243{0%{transform:translateY(0)}to{transform:translateY(40px)}}.bg-glow[data-v-8c838243]{pointer-events:none;background:radial-gradient(circle,#00e5c80f 0%,#0000 70%);border-radius:50%;width:600px;height:600px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.login-container[data-v-8c838243]{z-index:1;flex-direction:column;align-items:center;gap:24px;width:100%;max-width:400px;padding:24px 16px;display:flex;position:relative}.login-logo[data-v-8c838243]{text-align:center}.logo-ring[data-v-8c838243]{background:linear-gradient(135deg,#00e5c833,#00b8a91a);border:1px solid #00e5c84d;border-radius:20px;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 12px;display:flex;box-shadow:0 0 30px #00e5c826}.logo-name[data-v-8c838243]{color:var(--text-primary);letter-spacing:3px;font-size:22px;font-weight:800}.logo-desc[data-v-8c838243]{color:var(--text-secondary);letter-spacing:1px;margin-top:4px;font-size:12px}.login-card[data-v-8c838243]{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;width:100%;padding:28px 28px 20px;box-shadow:0 20px 60px #0006}.login-card-header[data-v-8c838243]{color:var(--text-primary);border-bottom:1px solid var(--border-color);align-items:center;gap:8px;margin-bottom:24px;padding-bottom:14px;font-size:15px;font-weight:700;display:flex}.form-group[data-v-8c838243]{margin-bottom:16px}.form-label[data-v-8c838243]{color:var(--text-secondary);margin-bottom:7px;font-size:12px;font-weight:600;display:block}.input-wrap[data-v-8c838243]{align-items:center;display:flex;position:relative}.form-input[data-v-8c838243]{background:var(--bg-secondary);border:1px solid var(--border-color);width:100%;color:var(--text-primary);border-radius:8px;outline:none;padding:10px 40px 10px 14px;font-family:Sarabun,sans-serif;font-size:14px;transition:border-color .2s,box-shadow .2s}.form-input[data-v-8c838243]::placeholder{color:var(--text-muted)}.form-input[data-v-8c838243]:focus{border-color:var(--accent-cyan);box-shadow:0 0 0 3px #00e5c81a}.form-group.error .form-input[data-v-8c838243]{border-color:var(--accent-red);box-shadow:0 0 0 3px #ff47571a}.input-eye[data-v-8c838243]{cursor:pointer;color:var(--text-muted);background:0 0;border:none;align-items:center;padding:0;transition:color .2s;display:flex;position:absolute;right:12px}.input-eye[data-v-8c838243]:hover{color:var(--text-secondary)}.form-error[data-v-8c838243]{color:var(--accent-red);align-items:center;gap:4px;margin-top:5px;font-size:11px;display:flex}.alert-error[data-v-8c838243]{color:var(--accent-red);background:#ff47571a;border:1px solid #ff47574d;border-radius:8px;align-items:center;gap:8px;margin-bottom:16px;padding:10px 12px;font-size:13px;display:flex}.slide-down-enter-active[data-v-8c838243],.slide-down-leave-active[data-v-8c838243]{transition:all .3s}.slide-down-enter-from[data-v-8c838243],.slide-down-leave-to[data-v-8c838243]{opacity:0;transform:translateY(-8px)}.btn-login[data-v-8c838243]{background:linear-gradient(135deg, var(--accent-cyan), var(--accent-teal));color:#0a0e1a;cursor:pointer;border:none;border-radius:8px;width:100%;min-height:42px;margin-top:4px;padding:11px;font-family:Sarabun,sans-serif;font-size:14px;font-weight:700;transition:all .2s}.btn-login[data-v-8c838243]:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 20px #00e5c84d}.btn-login[data-v-8c838243]:disabled{opacity:.7;cursor:not-allowed;transform:none}.loading-dots[data-v-8c838243]{align-items:center;gap:5px;display:inline-flex}.loading-dots span[data-v-8c838243]{background:#0a0e1a;border-radius:50%;width:6px;height:6px;animation:1.2s infinite dot-bounce-8c838243}.loading-dots span[data-v-8c838243]:nth-child(2){animation-delay:.2s}.loading-dots span[data-v-8c838243]:nth-child(3){animation-delay:.4s}@keyframes dot-bounce-8c838243{0%,80%,to{opacity:1;transform:translateY(0)}40%{opacity:.6;transform:translateY(-6px)}}.login-hint[data-v-8c838243]{text-align:center;color:var(--text-muted);margin-top:16px;font-size:11px}.login-footer[data-v-8c838243]{color:var(--text-muted);text-align:center;font-size:11px}.status-dot[data-v-8c838243]{background:var(--accent-green);border-radius:50%;width:6px;height:6px;margin-right:4px;animation:2s infinite pulse-green;display:inline-block}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#0a0e1a;--bg-secondary:#0d1425;--bg-card:#111827;--bg-card-hover:#162033;--border-color:#1e2d40;--border-accent:#00e5c8;--text-primary:#e2e8f0;--text-secondary:#89a;--text-muted:#4a5568;--accent-cyan:#00e5c8;--accent-teal:#00b8a9;--accent-green:#00d97e;--accent-yellow:gold;--accent-orange:#ff8c42;--accent-red:#ff4757;--accent-blue:#3d9eff;--accent-purple:#a855f7;--sidebar-width:220px;--header-height:56px;font-family:Sarabun,sans-serif}html,body,#app{background-color:var(--bg-primary);height:100%;color:var(--text-primary);font-size:14px;line-height:1.5}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--accent-cyan)}.app-layout{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-color);z-index:100;flex-direction:column;flex-shrink:0;display:flex}.sidebar-logo{border-bottom:1px solid var(--border-color);align-items:center;gap:10px;padding:16px;display:flex}.sidebar-logo .logo-icon{background:linear-gradient(135deg, var(--accent-cyan), var(--accent-teal));border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex}.sidebar-logo .logo-text{color:var(--text-primary);font-size:13px;font-weight:700;line-height:1.2}.sidebar-logo .logo-sub{color:var(--text-secondary);font-size:10px}.sidebar-nav{flex:1;padding:12px 8px;overflow-y:auto}.nav-section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;padding:8px 10px 4px;font-size:10px}.nav-item{cursor:pointer;color:var(--text-secondary);border-radius:8px;align-items:center;gap:10px;margin-bottom:2px;padding:10px 12px;font-size:13px;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.nav-item:hover{background:var(--bg-card);color:var(--text-primary)}.nav-item.active{color:var(--accent-cyan);border-left:3px solid var(--accent-cyan);background:#00e5c81f}.nav-item .nav-icon{text-align:center;width:20px;font-size:16px}.nav-item .nav-icon-svg{opacity:.8;flex-shrink:0;width:20px}.nav-item.active .nav-icon-svg{opacity:1}.sidebar-footer{border-top:1px solid var(--border-color);color:var(--text-muted);text-align:center;padding:12px;font-size:11px}.sidebar-user{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;align-items:center;gap:8px;margin:0 8px 8px;padding:10px 12px;display:flex}.user-avatar{background:#00e5c81a;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;display:flex}.user-info{flex:1;min-width:0}.user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:600;overflow:hidden}.user-role{color:var(--accent-cyan);font-size:10px}.logout-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;padding:4px;transition:all .2s;display:flex}.logout-btn:hover{color:var(--accent-red);background:#ff475726}.status-dot{background:var(--accent-green);border-radius:50%;width:6px;height:6px;margin-right:4px;animation:2s infinite pulse-green;display:inline-block}@keyframes pulse-green{0%,to{opacity:1}50%{opacity:.4}}.main-content{flex-direction:column;flex:1;display:flex;overflow:hidden}.topbar{height:var(--header-height);background:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-shrink:0;justify-content:space-between;align-items:center;padding:0 20px;display:flex}.topbar-left .page-title{color:var(--text-primary);font-size:18px;font-weight:700}.topbar-left .page-subtitle{color:var(--text-secondary);font-size:11px}.topbar-right{align-items:center;gap:12px;display:flex}.time-display{text-align:right}.time-display .time{color:var(--accent-cyan);font-size:20px;font-weight:700}.time-display .date{color:var(--text-secondary);font-size:11px}.badge{border-radius:20px;padding:4px 10px;font-size:11px;font-weight:600}.badge-green{color:var(--accent-green);background:#00d97e26;border:1px solid #00d97e4d}.badge-red{color:var(--accent-red);background:#ff475726;border:1px solid #ff47574d}.badge-yellow{color:var(--accent-yellow);background:#ffd70026;border:1px solid #ffd7004d}.badge-cyan{color:var(--accent-cyan);background:#00e5c826;border:1px solid #00e5c84d}.page-content{flex:1;padding:16px 20px;overflow-y:auto}.stats-grid{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);cursor:default;border-radius:10px;padding:14px 16px;transition:border-color .2s,transform .2s;position:relative;overflow:hidden}.stat-card:hover{border-color:var(--accent-cyan);transform:translateY(-1px)}.stat-card:before{content:"";background:var(--card-accent,var(--accent-cyan));height:2px;position:absolute;top:0;left:0;right:0}.stat-card .card-header{justify-content:space-between;align-items:flex-start;margin-bottom:8px;display:flex}.stat-card .card-label{color:var(--text-secondary);font-size:11px;font-weight:500}.stat-card .card-icon{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;display:flex}.alarm-icon{flex-shrink:0;justify-content:center;align-items:center;width:24px;display:flex}.stat-card .card-value{color:var(--text-primary);margin-bottom:4px;font-size:28px;font-weight:700;line-height:1}.stat-card .card-unit{color:var(--text-secondary);font-size:13px;font-weight:400}.stat-card .card-sub{color:var(--text-secondary);margin-top:4px;font-size:11px}.stat-card .card-trend{margin-top:4px;font-size:11px}.trend-up{color:var(--accent-red)}.trend-down,.trend-ok{color:var(--accent-green)}.section-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;overflow:hidden}.section-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.section-title{color:var(--text-primary);align-items:center;gap:8px;font-size:13px;font-weight:600;display:flex}.section-title .dot{background:var(--accent-cyan);border-radius:50%;width:8px;height:8px}.section-body{padding:16px}.charts-grid{grid-template-columns:2fr 1fr;gap:12px;margin-bottom:16px;display:grid}.thermal-grid{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.thermal-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;position:relative;overflow:hidden}.thermal-canvas{aspect-ratio:16/9;width:100%;display:block}.thermal-info{justify-content:space-between;align-items:center;padding:8px 10px;display:flex}.thermal-name{color:var(--text-secondary);font-size:11px}.thermal-temp{color:var(--accent-orange);font-size:20px;font-weight:700}.temp-normal{color:var(--accent-green)}.temp-warning{color:var(--accent-yellow)}.temp-danger{color:var(--accent-red)}.camera-grid-2x2{grid-template-columns:1fr 1fr;gap:12px;display:grid}.camera-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;flex-direction:column;display:flex;overflow:hidden}.camera-header{border-bottom:1px solid var(--border-color);background:#0000004d;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.camera-title{color:var(--text-primary);font-size:12px;font-weight:600}.camera-feed{aspect-ratio:16/9;background:#060b14;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.camera-placeholder{color:var(--text-muted);flex-direction:column;align-items:center;gap:8px;display:flex}.camera-placeholder svg{opacity:.3;width:48px;height:48px}.camera-placeholder span{font-size:11px}.camera-footer{justify-content:space-between;align-items:center;padding:8px 12px;font-size:11px;display:flex}.cam-status{color:var(--text-secondary);align-items:center;gap:6px;display:flex}.live-dot{background:var(--accent-red);border-radius:50%;width:6px;height:6px;animation:1s infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.plate-table{border-collapse:collapse;width:100%;font-size:12px}.plate-table th{text-align:left;color:var(--text-secondary);border-bottom:1px solid var(--border-color);background:var(--bg-secondary);padding:8px 12px;font-size:11px;font-weight:600}.plate-table td{color:var(--text-primary);border-bottom:1px solid #1e2d4080;padding:9px 12px}.plate-table tr:hover td{background:var(--bg-secondary)}.plate-badge{background:var(--bg-primary);border:1px solid var(--accent-cyan);color:var(--accent-cyan);letter-spacing:1px;border-radius:4px;padding:3px 10px;font-family:Courier New,monospace;font-size:13px;font-weight:700}.direction-in{color:var(--accent-green)}.direction-out{color:var(--accent-red)}.location-grid{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.location-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;position:relative;overflow:hidden}.location-card.alert{border-color:var(--accent-yellow)}.location-feed{aspect-ratio:4/3;background:#060b14;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.person-count-overlay{color:var(--accent-cyan);text-shadow:0 0 20px #00e5c880;font-size:32px;font-weight:700;position:absolute;bottom:8px;right:8px}.location-info{padding:8px 12px}.location-name{color:var(--text-primary);font-size:12px;font-weight:600}.location-meta{color:var(--text-secondary);margin-top:2px;font-size:11px}.progress-bar-wrap{background:var(--border-color);border-radius:2px;height:3px;margin-top:6px}.progress-bar-fill{background:linear-gradient(90deg, var(--accent-cyan), var(--accent-teal));border-radius:2px;height:100%;transition:width .5s}.progress-bar-fill.warn{background:linear-gradient(90deg, var(--accent-yellow), var(--accent-orange))}.progress-bar-fill.danger{background:linear-gradient(90deg, var(--accent-orange), var(--accent-red))}.bar-chart-section{margin-bottom:16px}.alarm-list{flex-direction:column;gap:8px;display:flex}.alarm-item{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;align-items:center;gap:10px;padding:10px 12px;display:flex}.alarm-item.alarm-active{border-color:var(--accent-red);background:#ff475714;animation:2s infinite alarm-pulse}@keyframes alarm-pulse{0%,to{border-color:var(--accent-red)}50%{border-color:#ff47574d}}.alarm-item.alarm-warning{border-color:var(--accent-yellow);background:#ffd7000d}.alarm-item.alarm-ok{border-color:var(--border-color)}.alarm-details{flex:1}.alarm-name{font-size:12px;font-weight:600}.alarm-loc{color:var(--text-secondary);font-size:11px}.alarm-time{color:var(--text-muted);font-size:11px}.gauge-wrap{justify-content:center;display:flex}.two-col{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px;display:grid}.three-col{grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:16px;display:grid}.full-col{margin-bottom:16px}.tag{border-radius:12px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.tag-green{color:var(--accent-green);background:#00d97e26}.tag-red{color:var(--accent-red);background:#ff475726}.tag-yellow{color:var(--accent-yellow);background:#ffd70026}.tag-blue{color:var(--accent-blue);background:#3d9eff26}.tag-cyan{color:var(--accent-cyan);background:#00e5c826}.tag-gray{color:var(--text-secondary);background:#4a55684d}.divider{background:var(--border-color);height:1px;margin:12px 0}.btn{cursor:pointer;border:none;border-radius:6px;padding:6px 14px;font-family:Sarabun,sans-serif;font-size:12px;font-weight:600;transition:all .2s}.btn-primary{background:var(--accent-cyan);color:#0a0e1a}.btn-primary:hover{background:var(--accent-teal)}.btn-outline{color:var(--accent-cyan);border:1px solid var(--accent-cyan);background:0 0}.btn-outline:hover{background:#00e5c81a}.fade-enter-active,.fade-leave-active{transition:opacity .3s}.fade-enter-from,.fade-leave-to{opacity:0}.apexcharts-tooltip{background:var(--bg-card)!important;border:1px solid var(--border-color)!important;color:var(--text-primary)!important}.apexcharts-tooltip-title{background:var(--bg-secondary)!important;border-bottom:1px solid var(--border-color)!important}.apexcharts-text{fill:var(--text-secondary)!important}.apexcharts-gridline{stroke:var(--border-color)!important}
