@import"https://fonts.googleapis.com/css2?family=Lato:wght@300;400;700&display=swap";:root{--bg-primary: #ffffff;--bg-secondary: #f4f4f4;--bg-dark: #32373c;--text-primary: #313131;--text-secondary: #707070;--text-inverse: #ffffff;--border-color: #d8d8d8;--accent: #00d084;--accent-hover: #00b871;--accent-dim: #00d08420;--danger: #d44;--panel-width: 380px}@media(prefers-color-scheme:dark){:root{--bg-primary: #1c1c1c;--bg-secondary: #242424;--bg-dark: #313131;--text-primary: #e8e8e8;--text-secondary: #999999;--text-inverse: #ffffff;--border-color: #3a3a3a;--accent-dim: #00d08415}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Lato,Arial,sans-serif;font-weight:400;background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased}.top-bar{height:36px;display:flex;align-items:center;justify-content:space-between;background:var(--bg-dark);border-bottom:1px solid #000;padding:0 14px;flex-shrink:0;z-index:1100}.top-bar-left{display:flex;align-items:center;gap:10px}.top-bar-logo{font-size:.7rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--accent);text-decoration:none}.top-bar-divider{width:1px;height:16px;background:#555}.top-bar-nav{display:flex;gap:2px}.top-bar-link{font-size:.75rem;font-weight:400;color:#aaa;text-decoration:none;padding:4px 10px;transition:color .15s,background .15s}.top-bar-link:hover{color:#fff;background:#ffffff0f}.top-bar-link.active{color:#fff;font-weight:700;background:#ffffff14}.top-bar-right{display:flex;align-items:center;gap:10px}.app-shell{display:flex;flex-direction:column;height:100vh}.page-layout{display:flex;flex:1;min-height:0}.map-panel{flex:1;position:relative}.side-panel{width:var(--panel-width);overflow-y:auto;background:var(--bg-secondary);border-left:1px solid var(--border-color);padding:16px;transition:width .25s,padding .25s,opacity .2s}.side-panel.collapsed{width:0;padding:0;overflow:hidden;border-left:none;opacity:0}.side-panel::-webkit-scrollbar{width:5px}.side-panel::-webkit-scrollbar-track{background:transparent}.side-panel::-webkit-scrollbar-thumb{background:var(--border-color)}@media(max-width:768px){.page-layout{flex-direction:column}.map-panel{height:55vh}.side-panel{width:100%;height:45vh;overflow-y:auto;border-left:none;border-top:1px solid var(--border-color)}.side-panel.collapsed{height:0;width:100%;border-top:none}}@media(max-width:480px){.map-panel,.side-panel{height:50vh}.energy-dashboard-chart{display:none}}.landing-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px}.landing-header{text-align:center;margin-bottom:60px}.landing-logo{font-size:.85rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--accent);margin-bottom:16px}.landing-header h1{font-size:clamp(2rem,4vw,3rem);font-weight:700;line-height:1.1;margin-bottom:16px;color:var(--text-primary)}.landing-header p{color:var(--text-secondary);font-size:1.1rem;font-weight:300;max-width:520px;line-height:1.6}.mode-cards{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border-color);max-width:800px;width:100%}@media(max-width:600px){.mode-cards{grid-template-columns:1fr}}.mode-card{display:block;text-decoration:none;color:var(--text-primary);background:var(--bg-primary);padding:40px 32px;text-align:left;transition:background .2s}.mode-card:hover{background:var(--bg-secondary)}.mode-card h2{font-size:1.3rem;font-weight:700;margin-bottom:12px}.mode-card p{color:var(--text-secondary);font-weight:300;line-height:1.6;margin-bottom:20px;font-size:.95rem}.mode-tag{font-size:.75rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--accent)}.landing-footer{margin-top:60px;font-size:.8rem;color:var(--text-secondary);font-weight:300}.loading{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--text-secondary);font-size:1rem;font-weight:300}.stat-card{background:var(--bg-primary);border:1px solid var(--border-color);padding:8px 10px;text-align:center}.control-section{margin-bottom:16px;padding:12px;background:var(--bg-primary);border:1px solid var(--border-color)}.control-heading{margin:0 0 8px;font-size:.7rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px}.control-btn{padding:6px 14px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;font-family:Lato,Arial,sans-serif;font-size:.85rem;font-weight:400;transition:background .15s,border-color .15s}.control-btn:hover:not(:disabled){border-color:var(--accent);background:var(--accent-dim)}.control-btn:disabled{opacity:.4;cursor:not-allowed}.control-btn.active{background:var(--bg-dark);color:var(--text-inverse);border-color:var(--bg-dark)}.control-btn.primary{background:var(--bg-dark);color:var(--text-inverse);border-color:var(--bg-dark);font-weight:700}.control-btn.primary:hover:not(:disabled){background:var(--accent);border-color:var(--accent);color:var(--text-inverse)}.control-btn-sm{padding:3px 8px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;font-family:Lato,Arial,sans-serif;font-size:.75rem;font-weight:400;transition:background .15s,border-color .15s}.control-btn-sm:hover:not(:disabled){border-color:var(--accent);background:var(--accent-dim)}.control-btn-sm:disabled{opacity:.4;cursor:not-allowed}.control-btn-sm.active{background:var(--bg-dark);color:var(--text-inverse);border-color:var(--bg-dark)}.control-select{width:100%;padding:5px 8px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-family:Lato,Arial,sans-serif;font-size:.85rem}input[type=range]{accent-color:var(--accent)}input[type=datetime-local],input[type=text],input[type=number]{border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-family:Lato,Arial,sans-serif;font-size:.85rem;padding:5px 8px;width:100%}.time-clock-btn{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 10px;margin-bottom:8px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-family:Lato,Arial,sans-serif;cursor:pointer;text-align:left}.time-clock-btn:hover:not(:disabled){border-color:var(--accent)}.time-clock-btn:disabled{opacity:.5;cursor:not-allowed}.time-clock-value{font-size:.95rem;font-weight:600;font-family:Lato,monospace}.time-clock-edit{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);border:1px solid var(--border-color);padding:2px 6px}.time-clock-btn:hover:not(:disabled) .time-clock-edit{color:var(--accent);border-color:var(--accent)}.time-picker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:1000;display:flex;align-items:center;justify-content:center}.time-picker{background:var(--bg-primary);border:1px solid var(--border-color);padding:16px;width:300px;box-shadow:0 8px 32px #0003}.time-picker-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.time-picker-title{font-size:.95rem;font-weight:700}.time-picker-nav{background:none;border:1px solid var(--border-color);color:var(--text-primary);width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.85rem}.time-picker-nav:hover{border-color:var(--accent);color:var(--accent)}.time-picker-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:12px}.time-picker-dow{text-align:center;font-size:.65rem;font-weight:700;text-transform:uppercase;color:var(--text-secondary);padding:4px 0;letter-spacing:.05em}.time-picker-day{text-align:center;padding:6px 0;font-size:.8rem;background:none;border:1px solid transparent;color:var(--text-primary);cursor:pointer;font-family:Lato,Arial,sans-serif}.time-picker-day:hover:not(:disabled){border-color:var(--accent);background:var(--accent-dim)}.time-picker-day.selected{background:var(--bg-dark);color:var(--text-inverse);font-weight:700}.time-picker-day.empty{cursor:default}.time-picker-time{display:flex;gap:8px;margin-bottom:12px}.time-picker-field{flex:1}.time-picker-field label{display:block;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:4px}.time-picker-field select{width:100%;padding:5px 8px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-family:Lato,Arial,sans-serif;font-size:.85rem}.time-picker-presets{display:flex;gap:4px}.time-picker-presets .control-btn-sm{flex:1;text-align:center}.detail-section{padding-top:10px;margin-top:10px;border-top:1px solid var(--border-color)}.truck-row{transition:background .1s}.truck-row:hover,.truck-row.selected{background:var(--accent-dim)}.user-menu{display:flex;align-items:center;gap:8px;background:var(--bg-primary);border:1px solid var(--border-color);padding:6px 12px;font-size:.8rem}.user-avatar{width:24px;height:24px}.user-name{font-weight:700}.role-badge{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--accent)}.login-btn{color:var(--text-primary);text-decoration:none;font-weight:700;font-size:.8rem;padding:4px 10px;border:1px solid var(--border-color);transition:border-color .15s}.login-btn:hover{border-color:var(--accent)}.logout-btn{background:none;border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;font-family:Lato,Arial,sans-serif;font-size:.75rem;padding:2px 8px}.logout-btn:hover{border-color:var(--danger);color:var(--danger)}.status-legend{display:flex;gap:12px;flex-wrap:wrap;padding:8px 0}.status-legend-item{display:flex;align-items:center;gap:4px;font-size:.75rem;font-weight:400;color:var(--text-secondary)}.status-legend-dot{width:10px;height:10px}.energy-bar-container{width:100%;height:20px;background:var(--bg-secondary);border:1px solid var(--border-color);display:flex;overflow:hidden}.energy-bar-segment{height:100%;transition:width .3s}.back-link{color:var(--text-primary);text-decoration:none;font-size:.8rem;font-weight:700;background:var(--bg-primary);padding:6px 12px;border:1px solid var(--border-color);transition:border-color .15s}.back-link:hover{border-color:var(--accent)}.connection-dot{width:8px;height:8px}.connection-dot.connected{background:var(--accent)}.connection-dot.disconnected{background:var(--danger)}.battery-bar{background:var(--border-color);height:18px;overflow:hidden;margin-bottom:4px}.battery-bar-fill{height:100%;transition:width .5s}.panel-toggle{position:absolute;top:80px;right:10px;z-index:1000;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;font-size:.75rem;transition:border-color .15s,color .15s}.panel-toggle:hover{border-color:var(--accent);color:var(--accent)}.modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;z-index:900;background:#00000059;display:flex;align-items:center;justify-content:center;padding:24px}.modal-content{background:var(--bg-primary);border:1px solid var(--border-color);width:100%;max-width:780px;max-height:90%;overflow-y:auto;display:flex;flex-direction:column}.modal-content::-webkit-scrollbar{width:5px}.modal-content::-webkit-scrollbar-thumb{background:var(--border-color)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:14px 18px}.modal-close{background:none;border:1px solid var(--border-color);width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.2rem;color:var(--text-secondary);transition:border-color .15s,color .15s}.modal-close:hover{border-color:var(--danger);color:var(--danger)}.modal-body{display:grid;grid-template-columns:1fr 1fr;gap:0;padding:0}.modal-col{padding:12px 18px}.modal-col+.modal-col{border-left:1px solid var(--border-color)}.modal-section{margin-bottom:16px}.modal-section:last-child{margin-bottom:0}.modal-section-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);margin-bottom:6px}.modal-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px 12px}.modal-stat{display:flex;justify-content:space-between;font-size:.8rem;padding:2px 0}.modal-stat-label{color:var(--text-secondary)}.modal-stat-value{font-weight:700}@media(max-width:600px){.modal-body{grid-template-columns:1fr}.modal-col+.modal-col{border-left:none;border-top:1px solid var(--border-color)}.modal-content{max-width:100%}}.schedule-grid{display:flex;flex-direction:column;gap:1px}.schedule-row{display:flex;gap:1px;align-items:center}.schedule-day-label{width:30px;flex-shrink:0;font-size:.65rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase}.schedule-hour-label{flex:1;font-size:.6rem;color:var(--text-secondary);text-align:center;height:12px}.schedule-cell{flex:1;height:14px;min-width:0}.schedule-cell-now{outline:2px solid #fff;outline-offset:-1px;box-shadow:0 0 0 3px #00000080;z-index:1;position:relative}.status-badge{display:inline-block;padding:2px 8px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-inverse)}
