@charset "UTF-8";:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.address-form .field{display:flex;flex-direction:column;margin-bottom:.75rem}.address-form .label{font-size:.875rem;font-weight:600;margin-bottom:.25rem;color:#334155}.address-form .input{border:1px solid #cbd5e1;border-radius:.5rem;color:#000;padding:.6rem .75rem;font-size:.95rem;outline:none;transition:border-color .12s ease,box-shadow .12s ease,background .12s ease}.address-form .input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626;background:#fff}.address-form .input.input--error{border-color:#ef4444;box-shadow:0 0 0 3px #ef444426}.address-form .error{font-size:.75rem;color:#dc2626;margin-top:.25rem}.address-form .btn{background:#3b82f6;color:#fff;padding:.6rem 1rem;border-radius:.5rem;font-weight:600;transition:transform .12s ease,box-shadow .12s ease,opacity .12s ease;border:none;cursor:pointer}.address-form .btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #3b82f640}.address-form .btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #3b82f633}.address-form .btn:disabled{opacity:.7;cursor:not-allowed}.address-form .autocomplete,.address-form .autocomplete__wrapper{position:relative}.address-form .autocomplete__list{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:50;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;box-shadow:0 14px 30px #0f172a1f;max-height:280px;overflow-y:auto;padding:.25rem;margin:0;list-style:none}.address-form .autocomplete__item{display:flex;align-items:baseline;gap:6px;padding:.55rem .6rem;border-radius:.4rem;cursor:pointer;transition:background .1s ease}.address-form .autocomplete__item:hover{background:#f8fafc}.address-form .autocomplete__item.is-active{background:#eff6ff;outline:2px solid rgba(59,130,246,.35)}.address-form .autocomplete__item .item__main{font-weight:600;color:#0f172a}.address-form .autocomplete__item .item__secondary{font-size:.875rem;color:#475569}@media(max-width:480px){.address-form .input{font-size:.9rem;padding:.55rem .65rem}.address-form .btn{width:100%}}html,body,#root{margin:0;padding:0;height:100%;width:100%;overflow:hidden}.map-viewer{display:flex;height:100vh;width:100vw;overflow:hidden;background:#0f172a;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}.sidebar-container{height:100vh;position:fixed;top:0;left:0;background:#1f2937;color:#fff;display:flex;flex-direction:column;justify-content:flex-start;overflow:hidden;box-shadow:2px 0 14px #00000059;z-index:10000}.map-container{flex:1;height:100vh;display:flex;justify-content:center;align-items:center;position:relative;overflow:hidden;background:#020617;cursor:default}.map-grid{position:absolute;inset:0;pointer-events:none;background-image:linear-gradient(to right,rgba(51,65,85,.6) 1px,transparent 1px),linear-gradient(to bottom,rgba(51,65,85,.6) 1px,transparent 1px),linear-gradient(to right,rgba(148,163,184,.5) 1px,transparent 1px),linear-gradient(to bottom,rgba(148,163,184,.5) 1px,transparent 1px);background-size:32px 32px,32px 32px,160px 160px,160px 160px;opacity:.9}.img-layer{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;will-change:transform;z-index:1}.map-image{-webkit-user-select:none;user-select:none;transform-origin:center center;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(1);object-fit:cover;border-radius:8px;box-shadow:0 18px 45px #0009;pointer-events:none}.draw-canvas,.preview-canvas{position:absolute;inset:0;width:100%;height:100%}.draw-canvas{z-index:2;pointer-events:auto}.preview-canvas{z-index:3;pointer-events:none}.preview-canvas.is-selecting{cursor:crosshair;pointer-events:auto}.error-message{display:flex;justify-content:center;align-items:center;height:100vh;width:100vw;color:#ef4444;font-size:1.1rem;background:#0f172a}.zoom-controls{position:absolute;bottom:20px;right:20px;display:flex;flex-direction:column;gap:10px;z-index:5}.zoom-button{width:40px;height:40px;border-radius:9999px;background:#3b82f6;color:#fff;border:none;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 18px #3b82f659;transition:transform .15s ease,background .15s ease}.zoom-button:hover{background:#2563eb;transform:translateY(-1px) scale(1.03)}.zoom-button:active{transform:translateY(0) scale(.97)}.status-bar{position:absolute;bottom:0;right:.01%;background:#2b2b2ba8;color:#f9fafb;padding:6px 14px;font-size:12.5px;letter-spacing:.2px;z-index:9999!important;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;flex-direction:column;align-items:flex-end;gap:2px;width:100%}.status-text{white-space:nowrap}.status-coords{display:flex;justify-content:flex-end;align-items:center;font-size:11px;color:#fff;opacity:.95;white-space:nowrap;width:100vh}.overlay-3d{position:absolute;inset:0;z-index:50;background:#0000000d}.overlay-3d .close-3d{position:absolute;top:8px;right:8px;z-index:51;padding:6px 10px;border:0;border-radius:8px;background:#111827;color:#fff;cursor:pointer}:root{--sidebar-width: 420px;--sidebar-collapsed-width: 80px;--border-radius: 8px;--border-radius-lg: 12px;--spacing-xs: 6px;--spacing-sm: 10px;--spacing-md: 14px;--spacing-lg: 18px;--spacing-xl: 24px;--color-primary: #ff6b35;--color-primary-light: #fff5f0;--color-primary-dark: #e55a2b;--color-surface: #ffffff;--color-surface-alt: #f8f9fa;--color-surface-elevated: #ffffff;--color-border: #e1e5e9;--color-border-light: #f1f3f4;--color-text: #1a1d21;--color-text-secondary: #5f6368;--color-text-tertiary: #9aa0a6;--color-success: #0cce6b;--color-warning: #ffa726;--color-error: #f44336;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .1);--shadow-md: 0 4px 8px rgba(0, 0, 0, .08);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .15);--transition: all .25s ease}.sidebar{height:100vh;background:var(--color-surface);display:flex;flex-direction:row;border-right:2px solid var(--color-border);position:relative;overflow:hidden;transition:width .25s ease;z-index:9999;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif}.sidebar--collapsed{width:var(--sidebar-collapsed-width)}.sidebar--expanded{width:var(--sidebar-width)}.sidebar-rail{width:var(--sidebar-collapsed-width);background:var(--color-surface);border-right:1px solid var(--color-border-light);display:flex;flex-direction:column;padding:var(--spacing-lg) var(--spacing-sm);gap:var(--spacing-lg)}.rail-top{display:flex;flex-direction:column;gap:var(--spacing-md)}.sidebar-toggle{align-self:flex-end;width:36px;height:36px;border-radius:8px;border:1px solid var(--color-border);background:var(--color-surface);color:#2b2b2b;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;transition:var(--transition);box-shadow:var(--shadow-sm);margin-right:15px}.sidebar-toggle svg{pointer-events:none}.sidebar-toggle:hover{border-color:var(--color-primary);background:#b8b8b8;transform:translateY(-1px);box-shadow:var(--shadow-md)}.brand-section{display:flex;flex-direction:row;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) 4px}.brand-logo{width:65px;height:auto;border-radius:var(--border-radius);object-fit:contain;filter:brightness(.9)}.brand-text{display:flex;flex-direction:column}.brand-name{font-weight:700;font-size:16px;color:var(--color-text);line-height:1.2;letter-spacing:-.2px}.brand-subtitle{font-size:12px;color:var(--color-text-secondary);font-weight:500;letter-spacing:.2px}.sidebar--collapsed .brand-text{display:none}.tabs-container{display:flex;flex-direction:column;border-radius:var(--border-radius);padding:6px;gap:4px}.tab{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:10px 4px;border:none;background:transparent;border-radius:8px;font-size:11px;font-weight:600;color:#2b2b2b;cursor:pointer;transition:var(--transition);text-align:center}.tab:hover{background:#c9c9c9e6;color:var(--color-text);transform:translateY(-1px)}.tab.tab--active{background:#f60;box-shadow:var(--shadow-sm)}.tab-label{line-height:1}.sidebar--collapsed .tab:after{display:none}.tab-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px}.sidebar-panel{flex:1;background:var(--color-surface);display:flex;flex-direction:column}.sidebar--collapsed .sidebar-panel{display:none}.sidebar-content{flex:1;overflow-y:auto;padding:var(--spacing-lg);transition:opacity .2s ease}.tab-content{display:flex;flex-direction:column;gap:var(--spacing-lg)}.action-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.primary-action{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:8px 12px;background:transparent;color:var(--color-primary);border:2px solid var(--color-primary);border-radius:var(--border-radius);font-size:13px;font-weight:600;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-xs);width:100%}.primary-action:hover{background:var(--color-primary);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-sm)}.primary-action.primary-action--active{background:var(--color-primary-dark);color:#fff;border-color:var(--color-primary-dark)}.primary-action.primary-action--disabled{opacity:.5;cursor:not-allowed}.primary-action.primary-action--disabled:hover{background:transparent;color:var(--color-primary);transform:none;box-shadow:var(--shadow-xs)}.action-icon{font-size:18px;font-weight:700}.toggle-group{display:flex;gap:var(--spacing-md)}.toggle-button{flex:1;padding:10px 14px;border:1px solid var(--color-border);background:var(--color-surface);border-radius:var(--border-radius);font-size:13px;font-weight:600;color:var(--color-text);cursor:pointer;transition:var(--transition)}.toggle-button:hover{border-color:var(--color-primary);transform:translateY(-1px)}.toggle-button.toggle-button--active{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.toggle-button.toggle-button--disabled{opacity:.5;cursor:not-allowed}.toggle-button.toggle-button--disabled:hover{border-color:var(--color-border);transform:none}.save-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.save-button{padding:14px 18px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--border-radius);font-size:15px;font-weight:600;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-sm)}.save-button:hover:not(:disabled){background:var(--color-primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.save-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.save-message{font-size:13px;color:var(--color-text-secondary);text-align:center;padding:6px}.zones-cards-container,.zones-cards{display:flex;flex-direction:column;gap:var(--spacing-md)}.zone-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius);padding:var(--spacing-md);cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-sm)}.zone-card:hover{border-color:var(--color-primary);transform:translateY(-1px);box-shadow:var(--shadow-md)}.zone-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.zone-card-title{font-weight:600;font-size:16px;color:var(--color-text)}.zone-card-delete{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--color-border);background:var(--color-surface);border-radius:6px;cursor:pointer;transition:var(--transition);color:var(--color-error)}.zone-card-delete:hover{background:#fef2f2;border-color:var(--color-error);transform:translateY(-1px)}.zone-detail-row{display:flex;flex-direction:row;align-items:flex-start;gap:48px;flex-wrap:wrap;justify-content:flex-start}.zone-detail-item{display:flex;flex-direction:column;align-items:center;gap:4px;margin-bottom:5px;text-align:center}.zone-detail-label{font-size:11px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;line-height:1.2;white-space:nowrap}.zone-detail-value{font-size:14px;font-weight:700;color:var(--color-text);line-height:1.2}.building-controls-section{margin:var(--spacing-md) 0;padding:var(--spacing-md);background:#7b9dc000}.building-controls-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid #dee2e6}.building-controls-header .building-icon{width:20px;height:20px;color:var(--color-primary)}.building-controls-header .building-title{font-size:14px;font-weight:600;color:var(--color-text);margin:0}.building-controls-grid{display:flex;flex-direction:column;gap:var(--spacing-md)}.control-group{background:#fff;border:1px solid var(--color-border);border-radius:8px;padding:var(--spacing-md);transition:var(--transition);box-shadow:var(--shadow-sm)}.control-group:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md)}.control-group.control-group--highlight{border-color:var(--color-primary);background:var(--color-primary-light)}.control-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-sm)}.control-header .control-label{font-size:13px;font-weight:600;color:var(--color-text);display:flex;align-items:center;gap:6px}.control-header .control-icon{width:16px;height:16px;color:var(--color-primary)}.control-header .control-unit{font-size:11px;font-weight:500;color:var(--color-text-secondary);background:#f1f3f4;padding:2px 6px;border-radius:4px}.control-input-wrapper{display:flex;align-items:center;gap:var(--spacing-sm);background:#fff;border:1px solid var(--color-border);border-radius:6px;padding:8px 12px;transition:var(--transition)}.control-input-wrapper:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 2px #ff6b351a}.control-input-wrapper .control-input{flex:1;border:none;background:transparent;font-size:14px;font-weight:500;color:var(--color-text);outline:none;min-width:0}.control-input-wrapper .control-input::placeholder{color:var(--color-text-tertiary)}.control-input-wrapper .control-input::-webkit-outer-spin-button,.control-input-wrapper .control-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.control-input-wrapper .control-input[type=number]{-moz-appearance:textfield}.control-input-wrapper .control-suffix{font-size:12px;font-weight:500;color:var(--color-text-secondary);white-space:nowrap}.control-description{font-size:11px;color:var(--color-text-tertiary);margin-top:4px;line-height:1.3}.zone-frame-groups{border-top:1px solid var(--color-border-light);padding-top:var(--spacing-md)}.frame-groups-header{font-size:14px;font-weight:600;color:var(--color-text);margin-bottom:var(--spacing-sm)}.frame-groups-content{margin-bottom:var(--spacing-md)}.empty-frame-groups{padding:var(--spacing-lg);text-align:center;border:1px dashed var(--color-border);border-radius:var(--border-radius);color:var(--color-text-tertiary)}.empty-frame-groups .empty-icon{font-size:24px;margin-bottom:var(--spacing-sm);opacity:.5}.zone-help-button{width:100%;padding:8px 14px;border:1px solid var(--color-border);background:transparent;color:var(--color-text);border-radius:var(--border-radius);font-size:12px;font-weight:600;cursor:pointer;transition:var(--transition)}.zone-help-button:hover{background:var(--color-surface-alt);transform:translateY(-1px)}.empty-state{padding:var(--spacing-xl);text-align:center;color:var(--color-text-tertiary)}.empty-icon{font-size:36px;margin-bottom:var(--spacing-md);opacity:.5}.empty-text{font-size:14px;font-weight:500}.drawing-actions{display:flex;flex-direction:column;gap:var(--spacing-md)}.primary-button{padding:14px 18px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--border-radius);font-size:15px;font-weight:600;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-sm)}.primary-button:hover:not(:disabled){background:var(--color-primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-md)}.primary-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.secondary-button{padding:12px 18px;border:1px solid var(--color-border);background:transparent;color:var(--color-text);border-radius:var(--border-radius);font-size:14px;font-weight:600;cursor:pointer;transition:var(--transition)}.secondary-button:hover:not(:disabled){background:var(--color-surface-alt);border-color:var(--color-text-tertiary);transform:translateY(-1px)}.secondary-button:disabled{opacity:.5;cursor:not-allowed}.info-text{font-size:13px;color:var(--color-text-secondary);line-height:1.5;padding:var(--spacing-md);background:var(--color-surface-alt);border-radius:var(--border-radius);border-left:4px solid var(--color-primary)}.units-section{padding-top:var(--spacing-lg);border-top:1px solid var(--color-border-light)}.modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-lg)}.modal{background:var(--color-surface);border-radius:var(--border-radius-lg);width:100%;max-width:560px;max-height:85vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);border:1px solid var(--color-border);overflow:hidden}.modal-title{padding:var(--spacing-lg);margin:0;font-size:20px;font-weight:600;color:#2b2b2b;text-align:center;border-bottom:1px solid var(--color-border);background:var(--color-surface)}.inverter-search-container,.panel-search-container{position:sticky;top:0;z-index:2;padding:var(--spacing-md) var(--spacing-lg);background:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;align-items:center;gap:var(--spacing-sm)}.inverter-search-input,.panel-search-input{flex:1;height:40px;padding:0 14px;border-radius:8px;border:1px solid var(--color-border);font-size:14px;outline:none}.inverter-search-input:focus,.panel-search-input:focus{border-color:#f60}.inverter-search-clear,.panel-search-clear{width:32px;height:32px;border-radius:50%;border:none;background:#f2f2f2;cursor:pointer;font-size:18px}.inverter-options-container,.panel-options-container{flex:1;overflow-y:auto;padding:var(--spacing-md);background:#fafafa}.inverter-option,.panel-option{display:flex;gap:var(--spacing-md);align-items:center;padding:var(--spacing-md);margin-bottom:var(--spacing-sm);border-radius:10px;border:1px solid var(--color-border);background:#fff;cursor:pointer;transition:all .2s ease}.inverter-option:hover,.panel-option:hover{border-color:#f60;box-shadow:var(--shadow-sm)}.inverter-option--selected,.panel-option--selected{border-color:#f60;background:#ff66000d}.inverter-option-image,.panel-option-image{width:64px;height:64px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#f5f5f5;border-radius:8px}.inverter-img,.panel-img{max-width:100%;max-height:100%;object-fit:contain}.roof-options{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.roof-option{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);border:1px solid var(--color-border);background:var(--color-surface);border-radius:var(--border-radius);cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-sm);color:#2b2b2b}.roof-option:hover{border-color:#000;background:#f60;transform:translateY(-2px);box-shadow:var(--shadow-md);color:#2b2b2b}.roof-option img{width:100%;height:90px;object-fit:contain;border-radius:4px;background:#fff;padding:10px}.roof-option span{font-size:14px;font-weight:600;color:var(--color-text);text-align:center}.modal-actions{display:flex;justify-content:center}.sidebar-content::-webkit-scrollbar{width:6px}.sidebar-content::-webkit-scrollbar-track{background:transparent}.sidebar-content::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.sidebar-content::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.sidebar{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.unit-toggle-wrapper{margin-bottom:var(--spacing-md);margin-right:8px}.unit-toggle-card{width:100%;border:none;padding:8px 6px 10px;border-radius:8px;background:#fff;color:#000;display:flex;flex-direction:column;align-items:center;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .15s ease}.unit-toggle-card:hover{background:#c9c9c9e6;transform:translateY(-1px)}.unit-toggle-title{font-size:12px;font-weight:600;margin-bottom:4px}.unit-toggle-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;margin-bottom:2px}.unit-toggle-icon img{width:100%;height:100%;object-fit:contain}.unit-toggle-label{font-size:11px;font-weight:600;letter-spacing:.03em}.view-switch-wrapper{margin-top:auto;margin-right:8px}.view-switch-card{width:100%;border:none;padding:8px 6px 10px;border-radius:8px;background:#fff;color:#000;display:flex;flex-direction:column;align-items:center;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .15s ease}.view-switch-card:hover{background:#c9c9c9e6;transform:translateY(-1px)}.view-switch-title{font-size:12px;font-weight:600;margin-bottom:4px}.view-switch-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;margin-bottom:2px}.view-switch-icon img{width:100%;height:100%;object-fit:contain}.view-switch-label{font-size:11px;font-weight:600;letter-spacing:.03em}.export-actions{display:flex;flex-direction:column;gap:var(--spacing-md)}.export-button{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);padding:14px 18px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--border-radius);font-size:15px;font-weight:600;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-sm)}.export-button:hover:not(:disabled){background:var(--color-primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-md)}.export-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.export-button .action-icon{font-size:18px}.snackbar{position:fixed;left:50%;bottom:24px;transform:translate(-50%) translateY(20px);padding:12px 16px;border-radius:8px;color:#0f5132;background:#d1e7dd;border:1px solid #badbcc;box-shadow:0 8px 24px #0000001f;opacity:0;pointer-events:none;transition:opacity .25s ease,transform .25s ease;z-index:1000;font-size:14px;font-weight:500}.snackbar--open{opacity:1;transform:translate(-50%) translateY(0);pointer-events:auto}.snackbar--success{color:#0f5132;background:#d1e7dd;border-color:#badbcc}.snackbar--error{color:#842029;background:#f8d7da;border-color:#f5c2c7}.export-info{font-size:13px;color:var(--color-text-secondary);line-height:1.5;padding:var(--spacing-md);background:var(--color-surface-alt);border-radius:var(--border-radius);border-left:4px solid var(--color-primary)}.export-info strong{color:var(--color-text)}.trash-icon{padding:12px}.zone-frame-groups{margin-top:14px;padding:14px;background:#f8f9fb;border-radius:12px;border:1px solid #e5e7eb}.zone-frame-groups .frame-groups-header{font-weight:600;font-size:14px;margin-bottom:10px;color:#111827}.zone-frame-groups .frame-groups-content{padding:6px 0}.zone-frame-groups .frame-groups-content .empty-frame-groups{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px 0;opacity:.6;text-align:center}.zone-frame-groups .frame-groups-content .empty-frame-groups .empty-icon{font-size:32px;margin-bottom:6px}.zone-frame-groups .frame-groups-content .empty-frame-groups div{font-size:13px;color:#6b7280}.zone-frame-groups .frame-groups-content .frame-group-list{list-style:none;margin:0;padding:0}.zone-frame-groups .frame-groups-content .frame-group-list .frame-group-row{padding:10px 12px;margin-bottom:6px;border-radius:10px;background:#fff;border:1px solid #e5e7eb;cursor:pointer;transition:all .15s ease}.zone-frame-groups .frame-groups-content .frame-group-list .frame-group-row:hover{background:#f3f4f6;border-color:#d1d5db}.zone-frame-groups .frame-groups-content .frame-group-list .frame-group-row .frame-group-main{display:flex;justify-content:space-between;font-size:14px;font-weight:600;color:#111827}.zone-frame-groups .frame-groups-content .frame-group-list .frame-group-row .frame-group-main .frame-group-title{display:inline-block}.zone-frame-groups .frame-groups-content .frame-group-list .frame-group-row .frame-group-main .frame-group-kw{font-size:13px;color:#059669;font-weight:600;background:#ecfdf5;padding:2px 6px;border-radius:6px}.zone-frame-groups .frame-groups-content .frame-group-list .frame-group-row .frame-group-meta{margin-top:4px;font-size:12px;color:#6b7280;display:flex;gap:8px}.zone-frame-groups .zone-help-button{width:100%;background:transparent;border:none;padding:8px 0 0;font-size:12px;color:#2563eb;cursor:pointer;opacity:.8}.zone-frame-groups .zone-help-button:hover{opacity:1;text-decoration:underline}.zone-card .zone-card-actions{margin-top:10px}.frame-group-stats{display:grid;grid-template-columns:1fr 1fr;gap:4px;margin-top:8px;padding-top:8px;border-top:1px solid #eee}.frame-group-stat{display:flex;justify-content:space-between;font-size:12px}.stat-label{color:#666}.stat-value{font-weight:500;color:#333}.building-icon,.control-icon{display:flex;align-items:center;justify-content:center}.building-icon svg,.control-icon svg{width:100%;height:100%}.save-loader-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#fff;z-index:9999}.save-loader-img{width:64px;height:64px;animation:save-loader-spin 1s linear infinite}@keyframes save-loader-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.inverter-frame{margin-top:var(--spacing-md);padding:var(--spacing-md);background:#f8f9fb;border-radius:12px;border:1px solid #e5e7eb}.inverter-frame .inverter-frame-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid #e5e7eb}.inverter-frame .inverter-frame-header .inverter-frame-title{font-weight:600;font-size:16px;color:#111827}.inverter-frame .inverter-frame-header .inverter-frame-count{background:var(--color-primary);color:#fff;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:600;min-width:24px;text-align:center}.inverter-frame .inverter-frame-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl) var(--spacing-md);text-align:center;color:#6b7280}.inverter-frame .inverter-frame-empty .empty-icon{font-size:48px;margin-bottom:var(--spacing-md);opacity:.5}.inverter-frame .inverter-frame-empty .empty-text{font-size:16px;font-weight:500;margin-bottom:var(--spacing-sm);color:#374151}.inverter-frame .inverter-frame-empty .empty-subtext{font-size:14px;line-height:1.4;max-width:280px}.inverter-frame .inverter-frame-content .inverter-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.inverter-frame .inverter-frame-content .inverter-item{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--spacing-md);background:#fff;border:1px solid #e5e7eb;border-radius:8px;transition:all .15s ease;cursor:pointer}.inverter-frame .inverter-frame-content .inverter-item:hover{background:#f9fafb;border-color:#d1d5db;transform:translateY(-1px);box-shadow:0 2px 4px #0000000d}.inverter-frame .inverter-frame-content .inverter-item .inverter-item-main{flex:1;min-width:0}.inverter-frame .inverter-frame-content .inverter-item .inverter-item-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-sm)}.inverter-frame .inverter-frame-content .inverter-item .inverter-item-header .inverter-name{font-weight:600;font-size:14px;color:#111827;margin:0}.inverter-frame .inverter-frame-content .inverter-item .inverter-item-header .inverter-status .status-badge{padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.inverter-frame .inverter-frame-content .inverter-item .inverter-item-header .inverter-status .status-badge.active{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}.inverter-frame .inverter-frame-content .inverter-item .inverter-item-header .inverter-status .status-badge.inactive{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}.inverter-frame .inverter-frame-content .inverter-item .inverter-details{display:flex;flex-direction:column;gap:4px}.inverter-frame .inverter-frame-content .inverter-item .inverter-details .inverter-position,.inverter-frame .inverter-frame-content .inverter-item .inverter-details .inverter-type,.inverter-frame .inverter-frame-content .inverter-item .inverter-details .inverter-capacity{display:flex;align-items:center;gap:6px;font-size:12px}.inverter-frame .inverter-frame-content .inverter-item .inverter-details .inverter-position .detail-label,.inverter-frame .inverter-frame-content .inverter-item .inverter-details .inverter-type .detail-label,.inverter-frame .inverter-frame-content .inverter-item .inverter-details .inverter-capacity .detail-label{font-weight:500;color:#6b7280;min-width:60px}.inverter-frame .inverter-frame-content .inverter-item .inverter-details .inverter-position .detail-value,.inverter-frame .inverter-frame-content .inverter-item .inverter-details .inverter-type .detail-value,.inverter-frame .inverter-frame-content .inverter-item .inverter-details .inverter-capacity .detail-value{color:#374151;font-weight:400}.inverter-frame .inverter-frame-content .inverter-item .inverter-actions{display:flex;gap:4px;margin-left:var(--spacing-sm)}.inverter-frame .inverter-frame-content .inverter-item .inverter-actions .inverter-action-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid #e5e7eb;background:#fff;border-radius:6px;cursor:pointer;transition:all .15s ease}.inverter-frame .inverter-frame-content .inverter-item .inverter-actions .inverter-action-btn:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.inverter-frame .inverter-frame-content .inverter-item .inverter-actions .inverter-action-btn.focus-btn{color:#2563eb}.inverter-frame .inverter-frame-content .inverter-item .inverter-actions .inverter-action-btn.focus-btn:hover{background:#dbeafe;border-color:#2563eb}.inverter-frame .inverter-frame-content .inverter-item .inverter-actions .inverter-action-btn.remove-btn{color:#dc2626}.inverter-frame .inverter-frame-content .inverter-item .inverter-actions .inverter-action-btn.remove-btn:hover{background:#fef2f2;border-color:#dc2626}.inverter-frame .inverter-frame-content .inverter-item .inverter-actions .inverter-action-btn svg{width:16px;height:16px}.inverter-rail{display:none}.tab-content .inverter-frame{margin-top:0}@media(max-width:768px){.inverter-item{flex-direction:column;gap:var(--spacing-sm)}.inverter-item .inverter-actions{margin-left:0;align-self:flex-end}}.modal--inverter-picker{max-width:480px}.inverter-options{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);max-height:400px;overflow-y:auto}.inverter-option{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border:2px solid var(--color-border);background:var(--color-surface);border-radius:var(--border-radius);cursor:pointer;transition:var(--transition);text-align:left;width:100%}.inverter-option:hover{border-color:var(--color-primary);background:var(--color-primary-light);transform:translateY(-1px)}.inverter-option.inverter-option--selected{border-color:var(--color-primary);background:var(--color-primary-light)}.inverter-option-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-surface-alt);border-radius:8px;color:var(--color-primary)}.inverter-option-icon svg{width:24px;height:24px}.inverter-option-info{flex:1}.inverter-option-name{font-weight:600;font-size:14px;color:var(--color-text);margin-bottom:2px}.inverter-option-specs{display:flex;gap:var(--spacing-md);font-size:12px;color:var(--color-text-secondary)}.inverter-capacity{font-weight:600;color:var(--color-primary)}.inverter-type{background:var(--color-surface-alt);padding:2px 6px;border-radius:4px;font-size:11px;font-weight:500}.inverter-option-check{width:20px;height:20px;display:flex;align-items:center;justify-content:center;color:var(--color-primary)}.selected-inverter-info{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--color-primary-light);border:1px solid var(--color-primary);border-radius:var(--border-radius);margin-top:var(--spacing-sm)}.selected-inverter-label{font-size:12px;font-weight:600;color:var(--color-text)}.selected-inverter-name{font-size:13px;font-weight:600;color:var(--color-primary-dark);flex:1}.clear-selection-btn{width:20px;height:20px;border:none;background:var(--color-error);color:#fff;border-radius:50%;font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.inverter-device-icon{width:24px;height:24px}.frame-group-row--clickable{cursor:pointer}.frame-group-row--clickable:hover{background:#00000008}.modal--panel-picker{max-width:500px}.panel-options{display:flex;flex-direction:column;gap:8px;max-height:400px;overflow-y:auto;margin:16px 0}.panel-option{display:flex;align-items:center;padding:16px;border:1px solid #e1e5e9;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s ease;text-align:left;width:100%}.panel-option:hover{border-color:#007bff;background:#f8f9fa}.panel-option.panel-option--selected{border-color:#007bff;background:#f0f8ff}.panel-option-icon{margin-right:12px;color:#495057}.panel-option-info{flex:1}.panel-option-name{font-weight:600;color:#212529;margin-bottom:4px}.panel-option-specs{display:flex;gap:12px;font-size:.875rem;color:#6c757d}.panel-capacity{font-weight:500;color:#28a745}.panel-dimensions,.panel-area{color:#6c757d}.panel-option-check{color:#007bff;margin-left:8px}.selected-panel-info{display:flex;align-items:center;gap:8px;margin-top:8px;padding:8px 12px;background:#f8f9fa;border-radius:4px;font-size:.875rem}.selected-panel-label{color:#6c757d}.selected-panel-name{font-weight:500;color:#212529}.clear-selection-btn{background:none;border:none;color:#6c757d;cursor:pointer;padding:2px 6px;border-radius:50%;font-size:1rem;line-height:1}.clear-selection-btn:hover{background:#e9ecef;color:#dc3545}.blockers-frame{margin-top:var(--spacing-md);padding:var(--spacing-md);background:#f8f9fb;border-radius:12px;border:1px solid #e5e7eb}.blockers-frame .blockers-frame-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid #e5e7eb}.blockers-frame .blockers-frame-header .blockers-frame-title{font-weight:600;font-size:16px;color:#111827}.blockers-frame .blockers-frame-header .blockers-frame-count{background:var(--color-primary);color:#fff;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:600;min-width:24px;text-align:center}.blockers-frame .blockers-frame-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl) var(--spacing-md);text-align:center;color:#6b7280}.blockers-frame .blockers-frame-empty .empty-icon{font-size:48px;margin-bottom:var(--spacing-md);opacity:.5}.blockers-frame .blockers-frame-empty .empty-text{font-size:16px;font-weight:500;margin-bottom:var(--spacing-sm);color:#374151}.blockers-frame .blockers-frame-empty .empty-subtext{font-size:14px;line-height:1.4;max-width:280px}.blockers-frame .blockers-frame-content .blockers-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.blockers-frame .blockers-frame-content .blocker-item{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--spacing-md);background:#fff;border:1px solid #e5e7eb;border-radius:8px;transition:all .15s ease;cursor:pointer}.blockers-frame .blockers-frame-content .blocker-item:hover{background:#f9fafb;border-color:#d1d5db;transform:translateY(-1px);box-shadow:0 2px 4px #0000000d}.blockers-frame .blockers-frame-content .blocker-item .blocker-item-main{flex:1;min-width:0}.blockers-frame .blockers-frame-content .blocker-item .blocker-item-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-sm)}.blockers-frame .blockers-frame-content .blocker-item .blocker-item-header .blocker-name-container{display:flex;align-items:center;gap:8px;min-width:0}.blockers-frame .blockers-frame-content .blocker-item .blocker-item-header .blocker-icon{font-size:20px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#f3f4f6;border-radius:8px;flex-shrink:0}.blockers-frame .blockers-frame-content .blocker-item .blocker-item-header .blocker-name{font-weight:600;font-size:14px;color:#111827;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.blockers-frame .blockers-frame-content .blocker-item .blocker-item-header .blocker-type{font-size:11px;font-weight:600;color:#6b7280;background:#f3f4f6;padding:2px 8px;border-radius:12px;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0;margin-left:auto;margin-right:8px}.blockers-frame .blockers-frame-content .blocker-item .blocker-details{display:flex;flex-direction:column;gap:6px}.blockers-frame .blockers-frame-content .blocker-item .blocker-details .blocker-position,.blockers-frame .blockers-frame-content .blocker-item .blocker-details .blocker-dimensions{display:flex;align-items:center;gap:6px;font-size:12px}.blockers-frame .blockers-frame-content .blocker-item .blocker-details .blocker-position .detail-label,.blockers-frame .blockers-frame-content .blocker-item .blocker-details .blocker-dimensions .detail-label{font-weight:500;color:#6b7280;min-width:70px}.blockers-frame .blockers-frame-content .blocker-item .blocker-details .blocker-position .detail-value,.blockers-frame .blockers-frame-content .blocker-item .blocker-details .blocker-dimensions .detail-value{color:#374151;font-weight:400;flex:1}.blockers-frame .blockers-frame-content .blocker-item .blocker-actions{display:flex;gap:4px;margin-left:var(--spacing-sm)}.blockers-frame .blockers-frame-content .blocker-item .blocker-actions .blocker-action-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid #e5e7eb;background:#fff;border-radius:6px;cursor:pointer;transition:all .15s ease;font-size:14px}.blockers-frame .blockers-frame-content .blocker-item .blocker-actions .blocker-action-btn:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.blockers-frame .blockers-frame-content .blocker-item .blocker-actions .blocker-action-btn:hover.focus-btn{background:#dbeafe;border-color:#2563eb;color:#2563eb}.blockers-frame .blockers-frame-content .blocker-item .blocker-actions .blocker-action-btn.focus-btn{color:#2563eb}@media(max-width:768px){.blocker-item{flex-direction:column;gap:var(--spacing-sm)}.blocker-item .blocker-actions{margin-left:0;align-self:flex-end}}.settings-section{padding:var(--spacing-md) 0}.settings-title{font-size:18px;font-weight:600;margin:0 0 var(--spacing-lg) 0;color:var(--color-text);padding:0 var(--spacing-md)}.setting-item{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--spacing-md);border-bottom:1px solid var(--color-border-light);transition:var(--transition);cursor:pointer}.setting-item:hover{background:#c9c9c91a}.setting-item:last-child{border-bottom:none}.setting-header{display:flex;align-items:flex-start;gap:var(--spacing-sm);flex:1}.setting-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);flex-shrink:0}.setting-icon svg{width:20px;height:20px}.setting-info{flex:1}.setting-name{font-size:14px;font-weight:600;color:var(--color-text);margin-bottom:2px}.setting-description{font-size:12px;color:var(--color-text-tertiary);line-height:1.4}.setting-control{margin-left:var(--spacing-sm);display:flex;align-items:center}.toggle-switch{display:flex;align-items:center;gap:8px;background:none;border:none;cursor:pointer;padding:6px;border-radius:var(--border-radius);transition:var(--transition);min-width:120px}.toggle-switch:hover{background:#c9c9c933}.toggle-switch-track{width:44px;height:24px;background:var(--color-border);border-radius:12px;position:relative;transition:background-color .3s ease;flex-shrink:0}.toggle-switch--on .toggle-switch-track{background:var(--color-primary)}.toggle-switch-thumb{width:20px;height:20px;background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:transform .3s ease;box-shadow:var(--shadow-sm)}.toggle-switch--on .toggle-switch-thumb{transform:translate(20px)}.toggle-switch-label{font-size:13px;font-weight:600;color:var(--color-text);min-width:60px;text-align:left;flex-shrink:0}.settings-quick-actions{margin-top:var(--spacing-lg);padding:0 var(--spacing-md)}.quick-actions-title{font-size:15px;font-weight:600;margin:0 0 var(--spacing-sm) 0;color:var(--color-text)}.quick-actions-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm)}.quick-action-btn{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-md) var(--spacing-sm);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius);cursor:pointer;transition:var(--transition);text-align:center;height:100%}.quick-action-btn:hover{background:#c9c9c91a;border-color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.quick-action-btn:active{transform:translateY(0)}.quick-action-icon{width:32px;height:32px;margin-bottom:var(--spacing-xs);display:flex;align-items:center;justify-content:center}.quick-action-icon img{width:100%;height:100%;object-fit:contain}.quick-action-icon svg{width:24px;height:24px;color:var(--color-text-secondary)}.quick-action-label{font-size:12px;font-weight:600;color:var(--color-text);line-height:1.3;text-align:center}@media(max-width:768px){.quick-actions-grid{grid-template-columns:1fr}.setting-item{flex-direction:column;gap:var(--spacing-sm)}.setting-control{margin-left:0;width:100%;justify-content:flex-end}.toggle-switch{min-width:auto;width:auto}.settings-section,.settings-quick-actions{padding:0 var(--spacing-sm)}}@media(max-width:480px){.quick-actions-grid{grid-template-columns:1fr}.setting-item{padding:var(--spacing-sm)}.toggle-switch{min-width:100px}}.modal--panel-picker{max-width:600px;max-height:80vh;display:flex;flex-direction:column}.panel-search-container{position:relative;margin:15px 0;padding:0 20px}.panel-search-input{width:100%;padding:12px 40px 12px 15px;border:1px solid #ddd;border-radius:8px;font-size:14px;transition:border-color .2s}.panel-search-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.panel-search-clear{position:absolute;right:25px;top:50%;transform:translateY(-50%);background:none;border:none;color:#999;font-size:20px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.panel-search-clear:hover{color:#666}.panel-options-container{flex:1;overflow:hidden;margin:0 20px;border-radius:8px;border:1px solid #eee}.panel-options-scrollable{max-height:400px;overflow-y:auto;padding:10px}.panel-options-scrollable::-webkit-scrollbar{width:6px}.panel-options-scrollable::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.panel-options-scrollable::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.panel-options-scrollable::-webkit-scrollbar-thumb:hover{background:#aaa}.panel-option{display:flex;align-items:center;width:100%;padding:12px;margin-bottom:8px;border:1px solid #e0e0e0;border-radius:8px;background:#fff;text-align:left;cursor:pointer;transition:all .2s}.panel-option:hover{border-color:#007bff;background:#f8f9ff}.panel-option.panel-option--selected{border-color:#007bff;background:#e8f4ff}.panel-option-image{width:60px;height:60px;margin-right:12px;flex-shrink:0}.panel-option-image .panel-img{width:100%;height:100%;object-fit:contain;border-radius:4px;border:1px solid #eee}.panel-option-image .panel-img-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#f0f0f0;border-radius:4px;font-size:24px;color:#666}.panel-option-info{flex:1;min-width:0}.panel-option-name{font-weight:600;font-size:14px;color:#333;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.panel-option-manufacturer{font-size:12px;color:#666;margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.panel-option-specs{display:flex;gap:12px;font-size:12px;color:#555;margin-bottom:4px}.panel-option-specs span{display:inline-flex;align-items:center}.panel-option-specs span:not(:last-child):after{content:"•";margin-left:12px;opacity:.5}.panel-option-series{font-size:11px;color:#888;font-style:italic}.panel-option-check{margin-left:12px;color:#007bff;flex-shrink:0}.panel-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;color:#666}.panel-loading .loader-spinner{width:40px;height:40px;border:3px solid #f3f3f3;border-top:3px solid #007bff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:12px}.panel-error{padding:15px;margin:10px 20px;background:#fff3cd;border:1px solid #ffeaa7;border-radius:8px;color:#856404;font-size:13px}.no-panels-found{padding:40px 20px;text-align:center;color:#999;font-style:italic}.load-more-panels{width:100%;padding:12px;background:#f8f9fa;border:1px dashed #ddd;border-radius:8px;color:#666;cursor:pointer;font-size:13px;margin-top:10px;transition:all .2s}.load-more-panels:hover{background:#e9ecef;border-color:#ccc}.panel-count-info{text-align:center;font-size:12px;color:#888;margin-top:15px;padding-top:10px;border-top:1px solid #eee}@media(max-width:768px){.modal--panel-picker{max-width:95vw;max-height:90vh}.panel-options-scrollable{max-height:300px}.panel-option-specs{flex-wrap:wrap;gap:6px}.panel-option-specs span:not(:last-child):after{display:none}}.modal--inverter-picker{max-width:600px;max-height:80vh;display:flex;flex-direction:column}.inverter-search-container{position:relative;margin:15px 0;padding:0 20px}.inverter-search-input{width:100%;padding:12px 40px 12px 15px;border:1px solid #ddd;border-radius:8px;font-size:14px;transition:border-color .2s}.inverter-search-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.inverter-search-clear{position:absolute;right:25px;top:50%;transform:translateY(-50%);background:none;border:none;color:#999;font-size:20px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.inverter-search-clear:hover{color:#666}.inverter-options-container{flex:1;overflow:hidden;margin:0 20px;border-radius:8px;border:1px solid #eee}.inverter-options-scrollable{max-height:400px;overflow-y:auto;padding:10px}.inverter-options-scrollable::-webkit-scrollbar{width:6px}.inverter-options-scrollable::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.inverter-options-scrollable::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.inverter-options-scrollable::-webkit-scrollbar-thumb:hover{background:#aaa}.inverter-option{display:flex;align-items:center;width:100%;padding:12px;margin-bottom:8px;border:1px solid #e0e0e0;border-radius:8px;background:#fff;text-align:left;cursor:pointer;transition:all .2s}.inverter-option:hover{border-color:#007bff;background:#f8f9ff}.inverter-option.inverter-option--selected{border-color:#007bff;background:#e8f4ff}.inverter-option-image{width:60px;height:60px;margin-right:12px;flex-shrink:0}.inverter-option-image .inverter-img{width:100%;height:100%;object-fit:contain;border-radius:4px;border:1px solid #eee}.inverter-option-image .inverter-img-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#f0f0f0;border-radius:4px;font-size:24px;color:#666}.inverter-option-info{flex:1;min-width:0}.inverter-option-name{font-weight:600;font-size:14px;color:#333;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.inverter-option-manufacturer{font-size:12px;color:#666;margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.inverter-option-specs{display:flex;gap:12px;font-size:12px;color:#555;margin-bottom:4px}.inverter-option-specs span{display:inline-flex;align-items:center}.inverter-option-specs span:not(:last-child):after{content:"•";margin-left:12px;opacity:.5}.inverter-option-details{display:flex;flex-wrap:wrap;gap:8px;font-size:11px;color:#777}.inverter-option-details .inverter-detail{padding:2px 6px;background:#f5f5f5;border-radius:4px;border:1px solid #eee}.inverter-option-check{margin-left:12px;color:#007bff;flex-shrink:0}.inverter-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;color:#666}.inverter-loading .loader-spinner{width:40px;height:40px;border:3px solid #f3f3f3;border-top:3px solid #007bff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:12px}.inverter-error{padding:15px;margin:10px 20px;background:#fff3cd;border:1px solid #ffeaa7;border-radius:8px;color:#856404;font-size:13px}.no-inverters-found{padding:40px 20px;text-align:center;color:#999;font-style:italic}.load-more-inverters{width:100%;padding:12px;background:#f8f9fa;border:1px dashed #ddd;border-radius:8px;color:#666;cursor:pointer;font-size:13px;margin-top:10px;transition:all .2s}.load-more-inverters:hover{background:#e9ecef;border-color:#ccc}.inverter-count-info{text-align:center;font-size:12px;color:#888;margin-top:15px;padding-top:10px;border-top:1px solid #eee}@media(max-width:768px){.modal--inverter-picker{max-width:95vw;max-height:90vh}.inverter-options-scrollable{max-height:300px}.inverter-option-specs{flex-wrap:wrap;gap:6px}.inverter-option-specs span:not(:last-child):after{display:none}.inverter-option-details{gap:4px}.inverter-option-details .inverter-detail{font-size:10px;padding:1px 4px}}.modal--confirm{max-width:400px;padding:24px}.confirm-message{margin:20px 0;text-align:center;color:#000}.confirm-message p{margin:10px 0;line-height:1.5;color:var(--text-secondary)}.modal-actions--confirm{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.modal-actions--confirm .secondary-button{flex:1}.modal-actions--confirm .primary-button--danger{flex:1;background-color:#ef4444}.modal-actions--confirm .primary-button--danger:hover{background-color:#dc2626}.inverter-item-main .inverter-item-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.inverter-item-main .inverter-item-header .inverter-name-container{display:flex;align-items:center;gap:8px}.inverter-item-main .inverter-item-header .inverter-name-container .inverter-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;flex-shrink:0}.inverter-item-main .inverter-item-header .inverter-name-container .inverter-icon svg{width:20px;height:20px;color:#4a90e2}.inverter-item-main .inverter-item-header .inverter-name-container .inverter-name{font-weight:600;font-size:14px;color:#333}.inverter-item-main .inverter-details{display:flex;flex-direction:column;gap:4px;font-size:12px}.inverter-item-main .inverter-details .detail-label{color:#666;margin-right:4px;font-weight:500}.inverter-item-main .inverter-details .detail-value{color:#333}.inverter-item-main .inverter-details .inverter-model-details .detail-value{font-weight:600;color:#2c5282}.inverter-option-image{width:48px;height:48px;display:flex;align-items:center;justify-content:center}.inverter-option-image .inverter-img{max-width:100%;max-height:100%;object-fit:contain}.panel-option-image{width:48px;height:48px;display:flex;align-items:center;justify-content:center}.panel-option-image .panel-img{max-width:100%;max-height:100%;object-fit:contain}:root{--roof3d-sidebar-width: 250px;--roof3d-topbar-height: 0px;--roof3d-bg: #f8fafc;--roof3d-border: #e2e8f0;--roof3d-shadow: 0 10px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--roof3d-toolbar-bg: rgba(255, 255, 255, .95);--roof3d-info-bg: rgba(255, 255, 255, .9)}.roof3d-content{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#020617;z-index:1000;overflow:hidden;display:flex;flex-direction:column}.roof3d-grid{position:absolute;inset:0;z-index:0;pointer-events:none;background-image:linear-gradient(to right,rgba(51,65,85,.6) 1px,transparent 1px),linear-gradient(to bottom,rgba(51,65,85,.6) 1px,transparent 1px),linear-gradient(to right,rgba(148,163,184,.5) 1px,transparent 1px),linear-gradient(to bottom,rgba(148,163,184,.5) 1px,transparent 1px);background-size:32px 32px,32px 32px,160px 160px,160px 160px;opacity:.9}.roof3d-canvas-inline{flex:1;width:100%;height:100%;display:block;position:relative;z-index:1;background:transparent}.roof3d-night{position:absolute;inset:0;background:#0000002d;pointer-events:none;transition:opacity .2s ease;opacity:0}.roof3d-toolbar-drawer{position:absolute;left:0;right:0;bottom:16px;width:auto;display:flex;justify-content:center;align-items:flex-end;pointer-events:none;z-index:900}.roof3d-toolbar-drawer .roof3d-toolbar{width:100%;margin:0 0 12px;padding:8px 30px 8px 18px;transform:translateY(100%);opacity:0}.roof3d-toolbar-drawer.open .roof3d-toolbar{transform:translateY(0);opacity:1}.roof3d-toolbar-drawer.closed .roof3d-toolbar{transform:translateY(100%);opacity:0}.roof3d-toolbar-drawer.open{pointer-events:auto}.roof3d-toolbar{position:relative;display:flex;flex-direction:row;flex-wrap:wrap;align-items:center;gap:10px;justify-content:flex-end;width:100%;max-width:calc(100% - 48px);margin:0 auto;padding:8px 12px;background:#2b2b2ba8;box-shadow:var(--roof3d-shadow);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap;color:#fff}.roof3d-toolbar .vm-btn,.roof3d-toolbar .btn-save,.roof3d-toolbar .roof3d-close-inline{flex:0 0 auto;white-space:nowrap}.quick-views{display:inline-flex;gap:8px;align-items:center;margin-left:12px;flex-wrap:wrap}.quick-views .vm-btn{padding:6px 10px;font-size:12px;border-radius:6px;border:1px solid rgba(255,255,255,.08);background:#fff;cursor:pointer;flex:0 0 auto}.toolbar-drawer-handle{position:absolute;left:97%;transform:translate(-50%);z-index:910;width:44px;height:28px;border:none;outline:none;background:#2b2b2ba8;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s ease,background .15s ease;bottom:28px;transition:bottom .22s ease,transform .2s ease,box-shadow .2s ease;border-radius:0!important;color:#fff}.toolbar-drawer-handle.open{bottom:74px;left:97%;transform:translate(-50%) translateY(0);box-shadow:0 8px 20px #0000004d}.toolbar-drawer-handle .handle-arrow{display:inline-block;transition:transform .2s ease;font-size:12px;line-height:1}.toolbar-drawer-handle.open .handle-arrow{transform:rotate(180deg)}.viewmode-switch{display:inline-flex;align-items:center;gap:6px;margin-right:6px}.vm-label{font-size:12px;opacity:.8;margin-right:2px}.vm-btn{border:1px solid #c9cbd1;background:#f6f7fb;padding:4px 7px;border-radius:6px;font-size:12px;cursor:pointer;line-height:1;transition:background .12s ease,border-color .12s ease,transform 60ms ease}.vm-btn:hover{transform:translateY(-1px)}.vm-btn.active{background:#e4e7f2;border-color:#a8acc4;font-weight:600}.quick-views .vm-btn:hover{transform:translateY(-1px)}.btn-save{background:#3b82f6;color:#fff;border:0;border-radius:8px;padding:8px 12px;font-size:12px;font-weight:500;cursor:pointer;box-shadow:0 1px 3px #0000001a;transition:all .2s ease}.btn-save:hover{background:#2563eb;transform:translateY(-1px)}.btn-save:active{transform:translateY(0)}.btn-save:disabled{opacity:.6;cursor:not-allowed;transform:none}.roof3d-close-inline{background:#4b5563;color:#fff;border:0;border-radius:8px;padding:8px 10px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.roof3d-close-inline:hover{background:#374151;transform:translateY(-1px)}.roof3d-close-inline:active{transform:translateY(0)}.sunpath{display:inline-flex;align-items:center;gap:10px;margin-left:6px;padding-left:8px;border-left:1px solid rgba(255,255,255,.06)}.sunpath-title{font-weight:700;color:#fff;font-size:13px;margin-right:6px}.sunpath-row{display:inline-flex;align-items:center;gap:8px}.sunpath-label{color:#fff;font-size:12px;font-weight:600;white-space:nowrap}.sunpath-time{display:flex;align-items:center;gap:10px}.sunpath-speed{display:inline-flex;align-items:center;gap:6px;font-size:12px}.sunpath-speed select{background:#fff;border:1px solid #d0d5dd;border-radius:8px;padding:4px 8px;font-size:12px;color:#111827;min-width:74px}.slider{-webkit-appearance:none;appearance:none;width:150px;height:18px;border-radius:999px;outline:none;background:#d1d5db}.slider::-webkit-slider-runnable-track{height:18px;border-radius:999px;background:#d1d5db}.slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:#0f9d98;border:2px solid #d1faf4;box-shadow:0 0 0 2px #0000000f;margin-top:0;cursor:pointer}.slider::-moz-range-track{height:18px;border-radius:999px;background:#d1d5db}.slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#0f9d98;border:2px solid #d1faf4;box-shadow:0 0 0 2px #0000000f;cursor:pointer}.sunpath-play{display:inline-grid;place-items:center;width:30px!important;height:28px!important;border-radius:100%!important;border:0;padding:0;line-height:0;background:#0f9d98;color:#fff;font-weight:700;text-align:center;box-shadow:0 4px 12px #00000026;cursor:pointer;transition:transform .12s ease,filter .12s ease;align-items:center}.sunpath-play:hover{transform:translateY(-1px);filter:brightness(1.05)}.sunpath-play:active{transform:translateY(0)}.sunpath-play.pause{background:#ef4444}.parapet-controls{display:inline-flex;gap:8px;align-items:center;margin-right:6px}.parapet-field{display:flex;flex-direction:column;gap:4px;min-width:72px;max-width:120px;font-size:12px}.parapet-field>span{color:#111827;font-weight:600;font-size:12px}.parapet-field>input{width:72px;padding:6px;border:1px solid #d0d5dd;border-radius:8px;background:#fff;color:#111827;font-size:13px}.roof3d-controls{position:absolute;top:20px;right:20px;z-index:10}.roof3d-info-panel{background:var(--roof3d-info-bg);border-radius:12px;padding:16px;box-shadow:var(--roof3d-shadow);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid var(--roof3d-border);min-width:180px}.roof3d-info-panel h3{margin:0 0 12px;font-size:16px;font-weight:600;color:#1f2937;border-bottom:1px solid #e5e7eb;padding-bottom:8px}.info-row{display:flex;justify-content:space-between;margin-bottom:6px}.info-row:last-child{margin-bottom:0}.info-row .label{font-size:13px;color:#6b7280;font-weight:500}.info-row .value{font-size:13px;color:#1f2937;font-weight:600}.roof3d-snackbar{position:fixed;left:50%;bottom:24px;transform:translate(-50%) translateY(20px);padding:12px 16px;border-radius:8px;color:#0f5132;background:#d1e7dd;border:1px solid #badbcc;box-shadow:0 8px 24px #0000001f;opacity:0;pointer-events:none;transition:opacity .25s ease,transform .25s ease}.roof3d-snackbar.show{opacity:1;transform:translate(-50%) translateY(0);pointer-events:auto}.roof3d-snackbar.error{background:#f8d7da;border-color:#f5c2c7;color:#842029}.roof3d-loader-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#ffffff2c;z-index:9999!important;opacity:0;pointer-events:none;transition:opacity .2s ease}.roof3d-loader-overlay.visible{opacity:1;pointer-events:auto}.roof3d-loader-inner{display:flex;flex-direction:column;align-items:center;padding:18px 20px;border-radius:10px;background:#00000047;box-shadow:0 8px 24px #0000;text-align:center}.roof3d-loader-image{width:72px;height:72px;object-fit:contain;filter:drop-shadow(0 6px 14px rgba(0,0,0,0))}@media(max-width:900px){.roof3d-toolbar{gap:8px;padding:10px;justify-content:center}.sunpath,.quick-views{width:100%;justify-content:center;margin-left:0;gap:8px}.sunpath-row,.parapet-controls{flex-wrap:wrap;gap:8px;justify-content:center}}@media(max-width:480px){.roof3d-toolbar{flex-direction:column;align-items:stretch;width:calc(100% - 24px);padding:12px;box-sizing:border-box}.roof3d-toolbar .vm-btn,.roof3d-toolbar .btn-save,.roof3d-toolbar .roof3d-close-inline{width:100%;text-align:center;padding:10px 12px;font-size:14px}.quick-views,.sunpath{width:100%;display:flex;flex-direction:row;flex-wrap:wrap;justify-content:space-between}.quick-views .vm-btn{flex:1 1 calc(50% - 8px);min-width:120px;margin-bottom:6px}.sunpath-speed select{min-width:120px}.toolbar-drawer-handle,.toolbar-drawer-handle.open{left:92%}}.compass{position:absolute;top:14px;right:14px;z-index:20;-webkit-user-select:none;user-select:none;cursor:pointer;display:inline-flex;flex-direction:column;align-items:center;gap:6px}.compass .dial{position:relative;width:64px;height:64px;border-radius:50%;box-shadow:0 10px 20px #0000002e;background:transparent;display:flex;align-items:center;justify-content:center;overflow:visible}.compass .dial-image{width:100%;height:100%;object-fit:contain;transform-origin:50% 50%;transition:transform 80ms linear;pointer-events:none}.compass .heading-marker{position:absolute;top:-4px;left:50%;transform:translate(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-bottom:8px solid #ffffff;filter:drop-shadow(0 0 3px rgba(0,0,0,.6));pointer-events:none}.compass .readout{font-size:11px;padding:3px 8px;border-radius:999px;background:#ffffffe6;border:1px solid rgba(0,0,0,.08);color:#111827;box-shadow:0 6px 12px #0000001f}:root{--color-primary: #1d4ed8;--color-primary-dark: #1e3a8a;--color-primary-light: #dbeafe;--color-primary-subtle: #f0f4ff;--color-surface: #ffffff;--color-surface-elevated: #f9fafb;--color-surface-alt: #f8fafc;--color-surface-border: #e2e8f0;--color-text-primary: #1e293b;--color-text-secondary: #475569;--color-text-tertiary: #64748b;--color-text-on-primary: #ffffff;--color-border: #cbd5e1;--color-border-light: #e2e8f0;--color-border-medium: #94a3b8;--color-border-strong: #1d4ed8;--color-border-focus: #3b82f6;--color-success: #1d4ed8;--color-success-light: #dbeafe;--color-warning: #1e40af;--color-warning-light: #dbeafe;--color-error: #1e3a8a;--color-error-light: #dbeafe;--color-info: #1d4ed8;--color-info-light: #dbeafe;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .05);--shadow-md: 0 2px 4px rgba(15, 23, 42, .06);--shadow-lg: 0 4px 8px rgba(15, 23, 42, .08);--shadow-xl: 0 8px 16px rgba(15, 23, 42, .1);--shadow-2xl: 0 12px 24px rgba(15, 23, 42, .12);--spacing-xs: 2px;--spacing-sm: 4px;--spacing-md: 6px;--spacing-lg: 8px;--spacing-xl: 10px;--spacing-2xl: 14px;--spacing-3xl: 18px;--radius-sm: 3px;--radius-md: 5px;--radius-lg: 8px;--radius-xl: 10px;--radius-2xl: 12px;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--transition-fast: .12s ease-out;--transition-normal: .2s ease-out;--transition-slow: .3s ease-out;--z-overlay: 1000;--z-panel: 1010;--z-suggestions: 1005}.sp-overlay{position:absolute;inset:0;pointer-events:none;font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.sp-overlay *{box-sizing:border-box}.sp-control-panel{position:absolute;top:0;right:0;bottom:0;width:min(340px,100vw);pointer-events:auto;z-index:9999;background:var(--color-surface);border-left:1px solid var(--color-border-strong);border-radius:0;padding:var(--spacing-md);box-shadow:var(--shadow-xl);overflow-y:auto;animation:sp-panel-slide-in var(--transition-normal);background:linear-gradient(to left,var(--color-surface) 0%,var(--color-surface-elevated) 100%)}.sp-control-panel::-webkit-scrollbar{width:5px}.sp-control-panel::-webkit-scrollbar-track{background:var(--color-surface-alt)}.sp-control-panel::-webkit-scrollbar-thumb{background:var(--color-border-medium);border-radius:var(--radius-sm)}.sp-control-panel::-webkit-scrollbar-thumb:hover{background:var(--color-primary)}@keyframes sp-panel-slide-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.sp-panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-sm);padding-bottom:var(--spacing-md);margin-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border-light)}.sp-panel-header h3{margin:0;font-size:15px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);line-height:1.2;flex:1;letter-spacing:-.01em}.sp-capacity-badge{flex-shrink:0;min-width:100px;text-align:center;border-radius:var(--radius-md);color:var(--color-text-on-primary);padding:6px 8px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);border:1px solid var(--color-primary-dark)}.sp-capacity-badge .sp-capacity-label{font-size:11px;font-weight:var(--font-weight-medium);opacity:.95;display:block;line-height:1.1;margin-bottom:2px;letter-spacing:.03em;text-transform:uppercase}.sp-capacity-badge .sp-capacity-value{font-size:16px;font-weight:var(--font-weight-bold);display:block;line-height:1.1;letter-spacing:-.01em}.sp-controls-section{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.sp-control-group{display:flex;flex-direction:column;gap:4px}.sp-control-label{font-size:12px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);display:flex;align-items:center;gap:var(--spacing-xs)}.sp-control-label:before{content:"";width:3px;height:12px;background:linear-gradient(to bottom,var(--color-primary) 0%,var(--color-primary-dark) 100%);border-radius:2px}.sp-control-subtitle{font-size:11px;color:var(--color-text-secondary);line-height:1.3;margin-top:2px;padding-left:8px;font-style:italic}.sp-dimension-inputs,.sp-orientation-inputs{display:flex;align-items:center;gap:var(--spacing-xs)}.sp-layout-inputs{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xs)}.sp-input{width:100%;background:var(--color-surface);color:var(--color-text-primary);padding:6px 8px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:12px;font-weight:var(--font-weight-medium);transition:all var(--transition-fast)}.sp-input:focus{outline:none;border-color:var(--color-border-strong);box-shadow:0 0 0 2px var(--color-primary-light);background:var(--color-surface)}.sp-input:hover:not(:focus){border-color:var(--color-border-medium);background:var(--color-surface-elevated)}.sp-input::placeholder{color:var(--color-text-tertiary);font-weight:var(--font-weight-normal)}.sp-dimension-separator,.sp-orientation-separator{min-width:20px;text-align:center;color:var(--color-text-tertiary);font-weight:var(--font-weight-medium);font-size:12px}.sp-dimension-unit,.sp-orientation-unit{min-width:25px;color:var(--color-text-secondary);font-size:11px;font-weight:var(--font-weight-medium)}.sp-actions-section{display:flex;flex-direction:column;gap:var(--spacing-md);margin-top:auto;padding-top:var(--spacing-md);border-top:1px solid var(--color-border-light)}.sp-placement-controls,.sp-management-controls{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.sp-btn{--btn-height: 32px;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);height:var(--btn-height);padding:0 10px;border-radius:var(--radius-md);font-size:12px;font-weight:var(--font-weight-semibold);cursor:pointer;border:1px solid var(--color-border);transition:all var(--transition-fast);line-height:1;flex-shrink:0;letter-spacing:.01em;background:var(--color-surface);color:var(--color-text-primary)}.sp-btn:hover:not(:disabled){transform:translateY(-1px);border-color:var(--color-border-strong);box-shadow:var(--shadow-md);background:var(--color-surface-elevated)}.sp-btn:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-sm)}.sp-btn:focus-visible{outline:2px solid var(--color-border-strong);outline-offset:1px}.sp-btn:disabled{cursor:not-allowed;opacity:.4;transform:none!important;box-shadow:none!important;background:var(--color-surface-alt)!important;color:var(--color-text-tertiary)!important;border-color:var(--color-border)!important}.sp-btn-primary{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:var(--color-text-on-primary);border-color:var(--color-primary-dark)}.sp-btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary-dark) 0%,var(--color-primary) 100%);border-color:var(--color-primary)}.sp-btn-secondary{background:var(--color-surface);color:var(--color-text-primary);border-color:var(--color-border-strong)}.sp-btn-secondary:hover:not(:disabled){background:var(--color-primary-subtle);border-color:var(--color-primary);color:var(--color-primary-dark)}.sp-btn-success{background:var(--color-surface);color:var(--color-primary-dark);border-color:var(--color-border-strong)}.sp-btn-success:hover:not(:disabled){background:var(--color-primary-subtle);border-color:var(--color-primary)}.sp-btn-warning{background:var(--color-surface);color:var(--color-primary-dark);border-color:var(--color-border-strong)}.sp-btn-warning:hover:not(:disabled){background:var(--color-primary-subtle);border-color:var(--color-primary)}.sp-btn-danger{background:var(--color-surface);color:var(--color-primary-dark);border-color:var(--color-border-strong)}.sp-btn-danger:hover:not(:disabled){background:var(--color-primary-subtle);border-color:var(--color-primary)}.sp-btn-ghost{background:transparent;color:var(--color-text-secondary);border-color:var(--color-border)}.sp-btn-ghost:hover:not(:disabled){background:var(--color-surface-alt);border-color:var(--color-border-medium);color:var(--color-text-primary)}.sp-btn-icon{font-size:14px;display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px}.sp-hint-section{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border-light)}.sp-hint{font-size:12px;color:var(--color-text-primary);line-height:1.4;margin-bottom:var(--spacing-sm);padding:8px 10px;background:var(--color-primary-light);border-radius:var(--radius-md);border:1px solid var(--color-primary);border-left-width:4px}.sp-panel-count{font-size:12px;color:var(--color-text-tertiary);font-weight:var(--font-weight-medium);text-align:center;padding:8px;background:var(--color-surface-alt);border-radius:var(--radius-md);border:1px solid var(--color-border);margin-bottom:var(--spacing-md)}.sp-panel-count .sp-panel-type{color:var(--color-primary);font-weight:var(--font-weight-semibold);margin-left:var(--spacing-sm)}.sp-frame{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border-light)}.sp-frame-title{font-size:14px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-md) 0;display:flex;align-items:center;gap:var(--spacing-sm)}.sp-frame-title:before{content:"";width:8px;height:8px;background:var(--color-primary);border-radius:50%}.sp-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.sp-two{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm)}.sp-footer-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-sm);margin-top:var(--spacing-md)}.sp-summary-item{text-align:center;color:var(--color-text-primary);border-radius:var(--radius-md);padding:8px 6px;background:var(--color-surface);border:1px solid var(--color-border-strong);transition:var(--transition-fast)}.sp-summary-item:hover{transform:translateY(-2px);background:var(--color-primary-subtle);box-shadow:var(--shadow-md)}.sp-summary-value{font-weight:var(--font-weight-bold);font-size:15px;line-height:1.2;display:block;letter-spacing:-.01em;color:var(--color-primary-dark)}.sp-summary-label{font-size:11px;font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin-top:2px;display:block;letter-spacing:.04em;text-transform:uppercase}.sp-input-wrap{display:flex;flex-direction:column}.sp-input-wrap small.sp-hint{font-size:11px;color:var(--color-text-tertiary);margin-top:2px}.sp-suggestions-panel{position:absolute;right:calc(340px + var(--spacing-md));bottom:var(--spacing-md);width:min(300px,100vw - 360px);max-height:min(260px,45vh);pointer-events:auto;z-index:var(--z-suggestions);background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:var(--shadow-xl);animation:sp-panel-enter var(--transition-normal);overflow-y:auto}.sp-suggestions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.sp-suggestions-header h4{margin:0;font-size:13px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);display:flex;align-items:center;gap:var(--spacing-sm)}.sp-suggestions-header h4:before{content:"💡";font-size:14px;color:var(--color-primary)}.sp-close-suggestions{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-tertiary);font-size:16px;cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-sm);transition:var(--transition-fast);display:flex;align-items:center;justify-content:center;width:24px;height:24px}.sp-close-suggestions:hover{background:var(--color-surface-alt);color:var(--color-text-secondary);border-color:var(--color-border-medium)}.sp-suggestions-list{margin:0;padding:0;list-style:none}.sp-suggestion-item{display:flex;gap:var(--spacing-sm);padding:var(--spacing-sm) 0;font-size:12px;line-height:1.4;color:var(--color-text-secondary)}.sp-suggestion-item:not(:last-child){border-bottom:1px solid var(--color-border-light)}.sp-suggestion-icon{font-size:14px;color:var(--color-primary);flex-shrink:0;margin-top:2px;width:16px;text-align:center}.sp-floating-help{position:absolute;right:calc(340px + var(--spacing-md));bottom:var(--spacing-md);width:44px;height:44px;border:1px solid var(--color-border-strong);border-radius:50%;background:var(--color-surface);color:var(--color-primary);font-size:20px;cursor:pointer;pointer-events:auto;box-shadow:var(--shadow-xl);transition:all var(--transition-normal);display:flex;align-items:center;justify-content:center}.sp-floating-help:hover{transform:scale(1.08) rotate(10deg);box-shadow:var(--shadow-2xl);background:var(--color-primary-subtle);border-color:var(--color-primary)}.sp-floating-help:active{transform:scale(1.04)}@media(max-width:1024px){.sp-control-panel{width:min(320px,100vw)}.sp-suggestions-panel{right:calc(320px + var(--spacing-md));width:min(280px,100vw - 340px)}.sp-floating-help{right:calc(320px + var(--spacing-md))}}@media(max-width:768px){.sp-control-panel{position:fixed;inset:0;width:100%;max-height:100vh;border-radius:0;border:none;padding:var(--spacing-md);animation:sp-panel-slide-up var(--transition-normal)}@keyframes sp-panel-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.sp-suggestions-panel{position:fixed;left:var(--spacing-md);right:var(--spacing-md);bottom:var(--spacing-md);width:auto;max-height:min(240px,40vh);border-radius:var(--radius-md);padding:var(--spacing-md)}.sp-panel-header{flex-direction:column;align-items:stretch;gap:var(--spacing-sm)}.sp-panel-header .sp-capacity-badge{align-self:stretch}.sp-placement-controls,.sp-management-controls{flex-direction:column}.sp-placement-controls .sp-btn,.sp-management-controls .sp-btn{width:100%;justify-content:center}.sp-layout-inputs,.sp-grid-2{grid-template-columns:1fr}.sp-footer-summary{grid-template-columns:repeat(3,1fr)}.sp-floating-help{right:var(--spacing-md);bottom:var(--spacing-md)}}@media(max-width:480px){.sp-control-panel,.sp-suggestions-panel{padding:var(--spacing-sm)}.sp-btn{--btn-height: 36px;font-size:13px}.sp-input{padding:7px 9px;font-size:13px}.sp-footer-summary{grid-template-columns:1fr;gap:var(--spacing-sm)}}@media(prefers-color-scheme:dark){:root{--color-surface: #0f172a;--color-surface-elevated: #1e293b;--color-surface-alt: #334155;--color-surface-border: #475569;--color-text-primary: #f1f5f9;--color-text-secondary: #cbd5e1;--color-text-tertiary: #94a3b8;--color-border: #475569;--color-border-light: #334155;--color-border-medium: #64748b;--color-border-strong: #3b82f6;--color-primary-subtle: #1e293b;--color-primary-light: rgba(59, 130, 246, .2)}.sp-control-panel{background:linear-gradient(to left,var(--color-surface) 0%,var(--color-surface-elevated) 100%);border-left-color:var(--color-border-strong);box-shadow:var(--shadow-2xl)}.sp-suggestions-panel{box-shadow:var(--shadow-lg);border-color:var(--color-border-strong)}.sp-input{background:var(--color-surface-elevated);color:var(--color-text-primary)}.sp-input:focus{background:var(--color-surface-elevated)}.sp-hint{background:var(--color-primary-light);border-color:var(--color-border-strong)}.sp-summary-item{background:var(--color-surface-elevated);border-color:var(--color-border-strong)}.sp-summary-item:hover{background:var(--color-primary-subtle)}.sp-btn{background:var(--color-surface-elevated);border-color:var(--color-border)}.sp-btn:hover:not(:disabled){background:var(--color-surface-alt);border-color:var(--color-border-strong)}.sp-btn-primary{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:var(--color-text-on-primary);border-color:var(--color-primary-dark)}.sp-btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary-dark) 0%,var(--color-primary) 100%);border-color:var(--color-primary-dark)}}.layout-popover{position:absolute;color:#000;top:150px;right:16px;width:220px;background:#fff;border:1px solid #d8dde6;border-radius:10px;box-shadow:0 8px 24px #0000001f;padding:10px;z-index:20;font-family:system-ui,sans-serif}.layout-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.layout-header .title{font-weight:600}.layout-header .close{background:transparent;border:0;cursor:pointer;font-size:14px;color:#000}.layout-actions .action{width:100%;padding:8px 10px;border-radius:8px;border:1px solid #0b3653;background:#0b3653;color:#fff;cursor:pointer}.inverter-ui{position:absolute;top:0;right:0;bottom:0;background:#fff;border-radius:8px;padding:12px;z-index:9999;width:240px;font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;box-shadow:0 4px 12px #0f172a1a}.inverter-ui .title{font-weight:600;margin-bottom:16px;color:#1e293b;font-size:14px;position:relative;padding-left:10px}.inverter-ui .title:before{content:"";position:absolute;left:0;top:3px;width:3px;height:14px;border-radius:2px;background:#1d4ed8}.inverter-ui .hint{font-size:12px;color:#64748b;margin-bottom:12px;line-height:1.4}.inverter-ui .finish{width:100%;padding:8px 10px;border-radius:6px;border:1px solid #1d4ed8;background:#fff;color:#1d4ed8;cursor:pointer;font-weight:600;font-size:12px;transition:all .15s ease;display:flex;align-items:center;justify-content:center;margin-top:10px}.inverter-ui .finish:hover{background:#f0f4ff;transform:translateY(-1px);box-shadow:0 4px 12px #1d4ed826}.inverter-ui .finish:active{transform:translateY(0)}.inverter-ui:before{content:"";position:absolute;inset-inline:0;top:0;height:2px;pointer-events:none}@media(prefers-color-scheme:dark){.inverter-ui{background:#0f172a;border-color:#1d4ed8;box-shadow:0 4px 12px #00000040}.inverter-ui .title{color:#e2e8f0}.inverter-ui .title:before{background:#1d4ed8}.inverter-ui .hint{color:#94a3b8}.inverter-ui .finish{background:#1e293b;border-color:#1d4ed8;color:#1d4ed8}.inverter-ui .finish:hover{background:#334155}.inverter-ui:before{background:#1d4ed8}}@media(max-width:768px){.inverter-ui{width:220px;right:12px;bottom:280px}}@media(max-width:480px){.inverter-ui{width:200px;right:8px;bottom:260px}}.blockers-placer{position:absolute;top:0;right:0;bottom:0;width:320px;display:flex;flex-direction:column;overflow:hidden;z-index:9999;background:#fff;color:#1e293b;box-shadow:0 18px 50px #0f172a26}.blockers-placer *{box-sizing:border-box;min-width:0}.blockers-placer:before{content:"";position:absolute;inset-inline:0;top:0;height:2px;pointer-events:none}.blockers-header{display:flex;flex-wrap:wrap;align-items:center;gap:8px 10px;padding:14px 16px;background:#f8fafc;border-bottom:1px solid #e2e8f0}.blockers-header h2{margin:0;font-size:15px;font-weight:700;color:#1e293b;letter-spacing:.02em;position:relative;padding-left:10px;flex:1 1 auto;min-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.blockers-header h2:before{content:"";position:absolute;left:0;top:3px;width:3px;height:14px;border-radius:2px;background:#1d4ed8}.blockers-header .header-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center;justify-content:flex-end;flex:0 1 auto;max-width:100%}.blockers-header .header-actions .move-toggle,.blockers-header .header-actions .close-btn,.blockers-header .header-actions .undo-btn,.blockers-header .header-actions .redo-btn{border:1px solid #cbd5e1;background:#fff;color:#1e293b;padding:8px 10px;border-radius:8px;cursor:pointer;font-size:12px;font-weight:600;transition:all .18s ease;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.blockers-header .header-actions .move-toggle:hover,.blockers-header .header-actions .close-btn:hover,.blockers-header .header-actions .undo-btn:hover,.blockers-header .header-actions .redo-btn:hover{background:#f0f4ff;border-color:#1d4ed8;transform:translateY(-1px)}.blockers-header .header-actions .move-toggle:active,.blockers-header .header-actions .close-btn:active,.blockers-header .header-actions .undo-btn:active,.blockers-header .header-actions .redo-btn:active{transform:translateY(0)}.blockers-header .header-actions .move-toggle:disabled,.blockers-header .header-actions .close-btn:disabled,.blockers-header .header-actions .undo-btn:disabled,.blockers-header .header-actions .redo-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none;background:#f8fafc;border-color:#e2e8f0}.blockers-header .header-actions .undo-btn,.blockers-header .header-actions .redo-btn{padding:7px 10px;line-height:1}.blockers-header .header-actions .undo-btn:hover:not(:disabled),.blockers-header .header-actions .redo-btn:hover:not(:disabled){border-color:#1d4ed8;box-shadow:0 6px 16px #1d4ed826}.blockers-header .header-actions .undo-btn:before{content:"⮪";font-size:13px;line-height:1;color:#1d4ed8}.blockers-header .header-actions .redo-btn:before{content:"⮫";font-size:13px;line-height:1;color:#1d4ed8}.blockers-header .header-actions .move-toggle.active{background:#1d4ed8;border-color:#1d4ed8;color:#fff;box-shadow:0 6px 16px #1d4ed840}.blockers-header .header-actions .close-btn{width:34px;height:34px;padding:0;justify-content:center;color:#64748b}.blockers-header .header-actions .close-btn:hover{background:#f0f4ff;color:#1d4ed8;border-color:#1d4ed8}.selected-blocker-controls{padding:14px 16px;background:#f8fafc;border-bottom:1px solid #e2e8f0;animation:slideDown .25s ease-out}.selected-blocker-controls h3{margin:0 0 10px;font-size:13px;font-weight:700;color:#1e293b;letter-spacing:.02em}.selected-blocker-controls .control-buttons{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.selected-blocker-controls .control-buttons .delete-btn{background:#fff;color:#1d4ed8;border:1px solid #1d4ed8;padding:8px 12px;border-radius:8px;cursor:pointer;font-size:12px;font-weight:700;transition:all .18s ease;display:inline-flex;align-items:center;gap:6px}.selected-blocker-controls .control-buttons .delete-btn:hover{background:#f0f4ff;transform:translateY(-1px);box-shadow:0 6px 16px #1d4ed826}.selected-blocker-controls .control-buttons .delete-btn:active{transform:translateY(0)}.selected-blocker-controls .control-buttons .rotate-btn{background:#fff;color:#1d4ed8;border:1px solid #1d4ed8;padding:8px 10px;border-radius:8px;cursor:pointer;font-size:11px;font-weight:700;transition:all .18s ease}.selected-blocker-controls .control-buttons .rotate-btn:hover{background:#f0f4ff;transform:translateY(-1px);box-shadow:0 6px 16px #1d4ed826}.selected-blocker-controls .control-buttons .rotate-btn:active{transform:translateY(0)}.blockers-types{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;padding:16px;overflow-y:auto;background:#fff}.blocker-type-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:14px 10px;min-height:88px;background:#fff;border:1px solid #cbd5e1;border-radius:12px;cursor:pointer;transition:all .18s ease}.blocker-type-btn .icon{font-size:26px;color:#1d4ed8}.blocker-type-btn .label{font-size:12.5px;font-weight:600;color:#1e293b;text-align:center;letter-spacing:.02em;white-space:nowrap}.blocker-type-btn:hover{background:#f0f4ff;border-color:#1d4ed8;transform:translateY(-2px);box-shadow:0 10px 24px #1d4ed81a}.blocker-type-btn.active{background:#f0f4ff;border-color:#1d4ed8;box-shadow:0 10px 26px #1d4ed826}.blocker-type-btn.active .label,.blocker-type-btn.active .icon{color:#1d4ed8}.blocker-type-btn:disabled{opacity:.5;cursor:not-allowed}.blocker-type-btn:disabled:hover{transform:none;background:#fff;border-color:#cbd5e1;box-shadow:none}.blocker-type-btn .new-badge{background:#1d4ed8;color:#fff;font-size:.65rem;font-weight:700;padding:2px 5px;border-radius:4px;margin-left:6px;letter-spacing:.5px;position:relative;top:-1px}.blocker-settings{padding:16px;background:#f8fafc;border-top:1px solid #e2e8f0;max-height:260px;overflow-y:auto}.blocker-settings h3{margin:0 0 12px;font-size:14px;font-weight:700;color:#1e293b;letter-spacing:.02em}.blocker-settings label{display:block;margin-bottom:14px;font-size:12.5px;font-weight:600;color:#475569}.blocker-settings label input[type=range]{width:100%;margin-top:10px;height:6px;border-radius:3px;background:#e2e8f0;outline:none;-webkit-appearance:none}.blocker-settings label input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#fff;border:2px solid #1d4ed8;cursor:pointer;box-shadow:0 2px 6px #1d4ed833;transition:transform .1s ease}.blocker-settings label input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.08);background:#f0f4ff}.blocker-settings label input[type=range]::-moz-range-track{height:6px;background:#e2e8f0;border-radius:3px}.blocker-settings label input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#fff;border:2px solid #1d4ed8;cursor:pointer;box-shadow:0 2px 6px #1d4ed833}.blocker-settings .draw-instructions{background:#f0f4ff;border:1px solid #1d4ed8;border-radius:10px;padding:12px}.blocker-settings .draw-instructions p{margin:0 0 8px;font-size:12.5px;color:#1d4ed8;line-height:1.55}.blocker-settings .draw-instructions p:last-child{margin-bottom:0}.blockers-help{padding:14px 16px;background:#f8fafc;border-top:1px solid #e2e8f0}.blockers-help p{margin:0;font-size:12.5px;color:#64748b;line-height:1.55}.blockers-help .rotation-help{margin-top:8px;padding:8px 12px;background:#f0f4ff;border:1px solid #1d4ed8;border-radius:8px;color:#1d4ed8;font-size:12px;font-weight:700}.blockers-help .rotation-help:before{content:"💡 "}.blockers-types::-webkit-scrollbar,.blocker-settings::-webkit-scrollbar{width:6px}.blockers-types::-webkit-scrollbar-track,.blocker-settings::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.blockers-types::-webkit-scrollbar-thumb,.blocker-settings::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.blockers-types::-webkit-scrollbar-thumb:hover,.blocker-settings::-webkit-scrollbar-thumb:hover{background:#94a3b8}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@media(max-height:700px){.blockers-placer{max-height:calc(100vh - 80px)}.blockers-types{max-height:300px}.blocker-settings{max-height:220px}}@media(max-width:480px){.blockers-placer{width:280px;right:10px;top:10px}.blockers-header{padding:12px}.blockers-header .header-actions{gap:6px}.blockers-types{grid-template-columns:repeat(2,1fr);gap:8px;padding:12px}.blocker-type-btn{padding:12px 8px;min-height:80px}.blocker-type-btn .icon{font-size:24px}.blocker-type-btn .label{font-size:12px}.selected-blocker-controls{padding:12px}.selected-blocker-controls .control-buttons{gap:6px}.selected-blocker-controls .control-buttons .delete-btn,.selected-blocker-controls .control-buttons .rotate-btn{padding:6px 8px;font-size:11px}}@media(prefers-color-scheme:dark){.blockers-placer{background:#0f172a;border-color:#1d4ed8;color:#e2e8f0}.blockers-header{background:#1e293b;border-bottom-color:#334155}.blockers-header h2{color:#e2e8f0}.blockers-header h2:before{background:#1d4ed8}.blockers-header .header-actions .move-toggle,.blockers-header .header-actions .close-btn,.blockers-header .header-actions .undo-btn,.blockers-header .header-actions .redo-btn{background:#1e293b;border-color:#475569;color:#e2e8f0}.blockers-header .header-actions .move-toggle:hover,.blockers-header .header-actions .close-btn:hover,.blockers-header .header-actions .undo-btn:hover,.blockers-header .header-actions .redo-btn:hover{background:#334155;border-color:#1d4ed8}.blockers-header .header-actions .move-toggle:disabled,.blockers-header .header-actions .close-btn:disabled,.blockers-header .header-actions .undo-btn:disabled,.blockers-header .header-actions .redo-btn:disabled{background:#1e293b;border-color:#475569}.blockers-header .header-actions .move-toggle.active{background:#1d4ed8;border-color:#1d4ed8;color:#fff}.selected-blocker-controls{background:#1e293b;border-bottom-color:#334155}.selected-blocker-controls h3{color:#e2e8f0}.selected-blocker-controls .delete-btn,.selected-blocker-controls .rotate-btn{background:#1e293b;border-color:#1d4ed8;color:#e2e8f0}.selected-blocker-controls .delete-btn:hover,.selected-blocker-controls .rotate-btn:hover{background:#334155}.blockers-types{background:#0f172a}.blocker-type-btn{background:#1e293b;border-color:#475569;color:#e2e8f0}.blocker-type-btn .icon{color:#1d4ed8}.blocker-type-btn .label{color:#e2e8f0}.blocker-type-btn:hover{background:#334155;border-color:#1d4ed8}.blocker-type-btn.active{background:#1e293b;border-color:#1d4ed8}.blocker-type-btn.active .label,.blocker-type-btn.active .icon{color:#1d4ed8}.blocker-settings{background:#1e293b;border-top-color:#334155}.blocker-settings h3{color:#e2e8f0}.blocker-settings label{color:#cbd5e1}.blocker-settings input[type=range]{background:#475569}.blocker-settings input[type=range]::-webkit-slider-thumb{background:#1e293b;border-color:#1d4ed8}.blocker-settings .draw-instructions{background:#1d4ed81a;border-color:#1d4ed8}.blocker-settings .draw-instructions p{color:#1d4ed8}.blockers-help{background:#1e293b;border-top-color:#334155}.blockers-help p{color:#94a3b8}.blockers-help .rotation-help{background:#1d4ed81a;border-color:#1d4ed8;color:#1d4ed8}.blockers-types::-webkit-scrollbar-track,.blocker-settings::-webkit-scrollbar-track{background:#1e293b}.blockers-types::-webkit-scrollbar-thumb,.blocker-settings::-webkit-scrollbar-thumb{background:#475569}}.page-header{display:flex;align-items:center;justify-content:space-between;padding:12px;background:#fff;color:#cfd6e4;border-bottom:1px solid rgba(255,255,255,.06)}.breadcrumbs{font-size:14px;display:flex;align-items:center;gap:6px}.breadcrumbs a{color:#000;text-decoration:none}.breadcrumbs a:hover{text-decoration:underline}.solar-logo{height:40px;cursor:pointer;transition:transform .2s ease}.solar-logo:hover{transform:scale(1.05)}.View3DPage{position:relative}.compass-overlay{position:absolute;top:64px;right:16px;z-index:30;pointer-events:none}.compass{width:84px;height:84px}.statuss-bar{position:absolute;bottom:0;right:.01%;background:#2b2b2ba8;color:#f9fafb;padding:6px 14px;font-size:12.5px;letter-spacing:.2px;z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;flex-direction:column;align-items:flex-end;gap:2px;width:100%}.statuss-coords{display:flex;justify-content:flex-end;align-items:center;font-size:11px;color:#fff;opacity:.95;white-space:nowrap;width:100%}.users-page{display:grid;grid-template-columns:320px 1fr;height:100vh}.users-list{border-right:1px solid #e5e7eb;padding:12px;overflow:auto;background:#fafafa}.users-list .users-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.users-list .users-header h2{margin:0;font-size:18px}.users-list .users-header .back-link{font-size:12px;color:#4f46e5;text-decoration:none}.users-list ul{list-style:none;margin:0;padding:0}.users-list li+li{margin-top:6px}.users-list .user-row{width:100%;text-align:left;border:1px solid #e5e7eb;border-radius:8px;background:#fff;padding:8px 10px;cursor:pointer}.users-list .user-row .user-name{font-weight:600}.users-list .user-row .user-meta{font-size:12px;opacity:.7}.users-list .user-row.active{outline:2px solid #6366f1}.users-main{padding:12px;overflow:hidden}.users-main .models-header{margin-bottom:8px}.users-main .models-header h2{margin:0;font-size:18px}.users-main .models-layout{display:grid;grid-template-columns:280px 1fr;gap:12px;height:calc(100vh - 56px)}.users-main .models-list{border-right:1px solid #e5e7eb;padding-right:12px;overflow:auto}.users-main .models-list h3{margin:8px 0}.users-main .models-list ul{list-style:none;padding:0;margin:0}.users-main .models-list li+li{margin-top:6px}.users-main .models-list .model-row{width:100%;display:flex;justify-content:space-between;align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:8px 10px;cursor:pointer}.users-main .models-list .model-row .date{font-size:12px;opacity:.75}.users-main .models-list .model-row.active{outline:2px solid #6366f1}.users-main .viewer{overflow:hidden;display:flex;flex-direction:column;gap:8px}.users-main .viewer .viewer-header{display:flex;align-items:center;justify-content:space-between}.users-main .viewer .open-map{text-decoration:none;color:#4f46e5;font-weight:600}.muted{color:#6b7280}.muted.small{font-size:12px}.error{color:#b91c1c}.CustomerPage{padding:0 20px 40px;max-width:1400px;margin:0 auto;padding:0 clamp(16px,5vw,48px) 40px;position:relative;min-height:100vh;overflow:visible}.CustomerPage .page-header{height:56px;display:grid;grid-template-columns:1fr auto;align-items:center;border-bottom:1px solid #e5e7eb;margin-bottom:10px}.CustomerPage .page-header .brand-logo{height:50px;width:auto;object-fit:contain}.CustomerPage .topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin:12px 0 8px}.CustomerPage .topbar .breadcrumbs{color:#6b7280;display:flex;align-items:center;gap:8px}.CustomerPage .topbar .breadcrumbs a{color:#4b5563;text-decoration:none}.CustomerPage .topbar .breadcrumbs span{color:#9ca3af}.CustomerPage .topbar .page-actions .btn.primary{background:#2563eb;color:#fff;border:0;padding:10px 14px;border-radius:10px;cursor:pointer}.CustomerPage .title{font-size:24px;margin:8px 0 16px;font-weight:700}.CustomerPage .card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:16px;margin-bottom:18px;box-shadow:0 2px 8px #0000000a}.CustomerPage .card .card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.CustomerPage .card .card-header h2{margin:0;font-size:16px}.CustomerPage .btn{background:#f3f4f6;border:1px solid #e5e7eb;padding:6px 10px;border-radius:10px;cursor:pointer}.CustomerPage .btn.xs{padding:4px 8px;font-size:12px}.CustomerPage .btn.lg{padding:10px 18px;font-weight:600}.CustomerPage .btn.primary{background:#3b82f6;color:#fff;border-color:#3b82f6}.CustomerPage .link-btn{background:transparent;border:0;color:#2563eb;cursor:pointer}.CustomerPage .icon-btn{background:transparent;border:0;cursor:pointer;font-size:16px;padding:4px}.CustomerPage .muted{color:#6b7280}.CustomerPage .error{color:#dc2626}.CustomerPage .project-info .info-grid{display:grid;grid-template-columns:1.2fr 1.2fr 1fr 200px;gap:18px;align-items:start}@media(max-width:1100px){.CustomerPage .project-info .info-grid{grid-template-columns:1fr 1fr}}@media(max-width:700px){.CustomerPage .project-info .info-grid{grid-template-columns:1fr}}.CustomerPage .project-info .info-col{display:grid;gap:10px}.CustomerPage .project-info .info-row{display:grid;grid-template-columns:160px 1fr auto;gap:8px;align-items:center}.CustomerPage .project-info .info-row.multiline{align-items:start}.CustomerPage .project-info .info-row .label{color:#6b7280}.CustomerPage .project-info .info-row .value{white-space:pre-wrap}.CustomerPage .project-info .map-thumb .map-box{width:200px;height:200px;border-radius:12px;overflow:hidden;background:#eef2ff;display:grid;place-items:center;color:#4f46e5;font-weight:600;border:1px solid #e5e7eb}.CustomerPage .documents .doc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:16px}.CustomerPage .documents .doc-uploader{border:2px dashed #cbd5e1;border-radius:14px;display:grid;place-items:center;padding:22px;min-height:140px;cursor:pointer;background:#f8fafc}.CustomerPage .documents .doc-uploader .plus{font-size:28px;line-height:1}.CustomerPage .documents .doc-uploader .label{color:#6b7280;margin-top:6px}.CustomerPage .documents .doc-card{display:grid;grid-template-columns:48px 1fr auto;gap:12px;align-items:center;border:1px solid #e5e7eb;border-radius:14px;padding:12px}.CustomerPage .documents .doc-card .doc-icon{font-size:28px}.CustomerPage .documents .doc-card .doc-meta .doc-name{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.CustomerPage .documents .doc-card .doc-meta .doc-size{color:#6b7280;font-size:12px}.CustomerPage .documents .doc-card .doc-actions{display:flex;gap:8px}.CustomerPage .modal-overlay{position:fixed;inset:0;background:#00000073;display:grid;place-items:center;z-index:50}.CustomerPage .preview-sheet{width:min(1000px,92vw);height:min(700px,80vh);background:#fff;border-radius:14px;overflow:hidden;border:1px solid #e5e7eb;box-shadow:0 10px 30px #00000040;display:grid;place-items:center}.CustomerPage .preview-sheet .no-preview{color:#6b7280}.CustomerPage .dialog-sheet{width:min(680px,92vw);background:#fff;border-radius:12px;border:1px solid #e5e7eb;box-shadow:0 10px 30px #00000040;padding:16px}.CustomerPage .dialog-sheet .dialog-header{display:flex;align-items:center;justify-content:space-between;padding:4px 2px 14px;border-bottom:1px solid #eef2f7;margin-bottom:14px}.CustomerPage .dialog-sheet .dialog-header .dialog-title{font-weight:700}.CustomerPage .dialog-sheet .form-col{display:grid;gap:6px;margin:12px 2px}.CustomerPage .dialog-sheet .form-col .field-label{font-weight:600;color:#374151}.CustomerPage .dialog-sheet .form-col .required{color:#ef4444;margin-left:2px}.CustomerPage .dialog-sheet .form-col .info-dot{display:inline-grid;place-items:center;width:16px;height:16px;font-size:12px;border-radius:50%;border:1px solid #9ca3af;color:#6b7280;margin-left:6px}.CustomerPage .dialog-sheet .form-col .field-input{height:42px;padding:8px 12px;border:1px solid #e5e7eb;border-radius:10px;background:#eef2f7;outline:none}.CustomerPage .dialog-sheet .form-col select.field-input{height:44px}.CustomerPage .dialog-sheet .dialog-actions{display:grid;place-items:center;margin-top:8px}.map-thumb{width:100%;height:100%;min-height:240px}.map-embed{width:100%;height:100%;min-height:240px;border:0;border-radius:12px;box-shadow:0 2px 10px #00000014}.map-fallback{display:grid;place-items:center;width:100%;height:100%;min-height:240px;background:repeating-linear-gradient(45deg,#f6f7f9,#f6f7f9 10px,#f0f1f4 10px 20px);border-radius:12px;color:#555}.map-fallback-inner{text-align:center}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}@keyframes dialogIn{0%{transform:translateY(10px) scale(.985);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.dialog-sheet.edit{width:min(900px,94vw);max-height:86vh;display:grid;grid-template-rows:auto 1fr auto;padding:0;animation:dialogIn .16s ease-out both}.dialog-sheet.edit .dialog-header{padding:14px 18px;border-bottom:1px solid #eef2f7}.dialog-sheet.edit .dialog-header .dialog-title{font-size:18px;font-weight:700}.dialog-sheet.edit .dialog-header .close{opacity:.7}.dialog-sheet.edit .dialog-header .close:hover{opacity:1}.dialog-sheet.edit .edit-body{padding:16px 18px;overflow:auto}.dialog-sheet.edit .edit-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}@media(max-width:860px){.dialog-sheet.edit .edit-grid{grid-template-columns:1fr}}.dialog-sheet.edit .form-col{display:grid;gap:10px}.dialog-sheet.edit .grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}@media(max-width:520px){.dialog-sheet.edit .grid2{grid-template-columns:1fr}}.dialog-sheet.edit .field{display:grid;gap:6px}.dialog-sheet.edit .field span{font-size:12px;color:#4b5563;font-weight:600;letter-spacing:.1px}.dialog-sheet.edit .field .input{height:42px;padding:10px 12px;border:1px solid #e5e7eb;border-radius:10px;background:#f9fafb;outline:none;transition:border-color .12s ease,box-shadow .12s ease,background .12s ease}.dialog-sheet.edit .field .input:hover{background:#f3f4f6}.dialog-sheet.edit .field .input:focus{border-color:#3b82f6;box-shadow:0 0 0 4px #3b82f61f;background:#fff}.dialog-sheet.edit .field input[type=number]{-moz-appearance:textfield}.dialog-sheet.edit .field input[type=number]::-webkit-outer-spin-button,.dialog-sheet.edit .field input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.dialog-sheet.edit .banner.error{margin-top:8px;padding:10px 12px;background:#fee2e2;color:#991b1b;border:1px solid #fecaca;border-radius:10px;font-size:13px}.dialog-sheet.edit .dialog-actions.sticky{position:sticky;bottom:0;background:linear-gradient(to bottom,#ffffffe6,#fff);border-top:1px solid #eef2f7;padding:12px 16px;display:flex;justify-content:flex-end;gap:10px}.dialog-sheet .btn{transition:transform .1s ease,box-shadow .12s ease}.dialog-sheet .btn:hover{transform:translateY(-1px);box-shadow:0 4px 10px #00000014}.dialog-sheet.edit .autocomplete__wrapper{position:relative}.dialog-sheet.edit .autocomplete__wrapper .autocomplete__spinner{position:absolute;right:10px;top:50%;transform:translateY(-50%);width:16px;height:16px;border:2px solid #cbd5e1;border-top-color:#64748b;border-radius:50%;animation:spinner .6s linear infinite;pointer-events:none}.dialog-sheet.edit .autocomplete__list{position:absolute;z-index:60;top:calc(100% + 6px);left:0;right:0;max-height:260px;overflow:auto;background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 12px 24px #0000001f;padding:6px;margin:0;list-style:none}.dialog-sheet.edit .autocomplete__list>li+li{border-top:1px solid #f1f5f9}.dialog-sheet.edit .autocomplete__item{display:grid;grid-template-columns:1fr auto;gap:6px;padding:10px;border-radius:8px;cursor:pointer}.dialog-sheet.edit .autocomplete__item .item__main{font-weight:600;color:#111827;line-height:1.2}.dialog-sheet.edit .autocomplete__item .item__secondary{color:#6b7280;font-size:12px;align-self:center;justify-self:end;white-space:nowrap;max-width:45%;overflow:hidden;text-overflow:ellipsis}.dialog-sheet.edit .autocomplete__item:hover{background:#f3f4f6}.dialog-sheet.edit .autocomplete__item.is-active{background:#e0ecff;outline:2px solid #3b82f6;outline-offset:-2px}.dialog-sheet.edit .autocomplete__list::-webkit-scrollbar{width:10px}.dialog-sheet.edit .autocomplete__list::-webkit-scrollbar-track{background:transparent}.dialog-sheet.edit .autocomplete__list::-webkit-scrollbar-thumb{background:#e5e7eb;border-radius:8px}.dialog-sheet.edit .autocomplete__list::-webkit-scrollbar-thumb:hover{background:#d1d5db}@keyframes spinner{to{transform:translateY(-50%) rotate(360deg)}}.save-location-bar{margin-top:10px;padding:8px 10px;border:1px solid #e5e7eb;border-radius:10px;background:#fafafa;display:grid;grid-template-columns:1fr auto;align-items:center;gap:10px}.save-location-bar .coords{display:flex;gap:10px;font-size:12px;color:#374151}.save-location-bar .actions{display:flex;gap:8px}.designs .design-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.designs .design-card{border:1px solid #e5e7eb;border-radius:14px;overflow:hidden;background:#fff;display:flex;flex-direction:column;transition:transform .1s ease,box-shadow .1s ease}.designs .design-card:hover{transform:translateY(-2px);box-shadow:0 4px 14px #00000014}.designs .design-card .thumb{height:180px;background:#f3f4f6;position:relative;cursor:pointer}.designs .design-card .thumb .map-thumb.real{position:relative;width:100%;height:100%;border-radius:0}.designs .design-card .thumb .map-thumb.real .map-embed-wrapper{position:absolute;inset:0;pointer-events:none;z-index:0}.designs .design-card .thumb .map-thumb.real .map-actions{position:absolute;top:8px;right:8px;display:flex;gap:6px;z-index:3}.designs .design-card .thumb .map-thumb.real .map-actions .icon-btn{background:#ffffffeb;border:1px solid #e5e7eb;border-radius:10px;padding:6px;box-shadow:0 2px 8px #00000014;font-size:16px}.designs .design-card .thumb .map-thumb.real .map-actions .icon-btn:hover{background:#fff;box-shadow:0 3px 10px #0000001f}.designs .design-card .thumb .map-thumb.real .map-info-overlay{position:absolute;bottom:8px;left:8px;right:8px;z-index:2;background:#ffffffe6;border-radius:8px;padding:6px 8px;display:flex;flex-direction:column;gap:2px}.designs .design-card .thumb .map-thumb.real .map-info-overlay .design-title{font-weight:600;font-size:13px;color:#111827;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.designs .design-card .thumb .map-thumb.real .map-info-overlay .design-date{font-size:12px;color:#6b7280}.designs .design-card .thumb .map-thumb.real .map-badges{position:absolute;left:8px;right:8px;top:8px;display:flex;gap:6px;flex-wrap:wrap;z-index:1}.designs .design-card .thumb .map-thumb.real .map-badges span{background:#ffffffe6;border-radius:6px;padding:2px 6px;font-size:12px;width:fit-content}.designs .design-card .thumb .map-thumb.real .click-capture{position:absolute;inset:0;z-index:1}.designs .design-card .design-meta{display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:10px 12px;border-top:1px solid #f3f4f6}.designs .design-card .design-meta .name{font-weight:600;font-size:14px;color:#111827}.designs .design-card .design-meta .subtle{font-size:12px;color:#6b7280}.designs .design-card .design-meta .actions{margin-top:6px;display:flex;gap:8px}.designs .design-card .design-meta .actions .icon-btn{background:transparent;border:none;cursor:pointer;font-size:16px}.designs .design-card .design-meta .actions .icon-btn:hover{color:#2563eb}.designs .design-add{border:2px dashed #cbd5e1;border-radius:14px;background:#f8fafc;padding:22px;min-height:160px;display:grid;place-items:center;font-weight:600;cursor:pointer;transition:background .15s ease}.designs .design-add .plus{font-size:28px;line-height:1;margin-bottom:4px}.designs .design-add:hover{background:#f1f5f9}.empty-badge{background:#ff6b6b;color:#fff;padding:2px 6px;border-radius:4px;font-size:.7em;font-weight:700}.empty-hint{font-size:.8em;color:#666;font-style:italic;margin-top:4px}html.customer-scroll,body.customer-scroll,#root.customer-scroll{height:auto!important;min-height:100vh;overflow-y:auto!important}.AddCustomerPage{padding:0 20px 40px;min-height:100vh;display:flex;justify-content:center}.AddCustomerPage .AddCustomerPage__inner{width:100%;max-width:1100px;margin:0 auto}.AddCustomerPage .page-header{height:56px;display:grid;grid-template-columns:1fr auto;align-items:center;border-bottom:1px solid #e5e7eb;margin-bottom:10px}.AddCustomerPage .page-header .brand-logo{height:45px;width:auto;object-fit:contain}.AddCustomerPage .title{font-size:24px;margin:16px 0;font-weight:700}.AddCustomerPage .card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:18px;box-shadow:0 2px 8px #0000000a}.AddCustomerPage .customer-form .grid{display:grid;grid-template-columns:repeat(3,minmax(220px,1fr));gap:14px}@media(max-width:1100px){.AddCustomerPage .customer-form .grid{grid-template-columns:repeat(2,minmax(220px,1fr))}}@media(max-width:700px){.AddCustomerPage .customer-form .grid{grid-template-columns:1fr}}.AddCustomerPage .customer-form .field{display:grid;gap:6px;position:relative}.AddCustomerPage .customer-form .field.wide{grid-column:1/-1}.AddCustomerPage .customer-form .field span{font-size:13px;color:#374151}.AddCustomerPage .customer-form .field .input{height:42px;border:1px solid #e5e7eb;border-radius:10px;padding:8px 12px;background:#f8fafc;outline:none;transition:border-color .12s ease,box-shadow .12s ease,background .12s ease}.AddCustomerPage .customer-form .field .input:hover{border-color:#d1d5db}.AddCustomerPage .customer-form .field .input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26;background:#fff}.AddCustomerPage .customer-form .field .input.input--error{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261f;background:#fff5f5}.AddCustomerPage .customer-form .field input[type=datetime-local]{height:42px}.AddCustomerPage .customer-form .field .autocomplete__wrapper{position:relative;z-index:1}.AddCustomerPage .customer-form .field .autocomplete__list{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:6px 0;box-shadow:0 10px 20px #00000014,0 2px 6px #0000000f;max-height:280px;overflow-y:auto;list-style:none;margin:0;z-index:50}.AddCustomerPage .customer-form .field .autocomplete__item{padding:10px 12px;cursor:pointer;display:grid;gap:2px;transition:background .12s ease}.AddCustomerPage .customer-form .field .autocomplete__item:hover{background:#f3f4f6}.AddCustomerPage .customer-form .field .autocomplete__item.is-active{background:#e8f0fe}.AddCustomerPage .customer-form .field .autocomplete__item .item__main{font-size:14px;color:#111827;font-weight:500;line-height:1.2}.AddCustomerPage .customer-form .field .autocomplete__item .item__secondary{font-size:12px;color:#6b7280;line-height:1.2}.AddCustomerPage .customer-form .field .autocomplete__list::-webkit-scrollbar{width:10px}.AddCustomerPage .customer-form .field .autocomplete__list::-webkit-scrollbar-thumb{background:#e5e7eb;border-radius:8px}.AddCustomerPage .customer-form .field .autocomplete__list::-webkit-scrollbar-thumb:hover{background:#d1d5db}.AddCustomerPage .customer-form .actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}.AddCustomerPage .customer-form .actions .btn{background:#f3f4f6;border:1px solid #e5e7eb;padding:10px 14px;border-radius:10px;cursor:pointer;transition:background .12s ease,border-color .12s ease,box-shadow .12s ease}.AddCustomerPage .customer-form .actions .btn:hover{background:#edeff2}.AddCustomerPage .customer-form .actions .btn:active{transform:translateY(.5px)}.AddCustomerPage .customer-form .actions .btn.primary{background:#2563eb;color:#fff;border-color:#2563eb;font-weight:600}.AddCustomerPage .customer-form .actions .btn.primary:hover{background:#1d4ed8;border-color:#1d4ed8}.AddCustomerPage .customer-form .actions .btn.primary:focus-visible{outline:none;box-shadow:0 0 0 3px #2563eb40}.dark .AddCustomerPage .card{background:#0b1220;border-color:#1f2937;box-shadow:none}.dark .AddCustomerPage .customer-form .field span{color:#cbd5e1}.dark .AddCustomerPage .customer-form .field .input{background:#0f172a;border-color:#243041;color:#e5e7eb}.dark .AddCustomerPage .customer-form .field .input:hover{border-color:#334155}.dark .AddCustomerPage .customer-form .field .input:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa33;background:#0b1220}.dark .AddCustomerPage .customer-form .field .input.input--error{border-color:#f87171;box-shadow:0 0 0 3px #f8717126;background:#201113}.dark .AddCustomerPage .customer-form .field .autocomplete__list{background:#0b1220;border-color:#243041;box-shadow:0 10px 20px #00000080}.dark .AddCustomerPage .customer-form .field .autocomplete__item:hover{background:#111827}.dark .AddCustomerPage .customer-form .field .autocomplete__item.is-active{background:#0e2a4a}.dark .AddCustomerPage .customer-form .field .autocomplete__item .item__main{color:#e5e7eb}.dark .AddCustomerPage .customer-form .field .autocomplete__item .item__secondary{color:#94a3b8}.dark .AddCustomerPage .customer-form .actions .btn{background:#0f172a;border-color:#243041;color:#e5e7eb}.dark .AddCustomerPage .customer-form .actions .btn:hover{background:#111b2e}.dark .AddCustomerPage .customer-form .actions .btn.primary{background:#2563eb;border-color:#2563eb}.dark .AddCustomerPage .customer-form .actions .btn.primary:hover{background:#1d4ed8;border-color:#1d4ed8}.HomePage{min-height:100vh;background:linear-gradient(135deg,#f8fafc,#e2e8f0);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.HomePage .page-header{background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000001a;padding:0 24px}.HomePage .page-header .header-content{display:flex;justify-content:space-between;align-items:center;height:72px;max-width:1200px;margin:0 auto}.HomePage .page-header .logo-container{display:flex;align-items:center;gap:12px}.HomePage .page-header .logo-container .brand-logo{height:32px;object-fit:contain;filter:brightness(.9)}.HomePage .page-header .logo-container .brand-name{font-size:20px;font-weight:700;color:#1e293b;letter-spacing:-.02em}.HomePage .page-content{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 72px);padding:40px 24px}.HomePage .auth-card{background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f,0 10px 15px -3px #0000001a;padding:40px;width:100%;max-width:480px;border:1px solid #f1f5f9}.HomePage .card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px}.HomePage .card-header .welcome-section{flex:1}.HomePage .card-header .welcome-section .welcome-title{font-size:28px;font-weight:700;color:#1e293b;margin:0 0 8px;line-height:1.2}.HomePage .card-header .welcome-section .welcome-subtitle{font-size:16px;color:#64748b;margin:0;line-height:1.5}.HomePage .card-header .icon-container{margin-left:20px}.HomePage .card-header .icon-container .company-icon{font-size:48px;opacity:.8}.HomePage .auth-form .input-group{margin-bottom:24px}.HomePage .auth-form .input-group .input-label{display:block;font-size:14px;font-weight:600;color:#374151;margin-bottom:8px}.HomePage .auth-form .input-group .form-input{width:100%;padding:16px;border:2px solid #e2e8f0;border-radius:12px;font-size:16px;background:#fff;transition:all .2s ease;box-sizing:border-box}.HomePage .auth-form .input-group .form-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.HomePage .auth-form .input-group .form-input:disabled{background:#f8fafc;color:#94a3b8;cursor:not-allowed}.HomePage .auth-form .input-group .form-input::placeholder{color:#9ca3af}.HomePage .submit-btn{width:100%;padding:16px 24px;background:#3b82f6;color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.HomePage .submit-btn:hover:not(:disabled){background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.HomePage .submit-btn:active:not(:disabled){transform:translateY(0)}.HomePage .submit-btn:disabled{background:#94a3b8;cursor:not-allowed;transform:none;box-shadow:none}.HomePage .submit-btn.loading{background:#3b82f6}.HomePage .submit-btn .spinner{width:18px;height:18px;border:2px solid transparent;border-top:2px solid #ffffff;border-radius:50%;animation:spin 1s linear infinite}.HomePage .card-footer{margin-top:32px;padding-top:24px;border-top:1px solid #f1f5f9}.HomePage .card-footer .hint-section{display:flex;gap:12px;align-items:flex-start}.HomePage .card-footer .hint-section .hint-icon{font-size:20px;opacity:.7;flex-shrink:0;margin-top:2px}.HomePage .card-footer .hint-section .hint-content .hint-title{font-size:14px;font-weight:600;color:#374151;margin:0 0 4px}.HomePage .card-footer .hint-section .hint-content .hint-text{font-size:13px;color:#64748b;margin:0;line-height:1.4}@media(min-width:0){.HomePage .auth-card{padding:36px}}@media(min-width:576px){.HomePage .page-header{padding:0 20px}.HomePage .page-header .logo-container .brand-name{font-size:18px}.HomePage .page-content{padding:28px 20px}.HomePage .auth-card{padding:32px;margin:0 8px;max-width:420px}.HomePage .card-header{flex-direction:column;text-align:center;gap:14px}.HomePage .card-header .icon-container{margin-left:0}.HomePage .card-header .company-icon{font-size:44px}.HomePage .welcome-title{font-size:24px}.HomePage .submit-btn{padding:14px 20px;font-size:15px}}@media(min-width:768px){.HomePage .page-content{padding:32px 36px}.HomePage .auth-card{max-width:520px;padding:36px}.HomePage .card-header .welcome-title{font-size:26px}}@media(min-width:992px){.HomePage .page-content{padding:48px 24px}.HomePage .auth-card{max-width:560px;padding:44px;border-radius:18px}.HomePage .card-header .company-icon{font-size:52px}}@media(min-width:1200px){.HomePage .page-content{padding:56px 24px}.HomePage .auth-card{max-width:640px}.HomePage .welcome-title{font-size:30px}}@media(min-width:1400px){.HomePage .auth-card{max-width:720px;padding:56px}.HomePage .welcome-title{font-size:32px}}@media(max-width:575px){.HomePage .page-header{padding:0 16px}.HomePage .page-content{padding:20px 12px}.HomePage .auth-card{padding:24px 16px;border-radius:12px}.HomePage .card-header{gap:12px}.HomePage .company-icon{font-size:40px}.HomePage .welcome-title{font-size:22px}.HomePage .submit-btn{padding:12px 16px;font-size:15px}}@media(hover:none)and (pointer:coarse){.HomePage .submit-btn{padding:18px 20px;border-radius:14px;font-size:16px}.HomePage .form-input{padding:18px}}@media(hover:hover)and (pointer:fine){.HomePage .submit-btn:hover:not(:disabled){transform:translateY(-2px)}}@media(orientation:landscape){.HomePage .card-header .company-icon{font-size:56px}}@media(orientation:portrait){.HomePage .card-header .welcome-title{line-height:1.15}}@media(-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.HomePage .brand-logo{filter:none}}@media(min-width:768px)and (max-width:992px){.HomePage .auth-card{max-width:520px}}@media(prefers-reduced-motion:reduce){.submit-btn{transition:none}.submit-btn:hover:not(:disabled){transform:none}.spinner{animation-duration:2s}}.snackbar{position:fixed;left:50%;bottom:24px;transform:translate(-50%) translateY(16px);min-width:280px;max-width:min(92vw,520px);display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;padding:12px 14px;border-radius:12px;color:#0f172a;background:#fff;border:1px solid #e2e8f0;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;opacity:0;pointer-events:none;transition:transform .2s ease,opacity .2s ease,box-shadow .2s ease;z-index:9999}.snackbar--open{opacity:1;pointer-events:auto;transform:translate(-50%) translateY(0)}.snackbar__icon{font-size:18px;line-height:1}.snackbar__message{font-size:14px;line-height:1.4;color:#0f172a}.snackbar__close{background:transparent;border:none;font-size:16px;line-height:1;cursor:pointer;color:#475569;padding:6px;border-radius:8px}.snackbar__close:hover{background:#f1f5f9}.snackbar--error{border-color:#fecaca;background:#fff7f7}.snackbar--error .snackbar__message{color:#b91c1c}.snackbar--success{border-color:#bbf7d0;background:#f0fdf4}.snackbar--success .snackbar__message{color:#166534}.snackbar--info{border-color:#bae6fd;background:#f0f9ff}.snackbar--info .snackbar__message{color:#075985}.snackbar--warning{border-color:#fde68a;background:#fffbeb}.snackbar--warning .snackbar__message{color:#92400e}@media(prefers-reduced-motion:reduce){.snackbar{transition:opacity .2s linear;transform:translate(-50%) translateY(0)}}.CompanyDataPage{min-height:100vh;background:#f8fafc;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.CompanyDataPage .page-header{background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000001a;padding:0 16px}@media(min-width:768px){.CompanyDataPage .page-header{padding:0 24px}}.CompanyDataPage .page-header .header-content{display:flex;flex-direction:column;gap:16px;padding:16px 0}@media(min-width:768px){.CompanyDataPage .page-header .header-content{flex-direction:row;justify-content:space-between;align-items:center;height:72px;padding:0}}.CompanyDataPage .page-header .header-content{max-width:1200px;margin:0 auto}.CompanyDataPage .page-header .header-left{text-align:center}@media(min-width:768px){.CompanyDataPage .page-header .header-left{text-align:left}}.CompanyDataPage .page-header .header-left .page-title{font-size:20px;font-weight:700;color:#1e293b;margin:0 0 4px}@media(min-width:768px){.CompanyDataPage .page-header .header-left .page-title{font-size:24px}}.CompanyDataPage .page-header .header-left .company-code{font-size:14px;color:#64748b;margin:0}.CompanyDataPage .page-header .header-left .company-code .code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;background:#f1f5f9;padding:2px 6px;border-radius:4px;color:#475569}.CompanyDataPage .page-header .header-right{display:flex;flex-direction:column;align-items:center;gap:16px}@media(min-width:768px){.CompanyDataPage .page-header .header-right{flex-direction:row;gap:20px}}.CompanyDataPage .page-header .header-right .logo-container{display:flex;align-items:center;order:-1}@media(min-width:768px){.CompanyDataPage .page-header .header-right .logo-container{order:1}}.CompanyDataPage .page-header .header-right .logo-container .brand-logo{height:40px;width:auto;object-fit:contain;filter:brightness(.9)}@media(min-width:768px){.CompanyDataPage .page-header .header-right .logo-container .brand-logo{height:50px}}.CompanyDataPage .page-content{max-width:1200px;margin:0 auto;padding:16px}@media(min-width:768px){.CompanyDataPage .page-content{padding:24px}}.CompanyDataPage .toolbar{display:flex;gap:16px;align-items:center;margin-bottom:24px}.CompanyDataPage .toolbar .search-container{position:relative;flex:1;max-width:100%}@media(min-width:768px){.CompanyDataPage .toolbar .search-container{max-width:500px}}.CompanyDataPage .toolbar .search-container .search-input{width:100%;padding:12px 16px 12px 44px;border:1px solid #cbd5e1;border-radius:8px;font-size:14px;background:#fff;transition:all .2s ease}.CompanyDataPage .toolbar .search-container .search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.CompanyDataPage .toolbar .search-container .search-input::placeholder{color:#94a3b8}.CompanyDataPage .toolbar .search-container .search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:#94a3b8}.CompanyDataPage .btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border-radius:8px;font-size:14px;font-weight:600;text-decoration:none;border:none;cursor:pointer;transition:all .2s ease;white-space:nowrap;width:100%}@media(min-width:768px){.CompanyDataPage .btn{width:auto;padding:12px 20px}}.CompanyDataPage .btn .btn-icon{font-size:18px;font-weight:500}.CompanyDataPage .btn.btn-primary{background:#3b82f6;color:#fff;border:1px solid #3b82f6}@media(min-width:768px){.CompanyDataPage .btn.btn-primary{margin-top:0;margin-left:0}}.CompanyDataPage .btn.btn-primary:hover{background:#2563eb;border-color:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.CompanyDataPage .btn.btn-primary:active{transform:translateY(0)}.CompanyDataPage .btn.btn-secondary{background:#fff;color:#475569;border:1px solid #cbd5e1}.CompanyDataPage .btn.btn-secondary:hover{background:#f8fafc;border-color:#94a3b8}.CompanyDataPage .loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 16px;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}@media(min-width:768px){.CompanyDataPage .loading-state{padding:60px 24px}}.CompanyDataPage .loading-state .spinner{width:32px;height:32px;border:3px solid #e2e8f0;border-top:3px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.CompanyDataPage .loading-state p{color:#64748b;font-size:16px;margin:0}.CompanyDataPage .error-state{display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px;padding:20px;background:#fef2f2;border:1px solid #fecaca;border-radius:12px;color:#dc2626}@media(min-width:768px){.CompanyDataPage .error-state{flex-direction:row;text-align:left;padding:24px}}.CompanyDataPage .error-state .error-icon{font-size:24px}.CompanyDataPage .error-state .error-content h3{margin:0 0 4px;font-size:16px;font-weight:600}.CompanyDataPage .error-state .error-content p{margin:0;font-size:14px;opacity:.9}.CompanyDataPage .table-container .table-header{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}@media(min-width:768px){.CompanyDataPage .table-container .table-header{flex-direction:row;justify-content:space-between;align-items:center;gap:0}}.CompanyDataPage .table-container .table-header h3{font-size:18px;font-weight:600;color:#1e293b;margin:0}.CompanyDataPage .table-container .table-header .results-count{font-size:14px;color:#64748b;background:#f1f5f9;padding:4px 12px;border-radius:16px;align-self:flex-start}@media(min-width:768px){.CompanyDataPage .table-container .table-header .results-count{align-self:center}}.CompanyDataPage .table-container .table-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden;overflow-x:auto}.CompanyDataPage .data-table{width:100%;border-collapse:collapse;min-width:600px}@media(max-width:767px){.CompanyDataPage .data-table{font-size:13px}}.CompanyDataPage .data-table th{background:#f8fafc;padding:12px 16px;text-align:left;font-size:11px;font-weight:600;color:#475569;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #e2e8f0}@media(min-width:768px){.CompanyDataPage .data-table th{padding:16px 20px;font-size:12px}}.CompanyDataPage .data-table td{padding:12px 16px;border-bottom:1px solid #f1f5f9;font-size:13px;color:#334155}@media(min-width:768px){.CompanyDataPage .data-table td{padding:16px 20px;font-size:14px}}.CompanyDataPage .data-table .table-row{transition:background-color .15s ease}.CompanyDataPage .data-table .table-row:hover{background:#f8fafc}.CompanyDataPage .data-table .table-row:last-child td{border-bottom:none}.CompanyDataPage .data-table .table-row .index-cell{color:#64748b;font-weight:500}.CompanyDataPage .data-table .table-row .name-cell{font-weight:500;color:#1e293b}.CompanyDataPage .data-table .table-row .gui-link{color:#3b82f6;text-decoration:none;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;word-break:break-all}@media(min-width:768px){.CompanyDataPage .data-table .table-row .gui-link{font-size:13px;word-break:normal}}.CompanyDataPage .data-table .table-row .gui-link:hover{color:#2563eb;text-decoration:underline}.CompanyDataPage .data-table .empty-row td{padding:40px 20px;text-align:center}@media(min-width:768px){.CompanyDataPage .data-table .empty-row td{padding:60px 20px}}.CompanyDataPage .empty-state{color:#94a3b8;text-align:center}.CompanyDataPage .empty-state .empty-icon{font-size:36px;margin-bottom:12px;opacity:.5}@media(min-width:768px){.CompanyDataPage .empty-state .empty-icon{font-size:48px;margin-bottom:16px}}.CompanyDataPage .empty-state h4{font-size:16px;font-weight:600;margin:0 0 8px;color:#64748b}.CompanyDataPage .empty-state p{font-size:14px;margin:0;opacity:.8}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
