*{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#0a0a0a;--bg-secondary:#111;--bg-tertiary:#1a1a1a;--border-color:#222;--text-primary:#e0e0e0;--text-secondary:#888;--accent:#2563eb;--accent-hover:#1d4ed8;--error:#ef4444;--success:#22c55e}body{background:var(--bg-primary);color:var(--text-primary);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.loading-screen{flex-direction:column;justify-content:center;align-items:center;gap:1rem;height:100vh;display:flex}.loading-spinner{border:3px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.landing-page{flex-direction:column;min-height:100vh;display:flex}.landing-hero{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:4rem 2rem;display:flex}.landing-hero h1{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:1rem;font-size:3rem;font-weight:600}.landing-tagline{color:var(--text-secondary);max-width:500px;margin-bottom:2rem;font-size:1.25rem}.local-mode-badge{background:var(--accent);color:#fff;border-radius:20px;margin-bottom:1.5rem;padding:.5rem 1rem;font-size:.875rem}.landing-cta{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:1rem 2.5rem;font-size:1.125rem;transition:all .2s}.landing-cta:hover{background:var(--accent-hover);transform:translateY(-2px)}.landing-features{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;max-width:1000px;margin:0 auto;padding:4rem 2rem;display:grid}.feature{background:var(--bg-secondary);border:1px solid var(--border-color);text-align:center;border-radius:12px;padding:2rem}.feature h3{margin-bottom:.5rem;font-size:1.25rem}.feature p{color:var(--text-secondary)}.auth-page{justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.auth-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;width:100%;max-width:400px;padding:2.5rem}.auth-card h1{text-align:center;margin-bottom:.5rem;font-size:1.75rem}.auth-subtitle{color:var(--text-secondary);text-align:center;margin-bottom:2rem}.form-group label{color:var(--text-secondary);font-size:.875rem}.form-group input{border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);border-radius:6px;padding:.75rem 1rem;font-size:1rem}.form-group input:focus{border-color:var(--accent);outline:none}.error-message{border:1px solid var(--error);color:var(--error);background:#ef44441a;border-radius:6px;padding:.75rem;font-size:.875rem}.auth-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;margin-top:.5rem;padding:.875rem;font-size:1rem;transition:background .2s}.auth-btn:hover:not(:disabled){background:var(--accent-hover)}.auth-btn:disabled{cursor:not-allowed;background:#333}.auth-footer{text-align:center;color:var(--text-secondary);margin-top:1.5rem}.auth-link{color:var(--accent);cursor:pointer}.auth-link:hover{text-decoration:underline}.chat-page{flex-direction:column;height:100vh;display:flex}.chat-header{border-bottom:1px solid var(--border-color);background:var(--bg-secondary);justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex}.chat-header h1{font-size:1.25rem;font-weight:500}.chat-header-right{align-items:center;gap:1rem;display:flex}.server-status{background:var(--bg-tertiary);border-radius:12px;padding:.25rem .75rem;font-size:.875rem}.server-status.online{color:var(--success)}.server-status.offline{color:var(--error)}.local-badge{background:var(--accent);color:#fff;border-radius:12px;padding:.25rem .75rem;font-size:.75rem}.logout-btn{border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:6px;padding:.375rem .75rem;font-size:.875rem}.logout-btn:hover{border-color:var(--error);color:var(--error)}.chat-messages{flex-direction:column;flex:1;gap:.75rem;padding:1rem;display:flex;overflow-y:auto}.message{border-radius:12px;max-width:75%;padding:.75rem 1rem;line-height:1.5}.message.user{background:var(--accent);color:#fff;border-bottom-right-radius:4px;align-self:flex-end}.message.assistant{background:var(--bg-secondary);border:1px solid var(--border-color);border-bottom-left-radius:4px;align-self:flex-start}.message.typing{color:var(--text-secondary);font-style:italic}.chat-input-container{border-top:1px solid var(--border-color);background:var(--bg-secondary);gap:.5rem;padding:1rem;display:flex}.chat-input{border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);border-radius:8px;flex:1;padding:.75rem 1rem;font-size:1rem}.chat-input:focus{border-color:var(--accent);outline:none}.chat-input:disabled{opacity:.5;cursor:not-allowed}.send-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;transition:background .2s}.send-btn:hover:not(:disabled){background:var(--accent-hover)}.send-btn:disabled{cursor:not-allowed;background:#333}.clear-btn{border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:8px;padding:.75rem 1rem;font-size:1rem}.clear-btn:hover{border-color:var(--error);color:var(--error)}.auth-page{background-color:#fff;flex-direction:column;align-items:center;min-height:100vh;padding:2rem;display:flex}.auth-container{background-color:#f8f9fa;border-radius:8px;width:100%;max-width:480px;margin:auto 0;padding:2rem;box-shadow:0 4px 6px #0000000d}.auth-header{text-align:center;margin-bottom:2rem}.auth-logo{width:120px;margin:0 auto 1rem}.auth-header h1{color:#333;margin-bottom:.5rem;font-size:1.5rem}.auth-header p{color:#666;font-size:1rem}.auth-error{color:#c62828;background:#ffebee;border-radius:6px;margin-top:.25rem;margin-bottom:20px;padding:12px;font-size:.875rem}.auth-form{flex-direction:column;gap:1.5rem;display:flex}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-label{color:#666;font-size:.875rem;font-weight:500}.form-group input{color:#333;box-sizing:border-box;background-color:#fff;border:1px solid #dee2e6;border-radius:4px;width:100%;padding:.75rem;font-size:1rem}.form-group input:focus{border-color:#1976d2;outline:none;box-shadow:0 0 0 2px #1976d233}.auth-button{color:#fff;cursor:pointer;background-color:#1976d2;border:none;border-radius:4px;width:100%;margin-top:1rem;padding:.75rem;font-size:1rem;font-weight:500;transition:background-color .3s}.auth-button:hover:not(:disabled){background-color:#1565c0}.auth-button:disabled{opacity:.7;cursor:not-allowed}.auth-links{text-align:center;color:#666;margin-top:2rem;font-size:.875rem}.auth-links a{color:#1976d2;font-weight:500;text-decoration:none}.auth-links a:hover{text-decoration:underline}.auth-google-button{color:#757575;cursor:pointer;background-color:#fff;border:1px solid #dee2e6;border-radius:4px;justify-content:center;align-items:center;gap:.75rem;width:100%;margin-top:1rem;padding:.75rem;font-size:1rem;font-weight:500;display:flex}.auth-google-button:hover{background-color:#f5f5f5}.google-icon{width:18px;height:18px}.divider{color:#666;align-items:center;margin:1.5rem 0;font-size:.875rem;display:flex}.divider:before,.divider:after{content:"";border-bottom:1px solid #dee2e6;flex:1}.divider:before{margin-right:1rem}.divider:after{margin-left:1rem}@media (width<=768px){.auth-container{padding:1.5rem}.auth-header h1{font-size:1.25rem}}@media (width<=480px){.auth-page{padding:1rem}.auth-container{box-shadow:none;background-color:#0000;padding:1rem}}
