*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;overflow:hidden}body{font-family:system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased;background:var(--bg-base);color:var(--text-primary)}:root{--bg-base: #12121a;--bg-surface: #1a1a28;--bg-surface-alt: #1e1e2e;--bg-elevated: #252535;--bg-canvas: #16161e;--bg-hover: #333345;--bg-active-accent: #1a3a2a;--bg-input: #252535;--border: #2a2a3c;--border-strong: #333345;--border-input: #444455;--text-primary: #e0e0e0;--text-secondary: #999;--text-tertiary: #888;--text-muted: #777;--text-faint: #666;--accent: #66bb6a;--accent-bold: #4a8a44;--accent-hover: #3d7a38;--accent-surface: #1a3a2a;--error: #ef5350;--error-surface: #3a1a1a;--error-hover: #4a2020;--warning: #ffa726;--warning-surface: #3a2a1a;--info: #42a5f5;--info-surface: #1a2a3a;--shadow-sm: 0 1px 3px rgba(0,0,0,.3);--shadow-md: 0 2px 8px rgba(0,0,0,.3);--shadow-lg: 0 8px 32px rgba(0,0,0,.4);--card-bg: #1e1e2e;--card-border: #2a2a3c;--login-gradient: linear-gradient(145deg, #0d1a12 0%, #121a18 50%, #1a1a10 100%);--priority-high-bg: #3a1a1a;--priority-med-bg: #3a2a1a;--priority-low-bg: #1a3a2a;--eventlog-bg: #1e1e1e;--eventlog-header: #252526;--eventlog-border: #333;--eventlog-text: #d4d4d4;--eventlog-source: #9cdcfe;--canvas-3d-bg: #16161e}[data-theme=light]{--bg-base: #f5f5f5;--bg-surface: #fff;--bg-surface-alt: #fff;--bg-elevated: #f0f0f0;--bg-canvas: #e8e8e8;--bg-hover: #eee;--bg-active-accent: #e8f5e9;--bg-input: #fff;--border: #e0e0e0;--border-strong: #d0d0d0;--border-input: #d0d0d0;--text-primary: #333;--text-secondary: #666;--text-tertiary: #888;--text-muted: #999;--text-faint: #aaa;--accent: #2e7d32;--accent-bold: #4a7c3f;--accent-hover: #3d6b34;--accent-surface: #e8f5e9;--error: #dc2626;--error-surface: #fef2f2;--error-hover: #fee2e2;--warning: #ea580c;--warning-surface: #fff3e0;--info: #2563eb;--info-surface: #eff6ff;--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 2px 8px rgba(0,0,0,.06);--shadow-lg: 0 8px 32px rgba(0,0,0,.1);--card-bg: #fff;--card-border: #e8e8e8;--login-gradient: linear-gradient(145deg, #e8f5e9 0%, #f1f8e9 50%, #fff8e1 100%);--priority-high-bg: #fef2f2;--priority-med-bg: #fff3e0;--priority-low-bg: #f1f8e9;--eventlog-bg: #1e1e1e;--eventlog-header: #252526;--eventlog-border: #333;--eventlog-text: #d4d4d4;--eventlog-source: #9cdcfe;--canvas-3d-bg: #e8e8e8}.login-screen{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--login-gradient)}.login-card{background:var(--bg-surface-alt);border-radius:16px;box-shadow:var(--shadow-lg);padding:48px 40px;text-align:center;max-width:380px;width:100%}.login-icon{font-size:3rem;margin-bottom:8px}.login-title{font-size:1.5rem;font-weight:700;color:var(--accent);margin:0 0 4px}.login-subtitle{font-size:.85rem;color:var(--text-tertiary);margin:0 0 28px}.login-form{display:flex;flex-direction:column;gap:12px}.login-input{width:100%;padding:12px 16px;border:2px solid var(--border-strong);border-radius:10px;font-size:1rem;outline:none;transition:border-color .2s;box-sizing:border-box;background:var(--bg-elevated);color:var(--text-primary)}.login-input:focus{border-color:var(--accent)}.login-btn{padding:12px 24px;border:none;border-radius:10px;background:var(--accent-bold);color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s,transform .1s}.login-btn:hover:not(:disabled){background:var(--accent-hover)}.login-btn:active:not(:disabled){transform:scale(.98)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-error{color:var(--error);font-size:.85rem;margin:0}.login-spinner{width:32px;height:32px;border:3px solid #333345;border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin:12px auto}@keyframes spin{to{transform:rotate(360deg)}}.garden-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;color:var(--text-tertiary);font-size:.95rem}.app{display:flex;flex-direction:column;height:100vh;background:var(--bg-base)}.app-content{flex:1;min-height:0;display:flex;flex-direction:column}.navbar{display:flex;align-items:center;flex-wrap:wrap;gap:8px;row-gap:6px;padding:8px max(12px,env(safe-area-inset-right)) 8px max(12px,env(safe-area-inset-left));padding-top:max(8px,env(safe-area-inset-top));min-height:48px;background:var(--bg-surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);flex-shrink:0;position:relative;z-index:20}@media (min-width: 800px){.navbar{flex-wrap:nowrap;height:48px;padding:0 16px;padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right));padding-top:max(0px,env(safe-area-inset-top))}}@media (max-width: 799px){.navbar-links{order:10;flex-basis:100%;width:100%;justify-content:stretch}.navbar-links .nav-link{flex:1;text-align:center;padding:8px 12px}.navbar-spacer{display:none}.navbar-garden-name{max-width:min(120px,35vw);min-width:0}.navbar-brand{min-width:0;margin-right:8px}.navbar-btn-signout{padding:5px 8px;font-size:.75rem}}.navbar-brand{font-size:1.05rem;font-weight:700;color:var(--accent);margin-right:24px;white-space:nowrap}.navbar-links{display:flex;gap:2px;background:var(--bg-elevated);border-radius:8px;padding:3px;flex-shrink:0}.nav-link{padding:5px 16px;border-radius:6px;font-size:.85rem;font-weight:500;color:var(--text-tertiary);text-decoration:none;transition:all .15s}.nav-link:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-link.active{background:var(--bg-surface-alt);color:var(--accent);box-shadow:var(--shadow-sm);font-weight:600}.navbar-spacer{flex:1;min-width:8px}.navbar-icon-btn{padding:5px 10px;border:1px solid var(--border);border-radius:6px;background:transparent;color:var(--text-tertiary);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s;flex-shrink:0}.navbar-icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.navbar-icon-btn.active{background:var(--bg-active-accent);border-color:var(--accent-bold);color:var(--accent)}.navbar-save{font-size:.78rem;font-weight:500;padding:3px 10px;border-radius:6px}.navbar-save.saving{background:var(--warning-surface);color:var(--warning)}.navbar-save.error{background:var(--error-surface);color:var(--error)}.navbar-btn{padding:5px 12px;border:none;border-radius:6px;background:transparent;color:var(--text-tertiary);font-size:.82rem;cursor:pointer;transition:all .15s}.navbar-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.navbar-theme-btn{padding:4px 8px;border:1px solid var(--border);border-radius:6px;background:transparent;cursor:pointer;font-size:.9rem;line-height:1;transition:all .15s}.navbar-theme-btn:hover{background:var(--bg-hover)}.plan-page{display:flex;flex-direction:column;flex:1;min-height:0}.toolbar{display:flex;align-items:center;justify-content:flex-start;gap:6px;padding:4px 12px;background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0}.toolbar-btn{padding:4px 10px;border:none;border-radius:6px;background:transparent;font-size:.8rem;cursor:pointer;color:var(--text-secondary);transition:all .15s;white-space:nowrap}.toolbar-btn:hover{background:var(--bg-hover)}.toolbar-btn.active{background:var(--bg-elevated);box-shadow:var(--shadow-sm);font-weight:500;color:var(--text-primary)}.toolbar-btn:disabled{opacity:.4;cursor:not-allowed}.view-toggle{display:flex;background:var(--bg-elevated);border-radius:8px;padding:2px;margin-right:8px}.view-btn{padding:4px 14px;border:none;border-radius:6px;background:transparent;font-size:.82rem;font-weight:600;cursor:pointer;color:var(--text-tertiary);transition:all .15s}.view-btn.active{background:var(--accent-bold);color:#fff;box-shadow:var(--shadow-sm)}.view-btn:not(.active):hover{background:var(--bg-hover)}.toolbar-delete{padding:4px 10px;border:none;border-radius:6px;background:var(--error-surface);color:var(--error);font-size:.82rem;cursor:pointer;transition:all .15s}.toolbar-delete:hover{background:var(--error-hover)}.toolbar-reset{padding:4px 10px;border:none;border-radius:6px;background:transparent;color:var(--text-tertiary);font-size:.82rem;cursor:pointer;transition:all .15s}.toolbar-reset:hover{background:var(--bg-hover)}.time-slider{display:flex;align-items:center;gap:6px;background:var(--bg-elevated);border-radius:8px;padding:4px 10px}.time-slider-label{font-size:.8rem;font-weight:500;white-space:nowrap;min-width:52px;text-align:center}.time-slider-input{width:90px;height:4px;cursor:pointer;accent-color:var(--warning)}.app-body{display:flex;flex:1;min-height:0}.tool-panel{width:200px;flex-shrink:0;background:var(--bg-surface);border-right:1px solid var(--border);overflow-y:auto;display:flex;flex-direction:column}.tool-panel-list{display:flex;flex-direction:column;padding:6px;gap:1px}.tool-panel-btn{display:flex;align-items:center;gap:8px;width:100%;padding:7px 10px;border:none;border-radius:6px;background:transparent;font-size:.82rem;cursor:pointer;color:var(--text-secondary);transition:all .15s;text-align:left}.tool-panel-btn:hover{background:var(--bg-elevated)}.tool-panel-btn.active{background:var(--bg-active-accent);color:var(--accent);font-weight:500}.tool-panel-btn:disabled{opacity:.35;cursor:not-allowed}.tool-panel-icon{font-size:1rem;width:22px;text-align:center;flex-shrink:0}.tool-panel-label{white-space:nowrap}.tool-panel-kbd{margin-left:auto;font-family:system-ui,sans-serif;font-size:.6rem;font-weight:600;min-width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;border-radius:3px;background:var(--bg-elevated);color:var(--text-muted, #999);border:1px solid var(--card-border, #ddd);flex-shrink:0}.tool-panel-group{font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted, #999);padding:8px 10px 2px;margin-top:2px}.tool-panel-item:first-child .tool-panel-group{padding-top:2px;margin-top:0}.tool-submenu{display:flex;flex-direction:column;padding:2px 0 4px 14px;gap:1px}.tool-submenu-btn{display:flex;align-items:center;gap:6px;width:100%;padding:5px 10px;border:none;border-radius:5px;background:transparent;font-size:.78rem;cursor:pointer;color:var(--text-tertiary);transition:all .12s;text-align:left}.tool-submenu-btn:hover{background:var(--bg-elevated)}.tool-submenu-btn.active{background:var(--bg-active-accent);color:var(--accent);font-weight:500}.tool-submenu-hint{margin-left:auto;font-size:.75em;opacity:.5}.tool-submenu-plant{padding:4px 0}.tool-submenu-plant .plant-picker{padding:6px 4px 6px 8px}.tool-submenu-plant .species-list{max-height:calc(100vh - 500px);min-height:120px}.canvas-area{flex:1;position:relative;overflow:hidden;background:var(--bg-canvas)}.canvas-2d-wrapper{width:100%;height:100%;position:relative}.canvas-2d{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--bg-canvas)}.cursor-grab{cursor:grab}.cursor-grab:active{cursor:grabbing}.cursor-default{cursor:default}.cursor-crosshair{cursor:crosshair}.canvas-status{position:absolute;bottom:12px;right:12px;background:var(--bg-elevated);border-radius:6px;padding:4px 10px;font-size:.75rem;color:var(--text-tertiary);pointer-events:none}.canvas-3d-wrapper{width:100%;height:100%;position:relative}.camera-presets{position:absolute;top:12px;right:12px;display:flex;gap:4px;z-index:10}.camera-preset-btn{padding:5px 12px;border:1px solid rgba(255,255,255,.2);border-radius:6px;background:#1e1e28b3;color:#ccc;font-size:.72rem;font-weight:600;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:background .15s,color .15s}.camera-preset-btn:hover{background:#323241d9;color:#fff}.camera-preset-btn.active{background:var(--accent, #4caf50);color:#fff;border-color:transparent}.time-slider-bar{position:absolute;bottom:12px;left:12px;right:12px;display:flex;align-items:center;gap:8px;padding:6px 12px;background:#1e1e28b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.15);border-radius:8px;z-index:10}.time-slider-icon{font-size:1.1rem;flex-shrink:0;line-height:1}.time-slider-range{flex:1;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#fff3;border-radius:2px;outline:none;cursor:pointer}.time-slider-range::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:#fff;border:2px solid var(--accent, #4caf50);cursor:pointer;box-shadow:0 1px 4px #0000004d}.time-slider-range::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:#fff;border:2px solid var(--accent, #4caf50);cursor:pointer;box-shadow:0 1px 4px #0000004d}.time-slider-label{font-size:.78rem;font-weight:600;color:#ddd;font-variant-numeric:tabular-nums;min-width:40px;text-align:right;flex-shrink:0}.loading-3d{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--text-tertiary);font-size:1.1rem}.sidebar{width:280px;flex-shrink:0;background:var(--bg-surface);border-left:1px solid var(--border);overflow-y:auto}.plan-app-body{position:relative}.plan-sidebar-backdrop{display:none}.plan-sidebar-host{flex-shrink:0;overflow:hidden;width:0;transition:width .2s ease;border-left:none;background:var(--bg-surface)}.plan-sidebar-host.plan-sidebar-open{width:280px;border-left:1px solid var(--border)}.plan-sidebar-host .sidebar{width:280px;height:100%;min-height:0;border-left:none}@media (max-width: 900px){.plan-sidebar-backdrop{display:block;position:absolute;top:0;right:0;bottom:0;left:0;z-index:50;margin:0;padding:0;border:none;background:#00000061;cursor:pointer}.plan-sidebar-host{position:absolute;top:0;right:0;bottom:0;z-index:60;width:0!important;max-width:none;border:none;background:transparent;transition:width .22s ease}.plan-sidebar-host.plan-sidebar-open{width:min(300px,88vw)!important;border-left:1px solid var(--border);background:var(--bg-surface);box-shadow:-10px 0 30px #00000038}}.panel{padding:16px;display:flex;flex-direction:column;gap:12px}.panel-title{font-size:.95rem;font-weight:600;color:var(--text-primary);margin:0}.panel-hint{font-size:.78rem;color:var(--text-muted);margin:0}.panel-input{display:block;width:100%;border:1px solid var(--border-input);border-radius:6px;padding:6px 8px;font-size:.85rem;margin-top:4px;outline:none;transition:border-color .15s;background:var(--bg-input);color:var(--text-primary)}.panel-input:focus{border-color:var(--accent)}select.panel-input{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto;background:var(--bg-elevated);color:var(--text-primary)}select.panel-input option{background:var(--bg-elevated);color:var(--text-primary)}.field{display:flex;flex-direction:column}.field-label{font-size:.7rem;text-transform:uppercase;color:var(--text-tertiary);font-weight:500;letter-spacing:.03em}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.panel-section{padding-top:12px;border-top:1px solid var(--border)}.panel-counts{font-size:.85rem;color:var(--text-secondary)}.panel-counts p{margin:2px 0}.panel-howto{font-size:.78rem;color:var(--text-muted)}.panel-howto p{margin:2px 0}.panel-save-btn{padding:6px 14px;border:none;border-radius:6px;background:var(--accent-bold);color:#fff;font-size:.78rem;font-weight:600;cursor:pointer;margin-top:4px;transition:background .15s}.panel-save-btn:hover{background:var(--accent-hover)}.panel-danger-btn{width:100%;padding:6px 14px;border:1px solid var(--error);border-radius:6px;background:var(--error-surface);color:var(--error);font-size:.78rem;font-weight:500;cursor:pointer;transition:background .15s}.panel-danger-btn:hover{background:var(--error-hover)}.panel-integration-row{display:flex;align-items:center;justify-content:space-between;font-size:.82rem;color:var(--text-secondary);padding:4px 0}.panel-badge{font-size:.68rem;font-weight:600;padding:2px 8px;border-radius:8px;background:var(--bg-elevated);color:var(--text-muted)}.panel-badge-ok{background:var(--accent-surface);color:var(--accent)}.plant-list{list-style:none;padding:0;margin:4px 0 0;display:flex;flex-direction:column;gap:4px}.plant-list-item{font-size:.85rem;display:flex;align-items:center;gap:6px}.plant-date{font-size:.75rem;color:#666}.plant-details{font-size:.85rem;color:var(--text-secondary)}.plant-details p{margin:4px 0}.plant-bed-ref{font-size:.75rem;color:#666}.plant-picker{padding:16px;display:flex;flex-direction:column;gap:12px}.species-list{display:flex;flex-direction:column;gap:4px;max-height:60vh;overflow-y:auto}.species-btn{width:100%;text-align:left;padding:8px;border:none;border-radius:6px;background:transparent;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:.85rem;color:#ccc;transition:all .15s}.species-btn:hover{background:var(--bg-elevated)}.species-btn.selected{background:var(--bg-active-accent);outline:2px solid #66bb6a}.species-icon{font-size:1.2rem}.species-info{display:flex;flex-direction:column}.species-name{font-weight:500}.species-meta{font-size:.72rem;color:var(--text-muted)}.navbar-garden-name{font-size:.82rem;color:var(--text-secondary);max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-right:12px}.navbar-settings-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;color:var(--text-tertiary);transition:all .15s;margin-right:4px}.navbar-settings-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.navbar-settings-btn.active{background:var(--bg-active-accent);color:var(--accent)}.placeholder-text{font-size:.85rem;color:var(--text-muted);line-height:1.5}.placeholder-graphic{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:24px 16px;text-align:center;color:#666;font-size:.85rem}.placeholder-graphic svg{opacity:.5}.placeholder-sub{font-size:.75rem;color:#555}.monitor-page{flex:1;padding:24px 32px;overflow-y:auto}.monitor-header h1{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 4px}.monitor-subtitle{font-size:.9rem;color:var(--text-tertiary);margin:0 0 20px}.monitor-subtitle strong{color:var(--text-secondary)}.monitor-summary{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:20px}.summary-card{display:flex;align-items:center;gap:10px;background:var(--card-bg);border:1px solid var(--border);border-left:3px solid #2a2a3c;border-radius:10px;padding:12px 16px;min-width:130px;flex:1}.summary-icon{font-size:1.4rem}.summary-data{display:flex;flex-direction:column}.summary-value{font-size:1.15rem;font-weight:700;color:var(--text-primary)}.summary-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.monitor-dashboard{display:grid;grid-template-columns:1fr 1.2fr 1fr;gap:16px;margin-bottom:16px}.monitor-col{display:flex;flex-direction:column;gap:16px}.monitor-card{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:0;display:flex;flex-direction:column}.monitor-card-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px 10px;border-bottom:1px solid var(--border)}.monitor-card-header h3{font-size:.9rem;font-weight:600;color:var(--text-primary);margin:0}.monitor-card-badge{background:var(--bg-active-accent);color:var(--accent);font-size:.72rem;font-weight:600;padding:2px 8px;border-radius:10px}.monitor-card-actions{display:flex;gap:4px}.monitor-chip{padding:3px 10px;border:1px solid var(--border-input);border-radius:12px;background:transparent;font-size:.72rem;color:var(--text-tertiary);cursor:pointer}.monitor-chip:disabled{opacity:.5;cursor:not-allowed}.monitor-card-body{padding:14px 18px;flex:1}.monitor-card-wide{grid-column:1 / -1}.monitor-minimap-placeholder{min-height:220px;display:flex;align-items:center;justify-content:center}.monitor-task-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.monitor-task-item{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:.82rem;border-bottom:1px solid var(--border)}.monitor-task-item:last-child{border-bottom:none}.monitor-task-priority{width:6px;height:6px;border-radius:50%;flex-shrink:0}.priority-high{background:#ef5350}.priority-medium{background:#ffa726}.priority-low{background:#66bb6a}.monitor-task-title{flex:1;color:var(--text-primary)}.monitor-task-category{font-size:.72rem;color:var(--text-tertiary);background:var(--bg-elevated);padding:2px 6px;border-radius:4px}.monitor-task-more{font-size:.78rem;color:var(--text-muted);text-align:center;padding:4px}.monitor-forecast-row{display:flex;gap:8px;justify-content:space-between}.monitor-forecast-day{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;padding:8px 4px;border-radius:8px;background:var(--bg-elevated)}.forecast-day-name{font-size:.72rem;font-weight:600;color:var(--text-secondary)}.forecast-day-icon{font-size:1.2rem}.forecast-day-temps{font-size:.78rem;color:var(--text-secondary)}.forecast-day-temps span{color:#666;margin-left:4px}.forecast-day-rain{font-size:.68rem;color:#42a5f5}.monitor-alert{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:8px;margin-bottom:8px;font-size:.82rem}.alert-warning{background:var(--warning-surface)}.alert-info{background:#1a2a3a}.alert-icon{font-size:1.1rem;flex-shrink:0;margin-top:1px}.alert-content{display:flex;flex-direction:column;gap:2px}.alert-content strong{font-size:.82rem;color:var(--text-primary)}.alert-content span{font-size:.75rem;color:var(--text-tertiary)}.monitor-sensor-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.monitor-sensor-item{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:.82rem;border-bottom:1px solid var(--border)}.monitor-sensor-item:last-child{border-bottom:none}.monitor-sensor-status{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-online{background:#66bb6a}.status-offline{background:#555}.status-low-battery{background:#ffa726}.monitor-sensor-name{flex:1;color:var(--text-primary)}.monitor-sensor-value{font-weight:600;color:var(--text-secondary);font-size:.82rem}.monitor-trends{margin-bottom:16px}.monitor-trends-placeholder{min-height:120px;display:flex;align-items:center;justify-content:center}@media (max-width: 1024px){.monitor-dashboard{grid-template-columns:1fr 1fr}.monitor-col-left{grid-column:1 / -1}}@media (max-width: 768px){.monitor-page{padding:16px}.monitor-dashboard{grid-template-columns:1fr}.summary-card{min-width:100px}}.guide-page{flex:1;overflow-y:auto}.guide-layout{display:grid;grid-template-columns:1fr 360px;gap:0;min-height:100%}.guide-main{padding:24px 32px;overflow-y:auto;display:flex;flex-direction:column;gap:20px}.guide-sidebar{border-left:1px solid var(--border);background:var(--bg-surface);padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:16px}.guide-header h1{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 4px}.guide-subtitle{font-size:.9rem;color:var(--text-tertiary);margin:0}.guide-subtitle strong{color:var(--text-secondary)}.guide-card{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;overflow:hidden}.guide-card-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px 10px;border-bottom:1px solid var(--border)}.guide-card-header h3{font-size:.9rem;font-weight:600;color:var(--text-primary);margin:0}.guide-card-badge{font-size:.68rem;font-weight:700;padding:2px 8px;border-radius:10px;background:linear-gradient(135deg,#1a3a2a,#2a4a3a);color:var(--accent)}.guide-card-count{font-size:.75rem;color:var(--text-tertiary)}.guide-assistant-body{display:flex;flex-direction:column}.guide-assistant-messages{padding:16px 18px}.guide-assistant-message{display:flex;gap:12px}.guide-message-avatar{width:36px;height:36px;border-radius:50%;background:var(--bg-active-accent);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}.guide-message-content{font-size:.85rem;color:var(--text-secondary);line-height:1.55}.guide-message-content p{margin:0 0 8px}.guide-message-content p:last-child{margin:0}.guide-message-hint{color:#666;font-size:.8rem}.guide-suggestions{display:flex;flex-wrap:wrap;gap:8px;padding:0 18px 12px}.guide-suggestion-btn{padding:6px 14px;border:1px solid var(--border-input);border-radius:16px;background:var(--bg-elevated);font-size:.78rem;color:var(--text-secondary);cursor:pointer;transition:all .15s}.guide-suggestion-btn:hover:not(:disabled){background:var(--bg-active-accent);border-color:#2a4a3a}.guide-suggestion-btn:disabled{opacity:.6;cursor:not-allowed}.guide-chat-input{display:flex;gap:8px;padding:12px 18px;border-top:1px solid var(--border);background:var(--bg-surface)}.guide-input{flex:1;padding:8px 14px;border:1px solid var(--border-input);border-radius:8px;font-size:.85rem;outline:none;transition:border-color .15s;background:var(--bg-elevated);color:var(--text-primary)}.guide-input:focus{border-color:var(--accent)}.guide-send-btn{padding:8px 16px;border:none;border-radius:8px;background:var(--accent-bold);color:#fff;font-size:.82rem;font-weight:600;cursor:pointer;transition:background .15s}.guide-send-btn:hover:not(:disabled){background:var(--accent-hover)}.guide-send-btn:disabled{opacity:.5;cursor:not-allowed}.guide-rec-list{padding:8px 18px 14px;display:flex;flex-direction:column;gap:4px}.guide-rec-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}.guide-rec-item:last-child{border-bottom:none}.guide-rec-icon{font-size:1.2rem;flex-shrink:0}.guide-rec-content{flex:1;display:flex;flex-direction:column;gap:2px}.guide-rec-content strong{font-size:.82rem;color:var(--text-primary)}.guide-rec-content span{font-size:.75rem;color:var(--text-muted)}.guide-rec-badge{font-size:.65rem;color:#666;background:var(--bg-elevated);padding:2px 6px;border-radius:4px;white-space:nowrap}.guide-category-filters{display:flex;flex-wrap:wrap;gap:4px;padding:10px 16px}.guide-cat-btn{padding:4px 10px;border:1px solid var(--border-strong);border-radius:12px;background:transparent;font-size:.72rem;color:var(--text-tertiary);cursor:pointer;transition:all .15s}.guide-cat-btn:hover{background:var(--bg-elevated)}.guide-cat-btn.active{background:var(--bg-active-accent);border-color:#2a4a3a;color:var(--accent);font-weight:600}.guide-task-feed{padding:0 16px 16px}.guide-task-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}.guide-task-item{display:flex;align-items:flex-start;gap:8px;padding:8px 0;border-bottom:1px solid var(--border)}.guide-task-item:last-child{border-bottom:none}.guide-task-item.done{opacity:.6}.guide-task-priority{width:6px;height:6px;border-radius:50%;flex-shrink:0;margin-top:6px}.guide-task-check{color:var(--accent);font-weight:700;font-size:.85rem}.guide-task-info{flex:1;display:flex;flex-direction:column;gap:2px}.guide-task-title{font-size:.82rem;color:var(--text-primary)}.guide-task-desc{font-size:.75rem;color:var(--text-muted)}.guide-task-meta{font-size:.7rem;color:#666}.guide-task-status{font-size:.68rem;padding:2px 6px;border-radius:4px;white-space:nowrap}.guide-task-status.status-pending{background:var(--warning-surface);color:var(--warning)}.guide-task-status.status-in-progress{background:#1a2a3a;color:#42a5f5}.guide-completed-section{margin-top:12px}.guide-completed-toggle{font-size:.78rem;color:var(--text-muted);cursor:pointer;padding:4px 0}.guide-completed-toggle:hover{color:var(--text-secondary)}.guide-task-list-done{opacity:.7}.guide-planner-body{padding:16px}@media (max-width: 900px){.guide-layout{grid-template-columns:1fr}.guide-sidebar{border-left:none;border-top:1px solid var(--border)}}.settings-page{flex:1;padding:24px 32px;overflow-y:auto;max-width:800px}.settings-header h1{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 4px}.settings-subtitle{font-size:.9rem;color:var(--text-tertiary);margin:0 0 24px}.settings-grid{display:flex;flex-direction:column;gap:24px}.settings-section{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:20px 24px}.settings-section h2{font-size:1.05rem;font-weight:600;color:var(--text-primary);margin:0 0 16px;padding-bottom:10px;border-bottom:1px solid var(--border)}.settings-field{display:flex;flex-direction:column;margin-bottom:12px}.settings-label{font-size:.72rem;text-transform:uppercase;color:var(--text-tertiary);font-weight:500;letter-spacing:.03em;margin-bottom:4px}.settings-input{padding:8px 12px;border:1px solid var(--border-input);border-radius:8px;font-size:.88rem;outline:none;transition:border-color .15s;background:var(--bg-elevated);color:var(--text-primary)}.settings-input:focus{border-color:var(--accent)}select.settings-input{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto;background:var(--bg-elevated);color:var(--text-primary)}select.settings-input option{background:var(--bg-elevated);color:var(--text-primary)}.settings-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.settings-hint{font-size:.8rem;color:var(--text-muted);margin:0 0 12px;line-height:1.4}.settings-save-btn{padding:8px 20px;border:none;border-radius:8px;background:var(--accent-bold);color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s;margin-top:4px}.settings-save-btn:hover{background:var(--accent-hover)}.settings-saved{font-size:.8rem;color:var(--accent);margin:8px 0 0}.settings-integration{padding:12px 0;border-bottom:1px solid var(--border)}.settings-integration:last-child{border-bottom:none}.settings-integration-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.settings-integration-name{font-size:.88rem;font-weight:500;color:var(--text-primary)}.settings-integration-badge{font-size:.7rem;font-weight:600;padding:2px 10px;border-radius:10px}.settings-integration-badge.ready{background:var(--bg-active-accent);color:var(--accent)}.settings-integration-badge.inactive{background:var(--bg-elevated);color:var(--text-muted)}.settings-stats{display:flex;gap:16px;flex-wrap:wrap}.settings-stat{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:80px;padding:12px;background:var(--bg-elevated);border-radius:8px;flex:1}.settings-stat-value{font-size:1.3rem;font-weight:700;color:var(--text-primary)}.settings-stat-label{font-size:.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.zone-type-picker{display:flex;gap:2px;background:var(--bg-elevated);border-radius:8px;padding:2px;margin-left:4px}.zone-type-btn{font-size:.78rem!important;padding:3px 8px!important}.zone-toggle{font-size:.78rem!important;border:1px solid var(--border-input)!important;border-radius:6px!important;margin-right:8px;transition:all .15s}.zone-toggle-on{background:var(--bg-active-accent)!important;border-color:var(--accent)!important;color:var(--accent)!important}.zone-list{list-style:none;padding:0;margin:4px 0 0;display:flex;flex-direction:column;gap:4px}.zone-list-item{font-size:.85rem;display:flex;align-items:center;gap:6px}.zone-list-type{font-size:.72rem;color:var(--text-muted);margin-left:auto;text-transform:capitalize}.weather-card{padding:12px 0}.weather-card-setup{color:var(--text-muted)}.weather-setup-msg{font-size:.82rem;margin:0}.weather-loading{font-size:.82rem;color:#666;margin:0}.weather-error{font-size:.82rem;color:var(--error);margin:0}.weather-current-main{display:flex;align-items:center;gap:12px;margin-bottom:4px}.weather-big-icon{font-size:2.2rem}.weather-big-temp{font-size:2rem;font-weight:700;color:var(--text-primary)}.weather-desc{font-size:.85rem;color:var(--text-tertiary);margin:0 0 8px;text-transform:capitalize}.weather-details-row{display:flex;gap:16px;font-size:.8rem;color:var(--text-secondary)}.forecast-row{display:flex;gap:8px;overflow-x:auto}.forecast-day-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 12px;border-radius:10px;background:var(--bg-elevated);border:1px solid var(--border-strong);min-width:72px;flex:1}.forecast-date{font-size:.72rem;font-weight:600;color:var(--text-secondary)}.forecast-icon{font-size:1.3rem}.forecast-temps{font-size:.78rem;color:var(--text-secondary)}.forecast-temps strong{color:var(--text-primary)}.forecast-rain{font-size:.68rem;color:#42a5f5}.weather-alerts{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.weather-alert{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:10px;font-size:.82rem}.weather-alert-warn{background:var(--warning-surface);color:var(--warning)}.weather-alert-info{background:#1a2a3a;color:#42a5f5}.weather-alert-icon{font-size:1.1rem;flex-shrink:0}.task-list{display:flex;flex-direction:column;gap:6px}.task-item{display:flex;align-items:flex-start;gap:10px;padding:8px 10px;border-radius:8px;background:var(--bg-elevated);border-left:3px solid transparent}.task-priority-high{border-left-color:var(--error)}.task-priority-medium{border-left-color:var(--warning)}.task-priority-low{border-left-color:var(--accent)}.task-icon{font-size:1rem;flex-shrink:0;margin-top:2px}.task-content{flex:1;display:flex;flex-direction:column;gap:2px}.task-title{font-size:.82rem;font-weight:500;color:var(--text-primary)}.task-desc{font-size:.72rem;color:var(--text-muted)}.task-actions{display:flex;gap:4px;flex-shrink:0}.task-done-btn,.task-skip-btn{width:26px;height:26px;border:none;border-radius:6px;font-size:.78rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.task-done-btn{background:var(--bg-active-accent);color:var(--accent)}.task-done-btn:hover{background:#2a4a3a}.task-skip-btn{background:var(--bg-elevated);color:var(--text-tertiary)}.task-skip-btn:hover{background:var(--bg-hover)}.alert-section{display:flex;flex-direction:column;gap:6px}.alert-heading{font-size:.82rem;font-weight:600;color:var(--warning);margin-bottom:4px}.alert-item{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--text-secondary);padding:4px 0}.monitor-stats p{margin:4px 0;font-size:.85rem;color:var(--text-secondary)}.sensor-charts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;margin-top:8px}.sensor-chart-item{padding:8px;background:var(--bg-elevated);border-radius:8px}.sparkline-container{display:flex;flex-direction:column;gap:4px}.sparkline-label{font-size:.72rem;font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.03em}.sparkline-svg{display:block}.sparkline-values{display:flex;justify-content:space-between;align-items:baseline}.sparkline-current{font-size:.85rem;font-weight:600;color:var(--text-primary)}.sparkline-range{font-size:.68rem;color:#666}.sparkline-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px}.sparkline-no-data{font-size:.72rem;color:#555}.sensor-status-row{display:flex;align-items:center;gap:8px}.sensor-status-dot{width:8px;height:8px;border-radius:50%}.sensor-status-text{font-size:.78rem;color:var(--text-secondary);text-transform:capitalize}.sensor-type-badge{font-size:.68rem;background:var(--bg-elevated);color:var(--text-tertiary);padding:2px 8px;border-radius:8px;margin-left:auto}.sensor-current-reading{display:flex;align-items:baseline;gap:8px;padding:8px 0}.sensor-reading-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.sensor-reading-time{font-size:.72rem;color:#666}.sensor-range-tabs{display:flex;gap:2px;background:var(--bg-elevated);border-radius:8px;padding:2px}.sensor-range-btn{flex:1;padding:4px 8px;border:none;border-radius:6px;background:transparent;font-size:.72rem;font-weight:500;color:var(--text-tertiary);cursor:pointer;transition:all .15s}.sensor-range-btn.active{background:var(--bg-surface-alt);color:var(--text-primary);box-shadow:var(--shadow-sm)}.guide-page{flex:1;padding:24px 32px;overflow-y:auto}.guide-stats{display:flex;gap:16px;margin-bottom:20px}.guide-stat{display:flex;flex-direction:column;align-items:center;gap:2px;padding:12px 20px;background:var(--card-bg);border:1px solid var(--border);border-radius:10px;min-width:80px}.guide-stat-value{font-size:1.3rem;font-weight:700;color:var(--text-primary)}.guide-stat-label{font-size:.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.guide-stat-warn .guide-stat-value{color:var(--warning)}.guide-filters{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.guide-status-tabs{display:flex;gap:2px;background:var(--bg-elevated);border-radius:8px;padding:3px;width:fit-content}.guide-tab{padding:5px 16px;border:none;border-radius:6px;background:transparent;font-size:.82rem;font-weight:500;color:var(--text-tertiary);cursor:pointer;transition:all .15s}.guide-tab.active{background:var(--bg-surface-alt);color:var(--text-primary);box-shadow:var(--shadow-sm)}.guide-category-chips{display:flex;gap:6px;flex-wrap:wrap}.guide-chip{display:flex;align-items:center;gap:4px;padding:4px 12px;border:1px solid var(--border-strong);border-radius:16px;background:transparent;font-size:.78rem;color:var(--text-tertiary);cursor:pointer;transition:all .15s}.guide-chip:hover{background:var(--bg-elevated)}.guide-chip.active{background:var(--bg-active-accent);border-color:#2a4a3a;color:var(--accent);font-weight:600}.guide-task-feed{display:flex;flex-direction:column;gap:10px}.guide-task-card{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;padding:14px 16px;border-left:4px solid transparent;transition:all .15s}.guide-task-card:hover{box-shadow:0 2px 8px #0003}.guide-task-priority-high{border-left-color:var(--error)}.guide-task-priority-medium{border-left-color:var(--warning)}.guide-task-priority-low{border-left-color:var(--accent)}.guide-task-done{opacity:.6}.guide-task-skipped{opacity:.5}.guide-task-header{display:flex;align-items:flex-start;gap:10px}.guide-task-icon{font-size:1.1rem;flex-shrink:0;margin-top:1px}.guide-task-meta{flex:1;display:flex;flex-direction:column;gap:4px}.guide-task-title{font-size:.88rem;font-weight:500;color:var(--text-primary)}.guide-task-tags{display:flex;gap:6px;align-items:center}.priority-badge{font-size:.65rem;font-weight:600;padding:1px 8px;border-radius:8px;text-transform:uppercase;letter-spacing:.03em}.priority-high{background:var(--error-surface);color:var(--error)}.priority-medium{background:var(--warning-surface);color:var(--warning)}.priority-low{background:#1a3a1a;color:var(--accent)}.due-badge{font-size:.68rem;color:var(--text-muted);background:var(--bg-elevated);padding:1px 8px;border-radius:8px}.guide-task-desc{font-size:.78rem;color:var(--text-tertiary);margin:6px 0 0;line-height:1.4}.guide-task-completed{font-size:.72rem;color:var(--accent);margin:6px 0 0}.guide-task-actions{display:flex;gap:6px;margin-top:10px}.guide-btn{padding:5px 14px;border:none;border-radius:6px;font-size:.78rem;font-weight:500;cursor:pointer;transition:all .15s}.guide-btn-done{background:var(--bg-active-accent);color:var(--accent)}.guide-btn-done:hover{background:#2a4a3a}.guide-btn-skip{background:var(--bg-elevated);color:var(--text-tertiary)}.guide-btn-skip:hover{background:var(--bg-hover)}.guide-btn-remove{background:var(--error-surface);color:var(--error)}.guide-btn-remove:hover{background:var(--error-hover)}.guide-empty{padding:40px 20px;text-align:center}.guide-empty p{font-size:.88rem;color:var(--text-muted);margin:0 0 8px}.guide-empty-hint{font-size:.8rem;color:#555}.guide-card-wide{grid-column:1 / -1;margin-bottom:16px}.guide-card h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 12px;padding:16px 18px 0}.eventlog-panel{height:180px;background:#1e1e1e;border-top:2px solid #333;display:flex;flex-direction:column;flex-shrink:0;font-family:SF Mono,Fira Code,Consolas,monospace}.eventlog-header{display:flex;align-items:center;gap:12px;padding:6px 12px;background:#252526;border-bottom:1px solid #333;flex-shrink:0}.eventlog-title{font-size:.78rem;font-weight:600;color:#ccc;margin:0;white-space:nowrap}.eventlog-filters{display:flex;gap:2px}.eventlog-filter-btn{padding:2px 8px;border:none;border-radius:4px;background:transparent;color:var(--text-tertiary);font-size:.68rem;font-family:inherit;cursor:pointer;transition:all .1s}.eventlog-filter-btn:hover{background:#333;color:#ccc}.eventlog-filter-btn.active{background:#3c3c3c;color:#fff}.eventlog-actions{margin-left:auto;display:flex;gap:6px}.eventlog-clear-btn{padding:2px 10px;border:1px solid #444;border-radius:4px;background:transparent;color:var(--text-secondary);font-size:.68rem;font-family:inherit;cursor:pointer}.eventlog-clear-btn:hover{background:#333;color:#ccc}.eventlog-close-btn{padding:2px 10px;border:1px solid #555;border-radius:4px;background:transparent;color:var(--text-secondary);font-size:.68rem;font-family:inherit;cursor:pointer}.eventlog-close-btn:hover{background:#333;color:#ccc}.eventlog-body{flex:1;overflow-y:auto;padding:4px 0}.eventlog-empty{padding:20px;text-align:center;color:#666;font-size:.78rem}.eventlog-entry{display:flex;flex-wrap:wrap;align-items:baseline;gap:8px;padding:3px 12px;border-left:3px solid transparent;font-size:.75rem;line-height:1.5}.eventlog-entry:hover{background:#ffffff08}.eventlog-time{color:#666;font-size:.68rem;min-width:65px;flex-shrink:0}.eventlog-level{font-size:.62rem;font-weight:700;padding:0 5px;border-radius:3px;flex-shrink:0}.eventlog-source{color:#9cdcfe;font-size:.72rem;flex-shrink:0}.eventlog-source:after{content:":"}.eventlog-msg{color:#d4d4d4;word-break:break-word}.eventlog-detail{width:100%;margin:2px 0 4px 76px;padding:4px 8px;background:#ffffff0a;border-radius:4px;color:var(--text-secondary);font-size:.68rem;white-space:pre-wrap;word-break:break-all}.dashboard-page{flex:1;padding:20px 24px;overflow-y:auto;background:var(--bg-base)}.dash-hero{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;min-height:340px}.dash-hero-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;overflow:hidden;display:flex;flex-direction:column}.dash-hero-label{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}.dash-hero-label h2{font-size:.95rem;font-weight:600;color:var(--text-primary);margin:0}.dash-hero-link{font-size:.78rem;color:var(--accent);text-decoration:none;font-weight:500}.dash-hero-link:hover{text-decoration:underline}.dash-hero-canvas{flex:1;min-height:280px;position:relative;overflow:hidden}.dash-summary{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:16px}.dash-summary-card{display:flex;align-items:center;gap:10px;background:var(--card-bg);border:1px solid var(--card-border);border-radius:10px;padding:12px 16px;min-width:140px;flex:1}.dash-summary-icon{font-size:1.4rem}.dash-summary-data{display:flex;flex-direction:column}.dash-summary-value{font-size:1.15rem;font-weight:700;color:var(--text-primary)}.dash-summary-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.dash-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.dash-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;padding:16px 20px}.dash-card h3{font-size:.95rem;font-weight:600;color:var(--text-primary);margin:0 0 12px}.dash-empty{font-size:.85rem;color:var(--text-muted);margin:0}.dash-task-list{display:flex;flex-direction:column;gap:6px}.dash-task{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;border-radius:8px;background:var(--bg-elevated);border-left:3px solid var(--border)}.dash-task-high{border-left-color:var(--error)}.dash-task-medium{border-left-color:var(--warning)}.dash-task-low{border-left-color:var(--accent)}.dash-task-icon{font-size:1rem;flex-shrink:0;margin-top:1px}.dash-task-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.dash-task-title{font-size:.85rem;font-weight:500;color:var(--text-primary)}.dash-task-desc{font-size:.75rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dash-task-actions{display:flex;gap:4px;flex-shrink:0}.dash-task-btn{width:26px;height:26px;border:1px solid var(--border);border-radius:6px;background:transparent;cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:all .15s}.dash-task-btn.done:hover{background:var(--accent-surface);color:var(--accent);border-color:var(--accent)}.dash-task-btn.skip:hover{background:var(--error-surface);color:var(--error);border-color:var(--error)}.dash-alert-list{display:flex;flex-direction:column;gap:6px}.dash-alert-heading{font-size:.8rem;font-weight:600;color:var(--warning);margin-bottom:4px}.dash-alert-item{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--text-primary);padding:6px 8px;border-radius:6px;background:var(--bg-elevated)}.dash-alert-item span:first-child{flex-shrink:0}.dash-alert-item span:nth-child(2){flex:1}.dash-recs{display:flex;flex-direction:column;gap:8px}.dash-rec{display:flex;align-items:center;gap:10px;font-size:.85rem;color:var(--text-secondary);padding:8px 10px;background:var(--bg-elevated);border-radius:8px}.dash-rec-icon{font-size:1.1rem;flex-shrink:0}.dash-zone-groups{display:flex;flex-direction:column;gap:10px}.dash-zone-group{background:var(--bg-elevated);border-radius:8px;overflow:hidden}.dash-zone-header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;font-size:.85rem;font-weight:600;border-left:3px solid var(--accent)}.dash-zone-header-ungrouped{border-left-color:var(--text-muted, #999);opacity:.75}.dash-zone-count{font-size:.75rem;font-weight:400;color:var(--text-secondary)}.dash-zone-plants{display:flex;flex-wrap:wrap;gap:4px;padding:6px 12px 8px}.dash-zone-plant-tag{display:inline-flex;align-items:center;gap:3px;font-size:.75rem;padding:2px 8px;border-radius:12px;background:var(--card-bg);color:var(--text-secondary)}.dash-agent-row{margin-top:16px}.agent-chat{background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;display:flex;flex-direction:column;height:380px;overflow:hidden}.agent-chat-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.agent-chat-title{display:flex;align-items:center;gap:8px}.agent-chat-title h3{font-size:.95rem;font-weight:600;color:var(--text-primary);margin:0}.agent-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.agent-status-dot.online{background:#4caf50;box-shadow:0 0 4px #4caf5080}.agent-status-dot.offline{background:var(--text-muted)}.agent-badge{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:2px 6px;border-radius:4px;background:var(--accent-surface);color:var(--accent)}.agent-clear-btn{padding:4px 10px;border:1px solid var(--border);border-radius:6px;background:transparent;color:var(--text-muted);font-size:.75rem;cursor:pointer;transition:all .15s}.agent-clear-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.agent-chat-messages{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:8px}.agent-chat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:20px}.agent-empty-title{font-size:.9rem;font-weight:500;color:var(--text-secondary);margin:0 0 12px}.agent-empty-hint{font-size:.8rem;color:var(--text-muted);margin:0;max-width:400px;line-height:1.5}.agent-empty-hint code{background:var(--bg-elevated);padding:1px 5px;border-radius:4px;font-size:.78rem}.agent-suggestions{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.agent-suggestion{padding:6px 12px;border:1px solid var(--border);border-radius:16px;background:transparent;color:var(--text-secondary);font-size:.78rem;cursor:pointer;transition:all .15s}.agent-suggestion:hover{background:var(--accent-surface);color:var(--accent);border-color:var(--accent)}.agent-msg{display:flex;max-width:85%}.agent-msg-user{align-self:flex-end}.agent-msg-assistant{align-self:flex-start}.agent-msg-bubble{padding:8px 12px;border-radius:12px;font-size:.85rem;line-height:1.5;white-space:pre-wrap;word-break:break-word}.agent-msg-user .agent-msg-bubble{background:var(--accent);color:#fff;border-bottom-right-radius:4px}.agent-msg-assistant .agent-msg-bubble{background:var(--bg-elevated);color:var(--text-primary);border-bottom-left-radius:4px}.agent-typing{display:inline-block;width:20px;height:12px;background:repeating-linear-gradient(90deg,var(--text-muted) 0px,var(--text-muted) 4px,transparent 4px,transparent 8px);background-size:16px 100%;animation:agent-typing-anim .8s infinite;border-radius:2px}@keyframes agent-typing-anim{0%{background-position:0}to{background-position:16px}}.agent-chat-input-row{display:flex;gap:8px;padding:10px 12px;border-top:1px solid var(--border);flex-shrink:0}.agent-chat-input{flex:1;padding:8px 12px;border:1px solid var(--border-input, var(--border));border-radius:8px;background:var(--bg-input, var(--bg-elevated));color:var(--text-primary);font-size:.85rem;outline:none;transition:border-color .15s}.agent-chat-input:focus{border-color:var(--accent)}.agent-chat-input:disabled{opacity:.6}.agent-send-btn{padding:8px 16px;border:none;border-radius:8px;background:var(--accent-bold, var(--accent));color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s;flex-shrink:0}.agent-send-btn:hover:not(:disabled){background:var(--accent-hover, var(--accent))}.agent-send-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 900px){.dash-hero{grid-template-columns:1fr;min-height:260px}.dash-grid{grid-template-columns:1fr}.dash-summary{gap:8px}.dash-summary-card{min-width:100px;padding:8px 12px}.agent-chat{height:320px}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:2000;display:flex;align-items:center;justify-content:center;animation:fadeIn .15s}.modal-content{background:var(--bg-surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-lg);max-width:560px;width:90%;max-height:85vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg-surface);border-radius:16px 16px 0 0;z-index:1}.modal-header h2{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0}.modal-close{width:32px;height:32px;border:none;border-radius:8px;background:transparent;cursor:pointer;font-size:1rem;color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:all .15s}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.settings-modal-body{padding:16px 20px;display:flex;flex-direction:column;gap:20px}.settings-danger-btn{padding:8px 16px;border:1px solid var(--error);border-radius:8px;background:transparent;color:var(--error);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s;margin-top:8px}.settings-danger-btn:hover{background:var(--error-surface)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.toolbar-spacer{flex:1}.asset-library-filter{display:flex;gap:.25rem;margin-bottom:.75rem}.asset-filter-btn{padding:.25rem .5rem;font-size:.75rem;border:1px solid #ccc;border-radius:4px;background:#fff;cursor:pointer;text-transform:capitalize}.asset-filter-btn.active{background:#4caf50;color:#fff;border-color:#4caf50}.asset-library-grid{display:flex;flex-direction:column;gap:.5rem;max-height:300px;overflow-y:auto}.asset-library-card{border:1px solid #e0e0e0;border-radius:6px;padding:.5rem;background:#fafafa}.asset-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.asset-card-label{font-weight:600;font-size:.85rem}.asset-card-badge{font-size:.65rem;padding:.1rem .35rem;border-radius:3px;font-weight:600;text-transform:uppercase}.asset-status-ready{background:#c8e6c9;color:#2e7d32}.asset-status-generating{background:#fff9c4;color:#f57f17}.asset-status-processing{background:#bbdefb;color:#1565c0}.asset-status-queued{background:#e0e0e0;color:#616161}.asset-status-failed{background:#ffcdd2;color:#c62828}.asset-card-meta{display:flex;gap:.5rem;font-size:.75rem;color:#777;margin-bottom:.25rem}.asset-card-warnings{color:#e65100}.asset-card-actions{display:flex;gap:.25rem}.asset-action-btn{padding:.2rem .5rem;font-size:.7rem;border:1px solid #ccc;border-radius:3px;background:#fff;cursor:pointer}.asset-action-btn:hover{background:#f0f0f0}.asset-action-btn.danger{color:#c62828;border-color:#ef9a9a}.asset-action-btn.danger:hover{background:#ffebee}.texture-preview{margin-top:4px;border-radius:6px;overflow:hidden;border:1px solid var(--card-border, #ddd)}.texture-preview img{display:block;width:100%;height:48px;object-fit:cover}.generate-asset-dialog{max-width:480px}.generate-asset-body{display:flex;flex-direction:column;gap:.5rem;padding:0 1rem 1rem}.generate-asset-textarea{resize:vertical;min-height:60px;font-family:inherit}.generate-asset-error{color:#c62828;font-size:.85rem}.generate-asset-result{text-align:center;padding:.5rem 0}.generate-asset-success{color:#2e7d32;font-weight:600;margin-bottom:.5rem}.generate-asset-actions{display:flex;gap:.5rem;justify-content:center}.generate-asset-progress{text-align:center;padding:1rem 0}.generate-asset-status-badge{display:inline-block;margin-top:.5rem;padding:.2rem .6rem;background:#fff9c4;color:#f57f17;border-radius:4px;font-size:.8rem;font-weight:600;text-transform:uppercase}.gen-mode-tabs{display:flex;gap:0;margin-bottom:.75rem;border-radius:6px;overflow:hidden;border:1px solid #444}.gen-mode-tab{flex:1;padding:.4rem 0;border:none;background:#2a2a2e;color:#999;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.gen-mode-tab:hover{background:#333;color:#ccc}.gen-mode-tab.active{background:#4a90d9;color:#fff}.image-drop-zone{border:2px dashed #555;border-radius:8px;padding:1.2rem;text-align:center;cursor:pointer;transition:border-color .15s,background .15s;background:#1e1e22;min-height:80px;display:flex;align-items:center;justify-content:center}.image-drop-zone:hover{border-color:#4a90d9;background:#252530}.image-drop-placeholder{color:#777;font-size:.85rem;margin:0}.image-drop-preview{display:flex;flex-direction:column;align-items:center;gap:.4rem}.image-drop-preview img{max-width:100%;max-height:120px;border-radius:4px;object-fit:contain}.image-drop-name{font-size:.75rem;color:#888;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}
