*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246/0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246/0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.visible{visibility:visible}.collapse{visibility:collapse}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.mx-auto{margin-left:auto;margin-right:auto}.-ml-px{margin-left:-1px}.mb-3{margin-bottom:.75rem}.ml-0\.5{margin-left:.125rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.min-h-screen{min-height:100vh}.w-24{width:6rem}.max-w-5xl{max-width:64rem}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-l-md{border-top-left-radius:.375rem;border-bottom-left-radius:.375rem}.rounded-r-md{border-top-right-radius:.375rem;border-bottom-right-radius:.375rem}.border{border-width:1px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-amber-500\/40{border-color:rgb(245 158 11/.4)}.border-amber-500\/60{border-color:rgb(245 158 11/.6)}.border-brand\/60{border-color:rgb(59 130 246/.6)}.border-emerald-500\/40{border-color:rgb(16 185 129/.4)}.border-emerald-500\/60{border-color:rgb(16 185 129/.6)}.border-neutral-500\/40{border-color:rgb(115 115 115/.4)}.border-neutral-700{--tw-border-opacity:1;border-color:rgb(64 64 64/var(--tw-border-opacity,1))}.border-neutral-800{--tw-border-opacity:1;border-color:rgb(38 38 38/var(--tw-border-opacity,1))}.border-red-500\/40{border-color:rgb(239 68 68/.4)}.border-sky-500\/60{border-color:rgb(14 165 233/.6)}.bg-amber-500\/10{background-color:rgb(245 158 11/.1)}.bg-amber-500\/20{background-color:rgb(245 158 11/.2)}.bg-brand\/10{background-color:rgb(59 130 246/.1)}.bg-emerald-500\/10{background-color:rgb(16 185 129/.1)}.bg-emerald-500\/20{background-color:rgb(16 185 129/.2)}.bg-neutral-500\/20{background-color:rgb(115 115 115/.2)}.bg-neutral-700\/30{background-color:rgb(64 64 64/.3)}.bg-neutral-800{--tw-bg-opacity:1;background-color:rgb(38 38 38/var(--tw-bg-opacity,1))}.bg-neutral-900{--tw-bg-opacity:1;background-color:rgb(23 23 23/var(--tw-bg-opacity,1))}.bg-neutral-950{--tw-bg-opacity:1;background-color:rgb(10 10 10/var(--tw-bg-opacity,1))}.bg-red-500\/20{background-color:rgb(239 68 68/.2)}.bg-red-500\/5{background-color:rgb(239 68 68/.05)}.bg-sky-500\/10{background-color:rgb(14 165 233/.1)}.p-3{padding:.75rem}.p-4{padding:1rem}.p-8{padding:2rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.pb-4{padding-bottom:1rem}.pt-3{padding-top:.75rem}.text-center{text-align:center}.text-right{text-align:right}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-\[10px\]{font-size:10px}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction)}.tracking-wider{letter-spacing:.05em}.text-amber-200{--tw-text-opacity:1;color:rgb(253 230 138/var(--tw-text-opacity,1))}.text-amber-300{--tw-text-opacity:1;color:rgb(252 211 77/var(--tw-text-opacity,1))}.text-brand{--tw-text-opacity:1;color:rgb(59 130 246/var(--tw-text-opacity,1))}.text-emerald-300{--tw-text-opacity:1;color:rgb(110 231 183/var(--tw-text-opacity,1))}.text-neutral-300{--tw-text-opacity:1;color:rgb(212 212 212/var(--tw-text-opacity,1))}.text-neutral-400{--tw-text-opacity:1;color:rgb(163 163 163/var(--tw-text-opacity,1))}.text-neutral-500{--tw-text-opacity:1;color:rgb(115 115 115/var(--tw-text-opacity,1))}.text-neutral-600{--tw-text-opacity:1;color:rgb(82 82 82/var(--tw-text-opacity,1))}.text-red-300{--tw-text-opacity:1;color:rgb(252 165 165/var(--tw-text-opacity,1))}.text-sky-300{--tw-text-opacity:1;color:rgb(125 211 252/var(--tw-text-opacity,1))}.blur{--tw-blur:blur(8px)}.blur,.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}:root{--accent-h:38;--accent-s:92%;--accent-l:50%;--accent:hsl(var(--accent-h) var(--accent-s) var(--accent-l));--accent-soft:hsl(var(--accent-h) var(--accent-s) var(--accent-l)/0.15);--accent-dim:hsl(var(--accent-h) var(--accent-s) 42%);--row-h:36px;--pad-x:14px;--pad-y:10px;--radius:8px;--radius-sm:6px;--font-sans:"Inter",ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;--font-mono:"JetBrains Mono",ui-monospace,"SFMono-Regular",Menlo,Consolas,monospace}.theme-dark,:root{color-scheme:dark;--bg:#0A0B0D;--bg-elev:#111214;--bg-card:#141518;--bg-card-2:#1A1C20;--bg-hover:#1F2125;--bg-input:#0E0F12;--border:#24262B;--border-strong:#30333A;--fg:#ECEDEE;--fg-2:#C9CBCF;--fg-3:#8A8D93;--fg-4:#5E6167;--status-on:#22C55E;--status-warn:#F59E0B;--status-err:#EF4444;--status-info:#3B82F6;--status-muted:#55585E;--shadow-sm:0 1px 0 rgba(255,255,255,0.02) inset,0 1px 2px rgba(0,0,0,0.4);--shadow-lg:0 20px 48px rgba(0,0,0,0.5)}.theme-light{color-scheme:light;--bg:#F7F7F5;--bg-elev:#FFFFFF;--bg-card:#FFFFFF;--bg-card-2:#FAFAF9;--bg-hover:#F0F0EE;--bg-input:#FFFFFF;--border:#E5E5E2;--border-strong:#D4D4D0;--fg:#17181A;--fg-2:#3A3C40;--fg-3:#6E7075;--fg-4:#A0A2A7;--status-on:#16A34A;--status-warn:#D97706;--status-err:#DC2626;--status-info:#2563EB;--status-muted:#9CA0A6;--shadow-sm:0 1px 2px rgba(0,0,0,0.05);--shadow-lg:0 20px 40px rgba(0,0,0,0.12)}.brand-aqutron-control{--accent-h:184;--accent-s:100%;--accent-l:40%;--status-info:#00C2CC;--accent:hsl(var(--accent-h) var(--accent-s) var(--accent-l));--accent-soft:hsl(var(--accent-h) var(--accent-s) var(--accent-l)/0.15);--accent-dim:hsl(var(--accent-h) var(--accent-s) 32%)}.density-compact{--row-h:30px;--pad-x:12px;--pad-y:8px}.density-comfy{--row-h:44px;--pad-x:18px;--pad-y:14px}*,:after,:before{box-sizing:border-box}#root,body,html{height:100%;margin:0}html{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;touch-action:pan-y}body,html{overflow-x:hidden;max-width:100%}body{font-family:var(--font-sans);font-size:13px;line-height:1.45;background:var(--bg);color:var(--fg);-webkit-font-smoothing:antialiased;font-feature-settings:"cv02","cv03","cv04","cv11";overscroll-behavior:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}button,input,select,textarea{font:inherit;color:inherit}button{cursor:pointer;border:0;background:none;padding:0}a{color:inherit;text-decoration:none}.mono,code,kbd{font-family:var(--font-mono)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px;border:2px solid transparent;background-clip:content-box}::-webkit-scrollbar-thumb:hover{background:var(--border-strong);background-clip:content-box;border:2px solid transparent}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-block-end:16px}.card:last-child{margin-block-end:0}.card-hd{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border);min-height:40px}.card-hd h3{margin:0;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--fg-3)}.card-body{padding:12px 14px}.btn{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card-2);color:var(--fg);font-weight:500;font-size:12.5px;transition:background .1s,border-color .1s}.btn:hover{background:var(--bg-hover);border-color:var(--border-strong)}.btn-primary{background:var(--accent);color:#0A0B0D;border-color:var(--accent);font-weight:600}.btn-primary:hover{background:var(--accent-dim);border-color:var(--accent-dim)}.btn-primary:disabled{opacity:.6;cursor:wait}.btn-ghost{border-color:transparent}.btn-ghost:hover{background:var(--bg-hover);border-color:var(--border)}.btn-sm{height:26px;padding:0 9px;font-size:11.5px}.btn-icon{width:30px;padding:0;justify-content:center}.badge{display:inline-flex;align-items:center;gap:6px;height:22px;padding:0 8px;border-radius:999px;font-size:11px;font-weight:500;border:1px solid var(--border);background:var(--bg-card-2);color:var(--fg-2);white-space:nowrap}.badge.sq{border-radius:4px;height:20px;padding:0 6px;font-size:10.5px;font-weight:600;letter-spacing:.03em;text-transform:uppercase}.badge-dot{width:6px;height:6px;border-radius:999px;background:var(--fg-4);flex-shrink:0}.badge.on{color:var(--status-on);border-color:color-mix(in srgb,var(--status-on) 40%,var(--border));background:color-mix(in srgb,var(--status-on) 10%,var(--bg-card-2))}.badge.on .badge-dot{background:var(--status-on);box-shadow:0 0 0 3px color-mix(in srgb,var(--status-on) 25%,transparent);animation:pulse 1.6s ease-in-out infinite}.badge.warn{color:var(--status-warn);border-color:color-mix(in srgb,var(--status-warn) 40%,var(--border));background:color-mix(in srgb,var(--status-warn) 10%,var(--bg-card-2))}.badge.warn .badge-dot{background:var(--status-warn)}.badge.err{color:var(--status-err);border-color:color-mix(in srgb,var(--status-err) 40%,var(--border));background:color-mix(in srgb,var(--status-err) 12%,var(--bg-card-2))}.badge.err .badge-dot{background:var(--status-err)}.badge.info{color:var(--status-info);border-color:color-mix(in srgb,var(--status-info) 40%,var(--border));background:color-mix(in srgb,var(--status-info) 10%,var(--bg-card-2))}.badge.info .badge-dot{background:var(--status-info)}.badge.accent{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 40%,var(--border));background:var(--accent-soft)}.badge.accent .badge-dot{background:var(--accent)}@keyframes pulse{0%,to{box-shadow:0 0 0 0 color-mix(in srgb,var(--status-on) 40%,transparent)}50%{box-shadow:0 0 0 5px color-mix(in srgb,var(--status-on) 0%,transparent)}}.kv{display:grid;grid-template-columns:auto 1fr;gap:4px 10px;font-size:12px}.kv dt{color:var(--fg-3);font-weight:500}.kv dd{margin:0;color:var(--fg-2);font-variant-numeric:tabular-nums;font-family:var(--font-mono);font-size:11.5px}.hr{height:1px;background:var(--border);border:0;margin:0}.input{width:100%;height:34px;padding:0 10px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--fg);font-size:13px;transition:border-color .1s,box-shadow .1s;outline:none}.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.input::-moz-placeholder{color:var(--fg-4)}.input::placeholder{color:var(--fg-4)}.label{display:block;font-size:11.5px;font-weight:500;color:var(--fg-2);margin-bottom:6px;letter-spacing:.01em}.app{display:grid;grid-template-columns:240px 1fr;grid-template-rows:48px 1fr;grid-template-areas:"sidebar topbar" "sidebar main";height:100vh;max-width:100%;overflow-x:hidden}.app.compact-sidebar{grid-template-columns:56px 1fr}.sidebar{grid-area:sidebar;background:var(--bg-elev);border-right:1px solid var(--border);display:flex;flex-direction:column;min-height:0}.sidebar-hd{height:48px;display:flex;align-items:center;gap:10px;padding:0 14px;border-bottom:1px solid var(--border)}.sidebar-hd .logo-mark{width:22px;height:22px;flex-shrink:0}.sidebar-hd .wordmark{font-weight:700;letter-spacing:.02em;font-size:14px;color:var(--fg)}.sidebar-hd .wordmark em{color:var(--accent);font-style:normal;font-weight:700}.app.compact-sidebar .env-chip,.app.compact-sidebar .nav-label,.app.compact-sidebar .sidebar-ft-info,.app.compact-sidebar .sidebar-hd .wordmark,.app.compact-sidebar .sidebar-sect{display:none}.app.compact-sidebar .nav-item,.app.compact-sidebar .sidebar-hd{justify-content:center;padding:0}.sidebar-sect{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-4);padding:14px 16px 6px}.sidebar-nav{display:flex;flex-direction:column;gap:1px;padding:0 8px}.nav-item{display:flex;align-items:center;gap:10px;height:32px;padding:0 10px;border-radius:6px;color:var(--fg-2);font-size:12.5px;font-weight:500;position:relative}.nav-item:hover{background:var(--bg-hover);color:var(--fg)}.nav-item.active{background:var(--bg-card-2);color:var(--fg)}.nav-item.active:before{content:"";position:absolute;left:-8px;top:6px;bottom:6px;width:2px;border-radius:2px;background:var(--accent)}.nav-item .nav-icon{width:16px;height:16px;flex-shrink:0;color:var(--fg-3)}.nav-item.active .nav-icon{color:var(--accent)}.nav-item .nav-soon{margin-left:auto;font-size:9.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--fg-4);background:var(--bg-card-2);padding:2px 5px;border-radius:3px;border:1px solid var(--border)}.nav-item.is-soon{color:var(--fg-4);cursor:default}.nav-item.is-soon:hover{background:transparent;color:var(--fg-4)}.sidebar-ft{margin-top:auto;border-top:1px solid var(--border);padding:10px;display:flex;align-items:center;gap:10px}.avatar{width:28px;height:28px;border-radius:6px;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;font-size:11px;font-weight:700;border:1px solid color-mix(in srgb,var(--accent) 30%,var(--border));flex-shrink:0}.sidebar-ft-info{flex:1;min-width:0}.sidebar-ft-info .n{font-size:12px;font-weight:600;color:var(--fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-ft-info .r{font-size:11px;color:var(--fg-3)}.sidebar-ft button{color:var(--fg-3);padding:4px;border-radius:5px}.sidebar-ft button:hover{background:var(--bg-hover);color:var(--fg)}.env-chip{display:inline-flex;align-items:center;gap:6px;font-size:10.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--status-warn);background:color-mix(in srgb,var(--status-warn) 12%,transparent);border:1px solid color-mix(in srgb,var(--status-warn) 35%,var(--border));padding:2px 7px;border-radius:4px;margin-left:6px}.topbar{grid-area:topbar;background:var(--bg-elev);border-bottom:1px solid var(--border);padding:0 16px;gap:12px;position:sticky;top:0;z-index:20}.breadcrumb,.topbar{display:flex;align-items:center}.breadcrumb{gap:8px;font-size:12.5px;color:var(--fg-3);min-width:0}.breadcrumb>*{white-space:nowrap}.breadcrumb .sep{color:var(--fg-4)}.breadcrumb .cur{color:var(--fg);font-weight:500;font-family:var(--font-mono);font-size:12px;overflow:hidden;text-overflow:ellipsis}.topbar-r{margin-left:auto;display:flex;align-items:center;gap:8px}.icon-btn{width:32px;height:32px;display:grid;place-items:center;border-radius:6px;color:var(--fg-3)}.icon-btn:hover{background:var(--bg-hover);color:var(--fg)}.icon-btn svg{width:16px;height:16px}.main{grid-area:main;overflow-y:auto;overflow-x:hidden;min-height:0;padding:20px 24px 32px}.main-inner{max-width:1480px;margin:0 auto;min-width:0}.page-banner{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius-sm);border:1px solid color-mix(in srgb,var(--status-err) 45%,var(--border));background:color-mix(in srgb,var(--status-err) 12%,var(--bg-card));color:var(--fg);font-size:12.5px;margin-bottom:14px}.page-banner.warn{border-color:color-mix(in srgb,var(--status-warn) 45%,var(--border));background:color-mix(in srgb,var(--status-warn) 10%,var(--bg-card))}.page-banner .banner-dot{width:8px;height:8px;border-radius:999px;background:var(--status-err);flex-shrink:0;animation:pulse-err 1.2s infinite}.page-banner.warn .banner-dot{background:var(--status-warn);animation:none}@keyframes pulse-err{0%,to{box-shadow:0 0 0 0 color-mix(in srgb,var(--status-err) 45%,transparent)}50%{box-shadow:0 0 0 6px color-mix(in srgb,var(--status-err) 0%,transparent)}}.page-banner .spacer{flex:1}@keyframes fadeInRight{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}@keyframes livePulse{0%,to{box-shadow:0 0 0 0 color-mix(in srgb,var(--accent) 50%,transparent);opacity:1}50%{box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 0%,transparent);opacity:.7}}.live-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--accent);animation:livePulse 1.5s ease-in-out infinite}.di-cell.on .di-val,.live-temp{transition:color .2s ease-out}.thermostat-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:4px;border-radius:2px;background:var(--bg-card-2);outline:none;border:1px solid var(--border);cursor:pointer}.thermostat-slider:disabled{opacity:.4;cursor:not-allowed}.thermostat-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);border:2px solid var(--bg-card);box-shadow:0 0 0 1px var(--accent);cursor:pointer;-webkit-transition:transform .12s ease;transition:transform .12s ease}.thermostat-slider::-webkit-slider-thumb:hover{transform:scale(1.15)}.thermostat-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--accent);border:2px solid var(--bg-card);box-shadow:0 0 0 1px var(--accent);cursor:pointer}.dev-hd{display:grid;grid-template-columns:1fr auto;gap:16px;align-items:start;padding:16px 18px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px}.dev-hd-title{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.dev-hd-title h1{margin:0;font-size:18px;font-weight:600;font-family:var(--font-mono);letter-spacing:-.01em}.dev-hd-sub{margin-top:6px;color:var(--fg-3);font-size:12px}.dev-hd-sub strong{color:var(--fg-2);font-weight:500}.caps{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}.dev-hd-meta{display:grid;grid-template-columns:auto auto;gap:6px 18px;font-size:11.5px;font-family:var(--font-mono);color:var(--fg-3);text-align:right}.dev-hd-meta,.dev-hd-meta dd,.dev-hd-meta dt{white-space:nowrap}.dev-hd-meta .k{color:var(--fg-4)}.dev-hd-meta .v{color:var(--fg-2)}.dev-hd-actions{display:flex;gap:6px;align-items:center}.io-grid{display:grid;grid-template-columns:5fr 7fr;gap:16px;margin-bottom:16px}.io-grid.stacked{grid-template-columns:1fr}@media (max-width:1100px){.io-grid{grid-template-columns:1fr}}.di-grid,.ro-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border);border-radius:0;overflow:hidden}.di-grid.cols-4{grid-template-columns:repeat(4,1fr)}.di-grid.cols-1{grid-template-columns:1fr}.di-cell{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;padding:10px 14px;background:var(--bg-card);min-height:var(--row-h)}.di-cell:hover{background:var(--bg-card-2)}.led{width:12px;height:12px;border-radius:999px;background:var(--status-muted);box-shadow:inset 0 0 0 1px rgba(0,0,0,.3);transition:background .15s ease,box-shadow .15s ease;position:relative;flex-shrink:0}.led.on{background:var(--status-on);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--status-on) 60%,transparent),0 0 10px color-mix(in srgb,var(--status-on) 70%,transparent),0 0 2px color-mix(in srgb,var(--status-on) 50%,transparent)}.led.just-flipped:after{content:"";position:absolute;inset:-4px;border-radius:999px;border:1px solid var(--accent);animation:ping .5s ease-out}@keyframes ping{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(2.2)}}.di-label{display:flex;flex-direction:column;gap:2px;min-width:0}.di-label .n{font-size:12.5px;font-weight:600;color:var(--fg)}.di-label .meta,.di-label .n{font-family:var(--font-mono);letter-spacing:.01em}.di-label .meta{font-size:10.5px;color:var(--fg-4);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.di-val{font-family:var(--font-mono);font-size:12.5px;font-weight:700;color:var(--fg-4);letter-spacing:.02em;min-width:22px;text-align:right}.di-cell.on .di-val{color:var(--status-on)}.ro-row{display:grid;grid-template-columns:auto minmax(80px,1fr) minmax(120px,1.4fr) auto auto;gap:10px;align-items:center;padding:10px 14px;background:var(--bg-card);min-height:var(--row-h);transition:background .12s}.ro-row:hover{background:var(--bg-card-2)}.ro-end{display:flex;align-items:center;gap:8px;justify-self:end}.ro-row .led.on{background:var(--accent);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--accent) 60%,transparent),0 0 8px color-mix(in srgb,var(--accent) 60%,transparent),0 0 2px color-mix(in srgb,var(--accent) 50%,transparent)}.ro-label{display:flex;flex-direction:column;gap:2px;min-width:0}.ro-label .n{font-size:12.5px;font-weight:600;color:var(--fg)}.ro-label .meta,.ro-label .n{font-family:var(--font-mono);letter-spacing:.01em}.ro-label .meta{font-size:10.5px;color:var(--fg-4)}.ro-cell.on .ro-label .meta{color:var(--accent)}.ro-spinner{width:12px;height:12px;border:1.5px solid color-mix(in srgb,var(--fg-4) 40%,transparent);border-top-color:var(--accent);border-radius:999px;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.switch{position:relative;width:38px;height:22px;border-radius:999px;background:var(--border);transition:background .15s;flex-shrink:0;border:1px solid var(--border-strong);cursor:pointer}.switch.on{background:var(--accent);border-color:var(--accent)}.switch.disabled{opacity:.55;cursor:not-allowed}.switch input{position:absolute;inset:0;width:100%;height:100%;margin:0;opacity:0;cursor:inherit;-moz-appearance:none;appearance:none;-webkit-appearance:none}.switch i{position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:999px;transition:transform .15s cubic-bezier(.3,.7,.4,1);box-shadow:0 1px 2px rgba(0,0,0,.3);pointer-events:none}.switch.on i{transform:translateX(16px);background:#0A0B0D}.events{font-family:var(--font-mono);font-size:12px;background:var(--bg-card);max-height:320px;overflow-y:auto}.events-row{display:grid;grid-template-columns:74px 78px 130px minmax(0,1fr) auto;gap:12px;padding:7px 14px;border-bottom:1px solid var(--border);align-items:baseline;color:var(--fg-3);font-size:11.5px}.events-row.is-new{animation:flash-row 1.2s ease-out}@keyframes flash-row{0%{background:var(--accent-soft)}to{background:transparent}}.events-row .ts{color:var(--fg-4)}.events-row .type{font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:1px 5px;border-radius:3px;justify-self:start}.events-row .type.announce{color:var(--status-info);background:color-mix(in srgb,var(--status-info) 15%,transparent)}.events-row .type.ro_set{color:#A78BFA;background:color-mix(in srgb,#A78BFA 15%,transparent)}.events-row .type.di_edge{color:var(--status-on);background:color-mix(in srgb,var(--status-on) 15%,transparent)}.events-row .type.boot{color:var(--status-warn);background:color-mix(in srgb,var(--status-warn) 15%,transparent)}.events-row .type.rule_match{color:var(--fg-3);background:var(--bg-card-2)}.events-row .type.heartbeat{color:var(--fg-4);background:var(--bg-card-2)}.events-row .type.error{color:var(--status-err);background:color-mix(in srgb,var(--status-err) 15%,transparent)}.events-row .actor{color:var(--fg-4)}.events-row .actor,.events-row .msg{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.events-row .msg{color:var(--fg-2)}.events-row .msg .k{color:var(--fg-4)}.events-row .msg .v{color:var(--fg)}.events-row .msg .v.ok{color:var(--status-on)}.events-row .msg .v.off{color:var(--fg-3)}.events-row .dur{color:var(--fg-4);justify-self:end}.events-empty{padding:24px 14px;text-align:center;color:var(--fg-4)}.events-foot{padding:10px 14px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;color:var(--fg-4);font-size:11px;font-family:var(--font-mono)}.events.table .events-row{grid-template-columns:90px 90px 1fr auto;font-family:var(--font-sans);font-size:12px}.events.table .events-row .actor{display:none}.events.table .events-row .type{font-family:var(--font-mono)}.events.timeline{padding:8px 0 0}.events.timeline .events-row{grid-template-columns:14px 80px 1fr auto;border-bottom:none;padding:6px 14px 6px 18px;position:relative}.events.timeline .events-row:before{content:"";position:absolute;left:25px;top:0;bottom:0;width:1px;background:var(--border)}.events.timeline .events-row .dot{width:8px;height:8px;border-radius:999px;background:var(--fg-4);justify-self:center;align-self:center;z-index:1;position:relative;box-shadow:0 0 0 2px var(--bg-card)}.events.timeline .events-row .dot.announce{background:var(--status-info)}.events.timeline .events-row .dot.ro_set{background:#A78BFA}.events.timeline .events-row .dot.di_edge{background:var(--status-on)}.events.timeline .events-row .dot.boot{background:var(--status-warn)}.events.timeline .events-row .dot.error{background:var(--status-err)}.events.timeline .events-row .actor,.events.timeline .events-row .type{display:none}.events.timeline .events-row .msg{font-family:var(--font-sans);font-size:12px}.toast-stack{position:fixed;right:20px;bottom:20px;z-index:1000;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{pointer-events:auto;display:flex;align-items:flex-start;gap:10px;min-width:300px;max-width:380px;padding:10px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);animation:toast-in .2s ease-out;font-size:12.5px}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}}.toast.err{border-color:color-mix(in srgb,var(--status-err) 45%,var(--border))}.toast.ok{border-color:color-mix(in srgb,var(--status-on) 45%,var(--border))}.toast .ti{flex-shrink:0;margin-top:1px;color:var(--status-err)}.toast.ok .ti{color:var(--status-on)}.toast .tt{font-weight:600;color:var(--fg)}.toast .tm{color:var(--fg-3);margin-top:2px;font-family:var(--font-mono);font-size:11px}.toast button{margin-left:auto;color:var(--fg-4)}.toast button:hover{color:var(--fg)}.login{min-height:100vh;background:radial-gradient(1200px 600px at 50% -20%,color-mix(in srgb,var(--accent) 10%,transparent),transparent 60%),radial-gradient(800px 400px at 80% 100%,color-mix(in srgb,var(--accent) 5%,transparent),transparent 60%),var(--bg);display:grid;grid-template-rows:1fr auto;position:relative}.login-grid{position:absolute;inset:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:48px 48px;-webkit-mask-image:radial-gradient(ellipse at 50% 40%,black 0,transparent 70%);mask-image:radial-gradient(ellipse at 50% 40%,black 0,transparent 70%);opacity:.35;pointer-events:none}.login-inner{display:grid;place-items:center;padding:40px 24px;position:relative;z-index:1}.login-card{width:100%;max-width:420px;background:color-mix(in srgb,var(--bg-card) 85%,transparent);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:12px;padding:28px;box-shadow:var(--shadow-lg)}.login-brand{display:flex;align-items:center;gap:10px;margin-bottom:24px}.login-brand .logo-mark{width:28px;height:28px}.login-brand .wordmark{font-weight:700;font-size:17px;letter-spacing:.01em}.login-brand .wordmark em{color:var(--accent);font-style:normal}.login-brand .env-chip{margin-left:auto}.login-h{margin:0 0 4px;font-size:18px;font-weight:600;letter-spacing:-.01em}.login-sub{color:var(--fg-3);font-size:12.5px;margin:0 0 20px}.login-alert{display:flex;align-items:flex-start;gap:8px;padding:9px 11px;border-radius:var(--radius-sm);background:color-mix(in srgb,var(--status-err) 12%,transparent);border:1px solid color-mix(in srgb,var(--status-err) 45%,var(--border));color:var(--fg);font-size:12px;margin-bottom:14px}.login-alert svg{color:var(--status-err);flex-shrink:0;margin-top:1px}.login-field{margin-bottom:12px}.login-btn-row{margin-top:18px;display:flex;flex-direction:column;gap:10px}.login-btn-row .btn-primary{height:38px;font-size:13px;justify-content:center}.login-helper{display:flex;align-items:center;justify-content:space-between;font-size:11.5px;color:var(--fg-3)}.login-helper a:hover{color:var(--fg)}.login-ft{padding:16px 24px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;color:var(--fg-4);font-size:11.5px;font-family:var(--font-mono);position:relative;z-index:1;background:color-mix(in srgb,var(--bg-elev) 60%,transparent);backdrop-filter:blur(8px)}.login-ft .links{display:flex;gap:16px}.login-ft a:hover{color:var(--fg-2)}.spinner-inline{width:14px;height:14px;border:2px solid color-mix(in srgb,#0a0b0d 30%,transparent);border-top-color:#0a0b0d;border-radius:999px;animation:spin .7s linear infinite}.proto-hint{position:fixed;left:16px;bottom:16px;font-family:var(--font-mono);font-size:10.5px;color:var(--fg-4);background:color-mix(in srgb,var(--bg-card) 80%,transparent);backdrop-filter:blur(8px);border:1px solid var(--border);padding:6px 10px;border-radius:6px;z-index:50;pointer-events:none;letter-spacing:.02em;white-space:nowrap}.proto-hint kbd{padding:0 4px;border:1px solid var(--border-strong);border-radius:3px;background:var(--bg-card-2);color:var(--fg-2);font-size:10px}.vfd-card{padding:14px 16px 16px;margin-bottom:16px}.vfd-card .card-hd{padding:0 0 12px}.vfd-role{color:var(--fg-3);font-weight:400;font-size:12px;letter-spacing:0}.vfd-fault{display:flex;align-items:center;gap:8px;padding:8px 10px;margin-bottom:12px;border-radius:var(--radius-sm);background:color-mix(in srgb,currentColor 12%,transparent);border:1px solid color-mix(in srgb,currentColor 35%,var(--border));font-size:12px}.vfd-fault-label{color:var(--fg-2)}.vfd-fault .spacer{flex:1}.vfd-kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}.vfd-kpi{background:var(--bg-card-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 10px}.vfd-kpi.primary{background:color-mix(in srgb,var(--accent) 8%,var(--bg-card-2));border-color:color-mix(in srgb,var(--accent) 40%,var(--border))}.vfd-kpi-label{display:flex;align-items:center;gap:4px;font-size:10.5px;color:var(--fg-3);letter-spacing:.02em;text-transform:uppercase}.vfd-kpi-value{font-family:var(--font-mono);font-size:18px;color:var(--fg);font-weight:600;margin-top:2px;line-height:1.1}.vfd-kpi.primary .vfd-kpi-value{color:var(--accent)}.vfd-kpi-unit{font-size:11px;color:var(--fg-3);margin-left:4px;font-weight:400}.vfd-stepper{margin-bottom:14px}.vfd-stepper-label{font-size:11px;color:var(--fg-3);margin-bottom:6px;letter-spacing:.02em;text-transform:uppercase}.vfd-stepper-actual{color:var(--fg-4);text-transform:none;letter-spacing:0}.vfd-stepper-row{display:flex;align-items:center;gap:8px}.vfd-stepper-btn{width:38px;height:38px;display:grid;place-items:center;border:1px solid var(--border-strong);background:var(--bg-card-2);border-radius:var(--radius-sm);color:var(--fg-2);transition:background .15s,border-color .15s,transform .05s}.vfd-stepper-btn:hover:not(:disabled){background:var(--bg-hover);border-color:var(--accent);color:var(--accent)}.vfd-stepper-btn:active:not(:disabled){transform:scale(.94)}.vfd-stepper-btn:disabled{opacity:.45;cursor:not-allowed}.vfd-stepper-input{flex:0 0 100px;height:38px;background:var(--bg-input);border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--fg);font-family:var(--font-mono);font-size:18px;font-weight:600;text-align:center;padding:0 8px}.vfd-stepper-input:focus{outline:none;border-color:var(--accent);background:color-mix(in srgb,var(--accent) 5%,var(--bg-input))}.vfd-stepper-input::-webkit-inner-spin-button,.vfd-stepper-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.vfd-stepper-input{-moz-appearance:textfield}.vfd-stepper-unit{color:var(--fg-3);font-size:13px;font-family:var(--font-mono)}.vfd-apply{margin-left:auto}.vfd-stepper-track{position:relative;height:6px;margin:14px 0 26px;background:var(--border);border-radius:3px}.vfd-stepper-track-fill{position:absolute;left:0;top:0;bottom:0;background:var(--accent);border-radius:3px;transition:width .4s ease-out}.vfd-stepper-tick{top:12px;font-family:var(--font-mono);font-size:9.5px;color:var(--fg-4)}.vfd-stepper-tick,.vfd-stepper-tick:before{position:absolute;transform:translateX(-50%)}.vfd-stepper-tick:before{content:"";left:50%;top:-10px;width:1px;height:6px;background:var(--border-strong)}.vfd-actions{display:flex;gap:8px;align-items:center}.vfd-actions .spacer{flex:1}.vfd-toggle-start{background:var(--status-on);color:#052e0d;border-color:var(--status-on);font-weight:600}.vfd-toggle-start:hover:not(:disabled){background:color-mix(in srgb,var(--status-on) 88%,white);border-color:color-mix(in srgb,var(--status-on) 88%,white)}.vfd-toggle-stop{background:var(--status-err);color:#fff;border-color:var(--status-err);font-weight:600}.vfd-toggle-stop:hover:not(:disabled){background:color-mix(in srgb,var(--status-err) 88%,white);border-color:color-mix(in srgb,var(--status-err) 88%,white)}.vfd-estop{color:var(--status-err);border-color:color-mix(in srgb,var(--status-err) 50%,var(--border));background:color-mix(in srgb,var(--status-err) 10%,var(--bg-card-2))}.vfd-estop:hover:not(:disabled){background:color-mix(in srgb,var(--status-err) 20%,var(--bg-card-2));border-color:var(--status-err)}.vfd-modal-backdrop{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.6);display:grid;place-items:center;animation:fadein .12s ease-out}@keyframes fadein{0%{opacity:0}to{opacity:1}}.vfd-modal{background:var(--bg-card);border:1px solid var(--border-strong);border-radius:var(--radius);padding:18px 20px;width:min(420px,92vw);box-shadow:var(--shadow-lg)}.vfd-modal h4{margin:0 0 8px;font-size:15px;font-weight:600;font-family:var(--font-mono);letter-spacing:-.01em}.vfd-modal p{margin:0 0 16px;font-size:13px;color:var(--fg-2);line-height:1.5}.vfd-modal-actions{display:flex;justify-content:flex-end;gap:8px}.ro-pulse-dur{display:inline-flex;align-items:center;gap:2px;background:var(--bg-input);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:2px 6px}.ro-pulse-dur,.ro-pulse-dur input{font-family:var(--font-mono);font-size:11px}.ro-pulse-dur input{width:38px;background:transparent;border:0;color:var(--fg);padding:0;-moz-appearance:textfield}.ro-pulse-dur input::-webkit-inner-spin-button,.ro-pulse-dur input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.ro-pulse-dur input:focus{outline:none}.ro-pulse-unit{color:var(--fg-3);font-size:10px}.vfd-summary{display:flex;align-items:center;gap:12px;padding:12px 14px;margin-top:16px;margin-bottom:16px;background:var(--bg-card);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--radius);text-decoration:none;color:inherit;transition:background .12s,border-color .12s}.vfd-summary:hover{background:var(--bg-hover);border-color:var(--accent)}.vfd-summary-icon{width:32px;height:32px;display:grid;place-items:center;background:color-mix(in srgb,var(--accent) 15%,transparent);color:var(--accent);border-radius:var(--radius-sm);flex-shrink:0}.vfd-summary-info{flex:1;min-width:0}.vfd-summary-title{font-size:13px;font-weight:600;color:var(--fg)}.vfd-summary-sub{font-size:11.5px;color:var(--fg-3);font-family:var(--font-mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.vfd-summary-cta{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--fg-3);letter-spacing:.02em}.vfd-page-hd{margin-bottom:16px}.vfd-grid{display:flex;flex-direction:column;gap:16px}@media (min-width:1100px){.vfd-grid{display:grid;grid-template-columns:1fr 1fr}}@media (max-width:768px){.vfd-kpi-grid{grid-template-columns:repeat(2,1fr)}.vfd-stepper-input{flex:1 1 auto;min-width:0}.vfd-apply{width:100%;margin:8px 0 0}.vfd-actions,.vfd-stepper-row{flex-wrap:wrap}.vfd-actions .spacer{display:none}.vfd-estop{margin-left:auto}}.mobile-menu-btn,.sidebar-backdrop{display:none}@media (max-width:768px){.app{grid-template-columns:1fr;grid-template-rows:48px 1fr;grid-template-areas:"topbar" "main"}.sidebar{position:fixed;top:0;bottom:0;left:env(safe-area-inset-left);right:auto;width:240px;z-index:60;transform:translateX(-110%);transition:transform .18s ease;box-shadow:var(--shadow-lg)}.app.mobile-nav-open .sidebar{transform:translateX(0)}.sidebar-backdrop{display:block;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:55;opacity:0;pointer-events:none;transition:opacity .18s ease}.app.mobile-nav-open .sidebar-backdrop{opacity:1;pointer-events:auto}.mobile-menu-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;margin-right:6px;color:var(--fg-2);background:transparent;border:1px solid var(--border);border-radius:6px}.mobile-menu-btn:active{background:var(--bg-hover)}.topbar{padding:0 10px}.topbar .breadcrumb{font-size:12px}.topbar-r{gap:4px}.topbar-r>:not(.badge):not(.mobile-sign-out){display:none}.topbar-r .mobile-sign-out{display:inline-flex}.mobile-hide{display:none!important}.topbar-r .badge{font-size:10px}.breadcrumb .sep,.breadcrumb>:not(.cur):not(.sep),.topbar-r .badge .badge-dot{display:none}.breadcrumb,.breadcrumb .cur{min-width:0;flex:1 1 auto}.dev-hd{grid-template-columns:1fr;padding:12px;min-width:0}.dev-hd>div{min-width:0;max-width:100%}.dev-hd>div:last-child{align-items:stretch!important;flex-direction:column!important;gap:10px!important}.dev-hd-actions{flex-wrap:wrap}.dev-hd-title h1{font-size:15px}.dev-hd-sub{font-size:11px;overflow-wrap:anywhere;word-break:break-word}.dev-hd-meta{text-align:left;font-size:10.5px;min-width:0;max-width:100%}.dev-hd-meta dd,.dev-hd-meta dt{white-space:normal;overflow-wrap:anywhere}.ro-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px 10px;padding:10px 12px}.ro-row .ro-label{flex:1 1 auto;min-width:0}.ro-row>select{order:10;flex:1 1 100%;min-width:0}.di-grid,.ro-grid{grid-template-columns:1fr}.switch{width:50px;height:30px;flex-shrink:0}.switch i{width:24px;height:24px;top:2px;left:2px}.switch.on i{transform:translateX(20px)}.events-row{font-size:10.5px;padding:6px 10px;grid-template-columns:auto auto minmax(0,1fr);gap:8px}.events-row .actor,.events-row .dur{display:none}.events-foot{font-size:10.5px}.login-card{margin:12px;padding:24px 18px}.main{padding:12px 12px 20px}}.app{height:100dvh}.app,.login{padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}.login{min-height:100dvh}@media (max-width:768px){input,select,textarea{font-size:16px}}.resolver-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;min-height:60vh;color:var(--fg-2);text-align:center;padding:24px}.resolver-msg{max-width:360px}.resolver-grid{max-width:720px;margin:48px auto;padding:0 16px}.resolver-h1{font-size:22px;font-weight:600;letter-spacing:-.01em;margin-bottom:4px}.resolver-sub{color:var(--fg-3);font-size:13px;margin-bottom:24px}.resolver-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}.resolver-card{display:flex;align-items:center;gap:12px;padding:16px;border:1px solid var(--border);border-radius:8px;background:var(--bg-2);text-decoration:none;color:var(--fg);transition:border-color .15s,transform .15s}.resolver-card:hover{border-color:var(--accent);transform:translateY(-1px)}.resolver-card-icon{width:36px;height:36px;display:grid;place-items:center;border-radius:6px;background:var(--bg-3);color:var(--accent);flex-shrink:0}.resolver-card-title{font-weight:600;font-size:14px;margin-bottom:2px}.resolver-card-meta{color:var(--fg-3);font-size:12px}.activity-filters{gap:16px;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--bg-2)}.activity-filter-group,.activity-filters{display:flex;flex-wrap:wrap;align-items:center}.activity-filter-group{gap:6px}.activity-filter-label{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--fg-3);margin-right:4px}.chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;font-size:11px;font-weight:500;background:transparent;border:1px solid var(--border);border-radius:999px;color:var(--fg-2);cursor:pointer;transition:border-color .12s,background .12s,color .12s;text-transform:capitalize}.chip:hover{border-color:var(--accent);color:var(--fg)}.chip.chip-active{background:var(--accent);border-color:var(--accent);color:var(--bg)}.activity-table-wrap{overflow-x:auto;border-bottom:1px solid var(--border)}.activity-table{width:100%;border-collapse:collapse;font-size:12px}.activity-table thead th{text-align:left;background:var(--bg-2);font-weight:500;color:var(--fg-3);text-transform:uppercase;letter-spacing:.04em;font-size:10px;position:sticky;top:0}.activity-table tbody td,.activity-table thead th{padding:8px 12px;border-bottom:1px solid var(--border)}.activity-table tbody td{vertical-align:middle}.activity-table tbody tr:hover{background:var(--bg-2)}.activity-table .mono{font-family:var(--font-mono)}.activity-footer{display:flex;justify-content:center;padding:16px}@media (max-width:768px){.activity-filters{padding:8px 12px;gap:8px}.activity-filter-group{gap:4px}.activity-filter-label{font-size:10px}.chip{padding:4px 10px}.activity-table,.chip{font-size:11px}.activity-table tbody td,.activity-table thead th{padding:6px 8px}.activity-table tbody td:nth-child(4),.activity-table thead th:nth-child(4){display:none}}.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--fg-2);height:30px;padding:0 12px;font-size:12px;border-radius:6px;display:inline-flex;align-items:center;gap:6px;cursor:pointer;transition:border-color .12s,background .12s}.btn-ghost:hover{border-color:var(--accent)}.btn-ghost:disabled{opacity:.5;cursor:wait}@keyframes vfdFlashOk{0%,55%{background:var(--status-on);border-color:var(--status-on);color:var(--bg)}}@keyframes vfdFlashErr{0%,55%{background:var(--status-err);border-color:var(--status-err);color:#fff}}.vfd-flash-err,.vfd-flash-ok{animation-duration:1.2s;animation-timing-function:ease-out}.vfd-flash-ok{animation-name:vfdFlashOk}.vfd-flash-err{animation-name:vfdFlashErr}.vfd-diag{border-top:1px solid var(--border);padding:8px 0 0;margin:8px 0}.vfd-diag-toggle{background:transparent;border:0;color:var(--fg-3);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.06em;cursor:pointer;padding:4px 0;display:inline-flex;align-items:center;gap:6px}.vfd-diag-toggle:hover{color:var(--fg-2)}.vfd-diag-arrow{font-size:10px;width:8px;display:inline-block}.vfd-diag-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;padding:8px 0 4px}.vfd-diag-cell{display:flex;flex-direction:column;gap:2px}.vfd-diag-label{font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--fg-3)}.vfd-diag-value{font-family:var(--font-mono);font-size:13px;font-weight:500;color:var(--fg-2)}.vfd-diag-unit{margin-left:3px;font-size:11px;color:var(--fg-3)}.vfd-diag-text{font-family:var(--font);font-size:12px}.schedules-list{display:flex;flex-direction:column;gap:8px;padding:16px}.schedule-row{display:grid;grid-template-columns:minmax(200px,1.4fr) minmax(140px,1fr) minmax(180px,1fr) auto;gap:16px;align-items:center;padding:14px 16px;border:1px solid var(--border-strong);border-radius:8px;background:var(--bg-card-2);transition:border-color .12s,background .12s}.schedule-row:hover{border-color:var(--accent-soft);background:var(--bg-hover)}.schedule-row-main{display:flex;flex-direction:column;gap:2px;min-width:0}.schedule-row-name{font-weight:600;font-size:14px;color:var(--fg)}.schedule-row-target{font-family:var(--font-mono);font-size:11px;color:var(--fg-3);margin-top:2px}.schedule-row-time{display:flex;flex-direction:column;gap:2px}.schedule-row-state .badge{white-space:nowrap}.schedule-row-actions{display:flex;align-items:center;gap:8px}@media (max-width:640px){.schedule-row{grid-template-columns:1fr;gap:8px}}.schedule-modal h4{margin:0 0 12px;font-size:16px}.schedule-form{gap:14px}.schedule-field,.schedule-form{display:flex;flex-direction:column}.schedule-field{gap:4px}.schedule-row-times{display:grid;grid-template-columns:1fr 1fr;gap:12px}.timer-slots{display:flex;flex-direction:column;gap:8px}.timer-slot{display:flex;align-items:center;gap:6px;padding:6px 8px;background:var(--bg-card-2);border:1px solid var(--border);border-radius:6px}.timer-slot .input{flex:0 1 auto}.timer-slot-arrow{color:var(--fg-3);font-family:var(--font-mono);font-size:12px}.timer-add{align-self:flex-start;margin-top:4px}.topbar-clock{display:inline-flex;align-items:center;gap:6px;padding:0 10px;height:26px;border-radius:6px;border:1px solid var(--border);background:var(--bg-card-2);font-family:var(--font-mono);white-space:nowrap;line-height:1}.topbar-clock-date{color:var(--fg-3);font-size:11px;text-transform:capitalize;line-height:1}.topbar-clock-time{color:var(--fg);font-size:12px;font-weight:600;font-variant-numeric:tabular-nums;line-height:1}@media (max-width:640px){.topbar-clock-date{display:none}}.hover\:border-neutral-600:hover{--tw-border-opacity:1;border-color:rgb(82 82 82/var(--tw-border-opacity,1))}.hover\:border-neutral-700:hover{--tw-border-opacity:1;border-color:rgb(64 64 64/var(--tw-border-opacity,1))}.disabled\:opacity-50:disabled{opacity:.5}@media (min-width:640px){.sm\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.sm\:grid-cols-8{grid-template-columns:repeat(8,minmax(0,1fr))}}