@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600&family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,600;1,9..144,300&display=swap";:root{--color-bg-deep: #0a0e14;--color-bg-elevated: #121820;--color-bg-card: #1a2129;--color-terminal-green: #7fdbca;--color-terminal-amber: #ffcc66;--color-terminal-red: #f07178;--color-terminal-blue: #6dcbfa;--color-text-primary: #d9d9d9;--color-text-secondary: #7a818a;--color-text-dim: #4a5159;--font-mono: "JetBrains Mono", "Courier New", monospace;--font-serif: "Fraunces", "Georgia", serif;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--ease-elastic: cubic-bezier(.68, -.55, .265, 1.55);--ease-smooth: cubic-bezier(.4, 0, .2, 1);--duration-fast: .15s;--duration-base: .3s;--duration-slow: .5s}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%;overflow:hidden}body{font-family:var(--font-mono);font-size:14px;line-height:1.6;color:var(--color-text-primary);background:var(--color-bg-deep);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;position:relative}body:before{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='2.5' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)' opacity='0.03'/%3E%3C/svg%3E");pointer-events:none;opacity:.5;z-index:9999}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--color-bg-elevated)}::-webkit-scrollbar-thumb{background:var(--color-text-dim);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}::selection{background:var(--color-terminal-green);color:var(--color-bg-deep)}*:focus-visible{outline:2px solid var(--color-terminal-green);outline-offset:2px}.text-mono{font-family:var(--font-mono)}.text-serif{font-family:var(--font-serif)}.glow-green{text-shadow:0 0 8px rgba(127,219,202,.6),0 0 16px rgba(127,219,202,.3)}.glow-amber{text-shadow:0 0 8px rgba(255,204,102,.6),0 0 16px rgba(255,204,102,.3)}.voice-orb-container{display:flex;flex-direction:column;align-items:center;gap:var(--space-lg);position:relative}.voice-orb{position:relative;width:200px;height:200px;border:none;background:transparent;cursor:pointer;padding:0;outline:none}.voice-orb:disabled{cursor:not-allowed;opacity:.5}.orb-ring{position:absolute;inset:0;border-radius:50%;pointer-events:none}.orb-core{position:absolute;inset:20px;border-radius:50%;transition:all var(--duration-base) var(--ease-smooth)}.orb-icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--color-bg-deep);pointer-events:none}.orb-label{font-size:1.25rem;font-weight:300;font-style:italic;letter-spacing:.02em;color:var(--color-text-secondary);text-align:center}@keyframes breathe{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.voice-orb:not(:disabled):hover .orb-core{animation:breathe 3s ease-in-out infinite}.chat-message{display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-md);margin-bottom:var(--space-md);border-radius:8px;background:var(--color-bg-card);border-left:3px solid var(--color-terminal-green);position:relative;overflow:hidden}.chat-message.user{border-left-color:var(--color-terminal-blue);background:var(--color-bg-elevated)}.chat-message.assistant{border-left-color:var(--color-terminal-green)}.chat-message:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,currentColor 50%,transparent);opacity:.1}.message-header{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.message-role{font-weight:600;letter-spacing:.05em;text-transform:uppercase}.chat-message.user .message-role{color:var(--color-terminal-blue)}.chat-message.assistant .message-role{color:var(--color-terminal-green)}.message-time{font-size:.7rem;opacity:.6}.message-content{color:var(--color-text-primary);line-height:1.7}.message-content.typing{min-height:24px}.message-content p{margin:0;font-size:.95rem;font-weight:300;letter-spacing:.01em}.message-image{margin-bottom:var(--space-sm);border-radius:8px;overflow:hidden;border:1px solid rgba(127,219,202,.2);background:var(--color-bg-deep)}.message-image img{width:100%;height:auto;display:block;max-height:400px;object-fit:contain}.image-filename{display:block;padding:var(--space-xs) var(--space-sm);font-size:.7rem;color:var(--color-text-secondary);background:#7fdbca0d;border-top:1px solid rgba(127,219,202,.1)}.typing-indicator{display:flex;gap:4px;font-size:1.5rem;color:var(--color-terminal-green);font-weight:700;height:24px;align-items:center}.chat-message:hover{background:var(--color-bg-elevated);transform:translate(2px);transition:all var(--duration-fast) var(--ease-smooth)}.chat-message.user:hover{background:var(--color-bg-card)}.chat-history{flex:1;overflow-y:auto;padding:var(--space-lg);display:flex;flex-direction:column}.messages-list{display:flex;flex-direction:column}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);opacity:.6;padding:var(--space-2xl)}.empty-icon{font-size:4rem;font-weight:600;line-height:1;margin-bottom:var(--space-md)}.empty-text{font-size:1.5rem;font-weight:300;font-style:italic;color:var(--color-text-secondary);margin:0}.empty-hint{font-size:.875rem;color:var(--color-text-dim);font-family:var(--font-mono);margin:0;letter-spacing:.02em}.image-upload{display:flex;align-items:center;gap:.5rem}.image-upload__btn{background:var(--color-bg-elevated);border:1px solid rgba(127,219,202,.2);color:var(--color-text-secondary);width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;padding:0}.image-upload__btn:hover:not(:disabled){background:#7fdbca1a;border-color:var(--color-terminal-green);color:var(--color-terminal-green);transform:translateY(-1px)}.image-upload__btn:active:not(:disabled){transform:translateY(0)}.image-upload__btn:disabled{opacity:.4;cursor:not-allowed}.image-upload__btn svg{width:20px;height:20px}.image-upload__processing{font-family:var(--font-mono);font-size:.75rem;color:var(--color-terminal-amber);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.text-input-container{padding:var(--space-lg);background:var(--color-bg-elevated);border-top:1px solid var(--color-text-dim)}.input-wrapper{display:flex;align-items:center;gap:var(--space-md);background:var(--color-bg-card);border:1px solid var(--color-text-dim);border-radius:8px;padding:var(--space-sm) var(--space-md);transition:all var(--duration-fast) var(--ease-smooth)}.input-wrapper:focus-within{border-color:var(--color-terminal-green);box-shadow:0 0 0 2px #7fdbca1a}.input-prompt{font-weight:600;font-size:1.1rem;flex-shrink:0}.text-input{flex:1;background:transparent;border:none;outline:none;color:var(--color-text-primary);font-size:.95rem;padding:var(--space-sm) 0;font-family:var(--font-mono)}.text-input::placeholder{color:var(--color-text-dim);font-style:italic}.text-input:disabled{opacity:.5;cursor:not-allowed}.send-button{background:var(--color-terminal-green);color:var(--color-bg-deep);border:none;border-radius:6px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all var(--duration-fast) var(--ease-smooth)}.send-button:hover:not(:disabled){background:var(--color-terminal-amber);box-shadow:0 0 12px #7fdbca66}.send-button:disabled{opacity:.3;cursor:not-allowed}.send-button svg{transform:rotate(0);transition:transform var(--duration-base) var(--ease-elastic)}.send-button:hover:not(:disabled) svg{transform:rotate(15deg)}.clear-image-button{background:#f0717833;border:1px solid var(--color-terminal-red);color:var(--color-terminal-red);width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.9rem;font-weight:600;flex-shrink:0;transition:all var(--duration-fast) var(--ease-smooth)}.clear-image-button:hover{background:var(--color-terminal-red);color:var(--color-bg-deep);transform:scale(1.1)}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-lg);background:var(--color-bg-deep)}.login-container{width:100%;max-width:480px;background:var(--color-bg-card);border-radius:12px;border:1px solid rgba(127,219,202,.2);overflow:hidden;box-shadow:0 8px 32px #0006,0 0 0 1px #7fdbca1a}.login-header{background:var(--color-bg-elevated);border-bottom:1px solid rgba(127,219,202,.15)}.terminal-bar{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md)}.terminal-dots{display:flex;gap:6px}.terminal-dots .dot{width:12px;height:12px;border-radius:50%;opacity:.8}.terminal-dots .dot.red{background:var(--color-terminal-red)}.terminal-dots .dot.yellow{background:var(--color-terminal-yellow)}.terminal-dots .dot.green{background:var(--color-terminal-green)}.terminal-title{font-size:.75rem;color:var(--color-text-secondary);letter-spacing:.05em}.login-content{padding:var(--space-xl) var(--space-lg)}.login-logo{text-align:center;margin-bottom:var(--space-xl)}.login-logo h1{font-size:2.5rem;font-weight:600;letter-spacing:.02em;margin:0 0 var(--space-sm) 0}.prompt-symbol{font-weight:700;margin-right:.3em}.login-subtitle{font-size:.9rem;color:var(--color-text-secondary);margin:0;font-weight:300}.login-form{display:flex;flex-direction:column;gap:var(--space-lg)}.form-group{display:flex;flex-direction:column;gap:var(--space-xs)}.form-label{font-size:.75rem;color:var(--color-text-secondary);letter-spacing:.05em;text-transform:lowercase}.form-input{width:100%;padding:var(--space-sm) var(--space-md);background:var(--color-bg-deep);border:1px solid rgba(127,219,202,.2);border-radius:6px;color:var(--color-text-primary);font-size:.95rem;letter-spacing:.02em;transition:all var(--duration-fast) var(--ease-smooth)}.form-input:focus{outline:none;border-color:var(--color-terminal-green);box-shadow:0 0 0 3px #7fdbca1a}.form-input:disabled{opacity:.5;cursor:not-allowed}.error-message{padding:var(--space-sm) var(--space-md);background:#f071781a;border:1px solid var(--color-terminal-red);border-radius:6px;color:var(--color-terminal-red);font-size:.85rem;display:flex;align-items:center;gap:var(--space-xs)}.error-icon{font-weight:700}.login-button{width:100%;padding:var(--space-md) var(--space-lg);background:linear-gradient(135deg,#7fdbca33,#7fdbca1a);border:1px solid var(--color-terminal-green);border-radius:8px;color:var(--color-terminal-green);font-size:1rem;font-weight:600;letter-spacing:.05em;cursor:pointer;transition:all var(--duration-base) var(--ease-smooth);position:relative;overflow:hidden}.login-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(127,219,202,.2),transparent);transition:left var(--duration-slow) var(--ease-smooth)}.login-button:hover:not(:disabled):before{left:100%}.login-button:hover:not(:disabled){background:linear-gradient(135deg,#7fdbca4d,#7fdbca33);box-shadow:0 0 20px #7fdbca4d}.login-button:disabled{opacity:.5;cursor:not-allowed}.button-prompt{margin-right:.3em}.loading-text{display:flex;align-items:center;justify-content:center;gap:.2em}.loading-dots{display:flex;gap:.1em}.login-footer{margin-top:var(--space-xl);text-align:center}.footer-text{font-size:.7rem;color:var(--color-text-secondary);letter-spacing:.05em;margin:0}@media(max-width:640px){.login-screen{padding:var(--space-md)}.login-content{padding:var(--space-lg) var(--space-md)}.login-logo h1{font-size:2rem}}.app{width:100%;height:100%;display:flex;flex-direction:column;background:var(--color-bg-deep);position:relative}.app-header{flex-shrink:0;padding:var(--space-lg) var(--space-xl);background:var(--color-bg-elevated);border-bottom:1px solid var(--color-text-dim);position:relative}.app-header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--color-terminal-green) 50%,transparent);opacity:.2}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto}.app-title{font-size:1.5rem;font-weight:600;letter-spacing:.05em;margin:0;display:flex;align-items:center;gap:var(--space-sm)}.title-prompt{font-size:1.8rem}.header-status{display:flex;align-items:center;gap:var(--space-sm);font-size:.875rem;color:var(--color-text-secondary)}.status-dot{width:8px;height:8px;border-radius:50%}.status-dot.connected{background:var(--color-terminal-green);box-shadow:0 0 8px var(--color-terminal-green)}.status-dot.disconnected{background:var(--color-terminal-red);box-shadow:0 0 8px var(--color-terminal-red)}.app-content{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative}.voice-section{position:absolute;bottom:var(--space-2xl);left:50%;transform:translate(-50%);z-index:10}.app-bottom{flex-shrink:0;display:flex;flex-direction:column;gap:var(--space-md)}.mode-toggle{background:var(--color-bg-card);border:1px solid var(--color-text-dim);color:var(--color-text-primary);padding:var(--space-sm) var(--space-lg);margin:0 var(--space-lg) var(--space-lg);border-radius:8px;font-size:.875rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);transition:all var(--duration-fast) var(--ease-smooth)}.mode-toggle:hover{background:var(--color-bg-elevated);border-color:var(--color-terminal-green)}.mode-icon{font-size:1.2rem}.mode-label{letter-spacing:.05em}@media(max-width:768px){.app-header{padding:var(--space-md) var(--space-lg)}.app-title{font-size:1.25rem}.voice-section{bottom:var(--space-xl)}}.app:before{content:"";position:fixed;inset:0;background:radial-gradient(circle at 50% 30%,rgba(127,219,202,.03),transparent 50%);pointer-events:none}
