:root{--bg-gradient-start: #0a0a0f;--bg-gradient-end: #1a1a2e;--accent-primary: #8b5cf6;--accent-secondary: #06b6d4;--accent-success: #10b981;--accent-danger: #ef4444;--text-primary: #ffffff;--text-muted: rgba(255, 255, 255, .6);--glass-bg: rgba(255, 255, 255, .05);--glass-border: rgba(255, 255, 255, .1);--glass-blur: 20px;--glow-idle: rgba(139, 92, 246, .4);--glow-listening: rgba(34, 197, 94, .7);--glow-processing: rgba(239, 68, 68, .5);--glow-speaking: rgba(239, 68, 68, .6);--color-listening: #22c55e;--color-processing: #ef4444;--color-speaking: #ef4444}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%;overflow:hidden}body{background:linear-gradient(135deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%);font-family:Inter,system-ui,-apple-system,sans-serif;color:var(--text-primary)}.app{width:100vw;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden}.app:before{content:"";position:absolute;inset:0;background-image:radial-gradient(2px 2px at 20px 30px,rgba(139,92,246,.3),transparent),radial-gradient(2px 2px at 40px 70px,rgba(6,182,212,.2),transparent),radial-gradient(1px 1px at 90px 40px,rgba(255,255,255,.3),transparent),radial-gradient(2px 2px at 130px 80px,rgba(139,92,246,.2),transparent),radial-gradient(1px 1px at 160px 120px,rgba(6,182,212,.3),transparent);background-size:200px 200px;animation:floatParticles 20s linear infinite;opacity:.6;pointer-events:none}@keyframes floatParticles{0%{transform:translateY(0)}to{transform:translateY(-200px)}}.access-denied{color:var(--text-primary);font-size:2rem;text-align:center;padding:2rem;background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:24px}.mic-button{width:min(50vw,50vh);height:min(50vw,50vh);max-width:350px;max-height:350px;border-radius:50%;border:none;background:radial-gradient(circle at 40% 40%,#8b5cf626,#0f0f1ecc);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));cursor:pointer;display:flex;align-items:center;justify-content:center;position:fixed;right:10%;top:50%;transform:translateY(-50%);transition:transform .4s cubic-bezier(.34,1.56,.64,1),box-shadow .4s ease;box-shadow:0 0 60px var(--glow-idle),inset 0 0 60px #8b5cf614;z-index:10}.mic-button:hover{transform:scale(1.04)}.mic-button:active{transform:scale(.96)}.mic-icon{width:40%;height:40%;fill:var(--text-primary);z-index:2;transition:fill .4s ease,filter .4s ease,transform .3s ease;filter:drop-shadow(0 0 20px var(--glow-idle))}.glow-ring{position:absolute;width:100%;height:100%;border-radius:50%;border:3px solid var(--glass-border);z-index:1;transition:border-color .4s ease}.outer-glow{position:absolute;width:140%;height:140%;border-radius:50%;opacity:0;z-index:0;pointer-events:none;transition:opacity .4s ease}.mic-button.idle{box-shadow:0 0 60px var(--glow-idle),inset 0 0 60px #8b5cf614}.mic-button.idle .glow-ring{border-color:#8b5cf64d;animation:idleBreathe 4s ease-in-out infinite}.mic-button.idle .outer-glow{opacity:.3;background:radial-gradient(circle,var(--glow-idle) 0%,transparent 70%);animation:breathe 4s ease-in-out infinite}.mic-button.listening{background:radial-gradient(circle at 40% 40%,#22c55e33,#0f0f1ecc);box-shadow:0 0 100px var(--glow-listening),0 0 200px #22c55e26,inset 0 0 80px #22c55e1a}.mic-button.listening .mic-icon{fill:var(--color-listening);filter:drop-shadow(0 0 40px var(--glow-listening));animation:iconPulse 1.5s ease-in-out infinite}.mic-button.listening .glow-ring{border-color:var(--color-listening);animation:listeningPulse 2s ease-in-out infinite}.mic-button.listening .outer-glow{opacity:.6;background:radial-gradient(circle,var(--glow-listening) 0%,transparent 70%);animation:outerPulseGreen 2s ease-in-out infinite}.mic-button.processing{background:radial-gradient(circle at 40% 40%,#ef444426,#0f0f1ecc);box-shadow:0 0 80px var(--glow-processing),0 0 160px #ef44441a,inset 0 0 60px #ef444414}.mic-button.processing .mic-icon{fill:var(--color-processing);filter:drop-shadow(0 0 30px var(--glow-processing));animation:thinkPulse 2s ease-in-out infinite}.mic-button.processing .glow-ring{border-color:var(--color-processing);animation:processingRing 1.5s ease-in-out infinite}.mic-button.processing .outer-glow{opacity:.5;background:radial-gradient(circle,var(--glow-processing) 0%,transparent 70%);animation:outerPulseRed 1.5s ease-in-out infinite}.mic-button.speaking{background:radial-gradient(circle at 40% 40%,#ef444433,#0f0f1ecc);box-shadow:0 0 120px var(--glow-speaking),0 0 240px #ef444426,inset 0 0 80px #ef44441a}.mic-button.speaking .mic-icon{fill:var(--color-speaking);filter:drop-shadow(0 0 40px var(--glow-speaking));animation:speakingBounce .6s ease-in-out infinite}.mic-button.speaking .glow-ring{border-color:var(--color-speaking);animation:speakingWave .8s ease-in-out infinite}.mic-button.speaking .outer-glow{opacity:.7;background:radial-gradient(circle,var(--glow-speaking) 0%,transparent 70%);animation:outerPulseSpeaking .8s ease-in-out infinite}@keyframes idleBreathe{0%,to{transform:scale(1);opacity:.5}50%{transform:scale(1.02);opacity:.8}}@keyframes breathe{0%,to{opacity:.2;transform:scale(1)}50%{opacity:.4;transform:scale(1.05)}}@keyframes iconPulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}@keyframes listeningPulse{0%,to{transform:scale(1);opacity:.6;border-width:3px}50%{transform:scale(1.06);opacity:1;border-width:5px}}@keyframes outerPulseGreen{0%,to{opacity:.4;transform:scale(1)}50%{opacity:.8;transform:scale(1.12)}}@keyframes processingRing{0%,to{transform:scale(1);opacity:.5}50%{transform:scale(1.04);opacity:.9}}@keyframes thinkPulse{0%,to{transform:scale(1)}25%{transform:scale(.95)}50%{transform:scale(1.05)}75%{transform:scale(.98)}}@keyframes speakingBounce{0%,to{transform:scale(1)}50%{transform:scale(1.12)}}@keyframes speakingWave{0%,to{transform:scale(1);opacity:.7}50%{transform:scale(1.08);opacity:1}}@keyframes outerPulseRed{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}@keyframes outerPulseSpeaking{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.9;transform:scale(1.15)}}.status-text{position:absolute;bottom:-60px;left:50%;transform:translate(-50%);font-size:.9rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:2px;white-space:nowrap}audio{display:none}.debug-panel{position:fixed;bottom:120px;left:110px;right:110px;max-height:120px;overflow-y:auto;background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:16px;padding:12px 16px;font-family:JetBrains Mono,Fira Code,monospace;font-size:12px;color:var(--text-muted);z-index:100;pointer-events:none}.debug-status{white-space:pre-wrap;opacity:.8}.transcript{margin-top:12px;padding-top:12px;border-top:1px solid var(--glass-border);color:var(--text-primary);font-size:14px;font-family:Inter,system-ui,sans-serif}.transcript strong{color:var(--accent-primary)}.audiobook-status{margin-top:12px;padding:12px;background:#06b6d41a;border:1px solid rgba(6,182,212,.2);border-radius:12px;color:var(--accent-secondary);font-size:14px;font-family:Inter,system-ui,sans-serif}.memory-panel{position:fixed;top:20px;right:20px;width:300px;max-height:400px;overflow-y:auto;background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:16px;padding:16px;z-index:100}.memory-panel h3{font-size:.875rem;font-weight:600;color:var(--accent-primary);margin-bottom:12px;display:flex;align-items:center;gap:8px}.memory-item{padding:10px 12px;background:#ffffff08;border-radius:10px;margin-bottom:8px;font-size:.8rem;color:var(--text-muted);line-height:1.4;border-left:2px solid var(--accent-secondary)}.memory-item:last-child{margin-bottom:0}.memory-empty{color:var(--text-muted);font-size:.8rem;font-style:italic;text-align:center;padding:20px}.debug-panel::-webkit-scrollbar,.side-panel::-webkit-scrollbar{width:6px}.debug-panel::-webkit-scrollbar-track,.side-panel::-webkit-scrollbar-track{background:transparent}.debug-panel::-webkit-scrollbar-thumb,.side-panel::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:3px}.panel-toggle{width:48px;height:48px;border-radius:50%;border:1px solid var(--glass-border);background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));color:var(--accent-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.panel-toggle:hover{transform:scale(1.05);box-shadow:0 0 20px #06b6d44d}.panel-toggle.active{background:#06b6d433;border-color:var(--accent-secondary)}.top-right-toggles{position:fixed;top:20px;right:20px;display:flex;gap:10px;z-index:101}.side-panel{position:fixed;top:80px;width:280px;max-height:calc(100vh - 200px);overflow-y:auto;background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:16px;padding:16px;z-index:100}.side-panel.left{left:20px}.side-panel.right{right:20px}.side-panel h3{font-size:.9rem;font-weight:600;color:var(--accent-secondary);margin-bottom:12px}.panel-item{width:100%;display:flex;justify-content:space-between;align-items:center;padding:10px 12px;margin-bottom:6px;background:#ffffff08;border:1px solid transparent;border-radius:10px;cursor:pointer;transition:all .2s ease;text-align:left}.panel-item:hover{background:#ffffff14;border-color:var(--glass-border)}.panel-item.selected{background:#06b6d426;border-color:var(--accent-secondary)}.panel-item.memory,.panel-item.reminder{flex-direction:row;align-items:center;cursor:default;border-left:2px solid var(--accent-secondary);gap:8px}.panel-item.done{opacity:.5;border-left-color:#10b98180}.panel-item.done .item-title{text-decoration:line-through}.panel-item-main{flex:1;display:flex;flex-direction:column;align-items:flex-start;min-width:0}.panel-item-actions{display:flex;gap:4px;flex-shrink:0}.panel-action-btn{width:32px;height:32px;border:none;background:#ffffff0d;border-radius:8px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;padding:0}.panel-action-btn:hover{background:#ffffff26;transform:scale(1.1)}.panel-action-btn.delete:hover{background:#ef444433}.panel-action-btn.done:hover{background:#10b98133}.tv-overlay{position:fixed;inset:0;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:200;display:flex;align-items:center;justify-content:center;animation:tvFadeIn .3s ease}@keyframes tvFadeIn{0%{opacity:0}to{opacity:1}}.tv-overlay-content{width:96%;max-width:800px;height:92vh;background:linear-gradient(135deg,#0f172af7,#1e293bf2);border:1px solid rgba(255,255,255,.1);border-radius:20px;box-shadow:0 20px 60px #00000080;display:flex;flex-direction:column;animation:tvSlideUp .35s ease}@keyframes tvSlideUp{0%{opacity:0;transform:translateY(30px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.tv-overlay-header{display:flex;align-items:center;gap:16px;padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0}.tv-overlay-header h2{font-size:36px;font-weight:700;color:#fff;margin:0;white-space:nowrap}.tv-overlay-header .tv-tabs{margin-bottom:0;flex:1;max-width:360px}.tv-overlay-close{background:#ffffff14;border:1px solid rgba(255,255,255,.12);color:#ffffffb3;width:36px;height:36px;border-radius:10px;font-size:16px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;margin-left:auto;flex-shrink:0}.tv-overlay-close:hover{background:#ef444433;border-color:#ef444466;color:#fff}.tv-list{display:flex;flex-direction:column;gap:16px;padding:20px 24px;overflow-y:auto;flex:1}.tv-list::-webkit-scrollbar{width:6px}.tv-list::-webkit-scrollbar-track{background:transparent}.tv-list::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.tv-tabs{display:flex;gap:4px;margin-bottom:12px;padding:3px;background:#ffffff0d;border-radius:10px}.tv-tab{flex:1;padding:10px 16px;border:none;background:transparent;color:#fff9;border-radius:8px;font-size:22px;font-weight:500;cursor:pointer;transition:all .2s ease}.tv-tab:hover{color:#ffffffe6;background:#ffffff14}.tv-tab.active{background:linear-gradient(135deg,#06b6d44d,#8b5cf64d);color:#fff;box-shadow:0 0 10px #06b6d426}.tv-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:12px;overflow:hidden;transition:all .2s ease;cursor:pointer;flex-shrink:0}.tv-card:hover{background:#ffffff12;border-color:#06b6d44d}.tv-card.reading{border-color:#06b6d499;background:#06b6d414;box-shadow:0 0 20px #06b6d426;animation:tvPulse 2s ease-in-out infinite}@keyframes tvPulse{0%,to{box-shadow:0 0 20px #06b6d426}50%{box-shadow:0 0 30px #06b6d440}}.tv-card.krimi{border-color:#ef44444d}.tv-card.krimi:hover{border-color:#ef444480}.tv-card-row{display:flex;flex-direction:column}.tv-card-thumb{width:100%;height:350px;flex-shrink:0;overflow:hidden;border-radius:12px 12px 0 0}.tv-card-thumb img{width:100%;height:100%;object-fit:cover;display:block}.tv-card-content{padding:18px 20px;flex:1;min-width:0}.tv-card-header{display:flex;align-items:center;gap:12px;margin-bottom:8px;flex-wrap:wrap}.tv-card-time{color:#06b6d4e6;font-weight:600;margin-left:auto;animation:tvReadingBlink 1.2s ease-in-out infinite}@keyframes tvReadingBlink{0%,to{opacity:1}50%{opacity:.4}}.tv-card-title{font-size:28px;font-weight:600;color:#fffffff2;line-height:1.3;margin-bottom:8px}.tv-card.krimi .tv-card-title{color:#facc15f2}.tv-card-desc{font-size:24px;color:#fff9;line-height:1.5}.panel-item.audiobook{gap:10px}.panel-item.audiobook svg{flex-shrink:0;color:var(--accent-secondary)}.audiobook-info{flex:1;display:flex;flex-direction:column;gap:2px;overflow:hidden}.item-title{font-size:.85rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-subtitle{font-size:.7rem;color:var(--text-muted)}.panel-empty{color:var(--text-muted);font-size:.8rem;font-style:italic;text-align:center;padding:20px}.ara-reply{margin-top:8px;padding:10px;background:#8b5cf61a;border-left:2px solid var(--accent-primary);border-radius:8px;font-size:.85rem;line-height:1.5}@media(max-width:768px){.side-panel{width:calc(100% - 40px);left:20px!important;right:20px!important;max-height:50vh}.top-right-toggles{right:10px;gap:8px}.panel-toggle{width:42px;height:42px}}.model-selector{position:fixed;top:20px;left:20px;display:flex;gap:4px;background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:12px;padding:4px;z-index:100}.model-btn{background:transparent;border:none;color:var(--text-muted);padding:8px 14px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:500;transition:all .3s ease;white-space:nowrap}.model-btn:hover{color:var(--text-primary);background:#ffffff14}.model-btn.active{color:var(--text-primary);background:var(--accent-primary);box-shadow:0 0 12px #8b5cf666}@media(max-width:600px){.model-selector{top:12px;left:12px}.model-btn{padding:6px 10px;font-size:12px}}.weather-widget{position:fixed;bottom:0;left:0;right:0;background:#0a0a19f2;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-top:1px solid rgba(139,92,246,.3);border-radius:24px 24px 0 0;padding:32px 40px 36px;z-index:200;animation:weatherSlideUp .5s cubic-bezier(.16,1,.3,1);box-shadow:0 -16px 64px #0009,0 0 40px #8b5cf633}@keyframes weatherSlideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.weather-close{position:absolute;top:12px;right:14px;background:none;border:none;color:var(--text-muted);font-size:22px;cursor:pointer;padding:6px}.weather-current{display:flex;align-items:center;gap:16px;margin-bottom:12px}.weather-icon{font-size:72px}.weather-temp{font-size:64px;font-weight:700;color:var(--text-primary);letter-spacing:-2px}.weather-desc{color:var(--text-muted);font-size:22px}.weather-details{display:flex;gap:32px;color:var(--text-muted);font-size:20px;padding-bottom:20px;margin-bottom:20px;border-bottom:1px solid rgba(255,255,255,.1)}.weather-forecast{display:flex;gap:8px;justify-content:space-between}.forecast-day{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1;padding:8px 4px;border-radius:12px;transition:background .2s}.forecast-day:first-child{background:#8b5cf626}.forecast-weekday{font-size:17px;color:var(--text-muted);font-weight:600}.forecast-icon{font-size:40px}.forecast-temps{display:flex;flex-direction:column;align-items:center;gap:2px}.temp-max{font-size:22px;color:var(--text-primary);font-weight:700}.temp-min{font-size:17px;color:var(--text-muted)}@media(max-width:600px){.weather-widget{padding:20px 16px 24px}.weather-icon{font-size:48px}.weather-temp{font-size:40px}.forecast-icon{font-size:28px}}.weather-time{color:var(--text-muted);font-size:16px;margin-left:auto}.widget-tray{position:fixed;bottom:240px;left:50%;transform:translate(-50%);display:flex;gap:12px;z-index:100}.widget-tray-btn{width:52px;height:52px;background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:50%;font-size:26px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;animation:trayFadeIn .4s ease}@keyframes trayFadeIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.widget-tray-btn:hover{background:#8b5cf633;border-color:#8b5cf666;box-shadow:0 0 20px #8b5cf64d;transform:scale(1.15)}.shopping-widget{position:fixed;bottom:0;left:0;right:0;background:#0a0a19f2;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-top:1px solid rgba(16,185,129,.3);border-radius:24px 24px 0 0;padding:32px 40px 36px;z-index:200;animation:weatherSlideUp .5s cubic-bezier(.16,1,.3,1);box-shadow:0 -16px 64px #0009,0 0 40px #10b98133}.shopping-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.shopping-header-icon{font-size:48px}.shopping-header-title{font-size:32px;font-weight:700;color:var(--text-primary)}.shopping-list{display:flex;flex-direction:column;gap:10px;max-height:300px;overflow-y:auto}.shopping-item{display:flex;align-items:center;gap:16px;padding:14px 20px;background:#ffffff0a;border:1px solid rgba(16,185,129,.15);border-radius:14px;transition:background .2s}.shopping-item:hover{background:#10b98114}.shopping-check{font-size:24px}.shopping-item-content{display:flex;flex-direction:column;gap:2px;flex:1}.shopping-item-name{font-size:20px;color:var(--text-primary);font-weight:500}.shopping-item-meta{display:flex;gap:16px;font-size:16px}.shopping-price{color:#10b981e6;font-weight:600}.shopping-shop{color:var(--text-muted)}@media(max-width:600px){.shopping-widget{padding:20px 16px 24px}.shopping-header-icon{font-size:32px}.shopping-header-title{font-size:24px}.shopping-item-name{font-size:16px}.widget-tray{bottom:200px}}.reminder-widget{position:fixed;bottom:0;left:0;right:0;background:#0a0a19f2;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-top:1px solid rgba(139,92,246,.3);border-radius:24px 24px 0 0;padding:32px 40px 36px;z-index:200;animation:weatherSlideUp .5s cubic-bezier(.16,1,.3,1);box-shadow:0 -16px 64px #0009,0 0 40px #8b5cf633}.reminder-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.reminder-header-icon{font-size:48px}.reminder-header-title{font-size:32px;font-weight:700;color:var(--text-primary)}.reminder-count{background:var(--accent-primary);color:#fff;font-size:18px;font-weight:700;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-left:8px}.reminder-list{display:flex;flex-direction:column;gap:12px;max-height:300px;overflow-y:auto}.reminder-item{display:flex;align-items:flex-start;gap:16px;padding:16px 20px;background:#ffffff0a;border:1px solid rgba(139,92,246,.15);border-radius:14px;transition:background .2s}.reminder-item:hover{background:#8b5cf61a}.reminder-dot{width:12px;height:12px;min-width:12px;background:var(--accent-primary);border-radius:50%;margin-top:6px;box-shadow:0 0 8px #8b5cf680}.reminder-content{display:flex;flex-direction:column;gap:4px}.reminder-text{font-size:20px;color:var(--text-primary);font-weight:500}.reminder-date{font-size:16px;color:var(--text-muted)}.reminder-empty{font-size:22px;color:var(--text-muted);text-align:center;padding:32px}@media(max-width:600px){.reminder-widget{padding:20px 16px 24px}.reminder-header-icon{font-size:32px}.reminder-header-title{font-size:24px}.reminder-text{font-size:16px}}.notification-popup{position:fixed;top:24px;left:50%;transform:translate(-50%);background:#0a0a19f2;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:2px solid rgba(250,204,21,.5);border-radius:20px;padding:20px 32px;z-index:300;display:flex;align-items:center;gap:20px;min-width:360px;max-width:600px;animation:notifSlideDown .5s cubic-bezier(.16,1,.3,1),notifGlow 2s ease-in-out infinite;box-shadow:0 8px 32px #00000080,0 0 30px #facc1533}@keyframes notifSlideDown{0%{opacity:0;transform:translate(-50%) translateY(-100px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes notifGlow{0%,to{box-shadow:0 8px 32px #00000080,0 0 20px #facc1533;border-color:#facc1566}50%{box-shadow:0 8px 32px #00000080,0 0 40px #facc1566;border-color:#facc15b3}}.notification-icon{font-size:40px;animation:notifBell 1s ease-in-out}@keyframes notifBell{0%{transform:rotate(0)}15%{transform:rotate(15deg)}30%{transform:rotate(-15deg)}45%{transform:rotate(10deg)}60%{transform:rotate(-10deg)}75%{transform:rotate(5deg)}to{transform:rotate(0)}}.notification-body{display:flex;flex-direction:column;gap:4px}.notification-text{font-size:22px;color:var(--text-primary);font-weight:600}.notification-label{font-size:16px;color:#facc15e6;font-weight:500}@media(max-width:600px){.notification-popup{left:16px;right:16px;transform:none;min-width:auto}@keyframes notifSlideDown{0%{opacity:0;transform:translateY(-100px)}to{opacity:1;transform:translateY(0)}}}.avatar-main-wrapper{position:fixed;left:50%;top:45%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:12px;z-index:10}.avatar-container{width:500px;height:500px;border-radius:50%;overflow:hidden;cursor:pointer;position:relative;transition:box-shadow .6s ease,filter .5s ease;box-shadow:0 0 40px #8b5cf633,0 0 80px #8b5cf614}.avatar-container.dragging{cursor:grabbing}.avatar-container canvas{pointer-events:none}.avatar-container.avatar-glow-idle{box-shadow:0 0 40px #8b5cf640,0 0 80px #8b5cf61a;animation:avatarIdleBreathe 4s ease-in-out infinite}@keyframes avatarIdleBreathe{0%,to{box-shadow:0 0 40px #8b5cf640,0 0 80px #8b5cf61a}50%{box-shadow:0 0 60px #8b5cf659,0 0 100px #8b5cf626}}.avatar-container.avatar-glow-listening{box-shadow:0 0 60px #22c55e66,0 0 120px #22c55e33,0 0 200px #22c55e14;animation:avatarListeningPulse 2s ease-in-out infinite}@keyframes avatarListeningPulse{0%,to{box-shadow:0 0 60px #22c55e66,0 0 120px #22c55e33,0 0 200px #22c55e14}50%{box-shadow:0 0 80px #22c55e8c,0 0 160px #22c55e4d,0 0 250px #22c55e1f}}.avatar-container.avatar-glow-processing{box-shadow:0 0 60px #f59e0b66,0 0 120px #f59e0b33,0 0 200px #f59e0b14;animation:avatarProcessingPulse 1.5s ease-in-out infinite}@keyframes avatarProcessingPulse{0%,to{box-shadow:0 0 60px #f59e0b66,0 0 120px #f59e0b33}50%{box-shadow:0 0 80px #f59e0b8c,0 0 160px #f59e0b4d}}.avatar-container.avatar-glow-speaking{box-shadow:0 0 80px #ef444473,0 0 160px #06b6d433,0 0 240px #ef44441a;animation:avatarSpeakingPulse .8s ease-in-out infinite}@keyframes avatarSpeakingPulse{0%,to{box-shadow:0 0 80px #ef444473,0 0 160px #06b6d433,0 0 240px #ef44441a}50%{box-shadow:0 0 100px #ef444499,0 0 200px #06b6d44d,0 0 280px #ef444426}}.avatar-status{font-family:Inter,sans-serif;font-size:14px;letter-spacing:3px;text-transform:uppercase;color:#ffffff80;text-align:center;transition:color .4s ease}.avatar-status.listening{color:#22c55ee6}.avatar-status.processing{color:#f59e0be6}.avatar-status.speaking{color:#ef4444e6}.avatar-controls{display:flex;align-items:center;gap:16px;background:#0f0f1e99;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:8px 20px;margin-top:4px}.avatar-control-row{display:flex;align-items:center;gap:8px}.control-label{font-size:20px;-webkit-user-select:none;user-select:none}.control-slider{-webkit-appearance:none;appearance:none;width:100px;height:6px;border-radius:3px;background:#ffffff1a;outline:none;cursor:pointer;transition:background .3s ease}.control-slider:hover{background:#ffffff2e}.control-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.control-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.laugh-slider::-webkit-slider-thumb{background:linear-gradient(135deg,#f59e0b,#fbbf24);box-shadow:0 0 10px #f59e0b80}.grind-slider::-webkit-slider-thumb{background:linear-gradient(135deg,#ef4444,#f87171);box-shadow:0 0 10px #ef444480}.avatar-reset-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;transition:background .3s ease,transform .3s ease}.avatar-reset-btn:hover{background:#ffffff26;transform:rotate(-180deg)}.avatar-settings-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;transition:background .3s ease,transform .3s ease}.avatar-settings-btn:hover{background:#ffffff26;transform:rotate(90deg)}.avatar-settings-panel{background:#0f0f1ebf;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:14px 20px;display:flex;flex-direction:column;gap:12px;margin-top:6px;animation:settingsFadeIn .2s ease}@keyframes settingsFadeIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.settings-row{display:flex;align-items:center;gap:10px}.settings-label{font-size:14px;color:#ffffffb3;min-width:70px;-webkit-user-select:none;user-select:none}.settings-value{font-size:12px;color:#ffffff80;min-width:35px;text-align:right;font-family:monospace}.settings-slider{flex:1}.eye-color-options{display:flex;gap:8px}.eye-color-btn{width:28px;height:28px;border-radius:50%;border:2px solid rgba(255,255,255,.15);cursor:pointer;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}.eye-color-btn:hover{transform:scale(1.15);border-color:#fff6}.eye-color-btn.active{border-color:#fff;box-shadow:0 0 12px #ffffff4d;transform:scale(1.1)}@media(max-width:1024px){.avatar-main-wrapper{top:42%}.avatar-container{width:420px;height:420px}.side-panel{width:250px}.debug-panel{max-width:300px;font-size:12px}.memory-panel{width:260px}.top-right-toggles{top:14px;right:14px}}@media(max-width:600px){.app{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.avatar-main-wrapper{top:38%;gap:8px}.avatar-container{width:300px;height:300px}.avatar-status{font-size:12px;letter-spacing:2px}.side-panel{width:calc(100vw - 32px);left:16px!important;right:16px!important;top:auto!important;bottom:calc(16px + env(safe-area-inset-bottom));max-height:50vh;border-radius:20px}.memory-panel{width:calc(100vw - 32px);right:16px;left:16px;max-height:300px}.top-right-toggles{top:calc(10px + env(safe-area-inset-top));right:10px;gap:8px}.panel-toggle{width:42px;height:42px}.debug-panel{bottom:calc(10px + env(safe-area-inset-bottom));left:10px;right:10px;max-width:none;width:auto;max-height:120px;font-size:11px;padding:10px;border-radius:14px}.mic-button{width:min(40vw,40vh);height:min(40vw,40vh);right:5%;bottom:calc(10% + env(safe-area-inset-bottom));top:auto;transform:none}.status-text{font-size:.65rem;letter-spacing:1.5px}}@media(max-width:430px){.avatar-main-wrapper{top:35%}.avatar-container{width:250px;height:250px}.avatar-status{font-size:11px;letter-spacing:1.5px}.debug-panel{max-height:100px;font-size:10px}.panel-toggle{width:38px;height:38px;font-size:14px}.top-right-toggles{gap:6px}.fullscreen-overlay{padding:8px}.overlay-content{width:100%;max-height:95vh;border-radius:12px;padding:12px}.overlay-header h2{font-size:1.1rem}}@media(max-height:500px)and (orientation:landscape){.avatar-main-wrapper{top:50%;flex-direction:row;gap:20px}.avatar-container{width:180px;height:180px}.debug-panel{max-height:80px}}@media(hover:none)and (pointer:coarse){.panel-item{padding:14px 12px;min-height:48px}.panel-action-btn{width:40px;height:40px;font-size:18px}.avatar-reset-btn:hover{transform:none}.panel-toggle:hover{transform:none;box-shadow:none}}.corner-btn{position:fixed;width:80px;height:80px;border-radius:20px;border:1px solid rgba(255,255,255,.15);background:#0f0f1ed9;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);cursor:pointer;z-index:50;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;transition:all .3s ease;box-shadow:0 4px 24px #0006}.corner-btn:hover{transform:scale(1.08);border-color:#8b5cf680;box-shadow:0 0 30px #8b5cf64d}.corner-btn:active{transform:scale(.95)}.corner-btn .corner-icon{font-size:32px;line-height:1}.corner-btn .corner-label{font-size:10px;font-weight:600;color:#ffffffb3;text-transform:uppercase;letter-spacing:.5px}.corner-btn.top-left{top:20px;left:20px}.corner-btn.top-right{top:20px;right:20px}.corner-btn.bottom-left{bottom:20px;left:20px}.corner-btn.bottom-right{bottom:20px;right:20px}.corner-close-x{position:absolute;top:2px;right:2px;width:22px;height:22px;background:#e63946;color:#fff;border-radius:50%;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1;box-shadow:0 2px 6px #e6394680;z-index:2;animation:badge-pop .3s ease}@keyframes badge-pop{0%{transform:scale(0)}60%{transform:scale(1.2)}to{transform:scale(1)}}.corner-btn.active{border-color:#e6394699;box-shadow:0 0 12px #e639464d,0 4px 12px #0000004d}.fullscreen-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:200;display:flex;align-items:center;justify-content:center;animation:overlayFadeIn .25s ease}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.overlay-content{width:90%;max-width:600px;max-height:85vh;background:linear-gradient(145deg,#1a1a2e,#0f0f1a);border:1px solid rgba(139,92,246,.2);border-radius:24px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #00000080}.overlay-content.wide{max-width:900px}.overlay-header{display:flex;align-items:center;gap:16px;padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0}.overlay-header h2{font-size:24px;font-weight:700;color:#fff;margin:0;flex:1}.overlay-close{width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.15);background:#ffffff0d;color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.overlay-close:hover{background:#ef44444d;border-color:#ef444480}.overlay-body{padding:16px 24px 24px;overflow-y:auto;flex:1}.overlay-body::-webkit-scrollbar{width:6px}.overlay-body::-webkit-scrollbar-track{background:transparent}.overlay-body::-webkit-scrollbar-thumb{background:#8b5cf64d;border-radius:3px}.overlay-section{margin-bottom:24px}.overlay-section h3{font-size:16px;font-weight:600;color:var(--accent-secondary, #06b6d4);margin:0 0 12px}.overlay-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;margin-bottom:8px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:12px;color:#fff;font-size:14px;line-height:1.5;transition:background .2s ease;width:100%;text-align:left;cursor:default}.overlay-item:hover{background:#ffffff0f}.overlay-item.shopping.done{opacity:.5;text-decoration:line-through}.overlay-item-actions{display:flex;gap:4px;flex-shrink:0}.overlay-item-actions button{width:32px;height:32px;border:none;background:#ffffff0d;border-radius:8px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.overlay-item-actions button:hover{background:#ffffff26;transform:scale(1.1)}.overlay-item-main{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.overlay-item-title{font-weight:600;color:#fff;font-size:17px;line-height:1.3}.overlay-item-sub{font-size:14px;color:#ffffff80}.overlay-item-delete{width:36px;height:36px;border:none;background:#ef44441a;border-radius:8px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.overlay-item-delete:hover{background:#ef44444d;transform:scale(1.1)}.model-selector-overlay{display:flex;gap:12px}.model-btn-large{flex:1;padding:16px;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:#ffffff08;color:#ffffffb3;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.model-btn-large.active{background:#8b5cf633;border-color:#8b5cf680;color:#fff;box-shadow:0 0 16px #8b5cf633}.model-btn-large:hover{background:#8b5cf61a;border-color:#8b5cf64d}.audiobook-search{display:flex;gap:8px;margin-bottom:20px}.audiobook-search-input{flex:1;padding:14px 16px;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:#fff;font-size:16px;outline:none;transition:border-color .2s ease}.audiobook-search-input::placeholder{color:#ffffff4d}.audiobook-search-input:focus{border-color:#8b5cf680}.audiobook-search-btn{padding:14px 20px;border-radius:12px;border:1px solid rgba(139,92,246,.3);background:#8b5cf626;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.audiobook-search-btn:hover:not(:disabled){background:#8b5cf64d}.audiobook-search-btn:disabled{opacity:.5;cursor:not-allowed}button.audiobook-result{cursor:pointer;border:none}button.audiobook-result:hover{background:#8b5cf61a;border-color:#8b5cf633}.audiobook-result-info{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.audiobook-play-icon{font-size:20px;flex-shrink:0;opacity:.6;transition:opacity .2s}button.audiobook-result:hover .audiobook-play-icon{opacity:1}.audiobook-status-bar{padding:12px 16px;margin-bottom:16px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.2);border-radius:12px;color:#fffc;font-size:14px;text-align:center}.audiobook-tabs{display:flex;gap:4px;margin-bottom:12px;background:#0000004d;border-radius:12px;padding:4px}.audiobook-tab{flex:1;padding:10px 16px;background:transparent;border:none;border-radius:10px;color:#ffffff80;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.audiobook-tab.active{background:#8b5cf64d;color:#fff;font-weight:600}.audiobook-tab:hover:not(.active){background:#ffffff0d;color:#ffffffb3}.librivox-book{margin-bottom:4px}.librivox-chapters{margin-left:16px;border-left:2px solid rgba(139,92,246,.3);padding-left:8px;margin-bottom:8px}.librivox-chapter{padding:8px 12px!important;font-size:13px!important;display:flex!important;justify-content:space-between!important;align-items:center!important;background:#0003!important;margin-bottom:2px!important}.librivox-chapter:hover{background:#8b5cf626!important}.chapter-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chapter-duration{color:#fff6;font-size:12px;margin-left:8px;flex-shrink:0}.youtube-player{padding-bottom:16px!important}.youtube-inline{position:relative;width:95%;max-width:700px;margin:12px auto 0;background:#0f0f1ee6;border:1px solid rgba(139,92,246,.3);border-radius:12px;padding:8px 12px 12px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:20}.youtube-inline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.youtube-inline-title{color:#fff;font-size:16px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;margin-right:8px}.youtube-inline-frame{width:100%;height:280px;border:none;border-radius:8px}.audiobook-player{position:fixed;bottom:0;left:0;right:0;padding:12px 24px;background:linear-gradient(180deg,#0f0f1ef2,#0a0a14fa);border-top:1px solid rgba(139,92,246,.2);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:150;display:flex;flex-direction:column;gap:8px}.audiobook-player-info{display:flex;justify-content:space-between;align-items:center}.audiobook-player-title{color:#fff;font-weight:600;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.audiobook-player-time{color:#ffffff80;font-size:12px;font-family:JetBrains Mono,monospace;flex-shrink:0;margin-left:12px}.audiobook-player-controls{display:flex;align-items:center;gap:12px}.audiobook-ctrl-btn{width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.15);background:#ffffff0d;color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.audiobook-ctrl-btn:hover{background:#8b5cf633;border-color:#8b5cf666;transform:scale(1.1)}.audiobook-ctrl-btn.stop:hover{background:#ef444433;border-color:#ef444466}.audiobook-progress{flex:1;height:6px;-webkit-appearance:none;appearance:none;background:#ffffff1a;border-radius:3px;outline:none;cursor:pointer}.audiobook-progress::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent-primary, #8b5cf6);cursor:pointer;border:none;box-shadow:0 0 8px #8b5cf666}.audiobook-progress::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--accent-primary, #8b5cf6);cursor:pointer;border:none}.audiobook-search{display:flex;flex-direction:column;gap:16px;height:100%}.audiobook-search-input{width:100%;padding:14px 16px;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:#fff;font-size:16px;transition:all .2s ease}.audiobook-search-input:focus{outline:none;border-color:var(--accent-primary, #8b5cf6);background:#ffffff14}.audiobook-search-btn{width:100%;padding:14px;border-radius:12px;background:var(--accent-primary, #8b5cf6);color:#fff;border:none;font-weight:600;font-size:16px;cursor:pointer;transition:opacity .2s,transform .1s}.audiobook-search-btn:hover{opacity:.9}.audiobook-search-btn:active{transform:scale(.98)}.audiobook-search-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.audiobook-tabs{display:flex;gap:8px;margin-bottom:8px;flex-wrap:wrap}.audiobook-results-list{display:flex;flex-direction:column;gap:8px;overflow-y:auto;flex:1}.audiobook-result-info{display:flex;flex-direction:column;flex:1;min-width:0}.audiobook-play-icon{font-size:20px;color:var(--accent-secondary, #06b6d4);flex-shrink:0;padding:0 8px}.librivox-book{display:flex;flex-direction:column;gap:8px;width:100%}.librivox-chapters{display:flex;flex-direction:column;gap:6px;padding-left:16px;border-left:2px solid rgba(255,255,255,.1);margin-top:-4px;margin-bottom:12px}.librivox-chapter{background:#ffffff05;border:1px solid transparent}.librivox-chapter:hover{background:#ffffff0d;border-color:#ffffff1a}.chapter-title{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:13px}.chapter-duration{font-size:12px;color:#ffffff80}@media(max-width:768px){.corner-btn{width:64px;height:64px;border-radius:16px}.corner-btn .corner-icon{font-size:26px}.corner-btn .corner-label{font-size:8px}.corner-btn.top-left{top:12px;left:12px}.corner-btn.top-right{top:12px;right:12px}.corner-btn.bottom-left{bottom:12px;left:12px}.corner-btn.bottom-right{bottom:12px;right:12px}.overlay-content{width:95%;max-height:90vh;border-radius:16px}.overlay-header h2{font-size:20px}.audiobook-player{padding:10px 16px}}
