@font-face{font-family:Syne;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/syne-latin-400-normal-CcHADMBd.woff2)format("woff2"),url(/assets/syne-latin-400-normal-CULFKXub.woff)format("woff")}@font-face{font-family:Syne;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/syne-latin-ext-400-normal-B5s6XpS5.woff2)format("woff2"),url(/assets/syne-latin-ext-400-normal-DCnt6qEA.woff)format("woff")}@font-face{font-family:Syne;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/syne-latin-500-normal-emxikWQ7.woff2)format("woff2"),url(/assets/syne-latin-500-normal-DR6mUQpY.woff)format("woff")}@font-face{font-family:Syne;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/syne-latin-ext-500-normal-DHUXVE3f.woff2)format("woff2"),url(/assets/syne-latin-ext-500-normal-C5b4wHnS.woff)format("woff")}@font-face{font-family:Syne;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/syne-latin-600-normal-BiwQbQXw.woff2)format("woff2"),url(/assets/syne-latin-600-normal-dRu9QuIh.woff)format("woff")}@font-face{font-family:Syne;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/syne-latin-ext-600-normal-ZnizrDKU.woff2)format("woff2"),url(/assets/syne-latin-ext-600-normal-DEzBMW8B.woff)format("woff")}@font-face{font-family:Syne;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/syne-latin-700-normal-AF3Rs61n.woff2)format("woff2"),url(/assets/syne-latin-700-normal-Cd-_iCn5.woff)format("woff")}@font-face{font-family:Syne;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/syne-latin-ext-700-normal-DuyXglMe.woff2)format("woff2"),url(/assets/syne-latin-ext-700-normal-C-qCH-vM.woff)format("woff")}@font-face{font-family:Syne;font-style:normal;font-display:swap;font-weight:800;src:url(/assets/syne-latin-800-normal-EehdNYzx.woff2)format("woff2"),url(/assets/syne-latin-800-normal-BuJcbPcX.woff)format("woff")}@font-face{font-family:Syne;font-style:normal;font-display:swap;font-weight:800;src:url(/assets/syne-latin-ext-800-normal-CAQAsWuS.woff2)format("woff2"),url(/assets/syne-latin-ext-800-normal-B2iBRfEf.woff)format("woff")}@font-face{font-family:Crimson Pro;font-style:normal;font-display:swap;font-weight:300;src:url(/assets/crimson-pro-latin-300-normal-BdPotd8_.woff2)format("woff2"),url(/assets/crimson-pro-latin-300-normal-Ilu4iuVU.woff)format("woff")}@font-face{font-family:Crimson Pro;font-style:normal;font-display:swap;font-weight:300;src:url(/assets/crimson-pro-latin-ext-300-normal-DO8p3e_z.woff2)format("woff2"),url(/assets/crimson-pro-latin-ext-300-normal-CQpSIbk0.woff)format("woff")}@font-face{font-family:Crimson Pro;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/crimson-pro-latin-400-normal-B4SlG4wx.woff2)format("woff2"),url(/assets/crimson-pro-latin-400-normal-BzhyrSeK.woff)format("woff")}@font-face{font-family:Crimson Pro;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/crimson-pro-latin-ext-400-normal-B3ID4PT2.woff2)format("woff2"),url(/assets/crimson-pro-latin-ext-400-normal-BWiDT69a.woff)format("woff")}@font-face{font-family:Crimson Pro;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/crimson-pro-latin-500-normal-D6GH0edE.woff2)format("woff2"),url(/assets/crimson-pro-latin-500-normal-BCdZ5465.woff)format("woff")}@font-face{font-family:Crimson Pro;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/crimson-pro-latin-ext-500-normal-Cu9CDuc4.woff2)format("woff2"),url(/assets/crimson-pro-latin-ext-500-normal-CUkD1wcf.woff)format("woff")}@font-face{font-family:Crimson Pro;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/crimson-pro-latin-600-normal-vJ8oEdKU.woff2)format("woff2"),url(/assets/crimson-pro-latin-600-normal-Ca4fy0Cf.woff)format("woff")}@font-face{font-family:Crimson Pro;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/crimson-pro-latin-ext-600-normal-DTIcmTiA.woff2)format("woff2"),url(/assets/crimson-pro-latin-ext-600-normal-ChXPf8Fx.woff)format("woff")}@font-face{font-family:Crimson Pro;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/crimson-pro-latin-700-normal-BfTu9YAt.woff2)format("woff2"),url(/assets/crimson-pro-latin-700-normal-CnzwvVon.woff)format("woff")}@font-face{font-family:Crimson Pro;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/crimson-pro-latin-ext-700-normal-DB6BXmm8.woff2)format("woff2"),url(/assets/crimson-pro-latin-ext-700-normal-B0XMIwQy.woff)format("woff")}@font-face{font-family:DM Mono;font-style:normal;font-display:swap;font-weight:300;src:url(/assets/dm-mono-latin-300-normal-CNmLoeDX.woff2)format("woff2"),url(/assets/dm-mono-latin-300-normal-CT8u5j2n.woff)format("woff")}@font-face{font-family:DM Mono;font-style:normal;font-display:swap;font-weight:300;src:url(/assets/dm-mono-latin-ext-300-normal-CnIee3y3.woff2)format("woff2"),url(/assets/dm-mono-latin-ext-300-normal-DQuwWybz.woff)format("woff")}@font-face{font-family:DM Mono;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/dm-mono-latin-400-normal-4GdczIuU.woff2)format("woff2"),url(/assets/dm-mono-latin-400-normal--0xN8mdc.woff)format("woff")}@font-face{font-family:DM Mono;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/dm-mono-latin-ext-400-normal-C2zvOubV.woff2)format("woff2"),url(/assets/dm-mono-latin-ext-400-normal-1aZr6b2b.woff)format("woff")}@font-face{font-family:DM Mono;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/dm-mono-latin-500-normal-DRMDZjhP.woff2)format("woff2"),url(/assets/dm-mono-latin-500-normal-CN8Miw6E.woff)format("woff")}@font-face{font-family:DM Mono;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/dm-mono-latin-ext-500-normal-BtRyHRi6.woff2)format("woff2"),url(/assets/dm-mono-latin-ext-500-normal-Dw3M13d8.woff)format("woff")}@font-face{font-family:Oswald;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/oswald-latin-400-normal-BAFo8sP8.woff2)format("woff2"),url(/assets/oswald-latin-400-normal-D1wpMXgf.woff)format("woff")}@font-face{font-family:Oswald;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/oswald-latin-ext-400-normal-DbVOzfr-.woff2)format("woff2"),url(/assets/oswald-latin-ext-400-normal-KcyBFdGH.woff)format("woff")}@font-face{font-family:Oswald;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/oswald-latin-500-normal-B-eyT0Dw.woff2)format("woff2"),url(/assets/oswald-latin-500-normal-DM85Di4w.woff)format("woff")}@font-face{font-family:Oswald;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/oswald-latin-ext-500-normal-QdEKgtiz.woff2)format("woff2"),url(/assets/oswald-latin-ext-500-normal-DcyNJhgm.woff)format("woff")}@font-face{font-family:Oswald;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/oswald-latin-600-normal-plFmSr5g.woff2)format("woff2"),url(/assets/oswald-latin-600-normal-DRToI_2E.woff)format("woff")}@font-face{font-family:Oswald;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/oswald-latin-ext-600-normal-5Cvn_Zbc.woff2)format("woff2"),url(/assets/oswald-latin-ext-600-normal-BUCHT9gM.woff)format("woff")}@font-face{font-family:Oswald;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/oswald-latin-700-normal-vy6hmKSr.woff2)format("woff2"),url(/assets/oswald-latin-700-normal-UmC9Ev9x.woff)format("woff")}@font-face{font-family:Oswald;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/oswald-latin-ext-700-normal-BKErdSR5.woff2)format("woff2"),url(/assets/oswald-latin-ext-700-normal-CJSSDThd.woff)format("woff")}:root{--font-display:"Syne", system-ui, sans-serif;--font-body:"Crimson Pro", Georgia, serif;--font-mono:"DM Mono", "Courier New", monospace;--bg:#f5f0e8;--bg-raised:#ede7dc;--ink:#1a1008;--ink-muted:#6b5c44;--ink-faint:#786652;--border:#d4c9b8;--accent:#1858c2;--accent-hover:#1446a0;--sidebar-bg:#0d1117;--sidebar-ink:#c5c8cc;--sidebar-ink-muted:#828a94;--sidebar-active:#161c25;--sidebar-hover:#13181f;--mid-bg:#ede7dc;--mid-border:#c9bea8;--slider-track:#c9bea8;--slider-progress:#1858c2;--slider-above:#4f8cff;--pill-bg:#e0d8cc;--pill-active-bg:#1858c2;--pill-active-ink:#fff;--pill-past-bg:#d0c8bc;--pill-past-ink:#4a3d2b;--tab-active-border:#1858c2;--color-error:#c0392b;--color-success:#2e7d32;--color-stat-default:#2e6be6;--feedback-bg:#1a0f12;--feedback-bg-hover:#2d1d22;--feedback-ink:#fff}[data-theme=dark]{--bg:#0d1117;--bg-raised:#13181f;--ink:#f0f2f5;--ink-muted:#b8bec8;--ink-faint:#8a96a8;--border:#2d2f34;--accent:#4f8cff;--accent-hover:#3a75e8;--mid-bg:#10141a;--mid-border:#1e2330;--slider-track:#1e2330;--slider-progress:#4f8cff;--slider-above:#4f8cff;--pill-bg:#161c25;--pill-active-bg:#4f8cff;--pill-active-ink:#fff;--pill-past-bg:#131820;--pill-past-ink:#8a9099;--tab-active-border:#4f8cff;--color-error:#e57373;--color-success:#4caf50;--color-stat-default:#2e6be6;--feedback-bg:#e8e3d8;--feedback-bg-hover:#d6cfc0;--feedback-ink:#1a0f12}[data-theme=sepia]{--bg:#f4efe6;--bg-raised:#ede6d9;--ink:#2c1a0e;--ink-muted:#6b4c2a;--ink-faint:#8c6b47;--border:#d4c4a8;--accent:#8b4513;--accent-hover:#6b3410;--sidebar-bg:#1a0f08;--sidebar-ink:#d4b896;--sidebar-ink-muted:#8c6b47;--sidebar-active:#2a1810;--sidebar-hover:#221208;--mid-bg:#ede6d9;--mid-border:#c9b89a;--slider-track:#c9b89a;--slider-progress:#8b4513;--slider-above:sienna;--pill-bg:#ddd0b8;--pill-active-bg:#8b4513;--pill-active-ink:#fff;--pill-past-bg:#cfc0a6;--pill-past-ink:#5c3d1e;--tab-active-border:#8b4513;--color-error:#c0392b;--color-success:#2e7d32;--color-stat-default:#8b4513;--feedback-bg:#1a0f12;--feedback-bg-hover:#2d1d22;--feedback-ink:#faf3e0}[data-theme=crimson]{--bg:#faf6f5;--bg-raised:#f3ecea;--ink:#1a0f12;--ink-muted:#5a3a40;--ink-faint:#6a484f;--border:#d8c8c8;--accent:#9d1f2a;--accent-hover:#7d1820;--sidebar-bg:#1f1a1c;--sidebar-ink:#d6c8c8;--sidebar-ink-muted:#8c7878;--sidebar-active:#2a2326;--sidebar-hover:#261f22;--mid-bg:#f3ecea;--mid-border:#d0bebe;--slider-track:#d0bebe;--slider-progress:#9d1f2a;--slider-above:#c43844;--pill-bg:#ebdcdc;--pill-active-bg:#9d1f2a;--pill-active-ink:#fff;--pill-past-bg:#dbc8c8;--pill-past-ink:#4a2228;--tab-active-border:#9d1f2a;--color-error:#c0392b;--color-success:#2e7d32;--color-stat-default:#9d1f2a;--feedback-bg:#1a0f12;--feedback-bg-hover:#2d1d22;--feedback-ink:#faf6f5}[data-theme=crimson-dark]{--bg:#1a1416;--bg-raised:#221a1c;--ink:#f0e6e6;--ink-muted:#c0a8a8;--ink-faint:#998080;--border:#3a2e30;--accent:#ef5260;--accent-hover:#d63e4c;--sidebar-bg:#110d0e;--sidebar-ink:#c8b8b8;--sidebar-ink-muted:#7a6868;--sidebar-active:#1a1416;--sidebar-hover:#16100f;--mid-bg:#1d1719;--mid-border:#2a2224;--slider-track:#2a2224;--slider-progress:#ef5260;--slider-above:#f37b86;--pill-bg:#221b1d;--pill-active-bg:#ef5260;--pill-active-ink:#1a0f12;--pill-past-bg:#1d1719;--pill-past-ink:#a89090;--tab-active-border:#ef5260;--color-error:#ff8a8a;--color-success:#66bb6a;--color-stat-default:#ef5260;--feedback-bg:#f3ecea;--feedback-bg-hover:#e3d7d4;--feedback-ink:#1a0f12}[data-theme=forest]{--bg:#0a110a;--bg-raised:#0f1a0f;--ink:#e8f0e8;--ink-muted:#9ab89a;--ink-faint:#7a987a;--border:#1e321e;--accent:#4caf50;--accent-hover:#388e3c;--sidebar-bg:#060d06;--sidebar-ink:#9ab89a;--sidebar-ink-muted:#5a785a;--sidebar-active:#0f1a0f;--sidebar-hover:#0c160c;--mid-bg:#0d160d;--mid-border:#1a2e1a;--slider-track:#1a2e1a;--slider-progress:#4caf50;--slider-above:#66bb6a;--pill-bg:#0f1a0f;--pill-active-bg:#4caf50;--pill-active-ink:#fff;--pill-past-bg:#0c160c;--pill-past-ink:#5a785a;--tab-active-border:#4caf50;--color-error:#e57373;--color-success:#66bb6a;--color-stat-default:#4caf50;--feedback-bg:#e8f0e8;--feedback-bg-hover:#d4dfd4;--feedback-ink:#0a110a}.skip-link{z-index:10000;background:var(--accent);color:#fff;font-family:var(--font-display);border-radius:0 0 6px 6px;padding:8px 16px;font-size:14px;font-weight:600;text-decoration:none;transition:top .1s;position:fixed;top:-100%;left:8px}.skip-link:focus{outline-offset:2px;outline:2px solid #fff;top:0}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overflow:hidden}body{font-family:var(--font-body);color:var(--ink);background-color:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}button{cursor:pointer;font-family:inherit;font-size:inherit;color:inherit;background:0 0;border:none}button:disabled{cursor:not-allowed;opacity:.55}ol,ul{list-style:none}.app-layout{height:100%;display:flex;overflow:hidden}.app-layout__main{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.sidebar{background:var(--sidebar-bg);width:220px;color:var(--sidebar-ink);border-right:1px solid #ffffff0f;flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.sidebar__header{border-bottom:1px solid #ffffff14;flex-shrink:0;padding:20px 16px 14px}.sidebar__title{font-family:var(--font-display);color:var(--sidebar-ink);white-space:nowrap;text-overflow:ellipsis;letter-spacing:.02em;cursor:pointer;text-align:left;background:0 0;border:none;width:100%;padding:0;font-size:15px;font-weight:700;overflow:hidden}.sidebar__title:hover{color:#fff}.sidebar__title:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:2px}.sidebar__title-input{font-family:var(--font-display);color:var(--sidebar-ink);letter-spacing:.02em;background:#ffffff1a;border:1px solid #ffffff40;border-radius:4px;outline:none;width:100%;padding:2px 6px;font-size:15px;font-weight:700}.sidebar__title-input:focus-visible{border-color:var(--accent);outline:2px solid var(--accent);outline-offset:1px}.sidebar__series-kicker{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;color:var(--sidebar-ink-muted);white-space:nowrap;text-overflow:ellipsis;margin-bottom:3px;font-size:10px;font-weight:600;display:block;overflow:hidden}.sidebar__char-list{flex:1;min-height:0;padding:8px 0;overflow:hidden auto}.sidebar__char-list::-webkit-scrollbar{width:4px}.sidebar__char-list::-webkit-scrollbar-track{background:0 0}.sidebar__char-list::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}.sidebar__empty{color:var(--sidebar-ink-muted);padding:12px 16px;font-size:13px;font-style:italic}.sidebar__char-item{text-align:left;border-left:3px solid #0000;border-radius:0;align-items:center;gap:10px;width:100%;padding:8px 14px;transition:background .12s;display:flex}.sidebar__char-item:hover{background:var(--sidebar-hover)}.sidebar__char-item.active{background:var(--sidebar-active);border-left-color:var(--accent)}.sidebar__char-item:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.sidebar__avatar{width:32px;height:32px;font-family:var(--font-display);letter-spacing:.04em;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.sidebar__char-info{flex-direction:column;gap:1px;min-width:0;display:flex}.sidebar__char-name{font-family:var(--font-display);color:var(--sidebar-ink);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.sidebar__char-subtitle{color:var(--sidebar-ink-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.sidebar__actions{border-top:1px solid #ffffff14;flex-shrink:0;padding:12px 14px}.sidebar__add-btn{width:100%;color:var(--sidebar-ink-muted);font-family:var(--font-display);letter-spacing:.04em;border:1px solid #ffffff26;border-radius:6px;padding:8px 12px;font-size:12px;font-weight:600;transition:background .12s,color .12s,border-color .12s}.sidebar__add-btn:hover:not(:disabled){background:var(--sidebar-hover);color:var(--sidebar-ink);border-color:#ffffff40}.sidebar__add-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.chapter-slider{background:var(--mid-bg);border-right:1px solid var(--mid-border);flex-direction:column;flex-shrink:0;width:200px;padding:16px 0;display:flex;position:relative;overflow:visible}.chapter-slider__scroll{flex:1;min-height:0;overflow:hidden auto}.chapter-slider__extra-section{flex-direction:column;flex-shrink:0;gap:2px;padding:6px 12px 6px 16px;display:flex}.chapter-slider__extra-pill{text-align:left;cursor:pointer;width:100%;font-family:var(--font-display);color:#ffffff73;white-space:nowrap;text-overflow:ellipsis;background:0 0;border:none;border-radius:5px;padding:5px 10px;font-size:12px;font-style:italic;transition:background .12s,color .12s;display:block;overflow:hidden}.chapter-slider__extra-pill:hover{background:var(--sidebar-hover);color:#fffc}.chapter-slider__extra-pill.active{background:var(--sidebar-active);color:#fff;font-style:normal;font-weight:600}.chapter-slider__scroll::-webkit-scrollbar{width:4px}.chapter-slider__scroll::-webkit-scrollbar-track{background:0 0}.chapter-slider__scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.chapter-slider__track{cursor:ns-resize;flex-direction:column;align-items:center;width:10px;display:flex;position:absolute;top:0;bottom:0;left:10px}.chapter-slider__track:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}.chapter-slider__track:before{content:"";background:var(--slider-track);pointer-events:none;border-radius:1px;width:2px;position:absolute;top:0;bottom:0;left:4px}.chapter-slider__progress{z-index:1;background:var(--slider-above);pointer-events:none;border-radius:1px;width:2px;min-height:0;transition:height .25s;position:relative}.chapter-slider__thumb{background:var(--slider-above);border:2px solid var(--mid-bg);cursor:grab;pointer-events:auto;z-index:2;border-radius:50%;width:10px;height:10px;transition:transform .15s,width .15s,height .15s;position:absolute;left:50%;transform:translate(-50%,-50%)}.chapter-slider__thumb:hover,.chapter-slider__thumb.dragging{cursor:grabbing;width:14px;height:14px}.chapter-slider__list{box-sizing:border-box;z-index:1;flex-direction:column;justify-content:space-evenly;gap:32px;min-height:100%;padding:8px 12px 8px 28px;display:flex;position:relative}.chapter-slider__item{position:relative}.chapter-pill__menu-btn{cursor:pointer;color:inherit;opacity:0;pointer-events:none;background:0 0;border:none;border-radius:3px;padding:2px 5px;font-size:14px;line-height:1;transition:opacity .1s;position:absolute;top:50%;right:4px;transform:translateY(-50%)}@media (hover:hover){.chapter-slider__item:hover .chapter-pill__menu-btn{opacity:1;pointer-events:auto}}.chapter-slider__item:focus-within .chapter-pill__menu-btn{opacity:1;pointer-events:auto}.chapter-pill__menu-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px;opacity:1;pointer-events:auto}.chapter-slider__pill{text-align:left;background:var(--pill-bg);width:100%;color:var(--ink-muted);border:1px solid #0000;border-radius:6px;align-items:center;gap:8px;padding:7px 10px;transition:background .12s,color .12s;display:flex}.chapter-slider__pill:hover{background:var(--bg-raised);color:var(--ink)}.chapter-slider__pill:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.chapter-slider__pill.past{background:var(--pill-past-bg);color:var(--slider-above)}.chapter-slider__pill.past .chapter-slider__pill-num{opacity:1}.chapter-slider__pill.active{background:var(--pill-active-bg);color:var(--pill-active-ink);border-color:#0000}.chapter-slider__pill-num{font-family:var(--font-display);text-align:center;opacity:.7;min-width:18px;font-size:11px;font-weight:700}.chapter-slider__pill.active .chapter-slider__pill-num{opacity:1}.chapter-slider__pill-title{font-size:12px;font-family:var(--font-display);white-space:nowrap;text-overflow:ellipsis;font-weight:500;display:block;overflow:hidden}.main-panel{background:var(--bg);flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}#write-view,#char-view,.write-view{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.editor-toolbar{background:var(--bg-raised);border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:2px;padding:6px 12px;display:flex}.editor-toolbar__btn{min-width:28px;height:28px;color:var(--ink-muted);background:0 0;border-radius:4px;justify-content:center;align-items:center;padding:0 6px;font-size:13px;line-height:1;transition:background .1s,color .1s;display:inline-flex}.editor-toolbar__btn:hover:not(:disabled){background:var(--border);color:var(--ink)}.editor-toolbar__btn.active{background:var(--accent);color:#fff}.editor-toolbar__btn:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.editor-toolbar__divider{background:var(--border);flex-shrink:0;width:1px;height:18px;margin:0 4px;display:inline-block}.editor-toolbar__select{border:1px solid var(--border);background:var(--bg);height:28px;color:var(--ink);font-family:var(--font-display);cursor:pointer;border-radius:4px;padding:0 6px;font-size:12px;transition:border-color .1s}.editor-toolbar__select:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}.story-action-bar{background:var(--bg-raised);border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:6px;padding:8px 14px;display:flex}.story-action-bar__btn{height:34px;font-family:var(--font-display);color:var(--ink-muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:5px;align-items:center;gap:6px;padding:0 14px;font-size:14px;line-height:1;transition:background .1s,color .1s;display:inline-flex}.story-action-bar__btn:hover{background:var(--border);color:var(--ink)}.story-action-bar__btn:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.story-action-bar__icon{font-size:15px;line-height:1}.story-action-bar__divider{background:var(--border);flex-shrink:0;width:1px;height:20px;margin:0 4px}.goals-bar{background:var(--bg);border-bottom:1px solid var(--border);font-family:var(--font-display);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:4px 0;padding:5px 14px;font-size:11px;display:flex;overflow-x:auto}.goals-bar__item{align-items:center;gap:4px;padding:2px 8px;display:flex}.goals-bar__label{color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em;font-size:10px;font-weight:600}.goals-bar__value{color:var(--ink);font-weight:600}.goals-bar__goal,.goals-bar__value--muted{color:var(--ink-muted);font-weight:400}.goals-bar__divider{background:var(--border);flex-shrink:0;width:1px;height:14px}.goals-bar__progress-track{background:var(--border);border-radius:2px;flex-shrink:0;width:60px;height:3px;overflow:hidden}.goals-bar__progress-fill{background:var(--accent);border-radius:2px;min-width:0;height:100%;transition:width .3s}.goals-bar__pct{color:var(--ink-faint);flex-shrink:0;font-size:.7rem;font-weight:500;line-height:1}.write-editor{flex-direction:column;flex:1;min-width:0;padding:32px 48px 80px;display:flex;overflow-y:auto}.write-editor:focus-within{outline:2px solid var(--accent);outline-offset:4px;border-radius:4px}.write-editor::-webkit-scrollbar{width:6px}.write-editor::-webkit-scrollbar-track{background:0 0}.write-editor::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.write-editor__chapter-title{font-family:var(--font-display);color:var(--ink);letter-spacing:-.02em;border-bottom:1px solid var(--border);margin-bottom:24px;padding-bottom:16px;font-size:26px;font-weight:700}.write-editor__body{flex-direction:column;flex:1;display:flex}.write-editor__content,.tiptap{font-family:var(--font-body);color:var(--ink);outline:none;flex:1;max-width:680px;font-size:17px;line-height:1.75}.write-editor__content p,.tiptap p{margin-bottom:1em}.write-editor__content h1,.tiptap h1{font-family:var(--font-display);letter-spacing:-.01em;margin-top:1.25em;margin-bottom:.5em;font-size:1.8em;font-weight:700}.write-editor__content h2,.tiptap h2{font-family:var(--font-display);margin-top:1em;margin-bottom:.4em;font-size:1.4em;font-weight:700}.write-editor__content h3,.tiptap h3{font-family:var(--font-display);margin-top:.9em;margin-bottom:.3em;font-size:1.15em;font-weight:700}.write-editor__content h4,.tiptap h4{font-family:var(--font-display);margin-top:.8em;margin-bottom:.25em;font-size:1em;font-weight:700}.write-editor__content blockquote,.tiptap blockquote{border-left:3px solid var(--accent);color:var(--ink-muted);margin:1em 0;padding-left:16px;font-style:italic}.write-editor__content ul,.tiptap ul{margin-bottom:1em;padding-left:1.5em;list-style:outside}.write-editor__content ol,.tiptap ol{margin-bottom:1em;padding-left:1.5em;list-style:decimal}.write-editor__content li,.tiptap li{margin-bottom:.25em}.tiptap p.is-editor-empty:first-child:before{content:attr(data-placeholder);color:var(--ink-faint);float:left;pointer-events:none;height:0}.find-replace-bar{background:var(--bg);border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:6px;padding:7px 14px;display:none}.find-replace-bar.open{display:flex}.find-replace-bar__input{border:1px solid var(--border);background:var(--bg-raised);font-family:var(--font-body);color:var(--ink);border-radius:4px;outline:none;width:200px;padding:5px 10px;font-size:14px}.find-replace-bar__input:focus{border-color:var(--accent)}.find-replace-bar__input:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.find-replace-bar__input--replace{width:160px}.find-replace-bar__count{font-family:var(--font-mono);color:var(--ink-faint);white-space:nowrap;min-width:60px;font-size:11px}.find-replace-bar__btn{border:1px solid var(--border);background:var(--bg-raised);font-family:var(--font-display);color:var(--ink-muted);cursor:pointer;white-space:nowrap;border-radius:4px;padding:5px 10px;font-size:11px;font-weight:500}.find-replace-bar__btn:hover{color:var(--ink)}.find-replace-bar__btn--accent{background:color-mix(in srgb, var(--accent) 15%, var(--bg));color:var(--accent)}.find-replace-bar__btn--accent:hover{background:var(--accent);color:#fff}.find-replace-bar__sep{background:var(--border);flex-shrink:0;width:1px;height:18px;margin:0 2px}.find-replace-bar__close{width:24px;height:24px;color:var(--ink-faint);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;font-size:14px;display:flex}.find-replace-bar__close:hover{background:var(--bg-raised);color:var(--ink)}.manuscript-search-modal{background:var(--bg-card);border-radius:12px;flex-direction:column;width:640px;max-width:95vw;max-height:80vh;display:flex;overflow:hidden;box-shadow:0 8px 40px #00000059}.manuscript-search__header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px 12px;font-weight:600;display:flex}.manuscript-search__toolbar{border-bottom:1px solid var(--border);flex-direction:column;gap:8px;padding:12px 20px;display:flex}.manuscript-search__row{align-items:center;gap:8px;display:flex}.manuscript-search__input{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:6px;flex:1;padding:7px 10px;font-size:.9rem}.manuscript-search__input:focus{border-color:var(--accent);outline:none}.manuscript-search__input:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.manuscript-search__count{color:var(--text-muted);white-space:nowrap;text-align:right;min-width:80px;font-size:.8rem}.manuscript-search__results{flex:1;padding:8px 0;overflow-y:auto}.manuscript-search__chapter-header{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;background:var(--bg-card);padding:10px 20px 4px;font-size:.75rem;font-weight:600;position:sticky;top:0}.manuscript-search__result{text-align:left;cursor:pointer;width:100%;color:var(--text);background:0 0;border:none;padding:8px 20px;font-size:.85rem;line-height:1.5;transition:background .1s}.manuscript-search__result:hover{background:var(--bg-hover,#80808014)}.manuscript-search__result mark{color:inherit;background:#fac83266;border-radius:2px;font-weight:600}.manuscript-search__empty{text-align:center;color:var(--text-muted);padding:32px 20px;font-size:.9rem}.manuscript-search__replace-feedback{color:var(--accent);white-space:nowrap;text-align:right;min-width:80px;font-size:.8rem}mark.search-highlight{color:inherit;background:#ffe066;border-radius:2px}mark.search-highlight.current{color:#fff;background:#f90}[data-theme=dark] mark.search-highlight{color:#ffe066;background:#7a6000}[data-theme=dark] mark.search-highlight.current{color:#fff;background:#c70}.char-view{flex-direction:column;flex:1;display:flex;overflow:hidden}.char-view__header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:flex-start;padding:20px 24px 16px;display:flex}.char-view__identity{flex-direction:column;gap:3px;min-width:0;display:flex}.char-view__name{font-family:var(--font-display);color:var(--ink);letter-spacing:-.01em;font-size:20px;font-weight:700}.char-view__subtitle{color:var(--ink-muted);font-size:13px}.char-view__close{color:var(--ink-faint);border-radius:4px;flex-shrink:0;padding:2px 6px;font-size:22px;line-height:1;transition:color .12s,background .12s}.char-view__close:hover{color:var(--ink);background:var(--bg-raised)}.char-view__close:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.char-view__tabs{border-bottom:1px solid var(--border);flex-shrink:0;gap:0;padding:0 16px;display:flex;overflow-x:auto}.char-view__tabs::-webkit-scrollbar{height:0}.char-view__tab{font-family:var(--font-display);letter-spacing:.04em;color:var(--ink-muted);white-space:nowrap;border-bottom:2px solid #0000;border-radius:0;margin-bottom:-1px;padding:10px 14px;font-size:12px;font-weight:600;transition:color .12s,border-color .12s}.char-view__tab:hover{color:var(--ink)}.char-view__tab.active{color:var(--accent);border-bottom-color:var(--tab-active-border)}.char-view__tab:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.char-view__content{flex:1;padding:24px;overflow-y:auto}.char-view__placeholder{color:var(--ink-faint);font-size:14px;font-style:italic}.char-view__empty{color:var(--ink-faint);flex:1;justify-content:center;align-items:center;font-size:14px;font-style:italic;display:flex}.char-view__header{align-items:center}.char-view__header-left{flex:1;align-items:center;gap:14px;min-width:0;display:flex}.char-view__avatar{width:60px;height:60px;font-family:var(--font-display);letter-spacing:.04em;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:20px;font-weight:700;display:flex;position:relative;overflow:hidden}.char-view__avatar--clickable{cursor:pointer;border:none;padding:0;transition:filter .15s}.char-view__avatar-overlay{color:#fff;opacity:0;pointer-events:none;background:#00000073;border-radius:50%;justify-content:center;align-items:center;font-size:1rem;transition:opacity .15s;display:flex;position:absolute;inset:0}.char-view__avatar--clickable:hover .char-view__avatar-overlay{opacity:1}.char-view__badges{flex-wrap:wrap;gap:4px;margin-top:4px;display:flex}.char-view__badge{font-family:var(--font-display);letter-spacing:.05em;text-transform:uppercase;background:var(--bg-raised);color:var(--ink-muted);border:1px solid var(--border);border-radius:999px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-block}.char-view__badge--class{background:color-mix(in srgb, var(--accent) 12%, var(--bg));color:var(--accent);border-color:color-mix(in srgb, var(--accent) 30%, var(--border))}.char-view__notes{color:var(--ink-muted);white-space:pre-wrap;word-break:break-word;max-width:480px;margin-top:6px;font-size:13px}.char-view__header-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.char-view__action-btn{border:1px solid var(--border);background:var(--bg-raised);color:var(--ink-muted);font-family:var(--font-display);letter-spacing:.03em;border-radius:5px;padding:5px 12px;font-size:11px;font-weight:600;transition:background .12s,color .12s}.char-view__action-btn:hover:not(:disabled){background:var(--border);color:var(--ink)}.char-view__action-btn--danger:hover:not(:disabled){color:#991b1b;background:#fee2e2;border-color:#fca5a5}.char-view__tab-wrap{align-items:stretch;display:flex;position:relative}.char-view__tab-menu-btn{cursor:pointer;color:var(--ink-muted);opacity:0;pointer-events:none;background:0 0;border:none;border-radius:3px;align-self:center;padding:2px 5px;font-size:14px;line-height:1;transition:opacity .1s}@media (hover:hover){.char-view__tab-wrap:hover .char-view__tab-menu-btn{opacity:1;pointer-events:auto}}.char-view__tab-wrap:focus-within .char-view__tab-menu-btn{opacity:1;pointer-events:auto}.char-view__tab-menu-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px;opacity:1;pointer-events:auto}.char-view__tab-add{font-family:var(--font-display);color:var(--ink-faint);border-bottom:2px solid #0000;border-radius:0;margin-bottom:-1px;padding:8px 12px;font-size:16px;font-weight:400;line-height:1;transition:color .12s,background .12s}.char-view__tab-add:hover{color:var(--accent);background:color-mix(in srgb, var(--accent) 8%, var(--bg))}.char-view__tab-add:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.char-view__tab-rename-input{font-family:var(--font-display);border:1px solid var(--accent);background:var(--bg);color:var(--ink);border-radius:4px;outline:none;align-self:center;width:100px;padding:6px 10px;font-size:12px;font-weight:600}.char-view__tab-rename-input:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.tab-ctx-menu{z-index:1000;background:var(--bg-raised);border:1px solid var(--border);border-radius:6px;min-width:120px;padding:4px 0;position:fixed;overflow:hidden;box-shadow:0 4px 16px #00000026}.tab-ctx-menu__item{text-align:left;width:100%;font-family:var(--font-display);color:var(--ink);background:0 0;border:none;padding:8px 14px;font-size:12px;font-weight:500;transition:background .1s;display:block}.tab-ctx-menu__item:hover{background:var(--border)}.tab-ctx-menu__item:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.tab-ctx-menu__item--danger{color:#c0392b}.tab-ctx-menu__item--danger:hover{color:#991b1b;background:#fee2e2}.panel{flex-direction:column;gap:24px;display:flex}.panel__section{flex-direction:column;gap:8px;display:flex}.panel__section-header{align-items:center;gap:8px;display:flex}.panel__section-title{font-family:var(--font-display);letter-spacing:.07em;text-transform:uppercase;color:var(--ink-muted);font-size:11px;font-weight:700}.panel__section-title--lost{color:var(--ink-faint)}.panel__new-pill{font-family:var(--font-display);letter-spacing:.04em;background:color-mix(in srgb, var(--accent) 18%, var(--bg));color:var(--accent);border:1px solid color-mix(in srgb, var(--accent) 30%, var(--border));border-radius:999px;padding:2px 8px;font-size:10px;font-weight:700;display:inline-block}.panel__empty{color:var(--ink-faint);font-size:13px;font-style:italic}.panel__list{flex-direction:column;gap:4px;display:flex}.panel__item-row{background:var(--bg-raised);border:1px solid var(--border);border-radius:6px;justify-content:space-between;align-items:flex-start;gap:8px;padding:8px 10px;display:flex}.panel__item-row--lost{opacity:.65}.panel__item-main{flex-wrap:wrap;flex:1;align-items:center;gap:6px;min-width:0;display:flex}.panel__item-name{font-family:var(--font-display);color:var(--ink);font-size:13px;font-weight:600}.panel__item-value{color:var(--ink-muted);font-size:13px;font-family:var(--font-mono)}.panel__item-note{color:var(--ink-faint);font-size:12px;font-style:italic}.panel__item-badges{align-items:center;gap:4px;display:flex}.panel__badge{font-family:var(--font-display);letter-spacing:.06em;text-transform:uppercase;border-radius:3px;padding:1px 6px;font-size:9px;font-weight:700;display:inline-block}.panel__badge--new{background:color-mix(in srgb, #22c55e 18%, var(--bg));color:#16a34a;border:1px solid color-mix(in srgb, #22c55e 30%, var(--border))}.panel__badge--lost{background:color-mix(in srgb, #ef4444 12%, var(--bg));color:#b91c1c;border:1px solid color-mix(in srgb, #ef4444 25%, var(--border))}.panel__item-actions{flex-shrink:0;align-self:center;gap:4px;display:flex}.panel__btn--edit,.panel__btn--remove,.panel__btn--save,.panel__btn--cancel{font-family:var(--font-display);letter-spacing:.03em;border:1px solid var(--border);background:var(--bg);color:var(--ink-muted);cursor:pointer;border-radius:4px;padding:3px 8px;font-size:10px;font-weight:600;transition:background .1s,color .1s}.panel__btn--edit:hover{background:var(--border);color:var(--ink)}.panel__btn--remove:hover{color:#991b1b;background:#fee2e2;border-color:#fca5a5}.panel__btn--save{background:color-mix(in srgb, var(--accent) 15%, var(--bg));color:var(--accent);border-color:color-mix(in srgb, var(--accent) 30%, var(--border))}.panel__btn--save:hover{background:var(--accent);color:#fff}.panel__btn--cancel:hover{background:var(--border);color:var(--ink)}.panel__btn--add{border:1px solid var(--accent);background:color-mix(in srgb, var(--accent) 12%, var(--bg));color:var(--accent);font-family:var(--font-display);letter-spacing:.04em;cursor:pointer;border-radius:5px;align-self:flex-start;padding:5px 14px;font-size:11px;font-weight:600;transition:background .12s,color .12s}.panel__btn--add:hover:not(:disabled){background:var(--accent);color:#fff}.panel__add-form{flex-direction:column;gap:6px;display:flex}.panel__edit-form{flex:1}.panel__input{border:1px solid var(--border);background:var(--bg);color:var(--ink);font-family:var(--font-body);border-radius:5px;outline:none;padding:6px 10px;font-size:13px;transition:border-color .1s}.panel__input:focus{border-color:var(--accent)}.panel__input:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.panel__input--short{flex-shrink:0;width:80px}.panel__select{border:1px solid var(--border);background:var(--bg);color:var(--ink);font-family:var(--font-display);cursor:pointer;border-radius:5px;outline:none;flex-shrink:0;padding:6px 8px;font-size:12px}.panel__select:focus{border-color:var(--accent)}.panel__select:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.panel__color-input{border:1px solid var(--border);cursor:pointer;background:var(--bg);border-radius:4px;flex-shrink:0;width:32px;height:32px;padding:2px}.panel__form-row{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.panel__form-sep{color:var(--ink-faint);flex-shrink:0;font-size:13px}.panel__form-actions{gap:6px;display:flex}.panel__error{font-family:var(--font-display);color:#c0392b;font-size:11px;font-weight:500}.stat-row{flex-direction:column;align-items:stretch;gap:6px}.stat-row__main{flex:1;align-items:center;gap:8px;display:flex}.stat-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.stat-row__val{font-family:var(--font-mono);color:var(--ink);margin-left:auto;font-size:13px}.stat-row__max{color:var(--ink-faint)}.stat-delta{font-size:11px;font-weight:700}.stat-delta--up{color:#16a34a}.stat-delta--down{color:#c0392b}.stat-bar{background:var(--border);border-radius:3px;width:100%;height:5px;overflow:hidden}.stat-bar__fill{border-radius:3px;min-width:0;height:100%;transition:width .3s}.skill-rank{font-family:var(--font-display);letter-spacing:.05em;background:color-mix(in srgb, var(--accent) 14%, var(--bg));color:var(--accent);border:1px solid color-mix(in srgb, var(--accent) 28%, var(--border));border-radius:4px;flex-shrink:0;padding:1px 7px;font-size:10px;font-weight:700;display:inline-block}.modal-backdrop{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg);border:1px solid var(--border);border-radius:8px;width:90%;min-width:320px;max-width:480px;max-height:90vh;padding:1.5rem;position:relative;overflow-y:auto}.modal__title{font-family:var(--font-display);color:var(--ink);margin-bottom:1rem;font-size:1.1rem;font-weight:600}.modal__footer{justify-content:flex-end;gap:.5rem;margin-top:1.25rem;display:flex}.modal__btn{cursor:pointer;font-size:.875rem;font-family:var(--font-display);border:none;border-radius:4px;padding:.4rem 1rem;font-weight:600}.modal__btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.modal__btn--primary{background:var(--accent);color:#fff}.modal__btn--primary:hover{background:var(--accent-hover)}.modal__btn--secondary{background:var(--bg-raised);color:var(--ink);border:1px solid var(--border)}.modal__btn--danger{color:#fff;background:#c0392b}.modal__btn--danger:hover:not(:disabled){background:#a93226}.modal__btn--danger:disabled{opacity:.45;cursor:not-allowed}.modal__field{margin-bottom:.875rem}.modal__field--danger{border-top:1px solid var(--border);margin-top:.5rem;padding-top:.875rem}.modal__hint{color:var(--ink-muted);margin:.25rem 0 0;font-size:.75rem}.modal__label{color:var(--ink-muted);font-size:.8rem;font-family:var(--font-display);margin-bottom:.3rem;font-weight:500;display:block}.modal__input{border:1px solid var(--border);background:var(--bg-raised);width:100%;color:var(--ink);font-size:.9rem;font-family:var(--font-body);box-sizing:border-box;border-radius:4px;padding:.4rem .6rem}.modal__input:focus{outline:2px solid var(--accent);outline-offset:1px}.modal__textarea{border:1px solid var(--border);background:var(--bg-raised);width:100%;color:var(--ink);font-size:.9rem;font-family:var(--font-body);resize:vertical;box-sizing:border-box;border-radius:4px;min-height:60px;padding:.4rem .6rem}.modal__textarea:focus{outline:2px solid var(--accent);outline-offset:1px}.modal__select{border:1px solid var(--border);background:var(--bg-raised);width:100%;color:var(--ink);font-size:.9rem;font-family:var(--font-display);border-radius:4px;padding:.4rem .6rem}.modal__error{color:var(--color-error);margin-top:.25rem;font-size:.8rem}.modal__message{color:var(--ink-muted);margin:0;font-size:.9rem;line-height:1.5}.readonly-banner{background:color-mix(in srgb, var(--accent) 12%, var(--bg-raised));color:var(--ink);border-bottom:1px solid var(--border);font-size:.85rem;font-family:var(--font-display);text-align:center;grid-column:1/-1;padding:.45rem 1rem}.readonly-banner strong{color:var(--ink);font-weight:600}.share-modal__section{margin-bottom:1rem}.share-modal__section--bordered{border-top:1px solid var(--border);margin-top:1rem;margin-bottom:0;padding-top:1rem}.share-modal__heading{font-family:var(--font-display);color:var(--ink);margin:0 0 .5rem;font-size:.95rem;font-weight:600}.share-modal__hint{color:var(--ink-muted);margin:0 0 .75rem;font-size:.85rem;line-height:1.45}.share-modal__url-row{align-items:stretch;gap:.5rem;margin-bottom:.4rem;display:flex}.share-modal__url-row .modal__btn{flex-shrink:0}.share-modal__url-input{font-family:var(--font-mono);font-size:.8rem}.share-modal__warning{color:var(--ink-muted);margin:0 0 .875rem;font-size:.78rem;font-style:italic}.share-modal__invite-form{margin-top:.5rem}.share-modal__list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.share-modal__row{background:var(--bg-raised);border:1px solid var(--border);border-radius:4px;align-items:center;gap:.75rem;padding:.5rem .6rem;display:flex}.share-modal__row-meta{flex:1;min-width:0}.share-modal__row-line{color:var(--ink);font-size:.85rem}.share-modal__row-sub{color:var(--ink-muted);word-break:break-word;margin-top:.15rem;font-size:.75rem}.share-modal__row-actions{flex-shrink:0;gap:.4rem;display:flex}.share-modal__live{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.modal__color-grid{flex-wrap:wrap;gap:6px;margin-top:.4rem;display:flex}.char-modal__avatar-btn{border:2px dashed var(--border);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;padding:0;font-size:1.4rem;font-weight:700;transition:border-color .15s;display:flex;overflow:hidden}.char-modal__avatar-btn:hover{border-color:var(--accent)}.char-modal__avatar-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.char-modal__avatar-img{object-fit:cover;border-radius:50%;width:100%;height:100%}.modal__color-opt{cursor:pointer;border:2px solid #0000;border-radius:50%;width:28px;height:28px;transition:border-color .1s;position:relative}.modal__color-opt:hover{opacity:.85}.modal__color-opt:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.modal__color-opt--selected{box-shadow:0 0 0 1px var(--bg);border-color:var(--ink)!important}.color-swatch__check{color:#fff;pointer-events:none;text-shadow:0 1px 2px #0009;font-size:.75rem;font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.modal__chapter-list{flex-direction:column;gap:4px;margin-bottom:.5rem;list-style:none;display:flex}.modal__chapter-row{align-items:center;gap:6px;transition:opacity .12s;display:flex;position:relative}.modal__chapter-row.dragging{opacity:.35}.modal__chapter-row.drop-before:before,.modal__chapter-row.drop-after:after{content:"";background:var(--accent);pointer-events:none;border-radius:1px;height:2px;position:absolute;left:0;right:0}.modal__chapter-row.drop-before:before{top:-3px}.modal__chapter-row.drop-after:after{bottom:-3px}.modal__chapter-drag{color:var(--ink-muted);cursor:grab;-webkit-user-select:none;user-select:none;font-size:14px;line-height:inherit;background:0 0;border:none;flex-shrink:0;padding:0 2px}.modal__chapter-drag:active{cursor:grabbing}.modal__chapter-drag:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:2px}.modal__chapter-input{flex:1}.modal__chapter-delete{color:var(--ink-muted);cursor:pointer;background:0 0;border:none;padding:0 6px;font-size:1rem}.modal__chapter-delete:hover:not(:disabled){color:#c0392b}.modal__chapter-delete:disabled{opacity:.35;cursor:not-allowed}.modal__matter-intro{color:var(--ink-muted);margin:-4px 0 16px;font-size:13px}.modal__matter-subtitle{color:var(--ink-muted);margin:2px 0 10px;font-size:11px}.modal__matter-grid{flex-wrap:wrap;gap:8px;display:flex}.modal__matter-chip{border:1px solid var(--border);color:var(--ink-muted);font-family:var(--font-display);cursor:pointer;background:0 0;border-radius:999px;align-items:center;gap:5px;padding:6px 14px;font-size:13px;transition:background .12s,color .12s,border-color .12s;display:inline-flex}.modal__matter-chip:hover{border-color:var(--accent);color:var(--accent)}.modal__matter-chip.selected{background:color-mix(in srgb, var(--accent) 15%, var(--bg));border-color:var(--accent);color:var(--accent);font-weight:600}.modal__matter-chip-check{font-size:11px}.library-screen{background:var(--bg);flex-direction:column;height:100%;min-height:100vh;display:flex;overflow-y:auto}.library-screen__banner{background:var(--bg-raised);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:center;align-items:center;width:100%;padding:52px 48px;display:flex;position:relative}.library-screen__body{box-sizing:border-box;flex-direction:column;flex:1;align-items:center;width:100%;padding:36px 32px 64px;display:flex}.library-screen__stats{font-family:var(--font-display);color:var(--ink-muted);align-items:center;gap:14px;margin-bottom:28px;font-size:14px;display:flex}.library-screen__stat strong{color:var(--ink);font-weight:700}.library-screen__stat-sep{color:var(--border);font-size:16px}.library-screen__banner-nav{align-items:center;gap:8px;display:flex;position:absolute;top:50%;right:48px;transform:translateY(-50%)}.library-screen__nav-btn{border:1px solid var(--ink-faint);color:var(--ink-muted);font-family:var(--font-display);cursor:pointer;background:0 0;border-radius:6px;padding:6px 12px;font-size:12px;transition:color .15s,border-color .15s}.library-screen__nav-btn:hover{color:var(--ink);border-color:var(--ink)}.library-screen__nav-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.library-screen__logout{border:1px solid var(--ink-faint);color:var(--ink-muted);font-family:var(--font-display);cursor:pointer;background:0 0;border-radius:6px;padding:6px 12px;font-size:12px;transition:color .15s,border-color .15s}.library-screen__logout:hover{color:var(--ink);border-color:var(--ink)}.library-screen__logout:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.library-screen__actions{gap:10px;margin-bottom:32px;display:flex}.library-screen__action-btn{font-family:var(--font-display);cursor:pointer;background:var(--accent);border:1px solid var(--accent);color:#fff;border-radius:7px;padding:8px 18px;font-size:13px;font-weight:600;transition:background .15s,color .15s,border-color .15s}.library-screen__action-btn:hover{opacity:.88}.library-screen__action-btn--secondary{border:1px solid var(--border);color:var(--ink-muted);background:0 0}.library-screen__action-btn--secondary:hover{opacity:1;border-color:var(--ink-muted);color:var(--ink)}.library-screen__logo{font-family:var(--font-display);color:var(--ink);letter-spacing:-.04em;cursor:pointer;background:0 0;border:none;padding:0;font-size:56px;font-weight:700;transition:opacity .15s}.library-screen__logo:hover{opacity:.75}.library-screen__logo:focus-visible{outline:2px solid var(--accent);outline-offset:4px;border-radius:4px}.library-screen__grid{box-sizing:border-box;background-color:var(--bg-raised);border:1px solid var(--border);border-bottom:5px solid var(--border);border-radius:10px;grid-template-columns:repeat(auto-fit,160px);justify-content:center;gap:24px;width:100%;padding:28px 24px 22px;display:grid;box-shadow:0 3px 12px #0000001f,inset 0 2px 8px #0000000f}.book-card{border-radius:8px;flex-direction:column;gap:10px;display:flex;position:relative}.book-card--dragging{opacity:.5;outline:2px dashed var(--accent);outline-offset:3px}.book-card__cover-btn{z-index:2;color:#fff;opacity:0;cursor:pointer;background:#00000080;border:none;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:12px;line-height:1;transition:opacity .15s;display:flex;position:absolute;top:6px;right:32px}.book-card:hover .book-card__cover-btn{opacity:1}.book-card__ctx-menu{z-index:9999;background:var(--bg-raised);border:1px solid var(--border);border-radius:7px;min-width:140px;padding:4px;position:fixed;overflow:hidden;box-shadow:0 4px 16px #00000059}.book-card__ctx-item{text-align:left;width:100%;font-family:var(--font-display);color:var(--ink);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:8px 12px;font-size:13px;transition:background .1s;display:block}.book-card__ctx-item:hover{background:var(--bg)}.book-card__ctx-item:focus-visible{outline:2px solid var(--accent);outline-offset:-2px;background:var(--bg)}.book-card__more-btn{z-index:2;color:#fff;opacity:0;cursor:pointer;background:#0000008c;border:none;border-radius:4px;justify-content:center;align-items:center;width:22px;height:22px;font-size:15px;line-height:1;transition:opacity .15s;display:flex;position:absolute;bottom:6px;right:6px}.book-card:hover .book-card__more-btn{opacity:1}.book-card__more-btn:focus-visible{opacity:1;outline:2px solid var(--accent);outline-offset:2px}.book-card__delete{z-index:2;color:#fff;opacity:0;cursor:pointer;background:#00000080;border:none;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:14px;line-height:1;transition:opacity .15s;display:flex;position:absolute;top:6px;right:6px}.book-card:hover .book-card__delete:not(:disabled){opacity:1}.book-card__delete:disabled{display:none}.book-card__cover-wrap{aspect-ratio:2/3;background:var(--bg-raised);border:1px solid var(--border);cursor:pointer;border-radius:6px;width:100%;transition:transform .15s,box-shadow .15s;display:block;position:relative;overflow:hidden}.book-card__cover-wrap:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.book-card__cover-img{object-fit:cover;width:100%;height:100%}.book-card__cover-placeholder{width:100%;height:100%;color:var(--ink-faint);justify-content:center;align-items:center;display:flex}.book-card__upload-overlay{opacity:0;pointer-events:none;background:#00000073;justify-content:center;align-items:center;transition:opacity .15s;display:flex;position:absolute;inset:0}.book-card__cover-wrap:hover .book-card__upload-overlay{opacity:1;pointer-events:auto}.book-card__upload-icon{color:#fff;cursor:pointer;background:0 0;border:none;border-radius:50%;padding:8px;font-size:24px;line-height:1;transition:background .15s}.book-card__upload-icon:hover{background:#fff3}.book-card__meta{text-align:left;cursor:pointer;background:0 0;border:none;width:100%;padding:0 2px;font-family:inherit}.book-card__title{font-family:var(--font-display);color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.book-card__subtitle{color:var(--ink-faint);font-size:11px;font-family:var(--font-display);margin-top:2px}.book-card__wordcount{color:var(--ink-muted);font-size:12px;font-family:var(--font-display);margin-top:3px;font-weight:600}.book-card--new{aspect-ratio:2/3;border:2px dashed var(--border);cursor:pointer;color:var(--ink-faint);background:0 0;border-radius:6px;flex-direction:column;justify-content:center;align-items:center;gap:10px;font-family:inherit;transition:border-color .15s,color .15s,background .15s;display:flex}.book-card--new:hover,.book-card--import:hover{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb, var(--accent) 5%, var(--bg))}.book-card--import{aspect-ratio:2/3;border:2px dashed var(--border);cursor:pointer;color:var(--ink-faint);background:0 0;border-radius:6px;flex-direction:column;justify-content:center;align-items:center;gap:10px;font-family:inherit;transition:border-color .15s,color .15s,background .15s;display:flex}.book-card__plus{font-size:32px;font-weight:300;line-height:1}.book-card__new-label{font-family:var(--font-display);letter-spacing:.04em;text-transform:uppercase;font-size:12px;font-weight:600}.sidebar__library-btn-wrap{flex-shrink:0;padding:16px 14px 6px}.sidebar__site-name{font-family:var(--font-display);color:var(--sidebar-ink);letter-spacing:-.01em;cursor:pointer;text-align:left;background:0 0;border:none;margin-bottom:10px;padding:0;font-size:1.6rem;font-weight:800;line-height:1;transition:opacity .15s}.sidebar__site-name:hover{opacity:.75}.sidebar__library-btn{width:100%;color:var(--sidebar-ink-muted);font-family:var(--font-display);letter-spacing:.03em;text-align:left;background:#ffffff0f;border:1px solid #ffffff14;border-radius:5px;padding:6px 10px;font-size:11px;font-weight:500;transition:background .12s,color .12s}.sidebar__library-btn:hover{background:var(--sidebar-hover);color:var(--sidebar-ink)}.auth-screen{background:var(--bg);flex-direction:column;justify-content:center;align-items:center;min-height:100%;padding:32px 16px;display:flex;overflow-y:auto}.auth-card{background:var(--bg-raised);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:24px;width:100%;max-width:380px;padding:36px 32px 28px;display:flex}.auth-card__brand{text-align:center;flex-direction:column;align-items:center;gap:4px;display:flex}.auth-card__logo{font-family:var(--font-display);color:var(--ink);letter-spacing:-.03em;font-size:28px;font-weight:700}.auth-card__tagline{font-family:var(--font-display);letter-spacing:.06em;text-transform:uppercase;color:var(--ink-faint);font-size:11px;font-weight:500}.auth-card__form{flex-direction:column;gap:14px;display:flex}.auth-card__title{font-family:var(--font-display);color:var(--ink);letter-spacing:-.01em;margin-bottom:2px;font-size:16px;font-weight:700}.auth-card__field{flex-direction:column;gap:5px;display:flex}.auth-card__label{font-family:var(--font-display);letter-spacing:.04em;color:var(--ink-muted);text-transform:uppercase;font-size:11px;font-weight:600}.auth-card__input{border:1px solid var(--border);background:var(--bg);width:100%;color:var(--ink);font-family:var(--font-body);border-radius:6px;outline:none;padding:9px 12px;font-size:15px;transition:border-color .15s}.auth-card__input:focus{border-color:var(--accent)}.auth-card__input:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.auth-card__input:disabled{opacity:.6}.auth-card__error{font-family:var(--font-display);color:#c0392b;background:color-mix(in srgb, #c0392b 10%, var(--bg));border:1px solid color-mix(in srgb, #c0392b 25%, var(--border));border-radius:5px;padding:8px 12px;font-size:12px;font-weight:500}.auth-card__success{font-family:var(--font-display);color:#2ecc71;background:color-mix(in srgb, #2ecc71 10%, var(--bg));border:1px solid color-mix(in srgb, #2ecc71 25%, var(--border));border-radius:5px;padding:8px 12px;font-size:12px;font-weight:500}.auth-card__forgot-link{text-align:right;color:var(--ink-muted);cursor:pointer;background:0 0;border:none;margin-top:4px;padding:0;font-size:12px;display:block}.auth-card__forgot-link:hover{text-decoration:underline}.auth-card__forgot-link:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:2px}.auth-card__submit{background:var(--accent);color:#fff;width:100%;font-family:var(--font-display);letter-spacing:.04em;cursor:pointer;border:none;border-radius:6px;margin-top:4px;padding:10px;font-size:13px;font-weight:700;transition:background .15s}.auth-card__submit:hover:not(:disabled){background:var(--accent-hover)}.auth-card__submit:disabled{cursor:not-allowed;opacity:.6}.auth-card__switch{text-align:center;font-family:var(--font-display);color:var(--ink-muted);font-size:12px}.auth-card__switch-link{color:var(--accent);font-family:inherit;font-size:inherit;cursor:pointer;text-underline-offset:2px;background:0 0;border:none;padding:0;font-weight:600;text-decoration:underline}.auth-card__switch-link:hover{color:var(--accent-hover)}.verify-banner{z-index:9999;text-align:center;color:#fff;padding:12px;font-size:.9rem;position:fixed;top:0;left:0;right:0}.verify-banner--success{background:var(--color-success)}.verify-banner--error{background:var(--color-error)}.toast-container{z-index:10001;pointer-events:none;flex-direction:column;gap:8px;max-width:min(380px,100vw - 40px);display:flex;position:fixed;bottom:20px;right:20px}.toast{color:#fff;pointer-events:auto;border-radius:6px;align-items:flex-start;gap:10px;padding:12px 14px;font-size:.875rem;line-height:1.4;animation:.18s ease-out toast-in;display:flex;box-shadow:0 4px 16px #00000040}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.toast--error{background:var(--color-error)}.toast--success{background:var(--color-success)}.toast--info{background:var(--accent)}.toast__message{flex:1}.toast__dismiss{color:#fff;cursor:pointer;opacity:.8;background:0 0;border:none;padding:0 2px;font-size:1.1rem;line-height:1}.toast__dismiss:hover{opacity:1}.toast__dismiss:focus-visible{outline-offset:2px;outline:2px solid #fff}.auth-loading{background:var(--bg);justify-content:center;align-items:center;height:100%;display:flex}.auth-loading__spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite auth-spin}@keyframes auth-spin{to{transform:rotate(360deg)}}.ai-modal{min-width:420px;max-width:560px}.ai-modal__textarea{border:1px solid var(--border);background:var(--bg-raised);width:100%;color:var(--ink);font-family:var(--font-body);resize:vertical;box-sizing:border-box;border-radius:5px;outline:none;min-height:140px;padding:.5rem .75rem;font-size:14px}.ai-modal__textarea:focus{border-color:var(--accent)}.ai-modal__textarea:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.ai-modal__response{border:1px solid var(--border);background:var(--bg-raised);width:100%;min-height:200px;max-height:400px;color:var(--ink);font-family:var(--font-mono);resize:vertical;white-space:pre-wrap;word-break:break-word;box-sizing:border-box;border-radius:5px;outline:none;padding:.5rem .75rem;font-size:12px;overflow-y:auto}.ai-modal__response:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.ai-modal__success{font-family:var(--font-display);color:#16a34a;background:color-mix(in srgb, #16a34a 10%, var(--bg));border:1px solid color-mix(in srgb, #16a34a 25%, var(--border));border-radius:5px;padding:8px 12px;font-size:12px;font-weight:600}.ai-modal__status{font-family:var(--font-display);color:var(--ink-muted);font-size:12px;font-style:italic}.ask-claude{flex-direction:column;gap:0;height:100%;display:flex}.ask-claude--upsell{justify-content:center;align-items:center;padding:24px}.ask-claude__history{flex-direction:column;flex:1;gap:12px;padding-bottom:12px;display:flex;overflow-y:auto}.ask-claude__history::-webkit-scrollbar{width:4px}.ask-claude__history::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.ask-claude__empty{color:var(--ink-faint);text-align:center;flex:1;justify-content:center;align-items:center;font-size:13px;font-style:italic;display:flex}.ask-claude__bubble{flex-direction:column;max-width:80%;display:flex}.ask-claude__bubble--user{align-self:flex-end;align-items:flex-end}.ask-claude__bubble--claude{align-self:flex-start;align-items:flex-start}.ask-claude__bubble-label{font-family:var(--font-display);letter-spacing:.05em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:4px;font-size:10px;font-weight:600}.ask-claude__bubble-text{font-family:var(--font-body);white-space:pre-wrap;word-break:break-word;border-radius:8px;padding:10px 14px;font-size:14px;line-height:1.6}.ask-claude__bubble--user .ask-claude__bubble-text{background:var(--accent);color:#fff;border-bottom-right-radius:3px}.ask-claude__bubble--claude .ask-claude__bubble-text{background:var(--bg-raised);border:1px solid var(--border);color:var(--ink);border-bottom-left-radius:3px}.ask-claude__input-row{border-top:1px solid var(--border);flex-shrink:0;gap:8px;padding-top:12px;display:flex}.ask-claude__input{border:1px solid var(--border);background:var(--bg-raised);color:var(--ink);font-family:var(--font-body);border-radius:6px;outline:none;flex:1;min-width:0;padding:9px 12px;font-size:14px;transition:border-color .15s}.ask-claude__input:focus{border-color:var(--accent)}.ask-claude__input:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.ask-claude__send{background:var(--accent);color:#fff;font-family:var(--font-display);letter-spacing:.04em;cursor:pointer;white-space:nowrap;border:none;border-radius:6px;flex-shrink:0;padding:9px 16px;font-size:12px;font-weight:700;transition:background .15s}.ask-claude__send:hover:not(:disabled){background:var(--accent-hover)}.ask-claude__send:disabled{opacity:.55;cursor:not-allowed}.write-view-wrapper{flex:1;display:flex;overflow:hidden}.write-view-topbar{flex-shrink:0;align-items:stretch;gap:0;display:flex}.write-view-topbar .editor-toolbar{flex:1;min-width:0}.write-view-comments-btn{border-left:1px solid var(--border);font-family:var(--font-display);color:var(--ink-muted);white-space:nowrap;background:var(--bg-raised);flex-shrink:0;padding:5px 14px;font-size:12px;font-weight:600;transition:background .12s,color .12s;position:relative}.write-view-comments-btn:hover{background:var(--bg-raised);color:var(--ink)}.comments-badge{background:var(--accent);color:#fff;font-family:var(--font-mono);text-align:center;border-radius:10px;min-width:16px;padding:1px 5px;font-size:9px;font-weight:700;position:absolute;top:-4px;right:-4px}.comment-highlight{border-bottom:2px solid var(--accent);cursor:pointer;background:#c06a2d33;border-radius:2px;transition:background .15s}.comment-highlight:hover{background:#c06a2d59}[data-theme=dark] .comment-highlight{border-bottom-color:var(--accent);background:#e0884033}[data-theme=dark] .comment-highlight:hover{background:#e0884059}.comment-panel{background:var(--bg-raised);border-left:1px solid var(--border);flex-direction:column;flex-shrink:0;width:0;transition:width .2s;display:flex;overflow:hidden}.comment-panel.open{width:280px}.comment-panel-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.comment-panel-title{font-family:var(--font-display);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-muted);font-size:12px;font-weight:700}.comment-panel-close{width:24px;height:24px;color:var(--ink-muted);border-radius:4px;justify-content:center;align-items:center;font-size:16px;display:flex}.comment-panel-close:hover{background:var(--border);color:var(--ink)}.comment-list{flex:1;padding:12px;overflow-y:auto}.comment-list::-webkit-scrollbar{width:3px}.comment-list::-webkit-scrollbar-thumb{background:var(--border)}.comment-card{background:var(--bg);border:1px solid var(--border);cursor:pointer;border-radius:6px;margin-bottom:10px;padding:11px 13px;transition:border-color .15s;position:relative}.comment-card:hover{border-color:var(--accent)}.comment-card.active-comment{border-color:var(--accent);box-shadow:0 0 0 2px #c06a2d26}[data-theme=dark] .comment-card.active-comment{box-shadow:0 0 0 2px #e0884026}.comment-card-quote{font-family:var(--font-body);color:var(--ink-muted);border-left:2px solid var(--accent);text-overflow:ellipsis;white-space:nowrap;margin-bottom:7px;padding-left:7px;font-size:12px;font-style:italic;overflow:hidden}.comment-card-text{font-family:var(--font-body);color:var(--ink);margin-bottom:6px;font-size:13px;line-height:1.5}.comment-card-meta{font-family:var(--font-mono);color:var(--ink-muted);justify-content:space-between;align-items:center;font-size:10px;display:flex}.comment-card-del{border-radius:3px;padding:2px 4px;font-size:11px}.comment-card-del:hover{color:#c83232;background:#c832321a}.comment-empty{min-height:120px;color:var(--ink-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:16px;font-size:13px;font-style:italic;display:flex}.comment-add-form{border-top:1px solid var(--border);background:var(--bg-raised);flex-shrink:0;padding:12px}.comment-add-form.hidden{display:none}.comment-add-quote{font-family:var(--font-body);color:var(--ink-muted);border-left:2px solid var(--accent);text-overflow:ellipsis;white-space:nowrap;margin-bottom:8px;padding-left:7px;font-size:11px;font-style:italic;overflow:hidden}.comment-add-textarea{border:1px solid var(--border);background:var(--bg);width:100%;min-height:70px;font-family:var(--font-body);color:var(--ink);resize:none;border-radius:6px;outline:none;margin-bottom:8px;padding:8px 10px;font-size:13px}.comment-add-textarea:focus{border-color:var(--accent)}.comment-add-textarea:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.comment-add-row{justify-content:flex-end;gap:6px;display:flex}.comment-add-cancel{color:var(--ink-muted);font-size:11px;font-family:var(--font-display);border-radius:5px;padding:5px 12px}.comment-add-cancel:hover{background:var(--border);color:var(--ink)}.comment-add-save{background:var(--accent);color:#fff;font-size:11px;font-family:var(--font-display);border-radius:5px;padding:5px 14px;font-weight:600}.comment-add-save:hover{background:var(--accent-hover)}.editor-ctx-menu{background:var(--bg);border:1px solid var(--border);z-index:500;border-radius:8px;min-width:170px;padding:5px 0;display:none;position:fixed;box-shadow:0 4px 16px #0000001f}.editor-ctx-menu.open{display:block}.editor-ctx-menu__item{width:100%;color:var(--ink);text-align:left;font-size:13px;font-family:var(--font-body);align-items:center;padding:8px 14px;display:flex}.editor-ctx-menu__item:hover{background:var(--bg-raised)}.editor-ctx-menu__item:focus-visible{outline:2px solid var(--accent);outline-offset:-2px;background:var(--bg-raised)}.editor-ctx-menu__item--danger{color:#c83232}.editor-ctx-menu__item--danger:hover{background:#c832321a}.app-layout.sidebar-collapsed .sidebar{display:none}.sidebar-toggle-tab{clip-path:polygon(0% 0%,65% 12%,100% 50%,65% 88%,0% 100%);background:var(--mid-bg);width:20px;height:64px;filter:drop-shadow(0 0 1px var(--sidebar-ink-muted));cursor:pointer;color:var(--ink-muted);z-index:10;border:none;justify-content:flex-start;align-items:center;min-height:44px;padding-left:3px;font-size:16px;line-height:1;transition:background .12s,color .12s;display:flex;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar-toggle-tab:hover{background:var(--bg-raised);color:var(--ink)}.sidebar-toggle-tab:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.app-layout.focus-mode .sidebar,.app-layout.focus-mode .chapter-slider,.app-layout.focus-mode .story-action-bar{display:none}.write-view-focus-btn{border-left:1px solid var(--border);font-family:var(--font-display);color:var(--ink-muted);white-space:nowrap;background:var(--bg-raised);flex-shrink:0;padding:5px 10px;font-size:14px;transition:background .12s,color .12s;position:relative}.write-view-focus-btn:hover{background:var(--border);color:var(--ink)}.write-view-focus-btn.active{background:var(--accent);color:#fff}.write-view-focus-btn:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.chapter-slider__focus-btn{border:1px solid var(--mid-border);background:var(--mid-bg);width:calc(100% - 24px);min-height:44px;color:var(--ink-muted);font-family:var(--font-display);cursor:pointer;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;gap:6px;margin:0 12px 8px;padding:7px 10px;font-size:12px;font-weight:600;transition:background .12s,color .12s,border-color .12s;display:flex}.chapter-slider__focus-btn:hover{background:var(--bg-raised);color:var(--ink)}.chapter-slider__focus-btn.active{background:var(--accent);color:#fff;border-color:#0000}.chapter-slider__focus-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.sidebar__section-label{background:var(--sidebar-active);color:var(--sidebar-ink);letter-spacing:.07em;text-transform:uppercase;cursor:pointer;font-size:.76rem;font-weight:700;font-family:var(--font-display);border:1px solid #ffffff24;border-radius:6px;align-items:center;width:auto;margin:10px 14px 5px;padding:4px 12px;transition:background .15s,border-color .15s;display:inline-flex}.sidebar__section-label:hover{background:var(--sidebar-hover);border-color:#ffffff38}.sidebar__search{width:calc(100% - 28px);color:var(--sidebar-ink);font-family:var(--font-display);background:#ffffff0f;border:1px solid #ffffff1f;border-radius:5px;outline:none;margin:4px 14px 8px;padding:6px 10px;font-size:12px;display:block}.sidebar__search::placeholder{color:var(--sidebar-ink-muted)}.sidebar__search:focus{border-color:#ffffff40}.sidebar__search:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.story-day-popover{z-index:600;background:var(--bg);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:8px;min-width:200px;padding:12px 14px;display:flex;position:fixed;box-shadow:0 4px 20px #00000026}.story-day-popover__title{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:2px;font-size:10px;font-weight:700}.story-day-popover__field{flex-direction:column;gap:3px;display:flex}.story-day-popover__label{font-family:var(--font-display);color:var(--ink-muted);text-transform:uppercase;letter-spacing:.05em;font-size:10px;font-weight:600}.story-day-popover__input{border:1px solid var(--border);background:var(--bg-raised);color:var(--ink);font-family:var(--font-body);border-radius:4px;outline:none;width:100%;padding:5px 8px;font-size:13px}.story-day-popover__input:focus{border-color:var(--accent)}.story-day-popover__input:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.story-day-popover__actions{justify-content:flex-end;gap:6px;margin-top:4px;display:flex}.story-day-popover__btn{font-family:var(--font-display);cursor:pointer;border:none;border-radius:4px;padding:4px 12px;font-size:11px;font-weight:600}.story-day-popover__btn--save{background:var(--accent);color:#fff}.story-day-popover__btn--save:hover{background:var(--accent-hover)}.story-day-popover__btn--cancel{background:var(--bg-raised);color:var(--ink-muted);border:1px solid var(--border)}.story-day-popover__btn--cancel:hover{background:var(--border);color:var(--ink)}.chapter-slider__pill-annotations{opacity:.75;flex-direction:column;gap:1px;min-width:0;font-size:9px;line-height:1.2;display:flex;overflow:hidden}.chapter-slider__pill-annotation{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.chapter-slider__pill-char-badge{font-family:var(--font-mono);color:inherit;opacity:.8;background:#0000002e;border-radius:999px;flex-shrink:0;padding:1px 5px;font-size:9px;font-weight:700}.chapter-slider__pill.active .chapter-slider__pill-char-badge{opacity:1;background:#ffffff40}.notes-editor{border:1px solid var(--border);background:var(--bg-raised);border-radius:6px;min-height:300px;max-height:500px;margin-bottom:0;padding:12px 16px;overflow-y:auto}.notes-editor__content,.notes-editor .tiptap{font-family:var(--font-body);color:var(--ink);outline:none;min-height:280px;font-size:15px;line-height:1.7}.notes-editor .tiptap p{margin-bottom:.75em}.char-screen{background:var(--bg);flex:1;height:100%;padding:24px;overflow-y:auto}.char-screen__header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.char-screen__title{font-family:var(--font-display);color:var(--ink);font-size:1.4rem;font-weight:700}.char-screen__header-actions{align-items:center;gap:8px;display:flex}.char-screen__add-btn{border:1px solid var(--border);background:var(--bg-raised);color:var(--ink-muted);font-family:var(--font-display);cursor:pointer;border-radius:6px;padding:7px 14px;font-size:.8rem;font-weight:600;transition:background .12s,color .12s,border-color .12s}.char-screen__add-btn:hover{background:var(--border);color:var(--ink);border-color:var(--accent)}.char-screen__close-btn{border:1px solid var(--border);background:var(--bg-raised);width:32px;height:32px;color:var(--ink-muted);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;font-size:1.2rem;line-height:1;transition:background .12s,color .12s;display:flex}.char-screen__close-btn:hover{background:var(--border);color:var(--ink)}.char-screen__grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;display:grid}.char-screen__card{background:var(--bg-raised);border:1px solid var(--border);cursor:pointer;text-align:center;border-radius:10px;flex-direction:column;align-items:center;padding:16px;transition:border-color .12s,background .12s;display:flex}.char-screen__card:hover{border-color:var(--accent);background:var(--bg)}.char-screen__card:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.char-screen__avatar{width:56px;height:56px;font-family:var(--font-display);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin:0 auto 10px;font-size:1.4rem;font-weight:700;display:flex}.char-screen__name{font-family:var(--font-display);color:var(--ink);margin-bottom:4px;font-size:1rem;font-weight:700}.char-screen__subtitle{color:var(--ink-muted);font-size:.8rem}.char-screen__status{background:var(--bg);border:1px solid var(--border);color:var(--ink-muted);border-radius:99px;margin-top:6px;padding:2px 8px;font-size:.75rem;display:inline-block}.char-screen__empty{color:var(--ink-muted);padding-top:8px;font-size:.95rem;font-style:italic}.toggle-switch{cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--ink);align-items:center;gap:10px;font-size:.9rem;display:inline-flex}.toggle-switch input{opacity:0;width:0;height:0;position:absolute}.toggle-switch__track{background:var(--border);border-radius:99px;flex-shrink:0;width:42px;height:24px;transition:background .2s;position:relative}.toggle-switch input:checked+.toggle-switch__track{background:var(--accent)}.toggle-switch__thumb{background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #0003}.toggle-switch input:checked+.toggle-switch__track .toggle-switch__thumb{transform:translate(18px)}.theme-swatches{grid-template-columns:repeat(4,1fr);gap:.5rem;display:grid}.theme-swatch{cursor:pointer;background:0 0;border:2px solid #0000;border-radius:6px;flex-direction:column;align-items:center;gap:.3rem;padding:.4rem .25rem;transition:border-color .15s;display:flex}.theme-swatch:hover{border-color:var(--border)}.theme-swatch--active{border-color:var(--accent)}.theme-swatch:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.theme-swatch__preview{border-radius:4px;justify-content:center;align-items:center;width:100%;height:36px;display:flex}.theme-swatch__dot{border-radius:50%;width:12px;height:12px}.theme-swatch__label{font-family:var(--font-display);color:var(--ink-muted);letter-spacing:.02em;font-size:.72rem;font-weight:500}.theme-swatch--active .theme-swatch__label{color:var(--accent)}.char-timeline{margin-top:40px;padding:0 4px 32px}.char-timeline__heading{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:16px;font-size:.8rem;font-weight:700}.char-timeline__grid{border-left:1px solid var(--border);gap:0;display:grid}.char-timeline__ch-label{color:var(--ink-muted);font-size:.72rem;font-family:var(--font-display);border-right:1px solid var(--border);white-space:nowrap;text-overflow:ellipsis;padding:0 8px 10px;overflow:hidden}.char-timeline__bar-wrap{align-items:center;min-height:36px;display:grid}.char-timeline__bar{background:color-mix(in srgb, var(--accent) 12%, var(--bg-raised));border:1px solid color-mix(in srgb, var(--accent) 30%, var(--border));border-radius:6px;align-items:center;gap:8px;min-width:0;margin:3px 4px;padding:4px 10px 4px 4px;display:flex}.char-timeline__dot{width:26px;height:26px;font-size:.65rem;font-weight:700;font-family:var(--font-display);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex;overflow:hidden}.char-timeline__name{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;font-weight:600;overflow:hidden}.char-screen__tabs{border-bottom:2px solid var(--border);gap:4px;margin-bottom:20px;padding-bottom:0;display:flex}.char-screen__tab{font-family:var(--font-display);color:var(--ink-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:8px 18px;font-size:.85rem;font-weight:600;transition:color .12s,border-color .12s}.char-screen__tab:hover{color:var(--ink)}.char-screen__tab--active{color:var(--accent);border-bottom-color:var(--accent)}.rel-web{flex-direction:column;gap:16px;height:100%;display:flex}.rel-web__char-row{flex-wrap:wrap;gap:8px;padding:10px 0 4px;display:flex}.rel-web__char-pill{border:1px solid var(--border);background:var(--bg-raised);cursor:pointer;font-family:var(--font-display);color:var(--ink-muted);border-radius:999px;align-items:center;gap:8px;padding:4px 12px 4px 4px;font-size:.8rem;font-weight:600;transition:border-color .12s,background .12s;display:flex}.rel-web__char-pill:hover{border-color:var(--accent);color:var(--ink)}.rel-web__char-pill--active{border-color:var(--accent);background:var(--bg);color:var(--accent)}.rel-web__char-pill-name{white-space:nowrap}.rel-web__canvas-wrap{background:var(--bg-raised);border:1px solid var(--border);border-radius:12px;flex:1;min-height:420px;position:relative;overflow:hidden}.rel-web__svg{width:100%;height:100%;display:block}.rel-web__line{stroke:var(--accent);stroke-width:2px;stroke-dasharray:6 3;opacity:.7}.rel-web__line-label{font-family:var(--font-display);fill:var(--ink-muted);font-size:11px;font-weight:600}.rel-web__node-btn{cursor:pointer;background:0 0;border:none;border-radius:50%;padding:0;display:block}.rel-web__center-node,.rel-web__outer-node{cursor:pointer;flex-direction:column;align-items:center;gap:4px;display:flex}.rel-web__outer-node{opacity:.45;transition:opacity .15s}.rel-web__outer-node--connected,.rel-web__outer-node:hover{opacity:1}.rel-web__node-name{font-family:var(--font-display);color:var(--ink-muted);text-align:center;white-space:nowrap;text-overflow:ellipsis;max-width:80px;font-size:10px;font-weight:600;overflow:hidden}.rel-web__node-name--center{color:var(--ink);font-size:11px}.rel-web__hint{color:var(--ink-muted);pointer-events:none;white-space:nowrap;font-size:.75rem;position:absolute;bottom:12px;left:50%;transform:translate(-50%)}.rel-web__modal-backdrop{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.rel-web__modal{background:var(--bg-raised);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:14px;min-width:320px;max-width:440px;padding:24px;display:flex;box-shadow:0 8px 40px #0006}.rel-web__modal-title{font-family:var(--font-display);color:var(--ink);font-size:1rem;font-weight:700}.rel-web__modal-label{font-family:var(--font-display);color:var(--ink-muted);font-size:.8rem;font-weight:600}.rel-web__modal-footer{justify-content:flex-end;align-items:center;gap:8px;display:flex}.relationship-web__list{border-collapse:collapse;width:100%;font-size:.9rem}.relationship-web__list th,.relationship-web__list td{border:1px solid var(--border);text-align:left;padding:.4rem .6rem}.relationship-web__list th{background:var(--bg-raised);font-weight:600}.relationship-web__view-toggle{border:1px solid var(--border);cursor:pointer;color:var(--ink);background:0 0;border-radius:4px;margin:.5rem 0;padding:.25rem .75rem;font-size:.8rem;display:block}.relationship-web__view-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.modal__btn--danger{color:#fff;font-family:var(--font-display);cursor:pointer;background:#c0392b;border:1px solid #c0392b;border-radius:6px;margin-right:auto;padding:7px 14px;font-size:.8rem;font-weight:600;transition:background .12s}.modal__btn--danger:hover{background:#a93226;border-color:#a93226}.homepage{background:var(--bg);height:100%;min-height:100vh;color:var(--ink);font-family:var(--font-body);overflow-y:auto}.homepage__header{border-bottom:1px solid var(--border);background:var(--bg);z-index:10;justify-content:space-between;align-items:center;padding:20px 48px;display:flex;position:sticky;top:0}.homepage__logo{font-family:var(--font-display);color:var(--ink);letter-spacing:-.02em;font-size:1.6rem;font-weight:800;line-height:1}.homepage__nav-btn{font-family:var(--font-display);color:var(--ink-muted);border:1px solid var(--ink-faint);cursor:pointer;letter-spacing:.02em;background:0 0;border-radius:6px;padding:8px 16px;font-size:.85rem;font-weight:600;transition:color .15s,border-color .15s}.homepage__nav-btn:hover{color:var(--ink);border-color:var(--ink)}.homepage__hero{text-align:center;max-width:860px;margin:0 auto;padding:80px 48px 64px}.homepage__hero-title{font-family:var(--font-display);color:var(--ink);letter-spacing:-.03em;margin:0 0 20px;font-size:clamp(2.4rem,6vw,4rem);font-weight:800;line-height:1.1}.homepage__hero-sub{font-family:var(--font-body);color:var(--ink-muted,#fff9);max-width:560px;margin:0 auto;font-size:1.15rem;line-height:1.65}.homepage__posts{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:24px;max-width:1100px;margin:0 auto;padding:0 48px 80px;display:grid}.homepage__post-card{background:var(--bg-raised);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:12px;padding:28px 28px 24px;transition:border-color .15s,background .15s;display:flex}.homepage__post-card:hover{background:var(--bg-raised);border-color:var(--ink-muted)}.homepage__post-card--has-image{padding:0;overflow:hidden}.homepage__post-card--has-image .homepage__post-card-body{flex-direction:column;gap:10px;padding:20px 24px;display:flex}.homepage__post-card-body{flex-direction:column;gap:12px;padding:0;display:flex}.homepage__card-image-wrap{aspect-ratio:16/9;width:100%;overflow:hidden}.homepage__card-image{object-fit:cover;width:100%;height:100%;transition:transform .3s;display:block}.homepage__post-card:hover .homepage__card-image{transform:scale(1.03)}.homepage__post-tag{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;color:var(--accent,#7c9fff);background:#7c9fff1f;border-radius:20px;align-self:flex-start;padding:3px 10px;font-size:.7rem;font-weight:700;display:inline-block}.homepage__post-title{font-family:var(--font-display);color:var(--ink);letter-spacing:-.01em;margin:0;font-size:1.1rem;font-weight:700;line-height:1.3}.homepage__post-excerpt{font-family:var(--font-body);color:var(--ink-muted,#fff9);flex:1;margin:0;font-size:.95rem;line-height:1.6}.homepage__post-date{font-family:var(--font-mono);color:#ffffff59;margin-top:4px;font-size:.75rem}.homepage__add-post-btn{color:#fff6;font-family:var(--font-display);cursor:pointer;text-align:center;background:0 0;border:1px dashed #fff3;border-radius:12px;padding:28px;font-size:.85rem;font-weight:600;transition:border-color .15s,color .15s}.homepage__add-post-btn:hover{color:#ffffffb3;border-color:#fff6}.homepage__post-card{position:relative}.homepage__post-admin-btns{opacity:0;gap:4px;transition:opacity .12s;display:flex;position:absolute;top:12px;right:12px}.homepage__post-card:hover .homepage__post-admin-btns{opacity:1}.homepage__post-admin-btn{color:#fff9;cursor:pointer;background:#ffffff1a;border:none;border-radius:6px;justify-content:center;align-items:center;width:26px;height:26px;font-size:.9rem;transition:background .12s,color .12s;display:flex}.homepage__post-admin-btn:hover{color:#fff;background:#fff3}.homepage__post-admin-btn--danger:hover{color:#fff;background:#dc3c3c66}.homepage__editor{max-width:680px;margin:0 auto 40px;padding:0 48px}.homepage__editor-title{font-family:var(--font-display);color:var(--ink-muted,#fff9);letter-spacing:.04em;text-transform:uppercase;margin-bottom:16px;font-size:1rem;font-weight:700}.homepage__editor-fields{flex-direction:column;gap:10px;display:flex}.homepage__editor-input{color:#fff;font-family:var(--font-body);background:#ffffff0f;border:1px solid #ffffff1f;border-radius:8px;outline:none;width:100%;padding:10px 14px;font-size:.95rem;transition:border-color .15s}.homepage__editor-input:focus{border-color:var(--accent)}.homepage__editor-input:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.homepage__editor-textarea{color:#fff;font-family:var(--font-body);resize:vertical;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:8px;outline:none;width:100%;padding:10px 14px;font-size:.95rem;transition:border-color .15s}.homepage__editor-textarea:focus{border-color:var(--accent)}.homepage__editor-textarea:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.homepage__editor-actions{justify-content:flex-end;gap:10px;margin-top:14px;display:flex}.homepage__editor-btn{font-family:var(--font-display);cursor:pointer;border:none;border-radius:7px;padding:8px 20px;font-size:.85rem;font-weight:600;transition:background .12s,opacity .12s}.homepage__editor-btn--cancel{color:#fff9;background:#ffffff14}.homepage__editor-btn--cancel:hover{background:#ffffff24}.homepage__editor-btn--save{background:var(--accent);color:#fff}.homepage__editor-btn--save:hover:not(:disabled){background:var(--accent-hover)}.homepage__editor-btn--save:disabled{opacity:.5;cursor:not-allowed}.homepage__editor-image-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.homepage__editor-image-preview{object-fit:cover;border:1px solid #ffffff1f;border-radius:6px;width:120px;height:68px}.homepage__detail{max-width:720px;margin:0 auto;padding:0 48px 80px}.homepage__detail-topbar{justify-content:space-between;align-items:center;padding:24px 0 32px;display:flex}.homepage__detail-hero{aspect-ratio:16/9;border-radius:12px;width:100%;margin-bottom:36px;overflow:hidden}.homepage__detail-hero-img{object-fit:cover;width:100%;height:100%;display:block}.homepage__detail-body{flex-direction:column;gap:12px;display:flex}.homepage__detail-title{font-family:var(--font-display);color:var(--ink);letter-spacing:-.02em;margin:4px 0 0;font-size:clamp(1.6rem,4vw,2.4rem);font-weight:800;line-height:1.15}.homepage__detail-content{font-family:var(--font-body);color:var(--ink-muted,#fffc);flex-direction:column;gap:20px;margin-top:24px;font-size:1.1rem;line-height:1.75;display:flex}@media (width<=640px){.homepage__header{padding:16px 20px}.homepage__hero{padding:48px 20px 40px}.homepage__posts{grid-template-columns:1fr;padding:0 20px 48px}.homepage__detail{padding:0 20px 48px}.library-screen__banner{padding:28px 20px}.library-screen__body{padding:24px 16px 56px}.library-screen__actions{flex-wrap:wrap;justify-content:center}.library-screen__grid,.custom-shelf__row{padding:20px 12px 16px}.series-shelf__row{padding:18px 12px 16px}.library-row{gap:6px}.library-row__grip{width:28px}}.pro-badge{font-size:.7em;font-family:var(--font-display);letter-spacing:.03em;color:#f59e0b;vertical-align:middle;cursor:default;background:#f59e0b1f;border:1px solid #f59e0b4d;border-radius:4px;align-items:center;gap:3px;padding:1px 5px;font-weight:600;line-height:1.4;display:inline-flex}.pro-upsell{text-align:center;background:#f59e0b0f;border:1px solid #f59e0b40;border-radius:8px;flex-direction:column;align-items:center;gap:12px;padding:28px 24px;display:flex}.pro-upsell__badge{margin-bottom:4px}.pro-upsell__title{font-family:var(--font-display);color:var(--ink-strong,var(--ink,inherit));margin:0;font-size:1.1rem;font-weight:600}.pro-upsell__body{max-width:42ch;color:var(--ink-muted);margin:0;font-size:.95rem;line-height:1.5}.pro-upsell__cta{margin-top:8px}.series-shelf{width:100%;margin-bottom:32px}.series-shelf__header{align-items:center;gap:12px;margin-bottom:12px;display:flex}.series-shelf__title{font-family:var(--font-display);color:var(--ink);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:2px 4px;font-size:1.05rem;font-weight:600;transition:background .15s}.series-shelf__title:hover{background:color-mix(in srgb, var(--ink) 8%, transparent)}.series-shelf__title:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.series-shelf__title-input{font-family:var(--font-display);color:var(--ink);background:var(--bg);border:1px solid var(--accent);border-radius:6px;padding:2px 6px;font-size:1.05rem;font-weight:600}.series-shelf__action{font-size:.78rem;font-family:var(--font-display);color:var(--accent);border:1px solid var(--accent);cursor:pointer;background:0 0;border-radius:6px;align-items:center;gap:6px;padding:3px 10px;font-weight:500;transition:background .15s,color .15s;display:inline-flex}.series-shelf__action:hover:not(:disabled){background:var(--accent);color:#fff}.series-shelf__action:disabled{opacity:.6;cursor:default}.series-shelf__row{box-sizing:border-box;background-color:var(--bg-raised);border:1px solid var(--border);border-bottom:5px solid var(--border);border-radius:10px;flex-wrap:wrap;justify-content:center;gap:16px;padding:24px 22px 20px;display:flex;box-shadow:0 3px 12px #0000001f,inset 0 2px 8px #0000000f}.library-screen__unshelved-section{width:100%}.library-screen__shelf-title{font-family:var(--font-display);color:var(--ink);margin:0 0 12px;font-size:1.05rem;font-weight:600}.library-screen__shelf-empty{text-align:center;width:100%;font-family:var(--font-display);color:var(--ink-muted);grid-column:1/-1;margin:0;padding:18px;font-size:.85rem}.library-row{align-items:stretch;gap:8px;width:100%;margin-bottom:32px;display:flex;position:relative}.library-row--dragging{opacity:.5;outline:2px dashed var(--accent);outline-offset:3px}.book-card--drop-before:after,.series-book-card--drop-before:after,.series-book-card--drop-after:after{content:"";background:var(--accent);pointer-events:none;border-radius:2px;width:3px;position:absolute;top:-4px;bottom:-4px}.book-card--drop-before:after{left:-12px}.series-book-card--drop-before:after{left:-8px}.series-book-card--drop-after:after{right:-8px}.library-row--drop-before:after{content:"";background:var(--accent);pointer-events:none;border-radius:2px;height:3px;position:absolute;top:-16px;left:0;right:0}.library-row__grip{background:var(--bg-raised);border:1px solid var(--border);border-bottom:5px solid var(--border);width:24px;color:var(--ink-muted);cursor:grab;border-radius:10px;flex:none;justify-content:center;align-self:stretch;align-items:center;padding:0;transition:color .15s,border-color .15s;display:flex}.library-row__grip:hover{color:var(--ink);border-color:var(--ink-muted)}.library-row__grip:active{cursor:grabbing}.library-row__grip:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.library-row__content{flex:auto;min-width:0}.library-row__content>.series-shelf,.library-row__content>.custom-shelf,.library-row__content>.library-screen__unshelved-section{margin-bottom:0}.custom-shelf{width:100%;margin-bottom:32px}.custom-shelf__header{align-items:center;gap:12px;margin-bottom:12px;display:flex}.custom-shelf__title{font-family:var(--font-display);color:var(--ink);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:2px 4px;font-size:1.05rem;font-weight:600;transition:background .15s}.custom-shelf__title:hover{background:color-mix(in srgb, var(--ink) 8%, transparent)}.custom-shelf__title:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.custom-shelf__title-input{font-family:var(--font-display);color:var(--ink);background:var(--bg);border:1px solid var(--accent);border-radius:6px;padding:2px 6px;font-size:1.05rem;font-weight:600}.custom-shelf__delete{font-family:var(--font-display);color:var(--ink-muted);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:6px;padding:3px 10px;font-size:.78rem;transition:color .15s,border-color .15s}.custom-shelf__delete:hover{color:var(--danger,#c0392b);border-color:var(--danger,#c0392b)}.custom-shelf__delete:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.custom-shelf__row{box-sizing:border-box;background-color:var(--bg-raised);border:1px solid var(--border);border-bottom:5px solid var(--border);border-radius:10px;grid-template-columns:repeat(auto-fit,160px);justify-content:center;gap:24px;padding:28px 24px 22px;display:grid;box-shadow:0 3px 12px #0000001f,inset 0 2px 8px #0000000f}.custom-shelf--shared .custom-shelf__title{cursor:default}.custom-shelf--shared .custom-shelf__title:hover{background:0 0}.book-card__shared-by{color:var(--ink-muted);background:color-mix(in srgb, var(--ink) 7%, transparent);text-overflow:ellipsis;white-space:nowrap;border-radius:999px;max-width:100%;padding:2px 8px;font-size:.7rem;display:inline-block;overflow:hidden}.book-card__shared-by strong{color:var(--ink);font-weight:600}.series-book-card{background:var(--bg-raised);border:1px solid var(--border);text-align:center;border-radius:10px;flex-direction:column;align-items:center;gap:8px;width:120px;padding:12px 8px;transition:border-color .15s,box-shadow .15s;display:flex;position:relative}.series-book-card:hover{border-color:var(--accent);box-shadow:0 2px 12px #1858c226}.series-book-card--dragging{opacity:.5;outline:2px dashed var(--accent);outline-offset:3px}.series-book-card__cover-btn{z-index:2;color:#fff;opacity:0;cursor:pointer;background:#00000080;border:none;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:12px;line-height:1;transition:opacity .15s;display:flex;position:absolute;top:6px;right:6px}.series-book-card:hover .series-book-card__cover-btn,.series-book-card__cover-btn:focus-visible{opacity:1}.series-book-card__more-btn{z-index:2;color:#fff;opacity:0;cursor:pointer;background:#0000008c;border:none;border-radius:4px;justify-content:center;align-items:center;width:22px;height:22px;font-size:15px;line-height:1;transition:opacity .15s;display:flex;position:absolute;top:6px;left:6px}.series-book-card:hover .series-book-card__more-btn,.series-book-card__more-btn:focus-visible{opacity:1}.series-book-card__more-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.series-book-card__cover-wrap{aspect-ratio:2/3;background:var(--bg);border:1px solid var(--border);cursor:pointer;border-radius:6px;width:64px;padding:0;transition:transform .15s,box-shadow .15s;display:block;overflow:hidden}.series-book-card__cover-wrap:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.series-book-card__cover-img{object-fit:cover;width:100%;height:100%}.series-book-card__cover-placeholder{width:100%;height:100%;color:var(--ink-faint);justify-content:center;align-items:center;display:flex}.series-book-card__meta-btn{cursor:pointer;text-align:center;background:0 0;border:none;flex-direction:column;align-items:center;gap:4px;width:100%;padding:0;font-family:inherit;display:flex}.series-book-card__name{font-family:var(--font-display);color:var(--ink);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.75rem;font-weight:600;line-height:1.3;display:-webkit-box;overflow:hidden}.series-book-card__meta{color:var(--ink-muted);margin:0;font-size:.68rem}.book-card__ctx-item--locked{color:var(--ink-muted)}.book-card__ctx-item--danger{color:#c83232}.book-card__ctx-item--danger:hover,.book-card__ctx-item--danger:focus-visible{background:#c832321f}.export-modal__scope{border-bottom:1px solid var(--border);gap:16px;margin-bottom:16px;padding-bottom:12px;display:flex}.export-modal__scope-label{color:var(--ink);cursor:pointer;align-items:center;gap:6px;font-size:.875rem;display:flex}.goals-modal__scope{border:0;border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:16px;margin:0 0 16px;padding:0 0 12px;display:flex}.goals-modal__scope-legend{color:var(--ink-muted);padding:0;font-size:.8rem;font-weight:600}.goals-modal__scope-label{color:var(--ink);cursor:pointer;align-items:center;gap:6px;font-size:.875rem;display:flex}.demo-banner{z-index:9999;color:#fef3c7;font-size:.85rem;font-family:var(--font-display);background:#b45309;justify-content:center;align-items:center;gap:1.5rem;padding:.5rem 1rem;display:flex;position:fixed;top:0;left:0;right:0}.demo-banner__text{opacity:.9}.demo-banner__cta{color:#92400e;font-size:.8rem;font-family:var(--font-display);cursor:pointer;background:#fef3c7;border:none;border-radius:4px;padding:.25rem .75rem;font-weight:700}.demo-banner__cta:hover{background:#fffbeb}.app-layout.demo-active{padding-top:2.25rem}.auth-screen__demo-link{justify-content:center;gap:.75rem;margin-top:1rem;display:flex}.auth-screen__try-btn{background:var(--accent);color:#fff;font-size:.875rem;font-family:var(--font-display);cursor:pointer;border:none;border-radius:8px;padding:.6rem 1.25rem;font-weight:600;transition:opacity .15s}.auth-screen__try-btn:hover{opacity:.88}.auth-screen__pricing-btn{border:1.5px solid var(--border);color:var(--ink);font-size:.875rem;font-family:var(--font-display);cursor:pointer;background:0 0;border-radius:8px;padding:.6rem 1.25rem;font-weight:500;transition:border-color .15s,color .15s}.auth-screen__pricing-btn:hover{border-color:var(--ink-muted)}.pricing-screen{background:var(--bg);min-height:100vh;color:var(--ink);flex-direction:column;align-items:center;padding:3rem 1.5rem;display:flex}.pricing-screen__header{text-align:center;width:100%;max-width:700px;margin-bottom:3rem}.pricing-screen__back{color:var(--ink-muted);cursor:pointer;font-size:.9rem;font-family:var(--font-display);background:0 0;border:none;margin-bottom:1.5rem;display:block}.pricing-screen__back:hover{color:var(--ink)}.pricing-screen__title{font-size:2.2rem;font-family:var(--font-display);margin:0 0 .5rem;font-weight:700}.pricing-screen__sub{color:var(--ink-muted);margin:0}.pricing-interval-toggle{background:var(--bg);border:1px solid var(--border);border-radius:8px;gap:3px;margin-bottom:2rem;padding:3px;display:flex}.pricing-interval-toggle__btn{color:var(--ink-muted);font-size:.85rem;font-family:var(--font-display);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:.5rem;padding:.4rem 1.1rem;font-weight:500;transition:background .15s,color .15s;display:flex}.pricing-interval-toggle__btn--active{background:var(--bg-raised);color:var(--ink);box-shadow:0 1px 3px #00000014}.pricing-interval-toggle__save{color:#fff;letter-spacing:.02em;background:#16a34a;border-radius:999px;padding:.15rem .45rem;font-size:.7rem;font-weight:700}.pricing-screen__grid{flex-wrap:wrap;justify-content:center;gap:2rem;width:100%;max-width:820px;display:flex}.pricing-tier{background:var(--bg-raised);border:1px solid var(--border);border-radius:12px;flex-direction:column;flex:1;min-width:280px;max-width:380px;padding:2rem;display:flex;position:relative}.pricing-tier--pro{border-color:var(--accent)}.pricing-tier__badge{background:var(--accent);color:#fff;font-size:.7rem;font-family:var(--font-display);white-space:nowrap;text-transform:uppercase;letter-spacing:.05em;border-radius:999px;padding:.2rem .75rem;font-weight:700;position:absolute;top:-.75rem;left:50%;transform:translate(-50%)}.pricing-tier__name{font-size:1.1rem;font-family:var(--font-display);color:var(--ink-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.5rem;font-weight:700}.pricing-tier__price{font-size:2rem;font-family:var(--font-display);margin-bottom:1.5rem;font-weight:700}.pricing-tier__price span{color:var(--ink-muted);font-size:.9rem;font-weight:400}.pricing-tier__price-sub{color:var(--ink-muted);margin-top:.2rem;font-size:.8rem;font-weight:400}.pricing-tier__features{flex:1;margin:0 0 1.5rem;padding:0;list-style:none}.pricing-tier__features li{border-bottom:1px solid var(--border);color:var(--ink-muted);padding:.4rem 0;font-size:.9rem}.pricing-tier__features li:first-child{border-top:1px solid var(--border)}.pricing-tier__features li strong{color:var(--ink)}.pricing-tier__cta{width:100%;font-family:var(--font-display);cursor:pointer;text-align:center;border:none;border-radius:6px;margin-top:auto;padding:.65rem;font-size:.9rem;font-weight:700;display:block}.pricing-tier__cta--free{background:var(--bg);color:var(--ink);border:1px solid var(--border)}.pricing-tier__cta--free:hover{background:var(--bg-raised)}.pricing-tier__cta--upgrade{background:var(--accent);color:#fff}.pricing-tier__cta--upgrade:hover{opacity:.88}.pricing-tier__cta--upgrade:disabled{opacity:.6;cursor:not-allowed}.pricing-tier__cta--manage{color:var(--ink);border:1px solid var(--border);background:0 0}.pricing-tier__cta--manage:hover{background:var(--bg-raised)}.pricing-tier__cta--manage:disabled{opacity:.6;cursor:not-allowed}.pricing-tier__badge--active{background:#16a34a}.pricing-tier__error{color:#e53e3e;text-align:center;margin:0 0 .5rem;font-size:.8rem}.onboarding-overlay{z-index:500;background:#000000b3;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.onboarding-card{background:var(--bg-raised);border:1px solid var(--border);border-radius:12px;width:100%;max-width:520px;padding:2.5rem}.onboarding-card__title{font-size:1.6rem;font-family:var(--font-display);margin:0 0 .75rem;font-weight:700}.onboarding-card__body{color:var(--ink-muted);margin:0 0 2rem;line-height:1.6}.onboarding-card__options{flex-direction:column;gap:.75rem;display:flex}.onboarding-option{background:var(--bg);border:1px solid var(--border);text-align:left;cursor:pointer;border-radius:8px;grid-template-rows:auto auto;grid-template-columns:1.5rem 1fr;column-gap:.75rem;padding:1.25rem;display:grid}.onboarding-option:hover{border-color:var(--accent)}.onboarding-option--sample:hover{background:color-mix(in srgb, var(--accent) 6%, var(--bg))}.onboarding-option__icon{color:var(--accent);grid-row:1;font-size:1.1rem}.onboarding-option__label{font-family:var(--font-display);grid-row:1;font-size:.95rem;font-weight:600}.onboarding-option__desc{color:var(--ink-muted);grid-area:2/2;margin-top:.3rem;font-size:.82rem;line-height:1.5}.homepage__header-nav{align-items:center;gap:.75rem;display:flex}@keyframes spin{to{transform:rotate(360deg)}}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.toolbar-icon--align-left:before,.toolbar-icon--align-center:before,.toolbar-icon--align-right:before{font-family:var(--font-mono);white-space:pre;font-size:.65em;line-height:1.4;display:block}.toolbar-icon--align-left:before{content:"———\a ——\a ——";text-align:left}.toolbar-icon--align-center:before{content:"———\a  —— \a ———";text-align:center}.toolbar-icon--align-right:before{content:"———\a  ——\a  ——";text-align:right}.save-status{z-index:9000;font-family:var(--font-mono,monospace);color:var(--ink);background:var(--bg-raised);border:1px solid var(--border);pointer-events:none;border-radius:999px;align-items:center;gap:7px;padding:6px 12px;font-size:12px;line-height:1;transition:opacity .18s;display:flex;position:fixed;bottom:14px;right:16px;box-shadow:0 2px 8px #0000002e}.save-status--idle{opacity:0}.save-status__dot{background:var(--ink-muted);border-radius:50%;flex:none;width:8px;height:8px}.save-status--saving .save-status__dot{background:var(--accent);animation:1s ease-in-out infinite save-status-pulse}.save-status--saved .save-status__dot{background:var(--color-success)}.save-status--offline .save-status__dot{background:var(--ink-faint,var(--ink-muted))}.save-status--error .save-status__dot{background:var(--color-error)}.save-status--error{border-color:var(--color-error)}@keyframes save-status-pulse{0%,to{opacity:1}50%{opacity:.35}}@media (prefers-reduced-motion:reduce){.save-status--saving .save-status__dot{animation:none}}.account-screen{background:var(--bg);min-height:100vh;color:var(--ink);outline:none;padding:2rem 1.5rem 4rem}.account-screen__header{max-width:720px;margin:0 auto 2rem}.account-screen__back{color:var(--ink-muted);cursor:pointer;font-size:.9rem;font-family:var(--font-display);background:0 0;border:none;margin-bottom:1.5rem;padding:0;display:block}.account-screen__back:hover{color:var(--ink)}.account-screen__back:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.account-screen__title{font-family:var(--font-display);color:var(--ink);margin:0;font-size:2rem;font-weight:700}.account-screen__body{flex-direction:column;gap:1.5rem;max-width:720px;margin:0 auto;display:flex}.account-card{background:var(--bg-raised);border:1px solid var(--border);border-radius:10px;padding:1.4rem 1.6rem}.account-card__title{font-family:var(--font-display);color:var(--ink);margin:0 0 1rem;font-size:1.1rem;font-weight:600}.account-card__rows{flex-direction:column;gap:.6rem;margin:0 0 1rem;display:flex}.account-card__row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:1rem;padding-bottom:.6rem;display:flex}.account-card__row:last-child{border-bottom:none;padding-bottom:0}.account-card__row dt{font-family:var(--font-display);color:var(--ink-muted);letter-spacing:.02em;text-transform:uppercase;font-size:.82rem}.account-card__row dd{font-family:var(--font-body);color:var(--ink);align-items:center;gap:.5rem;margin:0;font-size:1rem;display:inline-flex}.account-card__status{font-family:var(--font-body);color:var(--ink-muted);margin:0 0 1rem;font-size:.95rem}.account-card__status--error{color:var(--color-error)}.account-card__hint{font-family:var(--font-body);color:var(--ink-muted);margin:.5rem 0 1rem;font-size:.85rem;line-height:1.5}.account-card__actions{flex-wrap:wrap;align-items:center;gap:.6rem;display:flex}.account-card__badge{font-family:var(--font-display);letter-spacing:.04em;text-transform:uppercase;background:var(--pill-bg);color:var(--ink-muted);border-radius:999px;padding:2px 8px;font-size:.7rem;font-weight:600;display:inline-block}.account-card__badge--warn{background:var(--color-error);color:#fff}.chapter-slider__back-btn{border:1px solid var(--mid-border);background:var(--mid-bg);width:calc(100% - 24px);min-height:44px;color:var(--ink);font-family:var(--font-display);cursor:pointer;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;gap:6px;margin:8px 12px;padding:7px 10px;font-size:12px;font-weight:600;transition:background .12s,color .12s,border-color .12s;display:flex}.chapter-slider__back-btn:hover{background:var(--accent);color:#fff;border-color:#0000}.chapter-slider__back-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.stack-counter{align-items:center;gap:.25rem;margin:0 .5rem;display:inline-flex}.stack-counter__btn{border:1px solid var(--border);background:var(--bg-raised);width:28px;height:28px;color:var(--ink);font-family:var(--font-display);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;font-size:1rem;font-weight:700;line-height:1;display:inline-flex}.stack-counter__btn:hover:not(:disabled){background:var(--accent);color:#fff;border-color:#0000}.stack-counter__btn:disabled{opacity:.4;cursor:not-allowed}.stack-counter__btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.stack-counter__input{text-align:center;border:1px solid var(--border);background:var(--bg-raised);width:56px;height:28px;color:var(--ink);font-family:var(--font-body);appearance:textfield;border-radius:4px;font-size:.95rem}.stack-counter__input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.stack-counter__input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.stack-counter__input:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.inventory-group{border:1px solid var(--border);background:var(--bg-raised);border-radius:6px;margin-bottom:.5rem;overflow:hidden}.inventory-group>.panel__list{margin:0;padding:0 .5rem .5rem}.inventory-group__header{font-family:var(--font-display);letter-spacing:.04em;text-transform:uppercase;color:var(--ink-muted);cursor:pointer;justify-content:space-between;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.78rem;font-weight:600;display:flex}.inventory-group__header::-webkit-details-marker{color:var(--ink-muted)}.inventory-group[open]>.inventory-group__header{border-bottom:1px solid var(--border)}.inventory-group__label{flex:1}.inventory-group__count{background:var(--pill-bg);color:var(--ink-muted);border-radius:999px;padding:1px 8px;font-size:.7rem;display:inline-block}.inventory-group__header:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.ability-grid{grid-template-columns:repeat(auto-fill,minmax(108px,1fr));gap:.5rem;margin-top:.25rem;display:grid}.ability-tile{border:1px solid var(--border);background:var(--bg-raised);border-radius:8px;flex-direction:column;align-items:center;gap:.25rem;padding:.6rem .4rem .5rem;display:flex}.ability-tile__name{font-family:var(--font-display);letter-spacing:.05em;text-transform:uppercase;color:var(--ink-muted);cursor:pointer;background:0 0;border:none;border-radius:3px;padding:2px 4px;font-size:.72rem;font-weight:600}.ability-tile__name:hover{color:var(--accent)}.ability-tile__name:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.ability-tile__value-row{align-items:center;gap:.25rem;display:flex}.ability-tile__value{text-align:center;width:56px;height:38px;color:var(--ink);font-family:var(--font-display);background:0 0;border:1px solid #0000;border-radius:6px;font-size:1.5rem;font-weight:700}.ability-tile__value:hover{border-color:var(--border)}.ability-tile__value:focus-visible{border-color:var(--accent);outline:none}.ability-tile__bump{border:1px solid var(--border);background:var(--bg-raised);width:24px;height:24px;color:var(--ink);font-family:var(--font-display);cursor:pointer;opacity:0;border-radius:4px;font-size:.95rem;font-weight:700;line-height:1;transition:opacity .12s}.ability-tile:hover .ability-tile__bump,.ability-tile:focus-within .ability-tile__bump{opacity:1}.ability-tile__bump:hover{background:var(--accent);color:#fff;border-color:#0000}.ability-tile__bump:focus-visible{opacity:1;outline:2px solid var(--accent);outline-offset:2px}.modal__chip-row{flex-wrap:wrap;gap:.35rem;margin-top:.45rem;display:flex}.modal__chip{border:1px solid var(--border);background:var(--bg-raised);color:var(--ink);font-family:var(--font-display);cursor:pointer;border-radius:999px;padding:.25rem .7rem;font-size:.78rem;font-weight:500}.modal__chip:hover{background:var(--pill-bg)}.modal__chip--active{background:var(--accent);color:#fff;border-color:#0000}.modal__chip:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.modal__checkbox-row{font-family:var(--font-body);color:var(--ink);cursor:pointer;align-items:center;gap:.5rem;font-size:.92rem;display:flex}.modal__checkbox-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.modal__subfield{margin-top:.55rem;padding-left:1.5rem}.modal__input--narrow{width:110px}.modal__radio-group{border:1px solid var(--border);border-radius:6px;margin:0 0 .875rem;padding:.6rem .75rem .5rem}.modal__radio-group>legend{margin:0;padding:0 .4rem}.modal__radio{font-family:var(--font-body);color:var(--ink);cursor:pointer;align-items:flex-start;gap:.5rem;padding:.35rem 0;font-size:.88rem;display:flex}.modal__radio input[type=radio]{accent-color:var(--accent);cursor:pointer;margin-top:.2rem}.saving-modal__status{background:var(--bg-elev,var(--bg));border:1px solid var(--border);font-family:var(--font-body);color:var(--ink);border-radius:6px;align-items:center;gap:.6rem;margin:.75rem 0 .25rem;padding:.6rem .75rem;font-size:.92rem;display:flex}.saving-modal__spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;flex:0 0 18px;width:18px;height:18px;animation:.7s linear infinite auth-spin}.saving-modal__status-text{line-height:1.3}@media (prefers-reduced-motion:reduce){.saving-modal__spinner{animation:none}}.feedback-fab{z-index:950;border:1px solid var(--feedback-bg);background:var(--feedback-bg);min-height:44px;color:var(--feedback-ink);font-family:var(--font-display);cursor:pointer;border-radius:999px;align-items:center;gap:.45rem;padding:.55rem 1.05rem;font-size:.875rem;font-weight:600;transition:background .15s,transform .12s,box-shadow .15s;display:inline-flex;position:fixed;bottom:1.25rem;right:1.25rem;box-shadow:0 4px 12px #0000002e}.feedback-fab:hover{background:var(--feedback-bg-hover);border-color:var(--feedback-bg-hover);transform:translateY(-1px)}.feedback-fab:active{transform:translateY(0);box-shadow:0 2px 6px #0000002e}.feedback-fab:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.feedback-fab__label{line-height:1}@media (prefers-reduced-motion:reduce){.feedback-fab{transition:none}.feedback-fab:hover{transform:none}}body.feedback-suppressed .feedback-fab{display:none!important}body.comment-panel-open .feedback-fab{transition:right .2s,background .15s,transform .12s,box-shadow .15s;right:17.5rem}@media (prefers-reduced-motion:reduce){body.comment-panel-open .feedback-fab{transition:none}}.feedback-type-row{flex-wrap:wrap;gap:.4rem;display:flex}.feedback-type{border:1px solid var(--border);background:var(--bg-raised);color:var(--ink);font-size:.85rem;font-family:var(--font-body);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:999px;align-items:center;padding:.4rem .85rem;transition:background .12s,border-color .12s,color .12s;display:inline-flex}.feedback-type:hover{border-color:var(--feedback-bg)}.feedback-type input[type=radio]{clip:rect(0 0 0 0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.feedback-type--active{background:var(--feedback-bg);border-color:var(--feedback-bg);color:var(--feedback-ink)}.feedback-type:has(input[type=radio]:focus-visible){outline:2px solid var(--feedback-bg);outline-offset:2px}.feedback-modal .modal__btn--primary{background:var(--feedback-bg);color:var(--feedback-ink);border-color:var(--feedback-bg)}.feedback-modal .modal__btn--primary:hover{background:var(--feedback-bg-hover);border-color:var(--feedback-bg-hover)}@media (prefers-reduced-motion:reduce){.feedback-type{transition:none}}.feedback-textarea{resize:vertical;min-height:6.5rem;font-family:var(--font-body);line-height:1.45}.feedback-error{color:var(--color-error)}.landing{--font-display:"Oswald", system-ui, sans-serif;color:#1a0f12;height:100%;font-family:var(--font-body);scroll-behavior:smooth;background:#faf6f5;font-size:17px;line-height:1.6;overflow-y:auto}.landing-nav{z-index:100;-webkit-backdrop-filter:blur(12px);background:#faf6f5eb;border-bottom:1px solid #0000;justify-content:space-between;align-items:center;height:64px;padding:0 40px;transition:border-color .2s;display:flex;position:sticky;top:0}.landing-nav.scrolled{border-bottom-color:#0000001a}.landing-nav__wordmark{font-family:var(--font-display);color:#1a0f12;letter-spacing:-.03em;font-size:22px;font-weight:700;line-height:1;text-decoration:none}.landing-nav__actions{align-items:center;gap:10px;display:flex}.btn{font-family:var(--font-display);letter-spacing:.03em;cursor:pointer;border:none;border-radius:2px;justify-content:center;align-items:center;padding:8px 18px;font-size:13px;font-weight:600;text-decoration:none;transition:background .15s,border-color .15s,color .15s,opacity .15s;display:inline-flex}.btn:focus-visible{outline-offset:2px;outline:2px solid #9d1f2a}.btn--ghost{color:#1a0f12;background:0 0;border:1.5px solid #00000038}.btn--ghost:hover{background:#0000000d;border-color:#0006}.btn--accent{color:#fff;background:#9d1f2a;border:1.5px solid #0000}.btn--accent:hover{background:#7d1820}.btn--lg{border-radius:2px;padding:13px 28px;font-size:15px}.btn--secondary{color:#5a3a40;background:0 0;border:1.5px solid #0003}.btn--secondary:hover{color:#1a0f12;border-color:#0000005c}.landing-hero{text-align:left;isolation:isolate;flex-direction:column;align-items:flex-start;padding:100px 24px 96px 48px;display:flex;position:relative;overflow:hidden}.landing-hero:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(60% 50% at 30% 0,#9d1f2a1a 0%,#0000 70%),linear-gradient(#faf6f5 0%,#f3ecea 100%);position:absolute;inset:0}.landing-hero__content{z-index:2;width:55%;max-width:620px;position:relative}.landing-hero__headline{font-family:var(--font-display);color:#1a0f12;letter-spacing:-.04em;margin-bottom:24px;font-size:clamp(38px,6vw,68px);font-weight:700;line-height:1.08}.landing-hero__headline em{background:linear-gradient(135deg,#9d1f2a 0%,#c43844 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-style:normal}.landing-hero__sub{font-family:var(--font-body);color:#6a484f;max-width:540px;margin:0 0 40px;font-size:clamp(17px,2.2vw,21px);line-height:1.55}.landing-hero__ctas{flex-wrap:wrap;justify-content:flex-start;align-items:center;gap:12px;display:flex}.landing-hero__visual{z-index:1;clip-path:polygon(62% 0%,100% 0%,100% 100%,50% 100%);pointer-events:none;background:#1a0f12;position:absolute;inset:0}.landing-hero__photo{object-fit:contain;object-position:center right;transform-origin:100%;width:100%;height:100%;display:block;transform:scale(1.8)}.landing-hero__tint{mix-blend-mode:multiply;pointer-events:none;background:linear-gradient(to bottom right,#9d1f2a47 0%,#9d1f2a0a 100%);position:absolute;inset:0}.landing-hero__seam{z-index:2;pointer-events:none;width:100%;height:100%;position:absolute;inset:0}.landing-hero__seam line{stroke:#9d1f2acc;stroke-width:1.5px;vector-effect:non-scaling-stroke}.landing-features{padding:24px 0 80px}.landing-feature{border-bottom:1px solid #00000014;grid-template-columns:1fr 1fr;align-items:center;gap:48px;max-width:1100px;margin:0 auto;padding:72px 48px;display:grid}.landing-feature:last-child{border-bottom:none}.landing-feature--reverse{direction:rtl}.landing-feature--reverse>*{direction:ltr}.landing-feature__text{text-align:left;flex-direction:column;gap:16px;display:flex}.landing-feature__label{font-family:var(--font-display);letter-spacing:.1em;text-transform:uppercase;color:#9d1f2a;font-size:11px;font-weight:600}.landing-feature__heading{font-family:var(--font-display);color:#1a0f12;letter-spacing:-.025em;font-size:clamp(26px,3.5vw,38px);font-weight:700;line-height:1.15}.landing-feature__desc{font-family:var(--font-body);color:#6a484f;font-size:17px;line-height:1.65}.landing-feature__visual{aspect-ratio:4/3;background:#f3ecea;border:1px solid #0000001a;border-radius:12px;position:relative;overflow:hidden}.panel-chrome{background:#ece2e1;border-bottom:1px solid #0000001a;flex-shrink:0;align-items:center;gap:6px;height:36px;padding:0 12px;display:flex}.panel-chrome__dot{border-radius:50%;width:10px;height:10px}.panel-chrome__dot--red{background:#ff5f57}.panel-chrome__dot--amber{background:#febc2e}.panel-chrome__dot--green{background:#28c840}.panel-chrome__tab{font-family:var(--font-display);color:#6a484f;letter-spacing:.04em;background:#0000000f;border-radius:4px;margin-left:8px;padding:3px 10px;font-size:10px}.panel-body{flex-direction:column;gap:10px;height:calc(100% - 36px);padding:16px;display:flex;overflow:hidden}.illus-char{flex-direction:column;gap:10px;height:100%;display:flex}.illus-char__header{align-items:center;gap:10px;display:flex}.illus-char__avatar{background:linear-gradient(135deg,#9d1f2a 0%,#c43844 100%);border-radius:50%;flex-shrink:0;width:38px;height:38px}.illus-char__name-block{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.illus-char__name{font-family:var(--font-display);color:#1a0f12;letter-spacing:-.01em;font-size:14px;font-weight:600;line-height:1.15}.illus-char__role{font-family:var(--font-display);letter-spacing:.06em;text-transform:uppercase;color:#6a484f;font-size:10px;font-weight:500}.illus-char__row{border-bottom:1px solid #00000014;align-items:center;gap:8px;padding:6px 0;display:flex}.illus-char__icon{background:#9d1f2a;border-radius:50%;flex-shrink:0;width:14px;height:14px}.illus-char__row-label{font-family:var(--font-body);color:#1a0f12;white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:13px;line-height:1.2;overflow:hidden}.illus-char__row-chip{font-family:var(--font-display);letter-spacing:.04em;color:#9d1f2a;white-space:nowrap;background:#9d1f2a1f;border-radius:3px;padding:2px 8px;font-size:10px;font-weight:600}.illus-wp{flex-direction:column;gap:8px;height:100%;display:flex}.illus-wp__toolbar{border-bottom:1px solid #00000014;gap:5px;padding-bottom:8px;display:flex}.illus-wp__tool{width:22px;height:22px;font-family:var(--font-display);color:#6a484f;background:#00000012;border-radius:4px;justify-content:center;align-items:center;font-size:11px;font-weight:600;line-height:1;display:flex}.illus-wp__lines{flex-direction:column;flex:1;gap:4px;display:flex;overflow:hidden}.illus-wp__prose{font-family:var(--font-body);color:#1a0f12;margin:0;font-size:12.5px;line-height:1.45}.illus-wp__prose--highlighted{background:#9d1f2a29;border-radius:3px;width:fit-content;max-width:100%;padding:1px 4px;display:inline-block;position:relative}.illus-wp__comment-bubble{background:#9d1f2a;border-radius:50%;width:12px;height:12px;position:absolute;top:-6px;right:-10px}.illus-timeline{flex-direction:column;gap:12px;height:100%;display:flex}.illus-timeline__track{background:#0000001a;border-radius:3px;height:6px;margin:16px 8px 8px;position:relative}.illus-timeline__progress{background:#9d1f2a;border-radius:3px;width:55%;height:100%;position:absolute;top:0;left:0}.illus-timeline__thumb{background:#9d1f2a;border:3px solid #f3ecea;border-radius:50%;width:16px;height:16px;position:absolute;top:50%;left:55%;transform:translate(-50%,-50%);box-shadow:0 0 0 2px #9d1f2a}.illus-timeline__dots{justify-content:space-between;padding:0 8px;display:flex}.illus-timeline__dot{background:#00000024;border-radius:50%;width:8px;height:8px}.illus-timeline__dot--active{background:#9d1f2a}.illus-timeline__chapters{flex-wrap:wrap;gap:6px;padding:0 4px;display:flex}.illus-timeline__ch{font-family:var(--font-display);color:#6a484f;white-space:nowrap;background:#0000000f;border-radius:5px;padding:4px 10px;font-size:10px}.illus-timeline__ch--active{color:#9d1f2a;background:#9d1f2a1f}.illus-timeline__annotations{flex-direction:column;flex:1;gap:6px;display:flex}.illus-timeline__ann{align-items:center;gap:8px;display:flex}.illus-timeline__ann-dot{background:#9d1f2a;border-radius:50%;flex-shrink:0;width:8px;height:8px}.illus-timeline__ann-label{min-width:0;font-family:var(--font-display);flex:1;align-items:baseline;gap:8px;line-height:1.2;display:flex}.illus-timeline__ann-chapter{letter-spacing:.04em;color:#9d1f2a;flex-shrink:0;font-size:10px;font-weight:600}.illus-timeline__ann-text{color:#1a0f12;white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:500;overflow:hidden}.illus-ai{flex-direction:column;gap:10px;height:100%;display:flex}.illus-ai__bubble{border-radius:8px;flex-direction:column;gap:5px;max-width:82%;padding:7px 11px;display:flex}.illus-ai__bubble--user{background:#9d1f2a1f;border-radius:8px 8px 2px;align-self:flex-end}.illus-ai__bubble--ai{background:#0000000d;border-radius:8px 8px 8px 2px;align-self:flex-start}.illus-ai__text{font-family:var(--font-body);color:#1a0f12;margin:0;font-size:11.5px;line-height:1.4}.illus-ai__badge{font-family:var(--font-display);letter-spacing:.06em;text-transform:uppercase;color:#9d1f2a;background:#9d1f2a1a;border:1px solid #9d1f2a4d;border-radius:20px;align-self:flex-start;margin-top:4px;padding:3px 10px;font-size:9px}.illus-series{flex-direction:column;gap:10px;height:100%;display:flex}.illus-series__shelf{border-bottom:2px solid #0000001a;align-items:flex-end;gap:10px;padding:0 4px 8px;display:flex}.illus-series__book{border-radius:4px 6px 6px 4px;flex-shrink:0;justify-content:center;align-items:center;display:flex;overflow:hidden}.illus-series__book--a{background:linear-gradient(#9d1f2a 0%,#7d1820 100%);width:36px;height:72px}.illus-series__book--b{background:linear-gradient(#c43844 0%,#9d1f2a 100%);width:32px;height:62px}.illus-series__book--c{background:linear-gradient(#d4626c 0%,#c43844 100%);width:38px;height:76px}.illus-series__book-title{font-family:var(--font-display);letter-spacing:.08em;color:#fff;writing-mode:vertical-rl;white-space:nowrap;text-transform:uppercase;font-size:9px;font-weight:600;transform:rotate(180deg)}.illus-series__book--new{color:#00000052;width:30px;height:58px;font-size:18px;font-family:var(--font-display);background:#0000000d;border:2px dashed #0000002e;justify-content:center;align-items:center;font-weight:300;display:flex}.illus-series__chars{flex-direction:column;flex:1;gap:8px;display:flex}.illus-series__char-row{align-items:center;gap:8px;display:flex}.illus-series__char-avatar{border-radius:50%;flex-shrink:0;width:26px;height:26px}.illus-series__char-avatar--a{background:#9d1f2a}.illus-series__char-avatar--b{background:#c43844}.illus-series__char-avatar--c{background:#d4626c}.illus-series__char-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.illus-series__char-name{font-family:var(--font-display);color:#1a0f12;letter-spacing:-.005em;font-size:12.5px;font-weight:600;line-height:1.15}.illus-series__char-role{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;color:#6a484f;font-size:9px;font-weight:500}.illus-series__books-row{flex-shrink:0;gap:4px;display:flex}.illus-series__book-pill{background:#9d1f2a;border-radius:3px;width:14px;height:14px}.illus-series__book-pill--dimmed{background:#0000001a}.illus-export{flex-direction:column;gap:12px;height:100%;display:flex}.illus-export__doc{background:#00000008;border:1px solid #00000014;border-radius:6px;flex-direction:column;flex:1;gap:7px;padding:12px;display:flex}.illus-export__doc-title{font-family:var(--font-display);color:#1a0f12;letter-spacing:-.01em;margin:0 0 4px;font-size:13px;font-weight:700;line-height:1.15}.illus-export__doc-prose{font-family:var(--font-body);color:#1a0f12;margin:0;font-size:11.5px;line-height:1.4}.illus-export__formats{gap:8px;display:flex}.illus-export__format{background:#0000000a;border:1px solid #00000014;border-radius:7px;flex-direction:column;flex:1;align-items:center;gap:5px;padding:8px;display:flex}.illus-export__format-icon{border-radius:3px;width:24px;height:28px;position:relative}.illus-export__format-icon:after{content:"";border-top:7px solid #f3ecea;border-bottom:0 solid #0000;border-left:0 solid #0000;border-right:7px solid #0000;position:absolute;top:0;right:0}.illus-export__format-icon--pdf{background:#e74c3c}.illus-export__format-icon--docx{background:#2e86de}.illus-export__format-icon--json{background:#9d1f2a}.illus-export__format-label{font-family:var(--font-display);letter-spacing:.06em;text-transform:uppercase;color:#6a484f;font-size:9px;font-weight:700}.landing-footer{font-family:var(--font-display);color:#6a484f;border-top:1px solid #00000014;justify-content:space-between;align-items:center;padding:28px 48px;font-size:13px;display:flex}.landing-footer__links{align-items:center;gap:20px;display:flex}.landing-footer__link{font-family:var(--font-display);color:#6a484f;cursor:pointer;background:0 0;border:none;padding:0;font-size:13px;text-decoration:none;transition:color .15s}.landing-footer__link:hover{color:#1a0f12}.landing-footer__link:focus-visible{outline-offset:2px;border-radius:2px;outline:2px solid #9d1f2a}.auth-modal-backdrop{z-index:200;background:#0000008c;justify-content:center;align-items:center;padding:24px;animation:.18s auth-backdrop-in;display:flex;position:fixed;inset:0}@keyframes auth-backdrop-in{0%{opacity:0}to{opacity:1}}.auth-modal-backdrop .auth-card{animation:.2s auth-card-in;position:relative}@keyframes auth-card-in{0%{opacity:0;transform:translateY(12px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.auth-card__close{color:#6a484f;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:30px;height:30px;font-size:18px;line-height:1;transition:background .13s,color .13s;display:flex;position:absolute;top:12px;right:12px}.auth-card__close:hover{color:#1a0f12;background:#0000000f}.auth-card__close:focus-visible{outline-offset:2px;outline:2px solid #9d1f2a}@media (width<=900px){.landing-nav{padding:0 20px}.landing-hero{padding:72px 20px}.landing-feature{grid-template-columns:1fr;gap:32px;padding:56px 24px}.landing-feature--reverse{direction:ltr}.landing-footer{flex-direction:column;align-items:flex-start;gap:16px;padding:24px 20px}}@media (width<=768px){.landing-hero{padding:280px 20px 64px}.landing-hero__content{width:100%;max-width:100%}.landing-hero__visual{clip-path:none;border-bottom:1.5px solid #9d1f2acc;height:240px;bottom:auto}.landing-hero__seam{display:none}}@media (width<=480px){.landing-nav__actions{gap:6px}.btn--ghost,.btn--accent{padding:7px 12px;font-size:12px}.landing-hero__ctas{flex-direction:column;align-items:stretch}.landing-hero__ctas .btn{justify-content:center}}.admin-feedback{background:var(--bg);min-height:100vh;color:var(--ink);font-family:var(--font-body);flex-direction:column;display:flex}.admin-feedback__header{border-bottom:1px solid var(--border);background:var(--bg);z-index:2;justify-content:space-between;align-items:center;gap:1rem;padding:20px 48px;display:flex;position:sticky;top:0}.admin-feedback__logo{font-family:var(--font-display);color:var(--ink);letter-spacing:-.02em;flex:none;font-size:1.6rem;font-weight:800;line-height:1}.admin-feedback__title{font-family:var(--font-display);color:var(--ink);text-align:center;flex:auto;margin:0;font-size:1.15rem;font-weight:700}.admin-feedback__header-nav{flex:none;align-items:center;gap:.75rem;display:flex}.admin-feedback__unread{font-family:var(--font-display);color:var(--ink-muted);border:1px solid var(--ink-faint);border-radius:999px;padding:6px 12px;font-size:.85rem;font-weight:600}.admin-feedback__nav-btn{font-family:var(--font-display);color:var(--ink-muted);border:1px solid var(--ink-faint);cursor:pointer;background:0 0;border-radius:6px;padding:8px 16px;font-size:.85rem;font-weight:600;transition:color .15s,border-color .15s}.admin-feedback__nav-btn:hover:not(:disabled),.admin-feedback__nav-btn:focus-visible{color:var(--ink);border-color:var(--ink)}.admin-feedback__nav-btn:disabled{opacity:.5;cursor:not-allowed}.admin-feedback__main{flex:auto;padding:32px 48px 64px}.admin-feedback__main:focus{outline:none}.admin-feedback__empty{font-family:var(--font-body);color:var(--ink-muted);text-align:center;max-width:56ch;margin:0 auto;padding:64px 16px;font-size:1rem}.admin-feedback__split{grid-template-columns:minmax(0,1.6fr) minmax(0,1fr);align-items:flex-start;gap:24px;display:grid}@media (width<=900px){.admin-feedback__split{grid-template-columns:1fr}}.admin-feedback__list-pane{min-width:0}.admin-feedback__table{border-collapse:collapse;width:100%;font-size:.95rem}.admin-feedback__table thead th{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.05em;color:var(--ink-muted);text-align:left;border-bottom:1px solid var(--border);background:var(--bg);padding:10px 12px;font-size:.78rem;font-weight:700}.admin-feedback__th-actions{text-align:right}.admin-feedback__table tbody td{border-bottom:1px solid var(--border);vertical-align:top;padding:12px}.admin-feedback__row--unread td{background:var(--bg-elevated,var(--bg))}.admin-feedback__row--selected td{background:var(--accent-bg,color-mix(in srgb, var(--ink) 6%, transparent))}.admin-feedback__row-btn{font-family:var(--font-mono);color:var(--ink);cursor:pointer;text-underline-offset:2px;background:0 0;border:none;padding:0;font-size:.9rem;font-weight:700;text-decoration:underline;text-decoration-thickness:1px}.admin-feedback__row-btn:hover,.admin-feedback__row-btn:focus-visible{color:var(--accent,var(--ink))}.admin-feedback__row--unread .admin-feedback__row-btn:before{content:"●";color:var(--accent,var(--ink));vertical-align:1px;margin-right:4px;font-size:.7rem}.admin-feedback__cell-when{font-family:var(--font-mono);color:var(--ink-muted);white-space:nowrap;font-size:.82rem}.admin-feedback__cell-from{color:var(--ink-muted);word-break:break-all;max-width:200px;font-size:.88rem}.admin-feedback__cell-msg{color:var(--ink);word-break:break-word;min-width:200px;font-size:.9rem;line-height:1.4}.admin-feedback__cell-actions{text-align:right;white-space:nowrap}.admin-feedback__chip{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.05em;border:1px solid var(--ink-faint);color:var(--ink-muted);vertical-align:middle;border-radius:999px;padding:3px 8px;font-size:.72rem;font-weight:700;display:inline-block}.admin-feedback__chip--bug{color:var(--ink);border-color:var(--ink-muted)}.admin-feedback__chip--feature{color:var(--ink);border-color:var(--accent,var(--ink-muted))}.admin-feedback__chip--other{color:var(--ink-muted);border-color:var(--ink-faint)}.admin-feedback__action-btn{font-family:var(--font-display);color:var(--ink);background:var(--bg);border:1px solid var(--ink-faint);cursor:pointer;border-radius:6px;padding:6px 12px;font-size:.82rem;font-weight:600;text-decoration:none;transition:border-color .15s,background .15s,color .15s;display:inline-block}.admin-feedback__action-btn:hover,.admin-feedback__action-btn:focus-visible{border-color:var(--ink)}.admin-feedback__action-btn--primary{background:var(--ink);color:var(--bg);border-color:var(--ink)}.admin-feedback__action-btn--primary:hover,.admin-feedback__action-btn--primary:focus-visible{background:var(--ink-muted);border-color:var(--ink-muted)}.admin-feedback__pager{justify-content:center;padding:16px 0;display:flex}.admin-feedback__detail-pane{background:var(--bg);border:1px solid var(--border);border-radius:8px;align-self:flex-start;min-height:240px;max-height:calc(100vh - 140px);padding:20px;position:sticky;top:96px;overflow-y:auto}@media (width<=900px){.admin-feedback__detail-pane{max-height:none;position:static}}.admin-feedback__detail-empty{color:var(--ink-muted);margin:0;font-style:italic}.admin-feedback__detail-title{font-family:var(--font-display);align-items:center;gap:10px;margin:0 0 16px;font-size:1.1rem;font-weight:700;display:flex}.admin-feedback__meta{grid-template-columns:minmax(80px,max-content) 1fr;gap:6px 12px;margin:0 0 20px;font-size:.85rem;display:grid}.admin-feedback__meta div{display:contents}.admin-feedback__meta dt{color:var(--ink-muted);font-family:var(--font-display);text-transform:uppercase;letter-spacing:.05em;padding-top:3px;font-size:.7rem;font-weight:600}.admin-feedback__meta dd{color:var(--ink);word-break:break-word;margin:0}.admin-feedback__meta-mono{font-family:var(--font-mono);font-size:.78rem;line-height:1.4}.admin-feedback__status{font-family:var(--font-display);color:var(--ink-muted);font-size:.78rem;font-weight:600}.admin-feedback__status--unread{color:var(--ink)}.admin-feedback__detail-subhead{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.05em;color:var(--ink-muted);margin:0 0 8px;font-size:.72rem;font-weight:700}.admin-feedback__detail-body{font-family:var(--font-body);color:var(--ink);background:var(--bg-elevated,var(--bg));border:1px solid var(--border);white-space:pre-wrap;word-break:break-word;border-radius:6px;margin:0 0 16px;padding:12px;font-size:.95rem;line-height:1.5}.admin-feedback__detail-actions{flex-wrap:wrap;gap:8px;display:flex}@media (width<=700px){.admin-feedback__header{flex-wrap:wrap;padding:16px 20px}.admin-feedback__title{text-align:left;order:-1;width:100%}.admin-feedback__main{padding:24px 20px 48px}.admin-feedback__table thead th:nth-child(2),.admin-feedback__table thead th:nth-child(4),.admin-feedback__table tbody td:nth-child(2),.admin-feedback__table tbody td:nth-child(4){display:none}}.about-screen{background:var(--c-bg);min-height:100vh;color:var(--c-text);font-family:var(--font-body)}.about-screen__main{max-width:720px;margin:0 auto;padding:2rem 1.5rem 4rem}.about-screen__main:focus{outline:none}.about-screen__header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1.5rem;margin-bottom:3rem;display:flex}.about-screen__home-link{font-family:var(--font-display);color:var(--c-text);font-size:1.5rem;font-weight:700;text-decoration:none}.about-screen__home-link:hover,.about-screen__home-link:focus-visible{color:var(--c-accent)}.about-screen__nav{flex-wrap:wrap;gap:1.25rem;display:flex}.about-screen__nav-link{color:var(--c-text);font-size:.95rem;text-decoration:none}.about-screen__nav-link:hover,.about-screen__nav-link:focus-visible{color:var(--c-accent);text-decoration:underline}.about-screen__title{font-family:var(--font-display);margin:0 0 1.5rem;font-size:2.5rem;font-weight:700;line-height:1.15}.about-screen__lede{color:var(--c-text);margin:0 0 2.5rem;font-size:1.2rem;line-height:1.6}.about-screen__section{margin:0 0 2.5rem}.about-screen__section-title{font-family:var(--font-display);margin:0 0 1rem;font-size:1.4rem;font-weight:600}.about-screen__article p{margin:0 0 1rem;line-height:1.7}.about-screen__article a{color:var(--c-accent)}.about-screen__article a:focus-visible{outline:2px solid var(--c-accent);outline-offset:2px}
