:root{--brand:#891836;--bg-grad:radial-gradient(120% 120% at 10% 5%, #fff8f4 0%, #f4efe9 45%, #e7ded6 100%);--text:#2f2722;--muted:#6b5c52;--card:rgba(255, 255, 255, .58);--card-border:rgba(255, 255, 255, .65);--shadow:0 12px 36px rgba(79, 42, 36, .12)}html[data-theme=dark]{--bg-grad:radial-gradient(120% 130% at 20% 0%, #31211f 0%, #221c1a 45%, #181412 100%);--text:#f3ece6;--muted:#c4b7ad;--card:rgba(44, 35, 33, .56);--card-border:rgba(255, 255, 255, .14);--shadow:0 20px 46px rgba(0, 0, 0, .35)}body{margin:0;font-family:Ubuntu,Avenir Next,Segoe UI,sans-serif;color:var(--text);background:var(--bg-grad);min-height:100vh}main.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{min-height:100vh}.loading-screen.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca,.login-page.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{display:flex;flex-direction:column;justify-content:center;padding:1.25rem}.spinner.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{width:48px;height:48px;border:4px solid rgba(137,24,54,.2);border-top-color:var(--brand);border-radius:999px;animation:svelte-c2c8ca-spin 1s linear infinite;margin:0 auto .8rem}@keyframes svelte-c2c8ca-spin{to{transform:rotate(360deg)}}.card.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{border-radius:22px;padding:1rem}.glass.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{background:var(--card);border:1px solid var(--card-border);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.login-card.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{text-align:center}.login-card-red.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{background:#6f132b;color:#fff7f3;border:1px solid rgba(255,255,255,.26);box-shadow:0 18px 46px #41081959}.logo.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{width:min(230px,70vw);margin-bottom:.35rem}.logo.small.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{width:140px;margin-bottom:0}.pin-input.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{width:100%;box-sizing:border-box;text-align:center;letter-spacing:.45rem;font-size:1.35rem;border:1px solid rgba(137,24,54,.2);background:#ffffffad;padding:.85rem;border-radius:14px;margin-top:.7rem}.error.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{color:#ffe3ea;font-size:.94rem;margin:.8rem 0 0}.primary.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca,.pill.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca,.toggle.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca,.stepper.svelte-c2c8ca button.svelte-c2c8ca.svelte-c2c8ca{border:none;border-radius:12px;font-weight:700;cursor:pointer;transition:transform .2s ease,opacity .2s ease}.primary.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca,.pill.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{background:var(--brand);color:#fff;padding:.75rem 1rem;width:100%;margin-top:.9rem}.login-primary.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{background:#fff1e7;color:#6f132b}.pill.ghost.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{background:transparent;border:1px solid rgba(137,24,54,.4);color:var(--text)}.app-page.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{padding:5.2rem .85rem 5.8rem}.topbar.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{position:fixed;top:.65rem;left:.85rem;right:.85rem;z-index:1500;border-radius:18px;padding:.7rem .9rem;display:flex;justify-content:space-between;align-items:center;margin-bottom:.9rem;background:#5a0c21d6;border-color:#fff5f766;backdrop-filter:blur(14px) saturate(130%);-webkit-backdrop-filter:blur(14px) saturate(130%);box-shadow:0 14px 30px #41081957}.brand.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{display:flex;align-items:center;gap:.5rem}.conn-indicator.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{display:inline-flex;align-items:center;gap:.4rem;color:#fff7f3;font-size:.82rem;font-weight:700;margin-left:auto;margin-right:.5rem}.conn-indicator.svelte-c2c8ca .dot.svelte-c2c8ca.svelte-c2c8ca{width:.55rem;height:.55rem;border-radius:999px;display:inline-block;box-shadow:0 0 0 2px #ffffff38}.conn-indicator.svelte-c2c8ca .dot.online.svelte-c2c8ca.svelte-c2c8ca{background:#25d366}.conn-indicator.svelte-c2c8ca .dot.offline.svelte-c2c8ca.svelte-c2c8ca{background:#ff5a5f}.topbar.svelte-c2c8ca select.svelte-c2c8ca.svelte-c2c8ca{border-radius:10px;border:1px solid rgba(255,255,255,.35);padding:.38rem .55rem;background:#ffffffeb}.install-banner.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{border-radius:14px;padding:.75rem;margin-bottom:.85rem}.install-banner.svelte-c2c8ca p.svelte-c2c8ca.svelte-c2c8ca{margin:0;font-weight:700}.install-banner.svelte-c2c8ca small.svelte-c2c8ca.svelte-c2c8ca{display:block;margin-top:.3rem;color:var(--muted);line-height:1.35}.install-actions.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{margin-top:.6rem;display:flex;gap:.5rem}.install-btn.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{width:auto}.hint-text.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{margin:.35rem 0 0;color:var(--muted);line-height:1.4}.status-toggle.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{position:relative;margin-top:.6rem;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:.18rem;min-height:3.9rem;padding-left:2.35rem}.status-main.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{width:100%;display:flex;align-items:center;justify-content:center;gap:.45rem}.status-icon.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{position:absolute;left:.7rem;top:50%;transform:translateY(-50%);width:1.65rem;height:1.65rem;fill:currentColor;opacity:.92}.camera-line-icon.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{fill:none;stroke:currentColor;stroke-width:1.92px;stroke-miterlimit:10}.status-sub.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{font-size:.76rem;opacity:.9;line-height:1.2}.status-toggle.on.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{background:var(--brand);color:#fff}.status-toggle.off.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{background:#ffffffb8;color:#532f37;border:1px solid rgba(137,24,54,.24)}.state-dot.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{width:.55rem;height:.55rem;border-radius:999px;display:inline-block;box-shadow:0 0 0 2px #ffffff4d}.state-dot.on.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{background:#25d366}.state-dot.off.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{background:#ff5a5f}.content.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{animation:svelte-c2c8ca-fade-up .26s ease}@keyframes svelte-c2c8ca-fade-up{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.stack.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{display:grid;gap:.8rem}.kpi-row.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem}.weather-head.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{display:flex;align-items:center;gap:.8rem;margin-bottom:.7rem}.weather-head.svelte-c2c8ca p.svelte-c2c8ca.svelte-c2c8ca{margin:.2rem 0 0;color:var(--muted);font-size:.88rem;line-height:1.35}.weather-symbol.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{width:52px;height:52px;display:grid;place-items:center;border-radius:14px;font-size:1.7rem;background:#ffffff7a;box-shadow:inset 0 0 0 1px #ffffff59}.weather-kpis.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{margin-bottom:.6rem}.forecast-row.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{display:grid;grid-template-columns:repeat(auto-fit,minmax(72px,1fr));gap:.5rem}.forecast-item.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{border-radius:12px;background:#ffffff61;padding:.45rem .5rem;display:flex;flex-direction:column;gap:.15rem}.forecast-item.svelte-c2c8ca span.svelte-c2c8ca.svelte-c2c8ca{font-size:.75rem;color:var(--muted);text-transform:capitalize}.forecast-item.svelte-c2c8ca strong.svelte-c2c8ca.svelte-c2c8ca{font-size:.95rem}.forecast-item.svelte-c2c8ca small.svelte-c2c8ca.svelte-c2c8ca{color:var(--muted)}.kpi-row.svelte-c2c8ca div.svelte-c2c8ca.svelte-c2c8ca{border-radius:13px;padding:.6rem .8rem;background:#ffffff6b;display:flex;flex-direction:column;gap:.2rem}.kpi-row.svelte-c2c8ca span.svelte-c2c8ca.svelte-c2c8ca{font-size:.76rem;color:var(--muted)}.row-card.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{display:flex;justify-content:space-between;align-items:center}.toggle.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{min-width:76px;padding:.6rem;background:#d8d1cb;color:#453a34}.toggle.active.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{background:var(--brand);color:#fff}.toggle.pending.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{opacity:.7;cursor:wait}.camera-card.svelte-c2c8ca img.svelte-c2c8ca.svelte-c2c8ca{margin-top:.5rem;width:100%;border-radius:14px;background:#00000024;aspect-ratio:16 / 9;object-fit:cover}.camera-card.tappable.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{cursor:pointer}.camera-offline.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{margin-top:.5rem;width:100%;border-radius:14px;aspect-ratio:16 / 9;display:grid;place-items:center;text-align:center;padding:.8rem;box-sizing:border-box;color:var(--muted);background:#0000001a;border:1px dashed rgba(137,24,54,.35);font-weight:700}.wifi-row.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.wifi-row.svelte-c2c8ca code.svelte-c2c8ca.svelte-c2c8ca{word-break:break-word}.wifi-qr-button.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{flex-shrink:0;white-space:nowrap}.climate-card.svelte-c2c8ca .stepper.svelte-c2c8ca.svelte-c2c8ca{display:grid;grid-template-columns:44px 1fr 44px;gap:.5rem;align-items:center}.stepper.svelte-c2c8ca button.svelte-c2c8ca.svelte-c2c8ca{background:#89183626;color:var(--text);height:40px}.bottombar.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{position:fixed;left:.6rem;right:.6rem;bottom:.6rem;border-radius:18px;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));padding:.3rem;gap:.2rem}.bottombar.svelte-c2c8ca button.svelte-c2c8ca.svelte-c2c8ca{border:none;background:transparent;color:var(--muted);border-radius:12px;padding:.45rem .2rem .4rem;font-size:.77rem;font-weight:700;display:flex;flex-direction:column;align-items:center;gap:.15rem}.bottombar.svelte-c2c8ca button.svelte-c2c8ca svg.svelte-c2c8ca{width:19px;height:19px;fill:currentColor}.bottombar.svelte-c2c8ca button.active.svelte-c2c8ca.svelte-c2c8ca{background:var(--brand);color:#fff}.modal-backdrop.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:grid;place-items:center;z-index:2000;padding:1rem}.modal-panel.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{position:relative;box-sizing:border-box;border-radius:18px;padding:.75rem;max-width:calc(100vw - 2rem);max-height:calc(100vh - 2rem);overflow-x:hidden;overflow-y:auto}.modal-panel.svelte-c2c8ca h3.svelte-c2c8ca.svelte-c2c8ca{margin:0 0 .5rem;padding-right:2rem}.modal-media.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{display:flex;width:100%;min-height:0}.modal-media-centered.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{justify-content:center}.modal-media-plain.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{box-sizing:border-box;width:100%;padding:.65rem;border-radius:16px;background:#fff}.modal-media-image.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{display:block;width:100%;border-radius:12px;height:auto;max-height:calc(100vh - 180px);background:#0000001f}.modal-camera.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{max-width:720px}.modal-camera.svelte-c2c8ca .modal-media-image.svelte-c2c8ca.svelte-c2c8ca{aspect-ratio:16 / 9;object-fit:cover}.modal-qr.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{width:min(92vw,420px);max-width:420px}.modal-qr-image.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{width:100%;max-width:320px;max-height:calc(100vh - 190px);aspect-ratio:1;object-fit:contain;background:#fff}.camera-offline-modal.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{margin-top:0}.modal-close.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{position:absolute;top:.5rem;right:.5rem;width:32px;height:32px;border:none;border-radius:999px;background:#000000a6;color:#fff;font-weight:700;cursor:pointer}@media (min-width: 900px){.app-page.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{max-width:980px;margin:0 auto}.topbar.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{left:max(.85rem,calc((100vw - 980px)/2 + .85rem));right:max(.85rem,calc((100vw - 980px)/2 + .85rem))}.stack.svelte-c2c8ca.svelte-c2c8ca.svelte-c2c8ca{grid-template-columns:repeat(2,minmax(0,1fr))}.stack.svelte-c2c8ca .quick-actions{grid-column:1 / -1}}
