:root{--background:#eef3ec;--panel:#fff;--ink:#1d2428;--muted:#66737c;--line:#d9e2da;--soft-line:#e9eee9;--accent:#117a65;--accent-strong:#0b5f4f;--accent-soft:#e3f4ec;--danger:#b42318;--danger-soft:#fff1ee;--blue:#256eb8;--pin-on-bg:#dcefe3;--pin-on-border:#7ebd8f;--pin-off-bg:#f4dfdb;--pin-off-border:#d98d82;--pin-unused-bg:#e7ece8;--pin-unused-border:#d4ddd6;--shadow:0 14px 36px #1d2a241a}html,body{-moz-text-size-adjust:100%;text-size-adjust:100%;width:100%;min-height:100%;overflow-x:hidden}body{background:var(--background);min-height:100dvh;color:var(--ink);margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}button,input,textarea,select{font:inherit;font-size:16px}input,textarea,select{min-height:44px}button,a,[role=button]{touch-action:manipulation;min-height:44px}button{cursor:pointer;overflow-wrap:anywhere;max-width:100%}button:disabled{cursor:wait;opacity:.62}img,svg,video,canvas{max-width:100%}h1,h2,p{margin:0}h1{font-size:30px;line-height:1.05}h2{font-size:19px;line-height:1.15}.shell{width:min(100% - 20px,430px);margin:0 auto;padding:14px 0 28px}.auth-shell{grid-template-columns:1fr;align-content:start;gap:14px;min-height:100dvh;display:grid}.loading-panel,.hero-panel,.auth-card,.mobile-card{border:1px solid var(--line);background:var(--panel);box-shadow:var(--shadow);border-radius:18px}.loading-panel{color:var(--muted);justify-self:center;align-items:center;gap:10px;padding:16px 18px;display:inline-flex}.hero-panel,.auth-card{padding:18px}.hero-panel{gap:18px;display:grid}.hero-copy{color:var(--muted);margin-top:12px;font-size:17px;line-height:1.45}.hero-points{gap:10px;display:grid}.hero-points span{border:1px solid var(--soft-line);min-width:0;color:var(--muted);overflow-wrap:anywhere;background:#fbfcfb;border-radius:14px;align-items:center;gap:9px;padding:12px;display:flex}.auth-tabs{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px;display:grid}.auth-tabs button{border:1px solid var(--line);color:var(--muted);background:#fff;border-radius:14px;font-weight:850}.auth-tabs button.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-strong)}.auth-form,.phone-step-form{gap:12px;display:grid}.totp-form{gap:14px}.totp-heading{align-items:center;gap:12px;display:flex}.totp-heading>svg{color:var(--accent);flex:none}.totp-setup{gap:12px;display:grid}.totp-qr,.totp-qr-placeholder{border:1px solid var(--line);background:#fff;border-radius:18px;width:min(100%,240px);min-height:220px;margin:0 auto}.totp-qr{padding:10px;display:block}.totp-qr-placeholder{color:var(--muted);place-items:center;display:grid}.totp-secret-box{border:1px solid var(--soft-line);background:#fbfcfb;border-radius:16px;gap:8px;min-width:0;padding:12px;display:grid}.totp-secret-box span{color:var(--accent);letter-spacing:.08em;text-transform:uppercase;font-size:12px;font-weight:900}.totp-secret-box strong,.totp-secret-box code{overflow-wrap:anywhere;min-width:0}.totp-secret-box code{color:var(--muted);font-size:13px;line-height:1.3}.field{color:var(--muted);gap:7px;font-size:16px;font-weight:800;display:grid}.field input,.field select,.field textarea{border:1px solid var(--line);width:100%;min-width:0;min-height:48px;color:var(--ink);background:#fbfcfb;border-radius:14px;outline:none;padding:0 13px}.field textarea{resize:none;min-height:96px;padding:12px 13px;line-height:1.35}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 4px #117a651f}.picker-field{border:1px solid var(--line);width:100%;min-width:0;min-height:48px;color:var(--ink);text-align:left;background:#fbfcfb;border-radius:14px;justify-content:space-between;align-items:center;gap:10px;padding:0 13px;font-size:16px;font-weight:850;display:flex;overflow:hidden}.picker-field>span:not(.picker-field-icon){text-overflow:ellipsis;white-space:nowrap;flex:1 1 0;width:0;min-width:0;overflow:hidden}.picker-field svg{flex:none}.picker-field-icon{background:var(--accent-soft);width:34px;height:34px;color:var(--accent-strong);border-radius:11px;flex:0 0 34px;place-items:center;display:inline-grid}.location-picker-row{border:1px solid var(--line);width:100%;min-width:0;min-height:58px;color:var(--ink);text-align:left;background:#fbfcfb;border-radius:14px;align-items:center;gap:10px;padding:8px 12px;display:flex;overflow:hidden}.location-picker-row>svg{color:var(--accent-strong);flex:none}.location-picker-copy{flex:1 1 0;gap:3px;width:0;min-width:0;display:grid}.location-picker-copy strong,.location-picker-copy small{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.location-picker-copy strong{font-size:15px;font-weight:900}.location-picker-copy small{color:var(--muted);font-size:12px;font-weight:850}.button{border:1px solid var(--accent);background:var(--accent);color:#fff;border-radius:16px;justify-content:center;align-items:center;gap:8px;width:100%;max-width:100%;min-height:50px;font-weight:850;display:inline-flex;overflow:hidden}.button.secondary{color:var(--accent-strong);background:#fff}.button.ghost{border-color:var(--line);color:var(--accent-strong);background:#fff}.button,.firmware-back-link{text-decoration:none}.firmware-shell{gap:14px;display:grid}.firmware-hero{gap:14px}.firmware-back-link{width:fit-content;min-height:44px;color:var(--accent-strong);align-items:center;gap:8px;font-weight:900;display:inline-flex}.firmware-card{gap:14px;display:grid}.firmware-action-panel{gap:10px;display:grid}.firmware-version-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.firmware-version-grid div{border:1px solid var(--soft-line);background:#fbfcfb;border-radius:14px;gap:5px;min-width:0;padding:12px;display:grid}.firmware-version-grid span{color:var(--muted);font-size:12px;font-weight:900}.firmware-version-grid strong,.firmware-checksum,.firmware-command code{overflow-wrap:anywhere;min-width:0}.firmware-version-grid strong{font-size:15px;line-height:1.2}.firmware-list,.firmware-steps{color:var(--muted);gap:10px;margin:0;padding-left:22px;font-size:16px;line-height:1.35;display:grid}.firmware-list li,.firmware-steps li{padding-left:2px}.firmware-command{border:1px solid var(--soft-line);color:#f5fff9;white-space:pre-wrap;background:#1d2428;border-radius:14px;width:100%;margin:0;padding:12px;overflow-x:auto}.firmware-command code,.firmware-checksum{font-size:13px;line-height:1.4}.firmware-checksum{border:1px solid var(--soft-line);color:var(--accent-strong);background:#fbfcfb;border-radius:14px;padding:12px;display:block}.firmware-direct-link{min-height:44px;color:var(--accent-strong);text-align:center;border-radius:14px;justify-content:center;align-items:center;gap:8px;font-size:15px;font-weight:900;text-decoration:none;display:inline-flex}.firmware-feedback{border:1px solid var(--pin-on-border);background:var(--pin-on-bg);color:var(--accent-strong);border-radius:14px;padding:10px 12px;font-size:15px;font-weight:850;line-height:1.3}.compact-button{width:100%;padding:0 16px}.alert,.notice,.compact-alert,.compact-notice{border-radius:14px;padding:12px 14px;font-size:16px;line-height:1.25}.alert,.compact-alert{background:var(--danger-soft);color:var(--danger);border:1px solid #f1b4ad}.notice,.compact-notice{background:var(--accent-soft);color:var(--accent-strong);border:1px solid #75b798}.compact-alert,.compact-notice{min-height:44px;max-height:56px;overflow:hidden}.eyebrow{color:var(--accent);letter-spacing:.05em;text-transform:uppercase;margin:0 0 5px;font-size:13px;font-weight:900}.muted-text{color:var(--muted);overflow-wrap:anywhere;font-size:16px;line-height:1.35}.spin{animation:.9s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.phone-shell{background:radial-gradient(circle at 20% 10%,#117a6524,#0000 32%),linear-gradient(#eef3ecfa,#e5eee4fa);place-items:center;width:100%;height:100dvh;display:grid;overflow:hidden}.phone-screen{border-inline:1px solid var(--soft-line);background:var(--background);width:min(100%,460px);min-width:0;height:100dvh;max-height:932px;padding:max(14px, env(safe-area-inset-top)) 14px max(10px, env(safe-area-inset-bottom));flex-direction:column;gap:12px;display:flex;overflow:hidden}.phone-header{flex:none;justify-content:space-between;align-items:center;gap:10px;min-height:44px;display:flex}.phone-header>div{min-width:0}.phone-title{flex:none;min-width:0}.phone-title h1,.phone-header h1{text-overflow:ellipsis;white-space:nowrap;max-width:100%;overflow:hidden}.device-title h1{font-size:26px}.add-device-button,.back-button,.round-icon-button,.device-status-chip,.small-action-button,.sensor-enable{border:1px solid var(--line);background:var(--panel);min-width:0;max-width:100%;min-height:44px;color:var(--accent-strong);white-space:nowrap;border-radius:14px;justify-content:center;align-items:center;gap:8px;padding:0 12px;font-weight:850;display:inline-flex;overflow:hidden}.add-device-button{border-color:var(--accent);background:var(--accent);color:#fff}.round-icon-button{width:44px;color:var(--muted);flex:0 0 44px;padding:0}.back-button{max-width:70%;color:var(--ink);overflow:hidden}.device-status-chip{min-width:0;color:var(--muted)}.small-action-button{width:auto;padding-inline:14px}.dashboard-scroll,.settings-scroll,.map-scroll,.device-summary-scroll,.maintenance-scroll,.device-settings-scroll,.sensor-detail-scroll,.sensor-settings-scroll{overscroll-behavior-y:contain;flex:auto;min-height:0;padding-bottom:4px;overflow-y:auto}.dashboard-scroll,.settings-scroll,.map-scroll{align-content:start;gap:12px;display:grid}.summary-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.summary-grid.inside-card{grid-template-columns:repeat(2,minmax(0,1fr))}.summary-card{border:1px solid var(--line);background:var(--panel);min-width:0;box-shadow:var(--shadow);border-radius:16px;gap:6px;padding:12px 10px;display:grid}.summary-grid.inside-card .summary-card{box-shadow:none}.summary-icon{background:var(--accent-soft);width:34px;height:34px;color:var(--accent-strong);border-radius:12px;place-items:center;display:grid}.summary-card strong{color:var(--ink);font-size:24px;line-height:1}.summary-card.compact-summary-value strong{overflow-wrap:anywhere;font-size:clamp(15px,4.1vw,18px);line-height:1.18}.dht-live-card{gap:6px}.dht-reading-table{gap:3px;min-width:0;display:grid}.dht-reading-row{grid-template-columns:minmax(34px,.75fr) minmax(42px,1fr) minmax(34px,.8fr);align-items:center;gap:4px;min-width:0;display:grid}.dht-reading-row strong,.dht-reading-row span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.dht-reading-row strong{color:var(--ink);letter-spacing:.01em;font-size:11px;font-weight:950;line-height:1.15}.dht-reading-row span{color:var(--muted);text-align:right;font-size:11px;font-weight:850;line-height:1.15}.dht-reading-heading span{color:var(--muted);letter-spacing:.05em;text-transform:uppercase;font-size:11px;font-weight:900}.dht-reading-heading span:first-child,.dht-reading-row strong{text-align:left}.dht-reading-row.live span{color:var(--accent-strong)}.dht-average-row{margin-top:2px}.dht-average-row strong,.dht-average-row span{color:var(--ink);font-size:11px;font-weight:950}.summary-card .dht-card-label,.summary-card span{color:var(--muted);font-size:13px;font-weight:800;line-height:1.2}.summary-card .dht-reading-row span{text-align:right;font-size:11px;font-weight:850;line-height:1.15}.summary-card .dht-reading-heading span{color:var(--muted);letter-spacing:.05em;text-transform:uppercase;font-size:11px;font-weight:900}.summary-card .dht-average-row strong,.summary-card .dht-average-row span{color:var(--ink);font-size:11px;font-weight:950}.news-list{gap:10px;min-width:0;max-width:100%;display:grid}.news-item{border:1px solid var(--soft-line);width:100%;min-width:0;min-height:64px;color:var(--ink);text-align:left;background:#fbfcfb;border-radius:16px;gap:5px;padding:12px;display:grid}.news-item strong,.news-item span{overflow-wrap:anywhere;min-width:0;max-width:100%}.news-item strong{color:var(--ink);font-size:16px;line-height:1.2}.news-item span{color:var(--muted);font-size:15px;line-height:1.35}.news-date{color:var(--accent-strong);letter-spacing:.04em;text-transform:uppercase;font-size:12px;font-weight:950;line-height:1.1}.news-empty{border:1px dashed var(--line);color:var(--muted);text-align:center;border-radius:16px;padding:14px;font-size:15px;font-weight:800}.news-detail{touch-action:pan-y;gap:10px;width:100%;min-width:0;max-width:100%;display:grid;overflow-x:hidden}.news-detail h3{min-width:0;max-width:100%;color:var(--ink);overflow-wrap:anywhere;word-break:break-word;margin:0;font-size:20px;line-height:1.12}.news-body{gap:8px;min-width:0;max-width:100%;display:grid;overflow-x:hidden}.news-body p{min-width:0;max-width:100%;color:var(--muted);overflow-wrap:anywhere;word-break:break-word;font-size:15px;line-height:1.35}.news-pagination{grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:8px;display:grid}.news-pagination button{border:1px solid var(--line);min-width:0;color:var(--accent-strong);background:#fff;border-radius:14px;font-weight:900}.news-pagination span{color:var(--muted);font-size:13px;font-weight:900}.mobile-card{padding:14px}.section-heading{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.section-heading>div{min-width:0}.section-heading svg{color:var(--accent-strong)}.sensor-list{gap:10px;display:grid}.sensor-card{border:1px solid var(--line);background:#fbfcfb;border-radius:16px;gap:10px;padding:12px;display:grid}.sensor-card.healthy{background:#f3fbf6;border-color:#8fcdae}.sensor-card-top{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.sensor-card-top div{gap:3px;min-width:0;display:grid}.sensor-card-top strong{text-overflow:ellipsis;white-space:nowrap;font-size:17px;font-weight:900;overflow:hidden}.sensor-card-top span,.sensor-time,.sparkline-empty{color:var(--muted);font-size:13px;line-height:1.25}.sensor-status{max-width:42%;color:var(--muted);text-overflow:ellipsis;white-space:nowrap;background:#ecefed;border-radius:999px;padding:6px 9px;font-size:12px;font-weight:900;overflow:hidden}.sensor-status.ok{background:var(--accent-soft);color:var(--accent-strong)}.sensor-status.error{color:#9a4f00;background:#fff1d7}.reading-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.reading-grid div{background:#fff;border-radius:14px;align-items:center;gap:7px;min-width:0;padding:10px;display:flex}.reading-grid svg{color:var(--accent-strong);flex:none}.reading-grid strong{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:20px;overflow:hidden}.sparkline{width:100%;height:54px;color:var(--accent)}.sparkline-empty{border:1px dashed var(--line);border-radius:14px;place-items:center;min-height:54px;display:grid}.pin-matrix-card{grid-template-rows:auto minmax(0,1fr);gap:8px;min-height:0;padding:12px;display:grid;overflow:hidden}.pin-matrix-heading{min-width:0;color:var(--accent-strong);letter-spacing:.04em;text-transform:uppercase;align-items:center;gap:7px;font-size:13px;font-weight:950;line-height:1;display:inline-flex}.pin-matrix-heading svg{flex:none}.pin-matrix{--pin-matrix-gap:clamp(6px, 1.8vw, 9px);grid-auto-rows:var(--pin-cell-size,32px);grid-template-columns:repeat(var(--pin-matrix-columns,10), var(--pin-cell-size,32px));place-content:center;gap:var(--pin-matrix-gap);height:100%;min-height:0;display:grid;overflow:hidden}.map-placeholder-card,.map-location-card{gap:12px;display:grid}.map-live-shell,.location-map-shell{border:1px solid var(--line);background:#edf4ef;border-radius:18px;min-width:0;position:relative;overflow:hidden}.map-live-shell{min-height:220px}.map-live-canvas,.location-map-canvas{width:100%;min-width:0;height:100%;min-height:inherit}.map-overlay-message{border:0;border-radius:0;position:absolute;inset:0}.map-placeholder-visual{border:1px dashed var(--line);min-height:160px;color:var(--accent-strong);text-align:center;background:radial-gradient(circle at 30% 28%,#117a6524,#0000 28%),linear-gradient(135deg,#f8fbfa,#eef6f0);border-radius:18px;place-items:center;gap:10px;display:grid}.map-placeholder-visual span{max-width:20ch;color:var(--ink);font-size:18px;font-weight:900;line-height:1.15}.map-device-list{gap:8px;display:grid}.map-device-row{border:1px solid var(--soft-line);background:#fbfcfb;border-radius:16px;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:10px;min-width:0;min-height:56px;padding:10px 12px;display:grid}.map-status-dot{background:#a4adb4;border-radius:999px;width:10px;height:10px}.map-status-dot.online{background:#1f9d68;box-shadow:0 0 0 4px #1f9d681f}.map-device-row div{gap:3px;min-width:0;display:grid}.map-device-row strong,.map-device-row span,.map-empty-note{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.map-device-row strong{color:var(--ink);font-size:15px;font-weight:900}.map-device-row span,.map-empty-note{color:var(--muted);font-size:14px;font-weight:800}.location-picker-content{flex:auto;grid-template-rows:minmax(0,1fr) auto;gap:10px;min-height:0;display:grid;overflow:hidden}.location-map-card{grid-template-rows:minmax(0,1fr) auto;gap:12px;min-height:0;display:grid;overflow:hidden}.location-map-shell{height:100%;min-height:0}.location-map-fallback{color:var(--accent-strong);text-align:center;background:radial-gradient(circle at 30% 28%,#117a6524,#0000 28%),linear-gradient(135deg,#f8fbfa,#eef6f0);align-content:center;place-items:center;gap:10px;padding:18px;display:grid;position:absolute;inset:0}.location-map-fallback strong,.location-map-fallback span{overflow-wrap:anywhere;max-width:26ch}.location-map-fallback strong{color:var(--ink);font-size:18px;line-height:1.15}.location-map-fallback span{color:var(--muted);font-size:14px;line-height:1.35}.selected-location-card{border:1px solid var(--soft-line);background:#fbfcfb;border-radius:16px;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:10px;min-width:0;min-height:62px;padding:10px 12px;display:grid}.selected-location-card svg{color:var(--accent-strong)}.selected-location-card div{gap:3px;min-width:0;display:grid}.selected-location-card strong,.selected-location-card span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.selected-location-card strong{font-size:15px;font-weight:900}.selected-location-card span{color:var(--muted);font-size:13px;font-weight:800}.location-picker-actions{padding-bottom:env(safe-area-inset-bottom);flex:none;grid-template-columns:1fr;gap:8px;display:grid}.pin-cell{border:1px solid var(--pin-unused-border);background:var(--pin-unused-bg);color:#1d2428ad;border-radius:clamp(7px,2vw,12px);place-items:center;width:100%;min-width:0;height:100%;font-size:clamp(10px,3vw,14px);font-weight:900;line-height:1;display:grid}.pin-cell.on{border-color:var(--pin-on-border);background:var(--pin-on-bg);color:var(--accent-strong)}.pin-cell.off{border-color:var(--pin-off-border);background:var(--pin-off-bg);color:#9d3b31}.pin-cell.unused{border-color:var(--pin-unused-border);background:var(--pin-unused-bg)}.phone-content{flex:auto;grid-template-rows:minmax(0,1fr) 24px;gap:8px;min-height:0;display:grid;overflow:hidden}.phone-content.with-bottom-nav{min-height:0}.phone-step-content{flex:auto;align-content:start;gap:12px;min-height:0;display:grid;overflow-y:auto}.device-detail-content{flex:auto;min-height:0;display:grid;overflow:hidden}.device-tab-content{min-height:0;overflow:hidden}.device-summary-scroll,.automation-scroll,.maintenance-scroll,.device-settings-scroll{align-content:start;gap:12px;display:grid}.device-summary-scroll{grid-template-rows:auto minmax(0,1fr);align-content:stretch;padding-bottom:0;overflow:hidden}.controls-tab{grid-template-rows:minmax(0,1fr);display:grid}.automation-scroll{padding-bottom:4px;overflow:hidden auto}.maintenance-scroll{padding-bottom:calc(88px + env(safe-area-inset-bottom));scroll-padding-bottom:calc(88px + env(safe-area-inset-bottom));overflow:hidden auto}.automation-card{gap:12px;display:grid}.automation-rule-list{gap:8px;display:grid}.automation-rule-card{border:1px solid var(--line);background:#fbfcfb;border-radius:16px;gap:10px;padding:12px;display:grid}.automation-rule-card.disabled{opacity:.72}.automation-rule-card strong,.automation-rule-card span,.automation-rule-card small{overflow-wrap:anywhere;min-width:0;display:block}.automation-rule-card strong{color:var(--ink);font-size:15px;line-height:1.15}.automation-rule-card span{color:var(--accent-strong);margin-top:4px;font-size:13px;font-weight:850;line-height:1.2}.automation-rule-card small{color:var(--muted);margin-top:4px;font-size:12px;font-weight:800;line-height:1.25}.automation-rule-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.mini-action{border:1px solid var(--line);min-height:44px;color:var(--muted);background:#fff;border-radius:14px;font-size:14px;font-weight:850}.mini-action.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-strong)}.mini-action.danger{color:#a33830;border-color:#b92c2447}.automation-empty{border:1px dashed var(--line);min-height:52px;color:var(--muted);border-radius:16px;align-items:center;gap:10px;padding:0 12px;font-size:14px;font-weight:850;display:flex}.segmented-picker{grid-template-columns:repeat(auto-fit,minmax(72px,1fr));gap:7px;display:grid}.segmented-picker button{border:1px solid var(--line);min-width:0;min-height:44px;color:var(--muted);background:#fbfcfb;border-radius:14px;padding:0 8px;font-size:14px;font-weight:850}.segmented-picker button.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-strong)}.automation-two-fields{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.gpio-card{grid-template-rows:auto minmax(0,1fr);height:100%;min-height:0;display:grid;overflow:hidden}.gpio-pager-wrap{grid-template-rows:minmax(0,1fr) 24px;gap:8px;min-height:0;display:grid}.swipe-pages{overscroll-behavior-x:contain;scroll-snap-type:x mandatory;scroll-behavior:smooth;scrollbar-width:none;touch-action:pan-x;width:100%;min-width:0;min-height:0;display:flex;overflow:auto hidden}.swipe-pages::-webkit-scrollbar{display:none}.swipe-page{scroll-snap-align:start;flex:0 0 100%;min-width:100%;min-height:0}.device-page{grid-template-rows:repeat(3,minmax(0,1fr));grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;height:100%;display:grid}.device-tile{border:1px solid var(--line);background:var(--panel);height:100%;min-height:0;box-shadow:var(--shadow);color:var(--ink);text-align:left;border-radius:18px;grid-template-rows:auto auto auto auto;align-content:start;gap:clamp(4px,1.4vw,7px);padding:clamp(10px,3vw,13px);display:grid;position:relative;overflow:hidden}.device-tile svg{width:clamp(19px,5.4vw,23px);height:clamp(19px,5.4vw,23px);color:var(--accent)}.tile-led{background:#a4adb4;border-radius:50%;width:9px;height:9px;position:absolute;top:12px;right:12px}.tile-led.online{background:#1f9d68;box-shadow:0 0 0 4px #1f9d681f}.device-name,.device-id,.device-dht{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.device-name{color:var(--ink);font-size:clamp(13px,3.7vw,16px);font-weight:900;line-height:1.05}.device-id,.device-dht{color:var(--muted);font-size:clamp(11px,3.2vw,14px);line-height:1.12}.device-dht{color:var(--accent-strong);font-size:clamp(12px,3.3vw,14px);font-weight:900}.gpio-page{grid-template-rows:repeat(3,minmax(0,1fr));grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;height:100%;display:grid}.gpio-tile{border:1px solid var(--line);color:#fff;text-align:center;background:#6b706f;border-radius:18px;grid-template-rows:auto minmax(0,1fr) auto;place-items:center;gap:5px;height:100%;min-height:0;padding:9px 6px;display:grid;overflow:hidden}.gpio-tile svg{color:#fff}.gpio-tile span{color:#fff;overflow-wrap:anywhere;-webkit-line-clamp:3;-webkit-box-orient:vertical;min-width:0;max-width:100%;font-size:clamp(13px,3.7vw,17px);font-weight:900;line-height:1.12;display:-webkit-box;overflow:hidden}.gpio-tile:not(.sensor-control-tile) span{-webkit-line-clamp:2}.gpio-tile .gpio-pin-caption{color:#ffffffd1;text-overflow:ellipsis;white-space:nowrap;min-width:0;max-width:100%;font-size:clamp(10px,2.9vw,12px);font-weight:850;line-height:1;display:block;overflow:hidden}.gpio-tile.on{background:#238441;border-color:#1b8e55}.sensor-control-tile{color:var(--accent-strong);background:#f8fbfa;border-color:#b8d7d0;box-shadow:inset 0 0 0 1px #15806514}.sensor-control-tile.live{background:var(--accent-soft);border-color:#75b798}.sensor-control-tile svg,.sensor-control-tile span{color:var(--accent-strong)}.sensor-control-tile .sensor-tile-meta{justify-items:center;gap:2px;width:100%;min-width:0;display:grid}.sensor-control-tile .sensor-reading-caption,.sensor-control-tile .sensor-pin-caption{text-overflow:ellipsis;white-space:nowrap;min-width:0;max-width:100%;font-size:clamp(10px,2.9vw,12px);font-weight:900;line-height:1.05;display:block;overflow:hidden}.sensor-control-tile .sensor-reading-caption{color:var(--muted)}.sensor-control-tile .sensor-pin-caption{color:var(--accent-strong);letter-spacing:.04em;text-transform:uppercase}.gpio-label-preview{border:1px solid var(--line);color:var(--muted);background:#f8fbfa;border-radius:16px;gap:4px;padding:12px;display:grid}.gpio-label-preview svg{color:var(--accent-strong)}.gpio-label-preview span,.gpio-label-preview small{color:var(--muted);font-size:12px;font-weight:850;line-height:1.1}.gpio-label-preview strong{min-width:0;color:var(--ink);overflow-wrap:anywhere;font-size:clamp(15px,4vw,17px);font-weight:900;line-height:1.12;overflow:hidden}.mobile-sheet-backdrop{z-index:80;padding:14px 14px max(14px, env(safe-area-inset-bottom));background:#0d1c1942;place-items:end center;display:grid;position:fixed;inset:0}.mobile-picker-sheet{border:1px solid var(--line);background:#fff;border-radius:26px 26px 20px 20px;gap:14px;width:min(100%,480px);max-height:min(82dvh,640px);padding:16px;display:grid;overflow-y:auto;box-shadow:0 -20px 50px #14322a2e}.mobile-picker-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.mobile-picker-header h2{color:var(--ink);margin:0;font-size:20px;line-height:1.05}.picker-option-list{gap:8px;display:grid}.picker-option{border:1px solid var(--line);width:100%;min-height:58px;color:var(--ink);text-align:left;background:#fbfcfb;border-radius:16px;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:3px 10px;padding:10px 12px;display:grid}.picker-option svg{color:var(--accent-strong);grid-row:span 2}.picker-option span,.picker-option small{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.picker-option span{font-size:16px;font-weight:900}.picker-option small{color:var(--muted);font-size:12px;font-weight:850}.picker-icon-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.picker-icon-option{border:1px solid var(--line);min-height:74px;color:var(--ink);text-align:center;background:#fbfcfb;border-radius:18px;place-items:center;gap:7px;padding:10px 8px;display:grid}.picker-icon-option svg{color:var(--accent-strong)}.picker-icon-option span{text-overflow:ellipsis;white-space:nowrap;min-width:0;max-width:100%;font-size:13px;font-weight:900;line-height:1.05;overflow:hidden}.picker-option.active,.picker-icon-option.active{background:var(--accent-soft);color:var(--accent-strong);border-color:#66c097}.device-actions-card{gap:12px;padding:14px;display:grid}.placeholder-card{gap:8px;display:grid}.recovery-card{gap:12px;padding:14px;display:grid}.recovery-event-card{border:1px solid var(--line);background:#fbfcfb;border-radius:16px;gap:10px;padding:12px;display:grid}.recovery-event-card.unexpected{background:#fff8e7;border-color:#f0c36d}.recovery-event-card.scheduled{background:var(--accent-soft);border-color:#b9d8c7}.recovery-event-title{justify-content:space-between;align-items:center;gap:8px;min-width:0;display:flex}.recovery-event-title span,.recovery-event-title strong{overflow-wrap:anywhere;min-width:0}.recovery-event-title span{color:var(--ink);font-size:15px;font-weight:900}.recovery-event-title strong{color:var(--muted);font-size:12px}.recovery-fact-list{grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);align-items:start;gap:8px 10px;display:grid}.recovery-fact-list span{color:var(--muted);font-size:12px;font-weight:800}.recovery-fact-list strong{min-width:0;color:var(--ink);overflow-wrap:anywhere;text-align:right;font-size:13px;font-weight:900}.recovery-empty{border:1px dashed var(--line);min-height:48px;color:var(--muted);border-radius:16px;align-items:center;gap:8px;padding:10px 12px;font-size:13px;font-weight:800;display:flex}.device-action-button{border:1px solid var(--line);max-width:100%;min-height:48px;color:var(--ink);background:#fbfcfb;border-radius:16px;justify-content:center;align-items:center;gap:8px;padding:0 14px;font-weight:900;display:inline-flex;overflow:hidden}.device-action-button.full{width:100%}.device-action-button.danger{background:var(--danger-soft);color:var(--danger);border-color:#f1b4ad}.restart-confirm{background:var(--danger-soft);border:1px solid #f1b4ad;border-radius:16px;gap:10px;padding:12px;display:grid}.restart-confirm strong{color:var(--danger);font-size:16px;line-height:1.25}.restart-confirm-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.page-dots{justify-content:center;align-items:center;gap:7px;min-height:24px;display:flex}.page-dots button{background:0 0;border:0;border-radius:999px;width:44px;height:44px;min-height:44px;padding:0;position:relative}.page-dots button:before{content:"";background:#b6c1bb;border-radius:999px;width:7px;height:7px;position:absolute;inset:50% auto auto 50%;transform:translate(-50%,-50%)}.page-dots button.active:before{background:var(--accent);width:20px}.empty-phone-state{height:100%;min-height:220px;color:var(--muted);text-align:center;border:1px dashed #bdc7bf;border-radius:18px;align-content:center;place-items:center;gap:10px;padding:16px;font-weight:850;display:grid}.empty-phone-state.compact{min-height:150px}.claim-code{background:var(--accent-soft);color:var(--accent-strong);text-align:center;border:1px solid #75b798;border-radius:18px;padding:18px;font-size:clamp(42px,16vw,70px);font-weight:950;line-height:1}.setup-grid{gap:10px;display:grid}.setup-value{grid-template-columns:minmax(0,1fr) 44px;gap:7px;display:grid}.setup-value span{color:var(--muted);grid-column:1/-1;font-size:16px;font-weight:800}.setup-value code{border:1px solid var(--line);overflow-wrap:anywhere;background:#f7faf8;border-radius:14px;min-width:0;min-height:44px;padding:10px;font-size:16px;display:block}.setup-value button{border:1px solid var(--line);width:44px;height:44px;color:var(--blue);background:#fff;border-radius:14px;justify-content:center;align-items:center;display:inline-flex}.setup-note{color:var(--muted);font-size:16px;line-height:1.38}.sensor-settings-form,.device-settings-form{flex:auto;grid-template-rows:minmax(0,1fr) auto;gap:10px;min-height:0;display:grid}.sensor-detail-content{flex:auto;min-height:0;display:grid;overflow:hidden}.sensor-detail-scroll{align-content:start;gap:12px;display:grid}.sensor-hero-card{gap:12px;display:grid}.sensor-hero-card.healthy{background:#f3fbf6;border-color:#8fcdae}.sensor-large-readings{grid-template-columns:1fr 1fr;gap:10px;display:grid}.sensor-large-readings div{border:1px solid var(--soft-line);background:#fff;border-radius:18px;gap:7px;min-width:0;padding:13px;display:grid}.sensor-large-readings svg{color:var(--accent-strong)}.sensor-large-readings span{color:var(--muted);font-size:13px;font-weight:850}.sensor-large-readings strong{min-width:0;color:var(--ink);text-overflow:ellipsis;white-space:nowrap;font-size:clamp(24px,7vw,34px);line-height:1;overflow:hidden}.sensor-facts-card{gap:10px;display:grid}.sensor-fact-list{grid-template-columns:auto minmax(0,1fr);align-items:center;gap:9px 12px;display:grid}.sensor-fact-list span{color:var(--muted);font-size:14px;font-weight:850}.sensor-fact-list strong{min-width:0;color:var(--ink);text-align:right;text-overflow:ellipsis;white-space:nowrap;font-size:15px;overflow:hidden}.sensor-settings-scroll{align-content:start;gap:12px;display:grid}.sensor-config-card,.alexa-config-card{gap:12px;display:grid}.alexa-summary-row{border:1px solid var(--line);min-height:48px;color:var(--muted);background:#f8fbfa;border-radius:16px;justify-content:space-between;align-items:center;gap:12px;padding:0 12px;font-size:14px;font-weight:850;display:flex}.alexa-summary-row strong{color:var(--ink);font-size:16px}.alexa-pin-panel{gap:12px;display:grid}.alexa-toggle-row{border:1px solid var(--line);width:100%;min-height:58px;color:var(--ink);text-align:left;background:#fbfcfb;border-radius:16px;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;display:flex}.alexa-toggle-row.active{border-color:var(--accent);background:var(--accent-soft)}.alexa-toggle-row span:first-child{gap:4px;min-width:0;display:grid}.alexa-toggle-row strong,.alexa-toggle-row small{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.alexa-toggle-row strong{font-size:16px;font-weight:900}.alexa-toggle-row small{color:var(--muted);font-size:13px;font-weight:850}.toggle-pill{min-width:52px;color:var(--muted);text-align:center;background:#e9eeec;border-radius:999px;flex:none;font-size:13px;font-weight:900;line-height:28px}.alexa-toggle-row.active .toggle-pill{background:var(--accent);color:#fff}.alexa-category-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:7px;display:grid}.alexa-category-grid button{border:1px solid var(--line);min-width:0;min-height:44px;color:var(--muted);background:#fbfcfb;border-radius:14px;padding:0 8px;font-size:14px;font-weight:850}.alexa-category-grid button.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-strong)}.alexa-category-grid button:disabled,.field input:disabled{cursor:not-allowed;opacity:.62}.alexa-link-scroll{padding-bottom:calc(88px + env(safe-area-inset-bottom))}.alexa-link-card{gap:12px;display:grid}.alexa-link-facts{border:1px solid var(--line);background:#f8fbfa;border-radius:16px;grid-template-columns:minmax(0,1fr) minmax(0,auto);align-items:center;gap:10px 12px;padding:12px;display:grid}.alexa-link-facts span,.alexa-link-facts strong{overflow-wrap:anywhere;min-width:0}.alexa-link-facts span{color:var(--muted);font-size:14px;font-weight:850}.alexa-link-facts strong{color:var(--ink);text-align:right;font-size:15px;font-weight:900}.alexa-permission-list{gap:8px;display:grid}.alexa-permission-list div{border:1px solid var(--line);min-height:50px;color:var(--muted);background:#fbfcfb;border-radius:16px;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:10px;padding:10px 12px;font-size:14px;font-weight:850;line-height:1.25;display:grid}.alexa-permission-list svg{color:var(--accent-strong)}.alexa-permission-list span{overflow-wrap:anywhere;min-width:0}.sensor-enable{color:var(--muted);padding-inline:12px}.sensor-enable.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-strong)}.sticky-form-actions{padding-top:4px;padding-bottom:env(safe-area-inset-bottom);flex:none}.settings-actions{gap:8px;display:grid}.settings-row{border:1px solid var(--line);width:100%;min-width:0;max-width:100%;color:var(--ink);background:#fbfcfb;border-radius:16px;justify-content:flex-start;align-items:center;gap:10px;padding:0 12px;font-weight:850;display:flex;overflow:hidden}.settings-row span{text-overflow:ellipsis;white-space:nowrap;flex:1;width:0;min-width:0;overflow:hidden}.settings-row.danger{color:var(--danger)}.settings-row.placeholder{color:var(--muted)}.alexa-readiness-card{gap:12px;display:grid}.alexa-readiness-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.alexa-readiness-grid div{border:1px solid var(--line);background:#fbfcfb;border-radius:16px;gap:4px;min-height:62px;padding:10px;display:grid}.alexa-readiness-grid div.ready{background:#f2fbf7;border-color:#117a6547}.alexa-readiness-grid span,.alexa-readiness-grid strong{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.alexa-readiness-grid span{color:var(--muted);font-size:12px;font-weight:850}.alexa-readiness-grid strong{color:var(--ink);font-size:16px;font-weight:900}.alexa-setup-steps{gap:8px;display:grid}.alexa-setup-steps div{border:1px solid var(--line);min-height:48px;color:var(--muted);background:#fbfcfb;border-radius:16px;grid-template-columns:auto minmax(0,1fr);align-items:start;gap:9px;padding:10px 12px;font-size:14px;font-weight:850;line-height:1.25;display:grid}.alexa-setup-steps div.done{color:var(--accent-strong);background:#f2fbf7;border-color:#117a653d}.alexa-setup-steps svg{color:var(--accent-strong)}.alexa-setup-steps span{overflow-wrap:anywhere;min-width:0}.bottom-nav{border:1px solid var(--line);box-shadow:var(--shadow);padding:7px;padding-bottom:max(7px, env(safe-area-inset-bottom));background:#fffffff0;border-radius:22px;flex:none;grid-template-columns:repeat(4,minmax(0,1fr));gap:7px;display:grid}.bottom-nav button{min-width:0;min-height:54px;color:var(--muted);background:0 0;border:0;border-radius:16px;place-items:center;gap:2px;padding-inline:2px;font-weight:850;display:grid;overflow:hidden}.bottom-nav button.active{background:var(--accent-soft);color:var(--accent-strong)}.bottom-nav span{text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:12px;line-height:1;overflow:hidden}.device-bottom-nav{border:1px solid var(--line);box-shadow:var(--shadow);padding:7px;padding-bottom:max(7px, env(safe-area-inset-bottom));background:#fffffff0;border-radius:22px;flex:none;grid-template-columns:repeat(5,minmax(0,1fr));gap:6px;display:grid}.device-bottom-nav button{min-width:0;min-height:54px;color:var(--muted);background:0 0;border:0;border-radius:16px;place-items:center;gap:2px;padding-inline:2px;font-weight:850;display:grid;overflow:hidden}.device-bottom-nav button.active{background:var(--accent-soft);color:var(--accent-strong)}.device-bottom-nav span{text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:11px;line-height:1;overflow:hidden}.sensor-bottom-nav{border:1px solid var(--line);box-shadow:var(--shadow);padding:7px;padding-bottom:max(7px, env(safe-area-inset-bottom));background:#fffffff0;border-radius:22px;flex:none;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px;display:grid}.sensor-bottom-nav button{min-width:0;min-height:54px;color:var(--muted);background:0 0;border:0;border-radius:16px;place-items:center;gap:2px;padding-inline:2px;font-weight:850;display:grid;overflow:hidden}.sensor-bottom-nav button.active{background:var(--accent-soft);color:var(--accent-strong)}.sensor-bottom-nav span{text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:12px;line-height:1;overflow:hidden}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media (min-width:780px){.phone-screen{border:1px solid var(--line);border-radius:24px;height:min(100dvh,920px);box-shadow:0 24px 80px #1d2a2429}}@media (min-width:900px){.shell{width:min(860px,100% - 32px)}.auth-shell{grid-template-columns:minmax(0,1fr) minmax(320px,420px);align-items:center}}@media (max-width:360px){.phone-screen{gap:9px;padding-inline:10px}h1{font-size:26px}.summary-card{padding-inline:8px}.summary-card strong{font-size:21px}.gpio-page,.device-page{gap:7px}.sensor-large-readings{gap:8px}}@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important}}
