:root{color-scheme:dark;--bg: #0d0f14;--panel: #12151c;--card: #161a23;--card-2: #1b2029;--border: #232936;--text: #e7e9ee;--muted: #8b93a4;--accent: #7c8cff;--accent-700: #5b6bf0;--ok: #34d399;--warn: #f59e0b;--radius: 14px;--font: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif}*{box-sizing:border-box}html,body{height:100%}body{margin:0;background:radial-gradient(1200px 600px at 80% -10%,#1a1f2e 0%,var(--bg) 55%);color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased}#app,.shell{height:100%}.shell{display:flex}.sidebar{width:248px;flex:0 0 248px;height:100vh;position:sticky;top:0;display:flex;flex-direction:column;gap:8px;padding:20px 14px;border-right:1px solid var(--border);background:linear-gradient(180deg,var(--panel),#0f1219)}.brand{display:flex;align-items:center;gap:10px;padding:6px 10px 14px}.brand-mark{font-size:22px}.brand-name{font-size:20px;font-weight:700;letter-spacing:.2px}.brand-name:after{content:""}.nav{display:flex;flex-direction:column;gap:4px}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border:0;border-radius:10px;background:transparent;color:var(--muted);font:inherit;font-size:14.5px;cursor:pointer;text-align:left;transition:background .15s,color .15s}.nav-item:hover{background:#ffffff0a;color:var(--text)}.nav-item.active{background:linear-gradient(90deg,#7c8cff22,#7c8cff10);color:var(--text);box-shadow:inset 2px 0 0 var(--accent)}.nav-icon{width:20px;height:20px;display:grid;place-items:center}.nav-icon svg{width:18px;height:18px}.conn{margin-top:auto;padding:12px;border:1px solid var(--border);border-radius:12px;background:var(--card)}.conn-row{display:flex;align-items:center;gap:8px;margin-bottom:10px}.conn-dot{width:9px;height:9px;border-radius:50%;background:#3a4150;box-shadow:0 0 0 3px #3a415022}.conn-dot.on{background:var(--ok);box-shadow:0 0 0 3px #34d39933}.conn-text{font-size:13px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conn-note{margin:8px 0 0;font-size:11.5px;color:var(--muted)}.content{flex:1;min-width:0;height:100vh;overflow-y:auto}.page{max-width:820px;margin:0 auto;padding:32px 28px 64px}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px 22px;margin-bottom:18px}.card h2{margin:0 0 14px;font-size:16px;font-weight:600}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}@media(max-width:760px){.grid-2{grid-template-columns:1fr}.sidebar{width:200px;flex-basis:200px}}.muted{color:var(--muted)}.small{font-size:12.5px}.btn{font:inherit;font-size:14px;padding:9px 14px;border-radius:10px;border:1px solid var(--border);background:var(--card-2);color:var(--text);cursor:pointer;transition:background .15s,border-color .15s,transform .05s}.btn:hover{background:#232a36}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:default}.btn.primary{background:var(--accent);border-color:var(--accent);color:#0c0e14;font-weight:600}.btn.primary:hover{background:var(--accent-700);border-color:var(--accent-700)}.btn.ghost{background:transparent}.btn.block{width:100%}a.btn{text-decoration:none;display:inline-block}.actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}.inline-status{margin-top:10px;font-size:13px;min-height:1em}.field{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:9px 0;border-bottom:1px solid var(--border)}.field:last-of-type{border-bottom:0}.field label{display:flex;flex-direction:column;gap:2px}.field label span{font-size:14px}.field label small{color:var(--muted);font-size:12px}.field input[type=number]{width:8rem;padding:8px 10px;border-radius:8px;border:1px solid var(--border);background:#0e1117;color:var(--text);text-align:right;font:inherit}.field input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent)}.live-row{display:flex;align-items:center;gap:10px;padding:5px 0}.live-row .name{width:9.5rem;color:var(--muted);font-size:12.5px}.live-row .val{width:3.6rem;text-align:right;font-variant-numeric:tabular-nums;font-size:13px}.live-bar{flex:1;height:10px;background:#0e1117;border-radius:6px;overflow:hidden}.live-bar>div{height:100%;width:0;background:var(--accent);transition:width .08s linear}.pad{display:block;margin:0 auto}.cal-rows{display:flex;flex-direction:column;gap:4px;margin:6px 0 2px}.cal-row{display:flex;align-items:center;gap:8px;padding:7px 10px;background:var(--card-2);border:1px solid var(--border);border-radius:8px}.cal-row .name{flex:1;font-size:13px}.cal-row .val{width:3.4rem;text-align:right;font-variant-numeric:tabular-nums;font-size:13px}.empty{text-align:center;padding:40px 24px}.empty-icon{font-size:34px;margin-bottom:6px}.empty h2{margin:6px 0}.fw-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:6px}.fw-cell{background:var(--card-2);border:1px solid var(--border);border-radius:10px;padding:12px 14px}.fw-ver{font-size:20px;font-weight:700;font-variant-numeric:tabular-nums;margin-top:4px}.pill{display:inline-block;margin-top:6px;padding:3px 10px;border-radius:999px;font-size:12.5px;font-weight:600}.pill.ok{background:#34d39922;color:var(--ok)}.pill.warn{background:#f59e0b22;color:var(--warn)}.pill.muted{background:#ffffff10;color:var(--muted)}.note-box{background:var(--card-2);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:8px;padding:11px 14px;margin-bottom:12px;font-size:13.5px;line-height:1.55}.steps{margin:6px 0;padding-left:18px;line-height:1.9}.prog{margin-top:12px}.prog-track{height:10px;background:#0e1117;border:1px solid var(--border);border-radius:6px;overflow:hidden}.prog-track>div{height:100%;width:0;background:var(--accent);transition:width .12s linear}.ota-help{margin-top:14px;line-height:1.6}.conn-method{background:var(--card-2);border:1px solid var(--border);border-radius:10px;padding:14px 16px}.conn-method h3{margin:0 0 6px;font-size:13px;color:var(--accent);font-weight:600}.conn-method .steps{margin:0 0 12px;padding-left:18px;line-height:1.7;font-size:13.5px}.conn-method .actions{margin-top:0}.steps code,.prose code{background:#0e1117;border:1px solid var(--border);border-radius:5px;padding:1px 6px;font-size:12.5px}.led{display:inline-block;width:14px;height:14px;border-radius:50%;vertical-align:middle;margin-right:9px;flex:0 0 auto;background:currentColor;box-shadow:0 0 7px currentColor,0 0 2px currentColor}.led.green{color:#22c55e}.led.blue{color:#3b82f6}.led.white{color:#e8eaf0}.led.yellow{color:#eab308}.led.red{color:#ef4444}.led.purple{color:#a855f7}.led.solid{opacity:1}.led.breathe{animation:led-breathe 2.6s ease-in-out infinite}.led.blink{animation:led-blink 1.6s infinite}.led.fast{animation:led-fast .26s steps(1) infinite}.led.pulse{animation:led-breathe 1.7s ease-in-out infinite}.led.alt-bw{animation:led-alt-bw .8s steps(1) infinite}.led.alt-gw{animation:led-alt-gw .8s steps(1) infinite}@keyframes led-breathe{0%,to{opacity:.12}50%{opacity:1}}@keyframes led-blink{0%{opacity:1}9%{opacity:1}10%{opacity:.1}to{opacity:.1}}@keyframes led-fast{0%{opacity:1}50%{opacity:.12}to{opacity:.12}}@keyframes led-alt-bw{0%,49%{color:#3b82f6}50%,to{color:#e8eaf0}}@keyframes led-alt-gw{0%,49%{color:#22c55e}50%,to{color:#e8eaf0}}.led-row{display:flex;align-items:flex-start;gap:2px}.prose td .led{margin-top:2px}@media(prefers-reduced-motion:reduce){.led.heartbeat,.led.breathe,.led.blink,.led.fast,.led.pulse{animation:none;opacity:.9}}.prose{line-height:1.6}.prose h1{font-size:26px;margin:0 0 6px}.prose .lead{color:var(--muted);font-size:15px;margin-top:0}.prose h2{font-size:17px;margin:26px 0 10px;padding-bottom:6px;border-bottom:1px solid var(--border)}.prose ul,.prose ol{padding-left:20px;line-height:1.7}.prose table{width:100%;border-collapse:collapse;margin:8px 0}.prose th,.prose td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--border);font-size:14px}.prose th{color:var(--muted);font-weight:600;font-size:12.5px;text-transform:uppercase;letter-spacing:.3px}.prose .callout{background:var(--card);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:8px;padding:10px 14px;font-size:14px}.prose .dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:6px;vertical-align:middle}
