:root{--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--text-xs: 11px;--text-sm: 13px;--text-base: 15px;--text-lg: 17px;--text-xl: 20px;--text-2xl: 24px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--transition: all .2s ease;--bg-primary: #f8f9fa;--bg-secondary: #ffffff;--bg-tertiary: #f1f3f5;--text-primary: #1a1a2e;--text-secondary:#6c757d;--border: #e9ecef;--accent: #4a6fa5;--accent-soft: #e8eef7;--success: #40916c;--warning: #e76f51;--danger: #c1121f;--shadow: rgba(0, 0, 0, .08);--heat: #d2691e;--cool: #0096c7}[data-theme=dark]{--bg-primary: #0f0f1a;--bg-secondary: #1a1a2e;--bg-tertiary: #252540;--text-primary: #e8e8f0;--text-secondary:#8888aa;--border: #2a2a45;--accent: #6b8cba;--accent-soft: #1a2540;--success: #52b788;--warning: #f4a261;--danger: #e63946;--shadow: rgba(0, 0, 0, .3);--heat: #f4a261;--cool: #4cc9f0}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%}body{font-family:var(--font-family);font-size:var(--text-base);color:var(--text-primary);background:var(--bg-primary);transition:background .3s ease,color .3s ease;min-height:100dvh;-webkit-font-smoothing:antialiased}#root{min-height:100dvh;display:flex;flex-direction:column}a{color:var(--accent);text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input,textarea,select{font-family:inherit}img{max-width:100%}:root{--color-brand-primary: var(--accent);--color-brand-secondary: var(--accent-soft);--color-success: var(--success);--color-warning: var(--warning);--color-danger: var(--danger);--color-info: var(--accent);--color-neutral: var(--text-secondary);--color-heat: var(--heat);--color-cool: var(--cool);--color-standby: var(--text-secondary);--color-bg-primary: var(--bg-primary);--color-bg-secondary: var(--bg-secondary);--color-bg-elevated: var(--bg-secondary);--color-bg-subtle: var(--bg-tertiary);--color-border: var(--border);--color-text-primary: var(--text-primary);--color-text-secondary: var(--text-secondary);--color-text-muted: var(--text-secondary);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-12: 48px;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.5rem;--font-size-2xl: 2rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-mono: ui-monospace, "SF Mono", "Cascadia Code", "Segoe UI Mono", Menlo, Consolas, monospace;--radius-full: 9999px;--shadow-sm: 0 1px 2px var(--shadow);--shadow-md: 0 2px 8px var(--shadow);--shadow-lg: 0 8px 32px var(--shadow);--duration-fast: .15s;--duration-normal: .3s;--duration-slow: .5s;--ease-default: cubic-bezier(.4, 0, .2, 1)}@keyframes ss-pulse{0%,to{box-shadow:0 0 color-mix(in srgb,currentColor 55%,transparent)}50%{box-shadow:0 0 0 5px color-mix(in srgb,currentColor 0%,transparent)}}.card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px;box-shadow:0 1px 3px var(--shadow);transition:var(--transition)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:48px;padding:0 20px;border-radius:var(--radius-sm);font-size:var(--text-base);font-weight:500;transition:var(--transition);cursor:pointer;border:none}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){filter:brightness(1.08)}.btn-primary:active:not(:disabled){filter:brightness(.95)}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.btn-ghost:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-sm{min-height:36px;padding:0 14px;font-size:var(--text-sm)}.input{width:100%;min-height:48px;padding:0 14px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--text-base);color:var(--text-primary);outline:none;transition:var(--transition)}.input:focus{border-color:var(--accent);background:var(--bg-secondary)}.input::placeholder{color:var(--text-secondary)}.label{font-size:var(--text-xs);font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:var(--text-xs);font-weight:500;white-space:nowrap}.badge:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.8;flex-shrink:0}.badge-success{background:color-mix(in srgb,var(--success) 15%,transparent);color:var(--success)}.badge-warning{background:color-mix(in srgb,var(--warning) 15%,transparent);color:var(--warning)}.badge-danger{background:color-mix(in srgb,var(--danger) 15%,transparent);color:var(--danger)}.badge-neutral{background:var(--bg-tertiary);color:var(--text-secondary)}.badge-neutral:before{display:none}.toggle{position:relative;width:44px;height:26px;flex-shrink:0;cursor:pointer}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--border);border-radius:13px;transition:var(--transition)}.toggle-slider:after{content:"";position:absolute;left:3px;top:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:var(--transition);box-shadow:0 1px 3px #0003}.toggle input:checked+.toggle-slider{background:var(--accent)}.toggle input:checked+.toggle-slider:after{transform:translate(18px)}.toggle input:disabled+.toggle-slider{opacity:.5;cursor:not-allowed}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.online{background:var(--success)}.status-dot.offline{background:var(--border)}.spinner{width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.page{flex:1;padding:20px 16px 88px;max-width:600px;margin:0 auto;width:100%}.page-title{font-size:var(--text-xl);font-weight:600;color:var(--text-primary)}.section-title{font-size:var(--text-xs);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px;padding:0 2px}.page-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:20px;gap:12px}.empty-state{text-align:center;color:var(--text-secondary);font-size:var(--text-sm);padding:32px 16px}.loading-center{display:flex;align-items:center;justify-content:center;min-height:50vh}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;padding:16px;z-index:1000}.modal-box{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 8px 32px var(--shadow);padding:20px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto}.modal-title{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin-bottom:16px}.form-group{margin-bottom:14px}.form-group .label{display:block;margin-bottom:6px}.chip{display:inline-flex;flex-direction:column;align-items:center;gap:2px;min-width:72px;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-secondary);cursor:pointer;transition:var(--transition)}.chip:hover{background:var(--bg-tertiary)}.chip-active{border-color:var(--accent);background:var(--accent-soft)}.chip-value{font-size:1.6rem;font-weight:700;line-height:1}.chip-label{font-size:var(--text-xs);font-weight:600;color:var(--text-secondary);display:flex;align-items:center;gap:3px}.state-ind{display:inline-flex;align-items:center;gap:5px;font-weight:var(--font-weight-medium);white-space:nowrap}.state-ind .state-dot{border-radius:50%;flex-shrink:0;background:currentColor}.state-sm{font-size:var(--font-size-xs);gap:4px}.state-sm .state-dot{width:7px;height:7px}.state-md{font-size:var(--font-size-sm)}.state-md .state-dot{width:9px;height:9px}.state-lg{font-size:var(--font-size-base);gap:6px}.state-lg .state-dot{width:11px;height:11px}.state-online{color:var(--color-success)}.state-offline,.state-faulty{color:var(--color-danger)}.state-warning,.state-stale{color:var(--color-warning)}.state-saving{color:var(--color-info)}.state-inactive,.state-unknown{color:var(--color-neutral)}.state-dot-pulse{animation:ss-pulse 2s var(--ease-default) infinite}@media (prefers-reduced-motion: reduce){.state-dot-pulse{animation:none}}.fleet-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.fleet-table th{text-align:left;font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);padding:8px 10px;border-bottom:1px solid var(--border)}.fleet-table td{padding:10px;border-bottom:1px solid var(--border);vertical-align:middle}.fleet-table tr:hover td{background:var(--bg-tertiary)}.fleet-row-actions{display:flex;gap:6px;flex-wrap:wrap}.modal-overlay-blur{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.modal-footer{margin-top:var(--space-4)}.empty-state-box{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-2);padding:var(--space-12) var(--space-4);color:var(--color-text-secondary)}.empty-state-icon{font-size:2.5rem;line-height:1}.empty-state-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.empty-state-msg{font-size:var(--font-size-sm);max-width:360px}.empty-state-action{margin-top:var(--space-2)}.skeleton{display:block;background:linear-gradient(90deg,var(--color-bg-subtle) 25%,color-mix(in srgb,var(--color-bg-subtle) 55%,var(--color-border)) 50%,var(--color-bg-subtle) 75%);background-size:200% 100%;border-radius:var(--radius-sm);animation:ss-shimmer 1.3s linear infinite}.skeleton-line{height:12px}.skeleton-text,.skeleton-table{display:flex;flex-direction:column;gap:var(--space-2)}.skeleton-card{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-elevated)}.skeleton-circle{border-radius:50%}.skeleton-circle-sm{width:28px;height:28px}.skeleton-circle-md{width:44px;height:44px}.skeleton-circle-lg{width:64px;height:64px}@keyframes ss-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (prefers-reduced-motion: reduce){.skeleton{animation:none}}.ui-card{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:var(--space-4);transition:transform var(--duration-fast) var(--ease-default),box-shadow var(--duration-fast) var(--ease-default)}.ui-card-outlined{box-shadow:none}.ui-card-interactive{cursor:pointer}.ui-card-interactive:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.ui-card-interactive:focus-visible{outline:2px solid var(--color-brand-primary);outline-offset:2px}.ui-card-header{font-weight:var(--font-weight-semibold);margin-bottom:var(--space-2)}.ui-card-footer{margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--color-border)}.ss-row{display:flex;justify-content:space-between;align-items:center;gap:var(--space-4);padding:var(--space-2) 0}.ss-row+.ss-row{border-top:1px solid var(--color-border)}.dash-chips{display:flex;flex-wrap:wrap;gap:var(--space-4)}.dash-chip{display:flex;flex-direction:column;align-items:center;min-width:64px}.dash-chip-v{font-size:1.8rem;font-weight:var(--font-weight-bold);line-height:1}.dash-chip-l{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:var(--space-1)}.dash-alert{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);cursor:pointer}.dash-alert:hover{color:var(--color-brand-primary)}.dash-alert-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.dash-alert-msg{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.auto-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-3)}.auto-params-inline{display:flex;flex-wrap:wrap;gap:var(--space-4);margin-top:var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.auto-accordion{margin-top:var(--space-2);padding-top:var(--space-2);border-top:1px solid var(--color-border)}.ph-menu{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px;padding:var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-subtle)}.ph-item{font-family:monospace;font-size:var(--font-size-xs);padding:3px 8px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-elevated);cursor:pointer}.ph-item:hover{border-color:var(--color-brand-primary);color:var(--color-brand-primary)}.wiz-card{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4);margin-bottom:var(--space-3);transition:var(--transition)}.wiz-card-disabled{opacity:.55}.wiz-card-selected{border-color:var(--color-brand-primary);background:var(--color-brand-secondary)}.builder-group{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4);margin-bottom:var(--space-4)}.builder-group-title{font-weight:var(--font-weight-semibold);margin-bottom:var(--space-3)}.builder-row{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2);padding:var(--space-2) 0;border-bottom:1px solid var(--color-border)}.builder-row:last-of-type{border-bottom:none}.ce-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:var(--radius-full);background:var(--color-brand-secondary);color:var(--color-brand-primary);font-size:var(--font-size-xs);border:1px solid var(--color-brand-primary);cursor:pointer;white-space:nowrap}.ce-add{font-size:var(--font-size-xs);color:var(--color-text-muted);background:none;border:1px dashed var(--color-border);border-radius:var(--radius-full);padding:3px 9px;cursor:pointer;opacity:.35;transition:opacity var(--duration-fast) var(--ease-default);white-space:nowrap}.builder-row:hover .ce-add{opacity:1}.ce-add:hover{color:var(--color-brand-primary);border-color:var(--color-brand-primary)}.ph-chips{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.ph-chip{font-family:monospace;font-size:var(--font-size-xs);padding:3px 8px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-subtle);cursor:pointer;transition:var(--transition)}.ph-chip:hover{border-color:var(--color-brand-primary);color:var(--color-brand-primary)}.chip-toggle{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-bg-secondary);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:var(--transition)}.chip-toggle-mark{font-size:var(--font-size-xs)}.chip-toggle-on{background:var(--color-brand-primary);color:#fff;border-color:var(--color-brand-primary)}.chip-toggle-disabled{opacity:.5;cursor:not-allowed}.ss-check{display:inline-flex;align-items:center;gap:var(--space-2);cursor:pointer}.ss-check input{position:absolute;opacity:0;width:0;height:0}.ss-check-box{width:20px;height:20px;flex-shrink:0;border:2px solid var(--color-border);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;transition:var(--transition)}.ss-check input:checked+.ss-check-box{background:var(--color-brand-primary);border-color:var(--color-brand-primary)}.ss-check input:focus-visible+.ss-check-box{outline:2px solid var(--color-brand-primary);outline-offset:2px}.ss-check-label{font-size:var(--font-size-sm)}.ss-check-hint{color:var(--color-text-muted)}.ss-check-disabled{opacity:.5;cursor:not-allowed}.push-banner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-brand-secondary);border-bottom:1px solid var(--color-border)}.push-banner-text{font-size:var(--font-size-sm);flex:1;min-width:220px}.push-banner-actions{display:flex;gap:var(--space-2);flex-wrap:wrap}.benefits-grid{display:grid;grid-template-columns:1fr;gap:var(--space-4)}@media (min-width: 560px){.benefits-grid{grid-template-columns:1fr 1fr}}.benefits-disclaimer{border-color:var(--color-warning)}.activity-filters{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-4)}.activity-filters .input{max-width:220px}.activity-list{display:flex;flex-direction:column;gap:var(--space-1)}.activity-entry{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3);width:100%;text-align:left;color:var(--color-text-primary);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition)}.activity-entry:hover{border-color:var(--color-brand-primary)}.activity-icon{font-size:1.2rem;flex-shrink:0}.activity-body{display:flex;flex-direction:column;gap:2px}.activity-when{font-size:var(--font-size-xs);color:var(--color-text-muted)}.activity-msg{font-size:var(--font-size-sm);color:var(--color-text-primary)}.activity-json{background:var(--color-bg-subtle);border-radius:var(--radius-sm);padding:var(--space-3);font-size:var(--font-size-xs);overflow-x:auto;white-space:pre-wrap;word-break:break-word}@media (max-width: 560px){.activity-filters .input{max-width:none;flex:1}}.oper{max-width:1080px;margin:0 auto;padding:40px 32px 64px}.oper-narrow{max-width:760px}.oper-head{margin-bottom:28px}.oper-title{font-size:28px;font-weight:650;letter-spacing:-.02em;color:var(--text-primary);margin:0}.oper-sub{margin:4px 0 0;color:var(--text-secondary);font-size:var(--text-sm)}.surface{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg)}.note{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px 16px;color:var(--text-secondary);font-size:var(--text-sm);line-height:1.5}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:18px}.stat{padding:22px}.stat-num{font-family:var(--font-mono);font-size:34px;font-weight:600;line-height:1;color:var(--text-primary);font-variant-numeric:tabular-nums;letter-spacing:-.02em}.stat-label{margin-top:10px;color:var(--text-secondary);font-size:var(--text-sm)}.stat-sub{margin-top:2px;color:var(--text-secondary);font-size:var(--text-xs)}.feed{overflow:hidden}.feed-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:14px;width:100%;text-align:left;border:none;background:none;cursor:pointer;padding:14px 18px;border-bottom:1px solid var(--border);transition:background var(--duration-fast) var(--ease-default)}.feed-row:last-child{border-bottom:none}.feed-row:hover{background:var(--bg-tertiary)}.feed-dot{width:8px;height:8px;border-radius:50%;background:var(--text-secondary);flex-shrink:0}.feed-dot.info{background:var(--accent)}.feed-dot.success{background:var(--success)}.feed-dot.warning{background:var(--warning)}.feed-dot.error{background:var(--danger)}.feed-body{min-width:0;display:flex;flex-direction:column;gap:2px}.feed-msg{font-size:var(--text-sm);color:var(--text-primary);font-weight:500}.feed-meta{font-size:var(--text-xs);color:var(--text-secondary)}.feed-when{font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap;font-variant-numeric:tabular-nums}.oper-filters{display:flex;gap:10px;margin-bottom:18px;flex-wrap:wrap}.oper-filters .input{max-width:240px}@media (max-width: 860px){.oper{padding:26px 16px 32px}.stat-grid{grid-template-columns:1fr 1fr}}.shell{display:flex;min-height:100dvh;background:var(--bg-primary)}.sidebar{position:sticky;top:0;height:100dvh;width:248px;flex-shrink:0;display:flex;flex-direction:column;padding:22px 14px 16px;background:var(--bg-secondary);border-right:1px solid var(--border)}.brand{display:inline-flex;align-items:baseline;gap:3px}.sidebar .brand{padding:2px 12px 26px}.brand-mark{font-size:21px;font-weight:700;letter-spacing:-.035em;color:var(--text-primary)}.brand-dot{width:5px;height:5px;border-radius:50%;background:var(--heat);transform:translateY(-1px)}.mtopbar,.mbottomnav{display:none}.micon{display:flex;align-items:center;justify-content:center}.sidebar-nav{display:flex;flex-direction:column;gap:2px}.nav-row{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:var(--radius-sm);color:var(--text-secondary);text-decoration:none;font-size:var(--text-sm);font-weight:500;border:none;background:none;cursor:pointer;width:100%;transition:background var(--duration-fast) var(--ease-default),color var(--duration-fast) var(--ease-default)}.nav-row:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-row-icon{display:flex;color:currentColor;opacity:.85}.nav-row-label{line-height:1}.nav-row-active{background:var(--accent-soft);color:var(--accent);font-weight:600;position:relative}.nav-row-active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:18px;border-radius:0 3px 3px 0;background:var(--accent)}.nav-row-active .nav-row-icon{opacity:1}.sidebar-teasers{margin-top:18px}.teaser-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);padding:0 12px 6px;margin:0;opacity:.7}.nav-row-teaser{color:var(--text-secondary);opacity:.45;cursor:default}.nav-row-teaser:hover{background:none;color:var(--text-secondary)}.sidebar-foot{margin-top:auto;display:flex;flex-direction:column;gap:2px;padding-top:10px;border-top:1px solid var(--border)}.shell-main{flex:1;min-width:0;overflow-y:auto;height:100dvh}.sidebar-foot .user-menu{width:100%}.sidebar-foot .user-avatar-row{display:flex;align-items:center;gap:11px;padding:8px 12px;width:100%;border:none;background:none;cursor:pointer;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:var(--text-sm);transition:background var(--duration-fast)}.sidebar-foot .user-avatar-row:hover{background:var(--bg-tertiary)}.user-menu{position:relative}.user-avatar{width:28px;height:28px;border-radius:50%;flex-shrink:0;background:var(--accent-soft);border:1px solid var(--accent);color:var(--accent);font-size:var(--text-xs);font-weight:600;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition)}.user-avatar:hover{background:var(--accent);color:#fff}.user-menu-dropdown{position:absolute;bottom:calc(100% + 8px);left:0;min-width:220px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:var(--space-2);z-index:50}.user-menu-head{padding:var(--space-2)}.user-menu-name{font-weight:var(--font-weight-semibold)}.user-menu-email{font-size:var(--font-size-sm);color:var(--text-secondary);word-break:break-all}.user-menu-sep{height:1px;background:var(--border);margin:var(--space-1) 0}.user-menu-item{display:block;width:100%;text-align:left;background:none;border:none;color:inherit;padding:var(--space-2);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-sm);transition:var(--transition)}.user-menu-item:hover{background:var(--bg-tertiary)}.user-menu-danger{color:var(--color-danger)}@media (max-width: 860px){.shell{flex-direction:column}.sidebar{display:none}.shell-main{height:auto;padding-bottom:calc(60px + env(safe-area-inset-bottom,0px))}.mtopbar{display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;padding:10px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border)}.mtopbar-actions{display:flex;align-items:center;gap:8px}.micon{width:34px;height:34px;border-radius:50%;background:var(--bg-tertiary);border:none;color:var(--text-primary);cursor:pointer}.mbottomnav{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:100;background:var(--bg-secondary);border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom,0px)}.mnav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;min-height:56px;padding:8px 6px;position:relative;color:var(--text-secondary);text-decoration:none}.mnav-item-active{color:var(--accent)}.mnav-item-active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:34px;height:3px;border-radius:0 0 3px 3px;background:var(--accent)}.mnav-icon{display:flex}.mnav-label{font-size:11px;font-weight:500}.user-menu-dropdown{bottom:auto;top:calc(100% + 8px);left:auto;right:0}}.login-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:24px 16px;position:relative}.login-theme-btn{position:fixed;top:16px;right:16px;width:40px;height:40px;border-radius:50%;background:var(--bg-secondary);border:1px solid var(--border);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-primary);z-index:10;transition:var(--transition)}.login-theme-btn:hover{background:var(--bg-tertiary)}.login-container{width:100%;max-width:400px;display:flex;flex-direction:column;align-items:center;gap:24px}.login-logo{display:flex;align-items:center;gap:12px}.login-logo-icon{width:44px;height:44px;background:var(--accent);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:var(--text-xl)}.login-logo-text{font-size:var(--text-xl);font-weight:600;color:var(--text-primary)}.login-card{width:100%;padding:28px 24px}.login-title{font-size:var(--text-xl);font-weight:600;color:var(--text-primary);margin-bottom:4px}.login-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:24px}.login-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.login-error{font-size:var(--text-sm);color:var(--danger);padding:10px 14px;background:color-mix(in srgb,var(--danger) 10%,transparent);border-radius:var(--radius-sm);border:1px solid color-mix(in srgb,var(--danger) 25%,transparent)}.input-password-wrap{position:relative;display:flex;align-items:center}.input-password{padding-right:48px}.password-toggle{position:absolute;right:0;top:0;bottom:0;width:48px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--text-secondary);transition:var(--transition);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.password-toggle:hover{color:var(--text-primary)}.login-btn{width:100%;margin-top:4px}.login-version{font-size:var(--text-xs);color:var(--text-secondary)}.login-link{color:var(--accent, var(--color-heat, #f59e0b));font-size:var(--text-sm);text-decoration:none}.login-link:hover{text-decoration:underline}.ctrl-slider{display:flex;flex-direction:column;gap:var(--space-2)}.ctrl-slider-head{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-2)}.ctrl-slider-title{font-weight:var(--font-weight-semibold);display:inline-flex;align-items:center;gap:8px;font-size:var(--text-sm);color:var(--text-secondary)}.ctrl-slider-ico{display:inline-flex;color:var(--text-secondary)}.ctrl-slider-value{font-family:var(--font-mono);font-size:1.9rem;font-weight:var(--font-weight-semibold);font-variant-numeric:tabular-nums;letter-spacing:-.02em;color:var(--text-primary)}.ctrl-slider-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:10px;border-radius:999px;background:linear-gradient(to right,var(--accent) 0%,var(--accent) var(--ctrl-pct, 0%),var(--color-border) var(--ctrl-pct, 0%),var(--color-border) 100%);outline:none;cursor:pointer}.ctrl-slider-input::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:28px;height:28px;border-radius:50%;background:var(--accent);border:3px solid var(--color-bg-elevated, #fff);box-shadow:0 1px 4px #0000004d;cursor:pointer}.ctrl-slider-input::-moz-range-thumb{width:28px;height:28px;border-radius:50%;background:var(--accent);border:3px solid var(--color-bg-elevated, #fff);box-shadow:0 1px 4px #0000004d;cursor:pointer}.ctrl-slider-helper{font-size:var(--font-size-sm);color:var(--text-secondary)}.ctrl-slider-op,.ctrl-slider-reason{margin-top:var(--space-1)}.ctrl-slider-reason{font-size:var(--font-size-sm);color:var(--text-secondary)}.ctrl-slider-disabled{opacity:.55}.ctrl-slider-disabled .ctrl-slider-input{cursor:not-allowed;pointer-events:none;background:var(--color-border)}.ctrl-slider-disabled .ctrl-slider-input::-webkit-slider-thumb{background:var(--text-secondary);cursor:not-allowed}.ctrl-slider-disabled .ctrl-slider-input::-moz-range-thumb{background:var(--text-secondary);cursor:not-allowed}.oper-toolbar{display:flex;align-items:center;gap:14px;margin-bottom:20px;flex-wrap:wrap}.search{display:flex;align-items:center;gap:8px;flex:1;min-width:220px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:0 12px;height:38px;color:var(--text-secondary);transition:border-color var(--duration-fast) var(--ease-default)}.search:focus-within{border-color:var(--accent)}.search-input{flex:1;border:none;background:none;outline:none;color:var(--text-primary);font-size:var(--text-sm)}.search-input::placeholder{color:var(--text-secondary)}.segmented{display:inline-flex;gap:2px;background:var(--bg-tertiary);border-radius:var(--radius-md);padding:3px}.seg{display:inline-flex;align-items:center;gap:6px;border:none;background:none;cursor:pointer;padding:6px 12px;border-radius:calc(var(--radius-md) - 3px);font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);transition:background var(--duration-fast),color var(--duration-fast)}.seg:hover{color:var(--text-primary)}.seg-active{background:var(--bg-secondary);color:var(--text-primary);box-shadow:var(--shadow-sm)}.seg-count{font-size:var(--text-xs);color:var(--text-secondary);font-variant-numeric:tabular-nums}.seg-active .seg-count{color:var(--accent)}.oper-list{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.prow{display:grid;grid-template-columns:minmax(160px,1.1fr) auto auto;align-items:center;gap:24px;width:100%;text-align:left;border:none;background:none;cursor:pointer;padding:18px 22px;border-bottom:1px solid var(--border);transition:background var(--duration-fast) var(--ease-default)}.prow:last-child{border-bottom:none}.prow:hover{background:var(--bg-tertiary)}.prow-id{display:flex;flex-direction:column;gap:3px;min-width:0}.prow-name{font-size:var(--text-base);font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.prow-addr{font-size:var(--text-sm);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.prow-meta{display:flex;align-items:center;gap:14px;justify-self:end}.prow-autos{font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap}.row-chev{color:var(--text-secondary);opacity:.6;flex-shrink:0}.prow:hover .row-chev{opacity:1;color:var(--accent)}.prow-modules{display:flex;align-items:center;gap:28px}.clim{display:flex;align-items:center;gap:22px}.clim-readout{display:flex;align-items:baseline;gap:6px;min-width:84px}.clim-temp{font-family:var(--font-mono);font-size:23px;font-weight:600;line-height:1;color:var(--text-primary);font-variant-numeric:tabular-nums;letter-spacing:-.03em}.clim-unit{font-size:12px;font-weight:500;color:var(--text-secondary);margin-left:0}.clim-set{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-secondary);font-variant-numeric:tabular-nums}.prow-empty{font-size:var(--text-sm);color:var(--text-secondary);display:inline-flex;align-items:center;gap:8px}.prow-empty:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--border)}.clim-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;white-space:nowrap}.clim-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.clim-chip-heat{color:var(--heat);background:color-mix(in srgb,var(--heat) 12%,transparent)}.clim-chip-cool{color:var(--cool);background:color-mix(in srgb,var(--cool) 14%,transparent)}.clim-chip-standby{color:var(--text-secondary);background:var(--bg-tertiary)}.clim-metrics{display:flex;align-items:center;gap:18px}.clim-metric{display:flex;flex-direction:column;line-height:1.2}.clim-metric b{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.clim-metric i{font-size:10px;font-style:normal;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary)}.clim-control{min-width:0}.savings-note{text-align:center;color:var(--text-secondary);font-size:var(--text-sm);margin:22px 0 0}.modsel{display:flex;gap:6px;margin-bottom:18px}.modsel-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:11px 6px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;font-size:var(--text-xs);font-weight:500;position:relative;transition:background var(--duration-fast),border-color var(--duration-fast),color var(--duration-fast)}.modsel-ico{display:inline-flex}.modsel-active{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.modsel-teaser{opacity:.85}.modsel-teaser.modsel-active{color:var(--text-primary);border-color:var(--text-secondary);background:var(--bg-tertiary)}.modsel-soon{font-size:9px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.cmd-stats,.cmd-modules{display:none}.cmd-stats{grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px}.stat-tile{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px;display:flex;flex-direction:column;gap:3px}.stat-tile-num{font-family:var(--font-mono);font-size:20px;font-weight:600;line-height:1;color:var(--text-primary);font-variant-numeric:tabular-nums}.stat-tile-label{font-size:10px;color:var(--text-secondary)}.st-heat .stat-tile-num{color:var(--heat)}.st-cool .stat-tile-num{color:var(--cool)}.st-warn .stat-tile-num{color:var(--warning)}.cmd-modules{flex-direction:column;gap:10px;margin-bottom:18px}.mod-card{text-align:left;width:100%;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px;cursor:pointer;transition:background var(--duration-fast) var(--ease-default)}.mod-card:hover,.mod-card:active{background:var(--bg-tertiary)}.mod-card-head{display:flex;align-items:center;gap:10px}.mod-card-icon{display:flex;color:var(--text-secondary)}.mod-card-name{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);flex:1}.mod-card-soon{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);background:var(--bg-tertiary);border-radius:var(--radius-full);padding:3px 8px}.mod-card-preview{margin-top:8px;font-size:var(--text-xs);color:var(--text-secondary);display:flex;align-items:center;gap:8px}.mod-card-ex{font-size:9px;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);border:1px solid color-mix(in srgb,var(--accent) 50%,transparent);border-radius:var(--radius-full);padding:2px 6px}.gclim{padding:18px 20px;margin-bottom:18px}.gclim-title{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);margin:0 0 14px}.gclim-sliders{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:14px}.gclim-apply{width:auto}.gclim-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;width:100%}@media (max-width: 860px){.cmd-stats{display:grid}.cmd-modules{display:flex}.gclim-sliders{grid-template-columns:1fr;gap:16px}.gclim-apply{width:100%}}@media (max-width: 860px){.oper{padding:24px 16px 48px}.prow{grid-template-columns:1fr;gap:14px;align-items:stretch}.prow-modules{flex-wrap:wrap;gap:16px}.clim{flex-wrap:wrap;gap:14px 18px}.prow-meta{justify-self:start}}.pd-back{display:inline-flex;align-items:center;gap:5px;margin-bottom:16px;background:none;border:none;cursor:pointer;padding:4px 0;color:var(--text-secondary);font-size:var(--text-sm);font-weight:500;transition:color var(--duration-fast) var(--ease-default)}.pd-back:hover{color:var(--text-primary)}.pd-head{margin-bottom:18px}.pd-addr{display:inline-flex;align-items:center;gap:5px}.pd-tabs{display:flex;gap:2px;margin-bottom:var(--space-4);border-bottom:1px solid var(--color-border);overflow-x:auto}.pd-tab{flex-shrink:0;padding:var(--space-3) var(--space-4);background:transparent;color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);border-bottom:2px solid transparent;cursor:pointer;transition:var(--transition)}.pd-tab:hover{color:var(--color-text-primary)}.pd-tab-active{color:var(--color-brand-primary);font-weight:var(--font-weight-bold);border-bottom-color:var(--color-brand-primary)}.pd-stack{display:flex;flex-direction:column;gap:var(--space-4)}.pd-metrics{display:flex;flex-wrap:wrap;gap:var(--space-8)}.pd-metric{display:flex;flex-direction:column;gap:4px}.pd-metric-ico{color:var(--text-secondary)}.pd-metric-v{font-family:var(--font-mono);font-size:26px;font-weight:600;line-height:1;color:var(--text-primary);font-variant-numeric:tabular-nums;letter-spacing:-.02em}.pd-metric-u{font-size:13px;font-weight:500;color:var(--text-secondary);margin-left:1px}.eco{display:inline-flex;align-items:center;gap:3px;margin-left:4px}.eco i{width:6px;height:6px;border-radius:50%;background:var(--border);display:inline-block}.eco .eco-on{background:var(--cool)}.auto-ico{display:inline-flex;color:var(--text-secondary)}.res-teaser{padding:28px 24px;text-align:center}.res-teaser-icon{display:inline-flex;color:var(--text-secondary);margin-bottom:10px}.res-teaser-title{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin:0 0 6px;display:inline-flex;align-items:center;gap:10px}.res-teaser-soon{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);background:var(--bg-tertiary);border-radius:var(--radius-full);padding:3px 8px}.res-teaser-msg{color:var(--text-secondary);font-size:var(--text-sm);margin:0 auto 14px;max-width:380px}.res-teaser-preview{display:inline-flex;align-items:center;gap:8px;font-size:var(--text-xs);color:var(--text-secondary)}.pd-head-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.pd-gear{background:none;border:1px solid var(--border);border-radius:var(--radius-md);width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;color:var(--text-secondary);cursor:pointer;flex-shrink:0;transition:background var(--duration-fast) var(--ease-default)}.pd-gear:hover{background:var(--bg-tertiary);color:var(--text-primary)}.fmod-list{display:flex;flex-direction:column;gap:12px}.fmod{text-align:left;width:100%;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;cursor:pointer;transition:background var(--duration-fast) var(--ease-default)}.fmod:hover,.fmod:active{background:var(--bg-tertiary)}.fmod-head{display:flex;align-items:center;gap:10px}.fmod-icon{display:inline-flex;color:var(--text-secondary)}.fmod-name{font-size:var(--text-base);font-weight:600;color:var(--text-primary);flex:1}.fmod-chev{display:inline-flex;color:var(--text-secondary);opacity:.6}.fmod-soon{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);background:var(--bg-tertiary);border-radius:var(--radius-full);padding:3px 8px}.fmod-body{margin-top:12px}.fmod-teaser .fmod-name{color:var(--text-secondary)}.mod-mini{display:flex;flex-direction:column;gap:8px}.sk-line{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:var(--text-sm);color:var(--text-secondary)}.sk-bar{height:10px;border-radius:var(--radius-full);background:var(--bg-tertiary);display:inline-block}.sk-soon{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);background:var(--bg-tertiary);border-radius:var(--radius-full);padding:3px 8px;margin-left:8px}.sk-page{display:flex;flex-direction:column;gap:18px}.sk-sec{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}.sk-sec-title{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);margin:0 0 12px;display:flex;align-items:center}.sk-cal{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.sk-cal-cell{aspect-ratio:1;border-radius:var(--radius-sm);background:var(--bg-tertiary)}.sk-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 0;border-bottom:1px solid var(--border)}.sk-row:last-child{border-bottom:none}.sk-row-label{font-size:var(--text-sm);color:var(--text-secondary)}.sk-card{display:flex;flex-direction:column;gap:8px}.sk-note{font-size:var(--text-xs);color:var(--text-secondary);margin:10px 0 0}.sk-foot{text-align:center;font-size:var(--text-sm);color:var(--text-secondary);margin:2px 0 0}.sk-pf{display:flex;flex-direction:column}.sk-pf-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px solid var(--border)}.sk-pf-row:last-child{border-bottom:none}.sk-pf-name{font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.sk-pf-bars{display:inline-flex;gap:8px}.pd-device,.pd-event{display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);font-size:var(--font-size-sm)}.pd-device+.pd-device,.pd-event+.pd-event{border-top:1px solid var(--color-border);padding-top:var(--space-2)}.pd-device-name{font-weight:var(--font-weight-medium)}.pd-device-btn{width:100%;background:none;border:none;cursor:pointer;text-align:left;color:inherit;padding:var(--space-2) 0;border-radius:var(--radius-sm);transition:var(--transition)}.pd-device-btn:hover{background:var(--color-bg-subtle)}.pd-faulty{font-size:var(--font-size-xs);color:var(--color-warning)}.pd-ceiling-val{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);text-align:center;margin-bottom:var(--space-3)}.pd-slider{width:100%;height:6px;border-radius:var(--radius-full);-moz-appearance:none;appearance:none;-webkit-appearance:none;outline:none}.pd-slider::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:var(--color-brand-primary);border:2px solid var(--color-bg-elevated);box-shadow:var(--shadow-sm);cursor:pointer}.pd-slider::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:var(--color-brand-primary);border:2px solid var(--color-bg-elevated);cursor:pointer}.ac-strategy{display:flex;flex-direction:column;gap:var(--space-2)}.ac-strategy-opt{display:flex;gap:var(--space-2);align-items:flex-start;padding:var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition)}.ac-strategy-opt:hover{background:var(--color-bg-subtle)}.ac-strategy-opt-sel{border-color:var(--accent);background:var(--accent-soft)}.ac-strategy-body{display:flex;flex-direction:column;gap:2px}.ac-strategy-head{font-weight:var(--font-weight-medium)}.ac-strategy-desc{font-size:var(--font-size-sm);color:var(--text-secondary)}.ac-offcool{display:flex;gap:var(--space-2);align-items:flex-start;margin:calc(var(--space-1) * -1) 0 var(--space-1) var(--space-4);padding:var(--space-1) var(--space-2);border-left:2px solid var(--color-border);cursor:pointer}.ac-offcool-head{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.ac-offcool-desc{font-size:var(--font-size-xs);color:var(--text-secondary)}.ac-strategy-legend{font-size:var(--font-size-xs);color:var(--text-secondary);margin:calc(var(--space-1) * -1) 0 var(--space-1)}
