:root{--bg-desktop:#e8e8e8;--bg-window:#f5f5f5;--bg-content:#fafafa;--grid-color:#0000000f;--grid-size:20px;--bg-titlebar:#000;--bg-titlebar-inactive:#888;--bg-menu:#fff;--bg-input:#fff;--text-primary:#000;--text-secondary:#555;--text-titlebar:#fff;--text-menu:#000;--text-disabled:#999;--border-light:#fff;--border-dark:#888;--border-darker:#555;--border-darkest:#000;--accent:#000;--accent-hover:#333;--selection:#000;--selection-text:#fff;--titlebar-height:20px;--menubar-height:24px;--border-width:1px;--panel-min-width:200px;--font-system:"Chicago", "Geneva", "Helvetica Neue", Helvetica, Arial, sans-serif;--font-mono:"Monaco", "Courier New", Courier, monospace;--font-size-sm:11px;--font-size-base:12px;--font-size-lg:14px}[data-theme=dark]{--bg-desktop:#1a1a1a;--bg-window:#2a2a2a;--bg-content:#0a0a0a;--bg-titlebar:#3a3a3a;--bg-titlebar-inactive:#2a2a2a;--bg-menu:#2a2a2a;--bg-input:#1a1a1a;--grid-color:#ffffff0a;--grid-size:20px;--text-primary:#fff;--text-secondary:#aaa;--text-titlebar:#fff;--text-menu:#fff;--text-disabled:#555;--border-light:#4a4a4a;--border-dark:#1a1a1a;--border-darker:#0a0a0a;--border-darkest:#000;--accent:#fff;--accent-hover:#ccc;--selection:#444;--selection-text:#fff}:root[data-theme=amber],[data-theme=amber]{--bg-desktop:#0d0800;--bg-window:#1a1000;--bg-content:#0a0500;--bg-titlebar:#2a1800;--bg-titlebar-inactive:#1a1000;--bg-menu:#0d0800;--bg-input:#0a0500;--text-primary:#ffb000;--text-secondary:#c80;--text-titlebar:#ffb000;--text-menu:#ffb000;--text-disabled:#962;--border-light:#c80;--border-dark:#804000;--border-darker:#402000;--border-darkest:#ffb000;--accent:#fc0;--accent-hover:#f90;--selection:#804000;--selection-text:#ffb000;--crt-glow:0 0 5px #ffb000, 0 0 10px #ffb000, 0 0 15px #c80;--crt-text-shadow:0 0 5px #ffb000}[data-theme=amber] *{text-shadow:var(--crt-text-shadow)}[data-theme=amber] .window{box-shadow:var(--crt-glow)}[data-theme=amber] .editor-content{text-shadow:0 0 8px #ffb000,0 0 2px #ffb000}:root[data-theme=apple2],[data-theme=apple2]{--bg-desktop:#000;--bg-window:#000;--bg-content:#000;--bg-titlebar:#003010;--bg-titlebar-inactive:#001808;--bg-menu:#000;--bg-input:#000;--text-primary:#41ff00;--text-secondary:#30c000;--text-titlebar:#41ff00;--text-menu:#41ff00;--text-disabled:#308030;--border-light:#30c000;--border-dark:#186000;--border-darker:#0c3000;--border-darkest:#41ff00;--accent:#41ff00;--accent-hover:#30c000;--selection:#186000;--selection-text:#41ff00;--crt-glow:0 0 3px #41ff00, 0 0 8px #41ff00, 0 0 12px #30c000;--crt-text-shadow:0 0 3px #41ff00}[data-theme=apple2] *{text-shadow:var(--crt-text-shadow)}[data-theme=apple2] .window{box-shadow:var(--crt-glow)}[data-theme=apple2] .editor-content{text-shadow:0 0 6px #41ff00,0 0 2px #41ff00}[data-theme=amber]:after,[data-theme=apple2]:after{content:"";pointer-events:none;z-index:9998;background:repeating-linear-gradient(0deg,#00000026 0 1px,#0000 1px 2px);width:100%;height:100%;position:fixed;top:0;left:0}[data-theme=amber],[data-theme=apple2]{animation:.15s infinite crt-flicker}@keyframes crt-flicker{0%{opacity:.97}50%{opacity:1}to{opacity:.98}}*,:before,:after{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0;padding:0;overflow:hidden}body{font-family:var(--font-system);font-size:var(--font-size-base);color:var(--text-primary);background-color:var(--bg-desktop);-webkit-font-smoothing:none;-moz-osx-font-smoothing:unset;background-image:linear-gradient(var(--grid-color) 1px, transparent 1px), linear-gradient(90deg, var(--grid-color) 1px, transparent 1px);background-size:var(--grid-size) var(--grid-size)}.bevel-raised{border:1px solid var(--border-darkest);box-shadow:inset 1px 1px 0 var(--border-light), inset -1px -1px 0 var(--border-dark)}.bevel-sunken{border:1px solid var(--border-darkest);box-shadow:inset 1px 1px 0 var(--border-dark), inset -1px -1px 0 var(--border-light)}.bevel-flat{border:1px solid var(--border-darkest)}.window{background-color:var(--bg-window);height:100%;min-height:0;box-shadow:0 4px 20px #00000026, 0 0 0 1px var(--border-darkest);border-radius:8px;flex-direction:column;display:flex;overflow:hidden}.window-scanlines{background:repeating-linear-gradient(0deg, var(--text-primary) 0px, var(--text-primary) 2px, transparent 2px, transparent 4px);flex-shrink:0;height:24px}.window-titlebar{height:var(--titlebar-height);background-color:var(--bg-titlebar);background-image:repeating-linear-gradient(0deg, transparent, transparent 1px, var(--bg-window) 1px, var(--bg-window) 2px);color:var(--text-titlebar);-webkit-user-select:none;user-select:none;border-bottom:1px solid var(--border-darkest);flex-shrink:0;align-items:center;gap:4px;padding:0 4px;display:flex}.window-titlebar.inactive{background:var(--bg-titlebar-inactive)}.window-title{font-weight:700;font-size:var(--font-size-sm);white-space:nowrap;text-overflow:ellipsis;flex:1;padding-left:4px;overflow:hidden}.window-controls{order:-1;gap:2px;display:flex}.window-btn{background-color:var(--bg-window);border:1px solid var(--border-darkest);cursor:pointer;width:12px;height:12px;color:var(--text-primary);justify-content:center;align-items:center;padding:0;font-size:8px;font-weight:700;display:flex}.window-btn:hover{background-color:var(--border-dark)}.window-btn:active{background-color:var(--border-darker)}.window-content{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.menubar{background-color:var(--bg-menu);border-bottom:2px solid var(--border-darkest);z-index:100;flex-shrink:0;align-items:stretch;gap:0;height:32px;padding:0 12px;display:flex;position:relative}.menu-item{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:6px;align-items:center;margin:3px 2px;padding:6px 16px;font-size:14px;font-weight:700;transition:all .1s;display:flex;position:relative}.menu-item:hover,.menu-item.active{background-color:var(--text-primary);color:var(--bg-content);transform:scale(1.02)}.menu-dropdown{background-color:var(--bg-menu);border:2px solid var(--border-darkest);z-index:9999;border-radius:8px;min-width:220px;padding:2px 0;position:absolute;top:100%;left:0;overflow:hidden;box-shadow:4px 4px #0003}.menu-dropdown-item{cursor:pointer;color:var(--text-menu);background-color:var(--bg-menu);align-items:center;gap:10px;padding:8px 20px;font-size:13px;transition:all .1s;display:flex}.menu-dropdown-item:hover{background-color:var(--text-primary);color:var(--bg-content);padding-left:24px}.menu-dropdown-item.disabled{color:var(--text-disabled);cursor:default;text-shadow:none}.menu-dropdown-item.disabled:hover{background-color:var(--bg-menu);color:var(--text-disabled)}[data-theme=amber] .menu-dropdown-item.disabled{color:#962;text-shadow:none}[data-theme=apple2] .menu-dropdown-item.disabled{color:#308030;text-shadow:none}.menu-separator{background-color:var(--border-dark);border-top:1px solid var(--border-light);height:1px;margin:4px 2px}.menu-shortcut{color:var(--text-secondary);font-size:var(--font-size-sm);margin-left:auto}.btn{background-color:var(--bg-content);border:2px solid var(--text-primary);font-family:var(--font-system);cursor:pointer;color:var(--text-primary);border-radius:8px;padding:10px 24px;font-size:14px;font-weight:700;transition:all .15s}.btn:hover{background-color:var(--text-primary);color:var(--bg-content);transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.btn:active{box-shadow:none;transform:translateY(0)}.btn:disabled{color:var(--text-disabled);border-color:var(--text-disabled);cursor:default;transform:none}.btn-primary{background-color:var(--text-primary);color:var(--bg-content);border:2px solid var(--text-primary)}.btn-primary:hover{background-color:var(--bg-content);color:var(--text-primary)}.input{background-color:var(--bg-content);border:2px solid var(--border-dark);font-family:var(--font-system);color:var(--text-primary);border-radius:8px;outline:none;padding:10px 14px;font-size:14px;transition:border-color .15s}.input:focus{border-color:var(--text-primary);box-shadow:0 0 0 3px #0000001a}.panel{background-color:var(--bg-window);flex-direction:column;display:flex;overflow:hidden}.panel-header{background-color:var(--text-primary);color:var(--bg-content);letter-spacing:.5px;text-transform:uppercase;border-bottom:2px solid var(--border-darkest);flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 14px;font-size:13px;font-weight:700;display:flex}.panel-header .window-btn{background:var(--bg-content);color:var(--text-primary);border-radius:4px}.panel-content{background-color:var(--bg-content);background-image:linear-gradient(var(--grid-color) 1px, transparent 1px), linear-gradient(90deg, var(--grid-color) 1px, transparent 1px);background-size:var(--grid-size) var(--grid-size);flex:1;min-height:0;overflow:hidden auto}.resize-handle{background-color:var(--bg-window);cursor:col-resize;flex-shrink:0;justify-content:center;align-items:center;width:6px;display:flex}.resize-handle:after{content:"";background:repeating-linear-gradient(to bottom, var(--border-dark) 0px, var(--border-dark) 2px, transparent 2px, transparent 4px);width:2px;height:30px}.resize-handle:hover{background-color:var(--border-light)}.panel-content::-webkit-scrollbar{width:16px;height:16px}.panel-content::-webkit-scrollbar-track{background:repeating-linear-gradient(45deg, var(--bg-window) 0px, var(--bg-window) 2px, var(--border-light) 2px, var(--border-light) 4px)}.panel-content::-webkit-scrollbar-thumb{background-color:var(--bg-window);border:var(--border-width) solid;border-color:var(--border-light) var(--border-darker) var(--border-darker) var(--border-light)}.panel-content::-webkit-scrollbar-button{background-color:var(--bg-window);border:var(--border-width) solid;border-color:var(--border-light) var(--border-darker) var(--border-darker) var(--border-light);width:16px;height:16px;display:block}.statusbar{background-color:var(--text-primary);height:32px;color:var(--bg-content);border-top:2px solid var(--border-darkest);flex-shrink:0;align-items:center;gap:8px;padding:0 12px;display:flex}.statusbar-section{white-space:nowrap;border-radius:4px;padding:4px 12px;font-size:12px}.statusbar-section.flex{flex:1}.file-tree{padding:8px}.file-tree-item{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:8px;align-items:center;gap:10px;margin:2px 0;padding:8px 12px;font-size:13px;transition:all .1s;display:flex}.file-tree-item:hover{background-color:var(--bg-menu);transform:translate(2px)}.file-tree-item.selected{background-color:var(--text-primary);color:var(--bg-content);font-weight:700;box-shadow:2px 2px #00000026}.file-tree-icon{width:24px;height:24px;image-rendering:pixelated;background:var(--bg-menu);border:1px solid var(--border-dark);border-radius:6px;flex-shrink:0;padding:4px}.file-tree-item.selected .file-tree-icon{background:var(--bg-content);border-color:var(--bg-content)}.file-tree-label{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.file-tree-children{padding-left:20px}.file-tree-item.dragging{opacity:.5}.file-tree-item.drop-before{border-top:2px solid var(--accent)}.file-tree-item.drop-after{border-bottom:2px solid var(--accent)}.file-tree-item.drop-inside{background-color:var(--selection);color:var(--selection-text)}.file-tree-rename{font-size:var(--font-size-base);flex:1;min-width:50px;padding:1px 4px}.file-icon svg{width:100%;height:100%}.modal-overlay{z-index:9000;background-color:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-window{background-color:var(--bg-window);flex-direction:column;min-width:200px;max-width:90vw;max-height:90vh;display:flex}.modal-titlebar{height:var(--titlebar-height);background-color:var(--bg-titlebar);background-image:repeating-linear-gradient(0deg, transparent, transparent 1px, var(--bg-window) 1px, var(--bg-window) 2px);color:var(--text-titlebar);border-bottom:1px solid var(--border-darkest);align-items:center;gap:4px;padding:0 4px;display:flex}.modal-title{font-weight:700;font-size:var(--font-size-sm);flex:1;padding-left:4px}.modal-content{padding:16px;overflow:auto}.confirm-dialog,.prompt-dialog{flex-direction:column;gap:16px;display:flex}.confirm-message,.prompt-message{font-size:var(--font-size-base);margin:0;line-height:1.5}.confirm-buttons,.prompt-buttons{justify-content:flex-end;gap:8px;display:flex}.prompt-input{width:100%}.context-menu{z-index:9500;position:fixed}.editor-document h1{border-bottom:1px solid var(--border-dark);margin:0 0 16px;padding-bottom:8px;font-size:24px}.editor-document h2{margin:16px 0 8px;font-size:18px}.editor-document h3{margin:12px 0 6px;font-size:15px}.editor-document p{margin:4px 0;line-height:1.6}.editor-document li{margin-left:20px;line-height:1.6}.editor-empty,.editor-placeholder{color:var(--text-secondary);text-align:center;padding:40px;font-style:italic}.editor-text{white-space:pre-wrap}.editor-wrapper{flex:1;min-height:0;padding:16px;overflow-y:auto}.tiptap-editor{min-height:100%;font-family:var(--font-family);font-size:var(--font-size-base);color:var(--text-primary);box-shadow:none;background:0 0;border:none;outline:none;line-height:1.6}.tiptap-editor:focus{box-shadow:none;border:none;outline:none}.tiptap-editor.ProseMirror,.ProseMirror{box-shadow:none;background:0 0;border:none;outline:none}.ProseMirror:focus{box-shadow:none;border:none;outline:none}.tiptap-editor p{margin:0 0 1em}.tiptap-editor h1{border-bottom:1px solid var(--border-dark);margin:0 0 .5em;padding-bottom:.25em;font-size:2em}.tiptap-editor h2{margin:1em 0 .5em;font-size:1.5em}.tiptap-editor h3{margin:1em 0 .5em;font-size:1.25em}.tiptap-editor ul,.tiptap-editor ol{margin:0 0 1em;padding-left:1.5em}.tiptap-editor li{margin:.25em 0}.tiptap-editor blockquote{border-left:3px solid var(--border-dark);color:var(--text-secondary);margin:1em 0;padding-left:1em;font-style:italic}.tiptap-editor code{background-color:var(--bg-input);border-radius:2px;padding:.1em .3em;font-family:monospace}.tiptap-editor pre{background-color:var(--bg-input);border-radius:4px;margin:1em 0;padding:1em;overflow-x:auto}.tiptap-editor mark{color:#000;background-color:#ff0}.tiptap-editor .is-editor-empty:first-child:before{content:attr(data-placeholder);float:left;color:var(--text-disabled);pointer-events:none;height:0;font-style:italic}.toolbar-btn{background-color:var(--bg-menu);border:1px solid var(--border-dark);cursor:pointer;min-width:32px;height:32px;color:var(--text-primary);border-radius:8px;justify-content:center;align-items:center;padding:6px 10px;font-size:14px;font-weight:700;transition:all .1s;display:flex}.toolbar-btn:hover{background-color:var(--bg-content);transform:translateY(-1px);box-shadow:2px 2px #0000001a}.toolbar-btn.active{background-color:var(--text-primary);color:var(--bg-content);border-color:var(--text-primary);box-shadow:2px 2px #00000026}.toolbar-separator{color:var(--border-dark);margin:0 2px}.editor-wrapper.typewriter-mode,.editor-wrapper.typewriter-mode .tiptap-editor{padding-bottom:50vh}.inspector-panel{height:100%}.inspector-panel .panel-content{flex:1;min-height:0;overflow-y:auto}.inspector{padding:8px;font-size:12px}.inspector-empty{text-align:center;color:var(--text-secondary);padding:20px;font-style:italic}.inspector-section{border-bottom:1px solid var(--border-dark);margin-bottom:16px;padding-bottom:12px}.inspector-section:last-child{border-bottom:none;margin-bottom:0}.inspector-heading{color:var(--text-primary);margin:0 0 8px;font-size:12px;font-weight:700}.inspector-field{align-items:center;gap:8px;margin-bottom:4px;display:flex}.inspector-label{color:var(--text-secondary);min-width:50px}.inspector-value{color:var(--text-primary);font-weight:500}.inspector-stats{gap:16px;display:flex}.inspector-stat{flex-direction:column;align-items:center;display:flex}.inspector-stat-value{color:var(--text-primary);font-size:18px;font-weight:700}.inspector-stat-label{color:var(--text-secondary);text-transform:uppercase;font-size:10px}.inspector-input{flex:1;padding:4px 8px;font-size:11px}.inspector-textarea{resize:vertical;width:100%;min-height:60px;padding:6px;font-size:11px}.inspector-progress{background:var(--bg-input);border:1px solid var(--border-dark);border-radius:2px;height:20px;margin-top:8px;position:relative;overflow:hidden}.inspector-progress-bar{background:var(--accent);height:100%;transition:width .3s}.inspector-progress-text{color:var(--text-primary);white-space:nowrap;font-size:10px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.inspector-labels{flex-wrap:wrap;gap:4px;display:flex}.inspector-label-tag{background:var(--bg-input);border:1px solid var(--border-dark);color:var(--text-primary);border-radius:2px;padding:2px 8px;font-size:10px}.inspector-label-add{border:1px dashed var(--border-dark);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:2px;padding:2px 8px;font-size:10px}.inspector-label-add:hover{border-color:var(--accent);color:var(--accent)}.inspector-heading-collapsible{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:6px;display:flex}.inspector-heading-collapsible:hover{color:var(--accent)}.inspector-collapse-icon{width:10px;font-size:8px}.inspector-section-content{margin-top:8px}.inspector-label-tag{align-items:center;gap:4px;display:inline-flex}.inspector-label-remove{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:0;font-size:10px;line-height:1}.inspector-label-remove:hover{color:var(--accent)}.inspector-label-input{width:80px;padding:2px 6px;font-size:10px}.inspector-references-drop{border:1px dashed var(--border-dark);border-radius:4px;min-height:60px;padding:8px;transition:border-color .2s,background-color .2s}.inspector-references-drop.drag-over{border-color:var(--accent);background-color:var(--bg-input)}.inspector-references-empty{color:var(--text-secondary);text-align:center;margin:0;padding:12px 0;font-size:11px;font-style:italic}.inspector-references-list{flex-direction:column;gap:4px;display:flex}.inspector-reference-item{background:var(--bg-input);border:1px solid var(--border-dark);border-radius:2px;justify-content:space-between;align-items:center;padding:4px 8px;font-size:11px;display:flex}.inspector-reference-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.inspector-reference-remove{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:0 0 0 8px;font-size:10px}.inspector-reference-remove:hover{color:var(--accent)}.inspector-reference-section{background:var(--bg-input);border:1px solid var(--border-dark);border-radius:4px;margin-bottom:8px}.inspector-reference-section .inspector-heading{align-items:center;gap:6px;margin:0;padding:6px 8px;display:flex}.inspector-reference-title{cursor:pointer;text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.inspector-reference-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:2px 4px;font-size:12px;line-height:1}.inspector-reference-close:hover{color:var(--accent)}.inspector-reference-content{color:var(--text-secondary);background:var(--bg-content);border-top:1px solid var(--border-dark);white-space:pre-wrap;word-wrap:break-word;max-height:200px;padding:8px;font-size:11px;line-height:1.5;overflow-y:auto}.auth-modal{width:400px;max-width:90vw}.auth-form{padding:20px}.auth-error{color:#c00;background:#fcc;border:1px solid #c00;border-radius:4px;margin-bottom:16px;padding:10px;font-size:13px}.form-group{margin-bottom:16px}.form-group label{color:var(--text-primary);margin-bottom:6px;font-size:13px;font-weight:700;display:block}.form-input{border:1px solid var(--border-dark);background:var(--bg-input);width:100%;color:var(--text-primary);box-sizing:border-box;border-radius:4px;padding:10px 12px;font-size:14px}.form-input:focus{border-color:var(--accent);outline:none}.auth-submit{background:var(--bg-menu);width:100%;color:var(--text-primary);border:1px solid var(--border-dark);cursor:pointer;border-radius:4px;margin-top:8px;padding:12px;font-size:14px;font-weight:700}.auth-submit:hover{background:var(--bg-window)}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-switch{text-align:center;color:var(--text-secondary);margin-top:16px;font-size:13px}.auth-switch button{color:var(--accent);cursor:pointer;background:0 0;border:none;font-size:13px;text-decoration:underline}.auth-switch button:hover{color:var(--text-primary)}.github-modal{width:450px;max-width:90vw}.github-form{padding:20px}.github-info{color:var(--text-secondary);margin-bottom:16px;font-size:13px;line-height:1.5}.github-form small{color:var(--text-secondary);margin-top:4px;font-size:11px;display:block}.github-form small a{color:var(--accent)}.token-input-wrapper{gap:8px;display:flex}.token-input-wrapper .form-input{flex:1}.token-toggle{background:var(--bg-menu);border:1px solid var(--border-dark);cursor:pointer;border-radius:4px;padding:0 12px;font-size:16px}.token-toggle:hover{background:var(--bg-window)}.github-actions{justify-content:flex-end;gap:8px;margin-top:20px;display:flex}.btn-danger{color:#fff;background:#c44;border-color:#a33}.btn-danger:hover{background:#a33}.mobile-mode{background:var(--bg-content);color:var(--text-primary);z-index:9999;flex-direction:column;display:flex;position:fixed;inset:0}.mobile-header{text-align:center;background:var(--bg-window);border-bottom:1px solid var(--border-dark);padding:20px}.mobile-title{margin:0;font-size:24px;font-weight:700}.mobile-content{flex-direction:column;flex:1;justify-content:center;align-items:center;padding:40px 20px;display:flex}.mobile-upload-section{text-align:center}.mobile-upload-btn{background:var(--bg-window);color:var(--text-primary);border:2px solid var(--border-dark);cursor:pointer;border-radius:8px;padding:20px 40px;font-size:18px;transition:background .2s;display:inline-block}.mobile-upload-btn:hover{background:var(--bg-menu)}.mobile-upload-hint{color:var(--text-secondary);margin-top:16px;font-size:14px}.mobile-footer{background:var(--bg-window);border-top:1px solid var(--border-dark);justify-content:center;gap:16px;padding:20px;display:flex}.mobile-mode-btn{background:var(--bg-window);color:var(--text-primary);border:1px solid var(--border-dark);cursor:pointer;border-radius:4px;padding:12px 24px;font-size:14px}.mobile-mode-btn:hover{background:var(--bg-menu);color:var(--text-primary)}.focus-mode{z-index:9999;flex-direction:column;display:flex;position:fixed;inset:0}.focus-mode[data-theme=light]{color:#000;background:#fff}.focus-mode[data-theme=light] .focus-mode-header{background:#ddd;border-color:#888}.focus-mode[data-theme=light] .focus-mode-editor,.focus-mode[data-theme=light] .ProseMirror{color:#000}.focus-mode[data-theme=dark]{color:#e0e0e0;background:#0a0a0a}.focus-mode[data-theme=dark] .focus-mode-header{background:#2a2a2a;border-color:#444}.focus-mode[data-theme=dark] .focus-mode-editor,.focus-mode[data-theme=dark] .ProseMirror{color:#e0e0e0}.focus-mode[data-theme=amber]{color:#ffb000;background:#0a0500}.focus-mode[data-theme=amber] .focus-mode-header{background:#1a1000;border-color:#3a2000}.focus-mode[data-theme=amber] .focus-mode-editor,.focus-mode[data-theme=amber] .ProseMirror{color:#ffb000}.focus-mode[data-theme=apple2]{color:#3f3;background:#000}.focus-mode[data-theme=apple2] .focus-mode-header{background:#000;border-color:#040}.focus-mode[data-theme=apple2] .focus-mode-editor,.focus-mode[data-theme=apple2] .ProseMirror{color:#3f3}.focus-mode-header{background:var(--bg-window);border-bottom:1px solid var(--border-dark);box-sizing:border-box;flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.focus-mode-left{flex:1;align-items:center;gap:16px;display:flex}.focus-mode-title{color:var(--text-primary);font-weight:700}.focus-mode-center{flex:2;justify-content:center;align-items:center;gap:20px;display:flex}.focus-mode-right{flex:1;justify-content:flex-end;align-items:center;height:100%;display:flex}.focus-mode-stats{color:var(--text-secondary);gap:16px;font-size:12px;display:flex}.focus-mode-zoom{align-items:center;gap:4px;display:flex}.focus-mode-zoom select{background:var(--bg-input);border:1px solid var(--border-dark);color:var(--text-primary);cursor:pointer;padding:2px 6px;font-size:11px}.focus-mode-exit{vertical-align:middle;padding:5px 12px;font-size:11px;line-height:1}.focus-mode-editor{scrollbar-width:none;-ms-overflow-style:none;flex:1;width:100%;margin:0 auto;padding:40px 20px;overflow-y:auto}.focus-mode-editor::-webkit-scrollbar{display:none}.focus-mode-editor{max-width:700px}.focus-mode-editor .tiptap-editor{font-size:inherit;box-shadow:none;border:none;outline:none;line-height:1.8}.focus-mode-editor .ProseMirror{font-size:inherit}.focus-mode-editor .tiptap-editor:focus,.focus-mode-editor .ProseMirror,.focus-mode-editor .ProseMirror:focus{box-shadow:none;border:none;outline:none}.focus-mode.typewriter .focus-mode-editor{padding-top:40vh;padding-bottom:40vh}.file-tree-toggle{flex-shrink:0;justify-content:center;align-items:center;width:12px;height:12px;font-size:10px;display:flex}.editor-area{background-color:var(--bg-content);flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.editor-toolbar{background-color:var(--bg-window);border-bottom:1px solid var(--border-dark);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:4px;padding:4px 8px;display:flex}.editor-toolbar-btn{background-color:var(--bg-menu);border:1px solid var(--border-dark);cursor:pointer;width:32px;height:32px;color:var(--text-primary);border-radius:8px;justify-content:center;align-items:center;font-size:14px;font-weight:700;transition:all .1s;display:flex}.editor-toolbar-btn:hover{background-color:var(--bg-content);transform:translateY(-1px);box-shadow:2px 2px #0000001a}.editor-toolbar-btn:active,.editor-toolbar-btn.active{background-color:var(--text-primary);color:var(--bg-content);border-color:var(--text-primary);transform:none;box-shadow:2px 2px #00000026}.editor-toolbar-separator{background-color:var(--border-dark);width:1px;height:20px;margin:0 4px}.editor-content{min-height:0;font-family:var(--font-system);font-size:var(--font-size-lg);flex-direction:column;flex:1;line-height:1.6;display:flex;overflow:hidden}.focus-mode{z-index:9999;background-color:#000;flex-direction:column;display:flex;position:fixed;inset:0}.focus-mode .editor-content{color:#e0e0e0;background-color:#1a1a1a;width:100%;max-width:700px;margin:0 auto;padding:40px;font-size:16px;line-height:1.8}.focus-mode-exit{z-index:10000;position:fixed;top:16px;right:16px}.login-screen{background-color:var(--bg-desktop);justify-content:center;align-items:center;height:100%;display:flex}.login-window{width:320px}.login-form{flex-direction:column;gap:16px;padding:20px;display:flex}.login-field label{font-size:var(--font-size-sm)}.login-field .input{width:100%}.login-buttons{justify-content:flex-end;gap:8px;margin-top:8px;display:flex}.login-error{color:#c00;font-size:var(--font-size-sm);background-color:#fcc;border:1px solid #c00;padding:8px}@media (width<=768px){.desktop-only{display:none!important}.phone-mode .panel{z-index:100;position:fixed;inset:0}.phone-mode .menubar{height:44px}.phone-mode .menu-item{padding:12px 16px}}@media (width>=769px){.phone-only{display:none!important}}.hidden{display:none!important}.flex-1{flex:1}.text-center{text-align:center}.gap-sm{gap:4px}.gap-md{gap:8px}.gap-lg{gap:16px}.writing-goals{border-bottom:1px solid var(--border-dark);padding:12px}.writing-goals-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.writing-goals-header h4{color:var(--text-secondary);text-transform:uppercase;margin:0;font-size:12px}.streak-badge{background:var(--bg-menu);color:var(--text-primary);border-radius:10px;padding:2px 6px;font-size:11px}.goal-progress{margin-bottom:8px}.progress-bar{background:var(--bg-input);border-radius:4px;height:8px;margin-bottom:6px;overflow:hidden}.progress-fill{background:var(--accent);height:100%;transition:width .3s}.progress-fill.goal-met{background:#4caf50}.progress-text{align-items:center;gap:4px;font-size:13px;display:flex}.word-count{color:var(--text-primary);font-weight:700}.separator{color:var(--text-secondary)}.target-count{color:var(--text-secondary);cursor:pointer}.target-count:hover{color:var(--accent);text-decoration:underline}.target-input{border:1px solid var(--accent);background:var(--bg-input);width:80px;color:var(--text-primary);border-radius:3px;padding:2px 4px;font-size:13px}.goal-celebration{color:#4caf50;text-align:center;background:#4caf501a;border-radius:4px;padding:4px;font-size:12px}.snapshots-panel{border-bottom:1px solid var(--border-dark);padding:12px}.snapshots-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.snapshots-header h4{color:var(--text-secondary);text-transform:uppercase;margin:0;font-size:12px}.snapshot-create-form{margin-bottom:12px}.snapshot-create-form .form-input{margin-bottom:8px}.snapshot-form-actions{gap:6px;display:flex}.snapshots-empty{color:var(--text-secondary);margin:0;font-size:12px;font-style:italic}.snapshots-list{margin:0;padding:0;list-style:none}.snapshot-item{border:1px solid var(--border-dark);border-radius:4px;margin-bottom:8px;overflow:hidden}.snapshot-header{cursor:pointer;background:var(--bg-menu);justify-content:space-between;padding:8px 10px;display:flex}.snapshot-header:hover{background:var(--bg-window)}.snapshot-name{color:var(--text-primary);font-size:13px;font-weight:500}.snapshot-date{color:var(--text-secondary);font-size:11px}.snapshot-details{background:var(--bg-content);border-top:1px solid var(--border-dark);padding:10px}.snapshot-meta{color:var(--text-secondary);margin-bottom:8px;font-size:11px}.snapshot-preview{color:var(--text-secondary);max-height:60px;margin-bottom:10px;font-size:12px;line-height:1.4;overflow:hidden}.snapshot-actions{gap:6px;display:flex}.comments-panel{padding:12px}.comments-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.comments-header h4{color:var(--text-secondary);text-transform:uppercase;margin:0;font-size:12px}.comment-count{color:var(--text-secondary);font-size:11px}.comment-add-form{margin-bottom:12px}.comment-textarea{resize:vertical;width:100%;min-height:50px;margin-bottom:8px;font-family:inherit}.show-resolved-toggle{color:var(--text-secondary);cursor:pointer;align-items:center;gap:6px;margin-bottom:10px;font-size:12px;display:flex}.comments-empty{color:var(--text-secondary);margin:0;font-size:12px;font-style:italic}.comments-list{margin:0;padding:0;list-style:none}.comment-item{border:1px solid var(--border-dark);background:var(--bg-menu);border-radius:4px;justify-content:space-between;align-items:flex-start;margin-bottom:8px;padding:10px;display:flex}.comment-item.resolved{opacity:.6;background:0 0}.comment-content{flex:1}.comment-text{color:var(--text-primary);margin:0 0 4px;font-size:13px;line-height:1.4}.comment-date{color:var(--text-secondary);font-size:11px}.comment-actions{gap:4px;margin-left:8px;display:flex}.btn-icon{border:1px solid var(--border-dark);background:var(--bg-menu);width:24px;height:24px;color:var(--text-primary);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;font-size:14px;display:flex}.btn-icon:hover{background:var(--bg-window)}.btn-icon.btn-danger:hover{color:#fff;background:#c44}.btn-small{padding:4px 10px;font-size:12px}.daily-goal-status{align-items:center;gap:8px;font-size:12px;display:flex}.daily-goal-status span{white-space:nowrap}.daily-goal-bar{background:var(--bg-input);border-radius:3px;width:60px;height:6px;overflow:hidden}.daily-goal-fill{background:var(--accent);height:100%;transition:width .3s}.daily-goal-fill.goal-met{background:#4caf50}[data-ui-scale=small]{font-size:12px}[data-ui-scale=small] .menubar{height:22px;font-size:11px}[data-ui-scale=small] .statusbar{height:18px;font-size:10px}[data-ui-scale=small] .panel-header{padding:4px 8px;font-size:11px}[data-ui-scale=small] .file-tree-item{padding:2px 4px;font-size:11px}[data-ui-scale=small] .inspector-heading{font-size:10px}[data-ui-scale=small] .tiptap-editor,[data-ui-scale=medium]{font-size:14px}[data-ui-scale=large]{font-size:16px}[data-ui-scale=large] .menubar{height:32px;font-size:15px}[data-ui-scale=large] .statusbar{height:28px;font-size:13px}[data-ui-scale=large] .panel-header{padding:10px 14px;font-size:14px}[data-ui-scale=large] .file-tree-item{padding:6px 8px;font-size:14px}[data-ui-scale=large] .inspector-heading{font-size:13px}[data-ui-scale=large] .tiptap-editor{font-size:20px}[data-ui-scale=large] .toolbar-btn{width:32px;height:32px;font-size:16px}.login-screen{background-color:var(--bg-desktop);z-index:10000;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.login-scanlines{background:repeating-linear-gradient(0deg, var(--text-primary) 0px, var(--text-primary) 2px, transparent 2px, transparent 4px);width:100%;height:32px;position:absolute;top:0;left:0}.login-grid-overlay{background-image:linear-gradient(var(--grid-color) 1px, transparent 1px), linear-gradient(90deg, var(--grid-color) 1px, transparent 1px);background-size:var(--grid-size) var(--grid-size);pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}.login-container{background-color:var(--bg-content);border:2px solid var(--text-primary);z-index:1;border-radius:12px;width:100%;max-width:420px;padding:48px;position:relative;box-shadow:8px 8px #0003}.login-header{text-align:center;margin-bottom:32px}.login-title{letter-spacing:8px;color:var(--text-primary);margin:0 0 8px;font-size:48px;font-weight:700}.login-subtitle{color:var(--text-secondary);letter-spacing:2px;text-transform:uppercase;margin:0;font-size:14px}.login-form{flex-direction:column;gap:20px;display:flex}.login-error{color:#c62828;background-color:#ffebee;border:2px solid #c62828;border-radius:8px;align-items:center;gap:8px;padding:12px 16px;font-size:14px;display:flex}.login-error-icon{font-size:18px}.login-field{flex-direction:column;gap:8px;display:flex}.login-field label{text-transform:uppercase;letter-spacing:1px;color:var(--text-primary);font-size:13px;font-weight:700}.login-field input{background-color:var(--bg-content);border:2px solid var(--border-dark);color:var(--text-primary);font-size:16px;font-family:var(--font-system);border-radius:8px;padding:14px 16px;transition:border-color .15s}.login-field input:focus{border-color:var(--text-primary);outline:none;box-shadow:0 0 0 3px #0000001a}.login-field input::placeholder{color:var(--text-disabled)}.login-password-wrapper{display:flex;position:relative}.login-password-wrapper input{flex:1;padding-right:48px}.login-password-toggle{cursor:pointer;opacity:.6;background:0 0;border:none;padding:4px;font-size:18px;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.login-password-toggle:hover{opacity:1}.login-submit{background-color:var(--text-primary);color:var(--bg-content);border:2px solid var(--text-primary);cursor:pointer;text-transform:uppercase;letter-spacing:2px;border-radius:8px;margin-top:8px;padding:16px 24px;font-size:16px;font-weight:700;transition:all .15s}.login-submit:hover:not(:disabled){background-color:var(--bg-content);color:var(--text-primary);transform:translateY(-2px);box-shadow:4px 4px #0003}.login-submit:disabled{opacity:.5;cursor:not-allowed}.login-loading{justify-content:center;align-items:center;gap:12px;display:flex}.login-spinner{border:2px solid var(--bg-content);border-top-color:#0000;border-radius:50%;width:18px;height:18px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-footer{text-align:center;margin-top:24px}.login-security-badge{color:var(--text-secondary);background:var(--bg-menu);border-radius:20px;align-items:center;gap:8px;padding:8px 16px;font-size:12px;display:inline-flex}.project-selector{background-color:var(--bg-desktop);z-index:10000;flex-direction:column;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.project-selector-scanlines{background:repeating-linear-gradient(0deg, var(--text-primary) 0px, var(--text-primary) 2px, transparent 2px, transparent 4px);flex-shrink:0;height:32px}.project-selector-grid-overlay{background-image:linear-gradient(var(--grid-color) 1px, transparent 1px), linear-gradient(90deg, var(--grid-color) 1px, transparent 1px);background-size:var(--grid-size) var(--grid-size);pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}.project-selector-header{background-color:var(--bg-content);border-bottom:2px solid var(--text-primary);z-index:1;justify-content:space-between;align-items:center;padding:24px 48px;display:flex;position:relative}.project-selector-title h1{letter-spacing:6px;color:var(--text-primary);margin:0;font-size:32px;font-weight:700}.project-selector-subtitle{color:var(--text-secondary);letter-spacing:1px;font-size:14px}.project-selector-user{align-items:center;gap:16px;display:flex}.project-selector-username{color:var(--text-primary);font-weight:700}.project-selector-logout{border:2px solid var(--text-primary);cursor:pointer;color:var(--text-primary);background:0 0;border-radius:6px;padding:8px 16px;font-size:13px;font-weight:700;transition:all .15s}.project-selector-logout:hover{background-color:var(--text-primary);color:var(--bg-content)}.project-selector-content{z-index:1;flex:1;padding:48px;position:relative;overflow-y:auto}.project-selector-error{color:#c62828;background-color:#ffebee;border:2px solid #c62828;border-radius:8px;align-items:center;gap:12px;margin-bottom:24px;padding:16px 20px;display:flex}.project-selector-error button{color:#fff;cursor:pointer;background:#c62828;border:none;border-radius:4px;margin-left:auto;padding:6px 12px}.project-selector-loading{color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:64px;display:flex}.project-selector-spinner{border:3px solid var(--border-dark);border-top-color:var(--text-primary);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.project-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;display:grid}.project-card{background-color:var(--bg-content);border:2px solid var(--border-dark);cursor:pointer;border-radius:12px;flex-direction:column;gap:8px;padding:24px;transition:all .15s;display:flex;position:relative}.project-card-delete{cursor:pointer;opacity:0;width:28px;height:28px;color:var(--text-secondary);background:#0000001a;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:18px;transition:opacity .15s,background .15s;display:flex;position:absolute;top:8px;right:8px}.project-card:hover .project-card-delete{opacity:1}.project-card-delete:hover{color:#fff;background:#c62828}.project-card:hover{border-color:var(--text-primary);transform:translateY(-4px);box-shadow:6px 6px #00000026}.project-card-new{background-color:#0000;border-style:dashed;justify-content:center;align-items:center;min-height:180px}.project-card-new:hover{background-color:var(--bg-content)}.project-card-icon{margin-bottom:8px;font-size:48px}.project-card-new .project-card-icon{border:3px solid var(--text-primary);border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;font-size:32px;font-weight:700;display:flex}.project-card-name{color:var(--text-primary);font-size:18px;font-weight:700}.project-card-description{color:var(--text-secondary);font-size:14px;line-height:1.4}.project-card-date{color:var(--text-disabled);border-top:1px solid var(--border-light);margin-top:auto;padding-top:12px;font-size:12px}.project-selector-empty{text-align:center;color:var(--text-secondary);padding:64px}.project-modal-overlay{z-index:10001;background-color:#00000080;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.project-modal{background-color:var(--bg-content);border:2px solid var(--text-primary);border-radius:12px;width:100%;max-width:480px;box-shadow:8px 8px #0003}.project-modal-header{border-bottom:2px solid var(--border-dark);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.project-modal-header h2{margin:0;font-size:20px;font-weight:700}.project-modal-close{cursor:pointer;color:var(--text-primary);background:0 0;border:none;padding:4px 8px;font-size:24px;line-height:1}.project-modal-close:hover{color:var(--text-secondary)}.project-modal-form{flex-direction:column;gap:20px;padding:24px;display:flex}.project-modal-field{flex-direction:column;gap:8px;display:flex}.project-modal-field label{text-transform:uppercase;letter-spacing:1px;font-size:13px;font-weight:700}.project-modal-field input,.project-modal-field textarea{background-color:var(--bg-content);border:2px solid var(--border-dark);color:var(--text-primary);font-size:15px;font-family:var(--font-system);resize:vertical;border-radius:8px;padding:12px 14px}.project-modal-field input:focus,.project-modal-field textarea:focus{border-color:var(--text-primary);outline:none}.project-modal-actions{justify-content:flex-end;gap:12px;margin-top:8px;display:flex}.project-modal-cancel{border:2px solid var(--border-dark);cursor:pointer;color:var(--text-primary);background:0 0;border-radius:8px;padding:12px 24px;font-size:14px;font-weight:700}.project-modal-cancel:hover{border-color:var(--text-primary)}.project-modal-submit{background-color:var(--text-primary);color:var(--bg-content);border:2px solid var(--text-primary);cursor:pointer;border-radius:8px;padding:12px 24px;font-size:14px;font-weight:700}.project-modal-submit:hover:not(:disabled){background-color:var(--bg-content);color:var(--text-primary)}.project-modal-submit:disabled{opacity:.5;cursor:not-allowed}.project-modal-body{padding:0 24px 24px}.project-modal-body p{margin:0 0 12px;line-height:1.5}.project-modal-warning{color:#c62828;font-size:13px}.project-modal-delete-btn{color:#fff;cursor:pointer;background-color:#c62828;border:2px solid #c62828;border-radius:8px;padding:12px 24px;font-size:14px;font-weight:700}.project-modal-delete-btn:hover:not(:disabled){background-color:#b71c1c;border-color:#b71c1c}.project-modal-delete-btn:disabled{opacity:.5;cursor:not-allowed}
