*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #eff4fb;--bg-editor: #ffffff;--text-primary: #132034;--text-secondary: #435a75;--text-ghost: rgba(54, 105, 195, .45);--border-subtle: #bccde1;--shadow-page: 0 18px 42px rgba(16, 37, 72, .12), 0 3px 10px rgba(16, 37, 72, .08);--bg-panel: #e6eef8;--brand-ink: #10223c;--brand-primary: #3f74e6;--brand-primary-strong: #2c56b8;--brand-accent: #7bc8ff;--brand-surface: #e5eefb;--brand-shadow: rgba(53, 103, 207, .28);--font-body: "Source Serif 4", Georgia, "Times New Roman", serif;--font-ui: "Space Grotesk", "Segoe UI", sans-serif;--font-size-body: 19px;--line-height-body: 1.8;--editor-max-width: 720px;--paragraph-spacing: 0}html,body,#root{height:100%;width:100%}body{font-family:var(--font-body);font-size:var(--font-size-body);line-height:var(--line-height-body);color:var(--text-primary);background:radial-gradient(1200px 560px at 10% -12%,rgba(80,152,255,.2),transparent 64%),radial-gradient(980px 520px at 88% -16%,rgba(111,226,255,.16),transparent 62%),linear-gradient(180deg,#f8fbff 0%,#f1f6fc 52%,var(--bg-primary) 100%);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.auth-screen{min-height:100vh;display:grid;place-items:center;padding:32px 24px}.auth-card{width:min(460px,100%);border:1px solid var(--border-subtle);border-radius:18px;background:#ffffffdb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-page);padding:24px;font-family:var(--font-ui)}.auth-brand{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;margin-bottom:18px;text-align:center}.auth-brand-heading{display:inline-flex;align-items:center;justify-content:center;gap:10px}.auth-brand-mark{width:40px;height:40px;flex-shrink:0;filter:drop-shadow(0 4px 12px var(--brand-shadow))}.auth-title{font-family:var(--font-ui);font-size:28px;letter-spacing:-.03em;color:var(--brand-ink);margin-bottom:0}.auth-subtitle{font-size:13px;color:var(--text-secondary);margin-bottom:0}.auth-mode-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;margin-bottom:14px}.auth-mode-tab{border:1px solid var(--border-subtle);border-radius:999px;background:var(--bg-editor);color:var(--text-secondary);padding:8px 10px;font-size:12px;cursor:pointer}.auth-mode-tab:hover{color:var(--text-primary);border-color:#aaa}.auth-mode-tab--active{background:var(--brand-primary-strong);border-color:var(--brand-primary-strong);color:#fff;font-weight:600}.auth-form{display:grid;gap:10px}.auth-label{display:grid;gap:4px;color:var(--text-secondary);font-size:12px}.auth-input{border:1px solid var(--border-subtle);border-radius:6px;padding:8px 10px;font-size:14px;font-family:var(--font-ui);color:var(--text-primary);outline:none;background:var(--bg-editor)}.auth-input:focus{border-color:var(--brand-primary)}.auth-submit,.auth-google{border:1px solid var(--border-subtle);border-radius:8px;padding:9px 12px;font-size:13px;font-family:var(--font-ui);cursor:pointer}.auth-submit{background:var(--brand-primary-strong);border-color:var(--brand-primary-strong);color:#fff;font-weight:600}.auth-google{width:100%;background:#ffffffd1;color:var(--text-primary)}.auth-submit:disabled,.auth-google:disabled,.auth-mode-tab:disabled{opacity:.6;cursor:not-allowed}.auth-divider{margin:14px 0;font-size:11px;color:var(--text-secondary);text-align:center;text-transform:uppercase;letter-spacing:.05em}.auth-message{border-radius:6px;padding:8px 10px;font-size:12px}.auth-message--error{background:#fef2f2;color:#9b1c1c;border:1px solid #fca5a5}.auth-message--notice{background:#ecfdf5;color:#065f46;border:1px solid #6ee7b7}.app-auth-shell{position:relative}.user-menu{position:fixed;top:14px;right:14px;z-index:120;font-family:var(--font-ui)}.user-menu-trigger{display:inline-flex;align-items:center;gap:9px;border:1px solid var(--border-subtle);border-radius:999px;background:var(--bg-editor);color:var(--text-primary);font-size:12px;padding:6px 12px 6px 6px;cursor:pointer;box-shadow:0 4px 12px #00000014;transition:border-color .12s ease,box-shadow .12s ease,transform .12s ease}.user-menu-trigger:hover{border-color:#b9b9b0;box-shadow:0 8px 16px #0000001a;transform:translateY(-1px)}.user-menu-trigger--open{border-color:var(--brand-accent)}.user-menu-avatar{width:28px;height:28px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;letter-spacing:.03em;color:#fff;background:linear-gradient(145deg,var(--brand-primary),var(--brand-primary-strong))}.user-menu-name{max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600}.user-menu-popover{position:absolute;top:calc(100% + 8px);right:0;width:min(300px,calc(100vw - 28px));border:1px solid var(--border-subtle);border-radius:12px;background:var(--bg-editor);box-shadow:0 16px 36px #00000024,0 2px 6px #00000014;padding:10px;animation:userMenuFadeIn .14s ease-out}@keyframes userMenuFadeIn{0%{opacity:0;transform:translateY(-4px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}.user-menu-header{padding:4px 4px 8px;border-bottom:1px solid var(--border-subtle);margin-bottom:8px}.user-menu-header-name{font-size:13px;font-weight:600;color:var(--text-primary);line-height:1.3}.user-menu-header-email{font-size:11px;color:var(--text-secondary);overflow-wrap:anywhere;margin-top:1px}.user-menu-item{width:100%;border:1px solid var(--border-subtle);border-radius:8px;background:var(--bg-editor);color:var(--text-primary);font-size:12px;font-family:var(--font-ui);font-weight:600;text-align:left;padding:8px 10px;cursor:pointer;transition:background .12s ease,border-color .12s ease,color .12s ease}.user-menu-item:hover{background:#f4f4ef;border-color:#c5c5ba}.user-menu-item--danger{color:#a72f2f}.user-menu-item--danger:hover{background:#fef2f2;border-color:#f2bbbb}.user-menu-item:disabled{opacity:.65;cursor:not-allowed}.user-menu-error{margin-top:8px;font-size:11px;border:1px solid #f8b4b4;color:#9b1c1c;border-radius:6px;padding:6px 8px;background:#fef2f2}@media(max-width:640px){.user-menu{top:10px;right:10px}.user-menu-name{max-width:96px}}.project-list-container{display:grid;place-items:start center;min-height:100vh;padding:92px 24px 52px}.project-list{width:100%;max-width:760px}.project-brand-header{display:flex;align-items:center;gap:14px;margin-bottom:12px}.project-brand-mascot{width:52px;height:52px;flex-shrink:0;filter:drop-shadow(0 8px 18px var(--brand-shadow))}.project-list-title{font-family:var(--font-ui);letter-spacing:-.035em;font-size:42px;font-weight:700;color:var(--brand-ink);margin-bottom:6px;line-height:1}.project-list-subtitle{font-family:var(--font-ui);font-size:15px;color:var(--text-secondary);margin-bottom:24px}.project-list-error{background:#fef2f2;border:1px solid #e74c3c;border-radius:6px;color:#991b1b;font-size:13px;padding:10px 14px;margin-bottom:12px}.project-list-section-label{font-family:var(--font-ui);font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:10px}.project-cards{display:grid;grid-template-columns:1fr 1fr;gap:14px}.project-card{position:relative;display:flex;flex-direction:column;gap:6px;padding:20px 18px;border:1px solid var(--border-subtle);border-radius:14px;background:#ffffffd1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;text-align:left;font-family:var(--font-ui);transition:box-shadow .12s,border-color .12s,transform .12s}.project-card:hover{box-shadow:0 16px 32px #162f5829;border-color:var(--brand-accent);transform:translateY(-2px)}.project-card-title{font-size:15px;font-weight:600;color:var(--text-primary)}.project-card-date{font-size:12px;color:var(--text-secondary)}.project-card-delete{position:absolute;top:8px;right:8px;width:24px;height:24px;border:none;border-radius:4px;background:transparent;color:var(--text-secondary);font-size:16px;cursor:pointer;opacity:0;transition:opacity .1s,background .1s}.project-card:hover .project-card-delete{opacity:1}.project-card-delete:hover{background:#fee;color:#c44}.project-card--add{align-items:center;justify-content:center;border-style:solid;border-color:#3f74e659;background:linear-gradient(160deg,#ffffffe6,#ebf4ffeb);color:var(--text-secondary);font-size:14px;gap:8px}.project-card-plus{font-size:24px;line-height:1}.project-card--new{gap:12px}.project-card-input{width:100%;border:1px solid var(--border-subtle);border-radius:6px;padding:8px 10px;font-family:var(--font-ui);font-size:14px;color:var(--text-primary);outline:none}.project-card-input:focus{border-color:var(--brand-primary)}.project-card-actions{display:flex;gap:8px}.project-card-actions button{padding:6px 14px;border:1px solid var(--border-subtle);border-radius:6px;background:var(--bg-editor);font-family:var(--font-ui);font-size:13px;cursor:pointer;color:var(--text-primary)}.project-card-actions button:first-child{background:linear-gradient(140deg,var(--brand-primary),var(--brand-primary-strong));color:var(--bg-editor);border-color:var(--brand-primary-strong)}@media(max-width:760px){.project-list-container{padding:48px 16px 28px}.project-list-title{font-size:34px}.project-cards{grid-template-columns:1fr}}.project-shell{display:flex;flex-direction:column;height:100vh;overflow:hidden;position:relative}.project-shell--distraction-free .project-topbar,.project-shell--distraction-free .project-side-column,.project-shell--distraction-free .breadcrumb-bar{display:none}.project-shell--distraction-free .editor-area{padding-top:24px}.project-topbar{height:58px;min-height:58px;border-bottom:1px solid var(--border-subtle);background:var(--bg-panel);display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:16px;padding:8px 16px}.project-topbar-left{width:250px;min-width:250px;display:flex;align-items:center}.project-topbar-brand{display:inline-flex;align-items:center;gap:8px;min-width:0}.project-topbar-mark{width:24px;height:24px;flex-shrink:0;filter:drop-shadow(0 2px 6px rgba(44,86,184,.2))}.project-topbar-name{font-family:var(--font-ui);font-size:26px;font-weight:700;color:#213852;letter-spacing:-.03em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-topbar-center{display:flex;justify-content:center;min-width:0;padding:0 12px}.project-topbar-right{display:flex;align-items:center;justify-content:flex-end;gap:10px;width:250px;min-width:250px}.project-topbar-right .user-menu{position:relative;top:auto;right:auto;z-index:80}.project-topbar-right .user-menu-trigger{box-shadow:none;min-height:36px;padding-right:14px}.project-topbar-right .user-menu-trigger:hover{transform:none}.ai-usage-meter{display:inline-flex;align-items:center;justify-content:center;padding:2px 0;opacity:.85}.ai-usage-meter-track{width:8px;height:30px;border:1px solid #9fb4cc;border-radius:999px;background:#ffffff8c;position:relative;overflow:hidden}.ai-usage-meter-track--empty{background:#c8d3e28c}.ai-usage-meter-fill{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(180deg,#74a7ff,#3f74e6);transition:height .22s ease}.ai-usage-meter-fill--low{background:linear-gradient(180deg,#f0b16a,#d37848)}.project-workspace{flex:1;min-height:0;display:flex;position:relative}.project-side-column{position:relative;min-height:0;background:var(--bg-panel);overflow:visible;flex-shrink:0}.project-side-column--left{width:250px;min-width:250px;border-right:1px solid var(--border-subtle)}.project-side-column--right{width:330px;min-width:330px;border-left:1px solid var(--border-subtle)}.project-side-column--collapsed{width:22px;min-width:22px}.project-side-column-content{height:100%;min-height:0;overflow:hidden}.project-side-column--left .binder{width:100%;min-width:0;max-width:none;height:100%;border-right:none}.project-side-column--left .characters-dock{width:100%;height:100%;min-height:0;background:transparent;padding-bottom:38px}.project-side-toggle{position:absolute;top:50%;width:16px;height:56px;transform:translateY(-50%);border:1px solid #9cb3cb;background:#edf3fc;color:#2e4d73;font-size:15px;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;z-index:30;transition:background .12s ease,color .12s ease,border-color .12s ease}.project-side-toggle:hover{background:#e3edf9;color:#10223c;border-color:#7d9bbb}.project-side-toggle--left{right:-9px;border-radius:0 8px 8px 0}.project-side-toggle--right{left:-9px;border-radius:8px 0 0 8px}.project-editor-pane{flex:1;min-width:0;min-height:0;overflow:auto;padding-bottom:40px;--workspace-tabs-offset: 0px}.manuscript-side-rail{display:flex;flex-direction:column;min-height:100%;background:var(--bg-panel)}.manuscript-side-rail-tabs{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:8px 10px;border-bottom:1px solid var(--border-subtle)}.manuscript-side-rail-tab{border:1px solid var(--border-subtle);border-radius:999px;background:var(--bg-editor);color:var(--text-secondary);font-family:var(--font-ui);font-size:11px;font-weight:600;padding:5px 10px;cursor:pointer}.manuscript-side-rail-tab:hover{color:var(--text-primary)}.manuscript-side-rail-tab--active{background:var(--brand-primary-strong);color:var(--bg-editor);border-color:var(--brand-primary-strong)}.manuscript-side-rail-body{flex:1;min-height:0;overflow:auto;display:flex;flex-direction:column}.manuscript-side-rail-panel{flex:1;min-height:0;overflow:hidden}.manuscript-side-rail .inspector{width:100%;min-width:0;height:100%;border-left:none}.workspace-side-placeholder{padding:18px 16px;font-family:var(--font-ui)}.workspace-side-placeholder h3{font-size:15px;color:var(--text-primary);margin-bottom:8px}.workspace-side-placeholder p{font-size:12px;color:var(--text-secondary);line-height:1.55}.project-loading{display:flex;align-items:center;justify-content:center;height:100vh;font-family:var(--font-ui);font-size:14px;color:var(--text-secondary)}.workspace-tabs{display:inline-flex;align-items:center;gap:10px}.workspace-tab{border:1px solid transparent;border-radius:999px;padding:6px 16px;background:transparent;color:#3f5772;font-family:var(--font-ui);font-size:13px;font-weight:600;cursor:pointer;transition:all .12s ease}.workspace-tab:hover{border-color:#9fb4cc;color:var(--text-primary);background:#3f74e61a}.workspace-tab--active{color:var(--bg-editor);background:var(--brand-primary-strong);border-color:var(--brand-primary-strong);box-shadow:0 4px 10px #2c56b838}.binder{width:250px;min-width:200px;max-width:400px;height:100vh;display:flex;flex-direction:column;border-right:1px solid var(--border-subtle);background:var(--bg-panel);font-family:var(--font-ui);font-size:13px;-webkit-user-select:none;user-select:none;padding-bottom:46px}.binder-header{padding:14px 16px 10px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between}.binder-project-title{font-weight:700;font-size:15px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.binder-collapse-btn{border:none;background:transparent;font-size:11px;color:#4d637d;cursor:pointer;padding:4px 6px;border-radius:4px;opacity:.82;transition:opacity .15s;flex-shrink:0}.binder-collapse-btn:hover{opacity:1;background:#0000000d}.binder-expand-tab{position:absolute;left:0;top:50%;transform:translateY(-50%);z-index:50;width:20px;height:48px;border:none;border-right:1px solid var(--border-subtle);border-radius:0 6px 6px 0;background:var(--bg-panel);font-size:9px;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:.7;transition:opacity .15s}.binder-expand-tab:hover{opacity:1;background:#e4e4dc}.binder-tree{flex:1;min-height:0;overflow-y:auto;padding:8px 0 52px}.binder-main{position:relative;flex:1;min-height:0}.binder-footer{display:flex;gap:8px;padding:10px 12px 12px;border-top:1px solid var(--border-subtle);margin-bottom:2px}.binder-add-btn{flex:1;padding:5px 8px;border:1px solid var(--border-subtle);border-radius:5px;background:var(--bg-editor);font-family:var(--font-ui);font-size:12px;font-weight:600;color:#3f5772;cursor:pointer;transition:background 80ms}.binder-add-btn:hover{background:#eaf1fb;border-color:#9cb0c8;color:var(--text-primary)}.binder-node{display:flex;align-items:center;gap:6px;padding:5px 12px;cursor:pointer;border-radius:6px;margin:1px 6px;transition:background 60ms;white-space:nowrap;overflow:hidden;color:#2b3f58}.binder-node:hover{background:#3c639821}.binder-node--active{background:var(--brand-primary-strong);color:#fff;font-weight:600;border-radius:5px}.binder-node--active .binder-node-arrow,.binder-node--active .binder-node-icon{color:#fffc}.binder-node--dragging{opacity:.4}.binder-node--drop-target{background:#2f8e961f;outline:1px dashed rgba(47,142,150,.48);outline-offset:-1px;border-radius:4px}.binder-drop-line{height:2px;background:var(--brand-primary);border-radius:1px;margin-right:6px;pointer-events:none}.binder-node-arrow{display:inline-block;font-size:10px;color:#586d87;transition:transform .15s;width:12px;text-align:center;flex-shrink:0}.binder-node-arrow--open{transform:rotate(90deg)}.binder-node-icon{font-size:15px;flex-shrink:0;line-height:1}.binder-node-title{font-size:13px;line-height:1.25;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.binder-node-edit{flex:1;min-width:0;border:1px solid #aaa;border-radius:3px;padding:1px 4px;font-family:var(--font-ui);font-size:13px;outline:none}.binder-node-label{width:8px;height:8px;border-radius:50%;flex-shrink:0}.binder-context-menu{position:fixed;z-index:300;background:var(--bg-editor);border:1px solid var(--border-subtle);border-radius:8px;box-shadow:0 4px 20px #00000026,0 2px 4px #00000014;padding:4px 0;min-width:160px;animation:fadeIn 80ms ease-out}.binder-context-item{display:block;width:100%;padding:7px 14px;border:none;background:transparent;text-align:left;font-family:var(--font-ui);font-size:13px;color:var(--text-primary);cursor:pointer}.binder-context-item:hover{background:#ededea}.binder-context-item--danger{color:#c44}.binder-context-item--danger:hover{background:#fee}.binder-context-separator{height:1px;background:var(--border-subtle);margin:4px 0}.breadcrumb-bar{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:4px 12px;background:var(--bg-panel);border-bottom:1px solid var(--border-subtle);position:sticky;top:var(--workspace-tabs-offset, 0px);z-index:10;min-height:28px}.breadcrumb-main{min-width:0;flex:1;display:flex;align-items:center;gap:8px}.characters-workspace{display:grid;grid-template-columns:minmax(220px,300px) minmax(0,1fr);min-height:calc(100vh - 72px)}.characters-workspace--main-only{grid-template-columns:minmax(0,1fr)}.characters-dock{height:100%;display:flex;flex-direction:column;gap:8px;padding:10px;overflow-y:auto;font-family:var(--font-ui)}.characters-dock--embedded{background:var(--bg-panel)}.characters-dock-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.characters-dock-title{font-size:13px;font-weight:700;color:var(--text-primary)}.characters-dock-sub{margin-top:2px;font-size:11px;color:var(--text-secondary)}.characters-dock-list{display:flex;flex-direction:column;gap:4px;min-height:90px;max-height:220px;overflow-y:auto}.characters-dock-editor{display:flex;flex-direction:column;gap:6px;padding:8px;border:1px solid var(--border-subtle);border-radius:8px;background:#fff6}.characters-dock-editor-header{display:flex;align-items:center;justify-content:space-between;color:var(--text-secondary);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.characters-dock-editor label{display:flex;flex-direction:column;gap:4px;font-size:11px;color:var(--text-secondary)}.characters-dock-editor input,.characters-dock-editor textarea{width:100%;border:1px solid var(--border-subtle);border-radius:6px;background:var(--bg-editor);color:var(--text-primary);font-family:var(--font-ui);font-size:12px;line-height:1.5;outline:none;padding:6px 8px}.characters-dock-editor input:focus,.characters-dock-editor textarea:focus{border-color:#aaa}.characters-dock-linked{font-size:11px;color:var(--text-secondary)}.characters-dock-footer{margin-top:auto;padding-top:6px;border-top:1px solid var(--border-subtle)}.characters-sidebar{border-right:1px solid var(--border-subtle);background:#f4f4ee;padding:14px 12px;font-family:var(--font-ui);display:flex;flex-direction:column;gap:10px}.characters-sidebar-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.characters-sidebar-header h3{font-size:14px;color:var(--text-primary);margin-bottom:2px}.characters-sidebar-header p{font-size:11px;color:var(--text-secondary)}.characters-search{width:100%;border:1px solid var(--border-subtle);border-radius:6px;padding:7px 9px;background:var(--bg-editor);font-family:var(--font-ui);font-size:12px;color:var(--text-primary);outline:none}.characters-search:focus{border-color:#aaa}.characters-list{display:flex;flex-direction:column;gap:4px;overflow-y:auto;padding-right:2px}.characters-list-item{display:flex;align-items:center;gap:8px;width:100%;border:1px solid transparent;border-radius:8px;background:transparent;text-align:left;padding:8px;cursor:pointer}.characters-list-item:hover{background:#0000000a;border-color:var(--border-subtle)}.characters-list-item--active{background:#2f8e961f;border-color:#2f8e965c}.characters-list-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.characters-list-content{display:flex;flex-direction:column;gap:2px;min-width:0}.characters-list-name{font-size:12px;color:var(--text-primary);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.characters-list-role{font-size:10px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.characters-main{padding:20px 20px 100px;display:flex;flex-direction:column;gap:14px}.characters-card{border:1px solid var(--border-subtle);border-radius:10px;background:var(--bg-editor);box-shadow:0 1px 6px #0000000d;padding:14px 16px}.characters-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:10px}.characters-card-header h3{font-family:var(--font-ui);font-size:14px;color:var(--text-primary);margin-bottom:2px}.characters-card-header p{font-family:var(--font-ui);font-size:11px;color:var(--text-secondary)}.characters-form-grid{display:grid;gap:8px;grid-template-columns:repeat(2,minmax(0,1fr))}.characters-form-grid label{display:flex;flex-direction:column;gap:4px;font-family:var(--font-ui);font-size:11px;color:var(--text-secondary)}.characters-form-grid input,.characters-form-grid textarea{width:100%;border:1px solid var(--border-subtle);border-radius:6px;background:var(--bg-editor);color:var(--text-primary);font-family:var(--font-ui);font-size:12px;line-height:1.5;outline:none;padding:7px 9px}.characters-form-grid input:focus,.characters-form-grid textarea:focus{border-color:#aaa}.characters-field-span{grid-column:1 / -1}.characters-section-label{font-family:var(--font-ui);font-size:11px;font-weight:600;text-transform:uppercase;color:var(--text-secondary);letter-spacing:.05em;margin:12px 0 6px}.characters-chapter-chip-list{display:flex;flex-wrap:wrap;gap:6px}.characters-chapter-chip{border:1px solid var(--border-subtle);border-radius:999px;background:var(--bg-editor);color:var(--text-secondary);font-family:var(--font-ui);font-size:11px;padding:4px 10px;cursor:pointer}.characters-chapter-chip:hover{border-color:#aab9b8;color:var(--text-primary)}.characters-chapter-chip--active{background:#2f8e9624;color:var(--brand-primary-strong);border-color:#2f8e9666;font-weight:600}.characters-matrix-wrap{overflow:auto;border:1px solid var(--border-subtle);border-radius:8px}.characters-matrix{width:100%;border-collapse:collapse;min-width:520px;font-family:var(--font-ui);font-size:12px}.characters-matrix th,.characters-matrix td{border-bottom:1px solid #ecece6;border-right:1px solid #ecece6;padding:6px 8px;text-align:center}.characters-matrix th:first-child{position:sticky;left:0;background:#fafaf8;text-align:left;min-width:170px;z-index:1}.characters-matrix thead th{position:sticky;top:0;background:#f4f4ee;color:var(--text-secondary);font-weight:600;z-index:2}.characters-matrix thead th:first-child{z-index:3}.characters-matrix-name{display:inline-flex;align-items:center;gap:8px;border:none;background:transparent;font-family:var(--font-ui);font-size:12px;color:var(--text-primary);cursor:pointer}.characters-matrix-row--active th:first-child{background:#2f8e9614}.characters-matrix-cell{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border:1px solid transparent;border-radius:5px;background:transparent;color:transparent;cursor:default;transition:background 80ms ease,border-color 80ms ease,color 80ms ease}.characters-matrix-cell:hover{border-color:#bfcfcf}.characters-matrix-cell--active{background:#2f8e962e;border-color:#2f8e9673;color:var(--brand-primary-strong);font-weight:700}.characters-empty-note{font-family:var(--font-ui);font-size:11px;color:var(--text-secondary)}.characters-empty-state{min-height:360px;border:1px dashed var(--border-subtle);border-radius:10px;background:#ffffff73;display:flex;flex-direction:column;gap:8px;align-items:center;justify-content:center;text-align:center;padding:20px;font-family:var(--font-ui)}.characters-empty-state h3{font-size:16px;color:var(--text-primary)}.characters-empty-state p{font-size:13px;color:var(--text-secondary);max-width:460px}.character-wizard-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000003d;display:flex;align-items:center;justify-content:center;padding:18px;z-index:450}.character-wizard{width:min(860px,96vw);max-height:92vh;background:var(--bg-editor);border-radius:14px;border:1px solid var(--border-subtle);box-shadow:0 18px 54px #00000038;display:flex;flex-direction:column;overflow:hidden}.character-wizard-header{display:flex;justify-content:space-between;gap:10px;padding:16px 20px 12px;border-bottom:1px solid var(--border-subtle)}.character-wizard-header h3{font-family:var(--font-ui);font-size:18px;color:var(--text-primary)}.character-wizard-header p{font-family:var(--font-ui);font-size:12px;color:var(--text-secondary);margin-top:3px}.character-wizard-close{border:none;background:transparent;color:var(--text-secondary);font-size:16px;cursor:pointer}.character-wizard-steps{position:relative;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;padding:10px 20px;border-bottom:1px solid var(--border-subtle)}.character-wizard-step{border:1px solid var(--border-subtle);border-radius:8px;background:#f6f6f2;color:var(--text-secondary);font-family:var(--font-ui);font-size:12px;padding:8px 10px;display:flex;align-items:center;gap:8px;cursor:pointer}.character-wizard-step span{width:18px;height:18px;border-radius:50%;background:#00000014;display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:600}.character-wizard-step--active{border-color:#2f8e968c;color:var(--brand-primary-strong);background:#2f8e961a}.character-wizard-step--done{border-color:#2f8e9666}.character-wizard-progress{position:absolute;left:20px;right:20px;bottom:0;height:2px;background:#ecece6}.character-wizard-progress-fill{height:100%;background:var(--brand-primary);transition:width .18s ease}.character-wizard-body{flex:1;overflow-y:auto;padding:16px 20px 20px}.character-wizard-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.character-wizard-grid label,.character-wizard-label{display:flex;flex-direction:column;gap:4px;font-family:var(--font-ui);font-size:11px;color:var(--text-secondary)}.character-wizard-grid input,.character-wizard-grid textarea{width:100%;border:1px solid var(--border-subtle);border-radius:7px;padding:8px 10px;font-family:var(--font-ui);font-size:13px;line-height:1.5;color:var(--text-primary);outline:none}.character-wizard-grid input:focus,.character-wizard-grid textarea:focus{border-color:#aaa}.character-wizard-field--span{grid-column:1 / -1}.character-wizard-chapter-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:2px}.character-wizard-chip{border:1px solid var(--border-subtle);border-radius:999px;background:#fafaf8;color:var(--text-secondary);font-family:var(--font-ui);font-size:11px;padding:4px 10px;cursor:pointer}.character-wizard-chip--active{border-color:#2f8e967a;background:#2f8e961f;color:var(--brand-primary-strong)}.character-wizard-empty{font-family:var(--font-ui);font-size:11px;color:var(--text-secondary)}.character-wizard-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:1px solid var(--border-subtle)}@media(max-width:980px){.manuscript-side-rail{width:280px;min-width:220px}.characters-workspace{grid-template-columns:1fr}.characters-sidebar{border-right:none;border-bottom:1px solid var(--border-subtle);max-height:240px}.characters-main{padding:14px 12px 90px}.characters-form-grid,.character-wizard-grid{grid-template-columns:1fr}.character-wizard{width:min(720px,98vw)}.character-wizard-steps{grid-template-columns:1fr}}@media(max-width:760px){.manuscript-side-rail{position:absolute;right:0;top:0;bottom:32px;z-index:60;width:min(86vw,320px);box-shadow:-8px 0 22px #0000001f}}.breadcrumb-nav{display:flex;gap:2px;flex-shrink:0}.breadcrumb-nav-btn{border:none;background:transparent;font-size:10px;color:var(--text-secondary);cursor:pointer;padding:2px 5px;border-radius:3px;line-height:1}.breadcrumb-nav-btn:hover:not(:disabled){background:#0000000f;color:var(--text-primary)}.breadcrumb-nav-btn:disabled{opacity:.3;cursor:default}.breadcrumb-path{display:flex;align-items:center;gap:0;overflow:hidden;white-space:nowrap}.breadcrumb-tools{display:inline-flex;align-items:center;gap:8px;flex-shrink:0}.collection-toolbar{display:inline-flex;align-items:center;gap:6px}.collection-toolbar-select{border:1px solid var(--border-subtle);border-radius:999px;background:#fffc;color:#4a607c;font-family:var(--font-ui);font-size:11px;font-weight:600;line-height:1;padding:6px 10px;min-width:140px;outline:none}.collection-toolbar-btn{border:1px solid var(--border-subtle);border-radius:999px;background:#fffc;color:#4a607c;font-family:var(--font-ui);font-size:11px;font-weight:600;line-height:1;padding:6px 10px;cursor:pointer}.collection-toolbar-btn:hover{background:#3f74e61a;color:#1b3352}.manuscript-surface-toggle{display:inline-flex;align-items:center;gap:4px;padding:2px;border:1px solid var(--border-subtle);border-radius:999px;background:#ffffffb3}.manuscript-surface-btn{border:none;border-radius:999px;background:transparent;color:#4a607c;font-family:var(--font-ui);font-size:11px;font-weight:600;line-height:1;padding:5px 10px;cursor:pointer;transition:background .12s ease,color .12s ease}.manuscript-surface-btn:hover:not(:disabled){background:#3f74e61a;color:#1b3352}.manuscript-surface-btn--active{background:var(--brand-primary-strong);color:#fff}.manuscript-surface-btn:disabled{opacity:.45;cursor:not-allowed}.breadcrumb-segment{display:flex;align-items:center}.breadcrumb-separator{margin:0 4px;color:var(--text-secondary);opacity:.5;font-size:13px}.breadcrumb-link{border:none;background:transparent;font-family:var(--font-ui);font-size:12px;color:var(--text-secondary);cursor:pointer;padding:1px 2px;border-radius:2px}.breadcrumb-link:hover{color:var(--text-primary);background:#0000000d}.breadcrumb-current{font-family:var(--font-ui);font-size:12px;font-weight:600;color:var(--text-primary)}.editor-area{display:flex;justify-content:center;width:100%;min-width:0;padding:40px 24px 80px}.editor-area--notecards{justify-content:flex-start;padding:22px 24px 80px}.editor-area--outliner{justify-content:flex-start;padding:20px 24px 80px}.editor-area-empty{display:flex;align-items:center;justify-content:center;height:calc(100vh - 40px);font-family:var(--font-ui);font-size:14px;color:var(--text-secondary)}.editor-loading{padding:40px;text-align:center;font-family:var(--font-ui);font-size:14px;color:var(--text-secondary)}.editor-doc-title{font-family:var(--font-ui);font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;padding-top:8px}.scrivenings{display:flex;flex-direction:column;align-items:center;padding:20px 24px 80px}.scrivenings .editor-page{border-radius:0;box-shadow:none;border-bottom:none}.scriv-divider{width:100%;max-width:var(--editor-max-width);height:1px;background:var(--border-subtle);margin:4px 0}.editor-page{position:relative;width:100%;max-width:var(--editor-max-width);background:var(--bg-editor);border:1px solid #e0e0da;border-radius:4px;box-shadow:var(--shadow-page);padding:48px 56px;min-height:400px;transform-origin:top center;zoom:var(--editor-zoom-factor, 1)}.editor-page[data-view-mode=page]{max-width:var(--page-width);padding:var(--page-padding-top) var(--page-padding-side) var(--page-padding-bottom);min-height:var(--page-height);border-radius:3px 3px 0 0}.editor-page[data-view-mode=page] .tiptap{font-size:var(--page-font-size);line-height:var(--page-line-height);padding:0}.editor-page[data-view-mode=page][data-page-layout=focused]{max-width:min(100%,calc(var(--page-width) * 2.7));min-height:0;padding:12px 8px 14px;background:transparent;border:none;box-shadow:none}.page-focused-layout{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:16px}.page-focused-main{display:flex;flex-direction:column;align-items:center;gap:7px;width:var(--page-width);min-width:var(--page-width)}.page-focused-main-sheet{position:relative;width:var(--page-width);min-height:var(--page-height);max-height:var(--page-height);padding:var(--page-padding-top) var(--page-padding-side) var(--page-padding-bottom);background:var(--bg-editor);border:1px solid #e0e0da;border-radius:3px;box-shadow:var(--shadow-page);overflow:hidden}.editor-page[data-view-mode=page][data-page-layout=focused] .page-focused-main-sheet .tiptap{min-height:0;transform:translateY(calc(-1 * var(--page-focused-offset, 0px)));transform-origin:top left}.page-focused-main-number{font-family:var(--font-ui);font-size:10px;color:#7288a4}.page-focused-side{display:flex;flex-direction:column;align-items:center;gap:6px;pointer-events:none}.page-focused-side--empty{visibility:hidden}.page-focused-side-sheet{width:var(--page-width);min-height:var(--page-height);max-height:var(--page-height);padding:var(--page-padding-top) var(--page-padding-side) var(--page-padding-bottom);background:#fffffff2;border:1px solid #d5e0ec;border-radius:3px;box-shadow:0 10px 20px #1025481a;overflow:hidden;opacity:.9;transform:scale(.84);transform-origin:center center}.editor-page[data-view-mode=page][data-page-layout=focused] .page-focused-side-content.tiptap{min-height:0;opacity:.95;pointer-events:none}.page-focused-side-number{font-family:var(--font-ui);font-size:10px;color:#8a9cb4}@media(max-width:1180px){.editor-page[data-view-mode=page][data-page-layout=focused]{max-width:var(--page-width);padding:8px 0 12px}.page-focused-layout{grid-template-columns:auto;justify-content:center}.page-focused-side{display:none}}.notecard-board{width:100%;min-width:0}.notecard-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.notecard{position:relative;border:1px solid #c7d6e8;border-radius:10px;background:#fffdf8;color:var(--text-primary);text-align:left;padding:14px 14px 12px;min-height:172px;display:flex;flex-direction:column;gap:10px;cursor:pointer;box-shadow:0 3px 10px #10254814;transition:transform .11s ease,box-shadow .11s ease,border-color .11s ease}.notecard--editing{border-color:#7f9ec6;box-shadow:0 0 0 2px #3f74e61f,0 6px 16px #1025481f}.notecard:hover{transform:translateY(-2px);border-color:#93afd0;box-shadow:0 10px 22px #10254821}.notecard--drop-before{box-shadow:inset 0 3px #3f74e6,0 8px 20px #10254821}.notecard--drop-after{box-shadow:inset 0 -3px #3f74e6,0 8px 20px #10254821}.notecard--drop-inside{border-color:#3f74e6;box-shadow:0 0 0 2px #3f74e640,0 8px 20px #10254821}.notecard-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.notecard-title{font-family:var(--font-ui);font-size:13px;font-weight:700;color:#183250;line-height:1.35}.notecard-title-btn,.notecard-body-btn{border:none;background:transparent;text-align:left;padding:0;color:inherit;cursor:text}.notecard-title-btn{min-width:0}.notecard-title-btn .notecard-title{display:inline-block}.notecard-title-input{width:100%;border:1px solid #9eb6d2;border-radius:6px;background:#fff;color:#183250;font-family:var(--font-ui);font-size:13px;font-weight:700;line-height:1.35;padding:4px 7px;outline:none}.notecard-status{flex-shrink:0;font-family:var(--font-ui);font-size:10px;font-weight:700;letter-spacing:.02em;color:#33557a;border:1px solid #b8cbe0;border-radius:999px;padding:2px 8px;background:#edf4fd}.notecard-body{font-family:var(--font-ui);font-size:12px;line-height:1.45;color:#405974;flex:1;display:-webkit-box;-webkit-line-clamp:6;-webkit-box-orient:vertical;overflow:hidden}.notecard-body-btn,.notecard-body-btn .notecard-body{width:100%}.notecard-body-input{width:100%;border:1px solid #9eb6d2;border-radius:6px;background:#fff;color:#405974;font-family:var(--font-ui);font-size:12px;line-height:1.45;padding:7px 8px;resize:vertical;outline:none}.notecard-foot{display:flex;align-items:center;gap:7px;flex-wrap:wrap;font-family:var(--font-ui);font-size:10px;font-weight:600;color:#587191;text-transform:uppercase;letter-spacing:.05em}.notecard-type{color:#355778}.notecard-metric{padding-left:7px;border-left:1px solid #c8d5e5}.notecard-label{position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:10px 0 0 10px}.notecard-empty{width:100%;border:1px dashed #c2d3e5;border-radius:10px;padding:24px;color:#506883;font-family:var(--font-ui);font-size:13px;background:#ffffff8c}.outliner-wrap{width:100%;border:1px solid #cbd8ea;border-radius:10px;background:#ffffffbf;overflow:auto}.outliner-table{width:100%;border-collapse:collapse;min-width:980px;font-family:var(--font-ui)}.outliner-table thead th{position:sticky;top:0;z-index:2;text-align:left;font-size:11px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:#4c647f;background:#edf4ff;border-bottom:1px solid #c9d8ea;padding:10px}.outliner-handle-col{width:34px;min-width:34px;max-width:34px;padding-left:6px;padding-right:0}.outliner-open-col{width:42px;min-width:42px;max-width:42px;padding-left:0;padding-right:6px}.outliner-row td{border-top:1px solid #dde6f2;padding:8px 10px;vertical-align:top}.outliner-row{cursor:default}.outliner-handle-cell{padding:8px 0 8px 6px;vertical-align:middle}.outliner-drag-handle{width:22px;height:22px;border:1px solid #bed0e5;border-radius:6px;background:#f3f8ff;display:inline-flex;align-items:center;justify-content:center;cursor:grab;padding:0}.outliner-drag-handle:hover{border-color:#92adce;background:#e9f2ff}.outliner-drag-handle:active{cursor:grabbing}.outliner-drag-dots{width:10px;height:12px;background:radial-gradient(circle,#5f7fa6 1.2px,transparent 1.3px) 0 0 / 5px 4px,radial-gradient(circle,#5f7fa6 1.2px,transparent 1.3px) 2px 2px / 5px 4px;opacity:.85}.outliner-open-cell{text-align:right;vertical-align:middle;padding-right:8px}.outliner-open-btn{width:24px;height:24px;border:1px solid #bed0e5;border-radius:6px;background:#f3f8ff;color:#3e628e;display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;line-height:1;cursor:pointer;padding:0;transition:border-color .11s ease,background .11s ease,color .11s ease}.outliner-open-btn:hover{border-color:#92adce;background:#e9f2ff;color:#1e3a5e}.outliner-row--drop-before td{box-shadow:inset 0 3px #3f74e6}.outliner-row--drop-after td{box-shadow:inset 0 -3px #3f74e6}.outliner-row--drop-inside td{background:#3f74e61f}.outliner-row--active td{background:#3f74e614}.outliner-title-btn,.outliner-synopsis-btn{border:none;background:transparent;text-align:left;padding:0;width:100%;color:inherit;cursor:text}.outliner-title-text{display:block;color:#17304d;font-size:13px;font-weight:700;line-height:1.4}.outliner-title-type{display:inline-block;margin-top:2px;color:#617998;font-size:10px;text-transform:uppercase;letter-spacing:.04em}.outliner-synopsis-btn{color:#405974;font-size:12px;line-height:1.45;min-height:36px}.outliner-input,.outliner-textarea,.outliner-select{width:100%;border:1px solid #a9bed7;border-radius:6px;background:#fff;color:#16314f;font-family:var(--font-ui);font-size:12px;line-height:1.4;padding:6px 8px;outline:none}.outliner-textarea{resize:vertical;min-height:60px}.outliner-label-dot{display:inline-block;width:9px;height:9px;border-radius:999px;margin-left:6px;vertical-align:middle}.outliner-words{display:inline-flex;flex-direction:column;gap:2px;color:#1f3d5f;font-size:12px;font-weight:600}.outliner-words-sub{color:#667f9d;font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.03em}.outliner-empty{color:#7188a5;font-size:11px}.outliner-characters{color:#3b5574;font-size:11px;line-height:1.4}.collections-dialog{width:min(960px,92vw)}.collections-dialog-body{display:grid;grid-template-columns:260px 1fr;min-height:520px}.collections-dialog-list{border-right:1px solid var(--border-subtle);background:#f4f8fe;padding:12px;display:flex;flex-direction:column;gap:10px}.collections-dialog-list-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.collections-dialog-list-scroll{display:flex;flex-direction:column;gap:6px;overflow:auto;min-height:0}.collections-dialog-item{border:1px solid var(--border-subtle);border-radius:8px;background:#fff;color:var(--text-primary);text-align:left;font-family:var(--font-ui);padding:8px 10px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:8px}.collections-dialog-item--active{border-color:#789fcd;background:#e9f1fc}.collections-dialog-item-name{font-size:12px;font-weight:600}.collections-dialog-item-kind{font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:#6a83a2}.collections-dialog-editor{padding:14px 16px;display:flex;flex-direction:column;gap:12px}.collections-dialog-field{display:flex;flex-direction:column;gap:6px}.collections-dialog-field label{font-family:var(--font-ui);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:#4e6783}.collections-dialog-field input,.collections-dialog-field select{border:1px solid var(--border-subtle);border-radius:6px;background:#fff;color:var(--text-primary);font-family:var(--font-ui);font-size:13px;padding:8px 10px;outline:none}.collections-dialog-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.collections-dialog-kind-badge{border:1px solid #b8cae0;border-radius:999px;background:#eef5ff;color:#4f6785;font-family:var(--font-ui);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:4px 10px}.collections-dialog-subtle{color:#5f7794;font-family:var(--font-ui);font-size:11px}.collections-dialog-rules{display:flex;flex-direction:column;gap:10px}.collections-dialog-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.collections-dialog-grid label{display:flex;flex-direction:column;gap:4px;color:#566f8c;font-family:var(--font-ui);font-size:11px;font-weight:600}.collections-dialog-grid select{border:1px solid var(--border-subtle);border-radius:6px;background:#fff;color:var(--text-primary);font-family:var(--font-ui);font-size:12px;padding:6px 8px;outline:none}.collections-dialog-doc-list{border:1px solid var(--border-subtle);border-radius:8px;background:#fbfdff;max-height:290px;overflow:auto;padding:8px;display:flex;flex-direction:column;gap:4px}.collections-dialog-doc-item{display:flex;align-items:flex-start;gap:8px;padding:4px 6px;border-radius:6px;font-family:var(--font-ui);font-size:11px;color:#3c5473}.collections-dialog-doc-item:hover{background:#3f74e614}@media(max-width:980px){.collections-dialog-body{grid-template-columns:1fr;min-height:0}.collections-dialog-list{border-right:none;border-bottom:1px solid var(--border-subtle)}.collections-dialog-grid{grid-template-columns:1fr}}.page-separator{position:absolute;left:var(--page-padding-side, 0);right:var(--page-padding-side, 0);z-index:8;pointer-events:none;display:flex;align-items:center;justify-content:center;border-top:1px solid rgba(188,205,225,.85);border-bottom:1px solid rgba(188,205,225,.85);background:linear-gradient(180deg,#eff4fbf2,#eff4fbd9,#eff4fbf2);box-shadow:0 1px 2px #10254814}.page-separator-number{font-family:var(--font-ui);font-size:10px;font-weight:600;color:#5f7391;letter-spacing:.01em;opacity:.9;font-variant-numeric:tabular-nums}.tiptap{outline:none;min-height:100%;padding:2rem 0;font-size:var(--font-size-body);-moz-tab-size:4;tab-size:4}.tiptap p{margin-bottom:0;text-indent:2em}.tiptap>p:first-child{text-indent:0}.tiptap hr+p{text-indent:0}.tiptap hr{border:none;text-align:center;margin:1.5em 0;overflow:visible}.tiptap hr:after{content:"* * *";display:inline-block;font-family:var(--font-body);font-size:1em;color:var(--text-secondary);letter-spacing:.3em}.tiptap p.is-editor-empty:first-child:before{content:attr(data-placeholder);float:left;color:var(--text-secondary);opacity:.5;pointer-events:none;height:0;font-style:italic}.ghost-text-inline{color:var(--text-ghost);font-style:normal;text-decoration:underline dotted rgba(54,105,195,.35);text-underline-offset:.18em;pointer-events:none;-webkit-user-select:none;user-select:none}.ghost-text-inline::selection{background:transparent}.ghost-generation-nav{position:absolute;transform:translate(-50%);z-index:120;display:inline-flex;align-items:center;gap:4px;padding:2px 4px;border:1px solid var(--border-subtle);border-radius:999px;background:#ffffffeb;box-shadow:0 1px 4px #00000014;font-family:var(--font-ui);font-size:10px;color:var(--text-secondary);-webkit-user-select:none;user-select:none}.ghost-generation-nav-btn{width:18px;height:18px;border:1px solid transparent;border-radius:999px;background:transparent;font-family:var(--font-ui);font-size:12px;line-height:1;color:inherit;cursor:pointer;transition:background 80ms,color 80ms,border-color 80ms}.ghost-generation-nav-btn:hover:not(:disabled){color:var(--text-primary);background:#0000000d;border-color:var(--border-subtle)}.ghost-generation-nav-btn:disabled{opacity:.35;cursor:default}.ghost-generation-nav-count{min-width:28px;text-align:center;font-variant-numeric:tabular-nums}.format-toolbar{display:flex;align-items:center;gap:2px;padding:4px 0;margin-bottom:8px;border-bottom:1px solid var(--border-subtle);opacity:.7;transition:opacity .15s}.format-toolbar:hover,.editor-page:focus-within .format-toolbar{opacity:1}.format-toolbar-btn{border:1px solid transparent;background:transparent;font-family:var(--font-ui);font-size:13px;color:var(--text-secondary);cursor:pointer;padding:3px 8px;border-radius:4px;line-height:1;transition:background 80ms,color 80ms}.format-toolbar-btn:hover{background:#0000000d;border-color:var(--border-subtle);color:var(--text-primary)}.format-toolbar-btn--active{background:#00000014;border-color:#c0c0b8;color:var(--text-primary)}.format-toolbar-btn--scene{font-size:11px;letter-spacing:.1em}.format-toolbar-separator{width:1px;height:16px;background:var(--border-subtle);margin:0 4px}.status-bar{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:8px 18px;font-family:var(--font-ui);font-size:12px;color:var(--text-secondary);background:linear-gradient(180deg,#edf4ff,var(--brand-surface));border-top:1px solid var(--border-subtle);box-shadow:0 -2px 8px #122a4e14;z-index:100}.status-bar-left,.status-bar-right{display:flex;align-items:center;gap:9px}.status-bar-separator{color:#8fa2bb}.status-bar-back{border:none;background:transparent;font-family:var(--font-ui);font-size:12px;color:#36506d;font-weight:500;cursor:pointer;padding:4px 8px;border-radius:5px;transition:background 80ms,color 80ms,border-color 80ms}.status-bar-back:hover{color:var(--text-primary);background:#3f74e61f}.status-bar-focus-btn--active{color:#fff;background:#365fbb}.status-bar-focus-btn--active:hover{color:#fff;background:#2f56ab}.status-bar-fullscreen-btn--active{color:#fff;background:#264f9f}.status-bar-fullscreen-btn--active:hover{color:#fff;background:#22468d}.status-bar-gear{border:none;background:transparent;font-size:14px;color:#48617d;cursor:pointer;padding:4px 6px;border-radius:5px;line-height:1;opacity:.9;transition:opacity .1s,color .1s,background 80ms}.status-bar-gear:hover{opacity:1;color:var(--text-primary);background:#0000000f}.status-bar-save{font-size:12px;font-weight:500}.status-bar-save--error{color:#e74c3c;font-weight:600}.status-bar-zoom{display:flex;align-items:center;gap:2px}.status-bar-zoom-btn,.status-bar-zoom-value{border:1px solid transparent;border-radius:4px;background:transparent;color:#4c6480;font-family:var(--font-ui);font-size:12px;line-height:1;cursor:pointer;transition:background 80ms,color 80ms,border-color 80ms}.status-bar-zoom-btn{width:22px;height:22px}.status-bar-zoom-value{min-width:44px;height:22px;padding:0 6px;font-variant-numeric:tabular-nums}.status-bar-zoom-btn:hover:not(:disabled),.status-bar-zoom-value:hover{color:var(--text-primary);background:#3f74e61f;border-color:#9fb4cc}.status-bar-zoom-btn:disabled{opacity:.35;cursor:default}.completion-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000026;display:flex;align-items:flex-end;justify-content:center;padding-bottom:20vh;z-index:200;animation:fadeIn .1s ease-out}.completion-modal{background:var(--bg-editor);border:1px solid var(--border-subtle);border-radius:12px;padding:16px 20px;width:100%;max-width:560px;box-shadow:0 8px 32px #0000001f;animation:slideUp .15s ease-out}.completion-modal input{width:100%;border:none;outline:none;font-family:var(--font-ui);font-size:15px;color:var(--text-primary);background:transparent;padding:4px 0}.completion-modal input::placeholder{color:var(--text-secondary);opacity:.6}.completion-modal-hint{font-family:var(--font-ui);font-size:11px;color:var(--text-secondary);margin-top:8px;opacity:.6}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}.ai-loading{display:inline-block;margin-left:3px;vertical-align:text-bottom}.ai-loading--ghost{position:relative;width:16px;height:14px;animation:cairnShift 1.1s ease-in-out infinite}.ai-loading--ghost:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(8px 3px at 50% 24%,rgba(191,225,255,.95),rgba(115,166,240,.96) 80%,transparent 84%),radial-gradient(10px 4px at 50% 54%,rgba(139,191,255,.96),rgba(78,128,224,.98) 80%,transparent 84%),radial-gradient(13px 5px at 50% 86%,rgba(93,147,246,.98),rgba(46,92,190,.98) 80%,transparent 84%);filter:drop-shadow(0 2px 4px rgba(26,65,138,.35))}.ai-loading--ghost:after{content:"";position:absolute;width:14px;height:2px;left:1px;bottom:0;border-radius:999px;background:#15305e38}@keyframes cairnShift{0%,to{transform:translateY(0)}50%{transform:translateY(-1px)}}.rephrase-dropdown{position:absolute;z-index:150;background:var(--bg-editor);border:1px solid var(--border-subtle);border-radius:8px;box-shadow:0 4px 20px #0000001a;min-width:280px;max-width:480px;overflow:hidden;animation:fadeIn .1s ease-out}.rephrase-loading{padding:12px 16px;font-family:var(--font-ui);font-size:13px;color:var(--text-secondary);font-style:italic}.rephrase-option{display:flex;align-items:flex-start;gap:10px;width:100%;padding:10px 14px;border:none;background:transparent;cursor:pointer;text-align:left;font-family:var(--font-body);font-size:15px;line-height:1.5;color:var(--text-primary);transition:background 80ms}.rephrase-option:hover{background:#f0f0ed}.rephrase-option+.rephrase-option{border-top:1px solid var(--border-subtle)}.rephrase-key{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;margin-top:2px;border-radius:4px;background:#f0f0ed;font-family:var(--font-ui);font-size:11px;font-weight:600;color:var(--text-secondary)}.rephrase-text{flex:1}.rephrase-trigger{position:absolute;z-index:140;padding:4px 10px;border:1px solid var(--border-subtle);border-radius:6px;background:var(--bg-editor);box-shadow:0 2px 8px #00000014;font-family:var(--font-ui);font-size:11px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:background 80ms,color 80ms;animation:fadeIn .1s ease-out}.rephrase-trigger:hover{background:#f0f0ed;color:var(--text-primary)}.rephrase-panel{position:absolute;z-index:150;background:var(--bg-editor);border:1px solid var(--border-subtle);border-radius:10px;box-shadow:0 4px 24px #0000001f;min-width:320px;max-width:600px;overflow:hidden;animation:fadeIn .1s ease-out}.rephrase-panel-loading{padding:14px 18px;font-family:var(--font-ui);font-size:13px;color:var(--text-secondary);font-style:italic}.rephrase-panel-sentences{display:flex;flex-direction:column}.rephrase-sentence{display:flex;align-items:flex-start;gap:10px;width:100%;padding:10px 14px;border:none;background:transparent;cursor:pointer;text-align:left;font-family:var(--font-body);font-size:15px;line-height:1.5;color:var(--text-primary);transition:background 80ms}.rephrase-sentence:hover{background:#f5f5f2}.rephrase-sentence+.rephrase-sentence{border-top:1px solid var(--border-subtle)}.rephrase-sentence--changed{background:#f0f7ff}.rephrase-sentence--changed:hover{background:#e6f0fa}.rephrase-sentence-key{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;margin-top:2px;border-radius:4px;background:#f0f0ed;font-family:var(--font-ui);font-size:11px;font-weight:600;color:var(--text-secondary)}.rephrase-sentence--changed .rephrase-sentence-key{background:#d0e4f7;color:#3b6fa0}.rephrase-sentence-text{flex:1}.rephrase-panel-hint{padding:8px 14px;border-top:1px solid var(--border-subtle);font-family:var(--font-ui);font-size:11px;color:var(--text-secondary);opacity:.7}.inspector{width:280px;min-width:220px;height:100vh;display:flex;flex-direction:column;border-left:1px solid var(--border-subtle);background:var(--bg-panel);font-family:var(--font-ui);font-size:14px;overflow-y:auto;padding-bottom:32px}.inspector-header{padding:14px 16px 12px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:baseline;gap:8px}.inspector-title{font-weight:700;font-size:15px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inspector-type{font-size:11px;color:#5b728c;text-transform:uppercase;letter-spacing:.06em}.inspector-section{padding:12px 16px;border-bottom:1px solid var(--border-subtle)}.inspector-section-label{font-size:12px;font-weight:600;color:#4f6783;text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}.inspector-synopsis{width:100%;border:1px solid var(--border-subtle);border-radius:6px;padding:8px 10px;font-family:var(--font-ui);font-size:13px;line-height:1.5;color:var(--text-primary);background:var(--bg-editor);resize:vertical;outline:none}.inspector-synopsis:focus{border-color:var(--brand-primary)}.inspector-labels{display:flex;gap:6px;flex-wrap:wrap}.inspector-label-dot{width:22px;height:22px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:border-color 80ms}.inspector-label-dot--none{background:#e0e0dc}.inspector-label-dot--active{border-color:var(--text-primary)}.inspector-label-dot:hover{border-color:var(--text-secondary)}.inspector-status-select{width:100%;padding:6px 8px;border:1px solid var(--border-subtle);border-radius:6px;font-family:var(--font-ui);font-size:14px;color:var(--text-primary);background:var(--bg-editor);outline:none}.inspector-stat{font-size:16px;font-weight:600;color:var(--text-primary)}.inspector-readonly-character-list{display:flex;flex-wrap:wrap;gap:6px}.inspector-readonly-character-chip{border:1px solid var(--border-subtle);border-radius:999px;background:var(--bg-editor);color:var(--text-secondary);font-family:var(--font-ui);font-size:11px;padding:4px 10px;display:inline-flex;align-items:center;gap:6px;cursor:default;-webkit-user-select:none;user-select:none}.character-tracker{display:flex;flex-direction:column;gap:8px}.character-tracker-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.character-tracker-label{font-family:var(--font-ui);font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.character-tracker-sub{margin-top:3px;font-family:var(--font-ui);font-size:11px;color:var(--text-secondary)}.character-tracker-list{display:flex;flex-wrap:wrap;gap:6px}.character-tracker-item{border:1px solid var(--border-subtle);border-radius:999px;background:var(--bg-editor);color:var(--text-secondary);font-family:var(--font-ui);font-size:11px;padding:4px 10px;cursor:pointer;display:inline-flex;align-items:center;gap:6px}.character-tracker-item:hover{border-color:#aab9b8;color:var(--text-primary)}.character-tracker-item--active{background:#2f8e9624;color:var(--brand-primary-strong);border-color:#2f8e966b;font-weight:600}.character-tracker-name{line-height:1}.character-tracker-status{font-family:var(--font-ui);font-size:11px;color:var(--text-secondary)}.character-tracker-suggestions{display:flex;flex-direction:column;gap:6px}.character-tracker-chip-list{display:flex;flex-wrap:wrap;gap:6px}.find-replace-overlay{position:relative;z-index:180}.find-replace-panel{background:var(--bg-editor);border-bottom:1px solid var(--border-subtle);box-shadow:0 2px 8px #00000014;padding:12px 16px}.find-replace-header{display:flex;gap:8px;align-items:center}.find-replace-input{flex:1;border:1px solid var(--border-subtle);border-radius:6px;padding:7px 10px;font-family:var(--font-ui);font-size:14px;color:var(--text-primary);outline:none}.find-replace-input:focus{border-color:#888}.find-replace-btn{padding:7px 14px;border:1px solid var(--border-subtle);border-radius:6px;background:var(--bg-editor);font-family:var(--font-ui);font-size:13px;cursor:pointer;color:var(--text-primary)}.find-replace-btn:hover{background:#f0f0ed}.find-replace-close{border:none;background:transparent;font-size:18px;color:var(--text-secondary);cursor:pointer;padding:4px 8px}.find-replace-results{max-height:300px;overflow-y:auto;margin-top:8px}.find-replace-status{padding:8px 0;font-family:var(--font-ui);font-size:13px;color:var(--text-secondary)}.find-replace-result{display:flex;flex-direction:column;gap:2px;width:100%;padding:8px 6px;border:none;background:transparent;text-align:left;cursor:pointer;border-radius:4px}.find-replace-result:hover{background:#f0f0ed}.find-replace-result-title{font-family:var(--font-ui);font-size:12px;font-weight:600;color:var(--text-primary)}.find-replace-result-context{font-family:var(--font-ui);font-size:12px;color:var(--text-secondary);line-height:1.4}.status-bar-center{display:flex;align-items:center;gap:12px}.status-bar-target{display:flex;align-items:center;gap:6px}.status-bar-target-bar{width:80px;height:6px;background:#e0e0dc;border-radius:3px;overflow:hidden}.status-bar-target-fill{height:100%;background:var(--brand-primary);border-radius:3px;transition:width .3s ease}.status-bar-target-bar--session{width:60px}.status-bar-target-fill--session{background:#3aa96f}.status-bar-target-label{font-size:10px;font-weight:600;color:var(--text-secondary);min-width:28px}.view-mode-selector{display:flex;align-items:center;gap:2px}.view-mode-btn{border:1px solid transparent;background:transparent;font-family:var(--font-ui);font-size:11px;color:var(--text-secondary);cursor:pointer;padding:2px 8px;border-radius:3px;transition:background .1s,color .1s}.view-mode-btn:hover{background:#0000000f}.view-mode-btn--active{background:#00000014;color:var(--text-primary);font-weight:600}.view-mode-format-select{margin-left:4px;font-family:var(--font-ui);font-size:11px;color:var(--text-secondary);background:transparent;border:1px solid var(--border-subtle);border-radius:3px;padding:1px 4px;cursor:pointer}.view-mode-page-layout{margin-left:4px;display:inline-flex;align-items:center;gap:2px;border:1px solid var(--border-subtle);border-radius:4px;padding:1px;background:#fff9}.view-mode-page-layout-btn{width:22px;height:20px;border:1px solid transparent;border-radius:3px;background:transparent;color:#587090;display:inline-flex;align-items:center;justify-content:center;padding:0;cursor:pointer;transition:background 90ms ease,color 90ms ease,border-color 90ms ease}.view-mode-page-layout-btn svg{width:13px;height:13px;fill:currentColor}.view-mode-page-layout-btn:hover{background:#3f74e61a;color:#2f4f79}.view-mode-page-layout-btn--active{border-color:#9fb4cc;background:#3f74e629;color:#1f3e67}.binder-trash-section{position:absolute;left:0;right:0;bottom:0;border-top:1px solid var(--border-subtle);background:linear-gradient(180deg,#eff6ff33,#eff6ffa6);padding-top:4px}.binder-trash-toggle{display:flex;align-items:center;gap:6px;width:100%;padding:6px 10px;border:none;background:transparent;font-family:var(--font-ui);font-size:12px;color:#385573;cursor:pointer;text-align:left;border-radius:6px;margin:0 6px 6px}.binder-trash-toggle:hover{color:var(--text-primary);background:#3f74e61a}.binder-trash-items{position:absolute;left:6px;right:6px;bottom:calc(100% + 6px);max-height:220px;overflow-y:auto;border:1px solid #b8cae0;border-radius:8px;background:#f8fbff;box-shadow:0 10px 24px #1025482e;padding:4px 0}.binder-trash-empty{font-family:var(--font-ui);font-size:11px;color:#637d9b;padding:8px 10px}.binder-trash-item{display:flex;align-items:center;gap:6px;padding:5px 10px 5px 24px;font-size:12px;color:var(--text-secondary)}.binder-trash-item-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.binder-trash-restore{flex-shrink:0;border:none;background:transparent;font-family:var(--font-ui);font-size:10px;color:#4a9eff;cursor:pointer;padding:2px 6px;border-radius:3px;opacity:0;transition:opacity .1s}.binder-trash-item:hover .binder-trash-restore{opacity:1}.binder-trash-restore:hover{background:#eef5ff}.binder-trash-label{flex:1}.binder-trash-count{font-size:10px;font-weight:700;color:#587394;background:#ffffffeb;border:1px solid #b8cae0;border-radius:999px;padding:1px 7px}.compile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0003;display:flex;align-items:center;justify-content:center;z-index:500;animation:fadeIn .1s ease-out}.compile-dialog{background:var(--bg-editor);border-radius:12px;box-shadow:0 12px 48px #00000026;width:100%;max-width:480px;animation:slideUp .15s ease-out}.compile-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid var(--border-subtle)}.compile-title{font-family:var(--font-ui);font-size:16px;font-weight:600;color:var(--text-primary)}.compile-close{border:none;background:transparent;font-size:20px;color:var(--text-secondary);cursor:pointer;padding:0 4px;line-height:1}.compile-body{padding:16px 20px}.compile-info{margin-bottom:16px}.compile-info-row{display:flex;justify-content:space-between;padding:4px 0;font-family:var(--font-ui);font-size:13px;color:var(--text-primary)}.compile-info-label{color:var(--text-secondary);font-weight:500}.compile-format-section{margin-bottom:14px}.compile-format-label{font-family:var(--font-ui);font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}.compile-formats{display:flex;gap:8px}.compile-format-btn{padding:8px 20px;border:1px solid var(--border-subtle);border-radius:6px;background:var(--bg-editor);font-family:var(--font-ui);font-size:13px;color:var(--text-primary);cursor:pointer}.compile-format-btn:disabled{opacity:.4;cursor:not-allowed}.compile-format-btn--active{background:var(--text-primary);color:var(--bg-editor);border-color:var(--text-primary)}.compile-note{font-family:var(--font-ui);font-size:12px;color:var(--text-secondary);line-height:1.5;margin-bottom:8px}.compile-error{font-family:var(--font-ui);font-size:13px;color:#c44;margin-top:8px}.compile-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:1px solid var(--border-subtle)}.compile-cancel-btn{padding:8px 16px;border:1px solid var(--border-subtle);border-radius:6px;background:var(--bg-editor);font-family:var(--font-ui);font-size:13px;font-weight:500;color:var(--text-primary);cursor:pointer}.compile-cancel-btn:hover{background:#eaf1fb}.compile-submit-btn{padding:8px 20px;border:1px solid var(--brand-primary-strong);border-radius:6px;background:linear-gradient(140deg,var(--brand-primary),var(--brand-primary-strong));font-family:var(--font-ui);font-size:13px;font-weight:600;color:var(--bg-editor);cursor:pointer}.compile-submit-btn:hover{filter:brightness(1.04)}.compile-submit-btn:disabled{opacity:.4;cursor:not-allowed}.settings-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0b152466;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:500;animation:fadeIn .1s ease-out}.settings-dialog{background:var(--bg-editor);border:1px solid var(--border-subtle);border-radius:12px;box-shadow:0 16px 52px #0a152547;width:100%;max-width:640px;max-height:85vh;display:flex;flex-direction:column;animation:slideUp .15s ease-out}.settings-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid var(--border-subtle)}.settings-title{font-family:var(--font-ui);font-size:18px;font-weight:700;color:var(--text-primary)}.settings-close{border:none;background:transparent;font-size:20px;color:#4b617d;cursor:pointer;padding:0 4px;line-height:1}.settings-body{display:flex;flex:1;min-height:0;overflow:hidden}.settings-nav{width:148px;flex-shrink:0;background:#e8f0fa;border-right:1px solid var(--border-subtle);padding:12px 0;display:flex;flex-direction:column}.settings-nav-item{padding:9px 20px;border:none;background:transparent;font-family:var(--font-ui);font-size:14px;color:#445b76;cursor:pointer;text-align:left;transition:background 80ms,color 80ms}.settings-nav-item:hover{background:#0000000a;color:var(--text-primary)}.settings-nav-item--active{background:#2c56b824;color:#19365a;font-weight:600}.settings-content{flex:1;padding:22px 24px;overflow-y:auto}.settings-section-header{font-family:var(--font-ui);font-size:12px;font-weight:600;color:#4e6580;text-transform:uppercase;letter-spacing:.04em;margin-bottom:10px;margin-top:20px}.settings-section-header:first-child{margin-top:0}.settings-input{width:100%;border:1px solid var(--border-subtle);border-radius:6px;padding:8px 10px;font-family:var(--font-ui);font-size:14px;color:var(--text-primary);background:var(--bg-editor);outline:none}.settings-input:focus{border-color:var(--brand-primary)}.settings-input--narrow{max-width:180px}.settings-textarea{width:100%;border:1px solid var(--border-subtle);border-radius:6px;padding:8px 10px;font-family:var(--font-ui);font-size:13px;line-height:1.5;color:var(--text-primary);background:var(--bg-editor);resize:vertical;outline:none}.settings-textarea:focus{border-color:var(--brand-primary)}.settings-textarea::placeholder{color:var(--text-secondary);opacity:.5}.settings-textarea--readonly{background:#f3f7fd;cursor:default;opacity:1;font-family:Consolas,Monaco,Courier New,monospace;font-size:12px;line-height:1.5}.settings-textarea--readonly:focus{border-color:#ccc}.settings-stat-row{display:flex;justify-content:space-between;padding:4px 0;font-family:var(--font-ui);font-size:13px;color:var(--text-primary)}.settings-stat-label{color:var(--text-secondary);font-weight:500}.settings-field{margin-bottom:16px}.settings-field-label{display:block;font-family:var(--font-ui);font-size:13px;font-weight:500;color:var(--text-primary);margin-bottom:4px}.settings-field-hint{font-family:var(--font-ui);font-size:12px;color:#5a6f89;margin-top:3px}.settings-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:1px solid var(--border-subtle)}.snapshot-panel{display:flex;flex-direction:column;gap:8px}.snapshot-take-btn{width:100%;padding:6px 10px;border:1px solid var(--border-subtle);border-radius:6px;background:var(--bg-editor);font-family:var(--font-ui);font-size:12px;color:var(--text-primary);cursor:pointer;transition:background 80ms}.snapshot-take-btn:hover{background:#f0f0ed}.snapshot-loading,.snapshot-empty{font-size:12px;color:var(--text-secondary);font-style:italic}.snapshot-list{display:flex;flex-direction:column;gap:4px;max-height:200px;overflow-y:auto}.snapshot-item{display:flex;align-items:center;justify-content:space-between;gap:6px;padding:5px 8px;border-radius:4px;background:#f8f8f6}.snapshot-item-info{display:flex;flex-direction:column;gap:1px;min-width:0}.snapshot-item-date{font-size:11px;color:var(--text-primary);font-weight:500}.snapshot-item-words{font-size:10px;color:var(--text-secondary)}.snapshot-item-actions{display:flex;gap:4px;flex-shrink:0}.snapshot-action-btn{border:none;background:transparent;font-family:var(--font-ui);font-size:10px;color:#4a9eff;cursor:pointer;padding:2px 6px;border-radius:3px}.snapshot-action-btn:hover{background:#eef5ff}.snapshot-action-btn--danger{color:#c44}.snapshot-action-btn--danger:hover{background:#fee}.target-editor{display:flex;flex-direction:column;gap:8px}.target-editor-row{display:flex;align-items:center;gap:8px}.target-editor-label{font-size:12px;color:var(--text-secondary);white-space:nowrap;min-width:90px}.target-editor-input{flex:1;width:100%;border:1px solid var(--border-subtle);border-radius:5px;padding:4px 8px;font-family:var(--font-ui);font-size:12px;color:var(--text-primary);background:var(--bg-editor);outline:none}.target-editor-input:focus{border-color:#aaa}.target-editor-input::placeholder{color:var(--text-secondary);opacity:.5}:root{--ctx-count-warn: #b8860b;--ctx-count-over: #c0392b}.ctx-panel{width:300px;min-width:240px;height:100vh;display:flex;flex-direction:column;border-left:1px solid var(--border-subtle);background:var(--bg-panel);font-family:var(--font-ui);font-size:13px;overflow-y:auto;padding-bottom:32px}.ctx-header{padding:14px 16px 10px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between}.ctx-title{font-weight:600;font-size:14px;color:var(--text-primary)}.ctx-header-right{display:flex;align-items:center;gap:8px}.ctx-save-label{font-size:11px;color:var(--text-secondary);animation:ctxFadeIn .15s ease-out}@keyframes ctxFadeIn{0%{opacity:0}to{opacity:1}}.ctx-close-btn{border:none;background:transparent;font-size:18px;color:var(--text-secondary);cursor:pointer;padding:0 2px;line-height:1}.ctx-close-btn:hover{color:var(--text-primary)}.ctx-summary{padding:10px 16px;font-size:11px;color:var(--text-secondary);line-height:1.5;border-bottom:1px solid var(--border-subtle)}.ctx-summary-chars{display:block;margin-top:2px;font-variant-numeric:tabular-nums}.ctx-sections{flex:1}.ctx-section{border-bottom:1px solid var(--border-subtle)}.ctx-section-header{width:100%;display:flex;align-items:center;gap:6px;padding:10px 16px;border:none;background:transparent;cursor:pointer;font-family:var(--font-ui);text-align:left;transition:background 80ms}.ctx-section-header:hover{background:#00000008}.ctx-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.ctx-dot--empty{background:#ccc}.ctx-dot--partial{background:#d4a84b}.ctx-dot--full{background:#4a9d5b}.ctx-arrow{font-size:8px;color:var(--text-secondary);transition:transform .15s ease;flex-shrink:0}.ctx-arrow--open{transform:rotate(90deg)}.ctx-section-label{font-size:12px;font-weight:600;color:#4f6783;text-transform:uppercase;letter-spacing:.04em;flex:1}.ctx-char-count{font-size:11px;font-variant-numeric:tabular-nums;flex-shrink:0}.ctx-section-body{padding:0 16px 12px;animation:ctxExpand .15s ease-out}@keyframes ctxExpand{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.ctx-guidance{list-style:none;padding:0;margin:0 0 8px}.ctx-guidance li{position:relative;padding-left:14px;font-size:12px;color:var(--text-secondary);line-height:1.6;margin-bottom:2px}.ctx-guidance li:before{content:"•";position:absolute;left:2px;color:var(--border-subtle)}.ctx-textarea{width:100%;border:1px solid var(--border-subtle);border-radius:6px;padding:8px 10px;font-family:var(--font-ui);font-size:13px;line-height:1.55;color:var(--text-primary);background:var(--bg-editor);resize:vertical;outline:none;min-height:60px}.ctx-textarea:focus{border-color:var(--brand-primary)}.ctx-textarea::placeholder{color:var(--text-secondary);opacity:.45}.ctx-section-footer{display:flex;justify-content:flex-end;gap:4px;margin-top:6px}.ctx-clear-btn{border:none;background:transparent;font-family:var(--font-ui);font-size:11px;color:var(--text-secondary);cursor:pointer;padding:2px 6px;border-radius:4px;transition:background 80ms,color 80ms}.ctx-clear-btn:hover{background:#c0392b14;color:var(--ctx-count-over)}.ctx-dot--over{background:var(--ctx-count-over)}.ctx-drop-zone{display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px 12px;margin-bottom:8px;border:1.5px dashed var(--border-subtle);border-radius:8px;background:#00000004;cursor:pointer;transition:border-color .12s,background .12s}.ctx-drop-zone:hover,.ctx-drop-zone--active{border-color:#aaa;background:#00000008}.ctx-drop-icon{font-size:20px;line-height:1;opacity:.5}.ctx-drop-label{font-family:var(--font-ui);font-size:11px;color:var(--text-primary);font-weight:500}.ctx-drop-sublabel{font-family:var(--font-ui);font-size:10px;color:var(--text-secondary)}.ctx-file-input{display:none}.ctx-limit-note{font-family:var(--font-ui);font-size:10px;color:var(--ctx-count-warn);margin-top:4px;line-height:1.4}.ctx-upload-status{font-family:var(--font-ui);font-size:10px;color:var(--text-secondary);margin-top:4px;line-height:1.4}.ctx-upload-btn{border:none;background:transparent;font-family:var(--font-ui);font-size:11px;color:var(--text-secondary);cursor:pointer;padding:2px 6px;border-radius:4px;margin-right:auto;transition:background 80ms,color 80ms}.ctx-upload-btn:hover{background:#0000000d;color:var(--text-primary)}.ctx-edit-btn{padding:3px 10px;font-size:11px;font-weight:500;font-family:var(--font-ui);color:var(--text-secondary);background:transparent;border:1px solid var(--border-subtle);border-radius:4px;cursor:pointer;transition:all .12s ease}.ctx-edit-btn:hover{color:var(--text-primary);background:#0000000a;border-color:#aaa}.ctx-readonly-text{padding:2px 0 0;font-family:var(--font-ui);font-size:12px;line-height:1.55;color:var(--text-primary);white-space:pre-wrap;word-wrap:break-word;max-height:220px;overflow-y:auto}.ctx-empty-state{padding:14px 0;color:var(--text-secondary);font-size:12px;font-family:var(--font-ui);text-align:center}.ctx-add-link{display:block;margin:8px auto 0;padding:5px 12px;background:transparent;border:1px solid var(--border-subtle);border-radius:4px;color:var(--text-secondary);font-size:11px;font-family:var(--font-ui);cursor:pointer;transition:all .12s ease}.ctx-add-link:hover{color:var(--text-primary);background:#00000008;border-color:#aaa}.ctx-editor-dialog{max-width:720px}.ctx-editor-summary{padding:12px 20px;border-bottom:1px solid var(--border-subtle);font-size:13px;line-height:1.45;color:#4b617d;font-family:var(--font-ui);background:#f2f6fc}.ctx-editor-body{flex:1;overflow-y:auto;padding:16px 20px}.ctx-editor-section{margin-bottom:12px;border:1px solid var(--border-subtle);border-radius:8px;overflow:hidden}.ctx-editor-section:last-child{margin-bottom:0}.ctx-editor-section .ctx-section-header{background:#f2f6fc}.ctx-editor-section .ctx-section-header:hover{background:#e9f1fb}.project-start-overlay,.project-tour-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1800;background:#080a0cc7;display:flex;align-items:center;justify-content:center;padding:18px}.project-start-wizard{width:min(960px,96vw);max-height:min(90vh,920px);background:#fff;border:1px solid var(--border-subtle);border-radius:12px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 64px #00000059}.project-start-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding:18px 22px 14px;border-bottom:1px solid var(--border-subtle)}.project-start-header h2{margin:0;font-size:20px;letter-spacing:.01em}.project-start-header p{margin:6px 0 0;color:var(--text-secondary);font-size:12px}.project-start-step-count{border:1px solid var(--border-subtle);border-radius:999px;padding:4px 10px;font-size:12px;color:#4f6783;background:#fff}.project-start-steps{padding:12px 20px 2px;border-bottom:1px solid var(--border-subtle)}.project-start-step{border:none;background:transparent;color:#566e88;padding:2px 6px;margin-right:8px;margin-bottom:8px;border-radius:6px;font-size:12px;cursor:pointer;transition:all .11s ease}.project-start-step span{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:999px;border:1px solid var(--border-subtle);margin-right:6px;font-size:10px}.project-start-step--active{color:var(--text-primary);background:#3f74e61f}.project-start-step--done{color:#3f6b39}.project-start-step--done span{border-color:#3f6b39}.project-start-step:disabled{cursor:default;opacity:.7}.project-start-progress{margin-top:2px;width:100%;height:3px;border-radius:999px;background:#00000017;overflow:hidden}.project-start-progress-fill{height:100%;background:#3f6b39;transition:width .18s ease}.project-start-body{flex:1;overflow:auto;padding:16px 20px 8px}.project-start-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.project-start-field{display:flex;flex-direction:column;gap:6px}.project-start-field--span{grid-column:1 / -1}.project-start-field-header{display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:12px;color:#4f6680;text-transform:uppercase;letter-spacing:.06em}.project-start-field-skip{border:none;background:transparent;color:#697994;font-size:11px;text-transform:none;letter-spacing:0;cursor:pointer;padding:0}.project-start-field-skip:hover{color:var(--text-primary)}.project-start-field input,.project-start-field textarea,.project-start-review-card textarea{border:1px solid var(--border-subtle);border-radius:8px;padding:9px 11px;font-family:var(--font-ui);font-size:13px;line-height:1.5;color:var(--text-primary);background:#fff;resize:vertical}.project-start-field input:focus,.project-start-field textarea:focus{outline:none;border-color:var(--brand-primary);box-shadow:0 0 0 3px #3f74e61f}.project-start-field-hint{font-size:11px;color:var(--text-secondary)}.project-start-drop-zone{border:1px dashed #b7b7b4;border-radius:8px;padding:10px 12px;font-size:13px;color:#4f6783;text-align:center;cursor:pointer;background:#f8fbff;transition:border-color .11s ease,background .11s ease}.project-start-drop-zone:hover,.project-start-drop-zone--active{border-color:var(--brand-primary);background:#edf4ff}.project-start-file-input{display:none}.project-start-review{display:flex;flex-direction:column;gap:10px}.project-start-review-card{border:1px solid var(--border-subtle);border-radius:8px;padding:10px;background:#f8fbff}.project-start-review-heading{margin-bottom:8px;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary)}.project-start-review-card textarea{width:100%;background:#fdfdfd;color:var(--text-primary)}.project-start-review-metrics{display:flex;gap:16px;font-size:12px;color:var(--text-secondary)}.project-start-error{margin:0 20px 8px;border:1px solid rgba(176,62,62,.3);background:#b03e3e14;color:#7d2121;border-radius:8px;padding:8px 10px;font-size:12px}.project-start-footer{display:flex;gap:8px;justify-content:flex-end;align-items:center;border-top:1px solid var(--border-subtle);padding:12px 20px 14px}.project-start-saving{width:min(460px,92vw);border-radius:12px;border:1px solid var(--border-subtle);background:#fff;padding:22px 20px;box-shadow:0 20px 56px #00000047}.project-start-saving-title{font-size:16px;font-weight:600}.project-start-saving-subtitle{margin-top:6px;color:var(--text-secondary);font-size:12px}.project-tour-highlight{position:fixed;z-index:1810;border:2px solid #f4f4f3;border-radius:10px;box-shadow:0 0 0 200vmax #080a0cb3;pointer-events:none}.project-tour-card{position:fixed;z-index:1820;width:min(400px,calc(100vw - 32px));border-radius:12px;border:1px solid var(--border-subtle);background:#fff;padding:14px 14px 12px;box-shadow:0 18px 44px #00000059}.project-tour-step-count{font-size:12px;color:#4f6783}.project-tour-card h3{margin:6px 0 0;font-size:16px}.project-tour-card p{margin:7px 0 0;font-size:13px;line-height:1.5;color:#445c77}.project-tour-key-list{margin:9px 0 0;padding-left:18px}.project-tour-key-list li{font-size:12px;line-height:1.4;color:var(--text-primary);margin-bottom:4px}.project-tour-note{margin-top:10px;border-radius:8px;background:#242c3a14;color:#1f2a3f;padding:8px 10px;font-size:11px}.project-tour-footer{margin-top:10px;display:flex;justify-content:flex-end;gap:8px}@media(max-width:900px){.project-start-wizard{width:min(760px,96vw)}.project-start-grid{grid-template-columns:1fr}.project-start-review-metrics{flex-direction:column;gap:4px}}.project-delete-confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1850;background:#090e188f;display:grid;place-items:center;padding:18px}.project-delete-confirm-dialog{width:min(460px,100%);border:1px solid var(--border-subtle);border-radius:14px;background:var(--bg-editor);box-shadow:0 18px 40px #141f344d;padding:18px;font-family:var(--font-ui)}.project-delete-confirm-dialog h2{font-size:20px;color:var(--text-primary);margin-bottom:8px}.project-delete-confirm-dialog p{font-size:13px;color:var(--text-secondary);line-height:1.5;margin-bottom:12px}.project-delete-confirm-name{border:1px solid #f2b8b5;background:#fff1f0;border-radius:8px;color:#9d2f2a;font-size:14px;font-weight:600;padding:10px 12px;margin-bottom:12px;word-break:break-word}.project-delete-confirm-label{display:grid;gap:6px;color:var(--text-secondary);font-size:12px}.project-delete-confirm-input{width:100%;border:1px solid var(--border-subtle);border-radius:8px;padding:9px 10px;font-family:var(--font-ui);font-size:14px;color:var(--text-primary);outline:none}.project-delete-confirm-input:focus{border-color:var(--brand-primary)}.project-delete-confirm-error{margin-top:10px;border-radius:8px;border:1px solid #f4b4b4;background:#fef2f2;color:#9b1c1c;font-size:12px;padding:8px 10px}.project-delete-confirm-actions{margin-top:14px;display:flex;justify-content:flex-end;gap:8px}.project-delete-confirm-cancel,.project-delete-confirm-delete{border:1px solid var(--border-subtle);border-radius:8px;padding:8px 12px;font-family:var(--font-ui);font-size:13px;cursor:pointer;background:var(--bg-editor);color:var(--text-primary)}.project-delete-confirm-delete{border-color:#c53f36;background:linear-gradient(140deg,#db5548,#b6362c);color:#fff}.project-delete-confirm-delete:disabled,.project-delete-confirm-cancel:disabled{opacity:.6;cursor:not-allowed}
