.confirm-overlay[data-v-bda0d2d4]{position:fixed;top:0;left:0;right:0;bottom:0;background-color:var(--overlay);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn-bda0d2d4 .2s}@keyframes fadeIn-bda0d2d4{0%{opacity:0}to{opacity:1}}.confirm-modal[data-v-bda0d2d4]{background:var(--bg-secondary);border-radius:12px;box-shadow:0 8px 32px var(--shadow-md);width:100%;max-width:400px;animation:slideUp-bda0d2d4 .3s;padding:2rem;text-align:center}@keyframes slideUp-bda0d2d4{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.confirm-icon[data-v-bda0d2d4]{display:flex;justify-content:center;margin-bottom:1.5rem}.confirm-icon svg[data-v-bda0d2d4]{color:var(--color-warning)}.confirm-content[data-v-bda0d2d4]{margin-bottom:2rem}.confirm-title[data-v-bda0d2d4]{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0 0 .75rem}.confirm-message[data-v-bda0d2d4]{font-size:.95rem;color:var(--text-secondary);line-height:1.5;margin:0}.confirm-actions[data-v-bda0d2d4]{display:flex;gap:.75rem}.btn[data-v-bda0d2d4]{flex:1;padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-cancel[data-v-bda0d2d4]{background-color:var(--btn-secondary-bg);color:var(--text-primary)}.btn-cancel[data-v-bda0d2d4]:hover{background-color:var(--btn-secondary-hover)}.btn-confirm[data-v-bda0d2d4]{background-color:var(--color-danger);color:#fff}.btn-confirm[data-v-bda0d2d4]:hover{background-color:var(--color-danger-hover);transform:translateY(-1px);box-shadow:0 4px 12px #e74c3c4d}.btn[data-v-bda0d2d4]:active{transform:scale(.98)}@media (max-width: 600px){.confirm-modal[data-v-bda0d2d4]{padding:1.5rem}.confirm-actions[data-v-bda0d2d4]{flex-direction:column-reverse}.btn[data-v-bda0d2d4]{width:100%}}.settings-menu[data-v-d8f54508]{position:relative}.hamburger-btn[data-v-d8f54508]{position:relative;background:none;border:none;color:var(--text-header);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.hamburger-btn[data-v-d8f54508]:hover{background-color:#ffffff1a}.hamburger-btn[data-v-d8f54508]:active{transform:scale(.95)}.notification-dot[data-v-d8f54508]{position:absolute;top:6px;right:6px;width:8px;height:8px;border-radius:50%;background:var(--color-warning, #f59e0b);pointer-events:none}.menu-overlay[data-v-d8f54508]{position:fixed;top:0;left:0;right:0;bottom:0;background-color:var(--overlay);z-index:1000}.menu-panel[data-v-d8f54508]{position:fixed;top:0;right:0;bottom:0;width:100%;max-width:350px;background:var(--bg-secondary);box-shadow:-4px 0 20px var(--shadow-md);z-index:1001;display:flex;flex-direction:column;overflow-y:auto}.menu-header[data-v-d8f54508]{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--border-color);background:var(--bg-header);color:var(--text-header)}.menu-header h2[data-v-d8f54508]{font-size:1.25rem;font-weight:600;margin:0}.close-btn[data-v-d8f54508]{background:none;border:none;color:var(--text-header);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.close-btn[data-v-d8f54508]:hover{background-color:#ffffff1a}.menu-content[data-v-d8f54508]{flex:1;padding:1.5rem;overflow-y:auto}.setting-group[data-v-d8f54508]{border-bottom:1px solid var(--border-color)}.setting-group[data-v-d8f54508]:last-child{border-bottom:none}.accordion-header[data-v-d8f54508]{width:100%;background:none;border:none;padding:1rem 0;display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-size:1rem;font-weight:600;color:var(--text-primary);transition:all .2s}.accordion-header[data-v-d8f54508]:hover{color:var(--color-primary)}.accordion-badge[data-v-d8f54508]{margin-left:auto;margin-right:.5rem;padding:.15rem .5rem;border-radius:999px;font-size:.7rem;font-weight:600;background:color-mix(in srgb,var(--color-warning, #f59e0b) 15%,transparent);color:var(--color-warning, #f59e0b)}.accordion-header .chevron[data-v-d8f54508]{transition:transform .3s;color:var(--icon-color)}.accordion-header.expanded .chevron[data-v-d8f54508]{transform:rotate(180deg)}.accordion-content[data-v-d8f54508]{padding-bottom:1rem}.setting-options[data-v-d8f54508]{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.theme-section[data-v-d8f54508]{margin-bottom:1.5rem}.theme-section[data-v-d8f54508]:last-child{margin-bottom:0}.theme-label[data-v-d8f54508]{display:block;margin-bottom:.75rem;font-size:.85rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.mode-grid[data-v-d8f54508],.color-grid[data-v-d8f54508]{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.setting-btn[data-v-d8f54508]{background:var(--bg-tertiary);border:2px solid var(--border-color);color:var(--text-primary);padding:1rem;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:.5rem;font-size:.9rem;font-weight:500;transition:all .2s}.setting-btn[data-v-d8f54508]:hover{border-color:var(--color-primary);background-color:var(--hover-bg)}.setting-btn.active[data-v-d8f54508]{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.setting-btn[data-v-d8f54508]:active{transform:scale(.97)}.setting-btn.full-width[data-v-d8f54508]{grid-column:1 / -1}.color-btn[data-v-d8f54508]{background:var(--bg-tertiary);border:2px solid var(--border-color);padding:.75rem;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;min-height:60px}.color-btn[data-v-d8f54508]:hover{border-color:var(--color-primary);background-color:var(--hover-bg)}.color-btn.active[data-v-d8f54508]{border-color:var(--color-primary);background-color:var(--hover-bg);box-shadow:0 0 0 2px var(--color-primary)}.color-btn[data-v-d8f54508]:active{transform:scale(.97)}.color-circle[data-v-d8f54508]{width:32px;height:32px;border-radius:50%;border:2px solid rgba(255,255,255,.3);box-shadow:0 2px 4px #0003}.unit-icon[data-v-d8f54508],.time-icon[data-v-d8f54508]{font-size:1.5rem;font-weight:700}.action-button[data-v-d8f54508]{width:100%;background:none;border:none;padding:1rem 0;display:flex;align-items:center;gap:.75rem;cursor:pointer;font-size:1rem;color:var(--text-primary);transition:all .2s}.action-button[data-v-d8f54508]:hover{color:var(--color-primary)}.action-button .arrow[data-v-d8f54508]{margin-left:auto;color:var(--icon-color)}.action-button.danger[data-v-d8f54508]{color:var(--color-danger, #e74c3c)}.action-button.danger[data-v-d8f54508]:hover{color:var(--color-danger-hover, #c0392b)}.house-list[data-v-d8f54508]{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.house-item[data-v-d8f54508]{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.75rem;background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s;text-align:left;color:var(--text-primary);font-size:.95rem}.house-item[data-v-d8f54508]:hover{border-color:var(--color-primary);background-color:var(--hover-bg)}.house-item.active[data-v-d8f54508]{border-color:var(--color-primary);background-color:var(--hover-bg);cursor:default}.house-item-info[data-v-d8f54508]{display:flex;align-items:center;gap:.5rem;min-width:0}.house-item-name[data-v-d8f54508]{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.house-active-badge[data-v-d8f54508]{flex-shrink:0;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:.15rem .5rem;border-radius:999px;background:var(--color-primary);color:#fff}.house-edit-btn[data-v-d8f54508]{flex-shrink:0;background:none;border:none;color:var(--icon-color);cursor:pointer;padding:.25rem;border-radius:4px;display:flex;align-items:center;transition:all .2s}.house-edit-btn[data-v-d8f54508]:hover{color:var(--color-primary);background:#0000000d}.house-rename-row[data-v-d8f54508]{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:var(--bg-tertiary);border:2px solid var(--color-primary);border-radius:8px}.house-rename-input[data-v-d8f54508]{flex:1;min-width:0;padding:.5rem .75rem;font-size:.95rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);outline:none}.house-rename-input[data-v-d8f54508]:focus{border-color:var(--color-primary)}.house-rename-btn[data-v-d8f54508]{flex-shrink:0;background:none;border:none;cursor:pointer;padding:.375rem;border-radius:4px;display:flex;align-items:center;transition:all .2s}.house-rename-btn.save[data-v-d8f54508]{color:var(--color-success, #43a047)}.house-rename-btn.save[data-v-d8f54508]:hover{background:#43a0471a}.house-rename-btn.save[data-v-d8f54508]:disabled{opacity:.5;cursor:not-allowed}.house-rename-btn.cancel[data-v-d8f54508]{color:var(--color-danger, #e74c3c)}.house-rename-btn.cancel[data-v-d8f54508]:hover{background:#e74c3c1a}.house-item-arrow[data-v-d8f54508]{flex-shrink:0;color:var(--icon-color)}.house-actions[data-v-d8f54508]{display:flex;flex-direction:column;gap:.5rem}.add-house-button[data-v-d8f54508]{width:100%;padding:.75rem 1rem;background:var(--bg-tertiary);color:var(--text-primary);border:2px dashed var(--border-color);border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:500;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s}.add-house-button[data-v-d8f54508]:hover{border-color:var(--color-primary);color:var(--color-primary);background-color:var(--hover-bg)}.disconnect-button[data-v-d8f54508]{width:100%;padding:.75rem 1rem;background:var(--color-danger, #e74c3c);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s}.disconnect-button[data-v-d8f54508]:hover{background:var(--color-danger-hover, #c0392b);transform:translateY(-1px);box-shadow:0 4px 12px #e74c3c4d}.disconnect-button[data-v-d8f54508]:active{transform:translateY(0)}.system-loading[data-v-d8f54508]{color:var(--text-secondary);font-size:.9rem}.version-info[data-v-d8f54508]{display:flex;flex-direction:column;gap:.75rem}.version-row[data-v-d8f54508]{display:flex;justify-content:space-between;align-items:center}.version-label[data-v-d8f54508]{font-size:.9rem;color:var(--text-secondary)}.version-value[data-v-d8f54508]{font-size:.9rem;color:var(--text-primary);font-family:monospace}.status-badge[data-v-d8f54508]{display:inline-block;padding:.2rem .6rem;border-radius:12px;font-size:.8rem;font-weight:500}.status-ok[data-v-d8f54508]{background:color-mix(in srgb,var(--color-success, #22c55e) 15%,transparent);color:var(--color-success, #22c55e)}.status-update[data-v-d8f54508]{background:color-mix(in srgb,var(--color-warning, #f59e0b) 15%,transparent);color:var(--color-warning, #f59e0b)}.status-pending[data-v-d8f54508]{background:color-mix(in srgb,var(--color-primary) 15%,transparent);color:var(--color-primary)}.status-unknown[data-v-d8f54508]{background:var(--bg-tertiary);color:var(--text-secondary)}.update-button[data-v-d8f54508]{margin-top:.5rem;padding:.6rem 1.2rem;background:var(--color-primary);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:opacity .2s}.update-button[data-v-d8f54508]:hover{opacity:.9}.pending-message[data-v-d8f54508]{margin-top:.5rem;font-size:.85rem;color:var(--text-secondary);font-style:italic}.fade-enter-active[data-v-d8f54508],.fade-leave-active[data-v-d8f54508]{transition:opacity .3s}.fade-enter-from[data-v-d8f54508],.fade-leave-to[data-v-d8f54508]{opacity:0}.slide-enter-active[data-v-d8f54508],.slide-leave-active[data-v-d8f54508]{transition:transform .3s}.slide-enter-from[data-v-d8f54508],.slide-leave-to[data-v-d8f54508]{transform:translate(100%)}.accordion-enter-active[data-v-d8f54508],.accordion-leave-active[data-v-d8f54508]{transition:all .3s ease;max-height:500px;overflow:hidden}.accordion-enter-from[data-v-d8f54508],.accordion-leave-to[data-v-d8f54508]{max-height:0;opacity:0}@media (max-width: 600px){.menu-panel[data-v-d8f54508]{max-width:100%}.setting-options[data-v-d8f54508]{grid-template-columns:1fr}}.modal-overlay[data-v-21ff701c]{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content[data-v-21ff701c]{background:var(--bg-primary, #ffffff);border-radius:12px;max-width:500px;width:100%;box-shadow:0 20px 60px #00000080;animation:modalSlideIn-21ff701c .3s ease-out}@media (prefers-color-scheme: dark){.modal-content[data-v-21ff701c]{background:var(--bg-primary, #1e1e1e)}}@keyframes modalSlideIn-21ff701c{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header[data-v-21ff701c]{padding:2rem 2rem 1rem;text-align:center}.modal-header h2[data-v-21ff701c]{margin:0 0 .5rem;font-size:1.5rem;color:var(--text-primary, #1f2937)}.modal-subtitle[data-v-21ff701c]{margin:0;color:var(--text-secondary, #6b7280);font-size:.95rem}@media (prefers-color-scheme: dark){.modal-header h2[data-v-21ff701c]{color:var(--text-primary, #f9fafb)}.modal-subtitle[data-v-21ff701c]{color:var(--text-secondary, #9ca3af)}}.modal-body[data-v-21ff701c]{padding:1rem 2rem 2rem}.input-group[data-v-21ff701c]{display:flex;flex-direction:column;gap:.5rem}.input-group label[data-v-21ff701c]{font-weight:500;color:var(--text-primary, #1f2937);font-size:.9rem}@media (prefers-color-scheme: dark){.input-group label[data-v-21ff701c]{color:var(--text-primary, #f9fafb)}}.house-id-input[data-v-21ff701c]{padding:.75rem 1rem;font-size:1rem;font-family:Courier New,monospace;border:2px solid var(--border-color, #d1d5db);border-radius:8px;background:var(--bg-primary, #f9fafb);color:var(--text-primary, #1f2937);transition:all .2s}@media (prefers-color-scheme: dark){.house-id-input[data-v-21ff701c]{background:var(--bg-primary, #2d2d2d);color:var(--text-primary, #e5e7eb);border-color:var(--border-color, #4b5563)}}.house-id-input[data-v-21ff701c]:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #3b82f61a}.house-id-input.error[data-v-21ff701c]{border-color:#ef4444}.house-id-input.error[data-v-21ff701c]:focus{box-shadow:0 0 0 3px #ef44441a}.error-message[data-v-21ff701c]{margin:0;color:#ef4444;font-size:.85rem}.help-text[data-v-21ff701c]{margin:0;color:var(--text-secondary, #6b7280);font-size:.85rem}@media (prefers-color-scheme: dark){.help-text[data-v-21ff701c]{color:var(--text-secondary, #9ca3af)}}.modal-footer[data-v-21ff701c]{padding:1rem 2rem 2rem;display:flex;gap:1rem;justify-content:flex-end}.btn[data-v-21ff701c]{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.btn[data-v-21ff701c]:disabled{opacity:.5;cursor:not-allowed}.btn-primary[data-v-21ff701c]{background:var(--accent-color, #3b82f6);color:#fff}.btn-primary[data-v-21ff701c]:hover:not(:disabled){background:var(--accent-hover, #2563eb);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.btn-secondary[data-v-21ff701c]{background:transparent;color:var(--text-secondary, #6b7280);border:2px solid var(--border-color, #d1d5db)}.btn-secondary[data-v-21ff701c]:hover{background:var(--hover-bg, #f3f4f6);color:var(--text-primary, #1f2937)}@media (prefers-color-scheme: dark){.btn-secondary[data-v-21ff701c]{color:var(--text-secondary, #9ca3af);border-color:var(--border-color, #4b5563)}.btn-secondary[data-v-21ff701c]:hover{background:var(--hover-bg, #374151);color:var(--text-primary, #f9fafb)}}@media (max-width: 600px){.modal-content[data-v-21ff701c]{margin:1rem}.modal-header[data-v-21ff701c]{padding:1.5rem 1.5rem .75rem}.modal-body[data-v-21ff701c]{padding:.75rem 1.5rem 1.5rem}.modal-footer[data-v-21ff701c]{padding:.75rem 1.5rem 1.5rem;flex-direction:column-reverse}.btn[data-v-21ff701c]{width:100%}}.energy-flow[data-v-c7f070d6]{width:100%;max-width:320px;margin:0 auto;display:block}.node-value[data-v-c7f070d6]{font-size:11px;font-weight:600;fill:var(--text-primary)}.led[data-v-c7f070d6]{animation:blink-c7f070d6 2s infinite}.led-1[data-v-c7f070d6]{animation-delay:0s}.led-2[data-v-c7f070d6]{animation-delay:.6s}.led-3[data-v-c7f070d6]{animation-delay:1.2s}@keyframes blink-c7f070d6{0%,40%,to{opacity:1}20%{opacity:.2}}.flow-label-bg[data-v-c7f070d6]{fill:var(--bg-secondary);fill-opacity:.85;stroke:var(--border-color);stroke-width:1}.flow-label[data-v-c7f070d6]{font-size:10px;font-weight:600;fill:var(--text-primary)}.monitor-overlay[data-v-9b4742ea]{position:fixed;top:0;right:0;bottom:0;left:0;background-color:var(--overlay);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn-9b4742ea .2s}.monitor-modal[data-v-9b4742ea]{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;width:90%;max-width:380px;display:flex;flex-direction:column;box-shadow:0 8px 32px var(--shadow-md);animation:slideUp-9b4742ea .25s}.monitor-header[data-v-9b4742ea]{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color)}.monitor-header h3[data-v-9b4742ea]{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.close-btn[data-v-9b4742ea]{background:none;border:none;color:var(--icon-color);cursor:pointer;padding:4px;border-radius:4px;transition:background-color .15s,color .15s}.close-btn[data-v-9b4742ea]:hover{color:var(--text-primary);background-color:var(--hover-bg)}.monitor-body[data-v-9b4742ea]{padding:1.5rem 1.25rem;min-height:300px;display:flex;align-items:center;justify-content:center}.waiting-message[data-v-9b4742ea]{color:var(--text-secondary);font-size:.9rem}.monitor-footer[data-v-9b4742ea]{padding:.75rem 1.25rem;border-top:1px solid var(--border-color)}.progress-bar[data-v-9b4742ea]{height:3px;background:var(--bg-tertiary);border-radius:2px;overflow:hidden}.progress-fill[data-v-9b4742ea]{height:100%;background:var(--color-primary);border-radius:2px;transition:width 1s linear}@keyframes fadeIn-9b4742ea{0%{opacity:0}to{opacity:1}}@keyframes slideUp-9b4742ea{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background-color:var(--bg-header);color:var(--text-header);padding:1rem;box-shadow:0 2px 4px var(--shadow);display:flex;align-items:center;justify-content:space-between}.header-left{display:flex;align-items:center;gap:.75rem}.home-btn{display:flex;align-items:center;justify-content:center;color:var(--text-header);padding:.375rem;border-radius:6px;transition:all .2s;text-decoration:none;opacity:.8}.home-btn:hover{opacity:1;background-color:#ffffff1a}.home-btn:active{transform:scale(.95)}.app-header h1{font-size:1.5rem;font-weight:600}.header-controls{display:flex;align-items:center;gap:1rem}.power-monitor-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-header);cursor:pointer;padding:.375rem;border-radius:6px;transition:all .2s;opacity:.8}.power-monitor-btn:hover{opacity:1;background-color:#ffffff1a}.power-monitor-btn:active{transform:scale(.95)}.occupancy-filter{display:flex;gap:.5rem;align-items:center}.filter-btn{background:none;border:2px solid transparent;color:var(--text-header);cursor:pointer;padding:.5rem;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s;opacity:.6}.filter-btn:hover{opacity:1;background-color:#ffffff1a}.filter-btn.active{opacity:1;border-color:var(--color-primary);background-color:#3498db33}.filter-btn:active{transform:scale(.95)}.app-main{flex:1;padding:1rem;max-width:800px;margin:0 auto;width:100%}.app-main--full-width{max-width:none;padding:.5rem}.error-bar{display:flex;flex-direction:column;gap:0}.error-bar-item{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--color-danger, #e74c3c);color:#fff;font-size:.85rem;font-weight:500;animation:slideDown .25s}.error-bar-icon{flex-shrink:0;opacity:.9}.error-bar-item span{flex:1}.error-bar-dismiss{background:none;border:none;color:#fff;font-size:1.2rem;cursor:pointer;padding:0 .25rem;opacity:.7;transition:opacity .15s;line-height:1}.error-bar-dismiss:hover{opacity:1}@keyframes slideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}@media (max-width: 600px){.app-main{padding:.5rem}.app-header h1{font-size:1.25rem}}
