@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes fade-in-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in-down{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes scale-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes backdrop-in{0%{opacity:0}to{opacity:1}}@keyframes slide-in-alert{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes subtle-pulse{0%,to{opacity:1}50%{opacity:.65}}@keyframes nav-indicator-in{0%{opacity:0;transform:scaleX(0)}to{opacity:1;transform:scaleX(1)}}.animate-fade-in{animation:.35s both fade-in}.animate-fade-in-up{animation:.45s cubic-bezier(.22,1,.36,1) both fade-in-up}.animate-delay-1{animation-delay:80ms}.animate-fade-in-down{animation:.4s cubic-bezier(.22,1,.36,1) both fade-in-down}.animate-scale-in{animation:.28s cubic-bezier(.22,1,.36,1) both scale-in}.animate-backdrop-in{animation:.2s both backdrop-in}.animate-slide-in-alert{animation:.35s cubic-bezier(.22,1,.36,1) both slide-in-alert}.page-transition{animation:.4s cubic-bezier(.22,1,.36,1) both fade-in-up}.stagger-children>*{animation:.45s cubic-bezier(.22,1,.36,1) both fade-in-up}.stagger-children>:first-child{animation-delay:0s}.stagger-children>:nth-child(2){animation-delay:50ms}.stagger-children>:nth-child(3){animation-delay:.1s}.stagger-children>:nth-child(4){animation-delay:.15s}.stagger-children>:nth-child(5){animation-delay:.2s}.stagger-children>:nth-child(6){animation-delay:.25s}.stagger-children>:nth-child(7){animation-delay:.3s}.stagger-children>:nth-child(8){animation-delay:.35s}.stagger-children>:nth-child(9){animation-delay:.4s}.stagger-children>:nth-child(10){animation-delay:.45s}.stagger-children>:nth-child(11){animation-delay:.5s}.stagger-children>:nth-child(12){animation-delay:.55s}.dashboard-results{animation:.3s both fade-in}.dashboard-results>.meta-bar{animation:.4s cubic-bezier(.22,1,.36,1) both fade-in-down}.dashboard-results>.summary-cards{animation-delay:0s}.dashboard-results>.dashboard-grid{animation:.5s cubic-bezier(.22,1,.36,1) .1s both fade-in-up}.dashboard-results>.panel:nth-of-type(n){animation:.45s cubic-bezier(.22,1,.36,1) both fade-in-up}.dashboard-results>.panel:first-of-type{animation-delay:.15s}.dashboard-results>.panel:nth-of-type(2){animation-delay:.22s}.btn{transition:background-color var(--transition), border-color var(--transition), color var(--transition), transform .12s ease, box-shadow var(--transition)}.btn:active:not(:disabled){transform:scale(.98)}.summary-card{transition:border-color var(--transition), box-shadow var(--transition), transform .2s cubic-bezier(.22, 1, .36, 1)}.summary-card:hover{transform:translateY(-2px)}.panel{transition:box-shadow .2s ease, border-color var(--transition)}.app-navbar__link{transition:background var(--transition), color var(--transition), transform .15s ease;position:relative}.app-navbar__link:active{transform:scale(.97)}.app-navbar__link--active:after{content:"";background:#ffffff80;border-radius:1px;height:2px;animation:.25s both nav-indicator-in;position:absolute;bottom:2px;left:.85rem;right:.85rem}.sensor-grid__item{transition:background var(--transition), border-color var(--transition), transform .2s ease}.sensor-grid__item:hover{border-color:var(--color-border);transform:translate(3px)}.status-dot--fault{animation:2s ease-in-out infinite subtle-pulse}.empty-state-panel{animation:.55s cubic-bezier(.22,1,.36,1) both fade-in-up}.empty-state-panel__icon{animation:2.5s ease-in-out infinite subtle-pulse}.query-form__submit:not(:disabled):hover{box-shadow:0 4px 14px #3b82f659}.btn--loading{animation:1.2s ease-in-out infinite subtle-pulse}.dashboard-skeleton{animation:.3s both fade-in}.auth-split__brand{animation:.6s both fade-in}.auth-split__form .auth-card{animation:.45s cubic-bezier(.22,1,.36,1) .1s both scale-in}.modal-backdrop{animation:.2s both backdrop-in}.modal{animation:.28s cubic-bezier(.22,1,.36,1) both scale-in}.alert{animation:.35s cubic-bezier(.22,1,.36,1) both slide-in-alert}.heatmap__cell{transition:opacity .15s,transform .15s}.heatmap__cell:hover{opacity:.9;z-index:1;transform:scaleY(1.15)}.timeline-sensor-badges .badge{transition:background var(--transition), color var(--transition), transform .2s ease, opacity .2s ease}.timeline-sensor-badges--active .badge{animation:.2s both fade-in}.badge--faulty{animation:1.8s ease-in-out infinite subtle-pulse}.page__header{animation:.45s cubic-bezier(.22,1,.36,1) both fade-in-down}.panel--form{animation:.4s cubic-bezier(.22,1,.36,1) 50ms both fade-in-up}.temp-side{transition:opacity .25s ease, border-color var(--transition)}.temp-side input[type=range]{transition:accent-color var(--transition)}:root{--font-sans:"Plus Jakarta Sans", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, monospace;--color-bg:#0f172a;--color-bg-elevated:#1e293b;--color-surface:#1e293b;--color-surface-hover:#334155;--color-border:#334155;--color-border-subtle:#293548;--color-text:#f8fafc;--color-text-muted:#94a3b8;--color-text-subtle:#64748b;--color-primary:#3b82f6;--color-primary-hover:#2563eb;--color-success:#22c55e;--color-success-bg:#14532d;--color-warning:#f59e0b;--color-danger:#ef4444;--color-danger-bg:#3f1d1d;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-full:999px;--shadow-sm:0 1px 2px #00000040;--shadow-md:0 4px 12px #00000059;--space-xs:.35rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--transition:.15s ease;--input-height:2.75rem;--page-max-width:1280px}*,:before,:after{box-sizing:border-box}body{min-height:100vh;font-family:var(--font-sans);color:var(--color-text);background-color:var(--color-bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;margin:0;font-weight:400;line-height:1.5}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}code{font-family:var(--font-mono);background:#1a2332;border-radius:4px;padding:.1em .35em;font-size:.9em}#root{min-height:100vh}.dashboard{max-width:1280px;margin:0 auto;padding:1.5rem 1.25rem 3rem}.app-shell{flex-direction:column;min-height:100vh;display:flex}.app-navbar{z-index:10;background:#151c28;border-bottom:1px solid #2a3344;align-items:center;gap:1.5rem;padding:.85rem 1.25rem;display:flex;position:sticky;top:0}.app-navbar__brand{white-space:nowrap;color:#e8edf4;font-size:1rem;font-weight:600}.app-navbar__links{flex:1;align-items:center;gap:.35rem;display:flex;overflow-x:auto}.app-navbar__link{color:#8b9cb3;white-space:nowrap;border-radius:6px;padding:.45rem .85rem;font-size:.9rem;text-decoration:none}.app-navbar__link:hover{color:#e8edf4;background:#1a2332}.app-navbar__link--active{color:#fff;background:#2563eb}.app-navbar__user{flex-shrink:0;align-items:center;gap:.75rem;display:flex}.app-main{flex:1}.page{max-width:1280px;margin:0 auto;padding:1.5rem 1.25rem 3rem}.page__header{margin-bottom:1.25rem}.page__header h1{margin:0 0 .35rem;font-size:1.75rem;font-weight:600}.page__subtitle{color:#8b9cb3;margin:0;font-size:.9rem}.device-selector{grid-template-columns:minmax(140px,1fr) minmax(220px,1.5fr);gap:1rem;margin-bottom:1rem;display:grid}.iot-device-picker{flex-direction:column;gap:1rem;display:flex}.iot-device-filter{max-width:220px}.iot-device-list{flex-direction:column;gap:.5rem;display:flex}.iot-device-list__status{color:var(--color-text-muted);background:var(--color-bg);border:1px dashed var(--color-border-subtle);border-radius:var(--radius-md);margin:0;padding:.75rem 1rem;font-size:.9rem}.iot-device-row{border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);background:var(--color-bg);cursor:pointer;transition:border-color var(--transition), background var(--transition);align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.iot-device-row:hover{border-color:var(--color-border);background:var(--color-bg-elevated)}.iot-device-row--selected{border-color:var(--color-primary);background:#2563eb14}.iot-device-row__checkbox{width:1rem;height:1rem;accent-color:var(--color-primary);cursor:pointer;flex-shrink:0}.iot-device-row__id{font-family:var(--font-mono);color:var(--color-text);word-break:break-all;font-size:.85rem}.iot-device-expandable{flex-direction:column;gap:0;display:flex}.iot-device-expandable__panel{border-left:2px solid var(--color-primary);margin:0 0 .5rem .5rem;padding:0 .75rem .75rem 2.5rem;animation:.3s cubic-bezier(.22,1,.36,1) both fade-in-up}.iot-device-expandable__submit{min-width:12rem;margin-top:.75rem}.iot-device-expandable__desc{color:var(--color-text-muted);margin:0 0 .5rem;font-size:.9rem}.ota-panel__fields{gap:.75rem;margin:.75rem 0;display:grid}.ota-panel__optional{color:var(--color-text-subtle);font-weight:400}.iot-panel__action{margin-top:.5rem}.iot-panel__submit{min-width:12rem;height:2.75rem}.alert--success{color:#bbf7d0;background:#14532d;border:1px solid #166534;border-radius:6px;margin-top:1rem;padding:.75rem 1rem;font-size:.9rem}.temp-sides{grid-template-columns:1fr 1fr;gap:1rem;margin:1rem 0;display:grid}.temp-side{background:#0f1419;border:1px solid #2a3344;border-radius:8px;margin:0;padding:1rem}.temp-side legend{padding:0 .25rem}.temp-side__legend{color:#e8edf4;align-items:center;gap:.5rem;font-weight:500;display:inline-flex}.temp-side__field{color:#8b9cb3;justify-content:space-between;align-items:center;gap:1rem;margin-top:.75rem;font-size:.9rem;display:flex}.temp-side__field input[type=number]{color:#e8edf4;background:#151c28;border:1px solid #2a3344;border-radius:6px;width:6rem;height:2.5rem;padding:0 .75rem}@media (width<=768px){.app-navbar{flex-wrap:wrap}.app-navbar__links{order:3;width:100%}.device-selector,.temp-sides{grid-template-columns:1fr}}.dashboard__hero{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;display:flex}.dashboard__hero h1{margin:0 0 .35rem;font-size:1.75rem;font-weight:600}.dashboard__subtitle{color:#8b9cb3;max-width:52rem;margin:0}.dashboard__meta-bar{color:#8b9cb3;background:#151c28;border:1px solid #2a3344;border-radius:8px;flex-wrap:wrap;gap:1.5rem;margin-bottom:1rem;padding:.75rem 1rem;font-size:.9rem;display:flex}.panel{background:#151c28;border:1px solid #2a3344;border-radius:10px;margin-bottom:1.25rem;padding:1.25rem}.panel--form{padding-bottom:1rem}.panel__header{margin-bottom:1rem}.panel__header h2{margin:0 0 .25rem;font-size:1.1rem;font-weight:600}.panel__meta{color:#8b9cb3;margin:0;font-size:.85rem}.query-form{grid-template-columns:1fr 1fr;align-items:end;gap:.75rem;display:grid}.query-form__field--range,.query-form__field--submit,.query-form__error{grid-column:1/-1}.query-form__field--submit{margin-top:-.25rem}.date-range-picker{border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);background:var(--color-bg);flex-direction:column;gap:.65rem;padding:.85rem 1rem;display:flex}.date-range-picker__header{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.date-range-picker__header-icon{color:var(--color-primary);flex-shrink:0}.date-range-picker__title{color:var(--color-text);font-size:.85rem;font-weight:600}.date-range-picker__duration{color:var(--color-text-muted);background:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:999px;margin-left:auto;padding:.15rem .55rem;font-size:.8rem}.date-range-picker__duration--error{color:var(--color-danger);background:#ef444414;border-color:#ef444459}.date-range-picker__presets{flex-wrap:wrap;gap:.4rem;display:flex}.date-range-picker__preset{border:1px solid var(--color-border-subtle);background:var(--color-bg-elevated);color:var(--color-text-muted);cursor:pointer;transition:background var(--transition), border-color var(--transition), color var(--transition), transform .12s ease;border-radius:999px;padding:.35rem .75rem;font-size:.8rem;font-weight:500}.date-range-picker__preset:hover:not(:disabled){color:var(--color-text);border-color:var(--color-border);background:var(--color-surface-hover)}.date-range-picker__preset--active{color:#fff;background:var(--color-primary);border-color:var(--color-primary)}.date-range-picker__preset:active:not(:disabled){transform:scale(.97)}.date-range-picker__preset:disabled{opacity:.55;cursor:not-allowed}.date-range-picker__inputs{grid-template-rows:auto auto;grid-template-columns:1fr auto 1fr;align-items:center;gap:.3rem .75rem;display:grid}.date-range-picker__input--start{grid-area:1/1}.date-range-picker__arrow{color:#93c5fd;flex-shrink:0;grid-area:1/2;align-items:center;gap:.15rem;padding:0 .15rem;display:flex}.date-range-picker__arrow-line{background:linear-gradient(90deg,#94a3b859,#60a5fa);border-radius:999px;width:1.5rem;height:2px}.date-range-picker__arrow-icon{filter:drop-shadow(0 0 6px #60a5fa59);flex-shrink:0}.date-range-picker__input--end{grid-area:1/3}.date-range-picker__hint--start{grid-area:2/1}.date-range-picker__hint--end{grid-area:2/3}.date-range-picker__input{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-elevated);width:100%;height:2.75rem;color:var(--color-text);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;box-sizing:border-box;padding:0 .75rem;font-size:.95rem}.date-range-picker__input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 2px #3b82f640}.date-range-picker__input:disabled{opacity:.6;cursor:not-allowed}.date-range-picker__hint{color:var(--color-text-subtle);padding-left:.1rem;font-size:.75rem}@media (width<=768px){.date-range-picker__inputs{grid-template-rows:none;grid-template-columns:1fr;row-gap:.5rem}.date-range-picker__input--start{grid-area:auto/1}.date-range-picker__hint--start{grid-area:auto/1;margin-bottom:.15rem}.date-range-picker__arrow{grid-area:auto/1;justify-content:center;padding:.15rem 0;transform:rotate(90deg)}.date-range-picker__arrow-line{width:1.25rem}.date-range-picker__input--end,.date-range-picker__hint--end{grid-area:auto/1}.date-range-picker__duration{margin-left:0}}.query-form__field{flex-direction:column;min-width:0;display:flex}.query-form__error{margin-top:0}@media (width<=520px){.query-form{grid-template-columns:1fr}}.query-form__field label{color:#8b9cb3;min-height:2.5rem;margin-bottom:.35rem;font-size:.8rem;line-height:1.25;display:block}.query-form__label-spacer{visibility:hidden;-webkit-user-select:none;user-select:none;min-height:2.5rem;margin-bottom:.35rem}.query-form__field input,.query-form__field select,.query-form__submit{color:#e8edf4;box-sizing:border-box;background:#0f1419;border:1px solid #2a3344;border-radius:6px;width:100%;height:2.75rem;min-height:2.75rem;padding:0 .75rem;font-size:.95rem;line-height:1.25}.query-form__field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238b9cb3' d='M2 4l4 4 4-4'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;padding-right:2rem}.query-form__field input:focus,.query-form__field select:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 2px #3b82f640}.query-form__field input:disabled,.query-form__field select:disabled{opacity:.6;cursor:not-allowed}.query-form__submit{white-space:nowrap;cursor:pointer;color:#fff;background:#3b82f6;border:none;justify-content:center;align-items:center;font-weight:500;display:inline-flex}.query-form__submit:hover:not(:disabled){background:#2563eb}.query-form__submit:disabled{opacity:.55;cursor:not-allowed}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:6px;padding:.6rem 1.25rem;font-size:.95rem;font-weight:500}.btn--primary{color:#fff;background:#3b82f6}.btn--primary:hover:not(:disabled){background:#2563eb}.btn:disabled{opacity:.55;cursor:not-allowed}.alert{border-radius:6px;margin-top:1rem;padding:.75rem 1rem;font-size:.9rem}.alert--error{color:#fecaca;background:#3f1d1d;border:1px solid #7f1d1d}.alert__hint{color:#fca5a5;margin:.5rem 0 0;font-size:.85rem}.summary-cards{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem;margin-bottom:1.25rem;display:grid}.summary-card{background:#151c28;border:1px solid #2a3344;border-radius:8px;padding:1rem}.summary-card__label{color:#8b9cb3;text-transform:uppercase;letter-spacing:.04em;margin-bottom:.35rem;font-size:.75rem;display:block}.summary-card__value{font-size:1.5rem;font-weight:600}.summary-card--warn .summary-card__value{color:#f87171}.summary-card--ok .summary-card__value{color:#4ade80}.summary-card--off .summary-card__value{color:#94a3b8}.table-wrap{overflow-x:auto}.table-wrap--scroll{max-height:360px;overflow-y:auto}.data-table{border-collapse:collapse;width:100%;font-size:.88rem}.data-table th,.data-table td{text-align:left;border-bottom:1px solid #2a3344;padding:.55rem .75rem}.data-table th{color:#8b9cb3;background:#151c28;font-weight:500;position:sticky;top:0}.data-table tbody tr:hover{background:#1a2332}.row--fault{background:#7f1d1d26}.badge{text-transform:capitalize;border-radius:999px;padding:.15rem .5rem;font-size:.75rem;font-weight:500;display:inline-block}.badge--healthy{color:#86efac;background:#14532d}.badge--faulty{color:#fecaca;background:#7f1d1d}.badge--off{color:#94a3b8;background:#1e293b;border:1px solid #334155}.badge--idle{color:#64748b;opacity:.65;background:0 0;border:1px dashed #334155}.timeline-sensor-badges--active .badge{opacity:1}.badge--no_data{color:#d1d5db;background:#374151}.row--off{background:#1e293b59}.binary{letter-spacing:.08em;font-size:.82em}.chart-container{width:100%;min-height:280px}.timeline-sensor-badges{flex-wrap:wrap;gap:.35rem;margin-top:.65rem;display:flex}.timeline-tooltip{color:#e8edf4;background:#1a2332;border:1px solid #2a3344;border-radius:8px;padding:.6rem .75rem;font-size:.85rem}.timeline-tooltip__time{margin:0 0 .35rem;font-weight:600}.timeline-tooltip p{margin:.2rem 0}.timeline-tooltip__faults{color:#fca5a5}.timeline-tooltip__ok{color:#86efac}.heatmap-wrap{padding-bottom:.5rem;overflow-x:auto}.heatmap{gap:2px;min-width:min-content;display:grid}.heatmap__corner{min-height:24px}.heatmap__col-label{color:#6b7c93;text-align:center;writing-mode:vertical-rl;max-height:48px;font-size:.65rem;overflow:hidden;transform:rotate(180deg)}.heatmap__row-label{color:#8b9cb3;white-space:nowrap;align-items:center;padding-right:.5rem;font-size:.75rem;display:flex}.heatmap__cell{border-radius:2px;width:100%;min-width:6px;height:18px}.heatmap__cell--ok{background:#22c55e}.heatmap__cell--off{opacity:.45;background:0 0;border:1px dashed #334155}.heatmap__cell--fault{background:#ef4444}.heatmap-legend{color:#8b9cb3;gap:1rem;margin-top:.5rem;font-size:.8rem;display:flex}.heatmap-legend__item{align-items:center;gap:.35rem;display:inline-flex}.heatmap-legend__swatch{border-radius:2px;width:14px;height:14px;display:inline-block}.heatmap-legend__swatch--ok{background:#22c55e}.heatmap-legend__swatch--off{background:0 0;border:1px dashed #475569}.heatmap-legend__swatch--fault{background:#ef4444}.empty-state{color:#8b9cb3;margin:0;padding:1rem 0}.empty-state--ok{color:#4ade80}.auth-page{justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.auth-page__loading{color:#8b9cb3}.auth-card--clerk{box-shadow:none;background:0 0;border:none;padding:0}.auth-card{background:#151c28;border:1px solid #2a3344;border-radius:12px;width:100%;max-width:420px;padding:2rem}.auth-card h1{margin:0 0 .5rem;font-size:1.5rem;font-weight:600}.auth-card__subtitle{color:#8b9cb3;margin:0 0 1.5rem;font-size:.9rem}.auth-card__footer{text-align:center;color:#8b9cb3;margin:1.25rem 0 0;font-size:.9rem}.auth-card__footer a{color:#60a5fa;text-decoration:none}.auth-card__footer a:hover{text-decoration:underline}.auth-form{flex-direction:column;gap:1rem;display:flex}.auth-form__field label{color:#8b9cb3;margin-bottom:.35rem;font-size:.8rem;display:block}.auth-form__field input{color:#e8edf4;background:#0f1419;border:1px solid #2a3344;border-radius:6px;width:100%;padding:.55rem .75rem;font-size:.95rem}.auth-form__field input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 2px #3b82f640}.auth-form__submit{width:100%;margin-top:.25rem}.dashboard__user{flex-shrink:0;align-items:center;gap:.75rem;display:flex}.dashboard__email{color:#8b9cb3;font-size:.85rem}.btn--ghost{color:#8b9cb3;background:0 0;border:1px solid #2a3344}.btn--ghost:hover{color:var(--color-text);border-color:var(--color-primary)}.page__header{justify-content:space-between;align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-lg);display:flex}.page__header-main{align-items:flex-start;gap:var(--space-md);display:flex}.page__header-icon{border-radius:var(--radius-md);background:var(--color-bg-elevated);border:1px solid var(--color-border);width:48px;height:48px;color:var(--color-primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.page__header h1{letter-spacing:-.02em;margin:0 0 .35rem;font-size:1.75rem;font-weight:700}.meta-bar{gap:var(--space-md) var(--space-lg);background:var(--color-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);margin-bottom:var(--space-md);color:var(--color-text-muted);flex-wrap:wrap;padding:.75rem 1rem;font-size:.88rem;display:flex}.meta-bar strong{color:var(--color-text)}.dashboard-grid{gap:var(--space-md);margin-bottom:var(--space-md);grid-template-columns:1fr 320px;display:grid}.dashboard-grid__main,.dashboard-grid__side{gap:var(--space-md);flex-direction:column;min-width:0;display:flex}.dashboard-grid__main .panel,.dashboard-grid__side .panel{margin-bottom:0}.empty-state-panel{text-align:center;padding:var(--space-xl) var(--space-lg);background:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius-lg);margin-bottom:var(--space-lg)}.empty-state-panel__icon{color:var(--color-text-subtle);margin-bottom:var(--space-md)}.empty-state-panel__title{margin:0 0 .5rem;font-size:1.15rem;font-weight:600}.empty-state-panel__desc{color:var(--color-text-muted);margin:0;max-width:28rem;margin-inline:auto}.skeleton{background:linear-gradient(90deg, var(--color-bg-elevated) 25%, var(--color-surface-hover) 50%, var(--color-bg-elevated) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.2s ease-in-out infinite skeleton-shimmer}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-card{border:1px solid var(--color-border-subtle)}.skeleton-panel,.dashboard-skeleton .summary-cards{margin-bottom:var(--space-md)}.summary-card{border-left:3px solid var(--color-border);transition:border-color var(--transition), box-shadow var(--transition)}.summary-card:hover{box-shadow:var(--shadow-sm)}.summary-card--featured{border-left-width:4px}.summary-card--warn{border-left-color:var(--color-danger)}.summary-card--ok{border-left-color:var(--color-success)}.summary-card--off{border-left-color:var(--color-text-subtle)}.summary-card__top{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.summary-card__icon{color:var(--color-text-subtle);opacity:.85}.summary-card--warn .summary-card__icon{color:var(--color-danger)}.summary-card--ok .summary-card__icon{color:var(--color-success)}.panel__header-icon-inline{vertical-align:-3px;color:var(--color-primary);margin-right:.35rem}.sensor-grid{flex-direction:column;gap:.35rem;display:flex}.sensor-grid__item{border-radius:var(--radius-sm);background:var(--color-bg);border:1px solid var(--color-border-subtle);align-items:center;gap:.65rem;padding:.5rem .65rem;display:flex}.sensor-grid__text{flex:1;min-width:0}.sensor-grid__name{font-size:.82rem;font-weight:500;display:block}.sensor-grid__field{color:var(--color-text-muted);font-size:.72rem}.sensor-grid__state{text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);font-size:.7rem}.status-dot{border-radius:var(--radius-full);flex-shrink:0;width:8px;height:8px}.status-dot--ok{background:var(--color-success)}.status-dot--off{border:1px dashed var(--color-text-subtle);background:0 0}.status-dot--fault{background:var(--color-danger)}.app-navbar{background:var(--color-bg-elevated);border-bottom:1px solid var(--color-border-subtle);gap:var(--space-md);padding:.65rem 1.25rem}.app-navbar__brand{align-items:center;gap:.5rem;font-size:.95rem;font-weight:700;display:flex}.app-navbar__logo{color:var(--color-primary)}.app-navbar__nav{flex:1;align-items:center;display:flex;overflow-x:auto}.app-navbar__link{cursor:pointer;transition:background var(--transition), color var(--transition);align-items:center;gap:.4rem;display:inline-flex}.app-navbar__link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.app-navbar__user .dashboard__email{text-overflow:ellipsis;white-space:nowrap;align-items:center;gap:.35rem;max-width:180px;display:inline-flex;overflow:hidden}.btn--icon{align-items:center;gap:.4rem;display:inline-flex}.btn--danger{background:#dc2626}.btn--danger:hover:not(:disabled){background:#b91c1c}.auth-split{background:var(--color-bg);grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);min-height:100dvh;display:grid}.auth-split--login{overflow:hidden}@media (width>=901px){.auth-split--login{grid-template-rows:1fr;height:100dvh}}.auth-split__brand{border-right:1px solid var(--color-border-subtle);background:linear-gradient(155deg,#1e293b 0%,#0f172a 45%,#172554 100%);flex-direction:column;justify-content:center;align-items:flex-start;padding:clamp(1.5rem,4vw,3rem);display:flex;position:relative;overflow:hidden}@media (width>=901px){.auth-split__brand{height:100%;min-height:0;padding-left:clamp(2rem,6vw,3.5rem)}}.auth-split__mesh{pointer-events:none;background:radial-gradient(80% 60% at 10% 20%,#3b82f638,#0000 55%),radial-gradient(60% 50% at 90% 80%,#22c55e1f,#0000 50%);position:absolute;inset:0}.auth-split__grid{pointer-events:none;background-image:linear-gradient(#94a3b80f 1px,#0000 1px),linear-gradient(90deg,#94a3b80f 1px,#0000 1px);background-size:48px 48px;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#00000080,#0000 85%);mask-image:linear-gradient(#00000080,#0000 85%)}.auth-split__brand-inner{z-index:1;max-width:28rem;position:relative}.auth-split__logo-row{align-items:center;gap:.85rem;margin-bottom:1.25rem;display:flex}.auth-split__logo-icon{border-radius:var(--radius-md);color:#93c5fd;background:#3b82f624;border:1px solid #60a5fa59;justify-content:center;align-items:center;width:3.25rem;height:3.25rem;display:inline-flex;box-shadow:0 0 24px #3b82f626}.auth-split__eyebrow{letter-spacing:.12em;text-transform:uppercase;color:#93c5fd;margin:0;font-size:.72rem;font-weight:700}.auth-split__title{letter-spacing:-.02em;margin:.15rem 0 0;font-size:clamp(1.75rem,3vw,2.25rem);font-weight:700;line-height:1.15}.auth-split__brand h1{margin:var(--space-md) 0 .5rem;font-size:1.75rem;font-weight:700}.auth-split__lead{color:var(--color-text-muted);max-width:26rem;margin:0 0 1.5rem;font-size:1rem;line-height:1.6}.auth-split__brand p{margin:0 0 var(--space-lg);color:var(--color-text-muted);max-width:22rem}.auth-split__highlights{flex-direction:column;gap:.75rem;margin:0 0 1.5rem;padding:0;list-style:none;display:flex}.auth-split__highlights li{color:#cbd5e1;align-items:flex-start;gap:.65rem;font-size:.92rem;line-height:1.45;display:flex}.auth-split__highlights li svg{color:#4ade80;flex-shrink:0;margin-top:.1rem}.auth-split__domains{flex-wrap:wrap;gap:.5rem;display:flex}.auth-split__logo{color:var(--color-primary)}.auth-split__features{color:var(--color-text-muted);margin:0;padding-left:1.1rem;font-size:.9rem}.auth-split__features li{margin-bottom:.35rem}.auth-split__form{background:radial-gradient(ellipse 52% 42% at 50% 50%, #1e293b66, transparent 72%), radial-gradient(ellipse 70% 50% at 50% 0%, #3b82f614, transparent 60%), var(--color-bg);justify-content:center;align-items:center;padding:clamp(1.25rem,3vw,2.5rem);display:flex}@media (width>=901px){.auth-split__form{height:100%;min-height:0}}.auth-signin-panel{border-radius:var(--radius-lg);background:linear-gradient(168deg,#1e293bf7 0%,#111827fc 100%);border:1px solid #94a3b838;width:100%;max-width:440px;padding:1.35rem 1.5rem 1.25rem;position:relative;box-shadow:inset 0 0 0 1px #ffffff0d,inset 0 1px #ffffff12,0 10px 28px #0000006b,0 28px 56px #00000061}.auth-signin-panel:before{content:"";opacity:.9;background:linear-gradient(90deg,#3b82f6 0%,#22c55e 100%);border-radius:0 0 2px 2px;height:2px;position:absolute;top:0;left:1.25rem;right:1.25rem}.auth-signin-panel__header{border-bottom:1px solid #94a3b81f;margin-bottom:.875rem;padding-bottom:.875rem}.auth-signin-panel__eyebrow{letter-spacing:.1em;text-transform:uppercase;color:#93c5fd;margin:0 0 .3rem;font-size:.72rem;font-weight:700}.auth-signin-panel__title{letter-spacing:-.02em;color:#f1f5f9;margin:0 0 .3rem;font-size:1.45rem;font-weight:700}.auth-signin-panel__subtitle{color:#94a3b8;margin:0;font-size:.9rem;line-height:1.45}.auth-signin-panel__action{border-radius:var(--radius-md);background:#0f172a8c;border:1px solid #334155a6;padding:.875rem}.auth-signin-panel__footnote{color:#64748b;text-align:center;border-top:1px solid #94a3b81a;justify-content:center;align-items:center;gap:.4rem;margin:.875rem 0 0;padding-top:.75rem;font-size:.76rem;line-height:1.4;display:flex}.auth-signin-panel__footnote svg{color:#4ade80;flex-shrink:0}.auth-card--clerk{box-shadow:none;background:0 0;border:none;max-width:none;padding:0}.auth-card--clerk .cl-badge,.auth-card--clerk [data-localization-key=badge__trialMode],.auth-card--clerk [data-localization-key=badge__developmentMode]{display:none!important}.auth-domain-alert{margin-bottom:.75rem}.auth-domain-badge{border-radius:var(--radius-full);font-size:.8rem;font-family:var(--font-mono);color:#e2e8f0;background:#0f172aa6;border:1px solid #94a3b838;padding:.35em .65em;display:inline-block}.modal-backdrop{padding:var(--space-md);z-index:100;background:#000000a6;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:400px;padding:var(--space-lg);box-shadow:var(--shadow-md)}.modal__title{margin:0 0 .5rem;font-size:1.15rem}.modal__message{margin:0 0 var(--space-lg);color:var(--color-text-muted);font-size:.95rem}.modal__actions{justify-content:flex-end;gap:.5rem;display:flex}.temp-side__slider-row{color:var(--color-text-muted);flex-direction:column;gap:.5rem;margin-top:.75rem;font-size:.9rem;display:flex}.temp-side__slider-row input[type=range]{width:100%;accent-color:var(--color-primary)}.temp-side__number{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);width:5rem;height:2.25rem;color:var(--color-text);padding:0 .5rem}.temp-side__toggle-row{color:var(--color-text-muted);justify-content:space-between;align-items:center;margin-top:.75rem;font-size:.9rem;display:flex}.temp-side--disabled{opacity:.55}.temp-side__legend{align-items:center;gap:.5rem;display:inline-flex}@media (width<=1024px){.dashboard-grid{grid-template-columns:1fr}}@media (width<=900px){.auth-split{grid-template-columns:1fr;height:auto;min-height:100dvh}.auth-split__brand{padding:var(--space-lg);border-right:none;border-bottom:1px solid var(--color-border-subtle);height:auto;min-height:auto}.auth-split__brand-inner{max-width:none}.auth-split__highlights{margin-bottom:1rem}.auth-signin-panel{max-width:100%}}.hub-telemetry-page,.last-hub-telemetry-page{max-width:1600px}.hub-telemetry-page{padding-bottom:2rem;overflow:visible}.hub-telemetry-page .page__header{margin-bottom:1.85rem}.hub-telemetry-page .page__header h1,.hub-telemetry-page .hub-telemetry-explorer{margin-bottom:0}.get-last-telemetry{border:1px solid var(--color-border);border-radius:var(--radius-md);background:#0b0f14;flex-direction:column;gap:.85rem;padding:1rem;display:flex}.get-last-telemetry__body{grid-template-columns:minmax(280px,320px) minmax(0,1fr);align-items:stretch;gap:1.25rem;min-height:560px;display:grid}.get-last-telemetry__dashboard{min-width:0;min-height:0}.get-last-telemetry__header{color:var(--color-primary);align-items:flex-start;gap:.65rem;display:flex}.get-last-telemetry__title{color:var(--color-text);margin:0;font-size:1rem;font-weight:600}.get-last-telemetry__subtitle{color:var(--color-text-muted);margin:.25rem 0 0;font-size:.78rem;line-height:1.4}.get-last-telemetry__form{flex-direction:column;gap:.75rem;height:100%;min-height:0;display:flex}.get-last-telemetry__field label{color:var(--color-text-muted);margin-bottom:.35rem;font-size:.8rem;display:block}.get-last-telemetry__select,.get-last-telemetry__textarea{box-sizing:border-box;border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;color:var(--color-text);background:#0f1419;font-size:.85rem}.get-last-telemetry__select{height:2.5rem;font-family:var(--font-mono);padding:0 .65rem}.get-last-telemetry__textarea{font-family:var(--font-mono);resize:vertical;min-height:7rem;padding:.55rem .65rem;line-height:1.45}.get-last-telemetry__field-picker{flex-direction:column;gap:.45rem;display:flex}.get-last-telemetry__field-picker--fill{border-top:1px solid var(--color-border-subtle);flex:1;min-height:0;margin-top:.15rem;padding-top:.65rem}.get-last-telemetry__field-picker-header{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.get-last-telemetry__field-picker-label{color:var(--color-text-muted);font-size:.8rem}.get-last-telemetry__field-picker-count{color:var(--color-text-subtle);font-size:.72rem}.get-last-telemetry__field-picker-actions{flex-wrap:wrap;gap:.35rem;display:flex}.btn--sm{min-height:1.75rem;padding:.2rem .55rem;font-size:.72rem}.get-last-telemetry__field-groups{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:#0f1419;flex-direction:column;flex:1;gap:.25rem;min-height:0;padding:.35rem .35rem .65rem;scroll-padding-bottom:.75rem;display:flex;overflow:auto}.get-last-telemetry__field-group{border:1px solid var(--color-border-subtle);border-radius:var(--radius-sm);background:#0f172a73;border-left:2px solid #0000;flex-shrink:0;min-width:0;margin:0;padding:0;transition:border-color .2s,background .2s;overflow:hidden}.get-last-telemetry__field-group--has-selection:not(.get-last-telemetry__field-group--expanded){border-left-color:#4a9eff73}.get-last-telemetry__field-group--expanded{background:#0f172ab8;border-left-color:#4a9eff}.get-last-telemetry__field-group-header{align-items:stretch;min-height:2.35rem;display:flex}.get-last-telemetry__field-group-expand{min-width:0;color:var(--color-text);text-align:left;cursor:pointer;transition:background var(--transition);background:0 0;border:none;flex:1;align-items:flex-start;gap:.35rem;padding:.4rem .45rem;font-family:inherit;display:flex}.get-last-telemetry__field-group-expand:hover:not(:disabled){background:#ffffff0a}.get-last-telemetry__field-group-expand:active:not(:disabled){background:#ffffff0f}.get-last-telemetry__field-group-expand:disabled{cursor:not-allowed;opacity:.6}.get-last-telemetry__field-group-chevron{color:var(--color-text-subtle);flex-shrink:0;margin-top:.1rem;transition:transform .28s cubic-bezier(.22,1,.36,1),color .2s}.get-last-telemetry__field-group--expanded .get-last-telemetry__field-group-chevron{color:#93c5fd;transform:rotate(180deg)}.get-last-telemetry__field-group-expand-body{flex-direction:column;flex:1;gap:.3rem;min-width:0;display:flex}.get-last-telemetry__field-group-title-row{justify-content:space-between;align-items:center;gap:.5rem;width:100%;display:flex}.get-last-telemetry__field-group-title{color:var(--color-text);font-size:.78rem;font-weight:600}.get-last-telemetry__field-group-meta{color:var(--color-text-subtle);flex-shrink:0;font-size:.68rem;font-weight:500}.get-last-telemetry__field-preview{flex-wrap:wrap;gap:.25rem;display:flex}.get-last-telemetry__field-preview-chip{border-radius:var(--radius-full);color:#93c5fd;max-width:7.5rem;font-family:var(--font-mono);white-space:nowrap;text-overflow:ellipsis;background:#4a9eff1a;border:1px solid #4a9eff38;padding:.12rem .38rem;font-size:.62rem;line-height:1.3;overflow:hidden}.get-last-telemetry__field-preview-chip--more{max-width:none;color:var(--color-text-subtle);border-color:var(--color-border-subtle);background:#ffffff0a}.get-last-telemetry__field-group-all{border:none;border-left:1px solid var(--color-border-subtle);width:2.65rem;color:var(--color-text-subtle);letter-spacing:.02em;text-transform:uppercase;cursor:pointer;transition:background var(--transition), color var(--transition);background:#0000001f;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:.1rem;padding:.25rem .35rem;font-size:.62rem;font-weight:600;display:inline-flex}.get-last-telemetry__field-group-all:hover{color:var(--color-text);background:#4a9eff14}.get-last-telemetry__field-group-all input{accent-color:var(--color-primary);cursor:pointer;flex-shrink:0;margin:0}.get-last-telemetry__field-list-wrap{grid-template-rows:0fr;transition:grid-template-rows .28s cubic-bezier(.22,1,.36,1);display:grid}.get-last-telemetry__field-group--expanded .get-last-telemetry__field-list-wrap{grid-template-rows:1fr}.get-last-telemetry__field-list-inner{opacity:0;border-top:1px solid #0000;flex-direction:column;gap:.15rem;min-height:0;padding:0 .4rem .5rem .55rem;transition:opacity .22s cubic-bezier(.22,1,.36,1),transform .22s cubic-bezier(.22,1,.36,1),border-color .2s;display:flex;overflow:hidden;transform:translateY(-4px)}.get-last-telemetry__field-group--expanded .get-last-telemetry__field-list-inner{border-top-color:var(--color-border-subtle);opacity:1;min-height:auto;padding-top:.35rem;overflow:visible;transform:translateY(0)}.get-last-telemetry__check-row{border-radius:var(--radius-sm);cursor:pointer;border-left:2px solid #0000;align-items:center;gap:.45rem;padding:.3rem .45rem .3rem .4rem;font-size:.75rem;transition:background .15s,border-color .15s,transform .12s;display:flex}.get-last-telemetry__check-row:hover{background:#ffffff0a}.get-last-telemetry__check-row:active{transform:scale(.985)}.get-last-telemetry__check-row--active{background:#4a9eff1a;border-left-color:#4a9eff}.get-last-telemetry__check-row input{accent-color:var(--color-primary);flex-shrink:0}.get-last-telemetry__check-row code{color:var(--color-text-muted);background:0 0;padding:0;font-size:.72rem}.get-last-telemetry__check-row--active code{color:var(--color-text)}.get-last-telemetry__submit{justify-content:center;align-items:center;gap:.4rem;width:100%;height:2.5rem;display:inline-flex}.get-last-telemetry__form .date-range-picker{gap:.55rem;padding:.65rem .75rem}.ltd-placeholder{border:1px dashed var(--color-border-subtle);border-radius:var(--radius-md);min-height:360px;color:var(--color-text-muted);text-align:center;background:#ffffff05;justify-content:center;align-items:center;padding:1.5rem;font-size:.88rem;line-height:1.5;display:flex}.ltd{flex-direction:column;gap:.65rem;display:flex}.ltd__meta{color:var(--color-text-muted);flex-direction:column;gap:.25rem;padding-bottom:.25rem;font-size:.78rem;display:flex}.ltd__device{font-family:var(--font-mono);color:var(--color-text);font-size:.82rem}.ltd__time{flex-wrap:wrap;align-items:center;gap:.3rem;display:inline-flex}.ltd__time-ist{color:var(--color-text-subtle)}.ltd__count{color:var(--color-text-subtle);font-size:.72rem}.ltd__sides{grid-template-columns:1fr 1fr;gap:.55rem;display:grid}.ltd-side{border-radius:var(--radius-md);border:1px solid var(--color-border-subtle);background:#10161f;padding:.7rem .75rem}.ltd-side--left{border-top:2px solid #4a9eff}.ltd-side--right{border-top:2px solid #a78bfa}.ltd-side__header{justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.45rem;display:flex}.ltd-side__title{letter-spacing:.06em;margin:0;font-size:.72rem;font-weight:700}.ltd-side--left .ltd-side__title{color:#4a9eff}.ltd-side--right .ltd-side__title{color:#a78bfa}.ltd-side__status{color:var(--color-text-subtle);font-size:.68rem;font-weight:600}.ltd-side__status--on{color:#34d399}.ltd-side__temp{flex-wrap:wrap;align-items:center;gap:.45rem;margin-bottom:.55rem;display:flex}.ltd-side__temp-current,.ltd-side__temp-target{color:var(--color-text);font-size:1.35rem;font-weight:600;line-height:1.2}.ltd-side__temp-arrow{color:var(--color-text-muted);flex-shrink:0}.ltd-side__temp-target--high,.ltd-side__temp-arrow--high{color:#fb923c}.ltd-side__temp-target--low,.ltd-side__temp-arrow--low{color:#60a5fa}.ltd-side__section{border-top:1px solid var(--color-border-subtle);margin-top:.55rem;padding-top:.5rem}.ltd-side__section-title{letter-spacing:.05em;color:var(--color-text-subtle);align-items:center;gap:.3rem;margin:0 0 .35rem;font-size:.65rem;font-weight:700;display:flex}.ltd-metric{justify-content:space-between;align-items:center;gap:.5rem;padding:.2rem 0;font-size:.72rem;display:flex}.ltd-metric__label{color:var(--color-text-muted)}.ltd-metric__value{font-family:var(--font-mono);color:var(--color-text);font-weight:500}.ltd-metric__value--orange{color:#fb923c}.ltd-metric__value--teal{color:#2dd4bf}.ltd-metric__value--green{color:#34d399}.ltd-metric__value--blue{color:#60a5fa}.ltd-metric__value--purple{color:#c084fc}.ltd-card{border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);background:#10161f;padding:.7rem .75rem}.ltd-card__title{letter-spacing:.05em;color:var(--color-text-subtle);align-items:center;gap:.4rem;margin:0 0 .45rem;font-size:.68rem;font-weight:700;display:flex}.ltd-fans{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.ltd-fans__label{letter-spacing:.05em;color:var(--color-text-subtle);margin-bottom:.25rem;font-size:.65rem;font-weight:700;display:block}.ltd-water-row{justify-content:space-between;align-items:center;gap:.5rem;padding:.3rem 0;font-size:.75rem;display:flex}.ltd-water-row__label{color:var(--color-text-muted)}.ltd-water-row__meta{align-items:center;gap:.45rem;display:flex}.ltd-water-row__raw{color:var(--color-text-subtle);font-size:.65rem;font-family:var(--font-mono,ui-monospace, monospace)}.ltd-pill{letter-spacing:.03em;border:1px solid #0000;border-radius:999px;padding:.2rem .45rem;font-size:.65rem;font-weight:700}.ltd-pill--ok{color:#34d399;background:#34d3991f;border-color:#34d39940}.ltd-pill--warn{color:#fbbf24;background:#fbbf241f;border-color:#fbbf2440}.ltd-pill--danger{color:#f87171;background:#f871711f;border-color:#f8717140}.ltd-other{color:var(--color-text-muted);font-size:.78rem}.ltd-other summary{cursor:pointer;color:var(--color-text-subtle);padding:.35rem 0}.ltd-other__table-wrap{border:1px solid var(--color-border-subtle);border-radius:var(--radius-sm);max-height:180px;margin-top:.35rem;overflow:auto}.ltd-other__table{border-collapse:collapse;width:100%;font-size:.75rem}.ltd-other__table th,.ltd-other__table td{text-align:left;border-bottom:1px solid var(--color-border-subtle);padding:.35rem .5rem}.ltd-other__table th{text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-subtle);background:#151c28;font-size:.68rem}.ltd-other__table td code{background:0 0;padding:0;font-size:.72rem}@media (width<=960px){.get-last-telemetry__body{grid-template-columns:1fr;min-height:0}.get-last-telemetry__form{height:auto}.get-last-telemetry__field-picker--fill{min-height:300px}}@media (width<=720px){.ltd__sides,.ltd-fans{grid-template-columns:1fr}}.hub-telemetry-explorer{border:1px solid var(--color-border);border-radius:var(--radius-md);background:#0b0f14;flex-direction:column;gap:0;display:flex;overflow:visible}.hub-telemetry-explorer__chart-panel{border-bottom:1px solid var(--color-border);border-radius:var(--radius-md) var(--radius-md) 0 0;z-index:1;background:#0e1218;height:42vh;min-height:380px;position:relative;overflow:visible}.hub-telemetry-chart{width:100%;min-width:0;height:100%;position:relative;overflow:visible}.hub-telemetry-chart-tooltip-wrap{pointer-events:auto}.hub-telemetry-chart-tooltip{border:1px solid var(--color-border);border-radius:var(--radius-sm);box-sizing:border-box;background:#151c28;flex-direction:column;width:100%;min-width:200px;max-width:300px;max-height:320px;padding:.55rem .65rem;display:flex;box-shadow:0 8px 24px #00000073}.hub-telemetry-chart-tooltip__time{border-bottom:1px solid var(--color-border-subtle);color:var(--color-text);margin-bottom:.45rem;padding-bottom:.4rem;font-size:.76rem;font-weight:600;line-height:1.35}.hub-telemetry-chart-tooltip__rows{scrollbar-width:thin;flex-direction:column;flex:1;gap:.2rem;min-height:0;max-height:260px;padding-right:.15rem;display:flex;overflow-y:auto}.hub-telemetry-chart-tooltip__row{justify-content:space-between;align-items:center;gap:.65rem;font-size:.74rem;display:flex}.hub-telemetry-chart-tooltip__field{min-width:0;color:var(--color-text-muted);align-items:center;gap:.35rem;display:inline-flex}.hub-telemetry-chart-tooltip__field code{text-overflow:ellipsis;white-space:nowrap;background:0 0;padding:0;font-size:.72rem;overflow:hidden}.hub-telemetry-chart-tooltip__dot{border-radius:999px;flex-shrink:0;width:.45rem;height:.45rem}.hub-telemetry-chart-tooltip__value{font-variant-numeric:tabular-nums;color:#e2e8f0;white-space:nowrap;font-weight:600}.hub-telemetry-chart--empty{height:100%;color:var(--color-text-muted);justify-content:center;align-items:center;font-size:.95rem;display:flex}.hub-telemetry-explorer__toolbar{border-bottom:1px solid var(--color-border);z-index:5;background:#151c28;justify-content:space-between;align-items:center;gap:1rem;padding:.55rem .85rem;display:flex;position:relative;overflow:visible}.hub-telemetry-explorer__toolbar-actions{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex;position:relative;overflow:visible}.hub-telemetry-explorer__query-tab{align-items:center;gap:.5rem;display:flex}.hub-telemetry-explorer__query-label{color:var(--color-text);border-radius:var(--radius-sm);background:#3b82f626;border:1px solid #3b82f659;padding:.25rem .5rem;font-size:.85rem;font-weight:600}.hub-telemetry-explorer__query-time{color:var(--color-text-subtle);font-size:.8rem;font-family:var(--font-mono)}.hub-telemetry-explorer__icon-btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-elevated);width:2rem;height:2rem;color:var(--color-text-muted);cursor:pointer;justify-content:center;align-items:center;display:inline-flex}.hub-telemetry-explorer__icon-btn:hover:not(:disabled){color:var(--color-text);border-color:var(--color-border-subtle)}.hub-telemetry-explorer__icon-btn:disabled{opacity:.5;cursor:not-allowed}.hub-telemetry-explorer__range-pill{border:1px solid var(--color-border-subtle);background:var(--color-bg);font:inherit;color:var(--color-text-muted);cursor:pointer;transition:border-color var(--transition), color var(--transition), background var(--transition);border-radius:999px;align-items:center;gap:.35rem;padding:.35rem .65rem;font-size:.78rem;display:inline-flex}.hub-telemetry-explorer__range-pill:hover:not(:disabled){color:var(--color-text);border-color:var(--color-border)}.hub-telemetry-explorer__range-pill--open{color:var(--color-text);background:#3b82f614;border-color:#3b82f68c}.hub-telemetry-explorer__range-pill:disabled{opacity:.55;cursor:not-allowed}.hub-time-picker{position:relative}.hub-time-picker__popover{z-index:120;border:1px solid var(--color-border);border-radius:var(--radius-md);background:#151c28;width:min(480px,100vw - 2rem);padding:.75rem;position:absolute;top:calc(100% + .4rem);right:0;box-shadow:0 12px 40px #00000073}.hub-time-picker__presets{flex-wrap:wrap;gap:.35rem;margin-bottom:.65rem;display:flex}.hub-time-picker__inputs{grid-template-columns:1fr auto 1fr;align-items:center;gap:.5rem;display:grid}.hub-time-picker__arrow{color:#93c5fd;flex-shrink:0;justify-content:center;align-items:center;display:flex}.hub-time-picker__input{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);width:100%;height:2.25rem;color:var(--color-text);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;box-sizing:border-box;padding:0 .55rem;font-size:.82rem}.hub-time-picker__input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 2px #3b82f640}.hub-time-picker__input:disabled{opacity:.6;cursor:not-allowed}.hub-time-picker__error{color:var(--color-danger);margin:.45rem 0 0;font-size:.75rem}.hub-time-picker__apply{letter-spacing:.02em;text-transform:uppercase;width:100%;height:2.35rem;margin-top:.65rem;font-size:.82rem;font-weight:600}.hub-telemetry-explorer__submit{align-items:center;gap:.4rem;min-width:6.5rem;height:2.25rem;padding:0 1rem;font-size:.88rem;display:inline-flex}.hub-telemetry-explorer__builder{border-radius:0 0 var(--radius-md) var(--radius-md);grid-template-columns:minmax(140px,1fr) minmax(150px,.95fr) minmax(0,2.2fr) minmax(120px,.85fr);min-height:0;display:grid}.hub-telemetry-explorer__column--from{padding:.6rem .65rem}.hub-telemetry-explorer__column--fields .hub-telemetry-explorer__check-row span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.hub-telemetry-explorer__column{border-right:1px solid var(--color-border-subtle);flex-direction:column;gap:.45rem;min-width:0;padding:.65rem .75rem;display:flex}.hub-telemetry-explorer__column:last-child{border-right:none}.hub-telemetry-explorer__column-header{letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-subtle);align-items:center;gap:.35rem;font-size:.72rem;font-weight:700;display:flex}.hub-telemetry-explorer__column-header--sub{text-transform:none;letter-spacing:normal;margin-top:.35rem;font-size:.78rem;font-weight:600}.hub-telemetry-explorer__tag-key{color:#7dd3fc;text-transform:none;letter-spacing:normal;margin-left:auto;font-weight:500}.hub-telemetry-explorer__field-toolbar{justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.35rem;display:flex}.hub-telemetry-explorer__field-actions{flex-wrap:wrap;align-items:center;gap:.35rem;display:flex}.hub-telemetry-explorer__field-actions-divider{background:var(--color-border-subtle);flex-shrink:0;width:1px;height:1.35rem;margin:0 .1rem}.hub-telemetry-explorer__field-group{border:1px solid var(--color-border-subtle);border-radius:var(--radius-full);color:var(--color-text-muted);cursor:pointer;transition:background var(--transition), border-color var(--transition), color var(--transition), transform .12s ease;background:#0f172a8c;padding:.22rem .6rem;font-size:.72rem;font-weight:600;line-height:1.3}.hub-telemetry-explorer__field-group:hover:not(:disabled){color:var(--color-text);border-color:var(--color-border);background:#1e293bbf}.hub-telemetry-explorer__field-group:active:not(:disabled){transform:scale(.97)}.hub-telemetry-explorer__field-group:disabled{opacity:.45;cursor:not-allowed}.hub-telemetry-explorer__field-group--part-temperatures.hub-telemetry-explorer__field-group--active{color:#6ee7b7;background:#34d3991f;border-color:#34d39973}.hub-telemetry-explorer__field-group--left.hub-telemetry-explorer__field-group--active{color:#93c5fd;background:#3b82f624;border-color:#60a5fa73}.hub-telemetry-explorer__field-group--right.hub-telemetry-explorer__field-group--active{color:#f9a8d4;background:#ec48991f;border-color:#f472b673}.hub-telemetry-explorer__field-group--system.hub-telemetry-explorer__field-group--active{color:#fcd34d;background:#fbbf241a;border-color:#fbbf2473}.hub-telemetry-explorer__field-count{color:var(--color-text-subtle);white-space:nowrap;font-size:.68rem}.hub-telemetry-explorer__bucket{border-radius:var(--radius-sm);color:var(--color-text-muted);border:1px solid #0000;padding:.45rem .6rem;font-size:.85rem}.hub-telemetry-explorer__bucket--active{color:#fff;background:#3b82f633;border-color:#3b82f673}.hub-telemetry-explorer__search-wrap{position:relative}.hub-telemetry-explorer__search-icon{color:var(--color-text-subtle);pointer-events:none;position:absolute;top:50%;left:.55rem;transform:translateY(-50%)}.hub-telemetry-explorer__search,.hub-telemetry-explorer__select{border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;height:2.1rem;color:var(--color-text);box-sizing:border-box;background:#0f1419;padding:0 .65rem;font-size:.82rem}.hub-telemetry-explorer__search{padding-left:1.85rem}.hub-telemetry-explorer__select{appearance:none;font-family:var(--font-mono);padding-right:1.75rem}.hub-telemetry-explorer__select-icon{color:var(--color-text-subtle);pointer-events:none;position:absolute;top:50%;right:.55rem;transform:translateY(-50%)}.hub-telemetry-explorer__field-list{flex-direction:column;flex:1;gap:.15rem;max-height:360px;display:flex;overflow-y:auto}.hub-telemetry-explorer__check-row{border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;align-items:center;gap:.45rem;padding:.3rem .45rem;font-size:.82rem;display:flex}.hub-telemetry-explorer__check-row:hover{background:#ffffff0a}.hub-telemetry-explorer__check-row--active{color:#fff;background:#3b82f62e}.hub-telemetry-explorer__check-row input{accent-color:var(--color-primary);flex-shrink:0}.hub-telemetry-explorer__config-value{border-radius:var(--radius-sm);color:var(--color-text-muted);border:1px solid var(--color-border-subtle);background:var(--color-bg);padding:.35rem .5rem;font-size:.8rem}.hub-telemetry-explorer__config-value--active{color:#fff;background:#3b82f626;border-color:#3b82f666}.hub-telemetry-explorer__hint{color:var(--color-text-subtle);margin:0;padding:.35rem .2rem;font-size:.8rem}.hub-telemetry-spin{animation:.8s linear infinite hub-telemetry-spin}@keyframes hub-telemetry-spin{to{transform:rotate(360deg)}}@media (width<=1024px){.hub-telemetry-explorer__builder{grid-template-columns:1fr 1fr}.hub-telemetry-explorer__column--fields{grid-column:1/-1}}@media (width<=640px){.hub-telemetry-explorer__builder{grid-template-columns:1fr}.hub-telemetry-explorer__column{border-right:none;border-bottom:1px solid var(--color-border-subtle)}.hub-telemetry-explorer__toolbar{flex-direction:column;align-items:stretch}.hub-telemetry-explorer__toolbar-actions{justify-content:space-between}}
