:root{--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Helvetica", "Arial", sans-serif;--font-serif: "Georgia", "Times New Roman", "Iowan Old Style", "Apple Garamond", "Baskerville", "Palatino", serif;--font-mono: "SF Mono", "Monaco", "Menlo", "Consolas", "Liberation Mono", "Courier New", monospace;--font-editor: var(--font-sans);--font-ui: var(--font-sans);--color-bg-primary: #ffffff;--color-bg-secondary: #f5f5f5;--color-bg-tertiary: #e0e0e0;--color-text-primary: #333333;--color-text-secondary: #666666;--color-text-muted: #999999;--color-border: #e0e0e0;--color-accent: #007aff;--color-highlight-hard: rgba(255, 230, 0, .3);--color-highlight-very-hard: rgba(255, 100, 100, .3);--color-highlight-passive: rgba(0, 122, 255, .2);--color-highlight-adverb: rgba(150, 0, 255, .2)}[data-font=serif]{--font-editor: var(--font-serif)}[data-font=mono]{--font-editor: var(--font-mono)}[data-theme=cream]{--color-bg-primary: #f5f1e8;--color-bg-secondary: #ede8dc;--color-bg-tertiary: #e0d9ca;--color-text-primary: #2d2d2d;--color-text-secondary: #5a5a5a;--color-text-muted: #888888;--color-border: #d4ccba;--color-accent: #8b6f47;--color-highlight-hard: rgba(255, 200, 0, .25);--color-highlight-very-hard: rgba(220, 80, 80, .25);--color-highlight-passive: rgba(100, 120, 200, .2);--color-highlight-adverb: rgba(140, 80, 200, .2)}[data-theme=dark]{--color-bg-primary: #202020;--color-bg-secondary: #2a2a2a;--color-bg-tertiary: #3a3a3a;--color-text-primary: #e0e0e0;--color-text-secondary: #b0b0b0;--color-text-muted: #808080;--color-border: #404040;--color-accent: #0a84ff;--color-highlight-hard: rgba(255, 230, 0, .2);--color-highlight-very-hard: rgba(255, 100, 100, .25);--color-highlight-passive: rgba(0, 122, 255, .25);--color-highlight-adverb: rgba(150, 0, 255, .25)}*{box-sizing:border-box;transition:background-color .2s ease,color .2s ease,border-color .2s ease}body{margin:0;padding:0;font-family:var(--font-ui);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-bg-primary);color:var(--color-text-primary)}#root{min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.app-main{display:flex;flex:1;min-height:0}.sidebar-section{margin-bottom:1.5rem}.sidebar-section h3{margin:0 0 1rem;font-size:14px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.line-length-control{display:flex;flex-direction:column;gap:.5rem}.line-length-control label{font-size:14px;color:var(--color-text-primary)}.line-length-control input[type=range]{width:100%}.line-length-hint{color:var(--color-text-muted);font-size:12px}.context-menu{position:absolute;width:110px;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:6px;padding:.5rem;box-shadow:0 2px 8px #0000001a;z-index:10;transition:all .15s ease;box-sizing:border-box}.context-menu-block-type{margin-bottom:.5rem;position:relative}.context-menu-dropdown-button{width:100%;padding:.4rem .5rem;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:4px;font-size:12px;cursor:pointer;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:all .15s ease;box-sizing:border-box;color:var(--color-text-primary)}.context-menu-dropdown-button:hover{background:var(--color-bg-tertiary);border-color:var(--color-text-secondary)}.context-menu-dropdown{position:absolute;left:0;top:100%;margin-top:.25rem;width:140px;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:4px;box-shadow:0 2px 12px #00000026;max-height:300px;overflow-y:auto;z-index:20}.context-menu-dropdown-item{width:100%;padding:.5rem .75rem;background:none;border:none;text-align:left;cursor:pointer;font-size:13px;transition:background .1s ease;color:var(--color-text-primary)}.context-menu-dropdown-item:hover{background:var(--color-bg-secondary)}.context-menu-buttons{display:flex;flex-direction:column;gap:.25rem}.context-menu-row{display:flex;gap:.25rem;justify-content:space-between}.context-menu-button{flex:1;min-width:0;padding:.4rem .3rem;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:4px;font-size:12px;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center;white-space:nowrap;box-sizing:border-box;color:var(--color-text-primary)}.context-menu-button:hover{background:var(--color-bg-secondary);border-color:var(--color-text-secondary)}.context-menu-button.active{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.context-menu-button.active:hover{background:#06c;border-color:#06c}@media(max-width:768px){.context-menu{display:none}}.editor-wrapper{flex:1;display:flex;justify-content:center;padding:2rem;padding-left:100px;overflow-y:auto;position:relative}.editor-content{min-height:400px;outline:none;width:100%;margin:0 auto}.editor-content .ProseMirror{outline:none;padding:1rem;min-height:400px;font-family:var(--font-editor);font-size:16px;line-height:1.6;color:var(--color-text-primary)}.editor-content .ProseMirror:focus{outline:none}.editor-content .ProseMirror h1{font-size:2em;font-weight:700;margin:1em 0 .5em;line-height:1.2;color:var(--color-text-primary)}.editor-content .ProseMirror h2{font-size:1.5em;font-weight:600;margin:.9em 0 .4em;line-height:1.3;color:var(--color-text-primary)}.editor-content .ProseMirror h3{font-size:1.25em;font-weight:600;margin:.8em 0 .4em;line-height:1.4;color:var(--color-text-primary)}.editor-content .ProseMirror h4,.editor-content .ProseMirror h5,.editor-content .ProseMirror h6{font-size:1em;font-weight:600;margin:.7em 0 .3em;line-height:1.5;color:var(--color-text-primary)}.editor-content .ProseMirror p{margin:.75em 0}.editor-content .ProseMirror ul,.editor-content .ProseMirror ol{padding-left:1.5em;margin:.75em 0}.editor-content .ProseMirror li{margin:.25em 0}.editor-content .ProseMirror pre{background:var(--color-bg-secondary);border-radius:4px;padding:1em;margin:1em 0;overflow-x:auto;font-family:var(--font-mono);font-size:14px;line-height:1.4}.editor-content .ProseMirror code{background:var(--color-bg-secondary);padding:.2em .4em;border-radius:3px;font-family:var(--font-mono);font-size:.9em}.editor-content .ProseMirror blockquote{border-left:3px solid var(--color-border);padding-left:1em;margin:1em 0;color:var(--color-text-secondary);font-style:italic}.editor-content .ProseMirror a{color:var(--color-accent);text-decoration:none}.editor-content .ProseMirror a:hover{text-decoration:underline}.editor-content .ProseMirror strong{font-weight:600}.editor-content .ProseMirror em{font-style:italic}.editor-content .ProseMirror hr{border:none;border-top:2px solid var(--color-border);margin:2em 0}.editor-content .ProseMirror p.is-editor-empty:first-child:before{content:attr(data-placeholder);float:left;color:var(--color-text-muted);pointer-events:none;height:0}.writing-highlight-hard{background-color:#ffe6004d;border-radius:2px;cursor:help}.writing-highlight-very-hard{background-color:#ff64644d;border-radius:2px;cursor:help}.writing-highlight-passive{background-color:#007aff40;border-radius:2px;cursor:help}.writing-highlight-adverb{background-color:#9600ff33;border-radius:2px;cursor:help}.editor-content .ProseMirror .writing-highlight-long{border-bottom:2px solid rgba(59,130,246,.6);cursor:help}.editor-content .ProseMirror .writing-highlight-complex{border-bottom:2px solid rgba(147,51,234,.6);cursor:help}@media(max-width:768px){.editor-wrapper{padding-left:2rem;padding-right:2rem}.editor-content{max-width:100%!important}}.toolbar{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;border-bottom:1px solid var(--color-border);background:var(--color-bg-primary);min-height:50px}.toolbar-left,.toolbar-right{display:flex;gap:.5rem;align-items:center}.toolbar-center{flex:1;text-align:center}.toolbar-button{padding:.5rem 1rem;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:4px;font-size:14px;cursor:pointer;transition:all .15s ease;color:var(--color-text-primary)}.toolbar-button:hover{background:var(--color-bg-secondary);border-color:var(--color-text-secondary)}.toolbar-button:active{background:var(--color-bg-tertiary)}.toolbar-button-analysis.active{background:#007aff;color:#fff;border-color:#007aff}.toolbar-button-analysis.active:hover{background:#06d;border-color:#06d}.toolbar-filename{font-size:14px;color:var(--color-text-secondary);font-weight:500}@media(max-width:768px){.toolbar{padding:.5rem 1rem;flex-wrap:wrap;gap:.5rem}.toolbar-button{padding:.4rem .75rem;font-size:13px}.toolbar-filename{font-size:13px}.toolbar-center{order:3;flex-basis:100%;margin-top:.25rem}}.sidebar{width:300px;background:var(--color-bg-primary);border-left:1px solid var(--color-border);display:flex;flex-direction:column;overflow-y:auto}.sidebar-content{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}@media(max-width:768px){.sidebar{display:none}}.document-stats{display:flex;flex-direction:column;gap:1.5rem}.stats-grade-section{display:flex;flex-direction:column;gap:.75rem}.stats-grade-header{display:flex;align-items:center;gap:.75rem}.stats-grade-badge{width:48px;height:48px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;color:#fff;flex-shrink:0}.stats-grade-info{display:flex;flex-direction:column;gap:.125rem}.stats-grade-label{font-size:12px;font-weight:500;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px}.stats-grade-value{font-size:18px;font-weight:600;color:var(--color-text-primary)}.stats-grade-breakdown{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background:var(--color-bg-secondary);border-radius:6px}.stats-breakdown-item{display:flex;justify-content:space-between;align-items:center;font-size:13px}.stats-breakdown-label{color:var(--color-text-secondary);font-weight:500;display:flex;flex-direction:column;gap:.125rem}.stats-breakdown-detail{font-size:11px;color:var(--color-text-muted);font-weight:400}.stats-breakdown-value{color:var(--color-text-primary);font-weight:600;font-variant-numeric:tabular-nums}.stats-tips{margin-top:.75rem;padding:.75rem;background:#3b82f614;border-left:3px solid #3b82f6;border-radius:4px}.stats-tips-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.stats-tips-title{font-size:12px;font-weight:600;color:var(--color-text-primary)}.stats-tips-toggle{font-size:11px;padding:3px 8px;background:transparent;border:1px solid var(--color-border);border-radius:4px;color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease}.stats-tips-toggle:hover{background:var(--color-bg-secondary);border-color:var(--color-accent);color:var(--color-accent)}.stats-tips-list{margin:0;padding-left:1.25rem;list-style:disc}.stats-tip-item{font-size:12px;line-height:1.5;color:var(--color-text-secondary);margin-bottom:.375rem}.stats-tip-item:last-child{margin-bottom:0}.stats-section{display:flex;flex-direction:column;gap:.5rem}.stats-section-title{font-size:12px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem}.stats-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--color-border)}.stats-item:last-child{border-bottom:none}.stats-label{font-size:14px;color:var(--color-text-secondary);font-weight:500}.stats-value{font-size:14px;color:var(--color-text-primary);font-weight:600;font-variant-numeric:tabular-nums}.stats-issue-item .stats-label{font-size:13px}.stats-issue-item .stats-value{font-size:14px;font-weight:700;padding:4px 10px;border-radius:12px;min-width:28px;text-align:center}.stats-value-very-hard{background-color:#ff646499;color:#000}.stats-value-hard{background-color:#ffe60099;color:#000}.stats-value-passive{background-color:#007aff66;color:#fff}.stats-value-adverb{background-color:#9600ff80;color:#fff}.font-style-selector{display:flex;flex-direction:column;gap:.75rem}.font-style-label{font-size:14px;color:var(--color-text-primary);font-weight:500}.font-style-options{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.font-style-option{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.75rem .5rem;background:var(--color-bg-secondary);border:2px solid var(--color-border);border-radius:6px;cursor:pointer;transition:all .15s ease}.font-style-option:hover{background:var(--color-bg-tertiary);border-color:var(--color-text-secondary)}.font-style-option.active{border-color:var(--color-accent);background:var(--color-bg-primary);box-shadow:0 0 0 1px var(--color-accent)}.font-preview{font-size:24px;font-weight:500;color:var(--color-text-primary);height:32px;display:flex;align-items:center;justify-content:center}.font-preview-sans{font-family:var(--font-sans)}.font-preview-serif{font-family:var(--font-serif)}.font-preview-mono{font-family:var(--font-mono)}.font-label{font-size:12px;color:var(--color-text-secondary);font-weight:500}.font-style-option.active .font-label{color:var(--color-accent)}.appearance-selector{display:flex;flex-direction:column;gap:.75rem}.appearance-label{font-size:14px;color:var(--color-text-primary);font-weight:500}.appearance-options{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.appearance-option{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.75rem .5rem;background:var(--color-bg-secondary);border:2px solid var(--color-border);border-radius:6px;cursor:pointer;transition:all .15s ease}.appearance-option:hover{background:var(--color-bg-tertiary);border-color:var(--color-text-secondary)}.appearance-option.active{border-color:var(--color-accent);background:var(--color-bg-primary);box-shadow:0 0 0 1px var(--color-accent)}.appearance-preview{width:100%;height:40px;border-radius:4px;overflow:hidden;display:flex;align-items:center;justify-content:center}.appearance-preview-light{background:#fff;border:1px solid #e0e0e0}.appearance-preview-light .preview-content{width:80%}.appearance-preview-light .preview-line{height:4px;background:#333;margin:4px 0;border-radius:2px}.appearance-preview-light .preview-line:first-child{width:100%}.appearance-preview-light .preview-line:last-child{width:70%}.appearance-preview-dark{background:#202020;border:1px solid #404040}.appearance-preview-dark .preview-content{width:80%}.appearance-preview-dark .preview-line{height:4px;background:#e0e0e0;margin:4px 0;border-radius:2px}.appearance-preview-dark .preview-line:first-child{width:100%}.appearance-preview-dark .preview-line:last-child{width:70%}.appearance-preview-cream{background:#f5f1e8;border:1px solid #d4ccba}.appearance-preview-cream .preview-content{width:80%}.appearance-preview-cream .preview-line{height:4px;background:#2d2d2d;margin:4px 0;border-radius:2px}.appearance-preview-cream .preview-line:first-child{width:100%}.appearance-preview-cream .preview-line:last-child{width:70%}.appearance-preview-auto{background:linear-gradient(90deg,#fff 50%,#202020 50%);border:1px solid #e0e0e0;position:relative}.preview-icon{font-size:20px;text-align:center;filter:drop-shadow(0 1px 2px rgba(0,0,0,.2))}.appearance-label-text{font-size:12px;color:var(--color-text-secondary);font-weight:500}.appearance-option.active .appearance-label-text{color:var(--color-accent)}.frontmatter-editor{display:flex;flex-direction:column;gap:.75rem}.frontmatter-empty{color:var(--color-text-muted);font-size:14px;margin:0 0 .5rem}.frontmatter-field{display:grid;grid-template-columns:1fr 1fr auto;gap:.5rem;align-items:center}.frontmatter-input{padding:.5rem;border:1px solid var(--color-border);border-radius:4px;font-size:14px;font-family:inherit;background:var(--color-bg-primary);color:var(--color-text-primary)}.frontmatter-input:focus{outline:none;border-color:var(--color-accent)}.frontmatter-key{font-weight:500}.frontmatter-delete-button{padding:.25rem .5rem;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:4px;font-size:18px;line-height:1;cursor:pointer;color:var(--color-text-muted);transition:all .15s ease}.frontmatter-delete-button:hover{background:#fee;border-color:red;color:red}.frontmatter-add-button{padding:.5rem 1rem;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:4px;font-size:14px;cursor:pointer;transition:all .15s ease;color:var(--color-text-primary)}.frontmatter-add-button:hover{background:var(--color-bg-secondary);border-color:var(--color-text-secondary)}.files-section{margin-bottom:16px}.section-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 12px;background:none;border:none;cursor:pointer;text-align:left;transition:background-color .15s}.section-header:hover{background-color:var(--color-bg-secondary)}.section-header-left{display:flex;align-items:center;gap:8px}.section-icon{color:var(--color-text-secondary);flex-shrink:0}.section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary)}.section-chevron{color:var(--color-text-muted);flex-shrink:0}.section-content{padding:0;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.document-entry{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;cursor:pointer;transition:background-color .15s;border-radius:4px;margin:2px 8px;min-height:32px}.document-entry:hover{background-color:var(--color-bg-secondary)}.document-entry.active{background-color:var(--color-accent);color:#fff}.document-entry.active .document-entry-title{color:#fff;font-weight:500}.document-entry-content{display:flex;align-items:center;gap:6px;flex:1;min-width:0}.document-modified-icon{color:#3b82f6;flex-shrink:0}.document-entry.active .document-modified-icon{color:#fff}.document-entry-title{font-size:13px;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.document-entry-input{font-size:13px;padding:2px 4px;border:1px solid var(--color-accent);border-radius:2px;background:#fff;color:var(--color-text-primary);outline:none;width:100%}.document-entry-actions{display:flex;gap:4px;flex-shrink:0}.document-action-btn{display:flex;align-items:center;justify-content:center;padding:4px;background:none;border:none;cursor:pointer;border-radius:3px;color:var(--color-text-secondary);transition:background-color .15s}.document-action-btn:hover:not(:disabled){background-color:#0000001a}.document-action-btn:disabled{opacity:.3;cursor:not-allowed}.document-entry.active .document-action-btn{color:#fff}.document-entry.active .document-action-btn:hover:not(:disabled){background-color:#fff3}.browser-section-warning{padding:8px 12px;margin:4px 8px 8px;font-size:11px;color:var(--color-text-muted);background-color:#96969614;border-radius:4px;line-height:1.4}.browser-documents-list{margin:4px 0 8px}.new-document-btn{width:calc(100% - 16px);margin:0 8px 8px;padding:8px 12px;font-size:13px;font-weight:500;color:var(--color-accent);background:none;border:1px dashed var(--color-border);border-radius:4px;cursor:pointer;transition:all .15s}.new-document-btn:hover{background-color:var(--color-bg-secondary);border-color:var(--color-accent)}.files-browser{width:280px;height:100%;background-color:var(--color-bg-primary);border-right:1px solid var(--color-border);overflow-y:auto;overflow-x:hidden;padding:12px 0;flex-shrink:0}.section-empty-state{padding:12px;text-align:center;font-size:12px;color:var(--color-text-muted)}@media(max-width:768px){.files-browser{display:none}}
