:root{color-scheme:dark;--bg: #0a0a0f;--surface: #14141c;--border: #2a2a38;--text: #f2f2f7;--muted: #9898a8;--accent: #3b82f6;--accent-hover: #2563eb;--ok: #22c55e;--warn: #f59e0b;--radius: 12px;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100dvh;background:var(--bg);color:var(--text);line-height:1.5}.shell{max-width:720px;margin:0 auto;padding:2rem 1.25rem 3rem}.brand{margin:0 0 .25rem;font-size:1.75rem;font-weight:700;letter-spacing:-.02em}.tagline,.hint,.user-line,.device-meta,.device-id{color:var(--muted)}.header{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem 1rem;margin-bottom:1.5rem}.header .brand{flex:1 1 auto;margin-bottom:0}.lang-bar,.flash-header{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem 1rem}.flash-header{justify-content:space-between;margin-bottom:.5rem}.flash-header h1{margin:0}.lang-select{min-width:10.5rem;padding:.45rem .55rem;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text);font:inherit;font-size:.88rem}[dir=rtl] .header,[dir=rtl] .device-actions{flex-direction:row-reverse}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--border);border-radius:999px;padding:.65rem 1.25rem;font:inherit;cursor:pointer;background:var(--surface);color:var(--text)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn.primary{background:var(--accent);border-color:transparent;color:#fff}.btn.primary:hover:not(:disabled){background:var(--accent-hover)}.btn.ghost{background:transparent}.units-bar{display:flex;gap:.5rem;margin:.35rem 0 .75rem}.units-bar .units-btn.active{border-color:var(--accent);color:var(--accent);font-weight:600}.btn.btn-danger-sm{font-size:.82rem;padding:.35rem .85rem;background:transparent;color:var(--danger, #c0392b);border:1px solid var(--danger, #c0392b)}.btn.btn-danger-sm:hover:not(:disabled){background:#c0392b1f}.status-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin:1rem 0 .5rem}.status-header h2{margin:0}.btn.btn-sm{font-size:.82rem;padding:.35rem .85rem}.tesla-link-actions{margin-top:.5rem}.rtdb-status{font-size:.875rem;padding:.5rem .75rem;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);margin-bottom:1.5rem}.rtdb-status.ok{border-color:color-mix(in srgb,var(--ok) 40%,var(--border));color:var(--ok)}.rtdb-status.warn{border-color:color-mix(in srgb,var(--warn) 40%,var(--border));color:var(--warn)}.device-list h2{font-size:1.125rem;margin:0 0 1rem}.device-grid{display:grid;gap:1rem}.device-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem}.device-title{margin:0 0 .25rem;font-size:1.05rem}.device-id{font-family:ui-monospace,monospace;font-size:.875rem;margin:0 0 .5rem}.device-status{margin:0;font-size:.875rem;font-weight:600}.device-status.online{color:var(--ok)}.device-status.offline{color:var(--muted)}.setup-hub-status{margin:.5rem 0 0;font-size:.875rem;font-weight:600}.setup-hub-status.online{color:var(--ok)}.setup-hub-status.offline{color:var(--muted)}.live-hint{margin:.25rem 0 .75rem;font-size:.8125rem}.empty-state{padding:1.25rem;border-radius:var(--radius);background:var(--surface);border:1px dashed var(--border);color:var(--muted)}.loading{text-align:center;padding:3rem;color:var(--muted)}.add-device{margin-bottom:2rem;padding:1.25rem;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border)}.add-device h2{margin:0 0 1rem;font-size:1.125rem}.claim-step{margin-bottom:1.25rem}.claim-step h3{margin:0 0 .35rem;font-size:.95rem}.claim-step:last-child{margin-bottom:0}.input{display:block;width:100%;margin:.5rem 0;padding:.65rem .85rem;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);font:inherit}.token-line{font-family:ui-monospace,monospace;font-size:1.1rem;font-weight:600;letter-spacing:.08em;margin:.75rem 0}.device-card.clickable{cursor:pointer}.device-card.clickable:hover{border-color:var(--accent)}.device-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0}.telemetry-box{font-family:ui-monospace,monospace;font-size:.8rem;padding:.85rem;border-radius:8px;background:var(--bg);border:1px solid var(--border);white-space:pre-wrap;word-break:break-word}.telemetry-box.muted{color:var(--muted);max-height:240px;overflow:auto}.firmware-block{display:flex;flex-direction:column;gap:.35rem;align-items:flex-start;margin-bottom:.5rem}.key-status-line.online{color:var(--ok)}.device-setup{margin-top:1.5rem;padding:1.25rem;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border)}.device-setup>h2{margin:0 0 1rem;font-size:1.125rem}.setup-tabs{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:1rem}.setup-tab{padding:.45rem .85rem;font-size:.875rem}.zb-mappings-wrap{margin:1rem 0;overflow-x:auto}.zb-mappings-table{width:100%;border-collapse:collapse;font-size:.8rem}.zb-mappings-table th,.zb-mappings-table td{padding:.35rem .5rem;border-bottom:1px solid var(--border);text-align:left}.zb-mappings-table th{color:var(--muted);font-weight:600}.setup-tab.active{border-color:var(--accent);color:var(--accent)}button.btn.primary.active{border-color:var(--ok)}.setup-panel h2{margin:0 0 .5rem;font-size:1rem}.setup-backup-panel{margin:1rem 0;padding:.85rem 1rem;border-radius:var(--radius);border:1px dashed var(--border);background:color-mix(in srgb,var(--surface) 92%,var(--accent) 8%)}.setup-backup-panel h2{font-size:.95rem}.setup-backup-panel .device-actions{margin-top:.65rem}.warn-line{color:var(--warn);margin:.5rem 0}.portal-panel{margin:1.25rem 0 0;padding:1.25rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.dash{display:flex;flex-direction:column;gap:1rem;padding:.25rem 0 1.5rem}.dash-header{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem .75rem}.dash-title{margin:0;flex:1 1 auto;font-size:1.35rem;font-weight:700;letter-spacing:-.02em}.dash-section-title{margin:0 0 .65rem;font-size:.82rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.dash-tesla-strip{margin:0}.tesla-strip{display:flex;flex-wrap:wrap;align-items:center;gap:.65rem;padding:.85rem 1rem;border-radius:14px;border:1px solid var(--border);background:var(--surface)}.tesla-linked-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .75rem;border-radius:999px;font-size:.82rem;font-weight:600;background:color-mix(in srgb,var(--ok) 18%,transparent);color:var(--ok);border:1px solid color-mix(in srgb,var(--ok) 35%,var(--border))}.tesla-strip .tesla-link-actions{margin:0;flex:1 1 auto;display:flex;justify-content:flex-end}.tesla-strip .btn.primary{width:100%}.tesla-disconnect-link{font-size:.82rem;padding:.4rem .65rem}.tesla-link-status{flex:1 1 100%;margin:0;font-size:.82rem}.dash-vehicles-grid{display:flex;flex-direction:column;gap:.75rem}.vehicle-dash-card{padding:1rem 1.05rem .85rem;border-radius:16px;border:1px solid var(--border);background:linear-gradient(160deg,var(--surface) 0%,color-mix(in srgb,var(--surface) 88%,#000) 100%);cursor:pointer;transition:border-color .15s ease,transform .15s ease}.vehicle-dash-card:hover,.vehicle-dash-card:focus-visible{border-color:color-mix(in srgb,var(--accent) 55%,var(--border));outline:none}.vehicle-dash-card:active{transform:scale(.99)}.vdc-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.75rem}.vdc-title{margin:0;font-size:1.05rem;font-weight:650}.vdc-badge{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.2rem .5rem;border-radius:999px;background:var(--border);color:var(--muted)}.vdc-badge-live,.vdc-badge-recent{background:color-mix(in srgb,var(--ok) 20%,transparent);color:var(--ok)}.vdc-badge-stale{background:color-mix(in srgb,var(--warn) 18%,transparent);color:var(--warn)}.vdc-foot{margin:.65rem 0 0;font-size:.78rem;color:var(--muted)}.stat-grid{display:grid;gap:.5rem}.stat-grid-compact{grid-template-columns:repeat(3,minmax(0,1fr))}@media(max-width:520px){.stat-grid-compact{grid-template-columns:repeat(2,minmax(0,1fr))}}.stat-grid-full{grid-template-columns:repeat(2,minmax(0,1fr))}.stat-grid-empty{grid-column:1 / -1;margin:0;font-size:.85rem}.stat-tile{display:flex;flex-direction:column;gap:.15rem;padding:.65rem .75rem;border-radius:12px;background:color-mix(in srgb,var(--bg) 65%,var(--surface));border:1px solid color-mix(in srgb,var(--border) 80%,transparent);min-height:4.25rem}.stat-tile-wide{grid-column:1 / -1}.stat-value{font-size:1.25rem;font-weight:700;line-height:1.15;letter-spacing:-.02em}.stat-tile-battery .stat-value{font-size:1.05rem;line-height:1.2;word-break:break-word}.vehicle-location-section{margin:1rem 0 0;padding:.85rem 1rem;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface)}.vehicle-location-title{margin:0 0 .5rem;font-size:.95rem;font-weight:600}.vehicle-location-links{display:flex;flex-wrap:wrap;gap:.5rem;margin:.5rem 0 .75rem}.vehicle-location-map{width:100%;height:220px;border:0;border-radius:10px;background:color-mix(in srgb,var(--bg) 80%,var(--surface))}.vehicle-tpms-section{margin:1rem 0 0;padding:.85rem 1rem;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface)}.vehicle-tpms-title{margin:0 0 .65rem;font-size:.95rem;font-weight:600}.vehicle-tpms-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem}.vehicle-tpms-cell{display:flex;flex-direction:column;gap:.15rem;padding:.55rem .65rem;border-radius:10px;background:color-mix(in srgb,var(--bg) 70%,var(--surface))}.vehicle-tpms-label{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.vehicle-tpms-value{font-size:1.05rem;font-weight:600}.vehicle-tpms-value.muted{color:var(--muted);font-weight:500}.notifications-screen{display:flex;flex-direction:column;gap:.75rem}.notifications-topbar{display:flex;align-items:center;gap:.65rem}.notifications-title{margin:0;font-size:1.15rem;font-weight:600}.notifications-list{display:flex;flex-direction:column;gap:.65rem}.notifications-card{padding:.85rem 1rem;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface)}.notifications-card-title{margin:0 0 .35rem;font-size:.95rem}.notifications-card-body{margin:0 0 .65rem;font-size:.875rem;color:var(--muted)}.notifications-push-hint{margin:0}@media(min-width:400px){.stat-tile-battery .stat-value{font-size:1.15rem}}.stat-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.stat-sub{font-size:.78rem;color:var(--muted);margin-top:-.1rem}.stat-tile-accent .stat-value{color:var(--accent)}.stat-tile-ok .stat-value{color:var(--ok)}.stat-tile-warn .stat-value{color:var(--warn)}.dash-family-details{border:1px solid var(--border);border-radius:14px;padding:.65rem 1rem 1rem;background:var(--surface)}.dash-family-details summary{cursor:pointer;font-weight:600;font-size:.92rem;list-style:none}.dash-family-details summary::-webkit-details-marker{display:none}.dash-family-details .portal-card{border:none;padding:.75rem 0 0;background:transparent}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.vehicle-screen{min-height:min(100dvh,100vh);padding:0 0 2rem;margin:-.25rem -.15rem 0}.vehicle-topbar{display:grid;grid-template-columns:auto 1fr auto;align-items:start;gap:.65rem;padding:.35rem 0 1rem;position:sticky;top:0;z-index:2;background:color-mix(in srgb,var(--bg) 92%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);margin-bottom:.5rem}.vehicle-back{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--border);background:var(--surface);color:var(--text);width:2.5rem;height:2.5rem;border-radius:12px;font-size:1.15rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.vehicle-name{margin:0;font-size:1.15rem;font-weight:700;line-height:1.2}.vehicle-sub{margin:.15rem 0 0;font-size:.82rem;color:var(--muted)}.vehicle-live-badge{font-size:.72rem;font-weight:700;text-transform:uppercase;padding:.25rem .55rem;border-radius:999px;margin-top:.25rem;background:var(--border);color:var(--muted)}.vehicle-live-badge-live,.vehicle-live-badge-recent{background:color-mix(in srgb,var(--ok) 20%,transparent);color:var(--ok)}.vehicle-live-badge-stale{background:color-mix(in srgb,var(--warn) 18%,transparent);color:var(--warn)}.vehicle-stats-section{margin-bottom:.75rem}.live-data-banner{margin-bottom:1rem;padding:1rem;border-radius:14px;border:1px solid color-mix(in srgb,var(--accent) 35%,var(--border));background:color-mix(in srgb,var(--accent) 8%,var(--surface))}.live-data-banner-title{margin:0 0 .35rem;font-size:.95rem}.vehicle-updated{margin:0 0 1rem;font-size:.78rem;text-align:center}.vehicle-panel-details{margin-bottom:.65rem;border:1px solid var(--border);border-radius:14px;padding:.65rem 1rem 1rem;background:var(--surface)}.vehicle-panel-details summary{cursor:pointer;font-weight:600;font-size:.92rem;list-style:none}.vehicle-panel-details summary::-webkit-details-marker{display:none}.vehicle-settings-panel .form-field{margin-top:.75rem}@media(min-width:520px){.stat-grid-full{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:480px){.stat-grid-compact .stat-value{font-size:1.1rem}}.portal-panel-muted{opacity:.85}.portal-panel-muted .btn:disabled{cursor:not-allowed;opacity:.55}.shell-embedded{max-width:none;margin:0;padding:0}.portal-home{display:flex;flex-direction:column;gap:1rem}.portal-card{margin:0;padding:1.15rem 1.25rem;border:1px solid var(--border);border-radius:16px;background:var(--surface)}.portal-card-title,.portal-card .portal-card-title{margin:0 0 .35rem;font-size:1.05rem;font-weight:650}.portal-card-lead{margin:0 0 1rem;font-size:.9rem;color:var(--muted);line-height:1.5}.portal-subheading{margin:1.15rem 0 .65rem;font-size:.95rem;font-weight:600}.portal-card-share{margin-top:0}.portal-card-tesla .tesla-link-actions{margin-top:.75rem}.vehicle-card-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.vehicle-card-chevron{color:var(--muted);font-size:1.25rem;line-height:1}.empty-state.compact{padding:.85rem 1rem;font-size:.9rem}.embed-heading{margin:0 0 .5rem;font-size:1.15rem;font-weight:600}.commandpark-embed-section .card{padding:0;border:none;background:transparent;box-shadow:none}.commandpark-embed{padding:0;border:none;background:transparent}.portal-textarea{font-family:ui-monospace,monospace;font-size:.75rem;min-height:120px;resize:vertical}.panel-subhead{margin:1.25rem 0 .5rem;font-size:.9rem;font-weight:600}.form-field{margin-bottom:max(3px,.75rem)}.wifi-input-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:max(3px,.75rem);margin-bottom:max(3px,.75rem)}.wifi-inline-field{display:flex;flex-direction:column;gap:.25rem;min-width:0}.wifi-inline-field .field-label{margin-bottom:0}.wifi-inline-field .input{width:100%;margin:0}@media(max-width:720px){.wifi-input-row{grid-template-columns:1fr}}.form-field.checkbox-row,label.checkbox-row{display:flex;flex-direction:row;align-items:center;gap:.5rem}.form-field.checkbox-row .field-label,label.checkbox-row .field-label{margin-bottom:0;order:2;flex:1}.form-field.checkbox-row input[type=checkbox],label.checkbox-row input[type=checkbox]{order:1;width:1.1rem;height:1.1rem;flex-shrink:0;margin:0}.vehicle-settings-panel .settings-hint{margin:-.25rem 0 .75rem;font-size:.82rem}.zb-last-press{color:var(--ok);font-weight:500}.zb-remote-accordion{margin-top:.75rem}.zb-remote-accordion details{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.5rem;padding:.35rem .65rem}.zb-remote-accordion summary{cursor:pointer;font-weight:600}.zb-mapping-edit-row{display:grid;grid-template-columns:1fr 1fr;gap:.35rem .75rem;margin:.5rem 0;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.zb-slot-title{grid-column:1 / -1;margin:0;font-weight:600;font-size:.95rem}.zb-remove-remote{grid-column:1 / -1;justify-self:start;margin-top:.5rem;color:var(--danger, #c0392b)}.zb-mapping-edit-row:last-child{border-bottom:none}.macro-builder-block{margin:1rem 0;padding:.75rem 1rem;border:1px solid var(--border);border-radius:var(--radius)}.macro-step-row{display:grid;grid-template-columns:1fr auto;gap:.5rem;margin-bottom:.5rem;align-items:end}.field-label{display:block;font-size:.8rem;color:var(--muted);margin-bottom:.25rem}.wifi-connected-line.online{color:var(--ok)}.command-select{width:100%;max-width:100%;margin-bottom:.75rem}.macro-preset-list{display:grid;gap:.75rem;margin:1rem 0}.macro-preset-card{padding:.75rem 1rem;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg)}.macro-preset-name{margin:0 0 .25rem;font-size:.95rem}.macro-preset-meta{margin:.35rem 0 0;font-size:.75rem}.macro-preset-use{margin-top:.5rem}.advanced-block{margin-top:1.25rem;padding-top:.5rem}.advanced-block summary{cursor:pointer;font-size:.875rem;color:var(--muted)}.zb-learn-status.online,.valet-live-line.online{color:var(--ok)}.portal-panel h3{margin:1rem 0 .35rem;font-size:.95rem}.quiet-hours-row{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin:.75rem 0}.quiet-hours-row .input{width:auto;min-width:7rem}.telemetry-block p{margin:.25rem 0}
