:root{--bg: #f4f7f4;--surface: #ffffff;--surface-soft: #f8faf8;--border: #dce6e0;--border-soft: #edf2ef;--text: #10211d;--muted: #5f706a;--muted-soft: #7f918b;--brand: #173c33;--brand-2: #207d66;--accent: #f0b84a;--danger: #b53a2a;--danger-soft: #fff0ed;--success: #1e7a5f;--success-soft: #e8f6f0;--warning: #9b6b12;--warning-soft: #fff4cf;--shadow: 0 18px 44px rgba(19, 45, 38, .08);--radius: 8px;color:var(--text);background:var(--bg);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,select{font:inherit}button{cursor:pointer}input,select,button{max-width:100%}button:disabled{cursor:not-allowed;opacity:.55}button:focus-visible,input:focus-visible,select:focus-visible,a:focus-visible{outline:3px solid rgba(240,184,74,.55);outline-offset:2px}h1,h2,h3,p{margin-top:0}h1{margin-bottom:0;font-size:30px;line-height:1.1}h2{margin-bottom:0;font-size:18px}h3{margin-bottom:8px;font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:0}.appShell{display:grid;min-height:100vh;grid-template-columns:280px minmax(0,1fr)}.sidebar{position:sticky;top:0;display:flex;flex-direction:column;gap:26px;height:100vh;padding:24px;color:#eef8ef;background:var(--brand)}.brand{display:flex;align-items:center;gap:12px;min-width:0}.brand svg{flex:0 0 auto;width:34px;height:34px}.brand strong,.brand span{display:block}.brand span,.eyebrow{color:var(--muted-soft);font-size:13px}.brand.big{color:var(--brand);margin-bottom:26px}nav{display:grid;gap:8px}nav button,.ghost,.primary,.secondary,.linkButton,.dangerButton{display:inline-flex;align-items:center;justify-content:center;gap:9px;min-height:42px;border:0;border-radius:var(--radius);padding:0 14px}.primary,.secondary,.dangerButton{font-weight:700}nav button,.ghost{justify-content:flex-start;color:#e6f0ec;background:transparent}nav button.active,nav button:hover,.ghost:hover{background:#ffffff1a}nav button.active{box-shadow:inset 0 0 0 2px var(--accent)}.ghost{margin-top:auto}main{width:min(1180px,100%);padding:30px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:28px}.tenantPicker,.tenantBadge{display:inline-flex;align-items:center;gap:10px;min-height:46px;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);color:#40504a;background:var(--surface)}.tenantPicker select,input,select{min-height:40px;border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;color:var(--text);background:var(--surface)}.tenantPicker select{border:0;padding:0}.dashboardGrid,.helpGrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.metric,.panel,.widePanel,.helpCard,.authPanel,.publicPanel{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow)}.metric{display:grid;gap:8px;padding:20px}.metric svg{color:var(--brand-2)}.metric span,.dataCard span,.timeline span,.panelTitle span{color:var(--muted);font-size:13px}.metric strong{font-size:22px}.widePanel{grid-column:1 / -1;padding:24px}.twoColumn{display:grid;grid-template-columns:minmax(320px,380px) minmax(0,1fr);gap:18px;align-items:start}.pageStack{display:grid;gap:18px}.panel{padding:22px}.panelTitle{display:grid;gap:3px}.panelHeader,.pager,.timelineTop{display:flex;align-items:center;justify-content:space-between;gap:12px}.panelHeader{margin-bottom:14px}.panelHeader.flush{margin-bottom:10px}.toolbar{align-items:end}.toolbarActions{display:flex;align-items:center;justify-content:flex-end;gap:10px}.toolbarActions .primary,.toolbarActions .secondary{min-width:168px;padding:0 18px;white-space:nowrap}.toolbarActions .primary svg,.toolbarActions .secondary svg{flex:0 0 auto}.form,.formSection{display:grid;gap:14px;min-width:0}.formSection{padding-bottom:4px}.form label{display:grid;gap:6px;min-width:0;color:#40504a;font-size:14px}.compactFields{grid-template-columns:1fr .6fr;min-width:0;gap:14px}.compactFields h3{grid-column:1 / -1}.gatePicker{display:grid;gap:10px;margin:0;padding:12px;min-width:0;border:1px solid var(--border);border-radius:var(--radius)}.gatePicker legend{padding:0 6px;color:#40504a;font-size:14px}.checkboxRow{display:grid;grid-template-columns:18px minmax(0,1fr);gap:10px;align-items:start}.checkboxRow input{width:18px;height:18px;margin:2px 0 0;padding:0}.checkboxRow span,.checkboxRow small{display:grid;gap:2px}.checkboxRow small,.dataCard small{color:var(--muted);font-size:12px}.primary{color:#fff;background:var(--brand-2)}.secondary{color:var(--brand);background:#edf4f1}.dangerButton{color:#fff;background:var(--danger)}.linkButton{color:var(--brand-2);background:transparent}.notice{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-top:14px;padding:14px;border-radius:var(--radius);background:var(--success-soft)}.checklist{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:16px}.checklist span{display:grid;gap:4px;padding:12px;border:1px solid var(--border-soft);border-radius:var(--radius);background:var(--surface-soft)}.checklist svg{color:var(--brand-2)}.list,.timeline{display:grid;gap:10px}.shellyDevices{margin-top:14px}.dataCard{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:14px;align-items:center;padding:12px;border:1px solid var(--border-soft);border-radius:var(--radius);background:var(--surface)}.linkCard{grid-template-columns:minmax(0,1.3fr) minmax(260px,1fr) auto}.gateCard{grid-template-columns:auto minmax(0,1fr) auto auto auto}.deviceCard,.settingsCard{grid-template-columns:auto minmax(0,1fr) auto auto}.settingsCard{grid-template-columns:auto minmax(0,1fr)}.cardMain{min-width:0;display:grid;gap:4px}.cardMain strong,.cardMain span,.cardMain small,.metaItem strong{overflow-wrap:anywhere}.cardMeta{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;align-items:center}.metaItem{display:grid;gap:2px}.metaItem small{color:var(--muted);font-size:11px}.metaItem strong{font-size:13px;font-weight:600}.statusBadge{display:inline-flex;width:max-content;align-items:center;justify-content:center;min-height:24px;padding:3px 9px;border-radius:999px;border:1px solid var(--border);color:var(--muted);background:var(--surface-soft);font-size:12px;font-weight:700}.statusBadge.active,.statusBadge.online,.statusBadge.true{border-color:#b8dfce;color:var(--success);background:var(--success-soft)}.statusBadge.revoked,.statusBadge.disabled,.statusBadge.offline,.statusBadge.false{border-color:#f3c2ba;color:var(--danger);background:var(--danger-soft)}.statusBadge.maintenance,.statusBadge.expired{border-color:#f0d99c;color:var(--warning);background:var(--warning-soft)}.actionGroup{display:inline-flex;gap:8px}.iconButton{display:inline-grid;width:36px;height:36px;place-items:center;border:1px solid var(--border);border-radius:var(--radius);color:var(--brand);background:var(--surface)}.iconButton svg{width:17px;height:17px}.mutedText{color:var(--muted-soft);font-size:12px}.iconButton.danger{color:var(--danger)}.pager{margin:16px 0 0;color:var(--muted);font-size:13px}.searchInput{width:min(320px,100%)}.pageButtons{display:inline-flex;align-items:center;gap:6px}.pageButton{min-width:34px;height:34px;border:1px solid var(--border);border-radius:var(--radius);color:var(--brand);background:var(--surface)}.pageButton.active{color:#fff;background:var(--brand-2)}.timeline article{position:relative;display:grid;gap:8px;padding:14px 14px 14px 22px;border-left:3px solid var(--brand-2);background:var(--surface-soft)}.timeline p{margin-bottom:0}details{color:var(--muted);font-size:13px}summary{cursor:pointer}code{display:block;margin-top:8px;overflow-wrap:anywhere;color:#365249}.helpCard{display:grid;gap:12px;padding:22px}.helpCard svg{color:var(--danger)}.emptyState{display:grid;gap:6px;justify-items:start;padding:14px;border:1px dashed var(--border);border-radius:var(--radius);color:var(--muted);background:var(--surface-soft)}.emptyState svg{color:var(--brand-2)}.emptyState strong{color:var(--text)}.authLayout,.publicLayout{display:grid;min-height:100vh;place-items:center;padding:24px;background:linear-gradient(120deg,#173c33eb,#207d6694),url(https://images.unsplash.com/photo-1486406146926-c627a92ad1ab?auto=format&fit=crop&w=1800&q=80);background-size:cover;background-position:center}.authPanel,.publicPanel{width:min(440px,100%);padding:30px}.publicPanel{display:grid;justify-items:start;gap:14px}.publicSummary{display:grid;width:100%;gap:5px;padding:12px;border:1px solid var(--border-soft);border-radius:var(--radius);color:#40504a;background:var(--surface-soft)}.publicSummary strong{color:var(--brand)}.publicSummary span{font-size:13px}.publicGateList{display:grid;width:100%;gap:10px}.publicPanel svg{color:var(--brand-2)}.error{color:var(--danger)}.warning{padding:10px 12px;border-radius:var(--radius);color:var(--warning);background:var(--warning-soft)}.success{color:var(--success)}.dialogOverlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#0c1b177a}.dialogContent{position:fixed;top:50%;left:50%;z-index:60;display:grid;width:min(420px,calc(100vw - 32px));min-width:0;gap:14px;padding:22px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:0 24px 64px #00000038;transform:translate(-50%,-50%)}.formDialog{width:min(560px,calc(100vw - 32px));max-height:min(86vh,780px);overflow-x:hidden;overflow-y:auto}.dialogHeader{display:flex;align-items:start;justify-content:space-between;gap:14px}.dialogContent h2,.dialogContent p{margin:0}.dialogContent h2,.dialogContent [data-radix-dialog-title]{font-size:20px;font-weight:800}.dialogContent [data-radix-dialog-description]{color:var(--muted);font-size:13px}.dialogActions{display:flex;justify-content:flex-end;gap:10px}.toastViewport{position:fixed;right:18px;bottom:18px;z-index:80;display:grid;gap:10px;width:min(360px,calc(100vw - 28px))}.toast{padding:14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow)}.toast.success{border-color:#b8dfce}.toast.error{border-color:#f3c2ba}.toastTitle{font-weight:800}.toastDescription{margin-top:4px;color:var(--muted);font-size:13px}.createdLink{display:grid;gap:6px;margin-bottom:14px;color:#40504a;font-size:14px}@media(max-width:980px){.appShell{display:block}.sidebar{height:auto;border-radius:0 0 14px 14px;gap:12px;padding:12px;box-shadow:0 10px 24px #18342d2e}.sidebar nav{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}nav button,.ghost{justify-content:center;min-height:40px;padding:0 10px;white-space:nowrap}.ghost{width:100%;margin-top:0}main{padding:16px}.twoColumn,.dashboardGrid,.helpGrid,.checklist{grid-template-columns:1fr}.topbar{align-items:stretch;flex-direction:column;gap:12px;margin-bottom:16px}h1{font-size:24px}.tenantPicker,.tenantBadge{width:100%}.tenantPicker select{min-width:0;width:100%}.panel,.widePanel,.metric,.helpCard{padding:16px;box-shadow:none}.widePanel{grid-column:auto}.panelHeader,.toolbar{align-items:stretch;flex-direction:column}.panelHeader .iconButton{align-self:flex-end}.toolbarActions,.searchInput,.toolbar select{width:100%}.toolbarActions{align-items:stretch;flex-direction:column}.toolbarActions .primary,.toolbarActions .secondary{width:100%;min-width:0}.linkCard,.gateCard,.deviceCard,.settingsCard{grid-template-columns:minmax(0,1fr);align-items:stretch}.dataCard>svg{display:none}.cardMeta{grid-template-columns:repeat(2,minmax(0,1fr))}.actionGroup{justify-content:flex-start;flex-wrap:wrap}.pager{align-items:stretch;flex-direction:column}.pageButtons{flex-wrap:wrap}.notice{align-items:stretch;flex-direction:column}.authPanel,.publicPanel{padding:20px}}@media(max-width:520px){.brand span{display:none}.sidebar nav{grid-template-columns:repeat(2,minmax(0,1fr))}nav button svg,.ghost svg{width:17px;height:17px}main{padding:12px}.twoColumn{gap:12px}.panel,.widePanel,.metric,.helpCard{padding:14px}.form{gap:12px}.compactFields,.cardMeta{grid-template-columns:1fr}.dashboardGrid,.helpGrid{gap:12px}.metric strong{font-size:19px}.dataCard{padding:10px}.pageButton{min-width:32px;height:32px}.authLayout,.publicLayout{align-items:start;padding:14px}.primary,.secondary,.linkButton,.dangerButton{width:100%}.toastViewport{right:14px;bottom:14px}.dialogContent{width:calc(100vw - 24px);max-height:calc(100vh - 24px);padding:16px}.formDialog{overflow-x:hidden}}
