@import"https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=IBM+Plex+Mono:wght@300;400&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #04070f;--bg-2: #080e1c;--bg-3: #0d1629;--border: rgba(255,255,255,.07);--text: #e8edf7;--text-muted: #5a6a8a;--text-dim: #8899bb;--cyan: #00d4c8;--cyan-glow: rgba(0, 212, 200, .25);--cyan-faint: rgba(0, 212, 200, .08);--red: #ff4060;--red-glow: rgba(255, 64, 96, .3);--amber: #f59e0b;--amber-glow: rgba(245, 158, 11, .25);--orb-size: 100px;--font-main: "Syne", sans-serif;--font-mono: "IBM Plex Mono", monospace;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px)}html,body,#root{height:100%;width:100%;overflow:hidden}body{background:var(--bg);color:var(--text);font-family:var(--font-main);-webkit-font-smoothing:antialiased}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(0,212,200,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,212,200,.03) 1px,transparent 1px);background-size:40px 40px;pointer-events:none;z-index:0}.app{position:relative;z-index:1;display:flex;flex-direction:column;height:100%;height:100dvh;padding-top:var(--safe-top);padding-bottom:var(--safe-bottom)}header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);background:#04070fcc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);flex-shrink:0}.header-left{display:flex;align-items:center;gap:10px}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--text-muted);transition:background .3s,box-shadow .3s}.status-dot.recording{background:var(--red);box-shadow:0 0 8px var(--red-glow)}.status-dot.processing{background:var(--amber);box-shadow:0 0 8px var(--amber-glow);animation:blink .8s infinite}.status-dot.speaking{background:var(--cyan);box-shadow:0 0 8px var(--cyan-glow)}.status-dot.idle{background:var(--cyan);opacity:.5}.app-title{font-size:17px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text)}.header-right{display:flex;align-items:center;gap:6px}.icon-btn{background:none;border:1px solid var(--border);color:var(--text-dim);width:36px;height:36px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s,border-color .2s}.icon-btn:hover{background:var(--cyan-faint);color:var(--cyan);border-color:#00d4c84d}main{flex:1;overflow-y:auto;display:flex;flex-direction:column;align-items:center;padding:0 20px 24px;scroll-behavior:smooth}main::-webkit-scrollbar{width:4px}main::-webkit-scrollbar-track{background:transparent}main::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.orb-wrapper{position:relative;display:flex;align-items:center;justify-content:center;width:220px;height:220px;flex-shrink:0;margin-top:32px}.rings{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.ring{position:absolute;border-radius:50%;border:1px solid var(--cyan);opacity:0;transition:opacity .3s}.r1{width:130px;height:130px}.r2{width:165px;height:165px}.r3{width:200px;height:200px}.rings.idle .r1{opacity:.12;animation:pulse-ring 3s ease-in-out infinite}.rings.idle .r2{opacity:.07;animation:pulse-ring 3s ease-in-out .4s infinite}.rings.idle .r3{opacity:.04;animation:pulse-ring 3s ease-in-out .8s infinite}.rings.recording .ring{border-color:var(--red)}.rings.recording .r1{opacity:.5;animation:pulse-ring .9s ease-in-out infinite}.rings.recording .r2{opacity:.35;animation:pulse-ring .9s ease-in-out .15s infinite}.rings.recording .r3{opacity:.2;animation:pulse-ring .9s ease-in-out .3s infinite}.rings.processing .ring{border-color:var(--amber);border-style:dashed}.rings.processing .r1{opacity:.5;animation:spin 2s linear infinite}.rings.processing .r2{opacity:.3;animation:spin 3s linear reverse infinite}.rings.processing .r3{opacity:.2;animation:spin 4s linear infinite}.rings.speaking .r1{opacity:.5;animation:pulse-ring 1.4s ease-in-out infinite}.rings.speaking .r2{opacity:.35;animation:pulse-ring 1.4s ease-in-out .2s infinite}.rings.speaking .r3{opacity:.2;animation:pulse-ring 1.4s ease-in-out .4s infinite}.orb{position:relative;z-index:2;width:var(--orb-size);height:var(--orb-size);border-radius:50%;border:1.5px solid rgba(0,212,200,.4);background:radial-gradient(circle at 40% 35%,#0d2a3a,#060d1e 70%);color:var(--cyan);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s,box-shadow .3s,border-color .3s,background .3s;box-shadow:0 0 30px var(--cyan-glow),0 0 60px #00d4c814,inset 0 0 20px #00d4c80f;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.orb:active:not(:disabled){transform:scale(.94)}.orb.recording{border-color:#ff406099;color:var(--red);background:radial-gradient(circle at 40% 35%,#2a0d14,#0f060a 70%);box-shadow:0 0 30px var(--red-glow),0 0 60px #ff40601a,inset 0 0 20px #ff406014}.orb.processing{border-color:#f59e0b66;color:var(--amber);cursor:not-allowed;background:radial-gradient(circle at 40% 35%,#1e1500,#0e0b02 70%);box-shadow:0 0 30px var(--amber-glow),inset 0 0 20px #f59e0b0f}.orb.speaking{border-color:#00d4c8b3;box-shadow:0 0 40px var(--cyan-glow),0 0 80px #00d4c81f,inset 0 0 24px #00d4c81a}.status{margin-top:18px;font-family:var(--font-mono);font-size:12px;font-weight:300;letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted);flex-shrink:0}.error-msg{margin-top:10px;font-family:var(--font-mono);font-size:11px;color:var(--red);text-align:center;max-width:300px;opacity:.8}.empty-state{margin-top:40px;text-align:center;flex:1}.empty-state p{font-size:15px;font-weight:600;color:var(--text-dim);letter-spacing:.05em}.empty-state span{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);letter-spacing:.1em}.messages{width:100%;max-width:560px;display:flex;flex-direction:column;gap:12px;margin-top:28px;padding-bottom:8px}.message{display:flex;flex-direction:column;gap:5px;animation:fade-up .3s ease-out}.message.user{align-items:flex-end}.message.assistant{align-items:flex-start}.msg-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);padding:0 4px}.msg-text{font-size:14px;line-height:1.6;max-width:85%;padding:12px 16px;border-radius:14px;font-weight:400}.message.user .msg-text{background:linear-gradient(135deg,#00d4c81f,#00d4c80f);border:1px solid rgba(0,212,200,.2);color:var(--text);border-bottom-right-radius:4px}.message.assistant .msg-text{background:var(--bg-3);border:1px solid var(--border);color:var(--text);border-bottom-left-radius:4px}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#04070fcc;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:100;display:flex;align-items:flex-end;justify-content:center;padding:0 0 var(--safe-bottom);animation:fade-in .2s ease}.settings-panel{background:var(--bg-2);border:1px solid var(--border);border-bottom:none;border-radius:20px 20px 0 0;width:100%;max-width:560px;padding:28px 24px 32px;display:flex;flex-direction:column;gap:14px;animation:slide-up .25s cubic-bezier(.16,1,.3,1)}.settings-panel h2{font-size:16px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text);margin-bottom:6px}.settings-panel label{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.settings-panel input,.settings-panel textarea{background:var(--bg-3);border:1px solid var(--border);color:var(--text);border-radius:10px;padding:12px 14px;font-family:var(--font-main);font-size:14px;resize:vertical;outline:none;transition:border-color .2s;width:100%}.settings-panel input:focus,.settings-panel textarea:focus{border-color:#00d4c866}.settings-actions{display:flex;gap:10px;margin-top:6px}.btn-ghost{flex:1;padding:13px;background:none;border:1px solid var(--border);color:var(--text-dim);border-radius:10px;font-family:var(--font-main);font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.btn-ghost:hover{background:var(--bg-3)}.btn-primary{flex:1;padding:13px;background:linear-gradient(135deg,#00d4c833,#00d4c81a);border:1px solid rgba(0,212,200,.4);color:var(--cyan);border-radius:10px;font-family:var(--font-main);font-size:14px;font-weight:700;cursor:pointer;transition:background .2s,box-shadow .2s}.btn-primary:hover{background:linear-gradient(135deg,#00d4c84d,#00d4c826);box-shadow:0 0 16px var(--cyan-glow)}@keyframes pulse-ring{0%,to{transform:scale(1);opacity:var(--opacity, .3)}50%{transform:scale(1.06);opacity:calc(var(--opacity, .3) * .5)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}@keyframes fade-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.spin{animation:spin 1.2s linear infinite}@media (min-width: 600px){.orb-wrapper{margin-top:48px}main{padding-bottom:40px}}.app{display:flex;flex-direction:column;height:100dvh}main{flex:1;overflow-y:auto;padding:16px 20px 0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:0}.orb-static{position:relative;z-index:2;width:100px;height:100px;border-radius:50%;border:1.5px solid rgba(0,212,200,.4);background:radial-gradient(circle at 40% 35%,#0d2a3a,#060d1e 70%);color:var(--cyan);display:flex;align-items:center;justify-content:center;box-shadow:0 0 30px var(--cyan-glow),0 0 60px #00d4c814,inset 0 0 20px #00d4c80f}.empty-title{margin-top:24px;font-size:16px;font-weight:600;color:var(--text-dim);letter-spacing:.05em}.empty-sub{margin-top:6px;font-family:var(--font-mono);font-size:11px;color:var(--text-muted);letter-spacing:.1em}.mic-bar{flex-shrink:0;padding:12px 24px calc(12px + var(--safe-bottom));background:#04070fe6;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid var(--border)}.mic-bar-inner{display:flex;align-items:center;justify-content:space-between;max-width:560px;margin:0 auto}.mic-status{font-family:var(--font-mono);font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted)}.fab-wrapper{position:relative;display:flex;align-items:center;justify-content:center;width:80px;height:80px}.fab-rings{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.fab-ring{position:absolute;border-radius:50%;border:1px solid var(--cyan);opacity:0}.fr1{width:66px;height:66px}.fr2{width:80px;height:80px}.fab-rings.idle .fr1{opacity:.15;animation:pulse-ring 3s ease-in-out infinite}.fab-rings.idle .fr2{opacity:.07;animation:pulse-ring 3s ease-in-out .4s infinite}.fab-rings.recording .fab-ring{border-color:var(--red)}.fab-rings.recording .fr1{opacity:.6;animation:pulse-ring .9s ease-in-out infinite}.fab-rings.recording .fr2{opacity:.35;animation:pulse-ring .9s ease-in-out .15s infinite}.fab-rings.processing .fab-ring{border-color:var(--amber);border-style:dashed}.fab-rings.processing .fr1{opacity:.5;animation:spin 2s linear infinite}.fab-rings.processing .fr2{opacity:.3;animation:spin 3s linear reverse infinite}.fab-rings.speaking .fr1{opacity:.5;animation:pulse-ring 1.4s ease-in-out infinite}.fab-rings.speaking .fr2{opacity:.3;animation:pulse-ring 1.4s ease-in-out .2s infinite}.fab{position:relative;z-index:2;width:60px;height:60px;border-radius:50%;border:1.5px solid rgba(0,212,200,.4);background:radial-gradient(circle at 40% 35%,#0d2a3a,#060d1e 70%);color:var(--cyan);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s,box-shadow .3s,border-color .3s;box-shadow:0 0 20px var(--cyan-glow),inset 0 0 12px #00d4c80f;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.fab:active:not(:disabled){transform:scale(.92)}.fab.recording{border-color:#ff406099;color:var(--red);background:radial-gradient(circle at 40% 35%,#2a0d14,#0f060a 70%);box-shadow:0 0 24px var(--red-glow),inset 0 0 12px #ff406014}.fab.processing{border-color:#f59e0b66;color:var(--amber);cursor:not-allowed;background:radial-gradient(circle at 40% 35%,#1e1500,#0e0b02 70%);box-shadow:0 0 20px var(--amber-glow)}.fab.speaking{border-color:#00d4c8b3;box-shadow:0 0 28px var(--cyan-glow),inset 0 0 16px #00d4c81a}.login-screen{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);display:flex;align-items:center;justify-content:center;padding:24px;z-index:200}.login-box{display:flex;flex-direction:column;align-items:center;gap:14px;width:100%;max-width:320px;animation:fade-up .4s ease-out}.login-orb{width:80px;height:80px;border-radius:50%;border:1.5px solid rgba(0,212,200,.4);background:radial-gradient(circle at 40% 35%,#0d2a3a,#060d1e 70%);color:var(--cyan);display:flex;align-items:center;justify-content:center;box-shadow:0 0 30px var(--cyan-glow),inset 0 0 20px #00d4c80f;animation:pulse-ring 3s ease-in-out infinite;margin-bottom:8px}.login-title{font-size:28px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--text)}.login-sub{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;color:var(--text-muted);text-transform:uppercase;margin-bottom:8px}.login-input{width:100%;background:var(--bg-3);border:1px solid var(--border);color:var(--text);border-radius:12px;padding:14px 18px;font-family:var(--font-mono);font-size:15px;letter-spacing:.2em;outline:none;text-align:center;transition:border-color .2s,box-shadow .2s}.login-input:focus{border-color:#00d4c880;box-shadow:0 0 16px var(--cyan-glow)}.login-error{font-family:var(--font-mono);font-size:11px;color:var(--red);letter-spacing:.1em}.login-btn{width:100%;padding:14px;background:linear-gradient(135deg,#00d4c833,#00d4c814);border:1px solid rgba(0,212,200,.4);color:var(--cyan);border-radius:12px;font-family:var(--font-main);font-size:15px;font-weight:700;letter-spacing:.08em;cursor:pointer;transition:background .2s,box-shadow .2s;margin-top:4px}.login-btn:hover:not(:disabled){background:linear-gradient(135deg,#00d4c84d,#00d4c826);box-shadow:0 0 20px var(--cyan-glow)}.login-btn:disabled{opacity:.4;cursor:not-allowed}.side-panel{position:fixed;top:0;right:0;bottom:0;width:min(360px,100vw);background:var(--bg-2);border-left:1px solid var(--border);display:flex;flex-direction:column;gap:14px;padding:20px;overflow-y:auto;z-index:101;animation:slide-in-right .25s cubic-bezier(.16,1,.3,1)}@keyframes slide-in-right{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.panel-header h2{font-size:16px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.panel-desc{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);letter-spacing:.06em;line-height:1.6}.panel-label{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.panel-empty{font-family:var(--font-mono);font-size:12px;color:var(--text-muted);text-align:center;margin-top:20px;line-height:1.7}.panel-list{display:flex;flex-direction:column;gap:8px}.panel-item{position:relative;background:var(--bg-3);border:1px solid var(--border);border-radius:10px;padding:12px 36px 12px 14px;cursor:pointer;transition:border-color .2s,background .2s}.panel-item:hover{border-color:#00d4c84d;background:#00d4c80a}.panel-item-title{font-size:13px;color:var(--text);line-height:1.4}.panel-item-meta{font-family:var(--font-mono);font-size:10px;color:var(--text-muted);margin-top:4px}.panel-item-delete{position:absolute;top:10px;right:10px;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:12px;padding:2px 4px;border-radius:4px;transition:color .2s,background .2s}.panel-item-delete:hover{color:var(--red);background:#ff40601a}.memory-input-row{display:flex;gap:8px}.memory-input{flex:1;background:var(--bg-3);border:1px solid var(--border);color:var(--text);border-radius:10px;padding:10px 12px;font-family:var(--font-main);font-size:13px;outline:none;transition:border-color .2s}.memory-input:focus{border-color:#00d4c866}.memory-add{flex-shrink:0;padding:10px 16px!important;font-size:13px!important}.settings-textarea{width:100%;background:var(--bg-3);border:1px solid var(--border);color:var(--text);border-radius:10px;padding:12px 14px;font-family:var(--font-main);font-size:13px;resize:vertical;outline:none;transition:border-color .2s;line-height:1.6}.settings-textarea:focus{border-color:#00d4c866}.icon-btn.active{background:var(--cyan-faint);color:var(--cyan);border-color:#00d4c84d}.memory-badge{margin-top:16px;font-family:var(--font-mono);font-size:11px;color:var(--cyan);letter-spacing:.08em;opacity:.7}.search-badge{display:inline-block;margin-top:6px;font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;color:var(--cyan);opacity:.6}.speed-row{display:flex;align-items:center;gap:12px}.speed-slider{flex:1;-webkit-appearance:none;height:4px;border-radius:2px;background:var(--bg-3);outline:none;border:1px solid var(--border)}.speed-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--cyan);cursor:pointer;box-shadow:0 0 8px var(--cyan-glow)}.speed-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--cyan);cursor:pointer;border:none;box-shadow:0 0 8px var(--cyan-glow)}.speed-val{font-family:var(--font-mono);font-size:13px;color:var(--cyan);min-width:36px;text-align:right}
