.layout{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;padding-bottom:0;background:#0f0f14}.layout-header{display:flex;align-items:flex-start;justify-content:space-between;flex-shrink:0;padding:.5rem 1rem;padding-top:max(.5rem,env(safe-area-inset-top));padding-left:max(1rem,env(safe-area-inset-left));padding-right:max(1rem,env(safe-area-inset-right));background:#18181b;color:#e4e4e7;position:relative;z-index:20;border-bottom:1px solid rgba(255,255,255,.06)}.layout-brand{font-weight:700;font-size:1.1rem;color:inherit;text-decoration:none;min-height:48px;display:inline-flex;align-items:center;flex:1;min-width:0}.layout-brand.layout-quote{flex-direction:column;align-items:flex-start;justify-content:center;font-weight:500}.layout-quote-text{font-size:.85rem;line-height:1.3;white-space:pre-wrap;word-break:break-word}.layout-quote-author{font-size:.75rem;color:#71717a;margin-top:.15rem}.layout-menu-btn{display:flex;flex-direction:column;justify-content:center;gap:5px;width:48px;height:48px;padding:.5rem;background:transparent;border:none;cursor:pointer;color:inherit}.layout-menu-dot{display:block;width:20px;height:3px;background:currentColor;border-radius:2px}.layout-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:30}.layout-account{position:fixed;top:0;right:0;width:min(280px,85vw);max-height:50vh;padding:1rem;padding-top:max(3rem,calc(env(safe-area-inset-top) + 2rem));background:#18181b;color:#e4e4e7;box-shadow:-4px 0 24px #00000080;z-index:40;transform:translate(100%);transition:transform .2s ease-out;border-left:1px solid rgba(255,255,255,.06)}.layout-account-open{transform:translate(0)}.layout-account-email{margin:0 0 1rem;font-size:.9rem;color:#a1a1aa;word-break:break-all}.layout-signout{width:100%;min-height:48px;padding:.75rem 1rem;font-size:1rem;font-weight:600;background:#ef444433;color:#f87171;border:none;border-radius:8px;cursor:pointer}.layout-signout:hover{background:#ef44444d}.layout-main{flex:1;overflow:auto;padding:1rem;padding-left:max(1rem,env(safe-area-inset-left));padding-right:max(1rem,env(safe-area-inset-right));padding-bottom:calc(4rem + env(safe-area-inset-bottom));width:100%;max-width:100%;background:#0f0f14;color:#e4e4e7}.layout-bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:stretch;justify-content:space-around;padding:.5rem 0;padding-bottom:max(.5rem,env(safe-area-inset-bottom));padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);background:#18181b;color:#71717a;z-index:10;border-top:1px solid rgba(255,255,255,.06)}.layout-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;min-height:48px;padding:.35rem .5rem;color:inherit;text-decoration:none;font-size:.75rem;font-weight:500;transition:color .15s}.layout-tab:active{background:#ffffff0d}.layout-tab-active{color:#fff}.layout-tab-icon{font-size:1.25rem;line-height:1}.layout-tab-label{line-height:1.2}@media(min-width:768px){.layout-main{max-width:42rem;margin:0 auto;padding-bottom:2rem}.layout-bottom-nav{position:relative;max-width:42rem;margin:0 auto;border-radius:12px 12px 0 0;border-top:none;border:1px solid rgba(255,255,255,.06);border-bottom:none;box-shadow:0 -2px 20px #0000004d}.layout-main{padding-bottom:1.5rem}}.unauthorized{min-height:70vh;min-height:70dvh;display:flex;align-items:center;justify-content:center;padding:1.5rem 1.5rem 3rem}.unauthorized-card{text-align:center;width:100%;max-width:340px;padding:1.75rem;background:#18181b;color:#e4e4e7;border-radius:16px;box-shadow:0 12px 40px #00000080;border:1px solid rgba(255,255,255,.06)}.unauthorized-emoji{font-size:2.75rem;display:block;margin-bottom:.5rem}.unauthorized-title{margin:0 0 .75rem;font-size:1.25rem;font-weight:700;line-height:1.35}.unauthorized-sub{margin:0 0 1.5rem;color:#a1a1aa;font-size:.95rem;line-height:1.4}.unauthorized-btn{width:100%;min-height:48px;padding:.75rem 1.25rem;font-size:1rem;font-weight:600;color:#fff;background:#3f3f46;border:none;border-radius:10px;cursor:pointer}.unauthorized-btn:hover{background:#52525b}.unauthorized-btn:active{transform:scale(.98)}.dashboard{display:flex;flex-direction:column;gap:1rem;padding-bottom:1rem;width:100%}.ha-card{width:100%;background:#18181b;border-radius:12px;padding:1.25rem;border:1px solid rgba(255,255,255,.06)}.ha-card-label{display:block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#71717a;margin-bottom:.75rem}.ha-temperature{text-align:center}.ha-temp-row{display:flex;align-items:baseline;justify-content:center;gap:.35rem;margin-bottom:.5rem}.ha-temp-row:last-of-type{margin-bottom:.75rem}.ha-temp-label{font-size:.8rem;font-weight:500;color:#71717a;min-width:3.5rem;text-align:right}.ha-temp-value{font-size:2.75rem;font-weight:700;color:#fff;line-height:1}.ha-temp-current{font-size:2rem;color:#a1a1aa}.ha-temp-set{font-size:1.5rem}.ha-temp-unit{font-size:1.25rem;color:#71717a}.ha-temp-control{display:flex;align-items:center;justify-content:center;gap:1rem}.ha-temp-target{font-size:.85rem;color:#71717a;min-width:3rem}.ha-btn{min-height:48px;min-width:48px;display:inline-flex;align-items:center;justify-content:center;font:inherit;font-weight:600;border:none;border-radius:10px;cursor:pointer}.ha-btn-icon{width:48px;height:48px;background:#3f3f46;color:#fff;font-size:1.35rem;line-height:1}.ha-btn-icon:hover{background:#52525b}.ha-gate{display:flex;flex-direction:column;align-items:center;gap:.75rem}.ha-gate-status{margin:.25rem 0}.ha-gate-badge{display:inline-block;padding:.4rem .9rem;border-radius:20px;font-size:.95rem;font-weight:600}.ha-gate-closed{background:#27272a;color:#a1a1aa}.ha-gate-open{background:#22c55e33;color:#4ade80}.ha-btn-gate{width:100%;min-height:48px;padding:.75rem 1.25rem;background:#3f3f46;color:#fff;font-size:1rem}.ha-btn-gate:hover{background:#52525b}.ha-btn-gate-open{background:#27272a;color:#a1a1aa}.ha-btn-gate-open:hover{background:#3f3f46}.ha-light-list{list-style:none;margin:0;padding:0}.ha-light-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 0;border-bottom:1px solid rgba(255,255,255,.06);min-height:56px}.ha-light-item:last-child{border-bottom:none}.ha-light-name{font-weight:500;font-size:1rem;text-transform:capitalize;color:#e4e4e7}.ha-toggle{position:relative;width:56px;height:30px;min-width:56px;min-height:30px;padding:0;background:#27272a;border-radius:15px;cursor:pointer;transition:background .2s;flex-shrink:0}.ha-toggle:hover{background:#3f3f46}.ha-toggle-on{background:#3b82f6}.ha-toggle-on:hover{background:#2563eb}.ha-toggle-thumb{position:absolute;top:2px;left:2px;width:26px;height:26px;background:#fff;border-radius:50%;box-shadow:0 1px 3px #0000004d;transition:transform .2s}.ha-toggle-on .ha-toggle-thumb{transform:translate(26px)}@media(min-width:640px){.dashboard{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.ha-temperature{grid-column:1 / -1}}@media(min-width:900px){.dashboard{grid-template-columns:1fr 1fr 1fr}.ha-temperature,.ha-gate{grid-column:span 1}}.guests-page{padding-bottom:1rem}.guests-card{width:100%;background:#18181b;border-radius:12px;padding:1.25rem;border:1px solid rgba(255,255,255,.06)}.guests-title{margin:0 0 .25rem;font-size:1.35rem;font-weight:700;color:#fff}.guests-desc{margin:0 0 1.25rem;font-size:.875rem;color:#71717a}.guests-form{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem}.guests-input{flex:1;min-width:0;min-height:48px;padding:0 1rem;font-size:1rem;color:#e4e4e7;background:#27272a;border:1px solid rgba(255,255,255,.08);border-radius:10px}.guests-input::placeholder{color:#71717a}.guests-input:focus{outline:none;border-color:#3b82f6}.guests-btn-add{min-height:48px;padding:0 1.25rem;font-size:1rem;font-weight:600;color:#fff;background:#3b82f6;border:none;border-radius:10px;cursor:pointer}.guests-btn-add:hover:not(:disabled){background:#2563eb}.guests-btn-add:disabled{opacity:.6;cursor:not-allowed}.guests-error{margin:0 0 1rem;font-size:.875rem;color:#f87171}.guests-loading,.guests-empty{margin:0;font-size:.9rem;color:#71717a}.guests-list{list-style:none;margin:0;padding:0}.guests-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 0;border-bottom:1px solid rgba(255,255,255,.06)}.guests-item:last-child{border-bottom:none}.guests-email{font-size:.95rem;color:#e4e4e7;word-break:break-all}.guests-btn-remove{flex-shrink:0;padding:.4rem .75rem;font-size:.85rem;font-weight:500;color:#f87171;background:#ef444426;border:none;border-radius:8px;cursor:pointer}.guests-btn-remove:hover{background:#ef444440}.guests-forbidden{margin:0;font-size:1rem;color:#a1a1aa}*,*:before,*:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;font-size:16px}body{margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:1rem;line-height:1.5;color:#e4e4e7;background:#0f0f14;min-height:100vh;min-height:100dvh;padding:0;overflow-x:hidden}a,button{min-height:48px;min-width:48px;display:inline-flex;align-items:center;justify-content:center}button{cursor:pointer;font:inherit;border:none;background:none}.app-wrap{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);padding-bottom:env(safe-area-inset-bottom)}.page{padding:.25rem 0;width:100%;color:#e4e4e7}.page-title{margin:0 0 1rem;font-size:1.35rem;font-weight:700;line-height:1.2;color:#fff}.page-pre{margin-top:1rem;padding:1rem;background:#1a1a24;color:#a1a1aa;border:1px solid rgba(255,255,255,.08);border-radius:10px;overflow:auto;font-size:.875rem;-webkit-overflow-scrolling:touch}.btn{min-height:48px;padding:.75rem 1.25rem;font-size:1rem;font-weight:600;border-radius:10px;cursor:pointer;border:none}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:#3f3f46;color:#fff}.btn-primary:hover:not(:disabled){background:#52525b}@media(min-width:768px){.page-title{font-size:1.5rem}}
