:root{--bg-app:oklch(98.5% .003 240);--bg-surface:oklch(100% 0 0);--bg-sunken:oklch(96.5% .004 240);--bg-elevated:oklch(99% .003 240);--bg-hover:oklch(95.5% .006 240);--bg-active:oklch(93% .008 240);--line-soft:oklch(92% .005 240);--line:oklch(88% .006 240);--line-strong:oklch(78% .008 240);--text-primary:oklch(24% .012 250);--text-secondary:oklch(46% .012 250);--text-tertiary:oklch(62% .01 250);--text-muted:oklch(74% .008 250);--text-on-accent:oklch(99% .003 240);--accent:oklch(52% .08 240);--accent-hover:oklch(46% .09 240);--accent-soft:oklch(94% .025 240);--accent-line:oklch(78% .04 240);--status-ok:oklch(58% .08 155);--status-ok-soft:oklch(94% .03 155);--status-warn:oklch(66% .1 75);--status-warn-soft:oklch(95% .04 75);--status-err:oklch(55% .12 25);--status-err-soft:oklch(95% .04 25);--status-info:oklch(55% .07 240);--status-info-soft:oklch(94% .025 240);--sidebar-bg:oklch(96% .005 240);--sidebar-rail-bg:oklch(94% .006 240);--sidebar-fg:oklch(32% .01 250);--font-sans:"Inter Tight", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--fs-xs:13px;--fs-sm:14px;--fs-base:16px;--fs-md:17px;--fs-lg:19px;--fs-xl:24px;--fs-2xl:31px;--fs-3xl:41px;--lh-tight:1.2;--lh-snug:1.35;--lh-base:1.5;--sp-1:5px;--sp-2:7px;--sp-3:10px;--sp-4:14px;--sp-5:19px;--sp-6:24px;--sp-7:34px;--sp-8:48px;--sp-9:67px;--row-h:38px;--row-h-dense:31px;--header-h:53px;--rail-w:58px;--sidebar-w:298px;--radius-xs:4px;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--shadow-sm:0 1px 0 oklch(88% .006 240/.5);--shadow-md:0 1px 2px oklch(20% .01 250/.06), 0 2px 8px oklch(20% .01 250/.04);--shadow-lg:0 2px 4px oklch(20% .01 250/.06), 0 8px 24px oklch(20% .01 250/.08);--transition-fast:.12s cubic-bezier(.4, 0, .2, 1);--transition-base:.2s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box}html,body{height:100%;font-family:var(--font-sans);font-size:var(--fs-base);line-height:var(--lh-base);color:var(--text-primary);background:var(--bg-app);cursor:default;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"ss01", "cv11";margin:0;padding:0}button{font-family:inherit;font-size:inherit;color:inherit;cursor:pointer;background:0 0;border:none;padding:0}a{color:inherit;text-decoration:none}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}input,textarea{cursor:text}select{cursor:default}::selection{background:var(--accent-soft);color:var(--text-primary)}.mono{font-family:var(--font-mono);font-feature-settings:"ss02"}.text-xs{font-size:var(--fs-xs)}.text-sm{font-size:var(--fs-sm)}.text-md{font-size:var(--fs-md)}.text-lg{font-size:var(--fs-lg)}.text-xl{font-size:var(--fs-xl)}.text-2xl{font-size:var(--fs-2xl)}.muted{color:var(--text-tertiary)}.secondary{color:var(--text-secondary)}.uppercase{text-transform:uppercase;letter-spacing:.06em;font-size:var(--fs-xs);color:var(--text-tertiary);font-weight:500}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{border:2px solid var(--bg-app);background:oklch(85% .006 240);border-radius:8px}::-webkit-scrollbar-thumb:hover{background:oklch(75% .008 240)}.btn{align-items:center;gap:var(--sp-2);height:34px;padding:0 var(--sp-4);border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--bg-surface);color:var(--text-primary);font-size:var(--fs-sm);cursor:pointer;transition:background var(--transition-fast), border-color var(--transition-fast);white-space:nowrap;font-weight:500;display:inline-flex}.btn:hover{background:var(--bg-hover);border-color:var(--line-strong)}.btn:active{background:var(--bg-active)}.btn-primary{background:var(--accent);color:var(--text-on-accent);border-color:var(--accent)}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-ghost{background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--bg-hover);border-color:#0000}.btn-icon{justify-content:center;align-items:center;width:34px;height:34px;padding:0;display:inline-flex}.btn svg{flex:none;width:17px;height:17px}.kbd{min-width:22px;height:22px;font-family:var(--font-mono);color:var(--text-secondary);background:var(--bg-surface);border:1px solid var(--line);border-bottom-width:2px;border-radius:3px;justify-content:center;align-items:center;padding:0 5px;font-size:12px;display:inline-flex}.badge{height:22px;font-size:var(--fs-xs);background:var(--bg-sunken);color:var(--text-secondary);border:1px solid var(--line-soft);white-space:nowrap;border-radius:3px;align-items:center;gap:5px;padding:0 7px;font-weight:500;display:inline-flex}.badge.ok{background:var(--status-ok-soft);color:var(--status-ok);border-color:#0000}.badge.warn{background:var(--status-warn-soft);color:var(--status-warn);border-color:#0000}.badge.err{background:var(--status-err-soft);color:var(--status-err);border-color:#0000}.badge.info{background:var(--status-info-soft);color:var(--status-info);border-color:#0000}.badge.accent{background:var(--accent-soft);color:var(--accent);border-color:#0000}.dot{border-radius:50%;flex:none;width:7px;height:7px}.dot.ok{background:var(--status-ok)}.dot.warn{background:var(--status-warn)}.dot.err{background:var(--status-err)}.dot.idle{background:var(--text-muted)}.card{background:var(--bg-surface);border:1px solid var(--line-soft);border-radius:var(--radius-md);overflow:hidden}.card-header{padding:var(--sp-3) var(--sp-5);border-bottom:1px solid var(--line-soft);background:var(--bg-elevated);justify-content:space-between;align-items:center;display:flex}.card-title{font-size:var(--fs-md);color:var(--text-primary);font-weight:600}.card-body{padding:var(--sp-5)}.input{align-items:center;gap:var(--sp-2);height:34px;padding:0 var(--sp-3);border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--bg-surface);font-size:var(--fs-sm);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);display:flex}.input:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.input input{cursor:text;background:0 0;border:none;outline:none;flex:1;min-width:0}.input svg{width:16px;height:16px;color:var(--text-tertiary);flex:none}.tbl{border-collapse:collapse;width:100%;font-size:var(--fs-sm)}.tbl thead th{text-align:left;font-weight:500;font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);padding:var(--sp-2) var(--sp-4);border-bottom:1px solid var(--line);background:var(--bg-elevated);position:sticky;top:0}.tbl tbody td{padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--line-soft);vertical-align:middle}.tbl tbody tr{transition:background var(--transition-fast)}.tbl tbody tr:hover{background:var(--bg-hover)}.tbl tbody tr.selected{background:var(--accent-soft)}.tbl td.num,.tbl th.num{font-family:var(--font-mono);text-align:right;font-feature-settings:"tnum"}.tabs{background:var(--bg-sunken);border:1px solid var(--line-soft);border-radius:var(--radius-sm);gap:2px;padding:2px;display:flex}.tab{font-size:var(--fs-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);border-radius:3px;padding:5px 12px}.tab:hover{color:var(--text-primary)}.tab.active{background:var(--bg-surface);color:var(--text-primary);box-shadow:var(--shadow-sm)}.section-head{margin-bottom:var(--sp-4);justify-content:space-between;align-items:center;display:flex}.section-head h2{font-size:var(--fs-md);letter-spacing:-.01em;margin:0;font-weight:600}.field{flex-direction:column;gap:4px;display:flex}.field-label{font-size:var(--fs-xs);color:var(--text-secondary);font-weight:500}.field-hint{font-size:var(--fs-xs);color:var(--text-tertiary)}.field-input{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--bg-surface);width:100%;color:var(--text-primary);font-size:var(--fs-sm);transition:border-color var(--transition-fast);outline:none;padding:6px 10px;font-family:inherit}.field-input:focus{border-color:var(--accent)}.field-input:is(input,textarea){cursor:text}.field-input:is(select){cursor:default}.field-input:disabled{background:var(--bg-sunken);color:var(--text-tertiary);cursor:not-allowed}.field-input.mono{font-family:var(--font-mono);text-align:right;font-feature-settings:"tnum"}textarea.field-input{resize:vertical;min-height:32px}.dim-grid{gap:var(--sp-3);grid-template-columns:repeat(3,1fr);display:grid}.dim-cell{flex-direction:column;gap:2px;display:flex}.dim-label{align-items:baseline;gap:var(--sp-2);display:flex}.dim-symbol{font-family:var(--font-mono);font-size:var(--fs-md);color:var(--accent);min-width:14px;font-weight:600}.dim-hint{font-size:var(--fs-xs);color:var(--text-tertiary)}.section-list{gap:var(--sp-2);flex-direction:column;display:flex}.section-row{gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);cursor:grab;transition:background var(--transition-fast), border-color var(--transition-fast), opacity var(--transition-fast);grid-template-columns:18px 36px 1fr auto auto;align-items:center;display:grid}.section-row:active{cursor:grabbing}.section-row.dragging{opacity:.4}.section-row.drop-target{border-color:var(--accent);box-shadow:0 -2px 0 0 var(--accent) inset}.section-row.invalid{border-color:var(--status-warn)}.section-handle{color:var(--text-tertiary);font-family:var(--font-mono);letter-spacing:-2px;-webkit-user-select:none;user-select:none;text-align:center;font-size:14px}.section-row:hover .section-handle{color:var(--text-secondary)}.section-pos{background:var(--bg-sunken);border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-secondary);place-items:center;font-weight:600;display:grid}.section-main{flex-direction:column;gap:4px;min-width:0;display:flex}.section-meta{align-items:center;gap:var(--sp-2);font-size:var(--fs-xs);color:var(--text-tertiary);font-family:var(--font-mono);flex-wrap:wrap;display:flex}.section-tool-link{color:var(--accent);font-family:var(--font-sans);white-space:nowrap;text-decoration:none}.section-tool-link:hover{text-decoration:underline}.section-qty{align-items:center;gap:var(--sp-2);display:flex}.section-tools{gap:2px;display:flex}.section-tools .btn-icon{width:28px;height:28px}.drillstring-editor-grid{gap:var(--sp-5);grid-template-columns:minmax(0,1fr) 230px;align-items:start;display:grid}.drillstring-schematic-col{min-width:0}.drillstring-schematic-sticky{top:var(--sp-4);gap:var(--sp-3);padding:var(--sp-3);border:1px solid var(--line-soft);border-radius:var(--radius-md);background:var(--bg-elevated);flex-direction:column;max-height:calc(100vh - 120px);display:flex;position:sticky;overflow-y:auto}.drillstring-schematic-title{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);font-weight:600}.schematic-table{flex-direction:column;gap:6px;display:flex}.schematic-row{gap:var(--sp-3);padding:var(--sp-2);border:1px solid var(--line-soft);border-radius:var(--radius-sm);background:var(--bg-surface);grid-template-columns:90px minmax(0,1fr);align-items:center;display:grid}.schematic-cell{vertical-align:top;display:block}.schematic-meta{flex-direction:column;gap:2px;min-width:0;display:flex}.schematic-meta-head{align-items:center;gap:var(--sp-2);flex-wrap:wrap;display:flex}.schematic-meta-code{height:18px;font-family:var(--font-mono);color:var(--accent);background:var(--accent-soft);border-radius:var(--radius-xs);letter-spacing:0;align-items:center;padding:0 6px;font-size:11px;font-weight:700;display:inline-flex}.schematic-meta-qty{font-size:var(--fs-xs);color:var(--text-secondary);font-weight:600}.schematic-meta-dims{color:var(--text-tertiary);font-feature-settings:"tnum";word-break:break-word;font-size:11px}.schematic-break-cut{fill:var(--bg-surface)}.schematic-break-line{fill:none;stroke:oklch(42% .018 250);stroke-width:1px;stroke-linecap:round;stroke-linejoin:round}.schematic-empty{padding:var(--sp-4) var(--sp-2);text-align:center}.equipment-editor{gap:var(--sp-5);flex-direction:column;display:flex}.equipment-editor-head{gap:var(--sp-4);grid-template-columns:auto minmax(0,1fr) auto;align-items:center;display:grid}.equipment-editor-title h1{font-size:var(--fs-2xl);line-height:var(--lh-tight);margin:2px 0 0;font-weight:600}.equipment-editor-actions{gap:var(--sp-2);justify-content:flex-end;display:flex}.equipment-error{padding:var(--sp-3) var(--sp-4);color:var(--status-err)}.equipment-editor-grid{gap:var(--sp-5);grid-template-columns:286px minmax(0,1fr);align-items:start;display:grid}.equipment-kind-panel,.equipment-form-panel{min-width:0}.equipment-panel-title{margin-bottom:var(--sp-2);font-size:var(--fs-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.equipment-kind-list{gap:var(--sp-2);display:grid}.equipment-kind-btn{gap:var(--sp-3);min-height:64px;padding:var(--sp-2);border:1px solid var(--line-soft);border-radius:var(--radius-sm);background:var(--bg-surface);color:var(--text-secondary);text-align:left;transition:background var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);grid-template-columns:74px minmax(0,1fr);align-items:center;display:grid}.equipment-kind-btn:hover:not(:disabled){background:var(--bg-hover);border-color:var(--line);color:var(--text-primary)}.equipment-kind-btn.active{border-color:var(--accent-line);background:var(--accent-soft);color:var(--text-primary)}.equipment-kind-btn:disabled{cursor:default;opacity:1}.equipment-kind-icon{border:1px solid var(--line);border-radius:var(--radius-xs);background:var(--bg-sunken);width:74px;height:48px;display:block;position:relative;overflow:hidden}.equipment-kind-glyph{width:100%;height:100%;display:block}.equipment-kind-glyph .steel{fill:oklch(72% .018 250)}.equipment-kind-glyph .body{fill:oklch(58% .022 250)}.equipment-kind-glyph .dark{fill:oklch(34% .018 250)}.equipment-kind-glyph .accent-fill{fill:color-mix(in oklch, var(--accent) 62%, oklch(74% .08 72))}.equipment-kind-glyph .cone,.equipment-kind-glyph .cutters{fill:oklch(47% .024 250)}.equipment-kind-glyph .hollow{fill:var(--bg-sunken)}.equipment-kind-glyph .line{fill:none;stroke:oklch(84% .015 250);stroke-width:1.5px;stroke-linecap:round}.equipment-kind-icon span{border:1px solid var(--accent-line);border-radius:calc(var(--radius-xs) - 1px);background:color-mix(in oklch, var(--bg-surface) 88%, transparent);min-width:24px;color:var(--accent);font-family:var(--font-mono);letter-spacing:0;text-align:center;padding:1px 4px;font-size:11px;font-weight:700;line-height:1.35;position:absolute;top:4px;left:4px}.equipment-kind-name{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:var(--fs-sm);font-weight:500;overflow:hidden}.equipment-table-kind{align-items:center;gap:var(--sp-2);min-width:0;display:flex}.equipment-table-kind-icon{border:1px solid var(--line-soft);border-radius:var(--radius-xs);background:var(--bg-sunken);flex:none;width:46px;height:30px;display:block;overflow:hidden}.equipment-lock-hint{margin-top:var(--sp-3)}.equipment-form-panel{gap:var(--sp-5);flex-direction:column;display:flex}.equipment-blueprint{background:var(--bg-surface);border:1px solid var(--line-soft);border-radius:var(--radius-md);overflow:hidden}.equipment-blueprint-meta{align-items:center;gap:var(--sp-2);min-height:42px;padding:0 var(--sp-4);border-bottom:1px solid var(--line-soft);color:var(--text-secondary);font-size:var(--fs-sm);display:flex}.equipment-blueprint-stage{height:clamp(230px,30vw,420px);padding:var(--sp-5);background:linear-gradient(var(--line-soft) 1px, transparent 1px), linear-gradient(90deg, var(--line-soft) 1px, transparent 1px), var(--bg-elevated);background-size:24px 24px;place-items:center;display:grid}.equipment-blueprint-stage img{object-fit:contain;filter:drop-shadow(0 1px oklch(20% .01 250/.12));min-width:0;max-width:100%;min-height:0;max-height:100%}.equipment-form-section{gap:var(--sp-5);grid-template-columns:minmax(280px,.9fr) minmax(280px,1.1fr);align-items:start;display:grid}.equipment-form-main{gap:var(--sp-4);flex-direction:column;display:flex}.equipment-dim-grid{margin-top:var(--sp-2);grid-template-columns:repeat(auto-fit,minmax(142px,1fr));align-items:end}.equipment-no-dims{padding:var(--sp-5);border:1px dashed var(--line);border-radius:var(--radius-sm);background:var(--bg-elevated);color:var(--text-tertiary);font-size:var(--fs-sm)}@media (width<=768px){.card{overflow-x:auto}.tbl thead th,.tbl tbody td{white-space:nowrap}.tbl tbody td.text-xs{white-space:normal;max-width:200px}.btn{height:38px}.btn-icon{width:38px;height:38px}.field-input{height:auto;min-height:38px;padding:8px 10px}.input{height:38px}.dim-grid{grid-template-columns:repeat(2,1fr)}.section-row{column-gap:var(--sp-2);row-gap:var(--sp-2);padding:var(--sp-3);grid-template-columns:18px 1fr auto;grid-template-areas:"handle main qty"".tools tools"}.section-pos{display:none}.section-handle{grid-area:handle;align-self:center}.section-main{grid-area:main;min-width:0}.section-qty{grid-area:qty}.section-tools{grid-area:tools;justify-content:flex-end}.filter-row{gap:var(--sp-2);flex-wrap:wrap}.filter-row .input,.filter-row select{width:100%;max-width:none}.filter-row .filter-counter{text-align:left;width:100%;margin-left:0}.equipment-editor-head{grid-template-columns:1fr}.equipment-editor-actions{justify-content:stretch}.equipment-editor-actions .btn{flex:1}.equipment-editor-grid,.equipment-form-section{grid-template-columns:1fr}.equipment-kind-list{grid-template-columns:repeat(2,minmax(0,1fr))}.equipment-kind-btn{text-align:center;grid-template-columns:1fr;justify-items:center}.equipment-kind-name{max-width:100%}.equipment-blueprint-stage{height:220px;padding:var(--sp-3)}.drillstring-editor-grid{grid-template-columns:1fr}.drillstring-schematic-sticky{position:static}.schematic-stage{max-height:none}}.placeholder{background:repeating-linear-gradient(45deg, var(--bg-sunken), var(--bg-sunken) 10px, var(--bg-elevated) 10px, var(--bg-elevated) 20px);border:1px dashed var(--line);border-radius:var(--radius-sm);color:var(--text-tertiary);font-family:var(--font-mono);font-size:var(--fs-xs);justify-content:center;align-items:center;display:flex;position:relative}.knbk-assets .knbk-toolbar{align-items:center;gap:var(--sp-3);flex-wrap:wrap;display:flex}.knbk-seg{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--bg-surface);display:inline-flex;overflow:hidden}.knbk-seg-btn{font-size:var(--fs-sm);color:var(--text-secondary);cursor:pointer;background:0 0;border:0;padding:6px 12px}.knbk-seg-btn:hover{background:var(--bg-hover)}.knbk-seg-btn.active{background:var(--accent);color:var(--text-on-accent)}.knbk-select{height:30px;padding:0 var(--sp-3);border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--bg-surface);color:var(--text-primary);font-size:var(--fs-sm)}.knbk-check{font-size:var(--fs-sm);color:var(--text-secondary);cursor:pointer;align-items:center;gap:6px;display:inline-flex}.asset-grid{gap:var(--sp-4);grid-template-columns:repeat(auto-fill,minmax(170px,1fr));display:grid}.asset-card{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--bg-elevated);transition:border-color var(--transition-fast);flex-direction:column;margin:0;display:flex;overflow:hidden}.asset-card:hover{border-color:var(--line-strong)}.asset-canvas{background:linear-gradient(45deg, var(--bg-sunken) 25%, transparent 25%), linear-gradient(-45deg, var(--bg-sunken) 25%, transparent 25%), linear-gradient(45deg, transparent 75%, var(--bg-sunken) 75%), linear-gradient(-45deg, transparent 75%, var(--bg-sunken) 75%);background-position:0 0,0 8px,8px -8px,-8px 0;background-size:16px 16px;background-color:var(--bg-elevated);height:240px;padding:var(--sp-2);justify-content:center;align-items:center;display:flex;overflow:hidden}.mode-natural .asset-canvas{overflow:auto}.asset-canvas img{image-rendering:pixelated;display:block}.mode-fit .asset-canvas img{object-fit:contain}.asset-card figcaption{justify-content:space-between;gap:var(--sp-2);padding:6px var(--sp-3);border-top:1px solid var(--line-soft);font-size:var(--fs-xs);display:flex}.asset-name{font-family:var(--font-mono);color:var(--text-primary)}.asset-dims{color:var(--text-tertiary)}.app{grid-template-columns:var(--rail-w) auto 1fr;background:var(--bg-app);width:100vw;height:100vh;display:grid;overflow:hidden}.app.fullscreen{grid-template-columns:0 auto 1fr}.rail{background:var(--sidebar-rail-bg);border-right:1px solid var(--line-soft);padding:var(--sp-3) 0;align-items:center;gap:var(--sp-1);flex-direction:column;display:flex;overflow:hidden}.rail-logo{width:38px;height:38px;margin-bottom:var(--sp-3);background:var(--text-primary);color:var(--bg-app);border-radius:var(--radius-sm);font-family:var(--font-mono);letter-spacing:-.04em;place-items:center;font-size:17px;font-weight:700;display:grid}.rail-btn{border-radius:var(--radius-sm);width:38px;height:38px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);place-items:center;display:grid;position:relative}.rail-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.rail-btn.active{background:var(--bg-surface);color:var(--accent);box-shadow:var(--shadow-sm)}.rail-btn.active:before{content:"";background:var(--accent);border-radius:0 2px 2px 0;width:2px;position:absolute;top:7px;bottom:7px;left:-10px}.rail-btn svg{width:19px;height:19px}.rail-spacer{flex:1}.sidebar{background:var(--sidebar-bg);border-right:1px solid var(--line-soft);min-width:0;width:var(--sidebar-w);transition:width var(--transition-base);flex-direction:column;display:flex;overflow:hidden}.app.sidebar-collapsed .sidebar{border-right-width:0;width:0}.sidebar-header{padding:var(--sp-3) var(--sp-4);height:var(--header-h);border-bottom:1px solid var(--line-soft);justify-content:space-between;align-items:center;display:flex}.sidebar-title{align-items:center;gap:var(--sp-2);font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);font-weight:600;display:flex}.sidebar-actions{gap:2px;display:flex}.sidebar-actions .btn-icon{width:26px;height:26px;color:var(--text-tertiary)}.sidebar-actions .btn-icon svg{width:14px;height:14px}.sidebar-search{padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--line-soft)}.sidebar-body{padding:var(--sp-3) var(--sp-2);flex:1;overflow-y:auto}.tree-section{margin-bottom:var(--sp-4)}.tree-section-head{padding:2px var(--sp-3);text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:5px;font-size:12px;font-weight:600;display:flex}.tree-section-head:hover{color:var(--text-secondary)}.tree-section-head svg{width:12px;height:12px;transition:transform var(--transition-fast)}.tree-section.collapsed .tree-section-head svg{transform:rotate(-90deg)}.tree-section.collapsed .tree-list{display:none}.tree-item{align-items:center;gap:var(--sp-2);padding:5px var(--sp-3);border-radius:var(--radius-xs);height:31px;font-size:var(--fs-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;display:flex;overflow:hidden}.tree-item:hover{background:var(--bg-hover);color:var(--text-primary)}.tree-item.active{background:var(--accent-soft);color:var(--text-primary)}.tree-item .tree-dot{flex:none}.tree-item .tree-label{text-overflow:ellipsis;flex:1;min-width:0;overflow:hidden}.tree-item .tree-meta{font-family:var(--font-mono);color:var(--text-tertiary);font-size:12px}.tree-item.nested{padding-left:29px}.tree-item svg{width:14px;height:14px;color:var(--text-tertiary);flex:none}.sidebar-footer{padding:var(--sp-3) var(--sp-4);border-top:1px solid var(--line-soft);align-items:center;gap:var(--sp-3);font-size:var(--fs-xs);color:var(--text-tertiary);display:flex}.avatar{background:var(--accent);width:26px;height:26px;color:var(--text-on-accent);border-radius:50%;place-items:center;font-size:12px;font-weight:600;display:grid}.main{flex-direction:column;min-width:0;display:flex;overflow:hidden}.topbar{align-items:center;gap:var(--sp-4);height:var(--header-h);padding:0 var(--sp-5);border-bottom:1px solid var(--line-soft);background:var(--bg-app);flex:none;display:flex}.topbar-left{align-items:center;gap:var(--sp-2);flex:none;display:flex}.topbar-center{flex:1;justify-content:center;min-width:0;display:flex}.topbar-right{align-items:center;gap:var(--sp-2);flex:none;display:flex}.crumbs{font-size:var(--fs-sm);color:var(--text-secondary);align-items:center;gap:7px;min-width:0;display:flex}.crumbs .crumb{cursor:pointer;border-radius:3px;align-items:center;gap:5px;padding:4px 7px;display:inline-flex}.crumbs .crumb:hover{background:var(--bg-hover);color:var(--text-primary)}.crumbs .crumb.current{color:var(--text-primary);font-weight:500}.crumbs .sep{color:var(--text-muted);font-size:12px}.global-search{width:432px;max-width:100%}.content{flex:1;position:relative;overflow:auto}.page{padding:var(--sp-7) var(--sp-7) var(--sp-9);max-width:1680px;margin:0 auto}.page-wide{max-width:none;padding:var(--sp-5) var(--sp-6) var(--sp-9)}.page-header{justify-content:space-between;align-items:flex-end;gap:var(--sp-5);margin-bottom:var(--sp-7);display:flex}.page-title{font-size:var(--fs-2xl);letter-spacing:-.02em;margin:0 0 5px;font-weight:600}.page-subtitle{font-size:var(--fs-sm);color:var(--text-tertiary);margin:0}.drop-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:100;padding:var(--sp-7);opacity:0;pointer-events:none;transition:opacity var(--transition-base);background:oklch(24% .012 250/.55);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.drop-overlay.visible{opacity:1;pointer-events:auto}.drop-card{background:var(--bg-surface);border-radius:var(--radius-lg);width:100%;max-width:864px;padding:var(--sp-6);box-shadow:var(--shadow-lg)}.drop-files{gap:var(--sp-2);padding:var(--sp-3);background:var(--bg-sunken);border-radius:var(--radius-sm);margin-bottom:var(--sp-5);font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--text-secondary);flex-wrap:wrap;display:flex}.drop-file-chip{background:var(--bg-surface);border:1px solid var(--line);border-radius:3px;align-items:center;gap:5px;padding:3px 7px;display:inline-flex}.drop-zones{gap:var(--sp-3);grid-template-columns:repeat(2,1fr);display:grid}.drop-zone{padding:var(--sp-4);border:1px dashed var(--line);border-radius:var(--radius-sm);background:var(--bg-elevated);cursor:pointer;transition:all var(--transition-fast);text-align:left;flex-direction:column;gap:5px;display:flex}.drop-zone:hover{border-color:var(--accent);background:var(--accent-soft)}.drop-zone-title{font-weight:600;font-size:var(--fs-md)}.drop-zone-meta{font-size:var(--fs-xs);color:var(--text-tertiary)}.drop-zone-meta .mono{color:var(--text-secondary)}.stat{padding:var(--sp-5);background:var(--bg-surface);border:1px solid var(--line-soft);border-radius:var(--radius-md);flex-direction:column;gap:5px;display:flex}.stat-label{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);font-weight:500}.stat-value{font-family:var(--font-mono);font-size:var(--fs-2xl);letter-spacing:-.02em;color:var(--text-primary);font-feature-settings:"tnum";font-weight:500}.stat-delta{font-size:var(--fs-xs);color:var(--text-tertiary);align-items:center;gap:5px;display:flex}.stat-delta.up{color:var(--status-ok)}.stat-delta.down{color:var(--status-err)}.well-grid{gap:var(--sp-4);grid-template-columns:repeat(auto-fill,minmax(384px,1fr));display:grid}.well-card{background:var(--bg-surface);border:1px solid var(--line-soft);border-radius:var(--radius-md);padding:var(--sp-5);gap:var(--sp-4);cursor:pointer;transition:all var(--transition-fast);flex-direction:column;display:flex}.well-card:hover{border-color:var(--line-strong);box-shadow:var(--shadow-md);transform:translateY(-1px)}.well-card-head{justify-content:space-between;align-items:flex-start;gap:var(--sp-3);display:flex}.well-card-id{font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--text-tertiary);letter-spacing:.04em}.well-card-name{font-size:var(--fs-md);letter-spacing:-.005em;margin:3px 0 0;font-weight:600}.well-card-stats{gap:var(--sp-3);padding-top:var(--sp-3);border-top:1px solid var(--line-soft);grid-template-columns:repeat(3,1fr);display:grid}.well-card-stat-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);font-size:12px}.well-card-stat-value{font-family:var(--font-mono);font-size:var(--fs-md);color:var(--text-primary);font-feature-settings:"tnum";margin-top:3px}.well-card-spark{width:100%;height:43px}.note-layout{gap:var(--sp-5);padding:var(--sp-5) var(--sp-7);grid-template-columns:1fr 336px;max-width:1440px;margin:0 auto;display:grid}@media (width<=1320px){.note-layout{grid-template-columns:1fr}}.note-doc{max-width:912px}.note-doc h1{font-size:var(--fs-3xl);letter-spacing:-.02em;margin:0 0 var(--sp-2);font-weight:600}.note-doc h2{font-size:var(--fs-xl);letter-spacing:-.01em;margin:var(--sp-7) 0 var(--sp-3);border-bottom:1px solid var(--line-soft);padding-bottom:5px;font-weight:600}.note-doc h3{font-size:var(--fs-lg);margin:var(--sp-5) 0 var(--sp-2);font-weight:600}.note-doc p{margin:0 0 var(--sp-3);font-size:var(--fs-md);color:var(--text-primary);line-height:1.65}.note-doc ul{padding-left:var(--sp-5);margin:0 0 var(--sp-3)}.note-doc li{font-size:var(--fs-md);margin-bottom:5px;line-height:1.6}.note-doc code,.note-doc .inline-code{font-family:var(--font-mono);background:var(--bg-sunken);border:1px solid var(--line-soft);border-radius:3px;padding:1px 6px;font-size:.92em}.note-doc blockquote{margin:var(--sp-3) 0;padding:var(--sp-3) var(--sp-4);border-left:2px solid var(--accent);background:var(--accent-soft);border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--text-secondary)}.note-doc .frontmatter{font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--text-secondary);background:var(--bg-sunken);border:1px solid var(--line-soft);border-radius:var(--radius-sm);padding:var(--sp-3) var(--sp-4);margin-bottom:var(--sp-5);gap:5px var(--sp-4);grid-template-columns:max-content 1fr;display:grid}.note-doc .fm-key{color:var(--text-tertiary)}.note-doc .wlink{color:var(--accent);border-bottom:1px solid var(--accent-line);cursor:pointer}.note-doc .tag{font-family:var(--font-mono);font-size:var(--fs-xs);background:var(--accent-soft);color:var(--accent);cursor:pointer;border-radius:3px;margin-right:5px;padding:1px 7px;display:inline-block}.note-doc .checklist{padding-left:0;list-style:none}.note-doc .checklist li{align-items:flex-start;gap:var(--sp-2);margin-bottom:5px;display:flex}.note-doc .checklist input[type=checkbox]{accent-color:var(--accent);margin-top:6px}.note-aside{gap:var(--sp-5);font-size:var(--fs-sm);flex-direction:column;display:flex}.note-aside h4{text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);margin:0 0 var(--sp-3);font-size:12px;font-weight:600}.kv{gap:5px var(--sp-3);grid-template-columns:108px 1fr;display:grid}.kv .k{color:var(--text-tertiary);font-size:var(--fs-xs);padding-top:2px}.kv .v{font-size:var(--fs-sm)}.kv .v.mono{font-feature-settings:"tnum"}.backlink{padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-xs);cursor:pointer;font-size:var(--fs-sm);color:var(--text-secondary);border-left:2px solid #0000;display:block}.backlink:hover{background:var(--bg-hover);border-left-color:var(--accent-line);color:var(--text-primary)}.backlink-meta{color:var(--text-tertiary);margin-top:2px;font-size:12px}.telemetry-grid{gap:var(--sp-4);grid-template-columns:repeat(2,1fr);display:grid}.chart{width:100%;height:192px;display:block}.chart-tall{height:288px}.chart-frame{background:var(--bg-surface);border:1px solid var(--line-soft);border-radius:var(--radius-md);padding:var(--sp-5)}.chart-head{margin-bottom:var(--sp-3);justify-content:space-between;align-items:baseline;display:flex}.chart-title{font-size:var(--fs-sm);color:var(--text-secondary);font-weight:600}.chart-value{font-family:var(--font-mono);font-size:var(--fs-lg);color:var(--text-primary);font-feature-settings:"tnum"}.chart-unit{font-size:var(--fs-xs);color:var(--text-tertiary);margin-left:5px}.files-grid{gap:var(--sp-3);grid-template-columns:repeat(auto-fill,minmax(192px,1fr));display:grid}.file-card{background:var(--bg-surface);border:1px solid var(--line-soft);border-radius:var(--radius-md);padding:var(--sp-3);cursor:pointer;transition:all var(--transition-fast)}.file-card:hover{border-color:var(--line-strong);box-shadow:var(--shadow-md)}.file-thumb{background:var(--bg-sunken);border-radius:var(--radius-xs);height:105px;margin-bottom:var(--sp-3);color:var(--text-tertiary);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;place-items:center;font-size:12px;display:grid;position:relative;overflow:hidden}.file-thumb.tex{background:repeating-linear-gradient(135deg, var(--bg-sunken) 0 7px, var(--bg-elevated) 7px 14px)}.file-name{font-size:var(--fs-sm);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.file-meta{font-size:var(--fs-xs);color:var(--text-tertiary);font-family:var(--font-mono);margin-top:2px}.activity{flex-direction:column;display:flex}.activity-row{gap:var(--sp-4);padding:var(--sp-3) 0;border-bottom:1px solid var(--line-soft);font-size:var(--fs-sm);grid-template-columns:110px 1fr;display:grid}.activity-row:last-child{border-bottom:none}.activity-time{font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--text-tertiary);padding-top:2px}.activity-body{color:var(--text-secondary)}.activity-body strong{color:var(--text-primary);font-weight:500}.task-list{margin:0;padding:0;list-style:none}.task{align-items:flex-start;gap:var(--sp-3);padding:var(--sp-3);border-bottom:1px solid var(--line-soft);display:flex}.task:last-child{border-bottom:none}.task input[type=checkbox]{accent-color:var(--accent);margin-top:5px}.task.done .task-text{color:var(--text-tertiary);text-decoration:line-through}.task-text{font-size:var(--fs-sm);flex:1}.task-meta{font-size:var(--fs-xs);color:var(--text-tertiary);align-items:center;gap:7px;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;opacity:0;pointer-events:none;transition:opacity var(--transition-base);background:oklch(24% .012 250/.4);justify-content:center;align-items:flex-start;padding-top:120px;display:flex;position:fixed;inset:0}.modal-overlay.visible{opacity:1;pointer-events:auto}.search-modal{background:var(--bg-surface);border-radius:var(--radius-lg);width:100%;max-width:768px;box-shadow:var(--shadow-lg);overflow:hidden}.search-modal-input{align-items:center;gap:var(--sp-3);padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--line-soft);display:flex}.search-modal-input input{font-size:var(--fs-lg);background:0 0;border:none;outline:none;flex:1}.search-results{max-height:576px;overflow-y:auto}.search-result{gap:var(--sp-3);padding:var(--sp-3) var(--sp-5);border-bottom:1px solid var(--line-soft);cursor:pointer;grid-template-columns:22px 1fr auto;align-items:center;display:grid}.search-result:hover,.search-result.active{background:var(--accent-soft)}.search-result-title{font-size:var(--fs-md);font-weight:500}.search-result-snippet{font-size:var(--fs-xs);color:var(--text-tertiary);margin-top:2px}.search-result-snippet mark{background:var(--accent-soft);color:var(--accent);border-radius:2px;padding:0 2px}.search-result-kind{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);font-size:12px}.settings-layout{gap:var(--sp-7);max-width:1152px;padding:var(--sp-7);grid-template-columns:240px 1fr;margin:0 auto;display:grid}.settings-nav{flex-direction:column;gap:2px;display:flex}.settings-nav-item{padding:7px var(--sp-3);border-radius:var(--radius-xs);font-size:var(--fs-sm);color:var(--text-secondary);cursor:pointer}.settings-nav-item:hover{background:var(--bg-hover)}.settings-nav-item.active{background:var(--accent-soft);color:var(--text-primary);font-weight:500}.settings-section{margin-bottom:var(--sp-7)}.settings-section h3{font-size:var(--fs-md);margin:0 0 var(--sp-2);font-weight:600}.settings-section p{font-size:var(--fs-sm);color:var(--text-tertiary);margin:0 0 var(--sp-4)}.settings-row{padding:var(--sp-3) 0;border-bottom:1px solid var(--line-soft);justify-content:space-between;align-items:center;display:flex}.settings-row-label{font-size:var(--fs-sm)}.settings-row-desc{font-size:var(--fs-xs);color:var(--text-tertiary);margin-top:2px}.switch{background:var(--line);cursor:pointer;width:38px;height:22px;transition:background var(--transition-fast);border-radius:11px;position:relative}.switch:after{content:"";background:var(--bg-surface);width:16px;height:16px;transition:left var(--transition-fast);border-radius:50%;position:absolute;top:3px;left:3px}.switch.on{background:var(--accent)}.switch.on:after{left:19px}.well-page-grid{gap:var(--sp-5);padding:var(--sp-5) var(--sp-7);grid-template-columns:1fr 384px;max-width:1680px;margin:0 auto;display:grid}@media (width<=1416px){.well-page-grid{grid-template-columns:1fr}}.well-page-main{gap:var(--sp-5);flex-direction:column;min-width:0;display:flex}.well-page-aside{gap:var(--sp-4);flex-direction:column;display:flex}.well-hero{justify-content:space-between;align-items:flex-end;gap:var(--sp-5);padding-bottom:var(--sp-5);border-bottom:1px solid var(--line);display:flex}.well-hero-id{font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--text-tertiary);letter-spacing:.05em}.well-hero-title{font-size:var(--fs-3xl);letter-spacing:-.02em;margin:5px 0 7px;font-weight:600}.well-hero-subtitle{font-size:var(--fs-sm);color:var(--text-secondary);align-items:center;gap:var(--sp-3);display:flex}.well-hero-subtitle .sep{color:var(--text-muted)}.tools-page{gap:var(--sp-4);padding:var(--sp-5) var(--sp-7) var(--sp-9);flex-direction:column;max-width:1680px;margin:0 auto;display:flex}.tools-tabs{align-self:flex-start}.tools-page>.page{width:100%;max-width:none;margin:0;padding:0}.block{background:var(--bg-surface);border:1px solid var(--line-soft);border-radius:var(--radius-md)}.block-head{padding:var(--sp-3) var(--sp-5);border-bottom:1px solid var(--line-soft);justify-content:space-between;align-items:center;gap:var(--sp-3);flex-wrap:wrap;display:flex}.block-title{font-size:var(--fs-sm);color:var(--text-primary);font-weight:600}.block-body{padding:var(--sp-5)}.block-body.tight{padding:0}.row{align-items:center;gap:var(--sp-3);display:flex}.row.between{justify-content:space-between}.col{gap:var(--sp-3);flex-direction:column;display:flex}.spacer{flex:1}.divider{background:var(--line-soft);height:1px;margin:var(--sp-4) 0}.grid-3{gap:var(--sp-4);grid-template-columns:repeat(3,1fr);display:grid}.grid-4{gap:var(--sp-4);grid-template-columns:repeat(4,1fr);display:grid}.grid-2{gap:var(--sp-4);grid-template-columns:repeat(2,1fr);display:grid}.auth-splash{min-height:100vh;color:var(--text-secondary);font-size:var(--fs-md);justify-content:center;align-items:center;display:flex}.auth-gate{min-height:100vh;padding:var(--sp-5);background:var(--bg-base);justify-content:center;align-items:center;display:flex}.auth-gate-card{align-items:flex-start;gap:var(--sp-4);max-width:420px;padding:var(--sp-7) var(--sp-6);background:var(--bg-elev);border:1px solid var(--line-soft);border-radius:var(--radius-lg,12px);flex-direction:column;display:flex}.auth-gate-card h1{font-size:var(--fs-xl);margin:0}.auth-gate-card p{color:var(--text-secondary);margin:0}.mobile-menu-btn,.mobile-backdrop{display:none}@media (width<=768px){.app{grid-template-columns:1fr}.rail,.sidebar{z-index:90;transition:left .22s cubic-bezier(.4,0,.2,1);position:fixed;top:0;bottom:0}.rail{left:calc(var(--rail-w) * -1);width:var(--rail-w)}.sidebar{width:calc(100vw - var(--rail-w));border-right:1px solid var(--line-soft);max-width:280px;left:-100vw}.app.sidebar-collapsed .sidebar{width:calc(100vw - var(--rail-w));border-right-width:1px;max-width:280px}.app.mobile-menu-open .rail{left:0}.app.mobile-menu-open .sidebar{left:var(--rail-w)}.mobile-backdrop{z-index:80;opacity:0;pointer-events:none;background:oklch(24% .012 250/.45);transition:opacity .22s cubic-bezier(.4,0,.2,1);display:block;position:fixed;inset:0}.app.mobile-menu-open .mobile-backdrop{opacity:1;pointer-events:auto}.mobile-menu-btn{flex:none;display:inline-flex}.topbar{padding:0 var(--sp-3);gap:var(--sp-2);height:50px}.topbar-center{display:none}.topbar-right{gap:4px}.topbar-right .btn{justify-content:center;gap:0;width:34px;padding:0;font-size:0}.topbar-right .btn svg{width:17px;height:17px}.crumbs{font-size:var(--fs-xs);flex:1;min-width:0;overflow:hidden}.crumbs .crumb{text-overflow:ellipsis;white-space:nowrap;max-width:60vw;overflow:hidden}.page,.page-wide{padding:var(--sp-4) var(--sp-3) var(--sp-7)}.page-header{align-items:stretch;gap:var(--sp-3);margin-bottom:var(--sp-5);flex-direction:column}.page-title{font-size:var(--fs-xl)}.page-subtitle{font-size:var(--fs-xs)}.well-grid,.telemetry-grid{gap:var(--sp-3);grid-template-columns:1fr}.files-grid{gap:var(--sp-2);grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.drop-zones{grid-template-columns:1fr}.well-page-grid{padding:var(--sp-4) var(--sp-3);gap:var(--sp-4);grid-template-columns:1fr}.tools-page{padding:var(--sp-4) var(--sp-3) var(--sp-7);gap:var(--sp-3)}.note-layout,.settings-layout{padding:var(--sp-4) var(--sp-3);gap:var(--sp-4);grid-template-columns:1fr}.grid-2,.grid-3,.grid-4{gap:var(--sp-3);grid-template-columns:1fr}.well-card-stats{gap:var(--sp-2);grid-template-columns:repeat(3,1fr)}.well-hero{align-items:stretch;gap:var(--sp-3);padding-bottom:var(--sp-3);flex-direction:column}.well-hero-title{font-size:var(--fs-2xl)}.modal-overlay{padding:var(--sp-3);padding-top:var(--sp-5)}.search-modal{max-width:100%}.drop-card{padding:var(--sp-4)}.activity-row{padding:var(--sp-3) 0;grid-template-columns:1fr;gap:2px}.activity-time{padding-top:0}.block-head{padding:var(--sp-3);gap:var(--sp-2)}.block-body{padding:var(--sp-3)}}
