:root{--bg-canvas: #ffffff;--bg-app: #f7f7f5;--bg-sidebar: #fbfbfa;--bg-subtle: #f5f5f3;--bg-hover: #f0f0ee;--bg-active: #ffffff;--text: #1a1a18;--text-secondary: #6b6b66;--text-tertiary: #9a9a93;--text-onprimary: #ffffff;--border: #e9e8e4;--border-strong: #dcdbd6;--border-input: #e2e1dc;--primary: #1c1c1a;--primary-hover: #2e2e2b;--accent: #4f5bd5;--accent-soft: color-mix(in oklch, var(--accent) 12%, white);--accent-ring: color-mix(in oklch, var(--accent) 35%, transparent);--amber: #e8a13a;--green: #3f9b6b;--blue-badge: #2f7bf6;--r-sm: 6px;--r-md: 8px;--r-lg: 12px;--r-xl: 16px;--r-pill: 999px;--sh-xs: 0 1px 2px rgba(28, 28, 26, .05);--sh-sm: 0 1px 2px rgba(28, 28, 26, .06), 0 1px 3px rgba(28, 28, 26, .05);--sh-md: 0 4px 12px -2px rgba(28, 28, 26, .1), 0 2px 6px -2px rgba(28, 28, 26, .06);--sh-lg: 0 16px 40px -8px rgba(28, 28, 26, .18), 0 6px 16px -6px rgba(28, 28, 26, .1);--font-ui: "Helvetica Neue", Helvetica, "Inter", Arial, system-ui, sans-serif;--font-content: "Helvetica Neue", Helvetica, "Inter", Arial, system-ui, sans-serif;--content-width: 720px;--sidebar-w: 264px}[data-content-font=serif]{--font-content: "Iowan Old Style", "Palatino Linotype", "Georgia", "Times New Roman", serif}[data-theme=dark]{--bg-canvas: #1a1a18;--bg-app: #121211;--bg-sidebar: #161614;--bg-subtle: #222220;--bg-hover: #2a2a27;--bg-active: #232320;--text: #f2f1ec;--text-secondary: #a3a299;--text-tertiary: #6f6e67;--border: #2c2c29;--border-strong: #383834;--border-input: #34342f;--primary: #f2f1ec;--primary-hover: #e4e3dc;--text-onprimary: #1a1a18;--sh-sm: 0 1px 2px rgba(0, 0, 0, .4);--sh-md: 0 4px 14px -2px rgba(0, 0, 0, .5);--sh-lg: 0 18px 44px -8px rgba(0, 0, 0, .6)}*{box-sizing:border-box}html,body{height:100%;margin:0}#root{height:100%}body{font-family:var(--font-ui);color:var(--text);background:var(--bg-app);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-size:14px;line-height:1.45}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit}::selection{background:var(--accent-ring)}a{color:var(--accent)}.splash{height:100%;display:grid;place-items:center;background:var(--bg-app)}.route-fallback{min-height:60vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center;padding:48px 24px}.route-fallback h1{font-size:22px;font-weight:700;letter-spacing:-.02em;margin:0}.route-fallback p{color:var(--text-secondary);margin:0 0 8px}.splash-logo{width:44px;height:44px;border-radius:12px;background:var(--primary);color:var(--text-onprimary);display:grid;place-items:center}.splash-logo svg{width:24px;height:24px}.auth-screen{min-height:100%;display:grid;place-items:center;background:var(--bg-app);padding:24px}.auth-card{width:100%;max-width:380px;background:var(--bg-canvas);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--sh-md);padding:28px}.auth-brand{display:flex;align-items:center;gap:10px;margin-bottom:22px}.auth-brand .sb-logo{width:34px;height:34px}.auth-title{font-size:22px;font-weight:700;letter-spacing:-.02em;margin:0}.auth-sub{color:var(--text-secondary);margin:4px 0 20px;font-size:14px}.auth-submit{width:100%;justify-content:center;margin-top:8px}.field-error{display:block;color:#c0392b;font-size:12px;margin-top:5px}.auth-error{background:color-mix(in oklch,#c0392b 10%,transparent);color:#c0392b;border-radius:var(--r-md);padding:9px 12px;font-size:13px;margin:4px 0}.auth-switch{text-align:center;font-size:13px;color:var(--text-secondary);margin:16px 0 0}.auth-switch button{border:none;background:none;color:var(--accent);font-weight:600;font-size:13px}.auth-demo{text-align:center;font-size:12px;color:var(--text-tertiary);margin:14px 0 0}.auth-demo code{font-family:ui-monospace,Menlo,monospace;background:var(--bg-subtle);border-radius:4px;padding:1px 5px}.app{display:grid;grid-template-columns:var(--sidebar-w, 264px) 1fr;height:100%;background:var(--bg-app);overflow:hidden}.app.sidebar-collapsed{--sidebar-w: 0px}.sidebar{background:var(--bg-sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;min-width:0;overflow:hidden}.sb-top{display:flex;align-items:center;gap:10px;padding:16px 16px 12px}.sb-logo{width:30px;height:30px;border-radius:8px;background:var(--primary);display:grid;place-items:center;color:var(--text-onprimary);flex:none}.sb-logo svg{width:16px;height:16px}.sb-brand{font-weight:600;font-size:14px;letter-spacing:-.01em}.sb-brand small{display:block;color:var(--text-tertiary);font-weight:500;font-size:11px}.sb-collapse{margin-left:auto;border:none;background:transparent;color:var(--text-tertiary);width:28px;height:28px;border-radius:6px;display:grid;place-items:center}.sb-collapse:hover{background:var(--bg-hover);color:var(--text-secondary)}.sb-scroll{flex:1;overflow-y:auto;padding:4px 12px 12px}.sb-section-label{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-tertiary);padding:14px 8px 6px}.nav-item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:8px 10px;border-radius:8px;border:1px solid transparent;background:transparent;color:var(--text-secondary);font-size:14px;font-weight:500;transition:background .12s,color .12s}.nav-item:hover{background:var(--bg-hover);color:var(--text)}.nav-item.active{background:var(--bg-active);color:var(--text);border-color:var(--border);box-shadow:var(--sh-xs)}.nav-item svg{width:18px;height:18px;flex:none;color:currentColor;opacity:.85}.nav-item span:nth-child(2){white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-item .count{margin-left:auto;font-size:12px;font-weight:600;color:var(--text-secondary);background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--r-pill);padding:1px 8px;min-width:22px;text-align:center}.sb-user{margin:8px 12px 14px;padding:10px;display:flex;align-items:center;gap:10px;border:1px solid var(--border);border-radius:12px;background:var(--bg-canvas);box-shadow:var(--sh-xs)}.sb-user .meta{min-width:0}.sb-user .name{font-weight:600;font-size:13px}.sb-user .email{color:var(--text-tertiary);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sb-user .chev{margin-left:auto;color:var(--text-tertiary)}.sb-user .chev svg{width:18px;height:18px}.book-head{display:flex;gap:10px;align-items:center;padding:12px 14px;margin:0 0 4px}.book-back{border:1px solid var(--border);background:var(--bg-canvas);width:30px;height:30px;border-radius:8px;flex:none;display:grid;place-items:center;color:var(--text-secondary);box-shadow:var(--sh-xs)}.book-back:hover{background:var(--bg-hover);color:var(--text)}.book-back svg{width:18px;height:18px}.book-cover-sm{width:34px;height:46px;border-radius:4px;flex:none;object-fit:cover;box-shadow:var(--sh-sm);background:var(--bg-subtle)}.book-head .t{min-width:0}.book-head .t .name{font-weight:600;font-size:14px;letter-spacing:-.01em;line-height:1.2}.book-head .t .sub{color:var(--text-tertiary);font-size:12px}.tree{padding:2px 10px 10px}.chapter{margin-bottom:2px}.chapter-row{display:flex;align-items:center;gap:6px;padding:7px 8px;border-radius:8px;cursor:pointer;color:var(--text-secondary);font-weight:600;font-size:13px}.chapter-row:hover{background:var(--bg-hover);color:var(--text)}.chapter-row .twirl{width:16px;height:16px;display:grid;place-items:center;color:var(--text-tertiary);transition:transform .15s;flex:none}.chapter-row .twirl svg{width:16px;height:16px}.chapter-row.collapsed .twirl{transform:rotate(-90deg)}.chapter-row .ch-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chapter-row .ch-add{margin-left:auto;opacity:0;border:none;background:transparent;color:var(--text-tertiary);width:22px;height:22px;border-radius:6px;display:grid;place-items:center}.chapter-row:hover .ch-add{opacity:1}.chapter-row .ch-add:hover{background:var(--bg-active);color:var(--text);box-shadow:var(--sh-xs)}.chapter-row .ch-add svg{width:15px;height:15px}.pages{margin:1px 0 4px 15px;padding-left:14px;border-left:1px solid var(--border)}.page-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:7px;cursor:pointer;color:var(--text-secondary);font-size:13px;font-weight:500;border:1px solid transparent}.page-row:hover{background:var(--bg-hover);color:var(--text)}.page-row.active{background:var(--bg-active);color:var(--text);border-color:var(--border);box-shadow:var(--sh-xs)}.page-row svg{width:15px;height:15px;flex:none;opacity:.7}.page-row .pg-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tree-add{display:flex;align-items:center;gap:8px;width:100%;margin-top:4px;padding:7px 10px;border-radius:8px;border:1px dashed var(--border-strong);background:transparent;color:var(--text-tertiary);font-size:13px;font-weight:500}.tree-add:hover{color:var(--text);border-color:var(--text-tertiary);background:var(--bg-hover)}.tree-add svg{width:15px;height:15px}.main{display:flex;flex-direction:column;min-width:0;background:var(--bg-canvas);overflow:hidden}.topbar{display:flex;align-items:center;gap:12px;padding:14px 24px;border-bottom:1px solid var(--border);background:var(--bg-canvas);flex:none}.crumbs{display:flex;align-items:center;gap:4px;min-width:0}.crumb{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:7px;font-size:13px;font-weight:500;color:var(--text-secondary);background:transparent;border:none;white-space:nowrap}.crumb:hover{background:var(--bg-hover);color:var(--text)}.crumb.current{background:var(--bg-subtle);color:var(--text);font-weight:600}.crumb-sep{color:var(--text-tertiary);display:grid;place-items:center}.crumb-sep svg{width:16px;height:16px}.topbar-spacer{flex:1}.topbar-actions{display:flex;align-items:center;gap:10px}.btn{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:var(--r-md);font-size:13px;font-weight:600;letter-spacing:-.01em;border:1px solid transparent;background:transparent;color:var(--text);transition:background .12s,border-color .12s,box-shadow .12s,opacity .12s;white-space:nowrap}.btn svg{width:16px;height:16px}.btn-secondary{background:var(--bg-canvas);border-color:var(--border-strong);color:var(--text);box-shadow:var(--sh-xs)}.btn-secondary:hover{background:var(--bg-hover)}.btn-primary{background:var(--primary);color:var(--text-onprimary);box-shadow:var(--sh-xs)}.btn-primary:hover{background:var(--primary-hover)}.btn-primary:disabled{opacity:.6;cursor:default}.btn-ghost{color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-hover);color:var(--text)}.icon-btn{border:1px solid transparent;background:transparent;color:var(--text-secondary);width:34px;height:34px;border-radius:var(--r-md);display:grid;place-items:center}.icon-btn:hover{background:var(--bg-hover);color:var(--text)}.icon-btn.bordered{border-color:var(--border-strong);background:var(--bg-canvas);box-shadow:var(--sh-xs)}.icon-btn svg{width:18px;height:18px}.work-area{flex:1;display:grid;grid-template-columns:1fr;min-height:0}.work-area.with-panel{grid-template-columns:1fr 340px}.canvas-scroll{overflow-y:auto;min-width:0}.canvas-scroll::-webkit-scrollbar{width:12px}.canvas-scroll::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:999px;border:3px solid var(--bg-canvas)}.lib{max-width:1080px;margin:0 auto;padding:36px 40px 80px}.lib-hero{display:flex;align-items:flex-end;gap:16px;margin-bottom:28px}.lib-hero h1{font-size:28px;font-weight:700;letter-spacing:-.02em;margin:0}.lib-hero p{color:var(--text-secondary);margin:6px 0 0;font-size:14px}.lib-tabs{display:flex;gap:4px;margin:0 0 20px;border-bottom:1px solid var(--border)}.lib-tab{padding:9px 12px;border:none;background:transparent;color:var(--text-secondary);font-size:13px;font-weight:600;border-bottom:2px solid transparent;margin-bottom:-1px}.lib-tab:hover{color:var(--text)}.lib-tab.active{color:var(--text);border-bottom-color:var(--primary)}.lib-tab .pill{margin-left:7px;font-size:11px;color:var(--text-tertiary);background:var(--bg-subtle);border-radius:999px;padding:1px 7px}.lib-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:18px}.work-card{position:relative;text-align:left;border:1px solid var(--border);background:var(--bg-canvas);border-radius:var(--r-lg);padding:16px;box-shadow:var(--sh-xs);transition:box-shadow .15s,transform .15s,border-color .15s;cursor:pointer;display:flex;flex-direction:column;gap:14px}.work-card:hover{box-shadow:var(--sh-md);transform:translateY(-2px);border-color:var(--border-strong)}.work-card .cover-wrap{display:flex;gap:14px}.work-card .cover{width:64px;height:88px;border-radius:6px;flex:none;object-fit:cover;box-shadow:var(--sh-sm);background:var(--bg-subtle)}.work-card .doc-glyph{width:64px;height:88px;border-radius:6px;flex:none;background:var(--bg-subtle);border:1px solid var(--border);display:grid;place-items:center;color:var(--text-tertiary)}.work-card .doc-glyph svg{width:24px;height:24px}.work-card .wc-meta{min-width:0;display:flex;flex-direction:column}.work-card h3{font-size:15px;font-weight:600;letter-spacing:-.01em;margin:0 0 3px}.work-card .byline{color:var(--text-secondary);font-size:13px}.kind-tag{margin-top:auto;align-self:flex-start;display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--r-pill);padding:3px 9px}.kind-tag svg{width:14px;height:14px}.work-card .wc-foot{display:flex;align-items:center;gap:10px;padding-top:12px;border-top:1px solid var(--border);color:var(--text-tertiary);font-size:12px;white-space:nowrap}.work-card .wc-foot>span{flex-shrink:0}.work-card .wc-foot .dot{width:4px;height:4px;border-radius:50%;background:currentColor}.work-card .status{display:inline-flex;align-items:center;gap:6px;font-weight:600}.work-card .status .led{width:7px;height:7px;border-radius:50%}.status.published .led{background:var(--green)}.status.draft .led{background:var(--amber)}.editor-wrap{padding:30px 24px 200px}.editor{max-width:var(--content-width);margin:0 auto}.doc-title-input{display:block;width:100%;border:none;background:transparent;color:var(--text);font-family:var(--font-content);padding:2px 0;font-size:34px;font-weight:700;letter-spacing:-.02em;line-height:1.12;outline:none}.doc-title-input::placeholder{color:var(--text-tertiary)}.doc-meta-row{display:flex;align-items:center;gap:10px;margin:0 0 12px;color:var(--text-tertiary);font-size:13px}.doc-divider{height:1px;background:var(--border);margin:18px 0 8px}.bp-prose{position:relative}.bp-content{outline:none;font-family:var(--font-content)}.bp-content>*{margin:2px 0}.bp-content>*+*{margin-top:8px}.bp-content h1{font-size:28px;font-weight:700;letter-spacing:-.02em;line-height:1.2;margin:18px 0 4px}.bp-content h2{font-size:22px;font-weight:700;letter-spacing:-.015em;line-height:1.25;margin:16px 0 4px}.bp-content h3{font-size:18px;font-weight:600;letter-spacing:-.01em;line-height:1.3;margin:12px 0 4px}.bp-content p{font-size:16px;line-height:1.65;color:#28281f}[data-theme=dark] .bp-content p{color:var(--text)}.bp-content ul,.bp-content ol{margin:0;padding-left:24px;font-size:16px;line-height:1.6}.bp-content li{margin:3px 0}.bp-content li::marker{color:var(--text-tertiary)}.bp-content a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}.b-quote{border-left:3px solid var(--primary);padding:2px 0 2px 18px;font-size:18px;line-height:1.55;font-style:italic;color:var(--text)}.b-quote .cite{display:block;font-style:normal;font-size:13px;color:var(--text-tertiary);margin-top:8px;font-family:var(--font-ui)}.b-callout{display:flex;gap:12px;padding:14px 16px;border-radius:var(--r-lg);background:var(--accent-soft);border:1px solid var(--accent-ring);font-size:15px;line-height:1.55}.b-callout.tone-neutral{background:var(--bg-subtle);border-color:var(--border)}.b-callout.tone-warn{background:color-mix(in oklch,var(--amber) 14%,white);border-color:color-mix(in oklch,var(--amber) 40%,transparent)}.b-callout.tone-success{background:color-mix(in oklch,var(--green) 12%,white);border-color:color-mix(in oklch,var(--green) 38%,transparent)}[data-theme=dark] .b-callout{background:color-mix(in oklch,var(--accent) 22%,var(--bg-canvas))}.b-callout .ico{flex:none;line-height:1.4;color:var(--text)}.b-callout-body{flex:1;min-width:0;outline:none}.b-image figure{margin:0}.b-image .ph{position:relative;border-radius:var(--r-lg);overflow:hidden;background-color:var(--bg-subtle);background-image:repeating-linear-gradient(45deg,transparent,transparent 11px,rgba(0,0,0,.035) 11px,rgba(0,0,0,.035) 12px);border:1px solid var(--border);aspect-ratio:16/9;display:grid;place-items:center;color:var(--text-tertiary);cursor:pointer}.b-image img{display:block;width:100%;border-radius:var(--r-lg);border:1px solid var(--border)}.b-image .ph .label{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:12px;background:var(--bg-canvas);border:1px solid var(--border);border-radius:var(--r-pill);padding:5px 12px;box-shadow:var(--sh-xs)}.b-image figcaption{text-align:center;color:var(--text-tertiary);font-size:13px;margin-top:8px;font-family:var(--font-ui)}.b-image.align-left img,.b-image.align-left .ph{max-width:60%}.b-image.align-left figure{display:flex;flex-direction:column;align-items:flex-start}.b-divider{padding:14px 0}.b-divider hr{border:none;border-top:1px solid var(--border-strong);margin:0}.b-divider.dots{text-align:center;color:var(--text-tertiary);letter-spacing:.5em}.bp-content table{border-collapse:separate;border-spacing:0;width:100%;font-size:14px;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;margin:8px 0;table-layout:fixed}.bp-content td,.bp-content th{border-bottom:1px solid var(--border);border-right:1px solid var(--border);padding:9px 12px;text-align:left;vertical-align:top;position:relative}.bp-content tr td:last-child,.bp-content tr th:last-child{border-right:none}.bp-content tr:last-child td{border-bottom:none}.bp-content thead th{background:var(--bg-subtle);font-weight:600}.bp-content .selectedCell:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--accent-ring);pointer-events:none}.block-gutter{display:flex;gap:2px}.gutter-btn{width:22px;height:24px;border:none;background:transparent;color:var(--text-tertiary);border-radius:5px;display:grid;place-items:center;padding:0}.gutter-btn:hover{background:var(--bg-hover);color:var(--text)}.gutter-btn.handle{cursor:grab}.gutter-btn.handle:active{cursor:grabbing}.gutter-btn svg{width:16px;height:16px}.reader-title{font-family:var(--font-content);font-size:34px;font-weight:700;letter-spacing:-.02em;line-height:1.12;color:var(--text);margin:0}.reader-draft{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--amber);border:1px solid var(--border);border-radius:var(--r-pill);padding:2px 8px}.reader-nav{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:40px;padding-top:20px;border-top:1px solid var(--border)}.reader-nav .btn:disabled{opacity:.4;pointer-events:none}.reader-pos{color:var(--text-tertiary);font-size:12px;font-variant-numeric:tabular-nums}.reader-toc-draft{width:7px;height:7px;border-radius:50%;background:var(--amber);margin-left:auto;flex:none}.work-card .wc-open{display:block;width:100%;border:none;background:transparent;text-align:left;cursor:pointer;padding:0}.work-card .wc-read{display:inline-flex;align-items:center;gap:5px;margin-left:auto;border:1px solid var(--border);border-radius:var(--r-sm);padding:4px 10px;font-size:12px;font-weight:600;color:var(--text-secondary);background:transparent;cursor:pointer;transition:background .12s,color .12s,border-color .12s}.work-card .wc-read:hover{background:var(--bg-hover);color:var(--text);border-color:var(--border-strong)}.work-card .wc-read svg{width:14px;height:14px}.work-card .wc-buy{display:inline-flex;align-items:center;gap:5px;margin-left:auto;border:1px solid var(--border-strong);border-radius:var(--r-sm);padding:4px 10px;font-size:12px;font-weight:600;color:var(--text);background:var(--bg-canvas);text-decoration:none;box-shadow:var(--sh-xs);transition:background .12s,color .12s,border-color .12s}.work-card .wc-buy:hover{background:var(--bg-hover)}.work-card .wc-buy svg{width:14px;height:14px}.work-card .wc-buy+.wc-read{margin-left:8px}.menu{z-index:60;min-width:280px;max-height:340px;overflow-y:auto;background:var(--bg-canvas);border:1px solid var(--border-strong);border-radius:var(--r-lg);box-shadow:var(--sh-lg);padding:6px}.menu-label{font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-tertiary);padding:8px 10px 4px}.menu-item{display:flex;align-items:center;gap:12px;width:100%;text-align:left;padding:8px 10px;border-radius:8px;border:none;background:transparent;color:var(--text)}.menu-item:hover,.menu-item.cursor{background:var(--accent-soft)}.menu-item .m-ico{width:34px;height:34px;border-radius:7px;flex:none;display:grid;place-items:center;background:var(--bg-subtle);border:1px solid var(--border);color:var(--text)}.menu-item .m-ico svg{width:17px;height:17px}.menu-item .m-txt{min-width:0}.menu-item .m-title{display:block;font-size:13px;font-weight:600}.menu-item .m-desc{display:block;font-size:12px;color:var(--text-tertiary)}.menu-empty{padding:16px;text-align:center;color:var(--text-tertiary);font-size:13px}.float-toolbar{display:flex;align-items:center;gap:2px;background:#1f1f1d;color:#fff;border-radius:var(--r-md);padding:4px;box-shadow:var(--sh-lg)}[data-theme=dark] .float-toolbar{background:#34342f}.float-toolbar button{border:none;background:transparent;color:#e9e9e4;width:30px;height:30px;border-radius:6px;display:grid;place-items:center;font-weight:700;font-size:14px}.float-toolbar button:hover{background:#ffffff24;color:#fff}.float-toolbar button.on{background:#fff3;color:#fff}.float-toolbar button svg{width:16px;height:16px}.float-toolbar .sep{width:1px;height:18px;background:#ffffff2e;margin:0 3px}.panel{border-left:1px solid var(--border);background:var(--bg-sidebar);overflow-x:hidden;overflow-y:auto}.panel-inner{padding:18px}.panel .cover{width:128px;height:176px;border-radius:8px;flex:none;object-fit:cover;box-shadow:var(--sh-sm);background:var(--bg-subtle)}.panel-head{display:flex;align-items:center;gap:8px;margin-bottom:6px}.panel-head .ico{width:30px;height:30px;border-radius:8px;background:var(--bg-subtle);border:1px solid var(--border);display:grid;place-items:center;color:var(--text)}.panel-head .ico svg{width:16px;height:16px}.panel-head .t{font-weight:600;font-size:14px}.panel-head .t small{display:block;color:var(--text-tertiary);font-weight:500;font-size:12px}.panel-section{padding:16px 0;border-bottom:1px solid var(--border)}.panel-section:last-child{border-bottom:none}.panel-section>.ps-label{font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:10px}.field{margin-bottom:12px}.field>label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.input,.select,.textarea{width:100%;border:1px solid var(--border-input);background:var(--bg-canvas);color:var(--text);border-radius:var(--r-md);padding:8px 10px;font-size:13px;font-family:inherit}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.seg{display:flex;gap:4px;background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--r-md);padding:3px}.seg button{flex:1;border:none;background:transparent;color:var(--text-secondary);font-size:12px;font-weight:600;padding:6px 8px;border-radius:6px;display:grid;place-items:center}.seg button.on{background:var(--bg-canvas);color:var(--text);box-shadow:var(--sh-xs)}.seg button svg{width:15px;height:15px}.kv{display:flex;align-items:center;justify-content:space-between;padding:7px 0;font-size:13px}.kv .k{color:var(--text-secondary)}.kv .v{color:var(--text);font-weight:600;font-variant-numeric:tabular-nums}.danger-btn{color:#c0392b}.danger-btn:hover{background:color-mix(in oklch,#c0392b 10%,transparent)}.btn-danger{background:#c0392b;color:#fff;box-shadow:var(--sh-xs)}.btn-danger:hover{background:#a93226}.btn-danger:disabled{opacity:.6;cursor:default}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:grid;place-items:center;padding:16px;background:#1c1c1a73}.modal{width:min(420px,100%);background:var(--bg-canvas);border:1px solid var(--border-strong);border-radius:var(--r-lg);box-shadow:var(--sh-lg);padding:22px 22px 18px}.modal h3{margin:0 0 8px;font-size:16px;font-weight:600;letter-spacing:-.01em;color:var(--text)}.modal p{margin:0;font-size:13.5px;line-height:1.5;color:var(--text-secondary)}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.row-del{opacity:0;border:none;background:transparent;color:var(--text-tertiary);width:22px;height:22px;border-radius:6px;display:grid;place-items:center;cursor:pointer}.chapter-row:hover .row-del,.page-row:hover .row-del{opacity:1}.row-del:hover{background:color-mix(in oklch,#c0392b 12%,transparent);color:#c0392b}.row-del svg{width:14px;height:14px}.page-row .row-del{margin-left:auto}.book-head .book-del{align-self:flex-start;border:none;background:transparent;color:var(--text-tertiary);width:26px;height:26px;border-radius:6px;display:grid;place-items:center;cursor:pointer;flex-shrink:0}.book-head .book-del:hover{background:color-mix(in oklch,#c0392b 12%,transparent);color:#c0392b}.book-head .book-del svg{width:15px;height:15px}.work-card .wc-del{position:absolute;top:10px;right:10px;z-index:1;display:grid;place-items:center;width:28px;height:28px;border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-tertiary);background:var(--bg-canvas);box-shadow:var(--sh-xs);cursor:pointer;opacity:0;transition:opacity .12s,background .12s,color .12s,border-color .12s}.work-card:hover .wc-del,.work-card .wc-del:focus-visible{opacity:1}.work-card .wc-del:hover{background:color-mix(in oklch,#c0392b 10%,transparent);color:#c0392b;border-color:color-mix(in oklch,#c0392b 30%,var(--border))}.work-card .wc-del svg{width:15px;height:15px}.tag-row{display:flex;flex-wrap:wrap;gap:6px}.tag{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:500;color:var(--text-secondary);background:var(--bg-canvas);border:1px solid var(--border);border-radius:var(--r-pill);padding:4px 10px}.kbd{font-family:ui-monospace,Menlo,monospace;background:var(--bg-canvas);border:1px solid var(--border);border-radius:4px;padding:1px 6px;font-size:12px}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.appearance{position:fixed;right:18px;bottom:18px;z-index:80;display:flex;flex-direction:column;align-items:flex-end;gap:10px}.appearance-btn{width:40px;height:40px;border-radius:50%;border:1px solid var(--border-strong);background:var(--bg-canvas);color:var(--text-secondary);display:grid;place-items:center;box-shadow:var(--sh-md)}.appearance-btn:hover,.appearance-btn.on{color:var(--text);background:var(--bg-hover)}.appearance-btn svg{width:18px;height:18px}.appearance-panel{width:248px;background:var(--bg-canvas);border:1px solid var(--border-strong);border-radius:var(--r-lg);box-shadow:var(--sh-lg);padding:14px}.appearance-panel .ap-head{font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:12px}.appearance-panel .field{margin-bottom:12px}.ap-swatches{display:flex;gap:8px}.ap-swatch{width:28px;height:28px;border-radius:8px;border:2px solid transparent;box-shadow:0 0 0 1px var(--border),var(--sh-xs);cursor:pointer}.ap-swatch.on{border-color:var(--bg-canvas);box-shadow:0 0 0 2px var(--text),var(--sh-xs)}.member-panel{max-width:520px;margin:24px auto;padding:0 24px}.member-head{display:flex;gap:14px;align-items:flex-start;margin-bottom:20px}.member-icon{flex:none;display:grid;place-items:center;width:40px;height:40px;border-radius:var(--r-md);background:var(--bg-subtle);color:var(--text-secondary)}.member-title{font-size:20px;font-weight:700;letter-spacing:-.02em;margin:0}.member-sub{color:var(--text-secondary);margin:4px 0 0;font-size:14px}.member-form{display:flex;flex-direction:column;gap:14px}.member-form .btn{align-self:flex-start;margin-top:4px}.member-ok{display:flex;align-items:center;gap:8px;background:color-mix(in oklch,var(--green) 12%,transparent);color:var(--green);border-radius:var(--r-md);padding:10px 12px;font-size:13px;margin-bottom:16px}.member-ok svg{width:18px;height:18px;flex:none}.author-cell{display:flex;align-items:center;gap:10px}.author-cell .name{font-weight:600}.you-badge{display:inline-flex;align-items:center;font-size:11px;font-weight:600;letter-spacing:.02em;color:var(--accent);background:color-mix(in oklch,var(--accent) 16%,transparent);border:1px solid color-mix(in oklch,var(--accent) 32%,transparent);border-radius:var(--r-pill);padding:1px 8px}.status-suspended{display:inline-flex;align-items:center;font-size:11px;font-weight:600;letter-spacing:.02em;color:var(--amber);background:color-mix(in oklch,var(--amber) 14%,transparent);border:1px solid color-mix(in oklch,var(--amber) 32%,transparent);border-radius:var(--r-pill);padding:1px 8px}.authors-table tr.is-suspended .author-cell .name{color:var(--text-tertiary)}.author-actions{display:flex;gap:4px;justify-content:flex-end}.author-actions .btn{padding:4px 8px;font-size:12px}.authors-table tbody tr{animation:author-row-in .42s cubic-bezier(.22,1,.36,1) both}.authors-table tbody tr:hover{background:var(--bg-hover)}@keyframes author-row-in{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.authors-table tbody tr{animation:none}}.report{max-width:1040px;margin:0 auto;padding:24px}.report-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;margin-bottom:20px}.report-title{font-size:20px;font-weight:700;letter-spacing:-.02em;margin:0}.report-sub{color:var(--text-secondary);font-size:13px;margin:4px 0 0}.report-filters{display:flex;gap:10px;flex-wrap:wrap}.seg{display:inline-flex;background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--r-pill);padding:2px}.seg-btn{border:none;background:transparent;color:var(--text-secondary);font-size:12px;font-weight:600;padding:5px 12px;border-radius:var(--r-pill);cursor:pointer}.seg-btn.on{background:var(--bg-canvas);color:var(--text);box-shadow:var(--sh-xs)}.report-totals{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}.stat-card{background:var(--bg-canvas);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px}.stat-value{font-size:26px;font-weight:700;letter-spacing:-.02em}.stat-label{color:var(--text-secondary);font-size:12px;margin-top:2px}.report-empty{color:var(--text-secondary);font-size:14px;padding:32px 0;text-align:center}.report-table{width:100%;border-collapse:collapse;font-size:13px}.report-table th{text-align:left;color:var(--text-tertiary);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.04em;padding:8px 10px;border-bottom:1px solid var(--border)}.report-table th.num,.report-table td.num{text-align:right;font-variant-numeric:tabular-nums}.report-row{cursor:pointer}.report-row:hover{background:var(--bg-hover)}.report-row.active{background:var(--bg-subtle)}.report-table td{padding:10px;border-bottom:1px solid var(--border)}.report-bookname{font-weight:600}.muted{color:var(--text-tertiary)}.bar-row{display:flex;align-items:center;gap:8px;min-width:120px}.bar-track{flex:1;height:6px;border-radius:3px;background:var(--bg-subtle);overflow:hidden}.bar-fill{height:100%;background:var(--primary);border-radius:3px}.bar-pct{font-variant-numeric:tabular-nums;color:var(--text-secondary);font-size:12px;width:34px;text-align:right}.report-detail{margin-top:24px;padding:20px;background:var(--bg-canvas);border:1px solid var(--border);border-radius:var(--r-lg)}.report-detail-title{font-size:16px;font-weight:700;margin:0}.report-charts{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:16px}.chart-label{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-tertiary);font-weight:600;margin-bottom:10px}.chart-bars{display:flex;align-items:flex-end;gap:3px;height:90px}.cbar{flex:1;min-width:4px;height:100%;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;gap:4px}.cbar-fill{width:100%;background:var(--primary);border-radius:2px 2px 0 0;min-height:2px}.cbar-fill.alt{background:var(--accent)}.cbar-x{font-size:9px;color:var(--text-tertiary);white-space:nowrap}.report-clients{margin-top:20px}.client-chip{display:inline-block;background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--r-pill);padding:4px 10px;font-size:12px;margin-right:8px;color:var(--text-secondary)}
