:root{--bg: oklch(99% .003 250);--bg-deep: oklch(97% .004 250);--bg-row-hover: oklch(98% .005 245);--surface: oklch(100% 0 0);--surface-mute: oklch(97% .004 250);--ink: oklch(22% .02 250);--ink-mid: oklch(42% .014 250);--ink-soft: oklch(58% .012 250);--ink-faint: oklch(72% .008 250);--line: oklch(91% .006 250);--line-soft: oklch(95% .004 250);--line-strong: oklch(82% .01 250);--accent: oklch(40% .09 245);--accent-deep: oklch(30% .08 245);--accent-soft: oklch(96% .018 245);--accent-edge: oklch(82% .04 245);--ok: oklch(48% .1 155);--ok-soft: oklch(96% .02 155);--warn: oklch(58% .13 75);--warn-soft: oklch(96% .03 75);--danger: oklch(50% .18 25);--danger-soft: oklch(96% .02 25);--font-sans: "Geist", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", system-ui, -apple-system, sans-serif;--font-mono: "Geist Mono", ui-monospace, "SF Mono", "JetBrains Mono", Menlo, Consolas, monospace;--s-1: 4px;--s-2: 8px;--s-3: 12px;--s-4: 16px;--s-5: 20px;--s-6: 24px;--s-7: 32px;--s-8: 48px;--s-9: 64px;--r-1: 4px;--r-2: 6px;--r-3: 8px;--measure: 1180px;--shadow-sm: 0 1px 2px oklch(20% .02 250 / .04);--shadow-md: 0 4px 12px oklch(20% .02 250 / .06), 0 1px 2px oklch(20% .02 250 / .04);color-scheme:light;color:var(--ink);background:var(--bg);font-family:var(--font-sans);font-size:14px;line-height:1.5;font-feature-settings:"kern","liga","ss01","cv11";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-height:100vh}button,input,textarea{font:inherit;color:inherit}button{cursor:pointer;background:none;border:0;padding:0}button:disabled{cursor:not-allowed;opacity:.5}::selection{background:var(--accent-soft);color:var(--accent-deep)}a{color:inherit;text-decoration:none}.label{font-family:var(--font-mono);font-weight:500;font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft)}.mono{font-family:var(--font-mono);font-feature-settings:"tnum","ss01"}h1,h2,h3,h4,p{margin:0}.app{min-height:100vh;display:grid;grid-template-rows:auto auto 1fr auto;background:var(--bg)}.topbar{background:var(--surface);border-bottom:1px solid var(--line);padding:var(--s-3) var(--s-7);display:grid;grid-template-columns:1fr auto;gap:var(--s-6);align-items:center;position:sticky;top:0;z-index:20}.brand{display:flex;align-items:center;gap:var(--s-3);min-width:0}.brand-mark{width:22px;height:22px;border-radius:var(--r-1);background:var(--accent);display:grid;place-items:center;color:var(--surface);font-family:var(--font-mono);font-weight:600;font-size:12px}.brand-name{font-weight:600;font-size:14px;color:var(--ink);letter-spacing:-.01em}.brand-divider{width:1px;height:16px;background:var(--line-strong);margin:0 var(--s-2)}.brand-context{font-size:13px;color:var(--ink-mid);letter-spacing:-.005em}.topbar-meta{display:flex;align-items:center;gap:var(--s-4);font-family:var(--font-mono);font-size:12px;color:var(--ink-soft)}.steps{background:var(--surface);border-bottom:1px solid var(--line);padding:0 var(--s-7);display:flex;gap:var(--s-2);align-items:stretch;position:sticky;top:49px;z-index:19}.step{position:relative;display:flex;align-items:center;gap:var(--s-3);padding:var(--s-4) var(--s-2) calc(var(--s-4) - 2px);font-size:13px;color:var(--ink-soft);border-bottom:2px solid transparent;transition:color .14s ease,border-color .14s ease}.step:hover{color:var(--ink)}.step.is-active{color:var(--ink);border-bottom-color:var(--accent)}.step-num{font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--ink-faint);letter-spacing:.04em;min-width:18px}.step.is-active .step-num{color:var(--accent)}.step-label{font-weight:500;letter-spacing:-.005em}.body{padding:var(--s-7) var(--s-7) var(--s-9)}.body-inner{max-width:var(--measure);margin:0 auto}.section-head{display:grid;grid-template-columns:1fr auto;gap:var(--s-5);align-items:end;margin-bottom:var(--s-7)}.section-head .label{margin-bottom:var(--s-2)}.section-head h1{font-size:22px;font-weight:600;letter-spacing:-.018em;line-height:1.25;color:var(--ink)}.section-head .desc{margin-top:var(--s-2);font-size:13px;color:var(--ink-mid);line-height:1.55;max-width:64ch}.section-head-actions{display:flex;gap:var(--s-2);align-items:center}.notice{display:flex;align-items:baseline;gap:var(--s-3);padding:var(--s-3) var(--s-4);background:var(--accent-soft);border:1px solid var(--accent-edge);border-radius:var(--r-2);font-size:13px;color:var(--ink);margin-bottom:var(--s-5)}.notice .label{color:var(--accent-deep);flex-shrink:0}.notice.notice-error{background:var(--danger-soft);border-color:color-mix(in oklch,var(--danger) 35%,transparent)}.notice.notice-error .label{color:var(--danger)}.summary{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-3);padding:var(--s-5) var(--s-6);margin-bottom:var(--s-6);display:grid;grid-template-columns:1fr auto;gap:var(--s-6);align-items:center}.summary-meter{display:grid;gap:var(--s-3);min-width:0}.summary-meter-head{display:flex;justify-content:space-between;align-items:baseline;gap:var(--s-3)}.summary-meter-head .label{color:var(--ink-mid)}.summary-meter-head .ratio{font-family:var(--font-mono);font-size:13px;font-weight:500;color:var(--ink);font-feature-settings:"tnum"}.summary-meter-head .ratio em{color:var(--ink-faint);font-style:normal;font-weight:400}.summary-meter-bar{height:4px;background:var(--bg-deep);border-radius:999px;overflow:hidden;position:relative}.summary-meter-bar>span{display:block;height:100%;background:var(--accent);border-radius:999px;transition:width .48s cubic-bezier(.16,1,.3,1)}.summary-stats{display:flex;gap:var(--s-7);align-items:baseline;padding-left:var(--s-6);border-left:1px solid var(--line)}.summary-stat{display:flex;flex-direction:column;gap:2px;min-width:56px}.summary-stat .num{font-family:var(--font-mono);font-size:20px;font-weight:500;color:var(--ink);letter-spacing:-.01em;font-feature-settings:"tnum","ss01"}.summary-stat .num.num-accent{color:var(--accent)}.summary-stat .label{font-size:10px}.tree{list-style:none;margin:0;padding:0;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-3);overflow:hidden}.node,.node-children{list-style:none;margin:0;padding:0}.row{display:grid;grid-template-columns:56px 1fr auto;align-items:center;gap:var(--s-4);padding:var(--s-4) var(--s-5) var(--s-4) var(--s-5);border-bottom:1px solid var(--line-soft);position:relative;transition:background .14s ease;min-height:56px}.row:hover{background:var(--bg-row-hover)}.row:last-child{border-bottom:0}.tree>.node:last-child>.row{border-bottom:0}.node-children .row{padding-left:calc(var(--s-5) + var(--s-7));background:var(--bg-deep);box-shadow:inset 32px 0 0 -31px var(--line-strong)}.node-children .row .row-num{color:var(--ink-soft);font-size:10px}.node-children .row .row-name{font-weight:400;font-size:13px}.node-children .node-children .row{padding-left:calc(var(--s-5) + var(--s-7) + var(--s-6));box-shadow:inset 32px 0 0 -31px var(--line-strong),inset 56px 0 0 -55px var(--line)}.row-num{font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--ink-faint);letter-spacing:.04em;font-feature-settings:"tnum";white-space:nowrap}.row-main{display:flex;flex-direction:column;gap:4px;min-width:0}.row-name{font-size:14px;font-weight:500;color:var(--ink);letter-spacing:-.005em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.row-name-input{font-size:14px;font-weight:500;color:var(--ink);letter-spacing:-.005em;background:var(--bg-deep);border:1px solid var(--line);border-radius:var(--r-1);padding:6px 10px;width:100%;outline:none;transition:border-color .14s ease,background .14s ease}.row-name-input:focus{border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 3px color-mix(in oklch,var(--accent) 10%,transparent)}.row-sub{font-family:var(--font-mono);font-size:11px;color:var(--ink-soft);letter-spacing:.02em;font-feature-settings:"tnum"}.row-side{display:flex;align-items:center;gap:var(--s-3);flex-shrink:0}.status{font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;font-feature-settings:"tnum","ss01";white-space:nowrap}.status.is-empty{color:var(--ink-faint);font-weight:400}.status.is-filled{color:var(--ok);font-weight:500}.row-actions{display:flex;align-items:center;gap:2px;opacity:0;transition:opacity .14s ease}.row:hover .row-actions,.row:focus-within .row-actions{opacity:1}.row-action{font-size:12px;color:var(--ink-soft);padding:5px 10px;border-radius:var(--r-1);transition:color .12s ease,background .12s ease}.row-action:hover{color:var(--accent-deep);background:var(--accent-soft)}.row-action.is-danger:hover{color:var(--danger);background:var(--danger-soft)}.attachments{list-style:none;margin:0;padding:0;background:var(--surface);border-top:1px solid var(--line-soft)}.attachments .att{display:grid;grid-template-columns:56px 1fr auto auto auto;align-items:center;gap:var(--s-4);padding:10px var(--s-5) 10px calc(var(--s-5) + var(--s-7));border-bottom:1px dashed var(--line-soft);font-size:13px;color:var(--ink);min-height:40px}.node-children .attachments{background:var(--bg-deep);box-shadow:inset 32px 0 0 -31px var(--line-strong)}.node-children .attachments .att{padding-left:calc(var(--s-5) + var(--s-7) + var(--s-6))}.node-children .node-children .attachments{box-shadow:inset 32px 0 0 -31px var(--line-strong),inset 56px 0 0 -55px var(--line)}.node-children .node-children .attachments .att{padding-left:calc(var(--s-5) + var(--s-7) + var(--s-6) + var(--s-6))}.attachments .att:last-child{border-bottom:0}.att-icon{width:28px;height:32px;display:grid;place-items:center;background:var(--surface);border:1px solid var(--line);border-radius:3px;font-family:var(--font-mono);font-weight:500;font-size:9px;letter-spacing:.04em;color:var(--ink-soft);position:relative}.att-icon:after{content:"";position:absolute;top:0;right:0;width:6px;height:6px;background:linear-gradient(225deg,var(--bg-deep) 50%,var(--surface) 50%);border-left:1px solid var(--line);border-bottom:1px solid var(--line)}.att-name{font-size:13px;color:var(--ink);font-weight:400;letter-spacing:-.005em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:color .12s ease}.att-name:hover{color:var(--accent-deep);text-decoration:underline;text-underline-offset:2px}.att-size,.att-time{font-family:var(--font-mono);font-size:11px;color:var(--ink-soft);font-feature-settings:"tnum";white-space:nowrap}.att-remove{font-size:11px;font-family:var(--font-mono);color:var(--ink-soft);padding:4px 8px;border-radius:var(--r-1);opacity:0;transition:opacity .14s ease,color .12s ease,background .12s ease}.att:hover .att-remove,.att:focus-within .att-remove{opacity:1}.att-remove:hover{color:var(--danger);background:var(--danger-soft)}.drop{display:grid;grid-template-columns:56px 1fr auto;align-items:center;gap:var(--s-4);padding:var(--s-3) var(--s-5) var(--s-3) calc(var(--s-5) + var(--s-7));border-top:1px dashed var(--line);background:var(--surface);cursor:pointer;font-size:13px;color:var(--ink-soft);position:relative;transition:background .14s ease,color .14s ease,box-shadow .14s ease}.node-children .drop{padding-left:calc(var(--s-5) + var(--s-7) + var(--s-6));background:var(--bg-deep);box-shadow:inset 32px 0 0 -31px var(--line-strong)}.node-children .node-children .drop{padding-left:calc(var(--s-5) + var(--s-7) + var(--s-6) + var(--s-6));box-shadow:inset 32px 0 0 -31px var(--line-strong),inset 56px 0 0 -55px var(--line)}.drop:hover{color:var(--accent-deep);background:var(--accent-soft)}.drop input[type=file]{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.drop-mark{width:28px;height:28px;border:1px dashed var(--line-strong);border-radius:var(--r-1);display:grid;place-items:center;font-family:var(--font-mono);font-weight:500;font-size:14px;color:var(--ink-faint);background:var(--surface);transition:border-color .14s ease,color .14s ease}.drop:hover .drop-mark{border-color:var(--accent);color:var(--accent)}.drop-text{font-size:13px;color:var(--ink-mid)}.drop:hover .drop-text{color:var(--accent-deep)}.drop-hint{font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-faint);white-space:nowrap}.btn{font-family:var(--font-sans);font-weight:500;font-size:13px;letter-spacing:-.005em;padding:7px var(--s-4);border-radius:var(--r-1);border:1px solid var(--line-strong);background:var(--surface);color:var(--ink);transition:background .14s ease,color .14s ease,border-color .14s ease,box-shadow .14s ease;display:inline-flex;align-items:center;gap:6px;white-space:nowrap;box-shadow:var(--shadow-sm)}.btn:hover{background:var(--bg-deep);border-color:var(--ink-faint)}.btn-primary{background:var(--ink);color:var(--surface);border-color:var(--ink)}.btn-primary:hover{background:var(--accent-deep);border-color:var(--accent-deep)}.btn-text{background:transparent;border:0;color:var(--ink-mid);padding:6px var(--s-3);box-shadow:none}.btn-text:hover{background:var(--bg-deep);color:var(--ink);border-color:transparent}.empty{background:var(--surface);border:1px dashed var(--line-strong);border-radius:var(--r-3);padding:var(--s-9) var(--s-6);text-align:center;color:var(--ink-soft)}.empty-mark{width:36px;height:36px;margin:0 auto var(--s-4);border-radius:var(--r-2);background:var(--bg-deep);display:grid;place-items:center;color:var(--ink-faint);font-family:var(--font-mono);font-size:14px}.empty-title{font-size:14px;font-weight:500;color:var(--ink);margin-bottom:var(--s-2)}.empty p{font-size:13px;color:var(--ink-mid);max-width:48ch;margin:0 auto;line-height:1.6}.footer{border-top:1px solid var(--line);padding:var(--s-4) var(--s-7);display:flex;justify-content:space-between;align-items:center;font-family:var(--font-mono);font-size:11px;color:var(--ink-soft);letter-spacing:.02em;background:var(--surface)}.footer .footer-meta{display:flex;gap:var(--s-5)}@media (max-width: 820px){.topbar{grid-template-columns:1fr;gap:var(--s-2);padding:var(--s-3) var(--s-4)}.topbar-meta{gap:var(--s-2)}.steps{padding:0 var(--s-4);overflow-x:auto;scrollbar-width:none;top:80px}.steps::-webkit-scrollbar{display:none}.body{padding:var(--s-5) var(--s-4) var(--s-8)}.section-head{grid-template-columns:1fr;align-items:start}.summary{grid-template-columns:1fr;gap:var(--s-4);padding:var(--s-4)}.summary-stats{padding-left:0;border-left:0;border-top:1px solid var(--line);padding-top:var(--s-4);gap:var(--s-5)}.row{grid-template-columns:32px 1fr;grid-template-rows:auto auto;gap:var(--s-2);padding:var(--s-3) var(--s-4)}.row-side{grid-column:1 / -1;justify-content:flex-start}.row-actions{opacity:1}.node-children .row{padding-left:calc(var(--s-4) + var(--s-5))}.node-children .node-children .row{padding-left:calc(var(--s-4) + var(--s-5) + var(--s-4))}.attachments .att{grid-template-columns:32px 1fr auto;grid-template-rows:auto auto;padding:var(--s-2) var(--s-4) var(--s-2) calc(var(--s-4) + var(--s-5))}.att-time{display:none}.footer{padding:var(--s-3) var(--s-4);flex-direction:column;gap:var(--s-2)}}@media (prefers-reduced-motion: no-preference){.row,.att{animation:rowIn .22s cubic-bezier(.16,1,.3,1) backwards}@keyframes rowIn{0%{opacity:0;transform:translateY(2px)}to{opacity:1;transform:translateY(0)}}}.lock-banner[data-v-36963a74]{display:flex;align-items:center;gap:12px;padding:10px 16px;border-radius:8px;font-size:13px;margin-bottom:12px}.lock-banner .dot[data-v-36963a74]{width:8px;height:8px;border-radius:50%;flex-shrink:0}.lock-banner.owned[data-v-36963a74]{background:#22c55e1a;color:#166534;border:1px solid rgba(34,197,94,.3)}.lock-banner.owned .dot[data-v-36963a74]{background:#22c55e;box-shadow:0 0 0 3px #22c55e33}.lock-banner.blocked[data-v-36963a74]{background:#ef44441a;color:#991b1b;border:1px solid rgba(239,68,68,.3)}.lock-banner.blocked .dot[data-v-36963a74]{background:#ef4444;box-shadow:0 0 0 3px #ef444433}.lock-banner .ttl[data-v-36963a74]{font-size:12px;opacity:.85;margin-left:auto}.login-shell[data-v-fd2c8998]{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#f7f8fa,#e9ecf2);padding:24px}.login-card[data-v-fd2c8998]{width:100%;max-width:360px;background:#fff;border:1px solid #e3e6ec;border-radius:14px;padding:36px 32px 28px;box-shadow:0 12px 32px #0f172a0f;display:flex;flex-direction:column;gap:14px}.brand-mark[data-v-fd2c8998]{width:44px;height:44px;border-radius:12px;background:#111827;color:#fff;display:grid;place-items:center;font-weight:700;font-size:20px;margin:0 auto 4px}.login-card h1[data-v-fd2c8998]{margin:0;font-size:22px;text-align:center}.login-card .subtitle[data-v-fd2c8998]{margin:0 0 8px;text-align:center;color:#6b7280;font-size:13px}.login-card label[data-v-fd2c8998]{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#374151}.login-card input[data-v-fd2c8998]{padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;font-family:inherit}.login-card input[data-v-fd2c8998]:focus{outline:2px solid rgba(59,130,246,.4);border-color:#3b82f6}.error[data-v-fd2c8998]{margin:0;padding:8px 10px;background:#ef444414;color:#991b1b;border-radius:6px;font-size:13px}.btn[data-v-fd2c8998]{padding:10px 14px;border-radius:8px;border:1px solid transparent;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s}.btn-primary[data-v-fd2c8998]{background:#111827;color:#fff}.btn-primary[data-v-fd2c8998]:disabled{opacity:.6;cursor:not-allowed}.btn-primary[data-v-fd2c8998]:not(:disabled):hover{background:#000}.note[data-v-fd2c8998]{margin:4px 0 0;font-size:12px;color:#9ca3af;text-align:center}.tree-readonly{pointer-events:none;opacity:.6;filter:grayscale(.3)}.user-chip{display:inline-flex;align-items:center;gap:8px;margin-left:12px;padding:4px 10px;border-radius:999px;background:#1118270f;font-size:12px;color:#374151}.logout-btn{background:transparent;border:none;color:#6b7280;font-size:12px;cursor:pointer;padding:0}.logout-btn:hover{color:#111827;text-decoration:underline}
