*{margin:0;padding:0;box-sizing:border-box}:root{--sf-red: #ED1C24;--sf-red-dark: #c41920;--sf-red-light: #fee2e2;--sf-blue: #045AFF;--sf-blue-light: #e0ecff;--sf-black: #171717;--sf-dark: #333333;--bg-primary: #f4f5f7;--bg-white: #ffffff;--bg-warm: #f5f3f3;--bg-card: #ffffff;--bg-card-hover: #fafafa;--border-color: #e5e7eb;--border-light: #f1f1f1;--text-primary: #171717;--text-secondary: #6b7280;--text-muted: #9ca3af;--status-normal: #10b981;--status-normal-bg: #ecfdf5;--status-warning: #f59e0b;--status-warning-bg: #fffbeb;--status-critical: #ef4444;--status-critical-bg: #fef2f2;--status-info: #3b82f6;--status-info-bg: #eff6ff;--radius: 12px;--radius-sm: 8px;--radius-lg: 16px;--header-height: 64px;--sidebar-width: 0px;--gap: 12px;--gap-sm: 10px;--gap-lg: 16px;--shadow-sm: 0 1px 2px rgba(0,0,0,.04);--shadow: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 6px rgba(0,0,0,.06), 0 2px 4px rgba(0,0,0,.04);--shadow-lg: 0 10px 15px rgba(0,0,0,.08), 0 4px 6px rgba(0,0,0,.04)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.5;font-size:14px}#root{min-height:100vh}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}.header{position:fixed;top:0;left:0;right:0;height:var(--header-height);background:var(--bg-white);border-bottom:1px solid var(--border-color);display:flex;align-items:center;padding:0 24px;z-index:100;box-shadow:var(--shadow-sm)}.header-left{display:flex;align-items:center;gap:16px}.header-logo{height:36px;width:auto}.header-divider{width:1px;height:28px;background:var(--border-color)}.header-title{font-size:22px;font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.header-subtitle{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.header-right{margin-left:auto;display:flex;align-items:center;gap:16px}.site-selector{display:flex;align-items:center;gap:8px;padding:6px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-white);font-size:13px;color:var(--text-primary);cursor:pointer;transition:border-color .15s}.site-selector:hover{border-color:var(--sf-dark)}.site-selector select{border:none;background:transparent;font-size:13px;color:var(--text-primary);cursor:pointer;outline:none;font-family:inherit}.notification-toggle{position:relative;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);transition:background .15s,color .15s}.notification-toggle:hover{background:var(--bg-primary);color:var(--text-secondary)}.notification-toggle.active{color:var(--status-normal)}.notification-toggle.active:hover{color:var(--status-normal);background:var(--status-normal-bg)}.notif-blocked-dot{position:absolute;top:4px;right:4px;width:8px;height:8px;border-radius:50%;background:var(--status-critical);border:1.5px solid var(--bg-white)}.alert-bell{position:relative;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);transition:background .15s,color .15s}.alert-bell:hover{background:var(--bg-primary);color:var(--text-primary)}.alert-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;border-radius:8px;background:var(--sf-red);color:#fff;font-size:10px;font-weight:600;display:flex;align-items:center;justify-content:center;padding:0 4px}.live-indicator{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--status-normal);font-weight:500}.live-dot{width:8px;height:8px;border-radius:50%;background:var(--status-normal);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.main-content{margin-top:var(--header-height);padding:var(--gap-lg);max-width:1600px;margin-left:auto;margin-right:auto}.dashboard-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap)}.dashboard-grid .span-2{grid-column:span 2}.dashboard-grid .span-3{grid-column:span 3}.card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border-color);box-shadow:var(--shadow);overflow:hidden}.card-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid var(--border-light)}.card-header-left{display:flex;align-items:center;gap:10px}.card-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-sm);flex-shrink:0}.card-icon.weather{background:#dbeafe;color:#2563eb}.card-icon.labor{background:#fef3c7;color:#d97706}.card-icon.truck{background:#e0e7ff;color:#4f46e5}.card-icon.crane{background:#fee2e2;color:#dc2626}.card-icon.traffic{background:#d1fae5;color:#059669}.card-icon.cctv{background:#f3e8ff;color:#7c3aed}.card-icon.alert{background:#fef2f2;color:#ef4444}.card-title{font-size:13px;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.03em}.card-body{padding:16px 20px 20px}.card-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:6px;font-size:11px;font-weight:600}.card-badge.normal{background:var(--status-normal-bg);color:var(--status-normal)}.card-badge.warning{background:var(--status-warning-bg);color:var(--status-warning)}.card-badge.critical{background:var(--status-critical-bg);color:var(--status-critical)}.card-badge.info{background:var(--status-info-bg);color:var(--status-info)}.stat-row{display:flex;gap:24px;flex-wrap:wrap}.stat-item{flex:1;min-width:80px}.stat-value{font-size:28px;font-weight:700;color:var(--text-primary);line-height:1.1;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.stat-value.small{font-size:20px}.stat-label{font-size:12px;color:var(--text-secondary);margin-top:2px}.stat-unit{font-size:14px;font-weight:400;color:var(--text-muted);margin-left:2px}.weather-card-full{grid-column:span 3}.wx-body{padding:14px 20px 18px}.wx-layout{display:flex;gap:20px;align-items:stretch}.wx-today{flex-shrink:0;width:280px;display:flex;flex-direction:column;gap:12px}.wx-today-main{display:flex;align-items:center;gap:14px}.wx-today-icon{flex-shrink:0;opacity:.9}.wx-today-temp-block{display:flex;flex-direction:column;gap:2px}.wx-today-temp{font-size:36px;font-weight:700;color:var(--text-primary);line-height:1;letter-spacing:-.03em}.wx-today-unit{font-size:16px;font-weight:400;color:var(--text-muted);vertical-align:super}.wx-today-meta{display:flex;flex-direction:column}.wx-today-source{font-size:10px;font-weight:600;color:var(--text-secondary);letter-spacing:.02em}.wx-today-time{font-size:10px;color:var(--text-muted)}.wx-today-details{display:flex;flex-wrap:wrap;gap:8px}.wx-detail-pill{display:flex;align-items:center;gap:5px;padding:5px 10px;background:var(--bg-primary);border-radius:var(--radius-sm)}.wx-detail-label{font-size:11px;color:var(--text-secondary)}.wx-detail-value{font-size:12px;font-weight:600;color:var(--text-primary)}.wx-warnings{display:flex;flex-wrap:wrap;gap:5px}.wx-warning-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:5px;font-size:11px;font-weight:600;background:var(--status-warning-bg);color:var(--status-warning)}.wx-warning-tag.critical{background:var(--status-critical-bg);color:var(--status-critical)}.wx-divider{width:1px;background:var(--border-light);flex-shrink:0;align-self:stretch}.wx-forecast-area{flex:1;min-width:0}.wx-forecast-header{font-size:10px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}.forecast-week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.forecast-col{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px 10px;background:var(--bg-primary);border-radius:var(--radius-sm);transition:background .15s}.forecast-col:hover{background:var(--bg-warm)}.forecast-col-day{font-size:11px;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.03em}.forecast-col-date{font-size:9px;color:var(--text-muted);margin-top:-2px}.forecast-col-icon{opacity:.85;margin:2px 0}.forecast-col-temps{display:flex;flex-direction:column;align-items:center;gap:0}.forecast-col-max{font-size:13px;font-weight:700;color:var(--text-primary);line-height:1.3}.forecast-col-min{font-size:11px;font-weight:500;color:var(--text-muted);line-height:1.3}.psr-pill{display:inline-flex;align-items:center;gap:3px;padding:2px 6px;border-radius:4px;font-size:9px;font-weight:700;letter-spacing:.02em;margin-top:2px;white-space:nowrap}.psr-pill.low{background:#ecfdf5;color:#10b981}.psr-pill.medium-low{background:#f7fee7;color:#65a30d}.psr-pill.medium{background:#fefce8;color:#ca8a04}.psr-pill.medium-high{background:#fff7ed;color:#ea580c}.psr-pill.high{background:#fef2f2;color:#ef4444}.trade-list{display:flex;flex-direction:column;gap:8px;margin-top:12px}.trade-row{display:flex;align-items:center;gap:12px}.trade-name{width:110px;font-size:12px;color:var(--text-secondary);flex-shrink:0;text-align:right}.trade-bar-track{flex:1;height:20px;background:var(--bg-primary);border-radius:4px;overflow:hidden}.trade-bar-fill{height:100%;border-radius:4px;transition:width .6s ease;background:linear-gradient(90deg,#f59e0b,#eab308)}.trade-count{width:32px;font-size:13px;font-weight:600;color:var(--text-primary);text-align:right}.labor-tabs{display:flex;gap:2px;margin-top:14px;margin-bottom:12px;background:var(--bg-primary);border-radius:var(--radius-sm);padding:2px}.labor-tab{flex:1;padding:5px 10px;border:none;background:transparent;font-size:11px;font-weight:600;color:var(--text-secondary);cursor:pointer;border-radius:4px;transition:all .15s ease}.labor-tab:hover{color:var(--text-primary)}.labor-tab.active{background:var(--bg-card);color:var(--text-primary);box-shadow:0 1px 2px #0000000f}.labor-chart-container{min-height:180px}.labor-chart-skeleton{height:180px}.crane-list{display:flex;flex-direction:column;gap:16px}.crane-item{display:flex;align-items:center;gap:16px;padding:12px 16px;background:var(--bg-primary);border-radius:var(--radius-sm);border:1px solid var(--border-light)}.crane-id{font-size:14px;font-weight:700;color:var(--text-primary);min-width:48px}.crane-gauge-container{flex:1;display:flex;flex-direction:column;gap:4px}.crane-gauge-track{width:100%;height:12px;background:#e5e7eb;border-radius:6px;overflow:hidden}.crane-gauge-fill{height:100%;border-radius:6px;transition:width .6s ease,background .3s}.crane-gauge-fill.normal{background:linear-gradient(90deg,#10b981,#34d399)}.crane-gauge-fill.warning{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.crane-gauge-fill.critical{background:linear-gradient(90deg,#ef4444,#f87171)}.crane-info{display:flex;justify-content:space-between;font-size:11px;color:var(--text-secondary)}.crane-load-text{font-size:14px;font-weight:700;min-width:50px;text-align:right}.crane-load-text.normal{color:var(--status-normal)}.crane-load-text.warning{color:var(--status-warning)}.crane-load-text.critical{color:var(--status-critical)}.crane-status-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}.crane-status-badge.normal{background:var(--status-normal-bg);color:var(--status-normal)}.crane-status-badge.warning{background:var(--status-warning-bg);color:var(--status-warning)}.crane-status-badge.critical{background:var(--status-critical-bg);color:var(--status-critical);animation:flashCritical 1s ease-in-out infinite}@keyframes flashCritical{0%,to{opacity:1}50%{opacity:.6}}.cctv-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.cctv-item{position:relative;border-radius:var(--radius-sm);overflow:hidden;background:#000;aspect-ratio:16/9}.cctv-item video{width:100%;height:100%;object-fit:cover}.cctv-label{position:absolute;bottom:0;left:0;right:0;padding:6px 10px;background:linear-gradient(transparent,#000c);color:#fff;font-size:12px;font-weight:500}.cctv-live-badge{position:absolute;top:8px;right:8px;display:flex;align-items:center;gap:4px;padding:2px 8px;border-radius:4px;background:#ef4444e6;color:#fff;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.cctv-live-dot{width:6px;height:6px;border-radius:50%;background:#fff;animation:pulse 1.5s ease-in-out infinite}.alert-list{display:flex;flex-direction:column;gap:8px}.alert-item{display:flex;align-items:flex-start;gap:12px;padding:10px 14px;border-radius:var(--radius-sm);border:1px solid var(--border-light);transition:background .15s}.alert-item:hover{background:var(--bg-primary)}.alert-item.critical{border-left:3px solid var(--status-critical);background:var(--status-critical-bg)}.alert-item.warning{border-left:3px solid var(--status-warning)}.alert-item.info{border-left:3px solid var(--status-info)}.alert-icon{flex-shrink:0;margin-top:1px}.alert-content{flex:1;min-width:0}.alert-title{font-size:13px;font-weight:600;color:var(--text-primary)}.alert-message{font-size:12px;color:var(--text-secondary);margin-top:2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.alert-time{font-size:11px;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.alert-ack-btn{padding:4px 10px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-white);font-size:11px;color:var(--text-secondary);cursor:pointer;transition:all .15s;white-space:nowrap}.alert-ack-btn:hover{background:var(--bg-primary);border-color:var(--sf-dark);color:var(--text-primary)}.map-container{width:100%;height:280px;border-radius:var(--radius-sm);overflow:hidden}.map-container .leaflet-container{width:100%;height:100%}.route-selector-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;border-bottom:1px solid var(--border-light);gap:12px}.route-selector-left{display:flex;align-items:center;gap:8px;min-width:0}.route-selector-summary{font-size:12px;font-weight:600;color:var(--text-secondary);white-space:nowrap;flex-shrink:0}.route-selector-dropdown{position:relative}.route-selector-trigger{display:flex;align-items:center;gap:8px;padding:6px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-white);font-size:12px;font-weight:500;font-family:inherit;color:var(--text-secondary);cursor:pointer;transition:border-color .15s,background .15s;white-space:nowrap;max-width:260px;overflow:hidden;text-overflow:ellipsis}.route-selector-trigger:hover{border-color:var(--sf-dark)}.route-selector-trigger.active{border-color:var(--sf-blue);color:var(--text-primary);background:color-mix(in srgb,var(--sf-blue) 4%,transparent)}.route-chevron{color:var(--text-muted);transition:transform .2s;flex-shrink:0}.route-chevron.open{transform:rotate(180deg)}.route-selector-menu{position:absolute;top:calc(100% + 4px);left:0;min-width:280px;max-width:340px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:50;overflow:hidden}.route-menu-empty{padding:16px 20px;font-size:13px;color:var(--text-muted);text-align:center}.route-menu-item{display:flex;align-items:flex-start;gap:10px;width:100%;padding:10px 16px;border:none;background:none;font-family:inherit;font-size:13px;cursor:pointer;text-align:left;transition:background .1s}.route-menu-item:hover{background:var(--bg-primary)}.route-menu-item.selected{background:color-mix(in srgb,var(--sf-blue) 6%,transparent)}.route-menu-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:4px}.route-menu-info{display:flex;flex-direction:column;gap:2px;min-width:0}.route-menu-name{font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.route-menu-meta{font-size:11px;color:var(--text-muted)}.route-menu-active{color:var(--status-normal);font-weight:600}.route-clear-btn{padding:4px 10px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-white);font-size:11px;font-weight:600;font-family:inherit;color:var(--text-secondary);cursor:pointer;transition:all .15s;white-space:nowrap}.route-clear-btn:hover{background:var(--bg-primary);border-color:var(--sf-dark);color:var(--text-primary)}.route-map-container{width:100%;height:360px}.route-info-panel{display:flex;align-items:center;gap:12px;padding:12px 20px;border-top:1px solid var(--border-light);flex-wrap:wrap}.route-info-loading{display:flex;align-items:center;gap:16px;width:100%}.route-info-item{display:flex;align-items:center;gap:8px;color:var(--text-secondary)}.route-info-item.primary{color:var(--sf-blue)}.route-info-item.active{color:var(--status-normal)}.route-info-data{display:flex;flex-direction:column;gap:0}.route-info-value{font-size:14px;font-weight:700;color:var(--text-primary);line-height:1.2}.route-info-item.primary .route-info-value{color:var(--sf-blue)}.route-info-item.active .route-info-value{color:var(--status-normal)}.route-info-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;font-weight:500}.route-info-divider{width:1px;height:28px;background:var(--border-light);flex-shrink:0}.route-info-error{font-size:13px;color:var(--status-critical);font-weight:500;padding:4px 0}.route-error-state{padding:40px 20px;text-align:center;color:var(--status-critical);font-size:13px;font-weight:500}.truck-active-list{margin-top:12px;display:flex;flex-direction:column;gap:6px}.truck-active-item{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;background:var(--bg-primary);border-radius:6px;font-size:12px}.truck-id{font-weight:600;color:var(--text-primary)}.truck-weight{color:var(--text-secondary)}.truck-time{color:var(--text-muted);font-size:11px}.skeleton{background:linear-gradient(90deg,var(--bg-primary) 25%,var(--bg-warm) 50%,var(--bg-primary) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:6px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:14px;margin-bottom:8px}.skeleton-value{height:28px;width:80px}.section-title{display:flex;align-items:center;gap:8px;margin-bottom:16px;font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.section-title:after{content:"";flex:1;height:1px;background:var(--border-color)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:24px}.login-container{width:100%;max-width:420px;text-align:center}.login-header{margin-bottom:32px}.login-logo{height:56px;width:auto;margin:0 auto 16px}.login-title{font-size:26px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;margin-bottom:6px}.login-subtitle{font-size:14px;color:var(--text-secondary)}.login-form{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:28px 24px;margin-bottom:20px;box-shadow:var(--shadow);text-align:left}.login-error{background:var(--status-critical-bg);color:var(--status-critical);padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;margin-bottom:16px;border:1px solid color-mix(in srgb,var(--status-critical) 20%,transparent)}.login-field{margin-bottom:16px}.login-label{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.03em}.login-input-wrapper{position:relative}.login-input{width:100%;padding:10px 14px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;color:var(--text-primary);background:var(--bg-white);outline:none;transition:border-color .15s,box-shadow .15s}.login-input:focus{border-color:var(--sf-blue);box-shadow:0 0 0 3px color-mix(in srgb,var(--sf-blue) 12%,transparent)}.login-input:disabled{background:var(--bg-primary);color:var(--text-muted)}.login-input-wrapper .login-input{padding-right:42px}.login-eye-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;display:flex;align-items:center}.login-eye-btn:hover{color:var(--text-secondary)}.login-submit{width:100%;padding:12px;border:none;border-radius:var(--radius-sm);background:var(--sf-red);color:#fff;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:4px}.login-submit:hover:not(:disabled){background:var(--sf-red-dark)}.login-submit:disabled{opacity:.7;cursor:not-allowed}.login-demo-hint{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text-muted);background:var(--bg-warm);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:12px 16px;margin-bottom:20px;text-align:center}.login-demo-label{font-weight:600;color:var(--text-secondary)}.login-demo-hint code{background:var(--bg-primary);padding:1px 6px;border-radius:4px;font-size:12px;font-weight:600;color:var(--text-primary)}.login-footer{font-size:12px;color:var(--text-muted);letter-spacing:.02em}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:spin 1s linear infinite}.role-badge-header{display:inline-flex;align-items:center;padding:4px 12px;border-radius:6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--role-color, var(--sf-blue));background:color-mix(in srgb,var(--role-color, var(--sf-blue)) 10%,transparent);border:1px solid color-mix(in srgb,var(--role-color, var(--sf-blue)) 25%,transparent)}.logout-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-white);color:var(--text-secondary);cursor:pointer;transition:all .15s}.logout-btn:hover{background:var(--bg-primary);color:var(--sf-red);border-color:var(--sf-red)}.crane-summary-grid{display:flex;flex-wrap:wrap;gap:10px}.crane-summary-item{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--bg-primary);border-radius:var(--radius-sm);border:1px solid var(--border-light);flex:1;min-width:140px}@media(max-width:1200px){.dashboard-grid{grid-template-columns:repeat(2,1fr)}.dashboard-grid .span-3,.weather-card-full{grid-column:span 2}.cctv-grid{grid-template-columns:repeat(2,1fr)}.wx-layout{flex-direction:column}.wx-today{width:100%}.wx-divider{width:100%;height:1px}.forecast-week-grid{grid-template-columns:repeat(7,1fr)}}@media(max-width:768px){.main-content{padding:var(--gap)}.dashboard-grid{grid-template-columns:1fr}.dashboard-grid .span-2,.dashboard-grid .span-3,.weather-card-full{grid-column:span 1}.wx-layout{flex-direction:column}.wx-today{width:100%}.wx-divider{width:100%;height:1px}.forecast-week-grid{grid-template-columns:repeat(4,1fr)}.cctv-grid{grid-template-columns:1fr}.header-title{font-size:14px}.header-subtitle,.role-badge-header{display:none}}.user-dropdown-wrapper{position:relative}.user-dropdown-trigger{display:flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-white);cursor:pointer;font-family:inherit;font-size:13px;color:var(--text-primary);transition:border-color .15s,box-shadow .15s}.user-dropdown-trigger:hover{border-color:var(--sf-dark)}.user-avatar{width:28px;height:28px;border-radius:50%;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);flex-shrink:0}.user-dropdown-name{font-weight:500;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-chevron{color:var(--text-muted);transition:transform .2s;flex-shrink:0}.user-chevron.open{transform:rotate(180deg)}.user-dropdown-menu{position:absolute;top:calc(100% + 6px);right:0;width:260px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:200;overflow:hidden}.user-dropdown-header{padding:14px 16px;border-bottom:1px solid var(--border-light)}.user-dropdown-info-name{font-size:14px;font-weight:600;color:var(--text-primary)}.user-dropdown-info-email{font-size:12px;color:var(--text-muted);margin-top:2px}.role-badge-dropdown{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-top:8px;color:var(--role-color, var(--sf-blue));background:color-mix(in srgb,var(--role-color, var(--sf-blue)) 10%,transparent)}.user-dropdown-divider{height:1px;background:var(--border-light)}.user-dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 16px;border:none;background:none;font-size:13px;font-family:inherit;color:var(--text-secondary);cursor:pointer;transition:background .1s,color .1s}.user-dropdown-item:hover{background:var(--bg-primary);color:var(--text-primary)}.user-dropdown-item.logout:hover{background:var(--status-critical-bg);color:var(--status-critical)}.admin-layout{display:flex;min-height:100vh}.admin-sidebar{width:220px;background:var(--bg-white);border-right:1px solid var(--border-color);padding:20px 0;flex-shrink:0;position:fixed;top:0;bottom:0;left:0;z-index:50;display:flex;flex-direction:column}.admin-sidebar-header{padding:0 16px 16px;border-bottom:1px solid var(--border-light);margin-bottom:12px}.admin-back-btn{display:flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-white);font-size:12px;font-family:inherit;color:var(--text-secondary);cursor:pointer;transition:all .15s;margin-bottom:16px}.admin-back-btn:hover{background:var(--bg-primary);color:var(--text-primary)}.admin-sidebar-title{font-size:18px;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.admin-nav{display:flex;flex-direction:column;gap:2px;padding:0 8px}.admin-nav-item{display:flex;align-items:center;gap:10px;padding:9px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;color:var(--text-secondary);text-decoration:none;transition:background .1s,color .1s}.admin-nav-item:hover{background:var(--bg-primary);color:var(--text-primary)}.admin-nav-item.active{background:var(--sf-blue);color:#fff}.admin-content{flex:1;margin-left:220px;padding:32px;background:var(--bg-primary);min-height:100vh}.admin-page{max-width:960px}.admin-page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px}.admin-page-title{font-size:22px;font-weight:700;color:var(--text-primary);letter-spacing:-.01em;margin-bottom:4px}.admin-page-desc{font-size:13px;color:var(--text-secondary)}.admin-loading{padding:40px;text-align:center;color:var(--text-muted);font-size:14px}.admin-empty{padding:40px;text-align:center;color:var(--text-muted);font-size:13px}.admin-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s;border:1px solid transparent;white-space:nowrap}.admin-btn.primary{background:var(--sf-blue);color:#fff;border-color:var(--sf-blue)}.admin-btn.primary:hover:not(:disabled){background:#0349d6}.admin-btn.primary:disabled{opacity:.6;cursor:not-allowed}.admin-btn.secondary{background:var(--bg-white);color:var(--text-secondary);border-color:var(--border-color)}.admin-btn.secondary:hover{background:var(--bg-primary);color:var(--text-primary)}.admin-search{display:flex;align-items:center;gap:10px;padding:10px 14px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-white);margin-bottom:20px;color:var(--text-muted)}.admin-search input{border:none;outline:none;background:transparent;font-size:13px;font-family:inherit;color:var(--text-primary);flex:1}.admin-search input::placeholder{color:var(--text-muted)}.admin-table{width:100%;border-collapse:collapse;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);overflow:hidden;font-size:13px}.admin-table thead{background:var(--bg-primary)}.admin-table th{padding:10px 16px;text-align:left;font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border-color)}.admin-table td{padding:12px 16px;border-bottom:1px solid var(--border-light);vertical-align:middle}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--bg-primary)}.admin-table tr.inactive-row td{opacity:.55}.admin-cell-bold{font-weight:600;color:var(--text-primary)}.admin-user-cell{display:flex;flex-direction:column;gap:1px}.admin-user-name{font-weight:600;color:var(--text-primary)}.admin-user-email{font-size:12px;color:var(--text-muted)}.admin-role-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:5px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--role-color, var(--text-secondary));background:color-mix(in srgb,var(--role-color, var(--text-secondary)) 10%,transparent)}.admin-site-tags{display:flex;flex-wrap:wrap;gap:4px}.admin-site-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500;background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-light)}.admin-access-level{font-size:9px;font-weight:700;text-transform:uppercase;color:var(--text-muted);margin-left:2px}.admin-muted{font-size:12px;color:var(--text-muted)}.admin-status-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:5px;font-size:11px;font-weight:600}.admin-status-badge.active{background:var(--status-normal-bg);color:var(--status-normal)}.admin-status-badge.inactive{background:var(--bg-primary);color:var(--text-muted)}.admin-actions{display:flex;gap:4px}.admin-action-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:6px;border:1px solid var(--border-color);background:var(--bg-white);color:var(--text-secondary);cursor:pointer;transition:all .15s}.admin-action-btn:hover{background:var(--bg-primary);color:var(--text-primary);border-color:var(--sf-dark)}.admin-action-btn.danger:hover{background:var(--status-critical-bg);color:var(--status-critical);border-color:var(--status-critical)}.admin-modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:300}.admin-modal{background:var(--bg-card);border-radius:var(--radius-lg);padding:24px;width:100%;max-width:400px;box-shadow:var(--shadow-lg)}.admin-modal-title{font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:6px}.admin-modal-desc{font-size:13px;color:var(--text-secondary);margin-bottom:16px}.admin-modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}.admin-form{max-width:640px}.admin-field{margin-bottom:20px}.admin-label{display:block;font-size:12px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}.admin-field-hint{font-size:12px;color:var(--text-muted);margin-bottom:10px}.admin-field-error{background:var(--status-critical-bg);color:var(--status-critical);padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;margin-bottom:16px;border:1px solid color-mix(in srgb,var(--status-critical) 20%,transparent)}.admin-input{width:100%;padding:10px 14px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;color:var(--text-primary);background:var(--bg-white);outline:none;transition:border-color .15s,box-shadow .15s}.admin-input:focus{border-color:var(--sf-blue);box-shadow:0 0 0 3px color-mix(in srgb,var(--sf-blue) 12%,transparent)}.admin-input:disabled{background:var(--bg-primary);color:var(--text-muted)}.admin-role-options{display:grid;grid-template-columns:1fr 1fr;gap:8px}.admin-role-option{display:flex;flex-direction:column;gap:4px;padding:12px 14px;border:2px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:border-color .15s,background .15s}.admin-role-option:hover{border-color:var(--role-color, var(--sf-blue))}.admin-role-option.selected{border-color:var(--role-color, var(--sf-blue));background:color-mix(in srgb,var(--role-color, var(--sf-blue)) 5%,transparent)}.admin-role-option input[type=radio]{display:none}.admin-role-option-label{font-size:13px;font-weight:700;color:var(--text-primary)}.admin-role-option-desc{font-size:11px;color:var(--text-muted);line-height:1.4}.admin-site-assignments{display:flex;flex-direction:column;gap:6px}.admin-site-row{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-white);transition:border-color .15s,background .15s}.admin-site-row.assigned{border-color:var(--sf-blue);background:color-mix(in srgb,var(--sf-blue) 3%,transparent)}.admin-site-check{display:flex;align-items:center;gap:10px;cursor:pointer}.admin-site-check input[type=checkbox]{width:16px;height:16px;accent-color:var(--sf-blue)}.admin-site-check-name{font-size:13px;font-weight:500;color:var(--text-primary)}.admin-access-selector{display:flex;gap:2px;background:var(--bg-primary);border-radius:6px;padding:2px}.admin-access-btn{padding:4px 10px;border:none;background:transparent;font-size:11px;font-weight:600;font-family:inherit;color:var(--text-secondary);cursor:pointer;border-radius:4px;transition:all .15s;text-transform:capitalize}.admin-access-btn:hover{color:var(--text-primary)}.admin-access-btn.active{background:var(--bg-white);color:var(--sf-blue);box-shadow:0 1px 2px #0000000f}.admin-form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:28px;padding-top:20px;border-top:1px solid var(--border-light)}.admin-back-link{display:inline-flex;align-items:center;gap:6px;padding:0;border:none;background:none;font-size:13px;font-family:inherit;color:var(--text-secondary);cursor:pointer;margin-bottom:20px;transition:color .15s}.admin-back-link:hover{color:var(--text-primary)}.perm-user-picker{margin-bottom:24px}.perm-user-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px;max-height:180px;overflow-y:auto;padding:2px}.perm-user-list-empty{padding:16px;text-align:center;color:var(--text-muted);font-size:13px}.perm-user-item{display:flex;align-items:center;gap:8px;padding:6px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-white);cursor:pointer;font-family:inherit;font-size:13px;transition:all .15s}.perm-user-item:hover{border-color:var(--sf-blue);background:var(--bg-primary)}.perm-user-item.selected{border-color:var(--sf-blue);background:color-mix(in srgb,var(--sf-blue) 8%,transparent);box-shadow:0 0 0 2px color-mix(in srgb,var(--sf-blue) 20%,transparent)}.perm-user-item.inactive{opacity:.5}.perm-user-item-name{font-weight:500;color:var(--text-primary)}.perm-matrix-wrapper{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.perm-matrix-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-light)}.perm-matrix-user-info{display:flex;align-items:center;gap:10px}.perm-matrix-user-name{font-size:15px;font-weight:600;color:var(--text-primary)}.perm-matrix-actions{display:flex;gap:8px}.perm-empty-state{padding:48px 24px;text-align:center;color:var(--text-muted);font-size:14px}.perm-legend{display:flex;gap:20px;padding:12px 20px;border-bottom:1px solid var(--border-light);font-size:12px;color:var(--text-secondary)}.perm-legend-item{display:flex;align-items:center;gap:6px}.perm-matrix-scroll{overflow-x:auto}.perm-matrix-table{width:100%;border-collapse:collapse;font-size:13px}.perm-matrix-table thead{background:var(--bg-primary)}.perm-matrix-table th{padding:10px 16px;text-align:center;font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border-color);white-space:nowrap}.perm-matrix-section-col{text-align:left!important;min-width:160px}.perm-matrix-site-col{min-width:120px}.perm-matrix-table td{padding:10px 16px;border-bottom:1px solid var(--border-light);vertical-align:middle}.perm-matrix-table tr:last-child td{border-bottom:none}.perm-matrix-table tbody tr:hover td{background:color-mix(in srgb,var(--bg-primary) 60%,transparent)}.perm-matrix-section-cell{display:flex;flex-direction:column;gap:2px}.perm-section-name{font-weight:600;color:var(--text-primary)}.perm-role-default-hint{font-size:11px;color:var(--text-muted)}.perm-matrix-cell{text-align:center}.perm-chip{display:inline-flex;align-items:center;justify-content:center;padding:4px 12px;border-radius:6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;cursor:pointer;border:1px solid transparent;transition:all .15s;min-width:72px;font-family:inherit}.perm-chip.default{background:var(--bg-primary);color:var(--text-muted);border-color:var(--border-color)}.perm-chip.default:hover{background:var(--bg-warm);border-color:var(--sf-dark);color:var(--text-secondary)}.perm-chip.granted{background:var(--status-normal-bg);color:var(--status-normal);border-color:color-mix(in srgb,var(--status-normal) 30%,transparent)}.perm-chip.granted:hover{background:color-mix(in srgb,var(--status-normal) 15%,transparent)}.perm-chip.revoked{background:var(--status-critical-bg);color:var(--status-critical);border-color:color-mix(in srgb,var(--status-critical) 30%,transparent)}.perm-chip.revoked:hover{background:color-mix(in srgb,var(--status-critical) 15%,transparent)}.perm-resolved{display:block;font-size:10px;margin-top:3px;font-weight:500}.perm-resolved.visible{color:var(--status-normal)}.perm-resolved.hidden{color:var(--status-critical)}.perm-site-roles-hint{font-size:9px;font-weight:500;color:var(--text-muted);margin-top:2px;text-transform:none;letter-spacing:0}.role-badges-header{display:flex;align-items:center;gap:4px}.role-badges-dropdown{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px}.admin-site-role-tags{display:inline-flex;gap:3px;margin-left:4px}.admin-site-role-mini{display:inline-flex;align-items:center;padding:1px 5px;border-radius:3px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.02em;color:var(--role-color, var(--text-secondary));background:color-mix(in srgb,var(--role-color, var(--text-secondary)) 12%,transparent)}.admin-site-row-multi{border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-white);transition:border-color .15s,background .15s;overflow:hidden}.admin-site-row-multi.assigned{border-color:var(--sf-blue);background:color-mix(in srgb,var(--sf-blue) 2%,transparent)}.admin-site-row-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px}.admin-site-roles{display:flex;flex-direction:column;gap:1px;background:var(--border-light);border-top:1px solid var(--border-light)}.admin-site-role-row{display:flex;align-items:center;justify-content:space-between;padding:8px 14px 8px 36px;background:var(--bg-white);transition:background .1s}.admin-site-role-row.checked{background:color-mix(in srgb,var(--role-color, var(--sf-blue)) 3%,var(--bg-white))}.admin-site-role-check{display:flex;align-items:center;gap:8px;cursor:pointer}.admin-site-role-check input[type=checkbox]{width:14px;height:14px;accent-color:var(--role-color, var(--sf-blue))}.admin-site-role-label{font-size:12px;font-weight:600;color:var(--text-primary)}
