:root{color:#1a1a1a;background-color:#faf9f7;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5}*{box-sizing:border-box}body{min-height:100vh;margin:0}button{font-family:inherit}.centered{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:100vh;display:flex}button{cursor:pointer;border:1px solid #888;border-radius:8px;padding:.6rem 1.2rem;font-size:1rem}.projects{text-align:left;max-width:640px;margin:0 auto;padding:2rem 1rem}.projects-header{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.projects-header h1{margin:0;font-size:1.5rem}.user-email{opacity:.7;margin-right:.75rem;font-size:.9rem}.new-project{gap:.5rem;margin-bottom:1.5rem;display:flex}.new-project input{border:1px solid #888;border-radius:8px;flex:1;padding:.55rem .75rem;font-size:1rem}.project-list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.project-item{border:1px solid #888;border-radius:8px;justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.project-item .delete{font-size:.85rem}.empty{opacity:.7}.binder-layout{height:100vh;display:flex}.binder{border-right:1px solid #ddd;width:260px;padding:1rem;overflow-y:auto}.binder-top h2{margin:.5rem 0 0;font-size:1.1rem}.link{color:inherit;cursor:pointer;opacity:.7;background:0 0;border:none;padding:0;font-size:.9rem}.new-doc{gap:.4rem;margin:1rem 0;display:flex}.new-doc input{border:1px solid #bbb;border-radius:6px;flex:1;padding:.4rem .6rem}.doc-list{flex-direction:column;gap:.25rem;margin:0;padding:0;list-style:none;display:flex}.doc-item{cursor:pointer;border-radius:6px;justify-content:space-between;align-items:center;padding:.45rem .6rem;display:flex}.doc-item:hover{background:#0000000d}.doc-item.selected{background:#0000001a}.doc-item .delete{opacity:.6;cursor:pointer;background:0 0;border:none;font-size:.8rem}.editor-area{flex:1;padding:2rem 3rem;overflow-y:auto}.muted{opacity:.6}.project-title{cursor:pointer;flex:1}.editor{max-width:720px;margin:0 auto}.editor-bar{justify-content:space-between;margin-bottom:.5rem;font-size:.85rem;display:flex}.doc-title{margin:0 0 1rem;font-size:1.6rem}.ProseMirror{outline:none;min-height:60vh;font-size:1.1rem;line-height:1.7}.ProseMirror p{margin:0 0 1rem}.ProseMirror>:first-child{margin-top:0}.binder-actions{flex-direction:column;gap:.4rem;margin:.75rem 0;display:flex}.binder-actions input{border:1px solid #bbb;border-radius:6px;padding:.4rem .5rem}.binder-actions .row{gap:.4rem;display:flex}.binder-actions .row button{flex:1;padding:.4rem;font-size:.85rem}.tree,.tree-children{margin:0;padding:0;list-style:none}.tree-row{cursor:pointer;border-radius:6px;align-items:center;gap:.25rem;padding:.3rem;display:flex}.tree-row:hover{background:#0000000d}.tree-row.selected{background:#0000001a}.twisty{text-align:center;cursor:pointer;opacity:.7;background:0 0;border:none;width:1.1rem;min-width:1.1rem;padding:0;font-size:.75rem}.tree-icon{font-size:.8rem}.tree-title{text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.95rem;overflow:hidden}.row-action{opacity:0;cursor:pointer;background:0 0;border:none;padding:0 .15rem;font-size:.85rem}.tree-row:hover .row-action{opacity:.55}.row-action:hover{opacity:1}.drag-handle{cursor:grab;opacity:0;color:#999;touch-action:none;background:0 0;border:none;width:1rem;min-width:1rem;padding:0;font-size:.8rem}.tree-row:hover .drag-handle{opacity:.6}.drag-handle:active{cursor:grabbing}.rename-input{border:1px solid #888;border-radius:4px;flex:1;min-width:0;padding:.1rem .3rem;font-size:.95rem}.inspector{border-left:1px solid #ddd;flex-direction:column;gap:.35rem;width:260px;padding:1rem;display:flex;overflow-y:auto}.inspector-top{margin-bottom:.5rem;font-weight:600}.insp-label{text-transform:uppercase;letter-spacing:.03em;opacity:.6;margin-top:.5rem;font-size:.75rem}.insp-synopsis{resize:vertical;min-height:90px;font:inherit;border:1px solid #bbb;border-radius:6px;padding:.5rem}.insp-field{font:inherit;border:1px solid #bbb;border-radius:6px;padding:.4rem .5rem}.corkboard{max-width:900px;margin:0 auto}.corkboard-title{margin:0 0 1.5rem;font-size:1.5rem}.card-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;display:grid}.index-card{text-align:left;cursor:pointer;min-height:150px;font:inherit;background:#fffdf7;border:1px solid #e0d9c8;border-radius:8px;flex-direction:column;gap:.5rem;padding:.85rem;display:flex;box-shadow:0 1px 3px #0000000f}.index-card:hover{box-shadow:0 3px 10px #0000001a}.card-header{border-bottom:1px solid #eee3cf;justify-content:space-between;align-items:baseline;gap:.5rem;padding-bottom:.4rem;display:flex}.card-title{font-weight:600}.card-status{opacity:.7;white-space:nowrap;font-size:.7rem}.card-synopsis{flex:1;font-size:.9rem;line-height:1.45;overflow:hidden}.card-label{opacity:.7;font-size:.75rem}.view-toggle{gap:.4rem;margin-bottom:1.25rem;display:flex}.view-toggle button{background:0 0;border:1px solid #ccc;border-radius:8px;padding:.35rem .8rem;font-size:.85rem}.view-toggle button.active{background:#00000014;border-color:#888}.book-views{flex-direction:column;gap:.4rem;margin-top:.6rem;display:flex}.book-view-btn{background:0 0;border:1px solid #ccc;border-radius:8px;width:100%;padding:.4rem;font-size:.85rem}.book-view-btn.active{background:#00000014;border-color:#888}.outliner{max-width:1000px;margin:0 auto}.outliner-title{margin:0 0 1.5rem;font-size:1.5rem}.outliner-table{border-collapse:collapse;width:100%;font-size:.92rem}.outliner-table th{text-align:left;text-transform:uppercase;letter-spacing:.03em;opacity:.55;border-bottom:1px solid #ddd;padding:.4rem .6rem;font-size:.7rem;font-weight:600}.outliner-table td{vertical-align:top;border-bottom:1px solid #f0f0f0;padding:.35rem .6rem}.outliner-row{cursor:default}.outliner-row:hover{background:#0000000a}.outliner-row.is-folder{background:#00000005;font-weight:600}.col-title{width:28%}.col-synopsis{color:#444;width:46%}.col-status{white-space:nowrap;width:14%}.col-words{text-align:right;opacity:.7;font-variant-numeric:tabular-nums;width:12%}.outliner-icon{margin-right:.4rem;font-size:.8rem}.outliner-cell-text{display:inline-block}.outliner-status{opacity:.8;font-size:.78rem}.outliner-input{width:100%;font:inherit;box-sizing:border-box;border:1px solid #888;border-radius:4px;padding:.2rem .35rem}.outliner-open{cursor:pointer;background:0 0;border:none;border-radius:4px;margin-right:.45rem;padding:0 .15rem;font-size:.95rem;line-height:1}.outliner-open:hover{background:#0000001a}.outliner-title-text{cursor:text;border-radius:3px;padding:.05rem .2rem}.outliner-title-text:hover{background:#0000000d}.outliner-synopsis-text{cursor:text;border-radius:3px;min-height:1.2em;padding:.05rem .2rem;display:block}.outliner-synopsis-text:hover{background:#0000000d}.outliner-synopsis-text.is-empty{opacity:.4;font-style:italic}.outliner-select{font:inherit;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:4px;padding:.15rem .3rem}.outliner-select:hover{border-color:#ccc}.scrivenings{max-width:720px;margin:0 auto}.scrivenings-title{margin:0 0 .25rem;font-size:1.6rem}.scrivenings-meta{margin:0 0 2rem;font-size:.85rem}.scrivenings-chapter{cursor:pointer;border-bottom:2px solid #e0d9c8;margin:2.5rem 0 .75rem;padding-bottom:.35rem;font-size:1.25rem}.scrivenings-chapter:hover{opacity:.75}.scrivening{margin:0 0 2.5rem}.scrivening+.scrivening{border-top:1px solid #eee3cf;padding-top:1.75rem}.scrivening-title{letter-spacing:.04em;text-transform:uppercase;opacity:.55;cursor:pointer;margin:0 0 .75rem;font-size:.8rem;font-weight:600}.scrivening-title:hover{opacity:.9}.scrivening-body{font-size:1.1rem;line-height:1.7}.scrivening-body p{margin:0 0 1rem}.scrivening-body>:first-child{margin-top:0}.scrivening-empty{margin:0 0 1rem;font-style:italic}.scrivenings-head{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:2rem;display:flex}.scrivenings-head .scrivenings-title{margin-bottom:.25rem}.scrivenings-head .scrivenings-meta{margin:0}.scriv-mode-toggle{flex-shrink:0;gap:.4rem;display:flex}.scriv-mode-toggle button{background:0 0;border:1px solid #ccc;border-radius:8px;padding:.3rem .7rem;font-size:.8rem}.scriv-mode-toggle button.active{background:#00000014;border-color:#888}.scrivening-edit{position:relative}.scrivening-edit .ProseMirror{border:1px solid #0000;border-radius:6px;min-height:2.5rem;padding:.35rem .5rem;font-size:1.1rem;line-height:1.7;transition:border-color .15s,background .15s}.scrivening-edit .ProseMirror:hover{border-color:#eee3cf}.scrivening-edit .ProseMirror.ProseMirror-focused{background:#fffdf7;border-color:#d8ccae}.scrivening-edit .ProseMirror p{margin:0 0 1rem}.scrivening-edit .ProseMirror>:first-child{margin-top:0}.scrivening-save{pointer-events:none;font-size:.75rem;position:absolute;top:.4rem;right:.5rem}.snap-panel{border-top:1px solid #e0d9c8;margin-top:1.25rem;padding-top:1rem}.snap-head{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.snap-take{cursor:pointer;background:0 0;border:1px solid #ccc;border-radius:8px;padding:.25rem .6rem;font-size:.78rem}.snap-take:disabled{opacity:.5;cursor:default}.snap-empty{margin:.25rem 0;font-size:.8rem}.snap-list{flex-direction:column;gap:.35rem;max-height:40vh;margin:0;padding:0;list-style:none;display:flex;overflow-y:auto}.snap-item{align-items:stretch;gap:.3rem;display:flex}.snap-open{text-align:left;cursor:pointer;background:#fffdf7;border:1px solid #e0d9c8;border-radius:8px;flex-direction:column;flex:1;gap:.1rem;padding:.4rem .55rem;display:flex}.snap-open:hover{border-color:#d8ccae}.snap-when{font-size:.8rem}.snap-meta{font-size:.72rem}.snap-del{cursor:pointer;color:#b0876f;background:0 0;border:1px solid #0000;border-radius:8px;width:1.9rem;font-size:.85rem}.snap-del:hover{background:#fbeee9;border-color:#e0d9c8}.snap-modal-overlay{z-index:50;background:#28221859;justify-content:center;align-items:center;padding:2rem;display:flex;position:fixed;inset:0}.snap-modal{background:#fffdf7;border:1px solid #e0d9c8;border-radius:12px;flex-direction:column;width:min(700px,100%);max-height:85vh;display:flex;box-shadow:0 12px 40px #28221840}.snap-modal-head{border-bottom:1px solid #eee3cf;justify-content:space-between;align-items:center;padding:.9rem 1.1rem;display:flex}.snap-modal-when{font-size:.85rem}.snap-modal-close{cursor:pointer;color:#8a7f6a;background:0 0;border:none;font-size:1rem}.snap-modal-body{padding:1.1rem 1.3rem;font-size:1.05rem;line-height:1.7;overflow-y:auto}.snap-modal-body p{margin:0 0 1rem}.snap-modal-body>:first-child{margin-top:0}.snap-modal-actions{border-top:1px solid #eee3cf;justify-content:flex-end;gap:.6rem;padding:.85rem 1.1rem;display:flex}.snap-modal-actions button{cursor:pointer;background:0 0;border:1px solid #ccc;border-radius:8px;padding:.45rem .9rem;font-size:.85rem}.snap-restore{background:#f3e3d2!important;border-color:#c8a27a!important}.snap-restore:disabled{opacity:.5;cursor:default}.snap-diff-bar{border-bottom:1px solid #eee3cf;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;padding:.5rem 1.1rem;display:flex}.snap-diff-legend{align-items:center;gap:.5rem;font-size:.75rem;display:inline-flex}.diff-chip{border-radius:5px;padding:.05rem .4rem;font-size:.72rem}.diff-add-chip{color:#1f6b34;background:#d9f0dd}.diff-del-chip{color:#a12b2b;background:#f6dcdc}.snap-diff-note{color:#8a7f6a}.snap-diff-toggle{gap:.3rem;display:inline-flex}.snap-diff-toggle button{cursor:pointer;background:0 0;border:1px solid #ccc;border-radius:7px;padding:.2rem .55rem;font-size:.75rem}.snap-diff-toggle button.active{background:#00000014;border-color:#888}.snap-diff-text{white-space:pre-wrap;word-break:break-word;font-size:1.05rem;line-height:1.7}.diff-add{color:#1f6b34;background:#d9f0dd;border-radius:3px;text-decoration:none}.diff-del{color:#a12b2b;background:#f6dcdc;border-radius:3px;text-decoration:line-through}.snap-split{grid-template-columns:1fr 1fr;gap:1.25rem;display:grid}.snap-split-col{min-width:0}.snap-split-label{text-transform:uppercase;letter-spacing:.05em;margin-bottom:.4rem;font-size:.72rem}.confirm-overlay{z-index:60;background:#28221866;justify-content:center;align-items:center;padding:2rem;display:flex;position:fixed;inset:0}.confirm-box{background:#fffdf7;border:1px solid #e0d9c8;border-radius:12px;width:min(420px,100%);padding:1.3rem 1.4rem;box-shadow:0 12px 40px #28221840}.confirm-title{margin-bottom:.5rem;font-weight:600}.confirm-msg{margin:0 0 1.2rem;font-size:.95rem;line-height:1.5}.confirm-actions{justify-content:flex-end;gap:.6rem;display:flex}.confirm-actions button{cursor:pointer;background:0 0;border:1px solid #ccc;border-radius:8px;padding:.45rem 1rem;font-size:.88rem}.confirm-ok{background:#f3e3d2!important;border-color:#c8a27a!important}.confirm-danger{color:#a12b2b;background:#fbeae9!important;border-color:#d99!important}.kw-block{margin-top:1rem}.kw-chips{flex-wrap:wrap;align-items:center;gap:.35rem;display:flex}.kw-none{font-size:.85rem}.kw-chip{border:1px solid;border-radius:999px;align-items:center;gap:.3rem;padding:.12rem .5rem;font-size:.78rem;line-height:1.4;display:inline-flex}.kw-chip-x{cursor:pointer;color:inherit;opacity:.7;background:0 0;border:none;padding:0;font-size:.7rem}.kw-chip-x:hover{opacity:1}.kw-add{cursor:pointer;color:#8a7f6a;background:0 0;border:1px dashed #bbb;border-radius:999px;width:1.5rem;height:1.5rem;font-size:.9rem;line-height:1}.kw-add:hover{border-color:#888}.kw-picker{background:#fffdf7;border:1px solid #e0d9c8;border-radius:10px;margin-top:.6rem;padding:.6rem}.kw-existing{flex-wrap:wrap;gap:.3rem;margin-bottom:.6rem;display:flex}.kw-chip-pick{cursor:pointer}.kw-create{flex-direction:column;gap:.5rem;display:flex}.kw-name-input{width:100%}.kw-swatches{flex-wrap:wrap;gap:.3rem;display:flex}.kw-swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;width:1.3rem;height:1.3rem;padding:0}.kw-swatch.active{border-color:#333}.kw-create-btn{cursor:pointer;background:#f3e3d2;border:1px solid #c8a27a;border-radius:8px;align-self:flex-start;padding:.35rem .8rem;font-size:.82rem}.kw-create-btn:disabled{opacity:.5;cursor:default}.kwf-bar{margin:.4rem 0 .6rem}.kwf-row{flex-wrap:wrap;align-items:flex-start;gap:.4rem;display:flex}.kwf-icon{padding-top:.15rem;font-size:.9rem}.kwf-chips{flex-wrap:wrap;flex:1;gap:.3rem;min-width:0;display:flex}.kwf-chip-wrap{align-items:center;gap:.1rem;display:inline-flex}.kwf-chip{cursor:pointer}.kwf-del{cursor:pointer;color:#b0876f;background:0 0;border:none;padding:0 .1rem;font-size:.7rem}.kwf-actions{align-items:center;gap:.3rem;display:flex}.kwf-clear{cursor:pointer;color:#8a7f6a;background:0 0;border:none;font-size:.72rem;text-decoration:underline}.kwf-manage{cursor:pointer;color:#8a7f6a;background:0 0;border:1px solid #ccc;border-radius:6px;padding:.1rem .35rem;font-size:.72rem}.kwf-manage.active{background:#00000014;border-color:#888}.tree-kw{flex-shrink:0;gap:2px;margin-left:.3rem;display:inline-flex}.tree-kw-dot{border-radius:50%;width:7px;height:7px;display:inline-block}.pbar{margin:.4rem 0}.pbar-track{background:#eee3cf;border-radius:999px;height:10px;overflow:hidden}.pbar-fill{border-radius:999px;height:100%;transition:width .3s}.pbar-label{justify-content:space-between;gap:.5rem;margin-top:.25rem;font-size:.8rem;display:flex}.pbar-pct{font-weight:600}.pbar-compact .pbar-track{height:6px}.pbar-compact .pbar-label{font-size:.72rem}.insp-target{margin-top:1rem}.editor-target{opacity:.85}.dashboard{max-width:760px;margin:0 auto}.dash-title{margin:0 0 1.5rem;font-size:1.7rem}.dash-card{background:#fffdf7;border:1px solid #e0d9c8;border-radius:12px;margin-bottom:1.25rem;padding:1.1rem 1.3rem}.dash-card h2{margin:0 0 .6rem;font-size:1.05rem}.dash-card-head{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:.4rem;display:flex}.dash-card-head h2{margin:0}.dash-goal-input{color:#8a7f6a;align-items:center;gap:.4rem;font-size:.82rem;display:inline-flex}.dash-goal-input input{border:1px solid #ccc;border-radius:8px;width:6rem;padding:.3rem .5rem;font-size:.9rem}.dash-note{margin:.5rem 0 0;font-size:.78rem}.dash-stats{grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.25rem;display:grid}.dash-stat{text-align:center;background:#fffdf7;border:1px solid #e0d9c8;border-radius:12px;padding:1rem}.dash-stat-num{font-size:1.6rem;font-weight:600}.dash-stat-label{margin-top:.2rem;font-size:.78rem}.dash-status{flex-direction:column;gap:.35rem;margin:0;padding:0;list-style:none;display:flex}.dash-status li{border-bottom:1px solid #f0e8d6;justify-content:space-between;padding-bottom:.3rem;font-size:.9rem;display:flex}.dash-status li:last-child{border-bottom:none}.gd-open-btn{margin-right:.75rem}.gd-page{max-width:820px;margin:0 auto;padding:2rem 1.5rem}.gd-top{align-items:center;gap:1rem;margin-bottom:1.25rem;display:flex}.gd-top .dash-title{margin:0}.gd-chart{align-items:flex-end;gap:.4rem;height:120px;padding-top:.5rem;display:flex}.gd-bar-col{flex-direction:column;flex:1;align-items:center;height:100%;display:flex}.gd-bar-wrap{flex:1;align-items:flex-end;width:100%;display:flex}.gd-bar{background:#5f8f4e;border-radius:4px 4px 0 0;width:100%;min-height:2px;transition:height .3s}.gd-bar-label{white-space:nowrap;margin-top:.3rem;font-size:.65rem}.gd-projects{flex-direction:column;gap:.6rem;margin:0;padding:0;list-style:none;display:flex}.gd-proj-open{text-align:left;cursor:pointer;background:0 0;border:1px solid #e0d9c8;border-radius:10px;width:100%;padding:.7rem .9rem}.gd-proj-open:hover{background:#fffdf7;border-color:#d8ccae}.gd-proj-head{justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:.35rem;display:flex}.gd-proj-title{font-weight:600}.gd-proj-meta{font-size:.78rem}.gd-daylist{flex-direction:column;gap:.3rem;margin:.9rem 0 0;padding:0;list-style:none;display:flex}.gd-day{border-bottom:1px solid #f0e8d6;padding-bottom:.3rem;font-size:.85rem}.gd-day:last-child{border-bottom:none}.projects-toolbar{margin:.25rem 0 1rem}
