*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Noto Sans KR,sans-serif}.topbar{height:64px;display:flex;align-items:center;gap:18px;padding:0 22px;background:var(--panel);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.brand a{font-weight:800;text-decoration:none;font-size:1.15rem}.nav{display:flex;gap:10px;flex:1;overflow:auto}.nav a,.button,button{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:8px 13px;border-radius:12px;border:1px solid var(--border);background:var(--panel2);color:var(--text);text-decoration:none;cursor:pointer}.primary{background:var(--accent)!important;color:#00111c!important;border:0!important;font-weight:800}.userbox{display:flex;gap:10px;align-items:center;color:var(--muted)}.container{padding:20px;max-width:2200px;margin:0 auto}.panel,.card,.kpi{background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:18px;box-shadow:0 8px 26px rgba(0,0,0,.16)}.grid{display:grid;gap:14px}.kpi-grid{grid-template-columns:repeat(6,minmax(130px,1fr));margin-bottom:16px}.kpi b{display:block;font-size:2rem}.kpi span,.muted,small{color:var(--muted)}.dashboard-layout{display:grid;grid-template-columns:300px 1fr 310px;gap:16px}.section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}.small-cards{grid-template-columns:1fr}.device-card{display:block;background:var(--panel2);border:1px solid var(--border);border-radius:14px;padding:12px;text-decoration:none;color:var(--text);margin-bottom:10px}.badge{display:inline-flex;border-radius:999px;padding:3px 9px;font-weight:700;font-size:.85rem}.badge.ok{background:rgba(52,211,153,.15);color:var(--ok)}.badge.delay{background:rgba(253,224,71,.15);color:var(--delay)}.badge.warn{background:rgba(251,191,36,.15);color:var(--warn)}.badge.danger{background:rgba(251,113,133,.15);color:var(--danger)}.badge.off{background:rgba(148,163,184,.16);color:var(--off)}.alert{border-radius:14px;padding:12px;margin:8px 0;background:var(--panel2);border-left:5px solid var(--accent)}.alert.danger{border-color:var(--danger)}.alert.warn{border-color:var(--warn)}.table-wrap{overflow:auto}table{width:100%;border-collapse:collapse}th,td{padding:10px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}th{color:var(--muted);font-weight:700}.map-box{width:100%;border-radius:16px;border:1px solid var(--border);background:var(--panel2)}.map-box.compact{height:320px}.map-box.large{height:72vh}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.form label{display:grid;gap:6px}.filters{display:flex;flex-wrap:wrap;gap:10px;align-items:end;margin-bottom:14px}.filters label{display:grid;gap:4px}.codearea{width:100%;font-family:ui-monospace,Consolas,monospace}.json-view{background:var(--panel2);padding:14px;border-radius:14px;overflow:auto}.meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;margin-bottom:12px}.login-body{min-height:100vh;display:grid;place-items:center}.login-card{width:min(420px,92vw);background:var(--panel);border:1px solid var(--border);border-radius:22px;padding:28px;display:grid;gap:14px}.login-card label{display:grid;gap:6px}.login-card input{height:44px;border-radius:10px;padding:0 12px}.image-viewer{display:grid;grid-template-columns:280px 1fr;gap:16px}.thumbs{display:grid;gap:8px;max-height:70vh;overflow:auto}.thumbs button{display:grid;grid-template-columns:80px 1fr;gap:8px;text-align:left}.thumbs img{width:80px;height:54px;object-fit:cover}.big-image img{max-width:100%;border-radius:16px;border:1px solid var(--border)}
html,body{min-height:100%;height:100%}body{overflow-x:hidden}.container{min-height:calc(100vh - 64px);display:flex;flex-direction:column;width:100%;}.full-dashboard{flex:1;min-height:0}.center-panel,.device-side,.alert-side{min-height:0}.center-panel{display:flex;flex-direction:column}.status-wrap{max-height:34vh}.map-small{margin-top:12px;flex:1;display:flex;flex-direction:column;min-height:260px}.map-box.compact{height:clamp(340px,42vh,620px);flex:1}.dashboard-kpis .kpi{position:relative;overflow:hidden}.kpi.live:after{content:"";position:absolute;inset:auto 12px 12px auto;width:10px;height:10px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 0 rgba(52,211,153,.7);animation:livePulse 1.5s infinite}.live-strip{display:flex;align-items:center;gap:10px;margin-bottom:16px;padding:12px 16px;overflow:hidden}.live-dot{width:12px;height:12px;border-radius:50%;background:var(--ok);animation:livePulse 1.4s infinite}.live-ticker{display:flex;gap:20px;white-space:nowrap;overflow:hidden;mask-image:linear-gradient(90deg,#000 80%,transparent)}.live-ticker span{background:var(--panel2);border:1px solid var(--border);border-radius:999px;padding:7px 12px}.realtime-metrics{display:grid;grid-template-columns:1fr 1fr;gap:10px}.realtime-metrics div{background:var(--panel2);border:1px solid var(--border);border-radius:14px;padding:12px}.realtime-metrics b{display:block;font-size:1.4rem}.mt{margin-top:18px}.compact-head{margin-bottom:10px}.head-actions,.form-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}input,select,textarea{min-height:42px;border-radius:12px;padding:8px 11px;outline:none;font:inherit}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 25%,transparent)}input[type="date"],input[type="datetime-local"],input[type="number"],select{min-width:150px}button,.button{font-weight:700;transition:transform .15s ease,filter .15s ease,border-color .15s ease}button:hover,.button:hover{transform:translateY(-1px);filter:brightness(1.08);border-color:var(--accent)}.danger-btn{background:rgba(251,113,133,.14)!important;border-color:rgba(251,113,133,.55)!important;color:var(--danger)!important}.schedule-head h1{margin-bottom:4px}.schedule-panel{display:grid;gap:14px}.schedule-meta label{display:grid;gap:6px;color:var(--muted)}.schedule-meta input{color:var(--text)}.schedule-table th,.schedule-table td{vertical-align:middle}.schedule-table input,.schedule-table select{width:100%}.schedule-table-wrap{max-height:62vh}.toggle-cell{display:flex!important;align-items:center;gap:8px;white-space:nowrap}.toggle-cell input{width:20px;height:20px;min-height:20px;accent-color:var(--accent)}.inline-filter{margin:0}.image-viewer{min-height:260px}.thumbs button.active{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 25%,transparent)}.big-image{display:grid;place-items:start}.big-image img{max-height:68vh;object-fit:contain;background:var(--panel2)}.gm-pulse-marker{position:absolute;width:30px;height:30px;border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;background:color-mix(in srgb,var(--pulse-color) 25%,transparent);box-shadow:0 0 0 0 var(--pulse-color);animation:mapBreath 1.8s infinite}.gm-pulse-marker.danger{animation-duration:1s}@keyframes livePulse{0%{box-shadow:0 0 0 0 rgba(52,211,153,.7)}70%{box-shadow:0 0 0 12px rgba(52,211,153,0)}100%{box-shadow:0 0 0 0 rgba(52,211,153,0)}}@keyframes mapBreath{0%{opacity:.9;box-shadow:0 0 0 0 var(--pulse-color);transform:translate(-50%,-50%) scale(.65)}70%{opacity:.18;box-shadow:0 0 0 18px transparent;transform:translate(-50%,-50%) scale(1.25)}100%{opacity:.9;box-shadow:0 0 0 0 transparent;transform:translate(-50%,-50%) scale(.65)}}@media (max-width:1200px){.dashboard-layout{grid-template-columns:1fr}.device-side,.alert-side{order:2}.center-panel{order:1}.status-wrap{max-height:none}.map-box.compact{height:380px}.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1600px){.container{max-width:none;padding-left:28px;padding-right:28px}.dashboard-layout{grid-template-columns:300px minmax(900px,1fr) 310px}.map-box.compact{height:48vh}}
