@import"https://fonts.googleapis.com/css2?family=Fira+Code:wght@300;400;500&family=JetBrains+Mono:wght@300;400;500&display=swap";*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.visible{visibility:visible}.fixed{position:fixed}.block{display:block}.flex{display:flex}.hidden{display:none}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.italic{font-style:italic}.shadow{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}:root{--bg-color: #000000;--fg-color: #00ff00;--accent-color: #00cc00;--dim-color: #006600;--cursor-color: #00ff00;--font-family: "Fira Code";--font-size: 16px;--blink-speed: 1s}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-family),"Courier New",monospace;background:var(--bg-color);color:var(--fg-color);overflow:hidden;-moz-user-select:none;user-select:none;-webkit-text-size-adjust:100%;-webkit-touch-callout:none;-webkit-user-select:none}#root{height:100vh;height:100dvh;width:100vw}.app{height:100vh;height:100dvh;width:100vw;background:var(--bg-color);color:var(--fg-color);position:relative}.app.fullscreen .status-bar{display:none}.main-container{height:100vh;height:100dvh;width:100vw;display:flex;flex-direction:column;overflow:hidden}.editor-container{flex:1;position:relative;overflow:hidden;min-height:0}.main-editor{width:100%;height:100%;background:transparent;border:none;outline:none;resize:none;font-family:var(--font-family),"Courier New",monospace;font-size:var(--font-size);line-height:1.5;color:var(--fg-color);padding:2rem;caret-color:var(--cursor-color);overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--dim-color) transparent;font-size:max(16px,var(--font-size));-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.main-editor::-webkit-scrollbar{width:8px}.main-editor::-webkit-scrollbar-track{background:transparent}.main-editor::-webkit-scrollbar-thumb{background:var(--dim-color);border-radius:4px}.main-editor::-moz-placeholder{color:var(--dim-color);opacity:.7}.main-editor::placeholder{color:var(--dim-color);opacity:.7}@media (max-width: 768px){.main-editor{padding:1rem;font-size:max(16px,var(--font-size))}.app-header{height:45px;padding:0 .75rem;font-size:.8rem}.current-project-name{font-size:.8rem}.status-bar{height:35px;padding:0 .75rem;font-size:.8rem}.shortcuts-toggle{padding:.2rem .4rem;font-size:.75rem}.status-item{gap:.25rem}.chapter-panel,.settings-panel{width:100vw;max-width:100vw}.panel-close,.chapter-item,.settings-toggle{min-height:44px;display:flex;align-items:center}.shortcuts-panel{position:fixed;bottom:45px;left:50%;transform:translate(-50%);width:90vw;max-width:300px}}@media (max-width: 480px){.main-editor{padding:.75rem}.app-header{height:40px;padding:0 .5rem}.status-bar{height:32px;padding:0 .5rem;font-size:.75rem}.shortcuts-toggle{font-size:.7rem;padding:.15rem .3rem}.current-project-name{font-size:.75rem}}@media (max-height: 500px) and (orientation: landscape){.app-header{height:35px}.status-bar{height:30px}.main-editor{padding:.5rem}}.header-1{color:var(--accent-color);font-weight:700;font-size:1.5em;display:block;margin:1em 0 .5em}.header-2{color:var(--accent-color);font-weight:700;font-size:1.3em;display:block;margin:.8em 0 .4em}.header-3{color:var(--accent-color);font-weight:700;font-size:1.2em;display:block;margin:.7em 0 .3em}.header-4{color:var(--accent-color);font-weight:700;font-size:1.1em;display:block;margin:.6em 0 .3em}.header-5{color:var(--accent-color);font-weight:700;font-size:1.05em;display:block;margin:.5em 0 .2em}.header-6{color:var(--accent-color);font-weight:700;font-size:1em;display:block;margin:.4em 0 .2em}.main-editor{animation:blink var(--blink-speed) infinite;transition:all .2s ease}@keyframes blink{0%,50%{caret-color:var(--cursor-color)}51%,to{caret-color:transparent}}.main-editor.keystroke-pulse{box-shadow:0 0 20px rgba(var(--accent-color-rgb),.3);transform:scale(1.001)}.cursor-blink{animation:blink 1s infinite}.matrix-rain{mix-blend-mode:screen}.status-bar{height:40px;background:var(--bg-color);border-top:1px solid var(--dim-color);display:flex;align-items:center;justify-content:space-between;padding:0 1rem;font-size:.875rem;color:var(--dim-color)}.status-left,.status-center,.status-right{display:flex;align-items:center;gap:1rem}.status-center{position:relative}.status-item{display:flex;align-items:center;gap:.5rem}.shortcuts-toggle{background:none;border:none;color:var(--dim-color);cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:all .2s;display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-family:inherit}.shortcuts-toggle:hover{color:var(--accent-color);background:#ffffff0d}@media (max-width: 480px){.shortcuts-text{display:none}.shortcuts-toggle{gap:0;padding:.25rem}}.shortcuts-panel{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:var(--bg-color);border:1px solid var(--dim-color);border-radius:6px;padding:1rem;margin-bottom:.5rem;box-shadow:0 4px 12px #0000004d;z-index:1000;animation:fadeInUp .2s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.shortcuts-grid{display:grid;grid-template-columns:auto 1fr;gap:.5rem 1rem;align-items:center;min-width:200px}.shortcut-key{color:var(--accent-color);font-weight:500;font-family:var(--font-family),"Courier New",monospace;background:#ffffff0d;padding:.125rem .375rem;border-radius:3px;font-size:.75rem;border:1px solid var(--dim-color)}.shortcut-key.clickable{cursor:pointer;transition:all .2s ease}.shortcut-key.clickable:hover{background:var(--accent-color);color:var(--bg-color);transform:translateY(-1px);box-shadow:0 2px 4px #0003}.shortcut-desc{color:var(--fg-color);font-size:.875rem}.chapter-panel,.settings-panel{position:fixed;top:0;right:0;width:320px;height:100vh;background:var(--bg-color);border-left:1px solid var(--dim-color);display:flex;flex-direction:column;z-index:1000;animation:slideIn .2s ease-out}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.panel-header{height:60px;border-bottom:1px solid var(--dim-color);display:flex;align-items:center;justify-content:space-between;padding:0 1rem}.panel-title{display:flex;align-items:center;gap:.5rem;font-weight:500;color:var(--accent-color)}.panel-close{background:none;border:none;color:var(--fg-color);cursor:pointer;padding:.5rem;border-radius:4px;transition:background .2s}.panel-close:hover{background:var(--dim-color)}.chapter-list{flex:1;overflow-y:auto;padding:1rem 0}.no-chapters{padding:2rem 1rem;text-align:center;color:var(--dim-color);font-style:italic}.chapter-item{width:100%;background:none;border:none;color:var(--fg-color);padding:.75rem 1rem;text-align:left;cursor:pointer;display:flex;align-items:center;gap:.75rem;border-bottom:1px solid rgba(255,255,255,.1);transition:background .2s}.chapter-item:hover{background:var(--dim-color)}.chapter-item.scene-item{padding-left:2rem;border-left:2px solid var(--dim-color);margin-left:.5rem}.chapter-item.scene-item:hover{border-left-color:var(--accent-color)}.chapter-number{color:var(--accent-color);font-weight:500;min-width:2rem}.scene-number{color:var(--dim-color);font-size:1.2rem}.chapter-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.chapter-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chapter-stats{font-size:.75rem;color:var(--dim-color)}.settings-content{flex:1;overflow-y:auto;padding:1rem}.settings-group{margin-bottom:1.5rem}.settings-label{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;color:var(--accent-color);font-weight:500}.settings-select{width:100%;background:var(--bg-color);border:1px solid var(--dim-color);color:var(--fg-color);padding:.5rem;border-radius:4px;font-family:inherit}.settings-select:focus{outline:none;border-color:var(--accent-color)}.settings-range{width:calc(100% - 60px);margin-right:.5rem}.settings-value{color:var(--accent-color);font-weight:500;min-width:60px}.settings-toggles{display:flex;flex-direction:column;gap:.75rem;margin-top:2rem}.settings-toggle{display:flex;align-items:center;gap:.5rem;cursor:pointer;color:var(--fg-color)}.settings-toggle input[type=checkbox]{width:1rem;height:1rem;accent-color:var(--accent-color)}.crt-effect{position:relative}.crt-overlay{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10}.crt-effect:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(transparent 50%,#00ff0008 50%);background-size:100% 2px;pointer-events:none;z-index:10}.crt-effect:after{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:var(--bg-color);opacity:.02;animation:flicker .15s infinite linear alternate;pointer-events:none;z-index:10}@keyframes flicker{0%{opacity:.02}to{opacity:.04}}.progress-container{padding:0;font-size:.875rem}.progress-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.progress-stats{display:flex;align-items:center;gap:.5rem;color:var(--fg-color)}.current-words{color:var(--accent-color);font-weight:500;font-family:var(--font-family),"Courier New",monospace}.progress-separator{color:var(--dim-color)}.goal-input{background:transparent;border:none;color:var(--accent-color);font-family:var(--font-family),"Courier New",monospace;font-weight:500;width:80px;text-align:right;outline:none;border-bottom:1px solid transparent;transition:border-color .2s}.goal-input:hover,.goal-input:focus{border-bottom-color:var(--accent-color)}.words-label{color:var(--dim-color)}.progress-percentage{color:var(--accent-color);font-weight:500;font-family:var(--font-family),"Courier New",monospace}.progress-bar-container{position:relative}.progress-bar{height:8px;background:var(--dim-color);border-radius:4px;overflow:hidden;position:relative}.progress-fill{height:100%;background:var(--accent-color);transition:width .3s ease,background-color .3s ease;border-radius:4px}.progress-fill.complete{background:var(--fg-color);animation:celebration 2s ease-in-out}@keyframes celebration{0%,to{transform:scaleY(1)}50%{transform:scaleY(1.5)}}.milestone-marker{position:absolute;top:-2px;transform:translate(-50%);width:12px;height:12px;border-radius:50%;background:var(--dim-color);border:2px solid var(--bg-color);display:flex;align-items:center;justify-content:center;color:var(--bg-color);font-size:8px;transition:all .3s ease;cursor:help}.milestone-marker.achieved{background:var(--accent-color);color:var(--bg-color);transform:translate(-50%) scale(1.2)}.milestone-marker.new-achievement{animation:milestone-pop .6s ease-out}@keyframes milestone-pop{0%{transform:translate(-50%) scale(1)}50%{transform:translate(-50%) scale(1.8)}to{transform:translate(-50%) scale(1.2)}}.completion-celebration{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:.75rem;color:var(--accent-color);font-weight:500;animation:celebration-text 2s ease-in-out infinite}@keyframes celebration-text{0%,to{opacity:1}50%{opacity:.7}}.milestone-notification{position:fixed;top:2rem;right:2rem;background:var(--bg-color);border:2px solid var(--accent-color);border-radius:8px;padding:1rem;box-shadow:0 4px 12px #0000004d;z-index:2000;transform:translate(100%);opacity:0;transition:all .3s ease-out;max-width:300px}.milestone-notification.visible{transform:translate(0);opacity:1}.milestone-content{display:flex;align-items:flex-start;gap:.75rem}.milestone-icon{color:var(--accent-color);flex-shrink:0;animation:milestone-glow 2s ease-in-out infinite}@keyframes milestone-glow{0%,to{opacity:1}50%{opacity:.6}}.milestone-text{flex:1}.milestone-title{color:var(--accent-color);font-size:1rem;font-weight:500;margin:0 0 .25rem}.milestone-message{color:var(--fg-color);font-size:.875rem;margin:0;line-height:1.4}.milestone-close{background:none;border:none;color:var(--dim-color);cursor:pointer;padding:.25rem;border-radius:3px;transition:all .2s;flex-shrink:0}.logout-button{background:none;border:none;color:var(--dim-color);cursor:pointer;padding:.5rem;border-radius:4px;transition:all .2s;display:flex;align-items:center;justify-content:center}.logout-button:hover{color:var(--accent-color);background:#ffffff0d;transform:scale(1.05)}.logout-button:active{transform:scale(.95)}.milestone-close:hover{color:var(--fg-color);background:var(--dim-color)}@media (max-width: 768px){.chapter-panel,.settings-panel{width:100vw}.main-editor{padding:1rem}.progress-container{padding:.75rem 1rem}.milestone-notification{right:1rem}}.app{transition:all .3s ease}@media (prefers-contrast: high){.main-editor{border:1px solid var(--fg-color)}.status-bar{border-top:2px solid var(--fg-color)}}.loading-screen{height:100vh;width:100vw;display:flex;align-items:center;justify-content:center;background:var(--bg-color);color:var(--fg-color)}.loading-text{font-family:var(--font-family),"Courier New",monospace;font-size:1.2rem;animation:blink var(--blink-speed) infinite}.app-header{height:50px;background:var(--bg-color);border-bottom:1px solid var(--dim-color);display:flex;align-items:center;justify-content:center;position:relative;padding:0 1rem;font-size:.875rem}.app-header-left{position:absolute;left:1rem;display:flex;align-items:center;gap:.75rem}.app-header-center{display:flex;align-items:center;gap:.5rem}.app-header-right{position:absolute;right:1rem;display:flex;align-items:center;gap:.75rem}.save-indicator{color:var(--dim-color);font-size:.75rem}.current-project-name{color:var(--accent-color);font-weight:500;font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:300px}.export-button{background:none;border:none;color:var(--dim-color);cursor:pointer;padding:.5rem;border-radius:4px;transition:all .2s;display:flex;align-items:center;gap:.5rem;font-family:inherit;font-size:.75rem}.export-button:hover:not(:disabled){color:var(--accent-color);background:#ffffff0d;transform:scale(1.05)}.export-button:disabled{opacity:.5;cursor:not-allowed}.export-text{font-size:.75rem;white-space:nowrap}@media (max-width: 480px){.export-text{display:none}.export-button{gap:0;padding:.5rem .25rem}.current-project-name{max-width:200px}.app-header-left,.app-header-right{position:static}.app-header{justify-content:space-between}.app-header-center{flex:1;justify-content:center;margin:0 .5rem}}.saving{color:var(--accent-color);animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.projects-link{background:none;border:none;color:var(--accent-color);cursor:pointer;padding:.5rem 1rem;border-radius:4px;transition:all .2s;font-family:inherit;font-size:.875rem;font-weight:500;text-decoration:underline}.projects-link:hover{background:var(--dim-color);color:var(--fg-color);text-decoration:none}.project-selector{position:relative}.current-project{background:none;border:none;color:var(--fg-color);cursor:pointer;padding:.5rem 1rem;border-radius:4px;transition:all .2s;display:flex;align-items:center;gap:.5rem;font-family:inherit;font-size:.875rem}.current-project:hover{background:var(--dim-color)}.project-title{font-weight:500}.project-count{color:var(--dim-color);font-size:.75rem}.projects-dropdown{position:absolute;top:100%;left:0;width:300px;background:var(--bg-color);border:1px solid var(--dim-color);border-radius:6px;box-shadow:0 4px 12px #0000004d;z-index:1000;animation:fadeInUp .2s ease-out}.projects-header{padding:.75rem 1rem;border-bottom:1px solid var(--dim-color);display:flex;align-items:center;justify-content:space-between;font-weight:500;color:var(--accent-color)}.new-project-btn{background:none;border:1px solid var(--dim-color);color:var(--fg-color);cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:all .2s;display:flex;align-items:center;gap:.25rem;font-size:.75rem;font-family:inherit}.new-project-btn:hover{background:var(--accent-color);color:var(--bg-color)}.projects-list{max-height:300px;overflow-y:auto}.projects-loading,.projects-empty{padding:2rem 1rem;text-align:center;color:var(--dim-color);font-style:italic}.project-item{width:100%;background:none;border:none;color:var(--fg-color);padding:.75rem 1rem;text-align:left;cursor:pointer;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.1);transition:background .2s;font-family:inherit}.project-item:hover{background:var(--dim-color)}.project-item.active{background:var(--accent-color);color:var(--bg-color)}.project-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.project-name{font-weight:500}.project-date{font-size:.75rem;opacity:.7}.project-item:hover .project-actions{opacity:1}.project-action{background:none;border:none;color:inherit;cursor:pointer;padding:.25rem;border-radius:3px;transition:all .2s;display:flex;align-items:center}.project-action:hover{background:#ffffff1a}.project-edit-input{background:var(--bg-color);border:1px solid var(--accent-color);color:var(--fg-color);padding:.25rem .5rem;border-radius:3px;font-family:inherit;font-size:inherit;width:100%}.project-edit-input:focus{outline:none;box-shadow:0 0 0 2px rgba(var(--accent-color-rgb),.3)}.auth-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.auth-modal{background:var(--bg-color);border:1px solid var(--dim-color);border-radius:8px;width:100%;max-width:400px;margin:1rem;animation:slideInUp .3s ease-out}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-header{padding:1.5rem 1.5rem 0;display:flex;align-items:center;justify-content:space-between}.auth-title{color:var(--accent-color);font-size:1.25rem;font-weight:500;margin:0}.auth-close{background:none;border:none;color:var(--fg-color);cursor:pointer;padding:.5rem;border-radius:4px;transition:background .2s}.auth-close:hover{background:var(--dim-color)}.auth-form{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.auth-field{display:flex;flex-direction:column;gap:.5rem}.auth-label{display:flex;align-items:center;gap:.5rem;color:var(--accent-color);font-weight:500;font-size:.875rem}.auth-input{background:var(--bg-color);border:1px solid var(--dim-color);color:var(--fg-color);padding:.75rem;border-radius:4px;font-family:inherit;font-size:1rem;transition:border-color .2s}.auth-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px rgba(var(--accent-color-rgb),.2)}.auth-password-field{position:relative}.auth-password-toggle{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--dim-color);cursor:pointer;padding:.25rem;border-radius:3px;transition:color .2s}.auth-password-toggle:hover{color:var(--accent-color)}.auth-message{padding:.75rem;border-radius:4px;font-size:.875rem;text-align:center}.auth-message.error{background:#ff44441a;border:1px solid #ff4444;color:#f66}.auth-message.success{background:#22c55e1a;border:1px solid #22c55e;color:#4ade80}.auth-submit{background:var(--accent-color);border:none;color:var(--bg-color);padding:.75rem 1.5rem;border-radius:4px;font-family:inherit;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.auth-submit:hover:not(:disabled){background:var(--fg-color);transform:translateY(-1px);box-shadow:0 2px 4px #0003}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-switch{text-align:center;color:var(--dim-color);font-size:.875rem}.auth-switch-button{background:none;border:none;color:var(--accent-color);cursor:pointer;font-family:inherit;font-size:inherit;margin-left:.5rem;text-decoration:underline;transition:color .2s}.auth-switch-button:hover{color:var(--fg-color)}.auth-forgot-password{background:none;border:none;color:var(--dim-color);cursor:pointer;font-family:inherit;font-size:.875rem;text-align:center;width:100%;margin-top:.5rem;padding:.5rem;transition:color .2s}.auth-forgot-password:hover{color:var(--accent-color)}@media (max-width: 768px){.app-header{padding:0 .5rem}.projects-dropdown{width:280px}.auth-modal{margin:.5rem}}.landing-page{min-height:100vh;background:var(--bg-color);color:var(--fg-color);display:flex;flex-direction:column}.landing-hero{flex:1;display:flex;align-items:center;justify-content:center;padding:4rem 2rem;min-height:60vh}.hero-content{text-align:center;max-width:600px}.hero-icon{color:var(--accent-color);margin-bottom:2rem;animation:pulse 2s infinite}.hero-title{font-size:3.5rem;font-weight:500;color:var(--accent-color);margin:0 0 1rem;font-family:var(--font-family),"Courier New",monospace;text-shadow:0 0 20px rgba(var(--accent-color-rgb),.3)}.hero-subtitle{font-size:1.25rem;color:var(--fg-color);margin:0 0 3rem;line-height:1.6;opacity:.9}.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.hero-button{padding:1rem 2rem;border-radius:6px;font-family:var(--font-family),"Courier New",monospace;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;border:2px solid var(--accent-color);min-width:140px}.hero-button.primary{background:var(--accent-color);color:var(--bg-color)}.hero-button.primary:hover{background:var(--fg-color);border-color:var(--fg-color);transform:translateY(-2px);box-shadow:0 4px 12px rgba(var(--accent-color-rgb),.3)}.hero-button.secondary{background:transparent;color:var(--accent-color)}.hero-button.secondary:hover{background:var(--accent-color);color:var(--bg-color);transform:translateY(-2px);box-shadow:0 4px 12px rgba(var(--accent-color-rgb),.2)}.landing-features{padding:4rem 2rem;background:rgba(var(--accent-color-rgb),.02);border-top:1px solid var(--dim-color)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;max-width:1200px;margin:0 auto}.feature-card{background:var(--bg-color);border:1px solid var(--dim-color);border-radius:8px;padding:2rem;text-align:center;transition:all .3s ease}.feature-card:hover{border-color:var(--accent-color);transform:translateY(-4px);box-shadow:0 8px 24px #0003}.feature-icon{color:var(--accent-color);margin-bottom:1.5rem;opacity:.8}.feature-title{color:var(--accent-color);font-size:1.25rem;font-weight:500;margin:0 0 1rem;font-family:var(--font-family),"Courier New",monospace}.feature-description{color:var(--fg-color);line-height:1.6;margin:0;opacity:.9}.landing-footer{padding:2rem;text-align:center;border-top:1px solid var(--dim-color);color:var(--dim-color);font-style:italic}@media (max-width: 768px){.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.1rem}.hero-actions{flex-direction:column;align-items:center}.hero-button{width:100%;max-width:280px}.landing-hero,.landing-features{padding:2rem 1rem}.features-grid{grid-template-columns:1fr;gap:1.5rem}.feature-card{padding:1.5rem}}.projects-screen{height:100vh;width:100vw;background:var(--bg-color);color:var(--fg-color);display:flex;flex-direction:column;overflow:hidden}.projects-header{height:60px;border-bottom:1px solid var(--dim-color);display:flex;align-items:center;justify-content:space-between;padding:0 2rem;background:var(--bg-color)}.back-button{background:none;border:1px solid var(--dim-color);color:var(--fg-color);cursor:pointer;padding:.5rem 1rem;border-radius:4px;transition:all .2s;display:flex;align-items:center;gap:.5rem;font-family:inherit;font-size:.875rem}.back-button:hover{background:var(--dim-color);transform:translate(-2px)}.projects-title{display:flex;align-items:center;gap:.75rem;font-size:1.25rem;font-weight:500;color:var(--accent-color);margin:0}.projects-header-right{display:flex;align-items:center;gap:.75rem}.new-project-button{background:var(--accent-color);border:none;color:var(--bg-color);cursor:pointer;padding:.5rem 1rem;border-radius:4px;transition:all .2s;display:flex;align-items:center;gap:.5rem;font-family:inherit;font-size:.875rem;font-weight:500}.new-project-button:hover{background:var(--fg-color);transform:translateY(-1px);box-shadow:0 2px 4px #0003}.projects-content{flex:1;overflow-y:auto;padding:2rem}.projects-loading{display:flex;align-items:center;justify-content:center;height:200px}.loading-spinner{color:var(--accent-color);font-size:1.1rem;animation:pulse 1.5s infinite}.projects-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:400px;text-align:center;color:var(--dim-color)}.projects-empty svg{color:var(--dim-color);margin-bottom:1rem;opacity:.5}.projects-empty h2{color:var(--fg-color);margin:0 0 .5rem;font-size:1.5rem}.projects-empty p{margin:0 0 2rem;font-size:1rem}.create-first-project{background:var(--accent-color);border:none;color:var(--bg-color);cursor:pointer;padding:.75rem 1.5rem;border-radius:4px;transition:all .2s;display:flex;align-items:center;gap:.5rem;font-family:inherit;font-size:1rem;font-weight:500}.create-first-project:hover{background:var(--fg-color);transform:translateY(-1px);box-shadow:0 2px 8px #0003}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;max-width:1200px;margin:0 auto}.project-card{background:var(--bg-color);border:1px solid var(--dim-color);border-radius:6px;padding:1.5rem;transition:all .2s;display:flex;flex-direction:column;gap:1rem;min-height:240px}.project-card:hover{border-color:var(--accent-color);box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.project-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.project-name{color:var(--accent-color);font-size:1.1rem;font-weight:500;margin:0;flex:1;line-height:1.3}.project-actions{display:flex;gap:.25rem;opacity:0;transition:opacity .2s}.project-card:hover .project-actions{opacity:1}.project-action{background:none;border:none;color:var(--dim-color);cursor:pointer;padding:.25rem;border-radius:3px;transition:all .2s;display:flex;align-items:center}.project-action:hover{background:var(--dim-color);color:var(--fg-color)}.project-action.delete:hover{background:#f44;color:#fff}.project-stats{display:flex;align-items:center;gap:1rem;color:var(--dim-color);font-size:.875rem}.project-stat{display:flex;align-items:center;gap:.25rem}.stat-value{color:var(--accent-color);font-weight:500}.stat-label{color:var(--dim-color)}.project-preview{flex:1;color:var(--fg-color);font-size:.875rem;line-height:1.5;opacity:.8;overflow:hidden;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical}.project-open{background:none;border:1px solid var(--accent-color);color:var(--accent-color);cursor:pointer;padding:.5rem 1rem;border-radius:4px;transition:all .2s;font-family:inherit;font-size:.875rem;font-weight:500;align-self:flex-start}.project-open:hover{background:var(--accent-color);color:var(--bg-color);transform:translateY(-1px);box-shadow:0 2px 4px #0003}.project-edit{width:100%}.project-title-input{width:100%;background:var(--bg-color);border:1px solid var(--accent-color);color:var(--fg-color);padding:.5rem;border-radius:4px;font-family:inherit;font-size:1.1rem;font-weight:500}.project-title-input:focus{outline:none;box-shadow:0 0 0 2px rgba(var(--accent-color-rgb),.3)}.projects-footer{height:40px;border-top:1px solid var(--dim-color);display:flex;align-items:center;justify-content:center;padding:0 2rem;background:var(--bg-color)}.footer-time{color:var(--dim-color);font-size:.875rem;font-family:var(--font-family),"Courier New",monospace}.game-hud-mini-button{background:transparent;border:none;cursor:pointer;display:flex;align-items:center;gap:.5rem;font-size:.75rem;padding:.25rem .5rem;border-radius:4px;transition:all .2s ease;color:inherit;font-family:inherit}.game-hud-mini-button:hover{background:#ffffff1a;transform:scale(1.02)}.game-hud-mini-button:active{transform:scale(.98)}.level-badge{display:flex;align-items:center;gap:.25rem;color:var(--accent-color);font-weight:500}.xp-mini{display:flex;align-items:center;gap:.25rem}.xp-bar-mini{width:40px;height:4px;background:var(--dim-color);border-radius:2px;overflow:hidden}.xp-fill-mini{height:100%;background:var(--accent-color);transition:width .3s ease}.xp-text-mini{color:var(--dim-color);font-size:.7rem}.game-hud{background:var(--bg-color);border:1px solid var(--dim-color);border-radius:6px;padding:1rem;margin-bottom:1rem;display:flex;flex-direction:column;gap:.75rem}.hud-section{display:flex;align-items:center;justify-content:space-between;gap:1rem}.level-display{display:flex;align-items:center;gap:.5rem;color:var(--accent-color);font-weight:500}.xp-display{display:flex;align-items:center;gap:.5rem;flex:1}.xp-bar{flex:1;height:8px;background:var(--dim-color);border-radius:4px;overflow:hidden}.xp-fill{height:100%;background:var(--accent-color);transition:width .3s ease}.xp-text{color:var(--fg-color);font-size:.75rem;min-width:60px}.stat-item{display:flex;align-items:center;gap:.25rem;color:var(--dim-color);font-size:.75rem}.daily-challenge{background:#ffffff05;border:1px solid var(--dim-color);border-radius:4px;padding:.75rem}.challenge-header{display:flex;align-items:center;gap:.5rem;color:var(--accent-color);font-weight:500;margin-bottom:.5rem}.challenge-title{color:var(--fg-color);font-size:.875rem;margin-bottom:.5rem}.challenge-progress{display:flex;align-items:center;gap:.5rem}.challenge-bar{flex:1;height:6px;background:var(--dim-color);border-radius:3px;overflow:hidden}.challenge-fill{height:100%;background:var(--accent-color);transition:width .3s ease}.challenge-text{color:var(--dim-color);font-size:.75rem}.plot-decryption{background:#ffffff05;border:1px solid var(--dim-color);border-radius:4px;padding:.75rem}.decryption-header{margin-bottom:.5rem}.terminal-text{color:var(--accent-color);font-family:var(--font-family),"Courier New",monospace;font-size:.75rem;font-weight:500}.decryption-bar{height:6px;background:var(--dim-color);border-radius:3px;overflow:hidden;margin-bottom:.25rem}.decryption-fill{height:100%;background:var(--accent-color);transition:width .3s ease}.decryption-text{color:var(--dim-color);font-size:.75rem}.achievement-notification{position:fixed;top:2rem;right:2rem;left:2rem;background:var(--bg-color);border:2px solid var(--accent-color);border-radius:8px;padding:1rem;box-shadow:0 4px 12px #0000004d;z-index:2000;transform:translate(100%);opacity:0;transition:all .3s ease-out;max-width:none;width:auto}.achievement-notification.visible{transform:translate(0);opacity:1}.achievement-content{display:flex;align-items:flex-start;gap:.75rem}.achievement-icon{color:var(--accent-color);flex-shrink:0;animation:achievement-glow 2s ease-in-out infinite}@keyframes achievement-glow{0%,to{opacity:1}50%{opacity:.6}}.achievement-text{flex:1}.achievement-title{color:var(--accent-color);font-size:1rem;font-weight:500;margin:0 0 .5rem}.achievement-item{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.achievement-emoji{font-size:1.2rem}.achievement-name{color:var(--fg-color);font-weight:500;font-size:.875rem}.achievement-desc{color:var(--dim-color);font-size:.75rem}.achievement-close{background:none;border:none;color:var(--dim-color);cursor:pointer;padding:.25rem;border-radius:3px;transition:all .2s;flex-shrink:0}.achievement-close:hover{color:var(--fg-color);background:var(--dim-color)}.level-up-notification{position:fixed;top:50%;left:50%;right:1rem;transform:translate(-50%,-50%) scale(.8);background:var(--bg-color);border:3px solid var(--accent-color);border-radius:12px;padding:2rem;box-shadow:0 8px 24px #00000080;z-index:2500;opacity:0;transition:all .4s ease-out;text-align:center;width:calc(100vw - 2rem);max-width:400px}.level-up-notification.visible{transform:translate(-50%,-50%) scale(1);opacity:1}.level-up-content{position:relative}.level-up-icon{position:relative;color:var(--accent-color);margin-bottom:1rem;animation:level-up-pulse 2s ease-in-out infinite}@keyframes level-up-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.sparkle-1,.sparkle-2,.sparkle-3{position:absolute;color:var(--fg-color);animation:sparkle 1.5s ease-in-out infinite}.sparkle-1{top:-10px;right:-10px;animation-delay:0s}.sparkle-2{bottom:-5px;left:-15px;animation-delay:.5s}.sparkle-3{top:5px;left:-20px;animation-delay:1s}@keyframes sparkle{0%,to{opacity:0;transform:scale(.5)}50%{opacity:1;transform:scale(1)}}.level-up-title{color:var(--accent-color);font-size:1.5rem;font-weight:700;margin:0 0 .5rem;font-family:var(--font-family),"Courier New",monospace}.level-up-level{color:var(--fg-color);font-size:1.25rem;font-weight:500;margin-bottom:1rem}.level-up-reward{color:var(--dim-color);font-size:.875rem;font-style:italic}.badge-terminal{position:fixed;top:0;right:0;width:400px;height:100vh;background:var(--bg-color);border-left:1px solid var(--dim-color);display:flex;flex-direction:column;z-index:1000;animation:slideIn .2s ease-out}.badge-content{flex:1;overflow-y:auto;padding:1rem}.terminal-header{margin-bottom:1.5rem;font-family:var(--font-family),"Courier New",monospace}.terminal-line{color:var(--accent-color);font-size:.75rem;margin-bottom:.25rem}.terminal-divider{color:var(--dim-color);font-size:.75rem;margin:.5rem 0}.badge-section{margin-bottom:2rem}.section-title{display:flex;align-items:center;gap:.5rem;color:var(--accent-color);font-size:1rem;font-weight:500;margin-bottom:1rem;font-family:var(--font-family),"Courier New",monospace}.badge-grid{display:flex;flex-direction:column;gap:.75rem}.badge-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:6px;transition:all .2s}.badge-item.unlocked{background:#ffffff0d;border:1px solid var(--accent-color)}.badge-item.locked{background:#ffffff05;border:1px solid var(--dim-color);opacity:.6}.badge-icon{font-size:1.5rem;min-width:2rem;text-align:center}.badge-info{flex:1}.badge-name{color:var(--fg-color);font-weight:500;margin-bottom:.25rem}.badge-desc{color:var(--dim-color);font-size:.875rem;margin-bottom:.25rem}.badge-date,.badge-progress{color:var(--accent-color);font-size:.75rem;font-family:var(--font-family),"Courier New",monospace}.easter-egg-terminal{position:fixed;top:0;right:0;width:500px;height:100vh;height:100dvh;background:var(--bg-color);border-left:1px solid var(--dim-color);display:flex;flex-direction:column;z-index:1000;animation:slideIn .2s ease-out}.terminal-content{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.terminal-history{flex:1;overflow-y:auto;padding:1rem;font-family:var(--font-family),"Courier New",monospace;font-size:.875rem;line-height:1.4;min-height:0;-webkit-overflow-scrolling:touch}.terminal-line{margin-bottom:.5rem}.terminal-line.command .command-line{color:var(--accent-color);font-weight:500}.terminal-line.output .output-line{color:var(--fg-color);margin:0;white-space:pre-wrap;font-family:inherit}.terminal-line.error .output-line{color:#f66}.terminal-input-form{display:flex;align-items:center;padding:1rem;border-top:1px solid var(--dim-color);background:#ffffff05;flex-shrink:0}.terminal-prompt{color:var(--accent-color);font-family:var(--font-family),"Courier New",monospace;font-weight:500;margin-right:.5rem}.terminal-input{flex:1;background:transparent;border:none;color:var(--fg-color);font-family:var(--font-family),"Courier New",monospace;font-size:.875rem;outline:none;caret-color:var(--cursor-color)}.terminal-input::-moz-placeholder{color:var(--dim-color);opacity:.7}.terminal-input::placeholder{color:var(--dim-color);opacity:.7}@media (max-width: 768px){.projects-header{padding:0 1rem}.projects-content{padding:1rem}.projects-grid{grid-template-columns:1fr;gap:1rem}.project-card{padding:1rem}.projects-title{font-size:1.1rem}.back-button,.new-project-button{padding:.4rem .8rem;font-size:.8rem}.badge-terminal{width:100vw}.achievement-notification,.level-up-notification{right:.5rem;left:.5rem;top:1rem;transform:translate(0);width:auto;max-width:none}.achievement-notification.visible{transform:translate(0)}.level-up-notification{top:50%;left:50%;right:.5rem;transform:translate(-50%,-50%) scale(.8);width:calc(100vw - 1rem);max-width:none;padding:1.5rem}.level-up-notification.visible{transform:translate(-50%,-50%) scale(1)}.game-hud-mini{font-size:.7rem}.xp-bar-mini{width:30px}.easter-egg-terminal{width:100vw;height:100vh;height:100dvh}.terminal-input-form{padding:.75rem;position:sticky;bottom:0;background:var(--bg-color);border-top:2px solid var(--dim-color)}.terminal-history{padding:.75rem;padding-bottom:0}}
