@import "https://fonts.googleapis.com/css2?family=Geist:wght@100..900&family=JetBrains+Mono:ital,wght@0,100..800;1,100..800&display=swap";:root{--accent-h:38;--accent-c:.205;--accent-l:63%;--accent:oklch(var(--accent-l) var(--accent-c) var(--accent-h));--accent-glow:oklch(var(--accent-l) var(--accent-c) var(--accent-h) / .45);--accent-soft:oklch(var(--accent-l) var(--accent-c) var(--accent-h) / .12);--accent-line:oklch(var(--accent-l) var(--accent-c) var(--accent-h) / .3);--row-pad:12px;--gap-lg:22px;--gap-md:14px;--line-soft:oklch(100% 0 0/.06);--line:oklch(100% 0 0/.1);--line-strong:oklch(100% 0 0/.18);--bg1:oklch(7% 0 0);--bg2:oklch(11% 0 0);--bg3:oklch(15% 0 0);--bg-rack:linear-gradient(180deg, #1c1c1c, #0a0a0a);--fg1:oklch(98% 0 0);--fg2:oklch(78% 0 0);--fg3:oklch(56% 0 0);--spark:oklch(78% .13 218);--spark-soft:oklch(78% .13 218/.12);--spark-line:oklch(78% .13 218/.3);--success:oklch(70% .18 145);--warning:oklch(80% .165 85);--danger:oklch(58% .235 25);--radius-sm:4px;--radius-md:6px;--radius-lg:12px;--sidebar-w:244px;--font-sans:"Geist", "Inter", system-ui, sans-serif;--font-mono:"JetBrains Mono", "SF Mono", monospace;--glow-mult:1;--body-grad:radial-gradient(70% 50% at 0% 0%, oklch(15% .06 38/.18), transparent 60%), radial-gradient(60% 50% at 100% 100%, oklch(15% .06 220/.16), transparent 60%)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0}body{background:var(--body-grad,none), var(--bg1);color:var(--fg1);font-family:var(--font-sans);font-feature-settings:"ss01", "cv11";min-height:100vh;overflow:hidden}.mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.muted{color:var(--fg3)}.overline{letter-spacing:.14em;text-transform:uppercase;color:var(--fg3);font-family:JetBrains Mono,monospace;font-size:9.5px}.overline-accent{letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-family:JetBrains Mono,monospace;font-size:9.5px}.overline-spark{letter-spacing:.14em;text-transform:uppercase;color:var(--spark);font-family:JetBrains Mono,monospace;font-size:9.5px}.app{grid-template-columns:var(--sidebar-w) 1fr;width:100vw;height:100vh;display:grid;overflow:hidden}.sidebar{border-right:1px solid var(--line-soft);background:linear-gradient(oklch(9% .005 50),oklch(7% .003 50));flex-direction:column;gap:16px;padding:14px 10px;display:flex;position:relative;overflow:hidden}.sidebar:after{content:"";background:linear-gradient(180deg, transparent, var(--accent-line), var(--spark-line), transparent);width:1px;position:absolute;top:0;bottom:0;right:0}.brand{border-bottom:1px solid var(--line-soft);align-items:center;gap:12px;padding:4px 8px 14px;display:flex}.brand-mark{background:radial-gradient(circle at 50% 35%, oklch(20% .06 var(--accent-h)), oklch(8% .02 var(--accent-h)));border:1px solid var(--accent-line);width:34px;height:34px;box-shadow:0 0 14px var(--accent-glow), inset 0 1px 0 #ffffff0f;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative}.brand-mark:after{content:"";background:radial-gradient(circle at 50% 100%, var(--accent), transparent 60%), linear-gradient(180deg, transparent 50%, var(--accent) 100%);filter:blur(.5px);opacity:.85;border-radius:50%/60% 60% 40% 40%;position:absolute;inset:5px}.brand-text{flex-direction:column;gap:2px;min-width:0;display:flex}.brand-name{letter-spacing:-.025em;color:var(--fg1);font-size:16px;font-weight:700;line-height:1}.brand-name .accent{background:linear-gradient(180deg, oklch(75% .18 var(--accent-h)) 0%, var(--accent) 100%);color:#0000;-webkit-background-clip:text;background-clip:text}.brand-sub{color:var(--spark);letter-spacing:.1em;text-transform:uppercase;font-family:JetBrains Mono,monospace;font-size:9.5px}.rail-section{flex-direction:column;gap:2px;display:flex}.rail-label{letter-spacing:.14em;text-transform:uppercase;color:var(--fg3);padding:6px 10px 4px;font-family:JetBrains Mono,monospace;font-size:9px}.nav-item{color:var(--fg2);cursor:pointer;text-align:left;background:0 0;border:0;border-radius:6px;align-items:center;gap:10px;padding:7px 10px;font-family:inherit;font-size:13px;font-weight:500;transition:background .1s,color .1s;display:flex;position:relative}.nav-item:hover{color:var(--fg1);background:#ffffff0a}.nav-item.active{background:linear-gradient(90deg, var(--accent-soft), transparent);color:oklch(72% .165 var(--accent-h));box-shadow:inset 2px 0 0 var(--accent)}.nav-item.active svg{color:oklch(72% .165 var(--accent-h))}.nav-label{flex:1}.nav-badge{background:var(--accent);color:oklch(7% 0 0);letter-spacing:.04em;border-radius:3px;padding:1px 5px;font-family:JetBrains Mono,monospace;font-size:9.5px;font-weight:700}.nav-kbd{color:var(--fg3);border:1px solid var(--line-soft);background:#ffffff0d;border-radius:3px;padding:1px 5px;font-family:JetBrains Mono,monospace;font-size:9.5px}.batch-row{align-items:center;gap:8px;padding:5px 10px;font-size:12px;display:flex}.batch-dot{border-radius:999px;flex-shrink:0;width:6px;height:6px}.dot-accent{background:var(--accent);box-shadow:0 0 6px var(--accent);animation:1.6s cubic-bezier(.4,0,.2,1) infinite pulse}.dot-spark{background:var(--spark);box-shadow:0 0 6px var(--spark)}.dot-warn{background:var(--warning);box-shadow:0 0 6px var(--warning)}.dot-success{background:var(--success);box-shadow:0 0 6px var(--success)}.dot-off{background:var(--fg3)}.batch-name{color:var(--fg2);text-overflow:ellipsis;white-space:nowrap;flex:1;font-family:JetBrains Mono,monospace;font-size:11px;overflow:hidden}.batch-pct{font-variant-numeric:tabular-nums;color:var(--fg3);font-family:JetBrains Mono,monospace;font-size:10px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.rail-foot{border-top:1px solid var(--line-soft);margin-top:auto;padding-top:10px}.user{align-items:center;gap:10px;padding:6px;display:flex}.avatar{background:linear-gradient(135deg, var(--accent), oklch(40% .16 var(--accent-h)));color:oklch(7% 0 0);width:30px;height:30px;box-shadow:0 0 10px var(--accent-glow);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:700;display:flex}.user-meta{flex:1;min-width:0}.user-name{font-size:12.5px;font-weight:500}.user-org{color:var(--spark);letter-spacing:.06em;font-family:JetBrains Mono,monospace;font-size:9.5px}.main-col{flex-direction:column;min-width:0;height:100vh;display:flex;overflow:hidden}.topbar{border-bottom:1px solid var(--line-soft);background:linear-gradient(oklch(10% .005 50),oklch(8% .003 50));flex-shrink:0;align-items:center;gap:16px;padding:8px 18px;display:flex}.crumbs{color:var(--fg3);letter-spacing:.04em;align-items:center;gap:8px;font-family:JetBrains Mono,monospace;font-size:11px;display:flex}.crumbs .crumb-active{color:var(--fg1)}.crumbs .sep{color:var(--fg3);opacity:.5}.cmd-trigger{background:var(--bg2);border:1px solid var(--line-soft);max-width:460px;color:var(--fg3);cursor:pointer;border-radius:6px;flex:1;align-items:center;gap:8px;margin-left:12px;padding:6px 10px;font-family:inherit;font-size:12.5px;display:flex}.cmd-trigger:hover{border-color:var(--line);color:var(--fg2)}.cmd-trigger span:first-of-type{text-align:left;flex:1}.kbd{color:var(--fg2);background:#ffffff0f;border:1px solid #ffffff1a;border-radius:3px;padding:1px 5px;font-family:JetBrains Mono,monospace;font-size:10px}.topbar-actions{align-items:center;gap:8px;margin-left:auto;display:flex}.btn{letter-spacing:-.005em;white-space:nowrap;cursor:pointer;height:30px;color:var(--fg1);border:1px solid #0000;border-radius:6px;justify-content:center;align-items:center;gap:7px;padding:0 12px;font-family:inherit;font-size:12.5px;font-weight:500;transition:background .1s,border-color .1s,box-shadow .1s,transform 50ms;display:inline-flex}.btn:active{transform:translateY(.5px)}.btn-primary{background:var(--accent);color:oklch(7% 0 0);box-shadow:inset 0 1px 0 #ffffff4d, 0 0 14px var(--accent-glow);font-weight:600}.btn-primary:hover{background:oklch(70% .215 var(--accent-h));box-shadow:inset 0 1px 0 #ffffff4d, 0 0 22px var(--accent-glow)}.btn-ghost{color:var(--fg1);border-color:var(--line-soft);background:#ffffff0a}.btn-ghost:hover{border-color:var(--line);background:#ffffff14}.btn-spark{color:var(--spark);border-color:var(--spark-line);background:#34b8db1a}.btn-spark:hover{background:#34b8db29}.btn-sm{height:26px;padding:0 10px;font-size:11.5px}.btn-danger{color:var(--danger);background:#e44b4b1a;border-color:#e44b4b4d}.icon-btn{width:30px;height:30px;color:var(--fg2);cursor:pointer;background:0 0;border:0;border-radius:6px;justify-content:center;align-items:center;display:inline-flex}.icon-btn:hover{color:var(--fg1);background:#ffffff0f}.workspace{flex-direction:column;flex:1;display:flex;overflow:auto}.workspace.notebook-mode{padding:0}.page-title{letter-spacing:-.025em;margin:0;font-size:26px;font-weight:600;line-height:1.05}.page-sub{color:var(--fg3);max-width:60ch;margin-top:4px;font-size:13px}.chip{letter-spacing:.1em;text-transform:uppercase;color:var(--fg2);border:1px solid var(--line-soft);background:#ffffff0a;border-radius:3px;align-items:center;gap:4px;padding:2px 8px;font-family:JetBrains Mono,monospace;font-size:9.5px;display:inline-flex}.chip-accent{color:oklch(72% .165 var(--accent-h));background:var(--accent-soft);border-color:var(--accent-line)}.chip-spark{color:var(--spark);background:var(--spark-soft);border-color:var(--spark-line)}.chip-warn{color:var(--warning);background:#e8b8281a;border-color:#e8b8284d}.chip-danger{color:var(--danger);background:#e44b4b1a;border-color:#e44b4b4d}.chip-success{color:var(--success);background:#2ec4661a;border-color:#2ec4664d}.panel{background:var(--bg2);border:1px solid var(--line-soft);border-radius:12px;padding:18px 20px;box-shadow:inset 0 1px #ffffff0a}.panel-accent{background:radial-gradient(80% 60% at 100% 0%, var(--accent-soft), transparent 65%), linear-gradient(135deg, oklch(13% .04 var(--accent-h)), oklch(10% .02 var(--accent-h)) 50%, oklch(11% .04 220));border-color:var(--accent-line)}.panel-title{letter-spacing:-.015em;margin:0;font-size:17px;font-weight:600}.input{background:var(--bg2);width:100%;height:32px;color:var(--fg1);border:1px solid var(--line-soft);border-radius:6px;outline:none;padding:0 10px;font-family:inherit;font-size:13px;transition:border-color .1s,box-shadow .1s}.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.input::placeholder{color:var(--fg3)}textarea.input{resize:vertical;height:auto;padding:8px 10px}.led-row{letter-spacing:.1em;color:var(--fg2);text-transform:uppercase;align-items:center;gap:6px;font-family:JetBrains Mono,monospace;font-size:10px;display:inline-flex}.led{border-radius:999px;width:7px;height:7px}.led-on{animation:2s cubic-bezier(.4,0,.2,1) infinite pulse}.led-accent{background:var(--accent);box-shadow:0 0 6px var(--accent), inset 0 0 1px #ffffff80}.led-spark{background:var(--spark);box-shadow:0 0 6px var(--spark), inset 0 0 1px #ffffff80}.led-success{background:var(--success);box-shadow:0 0 6px var(--success), inset 0 0 1px #ffffff80}.led-warn{background:var(--warning);box-shadow:0 0 6px var(--warning), inset 0 0 1px #ffffff80}.led-rec{background:var(--danger);box-shadow:0 0 6px var(--danger), inset 0 0 1px #ffffff80}.led-off{background:oklch(26% 0 0)}.knob{-webkit-user-select:none;user-select:none;flex-direction:column;align-items:center;gap:8px;display:flex}.knob-arc{background:conic-gradient(from -135deg, var(--accent) 0deg, var(--accent) calc(var(--angle,0deg) + 135deg), #ffffff14 calc(var(--angle,0deg) + 135deg), #ffffff14 270deg, transparent 270deg);width:64px;height:64px;box-shadow:0 0 14px var(--accent-glow);border-radius:50%;padding:3px;position:relative}.knob-arc.spark{background:conic-gradient(from -135deg, var(--spark) 0deg, var(--spark) calc(var(--angle,0deg) + 135deg), #ffffff14 calc(var(--angle,0deg) + 135deg), #ffffff14 270deg, transparent 270deg);box-shadow:0 0 14px oklch(78% .13 218/.4)}.knob-dial{background:radial-gradient(circle at 50% 30%,#2c2c2c 0%,#181818 60%,#0a0a0a 100%);border:1px solid #ffffff0f;border-radius:50%;width:100%;height:100%;position:relative;box-shadow:inset 0 1px #ffffff1a,inset 0 -1px #0009,0 2px 6px #0009}.knob-indicator{background:var(--accent);width:2px;height:12px;box-shadow:0 0 8px var(--accent);transform-origin:50% 24px;border-radius:1px;position:absolute;top:6px;left:50%}.knob-arc.spark .knob-indicator{background:var(--spark);box-shadow:0 0 8px var(--spark)}.knob-label{letter-spacing:.1em;color:var(--fg3);text-transform:uppercase;font-family:JetBrains Mono,monospace;font-size:8.5px}.knob-val{color:var(--fg1);font-family:JetBrains Mono,monospace;font-size:12px;font-weight:500}.knob-val .unit{color:var(--fg3);margin-left:2px;font-size:9.5px}.notebook{flex:1;grid-template-columns:minmax(0,1fr) 296px;display:grid;overflow:hidden}.notebook-main{flex-direction:column;min-width:0;display:flex;overflow:hidden}.notebook-rail{background:var(--bg2);border-left:1px solid var(--line-soft);flex-direction:column;gap:0;padding:16px 14px;display:flex;overflow-y:auto}.rail-section-block{padding:14px 0}.rail-divider{background:var(--line-soft);flex-shrink:0;height:1px}.nb-header{border-bottom:1px solid var(--line-soft);flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:flex-start;gap:20px;padding:18px 24px 14px;display:flex}.nb-header__left{flex-direction:column;gap:4px;min-width:0;display:flex}.nb-header__right{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:8px;padding-top:2px;display:flex}.nb-cells{flex-direction:column;flex:1;gap:10px;padding:18px 24px 16px;display:flex;overflow-y:auto}.nb-cell{border:1px solid var(--line-soft);background:var(--bg2);border-radius:10px;grid-template-columns:40px 1fr;display:grid;position:relative;overflow:hidden;box-shadow:inset 0 1px #ffffff08}.nb-cell--prompt{background:linear-gradient(175deg, oklch(13% .03 var(--accent-h)), oklch(10% .02 var(--accent-h)) 80%);border-color:var(--accent-line)}.nb-cell--ai{border-color:var(--spark-line);background:linear-gradient(175deg,oklch(11% .02 218),oklch(9% .01 218) 80%)}.nb-cell--recipe{border-color:var(--line)}.nb-cell--safety{background:#e8b8280a;border-color:#e8b82847}.nb-cell__gutter{border-right:1px solid var(--line-soft);color:var(--fg3);background:#0000002e;flex-direction:column;align-items:center;gap:8px;padding:12px 0;font-family:JetBrains Mono,monospace;font-size:9.5px;display:flex}.nb-cell__num{font-weight:700}.nb-cell--prompt .nb-cell__gutter{color:oklch(72% .165 var(--accent-h));border-right-color:var(--accent-line)}.nb-cell--ai .nb-cell__gutter{color:var(--spark);border-right-color:var(--spark-line)}.nb-cell--safety .nb-cell__gutter{color:var(--warning);border-right-color:#e8b82847}.nb-cell__body{flex-direction:column;gap:10px;min-width:0;padding:12px 16px 14px;display:flex;position:relative}.nb-cell__tag{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.nb-kind{letter-spacing:.14em;text-transform:uppercase;color:var(--fg3);font-family:JetBrains Mono,monospace;font-size:9px}.nb-cell__title{color:var(--fg1);letter-spacing:-.01em;font-size:13.5px;font-weight:600}.nb-tag{letter-spacing:.1em;text-transform:uppercase;border:1px solid;border-radius:3px;padding:2px 7px;font-family:JetBrains Mono,monospace;font-size:9px}.nb-tag--you{color:oklch(72% .165 var(--accent-h));background:var(--accent-soft);border-color:var(--accent-line)}.nb-tag--ai{color:var(--spark);background:var(--spark-soft);border-color:var(--spark-line)}.nb-tag--draft{color:var(--fg2);border-color:var(--line-soft);background:#ffffff0a}.nb-tag--warn{color:var(--warning);background:#e8b8281a;border-color:#e8b8284d}.nb-cell__text{color:var(--fg1);margin:0;font-size:13.5px;line-height:1.6}.nb-cell__text strong{font-weight:600}.nb-cell__text code{color:var(--spark);background:#0006;border-radius:3px;padding:1px 5px;font-family:JetBrains Mono,monospace;font-size:12px}.nb-cell__actions{opacity:0;gap:4px;transition:opacity .12s;display:flex;position:absolute;top:10px;right:10px}.nb-cell:hover .nb-cell__actions{opacity:1}.nb-cell__btns{flex-wrap:wrap;gap:6px;display:flex}.nb-cell__footer{border-top:1px dashed var(--line-soft);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;padding-top:10px;display:flex}.param-grid{border:1px solid var(--line-soft);background:#0000004d;border-radius:8px;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:6px 14px;padding:10px 12px;display:grid}.param{flex-direction:column;gap:2px;display:flex}.param-k{letter-spacing:.1em;color:var(--fg3);text-transform:uppercase;font-family:JetBrains Mono,monospace;font-size:9px}.param-v{color:var(--fg1);font-family:JetBrains Mono,monospace;font-size:12.5px;font-weight:500}.param-v.accent{color:oklch(72% .165 var(--accent-h))}.param-v.spark{color:var(--spark)}.nb-add{border:1px dashed var(--line-soft);background:#ffffff03;border-radius:10px;align-items:center;gap:10px;padding:9px 14px;display:flex}.nb-add__label{letter-spacing:.12em;text-transform:uppercase;color:var(--fg3);flex-shrink:0;font-family:JetBrains Mono,monospace;font-size:9.5px}.nb-add__btns{flex-wrap:wrap;gap:6px;display:flex}.nb-add button{color:var(--fg2);border:1px solid var(--line-soft);cursor:pointer;letter-spacing:.08em;text-transform:uppercase;background:#ffffff0a;border-radius:5px;align-items:center;gap:5px;padding:4px 10px;font-family:JetBrains Mono,monospace;font-size:10px;display:inline-flex}.nb-add button:hover{color:var(--fg1);border-color:var(--line);background:#ffffff12}.nb-compose{border:1px solid var(--accent-line);box-shadow:0 8px 28px #0000008c, 0 0 20px var(--accent-glow), inset 0 1px 0 #ffffff0f;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:oklch(8% 0 0/.94);border-radius:12px;flex-direction:column;flex-shrink:0;gap:10px;margin:0 24px 20px;padding:12px 14px 10px;display:flex}.nb-compose__meta{color:var(--fg3);letter-spacing:.1em;text-transform:uppercase;align-items:center;gap:6px;font-family:JetBrains Mono,monospace;font-size:9.5px;display:flex}.nb-compose__mode{color:var(--spark)}.nb-compose__input{width:100%;color:var(--fg1);resize:none;background:0 0;border:0;outline:0;min-height:22px;max-height:120px;font-family:inherit;font-size:14px;line-height:1.55}.nb-compose__input::placeholder{color:var(--fg3)}.nb-compose__footer{border-top:1px solid var(--line-soft);justify-content:flex-end;align-items:center;gap:6px;padding-top:8px;display:flex}.nb-outline{flex-direction:column;gap:0;display:flex}.nb-outline__row{color:var(--fg2);cursor:pointer;border-radius:4px;grid-template-columns:28px 14px 1fr;align-items:center;gap:6px;padding:5px 0;font-family:JetBrains Mono,monospace;font-size:10.5px;display:grid}.nb-outline__row:hover{color:var(--fg1)}.nb-outline__row--warn{color:var(--warning)}.nb-outline__num{color:var(--fg3);font-size:9.5px}.nb-outline__label{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.nb-state-grid{grid-template-columns:repeat(2,1fr);justify-items:center;gap:14px 8px;display:grid}.nb-session{flex-direction:column;gap:6px;display:flex}.nb-session__row{color:var(--fg3);letter-spacing:.04em;justify-content:space-between;gap:8px;font-family:JetBrains Mono,monospace;font-size:10px;display:flex}.nb-session__k{text-transform:uppercase;letter-spacing:.1em;font-size:9px}.nb-session__v{color:var(--fg2);text-align:right}.brew-run{flex:1;grid-template-columns:minmax(0,1fr) 360px;gap:18px;padding:18px 24px 24px;display:grid;overflow:hidden}.brew-main,.brew-side{flex-direction:column;gap:14px;padding-right:4px;display:flex;overflow-y:auto}.hero-rack{background:var(--bg-rack);border:1px solid var(--line);border-radius:14px;flex-direction:column;gap:14px;padding:18px 22px;display:flex;position:relative;overflow:hidden;box-shadow:0 12px 32px #0009,inset 0 1px #ffffff14}.hero-rack:before{content:"";pointer-events:none;mix-blend-mode:overlay;background-image:repeating-linear-gradient(0deg,#ffffff05 0 1px,#0000 1px 3px);position:absolute;inset:0}.rack-head{border-bottom:1px dashed #ffffff14;justify-content:space-between;align-items:center;gap:18px;padding-bottom:12px;display:flex;position:relative}.rack-title-block{flex-direction:column;gap:6px;min-width:0;display:flex}.rack-title{letter-spacing:-.02em;margin:0;font-size:22px;font-weight:600;line-height:1}.rack-tags{flex-wrap:wrap;gap:6px;display:flex}.rack-readout{align-items:baseline;gap:14px;display:flex}.readout-grp{flex-direction:column;align-items:flex-end;gap:2px;display:flex}.readout-grp .lbl{letter-spacing:.12em;color:var(--fg3);text-transform:uppercase;font-family:JetBrains Mono,monospace;font-size:9px}.readout-grp .val{color:var(--accent);font-variant-numeric:tabular-nums;font-family:JetBrains Mono,monospace;font-size:22px;font-weight:600;line-height:1}.readout-grp.spark .val{color:var(--spark)}.timeline{flex-direction:column;gap:8px;display:flex;position:relative}.timeline-track{border:1px solid var(--line-soft);background:#0006;border-radius:6px;height:76px;position:relative;overflow:hidden}.timeline-bars{align-items:stretch;gap:1px;display:flex;position:absolute;inset:6px}.tl-bar{background:#ffffff0d;border-radius:1px;flex:1}.tl-bar.past{background:linear-gradient(180deg, oklch(78% .18 var(--accent-h)) 0%, var(--accent) 50%, oklch(45% .16 var(--accent-h)) 100%);box-shadow:0 0 3px var(--accent-glow)}.tl-bar.future{background:#ffffff0f}.tl-playhead{background:var(--spark);width:2px;box-shadow:0 0 10px var(--spark);position:absolute;top:-4px;bottom:-4px}.tl-flag{background:var(--spark);color:oklch(7% 0 0);letter-spacing:.04em;white-space:nowrap;border-radius:3px;padding:2px 6px;font-family:JetBrains Mono,monospace;font-size:9px;font-weight:700;position:absolute;top:-22px;transform:translate(-50%)}.timeline-ruler{justify-content:space-between;display:flex}.tl-tick{color:var(--fg3);letter-spacing:.1em;font-family:JetBrains Mono,monospace;font-size:8.5px}.transport{align-items:center;gap:4px;display:flex}.transport-btn{background:var(--bg3);border:1px solid var(--line-soft);width:32px;height:32px;color:var(--fg2);cursor:pointer;border-radius:5px;justify-content:center;align-items:center;display:inline-flex}.transport-btn:hover{color:var(--fg1);background:oklch(20% 0 0)}.transport-btn.is-active{background:var(--accent);border-color:oklch(56% .198 var(--accent-h));color:oklch(7% 0 0);box-shadow:0 0 12px var(--accent-glow)}.transport-btn.is-rec{background:var(--danger);color:var(--fg1);border-color:oklch(45% .2 25);box-shadow:0 0 12px oklch(58% .235 25/.4)}.checkpoint-list{flex-direction:column;gap:0;display:flex}.cp{border-top:1px solid var(--line-soft);grid-template-columns:32px 1fr auto;align-items:center;gap:10px;padding:12px 8px;display:grid}.cp:first-child{border-top:0}.cp-marker{border:1px solid var(--line);width:28px;height:28px;color:var(--fg3);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;font-family:JetBrains Mono,monospace;font-size:11px;display:flex}.cp.done .cp-marker{background:var(--accent);border-color:var(--accent);color:oklch(7% 0 0);box-shadow:0 0 10px var(--accent-glow)}.cp.active .cp-marker{border-color:var(--spark);color:var(--spark);box-shadow:0 0 12px oklch(78% .13 218/.5)}.cp.warn .cp-marker{border-color:var(--warning);color:var(--warning)}.cp-meta{min-width:0}.cp-name{color:var(--fg1);align-items:center;gap:8px;font-size:14px;font-weight:500;display:flex}.cp-sub{color:var(--fg3);letter-spacing:.04em;margin-top:3px;font-family:JetBrains Mono,monospace;font-size:10px}.cp.done .cp-name{color:var(--fg2);text-decoration:line-through;-webkit-text-decoration-color:var(--fg3);text-decoration-color:var(--fg3);text-decoration-thickness:1px}.cp-when{color:var(--fg3);text-align:right;font-family:JetBrains Mono,monospace;font-size:11px}.rack-sensors{border:1px solid var(--line-soft);background:#00000059;border-radius:10px;grid-template-columns:repeat(4,1fr);gap:14px;padding:16px 14px;display:grid}.sensor{flex-direction:column;align-items:center;gap:6px;display:flex}.sensor-meter{background:conic-gradient(from -135deg, var(--success) 0deg, var(--success) calc(var(--angle,0deg) + 135deg), #ffffff0f calc(var(--angle,0deg) + 135deg), #ffffff0f 270deg, transparent 270deg);border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;padding:3px;display:flex}.sensor-meter .knob-dial{width:100%;height:100%}.sensor-meter.warn{background:conic-gradient(from -135deg, var(--warning) 0deg, var(--warning) calc(var(--angle,0deg) + 135deg), #ffffff0f calc(var(--angle,0deg) + 135deg), #ffffff0f 270deg, transparent 270deg)}.sensor-meter.accent{background:conic-gradient(from -135deg, var(--accent) 0deg, var(--accent) calc(var(--angle,0deg) + 135deg), #ffffff0f calc(var(--angle,0deg) + 135deg), #ffffff0f 270deg, transparent 270deg)}.sensor-val{color:var(--fg1);font-family:JetBrains Mono,monospace;font-size:13px;font-weight:600}.sensor-val .unit{color:var(--fg3);margin-left:2px;font-size:9.5px}.sensor-name{letter-spacing:.1em;color:var(--fg3);text-transform:uppercase;font-family:JetBrains Mono,monospace;font-size:9px}.safety-banner{background:linear-gradient(90deg,#e8b8281a,#e8b82805);border:1px solid #e8b8284d;border-radius:10px;grid-template-columns:36px 1fr auto;align-items:center;gap:12px;padding:12px 14px;display:grid}.safety-banner.danger{background:linear-gradient(90deg,#e44b4b1f,#e44b4b05);border-color:#e44b4b66}.safety-icon{width:30px;height:30px;color:var(--warning);background:#e8b82829;border-radius:6px;justify-content:center;align-items:center;display:flex}.safety-banner.danger .safety-icon{color:var(--danger);background:#e44b4b29}.safety-text{color:var(--fg1);font-size:13px}.safety-text strong{font-weight:600}.safety-text .sub{color:var(--fg3);letter-spacing:.04em;margin-top:2px;font-family:JetBrains Mono,monospace;font-size:10px}.library-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;padding:22px 28px;display:grid}.recipe-card{background:var(--bg2);border:1px solid var(--line-soft);cursor:pointer;border-radius:12px;flex-direction:column;transition:border-color .24s,transform .24s,box-shadow .24s;display:flex;position:relative;overflow:hidden}.recipe-card:hover{border-color:var(--line-strong);transform:translateY(-1px);box-shadow:0 8px 24px #0006}.recipe-art{border-bottom:1px solid var(--line-soft);justify-content:center;align-items:center;height:120px;display:flex;position:relative;overflow:hidden}.recipe-art:before{content:"";mix-blend-mode:overlay;background-image:repeating-linear-gradient(0deg,#ffffff05 0 1px,#0000 1px 3px);position:absolute;inset:0}.recipe-body{flex-direction:column;gap:8px;padding:14px 16px;display:flex}.recipe-name{letter-spacing:-.012em;font-size:15px;font-weight:600}.recipe-meta{color:var(--fg3);letter-spacing:.06em;flex-wrap:wrap;gap:10px;font-family:JetBrains Mono,monospace;font-size:10px;display:flex}.recipe-stats{border-top:1px dashed var(--line-soft);gap:14px;margin-top:4px;padding-top:8px;display:flex}.recipe-stat{flex-direction:column;flex:1;gap:1px;display:flex}.recipe-stat .k{color:var(--fg3);letter-spacing:.1em;text-transform:uppercase;font-family:JetBrains Mono,monospace;font-size:8.5px}.recipe-stat .v{color:var(--fg1);font-family:JetBrains Mono,monospace;font-size:13px;font-weight:500}.recipe-stat .v.accent{color:oklch(72% .165 var(--accent-h))}.recipe-badge{color:var(--spark);border:1px solid var(--spark-line);letter-spacing:.1em;text-transform:uppercase;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;border-radius:3px;padding:2px 6px;font-family:JetBrains Mono,monospace;font-size:9px;position:absolute;top:10px;left:10px}.recipe-badge.imported{color:oklch(72% .165 var(--accent-h));border-color:var(--accent-line)}.library-toolbar{border-bottom:1px solid var(--line-soft);flex-wrap:wrap;align-items:center;gap:10px;padding:16px 28px;display:flex}.filter-chip{letter-spacing:.1em;text-transform:uppercase;color:var(--fg2);border:1px solid var(--line-soft);cursor:pointer;background:#ffffff0a;border-radius:4px;padding:5px 11px;font-family:JetBrains Mono,monospace;font-size:10px}.filter-chip:hover{border-color:var(--line);color:var(--fg1)}.filter-chip.is-on{color:oklch(72% .165 var(--accent-h));background:var(--accent-soft);border-color:var(--accent-line)}.safety-list{flex-direction:column;gap:12px;padding:22px 28px;display:flex}.safety-row{background:var(--bg2);border:1px solid var(--line-soft);border-left-width:3px;border-radius:10px;grid-template-columns:44px 1fr 180px;align-items:start;gap:16px;padding:14px 16px;display:grid}.safety-row.lvl-1{border-left-color:var(--success)}.safety-row.lvl-2{border-left-color:var(--warning)}.safety-row.lvl-3{border-left-color:var(--danger)}.safety-row .lvl-mark{border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-family:JetBrains Mono,monospace;font-size:12px;font-weight:700;display:flex}.safety-row.lvl-1 .lvl-mark{color:var(--success);background:#2ec4661f;border:1px solid #2ec4664d}.safety-row.lvl-2 .lvl-mark{color:var(--warning);background:#e8b82824;border:1px solid #e8b8284d}.safety-row.lvl-3 .lvl-mark{color:var(--danger);background:#e44b4b24;border:1px solid #e44b4b4d}.safety-row .text{flex-direction:column;gap:4px;display:flex}.safety-row .name{font-size:14px;font-weight:600}.safety-row .desc{color:var(--fg2);font-size:13px;line-height:1.55}.safety-row .meta{color:var(--fg3);letter-spacing:.06em;text-align:right;flex-direction:column;align-items:flex-end;gap:4px;font-family:JetBrains Mono,monospace;font-size:10px;display:flex}.coach{border:1px solid var(--spark-line);background:linear-gradient(135deg,#34b8db1a,#34b8db05);border-radius:12px;flex-direction:column;gap:10px;padding:14px 16px;display:flex;position:relative}.coach-head{align-items:center;gap:10px;display:flex}.coach-title{color:var(--spark);align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.typing{gap:3px;padding:4px 0;display:inline-flex}.typing span{background:var(--spark);border-radius:999px;width:5px;height:5px;animation:1.2s cubic-bezier(.4,0,.2,1) infinite blink}.typing span:nth-child(2){animation-delay:.2s}.typing span:nth-child(3){animation-delay:.4s}@keyframes blink{0%,80%,to{opacity:.3}40%{opacity:1}}.discover-row{background:var(--bg2);border:1px solid var(--line-soft);cursor:pointer;border-radius:10px;grid-template-columns:80px 1fr auto;align-items:center;gap:14px;padding:14px;display:grid}.discover-row:hover{border-color:var(--line)}.discover-thumb{background:linear-gradient(135deg, oklch(20% .1 var(--accent-h)), oklch(11% .04 220));border:1px solid var(--line-soft);border-radius:8px;justify-content:center;align-items:center;width:80px;height:80px;display:flex}.discover-meta{flex-direction:column;gap:4px;display:flex}.discover-name{font-size:14px;font-weight:600}.discover-source{color:var(--spark);letter-spacing:.06em;font-family:JetBrains Mono,monospace;font-size:10px}.discover-line{color:var(--fg3);font-size:12.5px}.statusbar{border-top:1px solid var(--line-soft);color:var(--fg3);letter-spacing:.06em;white-space:nowrap;background:linear-gradient(oklch(8% .005 50),oklch(6% .003 50));flex-shrink:0;align-items:center;gap:16px;padding:6px 18px;font-family:JetBrains Mono,monospace;font-size:10px;display:flex;overflow:hidden}.statusbar .grp{align-items:center;gap:6px;display:inline-flex}.statusbar .sep{background:var(--line-soft);width:1px;height:12px}.statusbar .acc{color:var(--accent)}.statusbar .sp{color:var(--spark)}.statusbar-right{gap:12px;margin-left:auto;display:inline-flex}.scrim{z-index:100;-webkit-backdrop-filter:blur(8px)saturate(120%);backdrop-filter:blur(8px)saturate(120%);background:oklch(0% 0 0/.65);justify-content:center;align-items:flex-start;padding-top:100px;animation:.24s cubic-bezier(.4,0,.2,1) fade;display:flex;position:fixed;inset:0}@keyframes fade{0%{opacity:0}to{opacity:1}}.palette{background:var(--bg3);border:1px solid var(--line-strong);width:580px;animation:pop .34s linear(0, .142, .491, .842, 1.063, 1.142, 1.114, 1.05, .997, .974, .979, .998, 1.012, 1.015, 1.011, 1.004, .999, .998, 1);border-radius:12px;overflow:hidden;box-shadow:0 24px 64px #000000b3,inset 0 1px #ffffff0f}@keyframes pop{0%{opacity:0;transform:scale(.96)translateY(8px)}to{opacity:1;transform:scale(1)}}.palette-input{border:0;border-bottom:1px solid var(--line-soft);width:100%;height:48px;color:var(--fg1);background:0 0;outline:0;padding:0 16px;font-family:inherit;font-size:14px}.palette-input::placeholder{color:var(--fg3)}.palette-list{max-height:360px;padding:6px;overflow-y:auto}.palette-row{color:var(--fg1);cursor:pointer;border-radius:6px;align-items:center;gap:10px;padding:8px 12px;font-size:13px;display:flex}.palette-row svg{color:var(--fg3)}.palette-row.active{background:var(--accent-soft)}.palette-row.active svg{color:var(--accent)}.palette-row .label{flex:1}.palette-row .group{color:var(--fg3);letter-spacing:.1em;text-transform:uppercase;font-family:JetBrains Mono,monospace;font-size:9.5px}.palette-foot{border-top:1px solid var(--line-soft);background:var(--bg2);color:var(--fg3);letter-spacing:.06em;gap:14px;padding:8px 14px;font-family:JetBrains Mono,monospace;font-size:10px;display:flex}.eb-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;display:grid}.eb-card{background:var(--bg2);border:1px solid var(--line-soft);border-radius:12px;transition:border-color .2s,transform .2s;overflow:hidden}.eb-card:hover{border-color:var(--line-strong);transform:translateY(-1px)}.eb-card-head{border-bottom:1px solid var(--line-soft);padding:16px 18px}.eb-card-body{padding:16px 18px}.eb-step{border-top:1px solid var(--line-soft);grid-template-columns:28px 1fr;gap:10px;padding:10px 0;display:grid}.eb-step:first-child{border-top:0}.eb-step-num{background:var(--accent-soft);width:24px;height:24px;color:oklch(72% .165 var(--accent-h));border:1px solid var(--accent-line);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:700;display:flex}.eb-step-text{color:var(--fg1);font-size:13.5px;line-height:1.55}.eb-step-tip{color:var(--fg3);margin-top:4px;font-family:JetBrains Mono,monospace;font-size:11px;line-height:1.5}.eb-swap-table{border-collapse:collapse;width:100%}.eb-swap-table th{letter-spacing:.12em;text-transform:uppercase;color:var(--fg3);text-align:left;border-bottom:1px solid var(--line);padding:8px 10px;font-family:JetBrains Mono,monospace;font-size:9px}.eb-swap-table td{border-bottom:1px solid var(--line-soft);color:var(--fg2);vertical-align:top;padding:10px;font-size:13px}.eb-swap-table td:first-child{color:var(--fg3);text-decoration:line-through;-webkit-text-decoration-color:var(--fg3);text-decoration-color:var(--fg3);font-size:12px}.eb-swap-table td:nth-child(2){color:var(--fg1);font-weight:500}.auth-page{justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-card{width:100%;max-width:400px}.auth-card .brand{border-bottom:0;justify-content:center;padding-bottom:24px}.auth-card .input{margin-bottom:12px}.auth-card .btn-primary{width:100%;height:36px;margin-top:4px}.auth-toggle{text-align:center;color:var(--fg3);margin-top:16px;font-size:13px}.auth-toggle button{color:var(--accent);cursor:pointer;background:0 0;border:none;font-family:inherit;font-size:13px;font-weight:500}.auth-toggle button:hover{text-decoration:underline}.auth-error{color:var(--danger);background:#e44b4b1a;border:1px solid #e44b4b4d;border-radius:6px;margin-bottom:12px;padding:8px 12px;font-size:12.5px}.admin-page{height:100%;padding:28px 32px;overflow-y:auto}.admin-header{margin-bottom:24px}.admin-tabs{background:var(--bg2);border:1px solid var(--line-soft);border-radius:var(--radius-md);gap:2px;width:fit-content;margin-bottom:24px;padding:4px;display:flex}.admin-tab{border-radius:calc(var(--radius-md) - 2px);color:var(--fg3);cursor:pointer;background:0 0;border:0;align-items:center;gap:7px;padding:7px 16px;font-family:inherit;font-size:13px;font-weight:500;transition:background .1s,color .1s;display:flex}.admin-tab:hover{color:var(--fg2);background:#ffffff08}.admin-tab.active{background:var(--bg3);color:var(--fg1);box-shadow:0 1px 3px #0000004d}.admin-body{max-width:720px}.td{flex-direction:column;gap:20px;display:flex}.td-section{flex-direction:column;gap:10px;display:flex}.td-section-head{color:var(--fg1);align-items:center;gap:8px;padding-bottom:4px;font-size:13px;font-weight:600;display:flex}.td-section-head svg{color:var(--accent)}.td-presets{flex-wrap:wrap;gap:8px;display:flex}.td-preset{background:var(--bg2);border:1px solid var(--line-soft);border-radius:var(--radius-lg);cursor:pointer;text-align:left;min-width:120px;color:var(--fg1);flex-direction:column;gap:6px;padding:12px 14px;font-family:inherit;transition:border-color .15s,transform .15s;display:flex;position:relative}.td-preset:hover{border-color:var(--line-strong);transform:translateY(-1px)}.td-preset.active{border-color:var(--accent-line);background:linear-gradient(135deg, var(--accent-soft), transparent 60%)}.td-preset-swatches{gap:4px;display:flex}.td-preset-dot{border:1px solid #ffffff1a;border-radius:999px;width:14px;height:14px}.td-preset-name{font-size:12.5px;font-weight:600}.td-preset-desc{color:var(--fg3);font-size:10.5px;line-height:1.4}.td-preset-check{color:var(--accent);position:absolute;top:10px;right:10px}.td-delete-btn{width:22px;height:22px;color:var(--fg3);cursor:pointer;background:0 0;border:0;border-radius:4px;justify-content:center;align-items:center;display:flex;position:absolute;top:8px;right:8px}.td-delete-btn:hover{color:var(--danger);background:#e44b4b26}.td-tabs{background:var(--bg2);border:1px solid var(--line-soft);border-radius:var(--radius-md);gap:2px;width:fit-content;padding:3px;display:flex}.td-tab{border-radius:calc(var(--radius-md) - 2px);color:var(--fg3);cursor:pointer;background:0 0;border:0;align-items:center;gap:6px;padding:6px 14px;font-family:inherit;font-size:12px;font-weight:500;transition:background .1s,color .1s;display:flex}.td-tab:hover{color:var(--fg2);background:#ffffff08}.td-tab.active{background:var(--bg3);color:var(--fg1);box-shadow:0 1px 3px #0000004d}.td-controls{flex-direction:column;gap:16px;display:flex}.td-color-group{background:var(--bg2);border:1px solid var(--line-soft);border-radius:var(--radius-lg);flex-direction:column;gap:8px;padding:14px 16px;display:flex}.td-color-head{align-items:center;gap:8px;padding-bottom:4px;display:flex}.td-color-title{color:var(--fg1);font-size:12.5px;font-weight:600}.td-swatch{border:1px solid #ffffff1f;border-radius:5px;flex-shrink:0;width:20px;height:20px}.td-swatch-sm{border:1px solid #ffffff14;border-radius:3px;flex-shrink:0;width:14px;height:14px}.td-slider-row{flex-direction:column;gap:4px;display:flex}.td-slider-head{justify-content:space-between;align-items:center;display:flex}.td-slider-label{color:var(--fg3);font-size:11.5px}.td-slider-val{font-family:var(--font-mono);color:var(--fg2);font-variant-numeric:tabular-nums;font-size:11px}.td-slider-track{align-items:center;gap:8px;display:flex}.td-slider-track input[type=range]{appearance:none;background:var(--bg3);border-radius:2px;outline:none;flex:1;height:4px}.td-slider-track input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--accent);border:2px solid var(--bg1);cursor:pointer;width:14px;height:14px;box-shadow:0 0 8px var(--accent-glow);border-radius:999px}.td-slider-track input[type=range]::-moz-range-thumb{background:var(--accent);border:2px solid var(--bg1);cursor:pointer;width:14px;height:14px;box-shadow:0 0 8px var(--accent-glow);border-radius:999px}.td-density-btns{gap:4px;display:flex}.td-density-btn{background:var(--bg3);border:1px solid var(--line-soft);border-radius:var(--radius-md);color:var(--fg2);cursor:pointer;text-align:center;flex:1;padding:8px 12px;font-family:inherit;font-size:12px;font-weight:500;transition:background .1s,border-color .1s,color .1s}.td-density-btn:hover{border-color:var(--line);color:var(--fg1)}.td-density-btn.active{background:var(--accent-soft);border-color:var(--accent-line);color:oklch(72% .165 var(--accent-h))}.td-font-options{flex-direction:column;gap:4px;display:flex}.td-font-btn{background:var(--bg3);border:1px solid var(--line-soft);border-radius:var(--radius-md);color:var(--fg1);cursor:pointer;text-align:left;flex-direction:column;gap:3px;padding:10px 14px;font-size:13px;font-weight:500;transition:border-color .1s;display:flex}.td-font-btn:hover{border-color:var(--line)}.td-font-btn.active{border-color:var(--accent-line);background:var(--accent-soft)}.td-font-preview{color:var(--fg3);font-size:11px}.td-toggle-row{cursor:pointer;justify-content:space-between;align-items:center;display:flex}.td-toggle-row span{color:var(--fg2);font-size:12px}.td-toggle{background:var(--bg3);border:1px solid var(--line-soft);cursor:pointer;border-radius:10px;width:36px;height:20px;padding:0;transition:background .15s;position:relative}.td-toggle.on{background:var(--accent);border-color:var(--accent)}.td-toggle-thumb{background:var(--fg1);border-radius:999px;width:14px;height:14px;transition:transform .15s;position:absolute;top:2px;left:2px}.td-toggle.on .td-toggle-thumb{transform:translate(16px)}.td-action-bar{border-top:1px solid var(--line-soft);justify-content:flex-end;gap:8px;padding-top:8px;display:flex}.td-save-dialog{background:var(--bg2);border:1px solid var(--accent-line);border-radius:var(--radius-lg);flex-direction:column;gap:10px;padding:14px 16px;display:flex}.td-save-btns{justify-content:flex-end;gap:6px;display:flex}.admin-account{flex-direction:column;gap:16px;display:flex}
