*{margin:0;padding:0;box-sizing:border-box}:root{--sf-red: #ED1C24;--sf-red-dark: #c41920;--sf-blue: #045AFF;--sf-blue-light: #3378ff;--sf-dark: #1a1a2e;--sf-dark-2: #16213e;--sf-dark-3: #0f3460;--sf-surface: #1e2a3a;--sf-surface-2: #243447;--sf-surface-3: #2a3f55;--sf-border: #2d4a5e;--sf-border-light: #3a5a72;--sf-text: #e8edf2;--sf-text-muted: #8899aa;--sf-text-dim: #5a6a7a;--sf-white: #ffffff;--sf-green: #27ae60;--sf-green-light: #2ecc71;--sf-yellow: #f39c12;--sf-yellow-light: #f1c40f;--sf-orange: #e67e22;--sf-bg: #0d1b2a;--header-height: 56px;--kpi-height: 80px;--radius: 8px;--radius-lg: 12px;--font-sans: "Geist", -apple-system, BlinkMacSystemFont, "Segoe UI", "Inter", "Helvetica Neue", sans-serif;--font-mono: "SF Mono", "Fira Code", "Fira Mono", Menlo, monospace}body{font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--sf-bg);color:var(--sf-text);min-height:100vh;overflow-x:hidden}#root{width:100%;min-height:100vh}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--sf-dark)}::-webkit-scrollbar-thumb{background:var(--sf-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--sf-border-light)}.dashboard-header{display:flex;align-items:center;justify-content:space-between;height:var(--header-height);padding:0 20px;background:var(--sf-dark);border-bottom:1px solid var(--sf-border);position:sticky;top:0;z-index:100}.header-left{display:flex;align-items:center;gap:12px}.header-logo{width:32px;height:32px;border-radius:4px;object-fit:contain}.header-title{font-size:.9375rem;font-weight:600;color:var(--sf-white);letter-spacing:-.01em}.header-site-name{font-size:.8125rem;color:var(--sf-text-muted);padding-left:12px;border-left:1px solid var(--sf-border)}.header-right{display:flex;align-items:center;gap:16px}.header-clock{font-size:.8125rem;font-family:var(--font-mono);color:var(--sf-text-muted)}.header-alert-bell{position:relative;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:none;background:transparent;color:var(--sf-text-muted);cursor:pointer;transition:background .15s,color .15s;font-size:1.125rem}.header-alert-bell:hover{background:var(--sf-surface);color:var(--sf-white)}.alert-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;border-radius:8px;background:var(--sf-red);color:var(--sf-white);font-size:.625rem;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px}.live-dot{width:8px;height:8px;border-radius:50%;background:var(--sf-green);animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.kpi-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;padding:12px 20px;background:var(--sf-dark);border-bottom:1px solid var(--sf-border)}.kpi-card{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--sf-surface);border-radius:var(--radius);border:1px solid var(--sf-border)}.kpi-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}.kpi-icon.weather{background:#3498db26;color:#3498db}.kpi-icon.labor{background:#2ecc7126;color:#2ecc71}.kpi-icon.trucks{background:#f39c1226;color:#f39c12}.kpi-icon.alerts{background:#ed1c2426;color:var(--sf-red)}.kpi-content{min-width:0}.kpi-label{font-size:.6875rem;color:var(--sf-text-muted);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.kpi-value{font-size:1.25rem;font-weight:700;color:var(--sf-white);line-height:1.2;font-variant-numeric:tabular-nums}.kpi-sub{font-size:.6875rem;color:var(--sf-text-muted)}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:auto auto auto;gap:12px;padding:12px 20px 20px}.panel-weather{grid-column:1;grid-row:1}.panel-traffic{grid-column:2;grid-row:1}.panel-cctv{grid-column:3;grid-row:1}.panel-labor{grid-column:1 / 3;grid-row:2}.panel-trucks{grid-column:3;grid-row:2}.panel-cranes{grid-column:1 / 4;grid-row:3}.panel{background:var(--sf-surface);border:1px solid var(--sf-border);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--sf-border);min-height:44px}.panel-title{font-size:.8125rem;font-weight:600;color:var(--sf-white);display:flex;align-items:center;gap:8px}.panel-title-icon{font-size:.875rem}.panel-meta{font-size:.6875rem;color:var(--sf-text-dim);font-family:var(--font-mono)}.panel-body{padding:16px;flex:1;min-height:0}.weather-main{display:flex;align-items:center;gap:16px;margin-bottom:16px}.weather-icon-large{font-size:2.5rem;line-height:1}.weather-temp{font-size:2rem;font-weight:700;color:var(--sf-white);line-height:1}.weather-temp-unit{font-size:1rem;font-weight:400;color:var(--sf-text-muted)}.weather-details{display:flex;flex-direction:column;gap:2px}.weather-detail-row{font-size:.75rem;color:var(--sf-text-muted)}.weather-forecast{font-size:.75rem;color:var(--sf-text-muted);line-height:1.5;padding:10px;background:var(--sf-dark);border-radius:var(--radius);margin-top:4px}.weather-warning-banner{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#ed1c241f;border:1px solid rgba(237,28,36,.3);border-radius:var(--radius);margin-top:12px;font-size:.75rem;color:var(--sf-red);font-weight:500}.traffic-map{width:100%;height:280px;border-radius:var(--radius);border:1px solid var(--sf-border);background:var(--sf-dark);overflow:hidden}.traffic-map iframe{width:100%;height:100%;border:none}.traffic-placeholder{width:100%;height:280px;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;color:var(--sf-text-dim);font-size:.8125rem;background:var(--sf-dark);border-radius:var(--radius);border:1px dashed var(--sf-border)}.cctv-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:6px}.cctv-feed{position:relative;border-radius:6px;overflow:hidden;background:var(--sf-dark);border:1px solid var(--sf-border);aspect-ratio:16/9}.cctv-feed img{width:100%;height:100%;object-fit:cover}.cctv-label{position:absolute;bottom:0;left:0;right:0;padding:4px 8px;background:linear-gradient(transparent,#000000bf);font-size:.625rem;color:var(--sf-white);display:flex;justify-content:space-between;align-items:center}.cctv-status{display:flex;align-items:center;gap:4px}.cctv-status-dot{width:5px;height:5px;border-radius:50%}.cctv-status-dot.online{background:var(--sf-green)}.cctv-status-dot.offline{background:var(--sf-red)}.labor-content{display:flex;gap:20px}.labor-chart{flex:1;min-width:0}.labor-bar-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}.labor-bar-label{font-size:.6875rem;color:var(--sf-text-muted);width:130px;flex-shrink:0;text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.labor-bar-track{flex:1;height:16px;background:var(--sf-dark);border-radius:3px;overflow:hidden;position:relative}.labor-bar-fill{height:100%;border-radius:3px;transition:width .6s ease;min-width:2px}.labor-bar-fill.good{background:var(--sf-green)}.labor-bar-fill.warning{background:var(--sf-yellow)}.labor-bar-fill.low{background:var(--sf-red)}.labor-bar-count{font-size:.6875rem;color:var(--sf-text-muted);width:50px;font-variant-numeric:tabular-nums;text-align:right}.labor-summary{width:200px;flex-shrink:0;display:flex;flex-direction:column;gap:8px}.labor-stat{padding:8px 10px;background:var(--sf-dark);border-radius:var(--radius);border:1px solid var(--sf-border)}.labor-stat-label{font-size:.625rem;color:var(--sf-text-dim);text-transform:uppercase;letter-spacing:.04em}.labor-stat-value{font-size:1.125rem;font-weight:700;color:var(--sf-white);font-variant-numeric:tabular-nums}.labor-stat-sub{font-size:.625rem;color:var(--sf-text-muted)}.truck-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}.truck-stat{padding:8px 10px;background:var(--sf-dark);border-radius:var(--radius);border:1px solid var(--sf-border);text-align:center}.truck-stat-value{font-size:1.125rem;font-weight:700;color:var(--sf-white);font-variant-numeric:tabular-nums}.truck-stat-label{font-size:.625rem;color:var(--sf-text-dim);text-transform:uppercase;letter-spacing:.03em}.truck-events{display:flex;flex-direction:column;gap:4px;max-height:180px;overflow-y:auto}.truck-event{display:flex;align-items:center;gap:8px;padding:6px 8px;font-size:.6875rem;border-radius:4px;background:var(--sf-dark)}.truck-event-type{padding:1px 6px;border-radius:3px;font-weight:600;font-size:.625rem;text-transform:uppercase}.truck-event-type.entry{background:#2ecc7126;color:var(--sf-green)}.truck-event-type.exit{background:#f39c1226;color:var(--sf-yellow)}.truck-event-type.deposit{background:#3498db26;color:#3498db}.truck-event-id{color:var(--sf-white);font-weight:500;font-family:var(--font-mono)}.truck-event-detail{color:var(--sf-text-muted);flex:1}.truck-event-time{color:var(--sf-text-dim);font-family:var(--font-mono);font-size:.625rem}.crane-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.crane-card{padding:16px;background:var(--sf-dark);border-radius:var(--radius);border:1px solid var(--sf-border);display:flex;flex-direction:column;gap:12px}.crane-card.alarm{border-color:#ed1c2480;background:#ed1c240d}.crane-card-header{display:flex;justify-content:space-between;align-items:center}.crane-name{font-size:.8125rem;font-weight:600;color:var(--sf-white)}.crane-status-badge{padding:2px 8px;border-radius:10px;font-size:.625rem;font-weight:600;text-transform:uppercase}.crane-status-badge.operating{background:#2ecc7126;color:var(--sf-green)}.crane-status-badge.idle{background:#8899aa26;color:var(--sf-text-muted)}.crane-status-badge.alarm{background:#ed1c2433;color:var(--sf-red)}.crane-gauge-container{display:flex;align-items:center;justify-content:center}.gauge-svg{width:120px;height:80px}.gauge-bg{fill:none;stroke:var(--sf-border);stroke-width:10;stroke-linecap:round}.gauge-fill{fill:none;stroke-width:10;stroke-linecap:round;transition:stroke-dashoffset .8s ease,stroke .3s ease}.gauge-fill.safe{stroke:var(--sf-green)}.gauge-fill.caution{stroke:var(--sf-yellow)}.gauge-fill.danger{stroke:var(--sf-red)}.gauge-text{font-size:16px;font-weight:700;fill:var(--sf-white);text-anchor:middle}.gauge-label{font-size:8px;fill:var(--sf-text-muted);text-anchor:middle}.crane-details{display:grid;grid-template-columns:1fr 1fr;gap:6px}.crane-detail{font-size:.6875rem}.crane-detail-label{color:var(--sf-text-dim)}.crane-detail-value{color:var(--sf-text);font-weight:500;font-variant-numeric:tabular-nums}.alert-drawer-overlay{position:fixed;inset:0;background:#00000080;z-index:200;animation:fadeIn .2s ease}.alert-drawer{position:fixed;top:0;right:0;width:400px;height:100vh;background:var(--sf-dark);border-left:1px solid var(--sf-border);z-index:201;display:flex;flex-direction:column;animation:slideIn .25s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.alert-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--sf-border)}.alert-drawer-title{font-size:.9375rem;font-weight:600;color:var(--sf-white)}.alert-drawer-close{width:32px;height:32px;border-radius:6px;border:none;background:var(--sf-surface);color:var(--sf-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:background .15s}.alert-drawer-close:hover{background:var(--sf-surface-2)}.alert-list{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px}.alert-item{padding:12px;border-radius:var(--radius);border:1px solid var(--sf-border);background:var(--sf-surface)}.alert-item.critical{border-left:3px solid var(--sf-red)}.alert-item.warning{border-left:3px solid var(--sf-yellow)}.alert-item.info{border-left:3px solid var(--sf-blue)}.alert-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.alert-item-title{font-size:.8125rem;font-weight:600;color:var(--sf-white)}.alert-severity-badge{padding:1px 6px;border-radius:3px;font-size:.5625rem;font-weight:700;text-transform:uppercase}.alert-severity-badge.critical{background:#ed1c2433;color:var(--sf-red)}.alert-severity-badge.warning{background:#f39c1233;color:var(--sf-yellow)}.alert-severity-badge.info{background:#045aff33;color:var(--sf-blue)}.alert-item-message{font-size:.75rem;color:var(--sf-text-muted);line-height:1.4;margin-bottom:6px}.alert-item-footer{display:flex;justify-content:space-between;align-items:center}.alert-item-time{font-size:.625rem;color:var(--sf-text-dim);font-family:var(--font-mono)}.alert-item-category{font-size:.5625rem;color:var(--sf-text-dim);text-transform:uppercase;letter-spacing:.05em}.toast-container{position:fixed;top:68px;right:20px;z-index:300;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{padding:10px 16px;border-radius:var(--radius);background:var(--sf-dark);border:1px solid var(--sf-border);color:var(--sf-text);font-size:.8125rem;min-width:280px;max-width:380px;animation:toastIn .3s ease;pointer-events:auto;display:flex;align-items:flex-start;gap:8px}.toast.critical{border-left:3px solid var(--sf-red)}.toast.warning{border-left:3px solid var(--sf-yellow)}.toast.info{border-left:3px solid var(--sf-blue)}@keyframes toastIn{0%{opacity:0;transform:translate(50px)}to{opacity:1;transform:translate(0)}}.toast-icon{flex-shrink:0;margin-top:1px}.toast-content{flex:1}.toast-title{font-weight:600;font-size:.75rem}.toast-message{font-size:.6875rem;color:var(--sf-text-muted);margin-top:2px}.loading-skeleton{background:linear-gradient(90deg,var(--sf-dark) 25%,var(--sf-surface) 50%,var(--sf-dark) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:4px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.panel-loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--sf-text-dim);font-size:.8125rem}.refresh-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--sf-green);margin-right:4px;vertical-align:middle}@media(max-width:1200px){.dashboard-grid{grid-template-columns:1fr 1fr}.panel-weather{grid-column:1;grid-row:1}.panel-traffic{grid-column:2;grid-row:1}.panel-cctv{grid-column:1 / 3;grid-row:2}.panel-labor{grid-column:1 / 3;grid-row:3}.panel-trucks{grid-column:1 / 3;grid-row:4}.panel-cranes{grid-column:1 / 3;grid-row:5}.crane-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.dashboard-grid{grid-template-columns:1fr}.panel-weather,.panel-traffic,.panel-cctv,.panel-labor,.panel-trucks,.panel-cranes{grid-column:1;grid-row:auto}.kpi-bar{grid-template-columns:1fr 1fr}.crane-grid{grid-template-columns:1fr}.labor-content{flex-direction:column}.labor-summary{width:100%;flex-direction:row}.alert-drawer{width:100%}.header-site-name{display:none}}
