*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0f0f1a;--bg-secondary: #1a1a2e;--bg-card: #16213e;--accent: #4a9eff;--accent-glow: rgba(74, 158, 255, .3);--text-primary: #e8e8f0;--text-secondary: #8888a0;--text-muted: #555570;--user-bubble: #1e3a5f;--assistant-bubble: #1f1f35;--border: #2a2a45;--danger: #ff4757;--success: #2ed573;--radius: 12px;--radius-sm: 8px}html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;overflow:hidden}#root{height:100%}.app{display:flex;flex-direction:column;height:100%;max-width:680px;margin:0 auto}.app-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0}.app-header h1{font-size:18px;font-weight:600;letter-spacing:.5px}.header-status{display:flex;align-items:center;gap:8px}.status-dot{width:8px;height:8px;border-radius:50%}.status-dot.connected{background:var(--success);box-shadow:0 0 6px var(--success)}.status-dot.disconnected{background:var(--danger)}.chat-view{flex:1;overflow-y:auto;padding:16px 20px;scroll-behavior:smooth}.chat-view.chat-empty{display:flex;align-items:center;justify-content:center}.empty-state{text-align:center;opacity:.8}.eagle-icon{font-size:64px;margin-bottom:12px}.empty-state h2{font-size:24px;margin-bottom:8px}.empty-state p{color:var(--text-secondary);font-size:15px}.empty-state .hint{margin-top:24px;color:var(--accent);font-size:14px}.message{margin-bottom:16px;display:flex;flex-direction:column}.message-user{align-items:flex-end}.message-assistant{align-items:flex-start}.message-bubble{max-width:85%;padding:12px 16px;border-radius:var(--radius);line-height:1.5;font-size:15px;word-wrap:break-word;white-space:pre-wrap}.message-user .message-bubble{background:var(--user-bubble);border-bottom-right-radius:4px}.message-assistant .message-bubble{background:var(--assistant-bubble);border-bottom-left-radius:4px;border:1px solid var(--border)}.message-time{font-size:11px;color:var(--text-muted);margin-top:4px;padding:0 4px}.typing-indicator{display:inline-block;color:var(--accent);animation:pulse 1s infinite}.typing-cursor{display:inline-block;color:var(--accent);animation:blink .6s step-end infinite;font-weight:300;margin-left:1px}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.thinking-indicator{display:flex;align-items:center;gap:8px;margin-top:6px;padding:6px 10px;background:#4a9eff14;border-radius:var(--radius-sm);border:1px solid rgba(74,158,255,.15)}.thinking-spinner{width:14px;height:14px;border:2px solid rgba(74,158,255,.2);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.thinking-text{font-size:.8rem;color:var(--accent);font-style:italic}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.input-bar{padding:12px 20px 20px;border-top:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0}.interim-text{font-size:13px;color:var(--accent);padding:4px 0 8px;font-style:italic}.input-row{display:flex;align-items:flex-end;gap:8px}.input-field{flex:1;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;color:var(--text-primary);font-size:15px;font-family:inherit;resize:none;outline:none;line-height:1.4;min-height:42px;max-height:120px;transition:border-color .2s}.input-field:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}.input-field::placeholder{color:var(--text-muted)}.input-field:disabled{opacity:.5}.send-btn,.voice-btn{width:42px;height:42px;border:none;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .2s}.send-btn{background:var(--accent);color:#fff}.send-btn:hover:not(:disabled){filter:brightness(1.15)}.send-btn:disabled{opacity:.3;cursor:default}.voice-btn{background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border)}.voice-btn:hover{color:var(--text-primary);border-color:var(--accent)}.voice-btn-active{background:var(--danger);color:#fff;border-color:var(--danger);animation:recording-pulse 1.5s infinite}@keyframes recording-pulse{0%,to{box-shadow:0 0 #ff475766}50%{box-shadow:0 0 0 8px #ff475700}}.welcome-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:24px}.welcome-screen h1{font-size:32px;margin-bottom:8px}.welcome-screen>p{color:var(--text-secondary);font-size:16px}.welcome-screen .subtitle{margin-top:8px;font-size:14px;max-width:320px}.register-form{margin-top:32px;display:flex;flex-direction:column;gap:12px;width:100%;max-width:300px}.name-input{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 16px;color:var(--text-primary);font-size:15px;font-family:inherit;outline:none;text-align:center;transition:border-color .2s}.name-input:focus{border-color:var(--accent)}.name-input::placeholder{color:var(--text-muted)}.invite-code-input{font-size:14px;letter-spacing:1px}.start-btn{background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);padding:14px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.start-btn:hover:not(:disabled){filter:brightness(1.15)}.start-btn:disabled{opacity:.5;cursor:default}.error{color:var(--danger);font-size:14px;margin-top:12px}.auth-choice{display:flex;flex-direction:column;gap:12px;width:100%;max-width:340px;margin-top:24px}.token-display{width:100%;max-width:380px;margin-top:16px;text-align:center}.token-warning{font-size:18px;font-weight:700;color:#f59e0b;margin-bottom:8px}.token-explain{font-size:13px;color:var(--text-muted);margin-bottom:16px;line-height:1.4}.token-box{background:var(--bg-tertiary);border:2px solid var(--accent);border-radius:12px;padding:16px;margin:12px 0;cursor:pointer;transition:border-color .2s;position:relative}.token-box:hover{border-color:#22c55e}.token-box:active{border-color:#22c55e;background:#22c55e1a}.token-box code{font-size:14px;color:var(--accent);word-break:break-all;display:block;line-height:1.5}.copy-hint{display:block;font-size:11px;color:var(--text-muted);margin-top:8px}.token-tip{font-size:12px;color:var(--text-muted);margin:12px 0;line-height:1.4}.token-login-section{margin-top:24px;width:100%;max-width:340px;text-align:center}.token-login-toggle{background:none;border:none;color:var(--accent);font-size:14px;cursor:pointer;text-decoration:underline;opacity:.7;transition:opacity .2s}.token-login-toggle:hover{opacity:1}.token-login-form{display:flex;flex-direction:column;gap:10px}.token-hint{font-size:12px;color:var(--text-muted);text-align:center;line-height:1.4}.token-input{font-family:monospace;font-size:12px!important}.token-login-btn{background:var(--bg-tertiary)!important;border:1px solid var(--accent)!important}.message-actions{margin-top:8px;max-width:85%}.action-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;margin-bottom:10px}.action-text{font-size:14px;font-weight:500;line-height:1.5}.action-reasoning{font-size:13px;color:var(--text-secondary);margin-top:6px;line-height:1.4}.action-card-actions{display:flex;gap:8px;margin-top:12px}.action-btn{flex:1;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s;min-height:44px}.action-btn-yes{background:#2ed57326;color:var(--success);border-color:#2ed5734d}.action-btn-yes:hover{background:#2ed57340}.action-btn-no{background:#ff47571a;color:var(--danger);border-color:#ff475740}.action-btn-no:hover{background:#ff475733}.action-btn-later{background:var(--bg-secondary);color:var(--text-secondary)}.action-btn-later:hover{color:var(--text-primary);border-color:var(--text-muted)}.action-card-footer{margin-top:8px;display:flex;justify-content:flex-end}.action-time{font-size:11px;color:var(--text-muted)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.settings-btn{background:none;border:none;color:var(--text-secondary);font-size:18px;cursor:pointer;padding:4px;transition:color .2s}.settings-btn:hover{color:var(--text-primary)}.settings-panel{background:var(--bg-secondary);border-bottom:1px solid var(--border);padding:16px 20px;flex-shrink:0;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.settings-header h2{font-size:16px;font-weight:600}.close-btn{background:none;border:none;color:var(--text-secondary);font-size:18px;cursor:pointer;padding:4px 8px}.close-btn:hover{color:var(--text-primary)}.settings-loading{color:var(--text-muted);font-size:14px}.settings-warning{color:var(--danger);font-size:13px;margin-bottom:12px}.settings-list{display:flex;flex-direction:column;gap:12px}.setting-item{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:8px 0}.setting-item-main{padding-bottom:12px;border-bottom:1px solid var(--border);margin-bottom:4px}.setting-info{display:flex;flex-direction:column;gap:2px;flex:1}.setting-label{font-size:14px;font-weight:500}.setting-desc{font-size:12px;color:var(--text-muted)}.toggle-btn{width:44px;height:24px;border-radius:12px;border:none;cursor:pointer;position:relative;transition:background .2s;flex-shrink:0}.toggle-on{background:var(--accent)}.toggle-off{background:var(--border)}.toggle-thumb{width:20px;height:20px;border-radius:50%;background:#fff;position:absolute;top:2px;transition:left .2s}.toggle-on .toggle-thumb{left:22px}.toggle-off .toggle-thumb{left:2px}.toggle-btn:disabled{opacity:.4;cursor:default}.test-notification-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--accent);padding:10px;font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;margin-top:4px;transition:all .2s}.test-notification-btn:hover:not(:disabled){border-color:var(--accent)}.test-notification-btn:disabled{color:var(--success);border-color:#2ed5734d}*:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button:focus-visible{outline:2px solid var(--accent);outline-offset:2px;box-shadow:0 0 0 4px var(--accent-glow)}input:focus-visible,textarea:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.voice-error{padding:8px 16px;background:#ff475726;color:var(--danger);border-radius:var(--radius-sm);font-size:13px;margin-bottom:8px;animation:fadeIn .2s ease}.settings-error{padding:8px 12px;background:#ff475726;color:var(--danger);border-radius:var(--radius-sm);font-size:13px;margin:8px 0;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.consent-gate{background:var(--bg-card);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--radius);padding:16px;margin:8px 0;max-width:480px}.consent-gate-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.consent-gate-icon{font-size:18px}.consent-gate-title{font-size:14px;font-weight:600;color:var(--text-primary)}.consent-gate-summary{font-size:13px;color:var(--text-secondary);line-height:1.5;margin-bottom:12px}.consent-gate-full{background:var(--bg-primary);border-radius:var(--radius-sm);padding:12px;margin-bottom:12px;max-height:300px;overflow-y:auto}.consent-gate-full p{font-size:12px;color:var(--text-secondary);line-height:1.6;margin-bottom:8px}.consent-gate-full p:last-child{margin-bottom:0}.consent-gate-actions{display:flex;gap:8px;flex-wrap:wrap}.consent-btn{padding:8px 16px;border-radius:var(--radius-sm);border:1px solid var(--border);font-size:13px;cursor:pointer;transition:all .15s ease}.consent-btn:disabled{opacity:.5;cursor:not-allowed}.consent-btn-grant{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}.consent-btn-grant:hover:not(:disabled){filter:brightness(1.1)}.consent-btn-info{background:transparent;color:var(--text-secondary)}.consent-btn-info:hover{color:var(--text-primary)}.consent-btn-deny{background:transparent;color:var(--text-muted)}.consent-btn-deny:hover{color:var(--danger)}.message-consent-requests{display:flex;flex-direction:column;gap:8px;margin-top:8px}.settings-desc-text{font-size:13px;color:var(--text-secondary);padding:0 0 12px;line-height:1.5}.consent-denied{font-size:12px;color:var(--text-muted);padding:4px 8px}.privacy-actions{display:flex;flex-direction:column;gap:8px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.privacy-action-btn{padding:10px 16px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);cursor:pointer;font-size:14px;transition:all .15s ease}.privacy-action-btn:hover:not(:disabled){background:var(--bg-secondary)}.privacy-action-btn:disabled{opacity:.5;cursor:not-allowed}.privacy-action-danger{border-color:#ff47574d;color:var(--danger)}.privacy-action-danger:hover:not(:disabled){background:#ff47571a}.delete-confirm{display:flex;flex-direction:column;gap:8px}.delete-warning{font-size:13px;color:var(--danger);padding:8px 12px;background:#ff47571a;border-radius:var(--radius-sm);line-height:1.4}@media(max-width:480px){.app-header{padding:10px 16px}.chat-view{padding:12px 16px}.input-bar{padding:10px 16px 16px}.message-bubble{max-width:90%}}
