@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;700&display=swap";:root{--term-bg: #0a0a0a;--term-bg-secondary: #111111;--term-green: #00ff41;--term-green-dim: #00cc33;--term-green-glow: rgba(0, 255, 65, .4);--term-amber: #ffb000;--term-amber-dim: #cc8800;--term-text: #00ff41;--term-text-dim: rgba(0, 255, 65, .6);--term-cursor: #00ff41;--term-border: #1a3a1a;--term-font: "JetBrains Mono", "Fira Code", "Consolas", monospace;--term-scanline-opacity: .03;--term-flicker-intensity: .02}.terminal-container{position:relative;display:flex;flex-direction:column;width:100%;max-width:900px;height:80vh;max-height:700px;margin:0 auto;background:var(--term-bg);border:2px solid var(--term-border);border-radius:8px;overflow:hidden;font-family:var(--term-font);box-shadow:0 0 40px #00ff411a,inset 0 0 100px #00000080}.terminal-container:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(transparent 50%,rgba(0,0,0,var(--term-scanline-opacity)) 50%);background-size:100% 4px;pointer-events:none;z-index:10}.terminal-container:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,255,65,var(--term-flicker-intensity));pointer-events:none;z-index:9;animation:flicker .15s infinite}@keyframes flicker{0%,to{opacity:1}50%{opacity:.98}25%,75%{opacity:.99}}.terminal-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--term-bg-secondary);border-bottom:1px solid var(--term-border)}.terminal-title{color:var(--term-text-dim);font-size:12px;letter-spacing:1px;text-transform:uppercase}.terminal-dots{display:flex;gap:8px}.terminal-dot{width:12px;height:12px;border-radius:50%;background:var(--term-green-dim);opacity:.6}.terminal-dot:first-child{background:#ff5f56}.terminal-dot:nth-child(2){background:#ffbd2e}.terminal-dot:last-child{background:#27ca40}.terminal-content{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.terminal-scroll-area{flex:1;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.terminal-scroll-area::-webkit-scrollbar{display:none}.terminal-messages{padding:0 20px 20px;display:flex;flex-direction:column;gap:16px}.terminal-message{display:flex;flex-direction:column;gap:4px}.message-prefix{font-size:11px;color:var(--term-text-dim);letter-spacing:.5px}.message-content{color:var(--term-text);font-size:14px;line-height:1.6;padding-left:4px;text-shadow:0 0 8px var(--term-green-glow);white-space:pre-wrap;word-break:break-word;overflow-wrap:anywhere}.message-user .message-prefix{color:var(--term-amber-dim)}.message-user .message-content{color:var(--term-amber);text-shadow:0 0 8px rgba(255,176,0,.4)}.typing-indicator{display:inline-flex;align-items:center;gap:4px;padding:4px 0}.typing-dot{width:6px;height:6px;background:var(--term-green);border-radius:50%;animation:typingPulse 1.4s ease-in-out infinite}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typingPulse{0%,60%,to{transform:scale(1);opacity:.4}30%{transform:scale(1.2);opacity:1}}.terminal-input-area{display:flex;align-items:center;padding:16px 20px;background:var(--term-bg-secondary);border-top:1px solid var(--term-border);gap:8px}.input-prompt{color:var(--term-green);font-size:14px;white-space:nowrap;text-shadow:0 0 8px var(--term-green-glow)}.terminal-input{flex:1;background:transparent;border:none;outline:none;color:var(--term-text);font-family:var(--term-font);font-size:14px;caret-color:var(--term-cursor);text-shadow:0 0 8px var(--term-green-glow)}.terminal-input::placeholder{color:var(--term-text-dim);opacity:.5}.terminal-input:focus{outline:none!important;border:none!important;box-shadow:none!important}.starter-prompts{display:flex;flex-direction:column;gap:10px;margin-top:28px;align-items:flex-start}.starter-prompt{background:transparent;border:1px solid var(--term-border);color:var(--term-text-dim);font-family:var(--term-font);font-size:13px;padding:10px 18px;border-radius:4px;cursor:pointer;transition:all .2s ease;text-align:left;width:100%;max-width:340px;opacity:0;animation:bootFadeIn .4s ease-out forwards}.starter-prompt:hover{border-color:var(--term-green);color:var(--term-green);background:#00ff410d;box-shadow:0 0 15px #00ff4126;transform:translate(4px)}.starter-prompt:active{transform:translate(4px) scale(.98)}.prompt-arrow{color:var(--term-green);margin-right:8px;opacity:.6;transition:opacity .2s ease}.starter-prompt:hover .prompt-arrow{opacity:1}.boot-text{animation:bootFadeIn .5s ease-out forwards;opacity:0}@keyframes bootFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.terminal-container{height:90vh;max-height:none;border-radius:4px}.terminal-header{padding:10px 14px}.terminal-messages{padding:16px}.message-content{font-size:13px}.message-prefix{font-size:10px}.input-prompt{font-size:12px}.terminal-input{font-size:13px}.terminal-input-area{padding:14px 16px}.starter-prompt{min-height:44px;display:flex;align-items:center;max-width:100%}}@media (max-width: 480px){.terminal-container{height:calc(100vh - 16px);height:calc(100dvh - 16px);border-radius:4px;padding-left:env(safe-area-inset-left,0px);padding-right:env(safe-area-inset-right,0px)}.terminal-header{padding:8px 12px}.terminal-title{font-size:10px}.terminal-dot{width:10px;height:10px}.terminal-messages{padding:12px;gap:12px;overflow-y:auto}.starter-prompts{margin-top:16px;gap:8px}.starter-prompt{font-size:13px;padding:12px 14px;min-height:44px}.message-content{font-size:13px;line-height:1.5}.message-prefix{font-size:10px}.terminal-input-area{padding:12px;gap:6px}.input-prompt{font-size:12px}.terminal-input{font-size:16px}}@media (prefers-reduced-motion: reduce){.terminal-container:after,.typing-dot,.terminal-input:focus{animation:none}.boot-text,.starter-prompt{animation:none;opacity:1;transform:none}}@media (max-width: 768px){.terminal-input-area.keyboard-open{position:fixed;bottom:0;left:0;right:0;z-index:1001;border-radius:0;border-left:none;border-right:none;border-bottom:none;box-shadow:0 -4px 20px #00000080;padding-bottom:calc(12px + env(safe-area-inset-bottom,0px))}.terminal-container.keyboard-open{overflow:hidden}.terminal-container.keyboard-open .terminal-messages{padding-bottom:70px}}.boot-welcome-container{padding:20px;display:flex;flex-direction:column;animation:bootShake .4s ease-out}.boot-welcome-container.ready{animation:none}@keyframes bootShake{0%{transform:translate(-2px) translateY(1px)}10%{transform:translate(2px) translateY(-1px)}20%{transform:translate(-1px) translateY(2px)}30%{transform:translate(1px) translateY(-1px)}40%{transform:translate(-1px) translateY(1px)}50%{transform:translate(1px) translateY(-1px)}60%,to{transform:translate(0) translateY(0)}}.boot-text-wrapper{transition:opacity .5s ease-out,max-height .5s ease-out;overflow:hidden}.boot-text-wrapper.fading-out{opacity:0;max-height:0;margin-bottom:0}.boot-section{margin-bottom:16px}.boot-line{color:var(--term-green);font-size:14px;line-height:1.6;text-shadow:0 0 8px var(--term-green-glow);animation:bootLineAppear .1s ease-out;white-space:pre}@keyframes bootLineAppear{0%{opacity:0;transform:translate(-4px)}to{opacity:1;transform:translate(0)}}.boot-highlight{color:var(--term-amber);text-shadow:0 0 8px rgba(255,176,0,.4)}.boot-logo-section{margin-bottom:24px}.boot-logo{color:var(--term-green-dim);font-size:10px;line-height:1.2;text-shadow:0 0 10px var(--term-green-glow);margin:0}.boot-welcome-container.logo .boot-logo{animation:bootLogoGlow 1s ease-in-out}@keyframes bootLogoGlow{0%{text-shadow:0 0 5px rgba(0,255,65,.3);opacity:.8}50%{text-shadow:0 0 20px rgba(0,255,65,.6);opacity:1}to{text-shadow:0 0 10px var(--term-green-glow);opacity:1}}.welcome-content{margin-top:8px}.welcome-text-boot{margin-bottom:16px}.welcome-text-boot .boot-line{line-height:1.8;white-space:pre-wrap;word-break:break-word}.boot-cursor{color:var(--term-green);font-size:14px;animation:bootCursorBlink .7s step-end infinite;text-shadow:0 0 8px var(--term-green-glow);margin-left:4px}@keyframes bootCursorBlink{0%,to{opacity:1}50%{opacity:0}}@media (max-width: 768px){.boot-welcome-container{padding:16px}.boot-line{font-size:13px}.boot-logo{font-size:7px}}@media (max-width: 480px){.boot-welcome-container{padding:12px}.boot-line{font-size:13px}.boot-logo{font-size:6px;overflow-x:auto}}@media (prefers-reduced-motion: reduce){.boot-welcome-container,.boot-line,.boot-cursor,.boot-logo,.welcome-content{animation:none}.boot-line,.welcome-content{opacity:1;transform:none}}.voice-mode-toggle{padding:4px 10px;background:transparent;border:1px solid var(--term-border);border-radius:3px;color:var(--term-text-dim);font-family:var(--term-font);font-size:10px;letter-spacing:1px;cursor:pointer;transition:all .2s ease}.voice-mode-toggle:hover{border-color:var(--term-green);color:var(--term-green)}.voice-mode-container{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.voice-mode-visualizer{flex:1;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}.voice-mode-canvas{position:absolute;top:0;left:0;width:100%;height:100%}.voice-mode-status{position:absolute;bottom:24px;left:50%;transform:translate(-50%);z-index:5;display:flex;align-items:center;gap:8px}.status-dot{width:6px;height:6px;border-radius:50%;background:var(--term-green-dim);opacity:.6}.status-dot.processing,.status-dot.synthesizing{background:var(--term-amber);opacity:1}.status-dot.transmitting{background:var(--term-green);opacity:1;animation:statusBlink .5s ease-in-out infinite}.status-dot.error{background:#ff5f56;opacity:1}.status-dot.idle{opacity:.4}@keyframes statusBlink{0%,to{opacity:1}50%{opacity:.4}}.status-text{color:var(--term-text-dim);font-family:var(--term-font);font-size:10px;letter-spacing:1px;text-transform:uppercase;opacity:.6}.voice-mode-hint{position:absolute;top:20px;left:50%;transform:translate(-50%);z-index:5;display:flex;align-items:center;gap:6px;padding:6px 12px;background:#0009;border:1px solid var(--term-border);border-radius:4px;opacity:.7}.hint-icon{width:12px;height:12px;color:var(--term-green-dim);filter:drop-shadow(0 0 3px var(--term-green-glow))}.hint-text{color:var(--term-text-dim);font-family:var(--term-font);font-size:9px;letter-spacing:.5px;text-transform:lowercase}@media (max-width: 768px){.voice-mode-toggle{padding:3px 8px;font-size:9px}.voice-mode-status{bottom:20px}.status-text{font-size:9px}}@media (max-width: 480px){.voice-mode-toggle{padding:3px 6px;font-size:8px}.voice-mode-status{bottom:16px}.status-dot{width:5px;height:5px}.status-text{font-size:8px}.voice-mode-hint{top:16px;padding:5px 10px}.hint-icon{width:10px;height:10px}.hint-text{font-size:8px}}@media (prefers-reduced-motion: reduce){.status-dot{animation:none;opacity:1}}.terminal-container.game-mode{padding:0}.breakout-container{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden;background:var(--term-bg)}.breakout-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--term-bg-secondary);border-bottom:1px solid var(--term-border)}.breakout-score{display:flex;align-items:center;gap:8px}.score-label{color:var(--term-text-dim);font-family:var(--term-font);font-size:12px;letter-spacing:1px}.score-value{color:var(--term-green);font-family:var(--term-font);font-size:14px;font-weight:700;text-shadow:0 0 8px var(--term-green-glow);min-width:60px}.breakout-exit{padding:4px 10px;background:transparent;border:1px solid var(--term-border);border-radius:3px;color:var(--term-text-dim);font-family:var(--term-font);font-size:10px;letter-spacing:1px;cursor:pointer;transition:all .2s ease}.breakout-exit:hover{border-color:#ff5f56;color:#ff5f56}.breakout-canvas-wrapper{flex:1;position:relative;overflow:hidden}.breakout-canvas{position:absolute;top:0;left:0;width:100%;height:100%;touch-action:none}.breakout-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#0a0a0ae6;z-index:10;gap:16px;padding:20px;text-align:center}.overlay-title{color:var(--term-green);font-family:var(--term-font);font-size:32px;font-weight:700;letter-spacing:4px;text-shadow:0 0 20px var(--term-green-glow);animation:titleGlow 2s ease-in-out infinite}@keyframes titleGlow{0%,to{text-shadow:0 0 20px var(--term-green-glow)}50%{text-shadow:0 0 40px var(--term-green-glow),0 0 60px var(--term-green-glow)}}.breakout-overlay.won .overlay-title{color:var(--term-amber);text-shadow:0 0 20px rgba(255,176,0,.6);animation:winGlow 1s ease-in-out infinite}@keyframes winGlow{0%,to{text-shadow:0 0 20px rgba(255,176,0,.6)}50%{text-shadow:0 0 40px rgba(255,176,0,.8),0 0 60px rgba(255,176,0,.6)}}.breakout-overlay.lost .overlay-title{color:#ff5f56;text-shadow:0 0 20px rgba(255,95,86,.6)}.overlay-subtitle{color:var(--term-text-dim);font-family:var(--term-font);font-size:14px;letter-spacing:1px}.overlay-score{color:var(--term-green);font-family:var(--term-font);font-size:18px;font-weight:700;text-shadow:0 0 10px var(--term-green-glow)}.overlay-button{margin-top:16px;padding:12px 32px;background:transparent;border:2px solid var(--term-green);border-radius:4px;color:var(--term-green);font-family:var(--term-font);font-size:14px;letter-spacing:2px;cursor:pointer;transition:all .2s ease;text-shadow:0 0 8px var(--term-green-glow)}.overlay-button:hover{background:#00ff411a;box-shadow:0 0 20px var(--term-green-glow);transform:scale(1.05)}.overlay-button:active{transform:scale(.98)}.overlay-controls{color:var(--term-text-dim);font-family:var(--term-font);font-size:11px;letter-spacing:1px;opacity:.7;margin-top:8px}.breakout-touch-hint{position:absolute;bottom:16px;left:50%;transform:translate(-50%);color:var(--term-text-dim);font-family:var(--term-font);font-size:10px;letter-spacing:.5px;opacity:.5;z-index:5}@media (max-width: 768px){.breakout-header{padding:10px 14px}.score-label{font-size:10px}.score-value{font-size:12px}.breakout-exit{font-size:9px;padding:3px 8px}.overlay-title{font-size:24px;letter-spacing:2px}.overlay-subtitle{font-size:12px}.overlay-button{padding:10px 24px;font-size:12px}}@media (max-width: 480px){.breakout-header{padding:8px 12px}.overlay-title{font-size:20px}.overlay-subtitle{font-size:11px}.overlay-button{padding:10px 20px;font-size:11px}.overlay-controls{font-size:10px}}@media (prefers-reduced-motion: reduce){.overlay-title,.breakout-overlay.won .overlay-title{animation:none}}.terminal-container.portrait-mode{padding:0}.portrait-container{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden;background:var(--term-bg)}.portrait-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--term-bg-secondary);border-bottom:1px solid var(--term-border)}.portrait-label{color:var(--term-text-dim);font-family:var(--term-font);font-size:12px;letter-spacing:1px}.portrait-exit{padding:4px 10px;background:transparent;border:1px solid var(--term-border);border-radius:3px;color:var(--term-text-dim);font-family:var(--term-font);font-size:10px;letter-spacing:1px;cursor:pointer;transition:all .2s ease}.portrait-exit:hover{border-color:#ff5f56;color:#ff5f56}.portrait-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;overflow:hidden}.portrait-ascii{display:flex;flex-direction:column;align-items:center;font-family:var(--term-font);font-size:12px;line-height:1.15;white-space:pre}.portrait-line{color:var(--term-green);text-shadow:0 0 10px var(--term-green-glow);animation:portraitLineAppear .15s ease-out forwards;opacity:0}@keyframes portraitLineAppear{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.portrait-footer{display:flex;flex-direction:column;align-items:center;width:100%;max-width:500px;margin-top:24px;animation:portraitFadeIn .5s ease-out forwards;opacity:0}@keyframes portraitFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.portrait-signature{color:var(--term-green-dim);font-family:var(--term-font);font-size:11px;font-style:italic;letter-spacing:1px;text-shadow:0 0 8px var(--term-green-glow);align-self:flex-end;margin-bottom:16px}.portrait-hint{color:var(--term-text-dim);font-family:var(--term-font);font-size:11px;letter-spacing:1px;opacity:.6}@media (max-width: 768px){.portrait-header{padding:10px 14px}.portrait-label{font-size:10px}.portrait-exit{font-size:9px;padding:3px 8px}.portrait-ascii,.portrait-hint{font-size:10px}}@media (max-width: 480px){.portrait-header{padding:8px 12px}.portrait-label{font-size:9px}.portrait-ascii{font-size:7px;line-height:1.1}.portrait-content{padding:12px}.portrait-footer{margin-top:16px}.portrait-hint{font-size:9px}}@media (max-width: 360px){.portrait-ascii{font-size:5.5px}}@media (prefers-reduced-motion: reduce){.portrait-line,.portrait-footer{animation:none;opacity:1;transform:none}}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;overflow:hidden}body{font-family:JetBrains Mono,Fira Code,Consolas,monospace;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#050505;color:#00ff41}body:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none;background:radial-gradient(ellipse at center,transparent 0%,transparent 60%,rgba(0,0,0,.4) 100%);z-index:999}#root{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;position:relative}#root:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background-image:linear-gradient(rgba(0,255,65,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,255,65,.03) 1px,transparent 1px);background-size:20px 20px;pointer-events:none;z-index:-1}.app{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px}.app-footer{position:fixed;bottom:20px;left:50%;transform:translate(-50%);color:#00ff414d;font-size:11px;letter-spacing:1px;text-transform:uppercase;z-index:10}::selection{background:#00ff414d;color:#00ff41}:focus-visible{outline:1px solid rgba(0,255,65,.5);outline-offset:2px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#0a0a0a}::-webkit-scrollbar-thumb{background:#0c3;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#00ff41}@media (max-width: 768px){#root{padding:12px}.app-footer{bottom:12px;font-size:10px;letter-spacing:.5px}}@media (max-width: 480px){#root{padding:8px}.app-footer{display:none}}
