.app-container{width:100%;max-width:450px;height:100%;display:flex;flex-direction:column;padding:24px;gap:16px;position:relative}.header{display:flex;justify-content:space-between;align-items:center;padding-bottom:12px}.brand{display:flex;align-items:center;gap:12px}.logo-orb{width:24px;height:24px;background:linear-gradient(45deg,var(--primary),var(--accent));border-radius:50%;box-shadow:0 0 15px var(--primary-glow)}h1{font-size:1.1rem;letter-spacing:.1em;color:var(--text)}.ai-tag{font-size:.6rem;background:var(--primary);padding:2px 6px;border-radius:4px;vertical-align:middle;margin-left:4px;color:#fff}.error-banner{background:rgba(239,68,68,.1);color:#ef4444;padding:10px 16px;border-radius:12px;display:flex;align-items:center;gap:10px;font-size:.85rem;border:1px solid rgba(239,68,68,.2);overflow:hidden}.main-content{flex:1;display:flex;flex-direction:column;align-items:center;gap:20px;justify-content:flex-start;padding:10px 0}.assistant-card{position:absolute;bottom:24px;left:24px;right:24px;width:auto;z-index:50;padding:20px 24px 16px;display:flex;flex-direction:column;overflow-y:auto;max-height:50vh;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text-dim);text-align:center}.hint{font-size:.85rem;font-style:italic;opacity:.7}.icon-bg{width:64px;height:64px;background:var(--surface);border-radius:20px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);margin-bottom:8px}.conversation-close-btn{position:absolute;top:10px;right:12px;background:none;border:none;color:var(--text-dim);font-size:1.2rem;line-height:1;cursor:pointer;padding:4px 6px;border-radius:6px;transition:background .15s}.conversation-close-btn:hover{background:var(--surface)}.conversation-area{display:flex;flex-direction:column;gap:16px;width:100%}.bubble{padding:16px;border-radius:20px;max-width:85%;font-size:.95rem;line-height:1.5}.user-bubble{align-self:flex-end;background:rgba(255,255,255,.08);color:var(--text);text-align:right;border-bottom-right-radius:4px}.ai-bubble{align-self:flex-start;background:var(--surface);color:var(--text);text-align:left;border-bottom-left-radius:4px;position:relative;padding-left:24px;border-left:1px solid var(--border);box-shadow:0 4px 15px #0003}.ai-accent-bar{position:absolute;left:0;top:16px;bottom:16px;width:4px;background:var(--primary);border-radius:0 4px 4px 0;box-shadow:0 0 10px var(--primary-glow)}.visualizer-container{display:flex;flex-direction:column;align-items:center;gap:20px;padding-bottom:10px}.orb-outer{width:110px;height:110px;border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;background:linear-gradient(135deg,var(--surface) 0%,#1e293b 100%);border:1px solid var(--border);box-shadow:0 0 30px #00000080;transition:all .5s cubic-bezier(.175,.885,.32,1.275)}.orb-outer.listening{box-shadow:0 0 40px var(--primary-glow);border-color:var(--primary)}.orb-outer.speaking{box-shadow:0 0 40px var(--accent-glow);border-color:var(--accent)}.orb-inner{width:64px;height:64px;border-radius:50%;background:#1e293b;display:flex;align-items:center;justify-content:center;z-index:2;color:var(--text-dim);border:1px solid var(--border)}.listening .orb-inner{color:var(--primary);border-color:var(--primary)}.speaking .orb-inner{color:var(--accent);border-color:var(--accent)}.ripple,.ripple-accent{position:absolute;width:100%;height:100%;border-radius:50%;border:2px solid var(--primary);animation:ripple 2.5s infinite ease-out;opacity:0}.ripple-accent{border-color:var(--accent)}.ripple.delayed{animation-delay:1.25s}.status-badge{display:flex;align-items:center;gap:8px;padding:6px 16px;background:rgba(255,255,255,.05);border-radius:100px;font-size:.8rem;color:var(--text-dim);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid var(--border)}.status-dot{width:6px;height:6px;border-radius:50%;background:#475569}.status-dot.active{background:var(--primary);box-shadow:0 0 8px var(--primary);animation:pulse 1.5s infinite}.status-dot.syncing{background:var(--accent);box-shadow:0 0 8px var(--accent)}.doc-title-row{display:flex;align-items:center;gap:8px}.doc-view-btn{color:var(--text-dim);transition:color .2s}.doc-view-btn:hover{color:var(--primary)}.docs-status-pill{display:flex;align-items:center;gap:8px;background:rgba(15,23,42,.6);padding:6px 14px;border-radius:100px;font-size:.75rem;border:1px solid var(--border);color:var(--text-dim);cursor:pointer;transition:border-color .2s,color .2s;max-width:220px}.docs-status-pill:hover{border-color:var(--primary);color:var(--text)}.doc-title-truncated{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}.doc-viewer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.6);z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.doc-viewer-panel{position:fixed;bottom:0;left:0;right:0;margin:0 auto;max-width:450px;height:80vh;z-index:101;display:flex;flex-direction:column;border-radius:20px 20px 0 0;overflow:hidden}.doc-viewer-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.doc-viewer-title{font-size:.9rem;font-weight:600;color:var(--text);letter-spacing:.02em}.doc-viewer-body{flex:1;overflow-y:auto;padding:20px;font-size:.82rem;line-height:1.7;color:var(--text-dim);white-space:pre-wrap;word-break:break-word;font-family:inherit;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.success-icon{color:#10b981}.spinner{width:10px;height:10px;border:2px solid rgba(255,255,255,.1);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}.mic-button{width:72px;height:72px;border-radius:50%;background:var(--primary);border:none;display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;box-shadow:0 10px 25px -5px var(--primary-glow);transition:all .3s cubic-bezier(.4,0,.2,1);outline:none}.mic-button:active:not(.disabled){transform:scale(.9);box-shadow:0 5px 15px -3px var(--primary-glow)}.mic-button.active{background:#ef4444;box-shadow:0 10px 25px -5px #ef444480;transform:scale(1.1)}.mic-button.disabled{background:#334155;cursor:not-allowed;opacity:.5;box-shadow:none}.stop-button{background:#ef4444;box-shadow:0 10px 25px -5px #ef444480}.icon-btn{color:var(--text-dim);cursor:pointer;transition:color .2s}.icon-btn:hover{color:var(--text)}.library-container{width:100%;max-width:450px;height:100%;display:flex;flex-direction:column;padding:24px;gap:20px}.library-header{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:8px}.library-header .header-actions{display:flex;align-items:center;gap:10px}.no-key-banner{background:rgba(234,179,8,.1);color:#ca8a04;padding:10px 16px;border-radius:12px;display:flex;align-items:center;gap:10px;font-size:.85rem;border:1px solid rgba(234,179,8,.25);overflow:hidden}.no-key-btn{margin-left:auto;flex-shrink:0;background:rgba(234,179,8,.15);color:#ca8a04;border:1px solid rgba(234,179,8,.35);border-radius:8px;padding:4px 10px;font-size:.8rem;cursor:pointer;transition:background .15s}.no-key-btn:hover{background:rgba(234,179,8,.25)}.library-subtitle{font-size:.78rem;color:var(--text-dim);margin-top:4px;letter-spacing:.02em}.search-box{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:10px 14px;transition:border-color .2s}.search-box:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.search-icon{color:var(--text-dim);flex-shrink:0}.search-input{flex:1;background:none;border:none;outline:none;color:var(--text);font-size:.9rem;font-family:inherit}.search-input::placeholder{color:var(--text-dim)}.search-clear{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:1.1rem;line-height:1;padding:0 2px;transition:color .2s}.search-clear:hover{color:var(--text)}.doc-list{display:flex;flex-direction:column;gap:12px;overflow-y:auto;flex:1;scrollbar-width:thin;scrollbar-color:var(--border) transparent;padding-right:4px}.contribute-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.6);z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.contribute-panel{position:fixed;bottom:0;left:0;right:0;margin:0 auto;max-width:450px;max-height:80vh;z-index:101;display:flex;flex-direction:column;border-radius:20px 20px 0 0;overflow:hidden}.contribute-panel-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.contribute-panel-title{display:flex;align-items:center;gap:10px;font-size:1rem;font-weight:600;color:var(--text)}.contribute-panel-content{padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:14px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.contribute-text{margin:0;font-size:.82rem;color:var(--text-dim)}.contribute-repo{margin:0;font-size:.8rem;color:var(--text-dim);overflow-wrap:anywhere}.contribute-repo a{color:var(--primary);text-decoration:none}.contribute-repo a:hover{text-decoration:underline}.contribute-steps{margin:0;padding-left:18px;color:var(--text-dim);font-size:.8rem;display:flex;flex-direction:column;gap:4px}.contribute-actions{display:flex;gap:8px;flex-wrap:wrap}.contribute-btn{display:inline-flex;align-items:center;gap:6px;text-decoration:none;color:#fff;background:var(--primary);border:1px solid var(--primary);padding:6px 10px;border-radius:8px;font-size:.78rem;transition:opacity .15s}.contribute-btn:hover{opacity:.9}.contribute-btn.secondary{background:rgba(255,255,255,.06);color:var(--text);border-color:var(--border)}.contribute-note{margin:0;font-size:.78rem;color:var(--text-dim)}.doc-card{width:100%;display:flex;align-items:center;gap:16px;padding:16px 20px;border-radius:16px;background:var(--surface);border:1px solid var(--border);cursor:pointer;text-align:left;color:var(--text);transition:border-color .2s,box-shadow .2s,opacity .2s}.doc-card:hover:not(:disabled){border-color:var(--primary);box-shadow:0 0 20px var(--primary-glow)}.doc-card:disabled{opacity:.5;cursor:not-allowed}.doc-card.loading{opacity:1;border-color:var(--primary);box-shadow:0 0 20px var(--primary-glow)}.doc-card-icon{width:40px;height:40px;border-radius:12px;background:rgba(255,255,255,.05);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--primary)}.doc-card-info{flex:1;display:flex;flex-direction:column;gap:6px;min-width:0}.doc-card-title{font-size:.95rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.doc-card-meta{display:flex;gap:6px;flex-wrap:wrap}.tag{font-size:.7rem;padding:2px 8px;border-radius:100px;background:rgba(255,255,255,.06);border:1px solid var(--border);color:var(--text-dim)}.tag-lang{background:rgba(99,179,237,.1);border-color:#63b3ed4d;color:#63b3ed}.doc-card-action{color:var(--text-dim);flex-shrink:0;display:flex;align-items:center}.doc-card:hover:not(:disabled) .doc-card-action{color:var(--primary)}.library-loading,.library-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text-dim);font-size:.9rem}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.1);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.spinner-large{width:36px;height:36px;border:3px solid rgba(255,255,255,.08);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.settings-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10}.settings-panel{position:fixed;bottom:0;left:0;right:0;width:100%;max-width:450px;margin:0 auto;z-index:11;border-radius:24px 24px 0 0;padding:24px;display:flex;flex-direction:column;gap:20px;background:#0f172a;border:1px solid var(--border);border-bottom:none;box-sizing:border-box}.settings-header{display:flex;justify-content:space-between;align-items:center}.settings-header h2{font-size:1rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text)}.settings-body{display:flex;flex-direction:column;gap:12px;padding-bottom:env(safe-area-inset-bottom,16px)}.settings-label{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--text-dim);letter-spacing:.05em;text-transform:uppercase}.key-input-row{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:10px 14px;transition:border-color .2s}.key-input-row:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.key-input{flex:1;background:none;border:none;outline:none;color:var(--text);font-size:.9rem;font-family:Courier New,monospace;min-width:0}.key-input::placeholder{color:var(--text-dim);font-family:inherit}.key-visibility-btn{flex-shrink:0;color:var(--text-dim)}.key-visibility-btn:hover{color:var(--text)}.settings-hint{font-size:.75rem;color:var(--text-dim);line-height:1.5;opacity:.8}.spin-icon{animation:spin 1s linear infinite;color:var(--primary)}.models-error-tag{font-size:.68rem;color:#ef4444;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.25);padding:1px 6px;border-radius:100px}.model-select-wrapper{position:relative}.model-select{width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:10px 36px 10px 14px;color:var(--text);font-size:.9rem;font-family:inherit;cursor:pointer;outline:none;transition:border-color .2s;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}.model-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.model-select option{background:#0f172a;color:var(--text)}.settings-save-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;border-radius:12px;background:var(--primary);color:#fff;border:none;font-size:.9rem;font-family:inherit;cursor:pointer;transition:background .2s,opacity .2s;margin-top:4px}.settings-save-btn:disabled{opacity:.4;cursor:not-allowed}.settings-save-btn.saved{background:#10b981}.settings-save-btn:hover:not(:disabled):not(.saved){opacity:.85}.settings-clear-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px;border-radius:12px;background:transparent;color:#ef4444;border:1px solid rgba(239,68,68,.35);font-size:.85rem;font-family:inherit;cursor:pointer;transition:background .2s;margin-top:2px}.settings-clear-btn:hover{background:rgba(239,68,68,.08)}:root{--primary: hsl(215, 100%, 60%);--primary-glow: hsla(215, 100%, 60%, .3);--accent: hsl(280, 100%, 70%);--accent-glow: hsla(280, 100%, 70%, .3);--bg: #030712;--surface: #0f172a;--text: #f8fafc;--text-dim: #94a3b8;--border: rgba(255, 255, 255, .1);font-family:Outfit,sans-serif}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}body{background:var(--bg);background-image:radial-gradient(at 0% 0%,hsla(215,100%,60%,.15) 0px,transparent 50%),radial-gradient(at 100% 100%,hsla(280,100%,70%,.15) 0px,transparent 50%);color:var(--text);overflow:hidden;height:100vh;width:100vw;display:flex;justify-content:center;align-items:center}#root{width:100%;height:100%}.glass-card{background:var(--surface);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:24px}h1,h2,h3{font-weight:600;letter-spacing:-.02em}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes ripple{0%{transform:scale(1);opacity:.5}to{transform:scale(1.5);opacity:0}}
