:root{font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body{min-width:320px}a{text-decoration:none}button{font-family:inherit}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.375rem;border:none;border-radius:var(--radius-md);font-family:inherit;font-weight:600;text-decoration:none;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden;-webkit-user-select:none;user-select:none;white-space:nowrap}.btn:focus{outline:none;box-shadow:0 0 0 2px #3b82f64d}.btn:focus:not(:focus-visible){box-shadow:none}.btn--small{padding:.375rem .625rem;font-size:.7rem;min-height:28px}.btn--medium{padding:.5rem .875rem;font-size:.8rem;min-height:32px}.btn--large{padding:.75rem 1.25rem;font-size:.9rem;min-height:40px}.btn--primary{background:var(--gradient-accent);color:#fff;box-shadow:var(--shadow-sm)}.btn--primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn--primary:active:not(:disabled){transform:translateY(0)}.btn--secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.btn--secondary:hover:not(:disabled){background:var(--bg-tertiary);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn--secondary:active:not(:disabled){transform:translateY(0)}.btn--ghost{background:transparent;color:var(--text-secondary);border:1px solid transparent}.btn--ghost:hover:not(:disabled){background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border-color)}.btn--ghost:active:not(:disabled){background:var(--bg-tertiary)}.btn--success{background:var(--gradient-success);color:#fff;box-shadow:var(--shadow-sm)}.btn--success:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn--danger{background:var(--gradient-error);color:#fff;box-shadow:var(--shadow-sm)}.btn--danger:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn--warning{background:var(--warning-color);color:#fff;box-shadow:var(--shadow-sm)}.btn--warning:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn--icon{padding:.375rem;min-width:32px;min-height:32px}.btn--icon.btn--small{min-width:24px;min-height:24px;padding:.25rem}.btn--icon.btn--large{min-width:40px;min-height:40px;padding:.5rem}.btn--disabled{opacity:.6;cursor:not-allowed;transform:none!important;box-shadow:none!important}.btn--loading{cursor:wait}.btn--loading .btn__content{opacity:.7}.btn__content{display:flex;align-items:center;gap:.375rem}.btn__icon{flex-shrink:0;transition:transform .2s ease}.btn__icon--left{margin-right:.125rem}.btn__icon--right{margin-left:.125rem}.btn:hover .btn__icon{transform:scale(1.05)}.btn__loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center}.btn__loading-icon{animation:spin 1s linear infinite}.btn-group{display:inline-flex;border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm)}.btn-group .btn{border-radius:0;border-right:1px solid var(--border-color)}.btn-group .btn:first-child{border-top-left-radius:var(--radius-md);border-bottom-left-radius:var(--radius-md)}.btn-group .btn:last-child{border-top-right-radius:var(--radius-md);border-bottom-right-radius:var(--radius-md);border-right:none}@media (max-width: 768px){.btn--large{padding:.625rem 1rem;font-size:.85rem;min-height:36px}.btn--icon.btn--large{min-width:36px;min-height:36px;padding:.5rem}}@media (max-width: 480px){.btn--medium{padding:.375rem .75rem;font-size:.75rem;min-height:28px}.btn--icon.btn--medium{min-width:28px;min-height:28px;padding:.375rem}}.language-selector{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid var(--border-color, #e1e5e9);border-radius:6px;background:var(--bg-secondary, #ffffff);color:var(--text-primary, #333333);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none;-webkit-user-select:none;user-select:none}.language-selector:hover{background:var(--bg-hover, #f8f9fa);border-color:var(--border-hover, #c1c7cd);transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.language-selector:active{transform:translateY(0);box-shadow:0 1px 4px #0000001a}.language-selector__text{font-weight:500}.language-selector--minimal{padding:6px 10px;min-width:40px;justify-content:center}.language-selector--minimal .language-code{font-weight:600;font-size:12px;letter-spacing:.5px}.language-selector--dropdown{position:relative;padding:0}.language-selector__button{display:flex;align-items:center;gap:8px;padding:8px 12px;border:none;background:transparent;color:inherit;font-size:inherit;font-weight:inherit;cursor:pointer;width:100%;text-align:left}.language-selector__button:hover{background:var(--bg-hover, #f8f9fa)}@media (prefers-color-scheme: dark){.language-selector{--bg-secondary: #2d3748;--text-primary: #e2e8f0;--border-color: #4a5568;--border-hover: #718096;--bg-hover: #4a5568}}@media (max-width: 768px){.language-selector{padding:6px 10px;font-size:13px}.language-selector--minimal{padding:4px 8px;min-width:36px}.language-selector--minimal .language-code{font-size:11px}}.options-menu{position:relative}.options-toggle{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:.375rem;cursor:pointer;transition:all .2s ease;min-width:28px;min-height:28px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.options-toggle:hover{background:var(--bg-secondary);color:var(--text-primary);transform:translateY(-1px);box-shadow:var(--shadow-md);border-color:var(--accent-color)}.options-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;background:var(--chat-menu-bg, var(--bg-card));border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:.5rem;min-width:200px;z-index:9999;animation:slideDown .15s ease-out;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}@keyframes slideDown{0%{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.options-item{width:100%;padding:.625rem .875rem;border:none;background:transparent;cursor:pointer;border-radius:var(--radius-md);text-align:left;transition:all .2s ease;display:flex;align-items:center;gap:.625rem;font-size:.8rem;font-weight:500;color:var(--text-primary);position:relative}.options-item:hover:not(:disabled){background:var(--bg-secondary);transform:translate(2px);box-shadow:var(--shadow-sm)}.options-item.active{background:var(--gradient-accent);color:#fff;box-shadow:var(--shadow-md)}.options-item.active:hover{background:var(--accent-hover)}.options-item:disabled{opacity:.5;cursor:not-allowed;transform:none}.options-item:disabled:hover{background:transparent;transform:none;box-shadow:none}.options-item:not(:last-child){margin-bottom:.125rem}.options-item-wrapper{position:relative}.language-selector-item{cursor:default;justify-content:space-between;padding-right:.5rem}.language-selector-item:hover{background:transparent;transform:none;box-shadow:none}.language-selector-item .language-selector{margin-left:auto}@media (max-width: 768px){.options-dropdown{left:auto;right:0;min-width:180px}}@media (max-width: 480px){.options-toggle{min-width:24px;min-height:24px}.options-dropdown{min-width:160px;padding:.375rem}.options-item{padding:.5rem .625rem;font-size:.75rem;gap:.5rem}}@media (max-width: 360px){.options-dropdown{min-width:140px;padding:.25rem}.options-item{padding:.375rem .5rem;font-size:.7rem;gap:.375rem}}.chat-header{padding:.5rem .75rem;background:var(--bg-card);border-bottom:1px solid var(--border-color);position:relative;overflow:visible;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:100}@media (max-width: 1023px){:root{--mobile-chat-header-height: 56px}}.chat-header:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gradient-accent);border-radius:0 0 2px 2px}.chat-header__toolbar{display:flex;align-items:center;gap:.5rem;width:100%;min-height:40px}.chat-header__start,.chat-header__end{display:flex;align-items:center;gap:.35rem;flex-shrink:0}.chat-header__brand{flex:1;min-width:0;text-align:center}.chat-header__title{font-size:1rem;font-weight:700;background:var(--gradient-accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;line-height:1.2;letter-spacing:-.02em}.chat-header__meta{display:flex;align-items:center;justify-content:center;gap:.35rem;margin:.125rem 0 0;font-size:.65rem;font-weight:500;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-header__meta-text{overflow:hidden;text-overflow:ellipsis}.chat-header__meta-sep{opacity:.6}.chat-header__dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.chat-header__dot--online{background:var(--success-color);box-shadow:0 0 0 2px color-mix(in srgb,var(--success-color) 35%,transparent)}.chat-header__dot--offline{background:var(--error-color);box-shadow:0 0 0 2px color-mix(in srgb,var(--error-color) 30%,transparent)}.chat-header__dot--checking{background:var(--warning-color);animation:chat-header-dot-pulse 1.5s ease-in-out infinite}.chat-header__dot--unknown{background:var(--text-muted)}@keyframes chat-header-dot-pulse{0%,to{opacity:1}50%{opacity:.45}}.chat-header__icon-btn{display:inline-flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;transition:border-color var(--transition-fast),background var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast);box-shadow:var(--shadow-sm);text-decoration:none;flex-shrink:0}.chat-header__icon-btn:hover{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--accent-color);transform:translateY(-1px);box-shadow:var(--shadow-md)}.chat-header__icon-btn--accent{background:color-mix(in srgb,var(--accent-color) 14%,var(--bg-tertiary));color:var(--accent-color);border-color:color-mix(in srgb,var(--accent-color) 35%,var(--border-color))}.chat-header__icon-btn--accent:hover{background:color-mix(in srgb,var(--accent-color) 22%,var(--bg-secondary));color:var(--accent-hover)}.chat-header__icon-btn--link:hover{background:var(--accent-color);color:#fff;border-color:transparent}.chat-header__icon-btn--danger:hover{background:var(--error-color);color:#fff;border-color:transparent}.chat-header__icon-btn svg{flex-shrink:0}.personality-selector{position:relative}.personality-menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--chat-menu-bg, var(--bg-card));border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl);padding:.75rem;min-width:min(420px,90vw);max-height:min(60vh,540px);overflow:auto;z-index:9999;animation:personality-menu-in .15s ease-out;backdrop-filter:blur(12px) saturate(120%);-webkit-backdrop-filter:blur(12px) saturate(120%);color:var(--text-primary)}@keyframes personality-menu-in{0%{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.personality-option{width:100%;padding:.625rem .875rem;border:none;background:transparent;cursor:pointer;border-radius:var(--radius-md);text-align:left;transition:all .2s ease;display:flex;align-items:center;justify-content:space-between;color:var(--text-primary)}.personality-option:hover{background:var(--bg-secondary);transform:translate(2px)}.personality-option.active{background:var(--gradient-accent);color:#fff;box-shadow:var(--shadow-md)}.personality-option-content{display:flex;flex-direction:column;gap:2px}.personality-name{font-weight:700;font-size:.85rem;color:var(--text-primary)}.personality-option.active .personality-name{color:#fff}.personality-style{font-size:.7rem;opacity:.85;text-transform:capitalize;color:var(--text-secondary)}.personality-option.active .personality-style{color:#ffffffe6}.personality-search{display:flex;align-items:center;gap:8px;margin-bottom:8px}.personality-search input{flex:1;height:34px;padding:6px 10px;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);outline:none}.personality-check{color:#fff;flex-shrink:0}@media (max-width: 1023px){.personality-menu{position:fixed;top:calc(env(safe-area-inset-top,0px) + var(--mobile-chat-header-height, 56px) + 8px);right:12px;left:12px;min-width:0;max-width:none}}@media (max-width: 480px){.chat-header{padding:.45rem .5rem}.chat-header__title{font-size:.95rem}.chat-header__meta{font-size:.6rem}.chat-header__icon-btn{width:2rem;height:2rem}.chat-header__toolbar{gap:.35rem}}@media (max-width: 360px){.chat-header__icon-btn{width:1.85rem;height:1.85rem}}.message{display:flex;margin-bottom:.5rem;animation:messageSlideIn .2s ease-out}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(5px) scale(.99)}to{opacity:1;transform:translateY(0) scale(1)}}.message-container{display:flex;align-items:flex-start;gap:.375rem;max-width:95%}.message-container--user{margin-left:auto;flex-direction:row-reverse}.message-container--bot{margin-right:auto}.message-content{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:.625rem .875rem;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:all .2s ease;min-width:120px}.message-content:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:var(--gradient-accent)}.message-content:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.message--user .message-content{background:var(--gradient-accent);color:#fff;border-color:var(--accent-color);box-shadow:var(--shadow-md)}.message--user .message-content:before{background:var(--accent-hover)}.message--user .message-text{color:#fff}.message--system .message-content{background:var(--gradient-secondary);color:#fff;border-color:var(--warning-color);font-style:italic;box-shadow:var(--shadow-md)}.message--error .message-content{background:var(--bg-card);border:1px solid var(--error-color);box-shadow:var(--shadow-md)}.message--error .message-content:before{background:var(--gradient-error)}.message-text{color:var(--text-primary);line-height:1.4;font-size:.8rem;font-weight:500;margin:0 0 .5rem;word-wrap:break-word}.message-avatar{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:var(--bg-tertiary);border-radius:50%;border:1px solid var(--border-color);flex-shrink:0;margin-top:.125rem}.emotion-icon{color:var(--accent-color)}.message-footer{display:flex;justify-content:space-between;align-items:center;gap:.5rem;margin-top:.375rem;padding-top:.375rem;border-top:1px solid var(--border-light)}.message-meta{display:flex;align-items:center;gap:.375rem;flex-wrap:wrap}.message-badge{display:inline-flex;align-items:center;gap:.2rem;background:var(--bg-tertiary);color:var(--text-secondary);padding:.15rem .3rem;border-radius:var(--radius-sm);font-size:.55rem;font-weight:600;border:1px solid var(--border-color);letter-spacing:.025em;text-transform:uppercase;box-shadow:var(--shadow-sm)}.message-badge--language{background:var(--accent-light);color:var(--accent-color);border-color:var(--accent-color)}.language-note{font-size:.5rem;opacity:.7;font-style:italic;margin-left:.125rem}.message-controls{display:flex;align-items:center;gap:.375rem;flex-shrink:0}.message-analysis{display:flex;gap:.25rem;align-items:center}.analysis-item{display:inline-flex;align-items:center;gap:.15rem;background:var(--bg-tertiary);color:var(--text-secondary);padding:.15rem .25rem;border-radius:var(--radius-sm);font-size:.55rem;font-weight:600;border:1px solid var(--border-color);letter-spacing:.025em;box-shadow:var(--shadow-sm)}.audio-button{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:.2rem;transition:all .2s ease;min-width:20px;min-height:20px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.audio-button:hover{background:var(--accent-color);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-md)}.audio-button--playing{background:var(--accent-color);color:#fff;animation:pulse-audio 1.5s infinite}.audio-button--playing:hover{background:var(--accent-hover);transform:translateY(-1px) scale(1.05)}.audio-button--checking{background-color:var(--muted-color);color:var(--text-muted);cursor:not-allowed}.audio-button--unavailable{background-color:var(--error-color);color:#fff;cursor:not-allowed;opacity:.7}.audio-button--unavailable:hover{background-color:var(--error-color);transform:none}.spinning{animation:spin 1s linear infinite}@keyframes pulse-audio{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.message-timestamp{display:flex;align-items:center;gap:.2rem;font-size:.55rem;color:var(--text-muted);font-weight:400;opacity:.7}@media (max-width: 768px){.message-container{max-width:98%}.message-content{padding:.5rem .75rem;min-width:100px}.message-text{font-size:.75rem}.message-avatar{width:18px;height:18px}.message-footer{flex-direction:column;align-items:flex-start;gap:.25rem}.message-controls{width:100%;justify-content:flex-end}.message-analysis{gap:.2rem}.analysis-item{padding:.125rem .2rem;font-size:.5rem}}@media (max-width: 480px){.message-container{max-width:99%}.message-content{padding:.375rem .625rem;min-width:80px}.message-text{font-size:.7rem}.message-avatar{width:16px;height:16px}.message-badge{padding:.125rem .25rem;font-size:.5rem}.analysis-item{padding:.1rem .15rem;font-size:.45rem}.audio-button{min-width:18px;min-height:18px;padding:.15rem}}.streaming-cursor{animation:blink .8s infinite;color:var(--accent-color);font-weight:700;margin-left:2px}.message-badge--streaming{background:linear-gradient(45deg,var(--accent-color),var(--accent-color-light));color:#fff;animation:pulse 1.5s infinite;font-size:11px;padding:2px 8px;border-radius:12px}@keyframes pulse{0%{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.message--bot.streaming{animation:none}.message--bot.streaming .message-text{transition:all .1s ease}.typing-indicator{display:flex;gap:4px;align-items:center;margin-bottom:8px}.typing-indicator span{width:6px;height:6px;border-radius:50%;background:var(--accent-color);animation:typing 1.4s infinite ease-in-out}.audio-preview{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:.75rem;margin:.5rem 0;box-shadow:var(--shadow-sm);animation:slideIn .3s ease-out}.audio-preview-content{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.audio-controls{display:flex;align-items:center;gap:.5rem;flex:1}.audio-play-button{background:var(--accent-color);color:#fff;border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;flex-shrink:0}.audio-play-button:hover{background:var(--accent-hover);transform:scale(1.05)}.audio-info{flex:1;min-width:0}.audio-time{font-size:.7rem;color:var(--text-secondary);margin-bottom:.25rem;font-weight:500}.audio-loading{color:var(--accent-color);font-style:italic;animation:pulse 1.5s infinite}.audio-progress{width:100%;height:4px;background:var(--bg-tertiary);border-radius:2px;overflow:hidden;position:relative}.audio-progress-bar{height:100%;background:var(--accent-color);border-radius:2px;transition:width .1s ease}.audio-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.audio-action-button{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:.375rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:28px;min-height:28px}.audio-action-button:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.audio-action-button--send{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.audio-action-button--send:hover{background:var(--accent-hover)}.audio-action-button--delete{background:var(--error-light);color:var(--error-color);border-color:var(--error-color)}.audio-action-button--delete:hover{background:var(--error-color);color:#fff}.transcription-status{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%}.transcription-progress{width:100%;height:4px;background-color:#e5e7eb;border-radius:2px;overflow:hidden}.transcription-progress-bar{height:100%;background:linear-gradient(90deg,#3b82f6,#1d4ed8);border-radius:2px;transition:width .3s ease;animation:pulse-progress 2s ease-in-out infinite}.transcription-text{font-size:12px;color:#6b7280;font-weight:500}@keyframes pulse-progress{0%,to{opacity:1}50%{opacity:.7}}@media (max-width: 768px){.audio-preview{padding:.5rem}.audio-preview-content{gap:.5rem}.audio-controls{gap:.375rem}.audio-play-button{width:28px;height:28px}.audio-time{font-size:.65rem}.audio-action-button{padding:.25rem;min-width:24px;min-height:24px}}@media (max-width: 480px){.audio-preview-content{flex-direction:column;align-items:stretch;gap:.5rem}.audio-controls,.audio-actions{justify-content:center}}.chat-input{padding:1rem;background:var(--bg-card);border-top:1px solid var(--border-color);position:relative;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:var(--shadow-lg)}.chat-input:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gradient-accent);border-radius:0 0 2px 2px}.input-container{display:flex;gap:.75rem;align-items:flex-end;margin-bottom:.5rem}.input-wrapper{flex:1;position:relative}.message-textarea{width:100%;min-height:40px;max-height:100px;padding:.625rem .875rem;border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--bg-secondary);color:var(--text-primary);font-family:inherit;font-size:.85rem;font-weight:500;resize:none;outline:none;transition:all .2s ease;line-height:1.4;box-shadow:var(--shadow-sm)}.message-textarea:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #3b82f61a;background:var(--bg-primary);transform:translateY(-1px)}.message-textarea:disabled{opacity:.6;cursor:not-allowed;background:var(--bg-tertiary);transform:none}.message-textarea::placeholder{color:var(--text-muted);font-weight:400}.message-textarea{overflow-y:hidden;resize:none}.chat-input .send-button{flex-shrink:0;min-width:40px;min-height:40px;border-radius:var(--radius-lg);background:var(--gradient-accent);color:#fff!important;box-shadow:var(--shadow-md);transition:all .2s ease;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-weight:600}.chat-input .send-button .btn__icon{color:#fff!important;opacity:1!important}.chat-input .send-button svg,.chat-input .send-button .btn__icon svg{color:#fff!important;fill:#fff!important;stroke:#fff!important}.chat-input .send-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-lg),var(--glow);filter:brightness(1.1)}.chat-input .send-button:active:not(:disabled){transform:translateY(0)}.chat-input .send-button:disabled{opacity:.8;cursor:not-allowed;transform:none;box-shadow:none;background:var(--bg-secondary);color:var(--text-secondary)!important;border:1px solid var(--border-color)}.chat-input .send-button:disabled .btn__icon{opacity:1!important;color:var(--text-secondary)!important}.chat-input .send-button:disabled svg,.chat-input .send-button:disabled .btn__icon svg{color:var(--text-secondary)!important;fill:var(--text-secondary)!important;stroke:var(--text-secondary)!important}.input-hint{display:flex;justify-content:center;font-size:.7rem;color:var(--text-muted);font-weight:500;letter-spacing:.025em}.input-hint span{padding:.25rem .5rem;background:var(--bg-tertiary);border-radius:var(--radius-sm);border:1px solid var(--border-color)}.audio-error{display:flex;align-items:center;gap:.5rem;background:var(--error-light);color:var(--error-color);padding:.625rem .875rem;border-radius:var(--radius-md);margin-bottom:.5rem;font-size:.75rem;font-weight:500;border:1px solid var(--error-color)}.input-buttons{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.voice-button{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:.5rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:40px;min-height:40px;color:var(--text-secondary)}.voice-button:hover:not(:disabled){background:var(--accent-color);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-md)}.voice-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.recording-controls{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.recording-timer{background:var(--error-light);color:var(--error-color);padding:.5rem .75rem;border-radius:var(--radius-md);font-size:.75rem;font-weight:600;border:1px solid var(--error-color);min-width:70px;text-align:center;animation:pulse-recording 1s infinite}@keyframes pulse-recording{0%,to{opacity:1}50%{opacity:.7}}.recording-button{background:var(--error-color);color:#fff;border:none;border-radius:var(--radius-lg);padding:.5rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:40px;min-height:40px}.recording-button:hover{background:var(--error-hover);transform:scale(1.05)}.recording-button--stop{animation:pulse-recording 1s infinite}@media (max-width: 768px){.chat-input{padding:.75rem}.input-container{gap:.5rem}.message-textarea{min-height:36px;padding:.5rem .75rem;font-size:.8rem}.chat-input .send-button,.voice-button,.recording-button{min-width:36px;min-height:36px;padding:.5rem}.input-buttons,.recording-controls{gap:.5rem}.recording-timer{padding:.5rem .75rem;font-size:.7rem;min-width:60px}.input-hint{font-size:.65rem}.audio-error{font-size:.7rem;padding:.5rem .75rem}}@media (max-width: 480px){.chat-input{padding:.5rem}.input-container{gap:.375rem}.message-textarea{min-height:32px;padding:.375rem .625rem;font-size:.75rem}.chat-input .send-button,.voice-button,.recording-button{min-width:32px;min-height:32px;padding:.375rem}.input-buttons,.recording-controls{gap:.375rem}.recording-timer{padding:.375rem .625rem;font-size:.65rem;min-width:55px}.input-hint{font-size:.6rem}.input-hint span{padding:.2rem .375rem}.audio-error{font-size:.65rem;padding:.375rem .625rem}}@media (max-width: 360px){.chat-input{padding:.375rem}.input-container{gap:.25rem}.message-textarea{min-height:28px;padding:.25rem .5rem;font-size:.7rem}.chat-input .send-button,.voice-button,.recording-button{min-width:28px;min-height:28px;padding:.25rem}.input-buttons,.recording-controls{gap:.25rem}.recording-timer{padding:.25rem .5rem;font-size:.6rem;min-width:50px}.input-hint{font-size:.55rem}.input-hint span{padding:.15rem .25rem}.audio-error{font-size:.6rem;padding:.25rem .5rem}}.status-bar{padding:.5rem .75rem;background:var(--bg-tertiary);border-top:1px solid var(--border-color);font-size:.65rem;color:var(--text-muted);font-weight:500;letter-spacing:.025em;text-transform:uppercase;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.375rem;position:sticky;bottom:0;width:100%;z-index:1}.status-left,.status-right{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.status-right{margin-left:auto}.status-item{display:flex;align-items:center;gap:.25rem;padding:.2rem .375rem;background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border-color);font-size:.6rem;font-weight:600;letter-spacing:.025em;text-transform:uppercase;box-shadow:var(--shadow-sm);transition:all .2s ease}.status-item:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.status-item--warning{background:var(--warning-color);color:#fff;border-color:var(--warning-color)}.status-item--streaming{color:var(--accent-color);animation:pulse 2s infinite}.status-item--info{color:var(--accent-color);opacity:.8}.status-icon{flex-shrink:0;color:var(--text-secondary)}.status-icon.loading{animation:spin 1s linear infinite}.status-icon.streaming{animation:pulse 2s infinite}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}@media (max-width: 768px){.status-bar{padding:.375rem .5rem;flex-direction:column;align-items:flex-start;gap:.25rem}.status-left,.status-right{width:100%;justify-content:center;gap:.375rem}.status-item{padding:.15rem .3rem;font-size:.55rem}}@media (max-width: 480px){.status-bar{padding:.25rem .375rem;font-size:.6rem}.status-left,.status-right{gap:.25rem}.status-item{padding:.125rem .25rem;font-size:.5rem;gap:.2rem}}.context-info{margin:.5rem 0;border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-tertiary);border:1px solid var(--border-color)}.context-toggle{width:100%;padding:.5rem .75rem;background:var(--bg-secondary);border:none;border-radius:var(--radius-lg);cursor:pointer;display:flex;align-items:center;gap:.5rem;font-size:.75rem;font-weight:500;color:var(--text-primary);transition:all .2s ease}.context-toggle:hover{background:var(--bg-tertiary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.context-arrow{margin-left:auto;transition:transform .2s ease}.context-details{padding:.75rem;background:var(--bg-secondary);border-top:1px solid var(--border-color);animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.context-section{margin-bottom:.75rem}.context-section:last-child{margin-bottom:0}.context-section-header{display:flex;align-items:center;gap:.375rem;margin-bottom:.375rem;font-size:.7rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.025em}.context-summary{font-size:.75rem;line-height:1.4;color:var(--text-primary);margin:0;padding:.375rem;background:var(--bg-tertiary);border-radius:var(--radius-md);border-left:3px solid var(--accent-color)}.context-topics,.context-names{display:flex;flex-wrap:wrap;gap:.25rem}.context-topic,.context-name{padding:.2rem .5rem;background:var(--gradient-accent);color:#fff;border-radius:var(--radius-sm);font-size:.65rem;font-weight:500;text-transform:capitalize}.context-name{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.context-keypoints{display:flex;flex-direction:column;gap:.25rem}.context-keypoint{padding:.375rem .5rem;background:var(--bg-tertiary);border-radius:var(--radius-md);font-size:.7rem;line-height:1.3;color:var(--text-primary);border-left:2px solid var(--warning-color)}.context-stats{display:flex;gap:1rem;flex-wrap:wrap}.context-stat{display:flex;align-items:center;gap:.25rem;font-size:.7rem}.stat-label{color:var(--text-secondary);font-weight:500}.stat-value{color:var(--text-primary);font-weight:600;background:var(--bg-tertiary);padding:.125rem .375rem;border-radius:var(--radius-sm);border:1px solid var(--border-color)}@media (max-width: 768px){.context-toggle{padding:.375rem .5rem;font-size:.7rem}.context-details{padding:.5rem}.context-summary{font-size:.7rem;padding:.25rem}.context-topic,.context-name{font-size:.6rem;padding:.15rem .375rem}.context-keypoint{font-size:.65rem;padding:.25rem .375rem}.context-stats{gap:.75rem}.context-stat{font-size:.65rem}}@media (max-width: 480px){.context-info{margin:.375rem 0}.context-toggle{padding:.25rem .375rem;font-size:.65rem;gap:.375rem}.context-details{padding:.375rem}.context-section{margin-bottom:.5rem}.context-section-header{font-size:.65rem;margin-bottom:.25rem}}.landing-page{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;color:var(--text-primary);background:var(--bg-primary);overflow-x:hidden;scroll-padding-top:84px}.landing-container{max-width:1400px;margin:0 auto;padding:0 var(--space-xl)}@media (max-width: 768px){.landing-container{padding:0 var(--space-lg)}}@media (max-width: 480px){.landing-container{padding:0 var(--space-md)}}.landing-header{position:fixed;top:0;left:0;right:0;background:color-mix(in srgb,var(--bg-primary) 92%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-color);z-index:1000;padding:var(--space-lg) 0;transition:var(--transition-normal)}.landing-header.scrolled{background:var(--bg-primary);box-shadow:0 1px 0 var(--border-color)}.landing-header-inner{display:flex;justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto;padding:0 var(--space-xl);flex-wrap:nowrap}.landing-page .logo{display:flex;align-items:center;gap:var(--space-sm);font-weight:700;font-size:var(--font-size-xl);text-decoration:none;transition:var(--transition-normal)}.landing-page .logo:hover{transform:scale(1.05)}.landing-page .logo:hover .logo-icon{box-shadow:none}.landing-page .logo-text{color:var(--text-primary);font-weight:800;position:relative;letter-spacing:-.02em}.landing-page .landing-header .logo-text:after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:2px;background:var(--accent-color);transition:width .3s ease;border-radius:2px}.landing-page .landing-header .logo:hover .logo-text:after{width:100%}.nav-menu{display:flex;align-items:center;gap:var(--space-2xl)}.nav-menu a,.nav-menu .nav-link{text-decoration:none;color:var(--text-secondary);font-weight:500;font-size:var(--font-size-sm);transition:var(--transition-normal);position:relative;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);background:none;border:none;cursor:pointer;font-family:inherit}.nav-menu a:hover,.nav-menu .nav-link:hover{color:var(--text-primary);background:#ffffff0d}.nav-menu a:after,.nav-menu .nav-link:after{content:"";position:absolute;bottom:-2px;left:50%;width:0;height:2px;background:var(--accent-color);transition:var(--transition-normal);transform:translate(-50%)}.nav-menu a:hover:after,.nav-menu .nav-link:hover:after{width:80%}.mobile-menu-btn,.mobile-menu{display:none}@media (max-width: 768px){.mobile-menu-btn{display:flex;flex-direction:column;gap:4px;cursor:pointer;padding:var(--space-sm);background:none;border:none;z-index:1001;margin-left:auto}.mobile-menu-btn span{width:22px;height:2px;background:var(--text-primary);transition:var(--transition-normal);border-radius:1px}.mobile-menu-btn.active span:nth-child(1){transform:rotate(45deg) translate(6px,6px)}.mobile-menu-btn.active span:nth-child(2){opacity:0}.mobile-menu-btn.active span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}.mobile-menu{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-lg);background:var(--bg-card);border-top:1px solid var(--border-color);box-shadow:var(--shadow-lg);position:absolute;top:100%;left:0;right:0;z-index:1000;animation:slideInDown .25s var(--ease-out)}.mobile-nav-link{background:none;border:none;color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:600;padding:var(--space-sm) var(--space-md);text-align:left;cursor:pointer;transition:var(--transition-normal);border-radius:var(--radius-md)}.mobile-nav-link:hover{color:var(--text-primary);background:#ffffff0d}.landing-page .mobile-menu .btn{padding:var(--space-sm) var(--space-lg);font-size:var(--font-size-sm);border-radius:var(--radius-lg)}.mobile-language-selector{display:flex;justify-content:center;padding:var(--space-md) 0;border-top:1px solid var(--border-color);margin-top:var(--space-sm)}.mobile-language-selector .language-selector{width:100%;max-width:200px}.mobile-language-selector .language-selector button{width:100%;justify-content:center;padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-weight:500;transition:all .2s ease}.mobile-language-selector .language-selector button:hover{background:var(--bg-primary);border-color:var(--accent-color)}.landing-header-inner{gap:var(--space-sm)}.landing-page .logo{gap:var(--space-xs)}.landing-page .logo-icon{width:40px;height:40px;font-size:1.1rem}.landing-page .logo-text{font-size:1.1rem}.hero-image{margin-top:12px}}.landing-page .btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-lg);font-weight:600;text-decoration:none;transition:var(--transition-normal);border:2px solid transparent;cursor:pointer;font-size:var(--font-size-sm);position:relative;overflow:hidden;white-space:nowrap}.landing-page .btn-primary{background:var(--accent-color);color:#fff;box-shadow:none;border-color:transparent}.landing-page .btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.landing-page .btn-outline{background:transparent;color:var(--text-primary);border-color:var(--border-color)}.landing-page .btn-outline:hover{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border-light);transform:translateY(-1px);box-shadow:none}.landing-page .btn-large{padding:var(--space-md) var(--space-xl);font-size:var(--font-size-base);border-radius:var(--radius-xl)}.landing-page .btn-full{width:100%}.landing-page .btn-loading{position:relative;color:transparent}.landing-page .btn-loading:after{content:"";position:absolute;width:20px;height:20px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}.hero-section{padding:calc(var(--space-3xl) + 24px) 0 var(--space-2xl);background:var(--bg-primary);min-height:100svh;display:flex;align-items:center;position:relative;overflow:hidden}.hero-section:before{display:none}.hero-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,340px),1fr));gap:clamp(var(--space-xl),4vw,var(--space-3xl));align-items:center;position:relative;z-index:2}.hero-text,.hero-visual{min-width:0}.hero-title{font-size:clamp(2rem,4vw,3.25rem);font-weight:900;line-height:1.1;margin-bottom:var(--space-lg);letter-spacing:-.02em;animation:fadeInUp 1s var(--ease-out)}.gradient-text{color:var(--accent-color)}.hero-description{font-size:clamp(1rem,1.6vw,var(--font-size-xl));color:var(--text-secondary);margin-bottom:var(--space-2xl);line-height:1.7;animation:fadeInUp 1s var(--ease-out) .2s both;max-width:600px}.hero-cta{display:flex;gap:var(--space-lg);margin-bottom:var(--space-3xl);animation:fadeInUp 1s var(--ease-out) .4s both}.hero-stats{display:flex;gap:clamp(12px,2vw,var(--space-2xl));animation:fadeInUp 1s var(--ease-out) .6s both}.stat{text-align:center;padding:clamp(10px,2vw,var(--space-lg));background:var(--bg-card);border-radius:var(--radius-xl);border:1px solid var(--border-color);transition:var(--transition-normal)}.stat:hover{transform:translateY(-2px);border-color:var(--border-light);box-shadow:var(--shadow-sm)}.stat-number{display:block;font-size:clamp(1rem,2.4vw,var(--font-size-2xl));font-weight:800;color:var(--accent-color);margin-bottom:var(--space-xs)}.stat-label{font-size:clamp(.7rem,1.2vw,var(--font-size-sm));color:var(--text-muted);font-weight:500;letter-spacing:.02em}.hero-visual{display:flex;justify-content:center;align-items:center}.hero-image{width:min(520px,100%);height:auto;border-radius:var(--radius-2xl);box-shadow:var(--shadow-lg);border:1px solid var(--border-color)}.section-header{text-align:center;margin-bottom:4rem}.section-header h2{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;margin-bottom:1rem;color:var(--text-primary);letter-spacing:-.02em}.section-header p{font-size:1.125rem;color:var(--text-secondary);max-width:600px;margin:0 auto}.features-section{padding:var(--space-3xl) 0;background:var(--bg-secondary);position:relative}.features-section:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:var(--border-color)}.landing-page .features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,260px),1fr));gap:clamp(16px,3vw,var(--space-2xl));margin-top:var(--space-3xl)}.feature-card{padding:var(--space-2xl);border-radius:var(--radius-2xl);background:var(--bg-card);box-shadow:var(--shadow-md);border:1px solid var(--border-color);transition:var(--transition-normal);position:relative;overflow:hidden}.feature-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent-color);transform:scaleX(0);transition:var(--transition-normal)}.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--border-light)}.feature-card:hover:before{transform:scaleX(1)}.feature-icon{font-size:var(--font-size-2xl);margin-bottom:var(--space-lg);color:var(--accent-color);background:#3b82f61a;width:72px;height:72px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-xl);border:2px solid rgba(59,130,246,.2);transition:var(--transition-normal);position:relative}.feature-card:hover .feature-icon{background:color-mix(in srgb,var(--accent-color) 14%,var(--bg-card));border-color:var(--accent-color);box-shadow:none;transform:none}.feature-card h3{font-size:var(--font-size-xl);font-weight:700;margin-bottom:var(--space-md);color:var(--text-primary);line-height:1.3}.feature-card p{color:var(--text-secondary);line-height:1.7;font-size:var(--font-size-base)}.pricing-section{padding:var(--space-3xl) 0;background:var(--bg-primary);position:relative}.pricing-section:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:var(--border-color)}.pricing-toggle{display:flex;justify-content:center;gap:var(--space-sm);margin-bottom:var(--space-3xl);background:var(--bg-secondary);padding:var(--space-sm);border-radius:var(--radius-xl);box-shadow:none;max-width:320px;margin-left:auto;margin-right:auto;border:1px solid var(--border-color)}.toggle-btn{padding:var(--space-md) var(--space-xl);border:none;background:transparent;border-radius:var(--radius-lg);font-weight:600;cursor:pointer;transition:var(--transition-normal);position:relative;color:var(--text-secondary);font-size:var(--font-size-sm)}.toggle-btn.active{background:var(--accent-color);color:#fff;box-shadow:none}.toggle-btn:hover:not(.active){color:var(--text-primary);background:#ffffff0d}.discount-badge{position:absolute;top:-8px;right:-8px;background:var(--success-color);color:#fff;font-size:var(--font-size-xs);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-lg);font-weight:700;box-shadow:var(--shadow-sm)}.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,260px),1fr));gap:clamp(var(--space-lg),3vw,var(--space-2xl));max-width:1200px;margin:0 auto}.pricing-card{background:var(--bg-card);border-radius:var(--radius-2xl);padding:clamp(16px,3vw,var(--space-2xl));box-shadow:var(--shadow-lg);border:2px solid var(--border-color);transition:var(--transition-normal);position:relative;overflow:hidden;display:flex;flex-direction:column}.pricing-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent-color);transform:scaleX(0);transition:var(--transition-normal)}.pricing-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--border-light)}.pricing-card:hover:before{transform:scaleX(1)}.pricing-card.popular{border-color:var(--accent-color);transform:none;box-shadow:var(--shadow-md)}.pricing-card.popular:before{transform:scaleX(1)}.popular-badge{position:absolute;top:12px;right:12px;background:var(--accent-color);color:#fff;padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-weight:700;box-shadow:none;z-index:10}.plan-header{text-align:center;margin-bottom:var(--space-xl);display:flex;flex-direction:column;align-items:center}.plan-topline{display:inline-flex;align-items:center;gap:10px;justify-content:center;margin-bottom:10px}.plan-icon{font-size:var(--font-size-2xl);color:var(--accent-color);display:inline-flex;justify-content:center}.plan-header h3{font-size:clamp(1.05rem,2.2vw,1.4rem);font-weight:700;margin:0;color:var(--text-primary)}.plan-price{display:inline-flex;align-items:baseline;justify-content:center;gap:6px;margin-bottom:.25rem;white-space:nowrap}.currency{font-size:1.25rem;font-weight:700;color:var(--accent-color)}.amount{font-size:clamp(2rem,4.5vw,3.25rem);font-weight:900;color:var(--text-primary);line-height:1}.period{font-size:.95rem;color:var(--text-secondary);line-height:1.1;margin-left:2px}.plan-subtitle{color:var(--text-secondary);font-size:.9rem;margin-top:8px;display:block;width:100%;clear:both}.plan-features{list-style:none;padding:0;margin-bottom:var(--space-xl)}.landing-page .pricing-card .btn-full,.landing-page .pricing-card .btn-primary,.landing-page .pricing-card .btn-outline{margin-top:auto}.plan-features li{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;color:var(--text-muted)}.check-icon{color:#48bb78;font-weight:700;font-size:1.125rem}.testimonials-section{padding:var(--space-3xl) 0;background:var(--bg-secondary)}.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.testimonial-card{background:var(--bg-card);padding:var(--space-2xl);border-radius:var(--radius-xl);border-left:4px solid var(--accent-color);border:1px solid var(--border-color);box-shadow:var(--shadow-md)}.testimonial-content{margin-bottom:1.5rem}.testimonial-content p{font-style:italic;color:var(--text-secondary);line-height:1.6}.testimonial-author{display:flex;align-items:center;gap:1rem}.author-avatar{font-size:1.5rem;font-weight:700;width:50px;height:50px;background:var(--accent-color);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center}.author-info h4{font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.author-info span{color:var(--text-secondary);font-size:.875rem}.cta-section{padding:6rem 0;background:var(--bg-secondary);color:var(--text-primary);text-align:center;border-top:1px solid var(--border-color)}.cta-content h2{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;margin-bottom:1rem;text-align:center;letter-spacing:-.02em}.cta-content p{font-size:1.125rem;margin-bottom:2rem;color:var(--text-secondary);text-align:center}.cta-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.landing-page .cta-section .btn-outline{background:transparent;color:var(--text-primary);border-color:var(--border-color)}.landing-page .cta-section .btn-outline:hover{background:var(--bg-card);color:var(--text-primary);border-color:var(--border-light)}.landing-footer{background:var(--bg-card);color:var(--text-primary);padding:4rem 0 2rem}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-xl);margin-bottom:var(--space-2xl)}@media (min-width: 1024px){.footer-content{grid-template-columns:2fr 1fr 1fr;gap:var(--space-2xl)}.footer-section+.footer-section{border-left:1px solid var(--border-color);padding-left:var(--space-xl)}}.landing-page .landing-footer .logo{justify-content:flex-start;margin-bottom:var(--space-2xl)}.landing-page .landing-footer .logo:hover{transform:none}.landing-page .landing-footer .logo:hover .logo-icon{box-shadow:none}.footer-section h4{font-weight:600;margin-bottom:1rem;color:var(--text-primary);text-align:center}.footer-section a{display:block;color:var(--text-secondary);text-decoration:none;margin-bottom:.25rem;padding:.25rem 0;transition:color .3s ease;text-align:center}.footer-section a:hover{color:var(--text-primary);text-decoration:underline}.footer-section p{color:var(--text-secondary);line-height:1.7}.footer-section a:hover{color:var(--text-primary)}.footer-bottom{border-top:1px solid var(--border-color);padding-top:2rem;text-align:center;color:var(--text-secondary);font-size:.9rem}@media (max-width: 768px){.landing-page .landing-footer .logo{justify-content:flex-start}.footer-section h4,.footer-section a,.footer-section p{text-align:left}.footer-section{margin-bottom:var(--space-lg)}.landing-footer .landing-container{padding-left:var(--space-lg);padding-right:var(--space-lg)}}@media (max-width: 1024px){.hero-content{margin-top:3rem;gap:var(--space-2xl)}}@media (max-width: 768px){.landing-header-inner{padding:0 var(--space-lg)}.nav-menu{display:none}.mobile-menu-btn{display:flex;flex-direction:column;gap:4px;cursor:pointer;padding:var(--space-sm);background:none;border:none;z-index:1001;position:relative;align-items:center;justify-content:center}.mobile-menu-btn span{width:24px;height:2px;background:var(--text-primary);transition:var(--transition-normal)}.mobile-menu-btn.active span:nth-child(1){transform:rotate(45deg) translate(6px,6px)}.mobile-menu-btn.active span:nth-child(2){opacity:0}.mobile-menu-btn.active span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}.hero-content{grid-template-columns:1fr;text-align:center;gap:var(--space-2xl);padding-top:var(--space-xl);margin-top:4rem}.hero-title{font-size:clamp(2.5rem,10vw,3.5rem);line-height:1.1;margin-bottom:var(--space-xl)}.hero-description{font-size:var(--font-size-lg);margin-bottom:var(--space-2xl);padding:0 var(--space-md)}.hero-cta{flex-direction:column;align-items:center;gap:var(--space-lg);margin-bottom:var(--space-2xl)}.landing-page .hero-cta .btn{width:100%;max-width:280px;padding:var(--space-sm) var(--space-lg);font-size:var(--font-size-sm)}.hero-stats{justify-content:center;flex-wrap:wrap;gap:var(--space-lg);padding:0 var(--space-sm)}.stat{flex:1;min-width:120px;max-width:150px;padding:var(--space-lg);border-radius:var(--radius-lg)}.stat-number{font-size:clamp(1.125rem,4.5vw,1.5rem)}.hero-visual{order:-1;margin-bottom:var(--space-xl)}.hero-image{width:min(360px,100%)}.hero-avatar{width:280px;height:280px;margin:0 auto}.landing-page .features-grid{grid-template-columns:1fr;gap:var(--space-xl);padding:0 var(--space-sm)}.feature-card{padding:var(--space-2xl);text-align:center}.feature-icon{margin:0 auto var(--space-xl)}.pricing-grid{grid-template-columns:1fr;gap:var(--space-xl);padding:0 var(--space-sm)}.pricing-card.popular .plan-header{padding-top:var(--space-2xl)}.pricing-card .popular-badge{top:8px;right:8px}.pricing-card.popular{transform:none}.pricing-card{padding:var(--space-2xl)}.landing-page .pricing-card .btn-full{padding:var(--space-sm) var(--space-lg);font-size:var(--font-size-sm)}.pricing-toggle{margin-bottom:var(--space-2xl)}.testimonials-grid{grid-template-columns:1fr;gap:var(--space-xl);padding:0 var(--space-sm)}.testimonial-card{padding:var(--space-2xl)}.cta-buttons{flex-direction:column;align-items:center;gap:var(--space-lg)}.landing-page .cta-buttons .btn{width:100%;max-width:320px}.landing-page .cta-section .btn-large{padding:var(--space-md) var(--space-xl);font-size:var(--font-size-sm)}.hero-section{padding-top:clamp(104px,16vh,140px)}.footer-content{grid-template-columns:1fr;text-align:center;gap:var(--space-2xl)}.section-header{margin-bottom:var(--space-2xl);padding:0 var(--space-sm)}.section-header h2{font-size:clamp(2rem,8vw,2.5rem);margin-bottom:var(--space-lg)}.section-header p{font-size:var(--font-size-lg);padding:0 var(--space-md)}}@media (max-width: 640px){.landing-container,.landing-header-inner{padding:0 var(--space-md)}.hero-section{padding:var(--space-2xl) 0 var(--space-xl);min-height:auto}.hero-content{gap:var(--space-xl);padding-top:var(--space-lg)}.hero-title{font-size:clamp(2rem,8vw,2.5rem)}.hero-description{font-size:var(--font-size-base);padding:0}.hero-stats{flex-direction:column;gap:var(--space-md);padding:0}.stat{flex:none;min-width:auto;max-width:none;padding:var(--space-md);border-radius:var(--radius-lg)}.stat-number{font-size:clamp(1.05rem,4.2vw,1.35rem)}.stat-label{font-size:.8rem}.hero-avatar{width:240px;height:240px}.features-section,.pricing-section,.testimonials-section,.cta-section{padding:var(--space-2xl) 0}.feature-card,.pricing-card,.testimonial-card{padding:var(--space-xl)}.section-header,.section-header p{padding:0}}@media (max-width: 480px){.hero-stats{gap:var(--space-sm)}.stat{padding:var(--space-md);border-radius:var(--radius-md)}.stat-number{font-size:clamp(1rem,4vw,1.25rem)}.stat-label{font-size:.75rem}.landing-container{padding:0 var(--space-sm)}.landing-header-inner{padding:0 var(--space-sm);gap:var(--space-xs);justify-content:space-between}.landing-header{padding:var(--space-md) 0}.landing-page .landing-header .logo{margin:0}.landing-page .landing-header .logo-text{font-size:1.1rem;letter-spacing:.1px}.mobile-menu-btn{margin-left:auto}.hero-title{font-size:clamp(1.85rem,7vw,2.25rem)}.hero-description{font-size:var(--font-size-base)}.hero-cta{gap:var(--space-sm)}.section-header h2{font-size:clamp(1.5rem,5vw,2rem)}.section-header p{font-size:var(--font-size-base)}.cta-content h2{font-size:clamp(1.5rem,5vw,2rem)}.cta-content p{font-size:var(--font-size-base)}.feature-card,.pricing-card{padding:var(--space-lg)}.landing-page .btn-large{padding:var(--space-md) var(--space-xl);font-size:var(--font-size-sm)}}@media (max-width: 360px){.landing-container,.landing-header-inner{padding:0 var(--space-xs)}.hero-title{font-size:clamp(1.5rem,5vw,2rem)}.hero-description{font-size:var(--font-size-sm)}.section-header h2,.cta-content h2{font-size:clamp(1.25rem,4vw,1.75rem)}}.animate-on-scroll{opacity:0;transform:translateY(30px);transition:var(--transition-slow)}.animate-on-scroll.animate-in{opacity:1;transform:translateY(0)}.feature-card.animate-on-scroll.animate-in,.section-header.animate-on-scroll.animate-in{animation:fadeInUp var(--transition-slow) var(--ease-out) forwards}@media (prefers-reduced-motion: reduce){.landing-page *,.landing-page *:before,.landing-page *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.landing-page .animate-on-scroll{opacity:1;transform:none}}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:var(--bg-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;position:relative}.auth-card{background:var(--bg-card);border-radius:var(--radius-2xl);padding:2rem;box-shadow:var(--shadow-md);width:100%;max-width:520px;position:relative;border:1px solid var(--border-color);animation:scaleIn .6s var(--ease-out);overflow:hidden}.auth-card--large{max-width:600px}@media (min-width: 768px){.auth-card{max-width:580px}.auth-card--large{max-width:720px}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.auth-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent-color)}.auth-header{text-align:center;margin-bottom:1.5rem;position:relative;z-index:2}.auth-header .logo{display:inline-flex;align-items:center;gap:.75rem;font-weight:800;font-size:1.25rem;text-decoration:none;margin-bottom:.75rem;padding:.375rem 1.25rem;background:var(--bg-secondary);border-radius:var(--radius-xl);border:1px solid var(--border-color);transition:all var(--transition-normal)}.auth-header .logo:hover{background:var(--bg-tertiary);border-color:var(--border-light);transform:none;box-shadow:none}.auth-header .logo-text{color:var(--text-primary);font-size:1.5rem;position:relative}.auth-header h1{font-size:1.75rem;font-weight:800;color:var(--text-primary);margin-bottom:.375rem;line-height:1.2}.auth-header p{color:var(--text-secondary);font-size:1rem;line-height:1.5;opacity:.9;max-width:min(100%,26rem);margin:0 auto}.auth-container--callback-minimal{align-items:center;justify-content:center}.auth-callback-simple{width:100%;max-width:18rem;margin:0 auto;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem;padding:.5rem}.auth-callback-brand{font-weight:800;font-size:1.125rem;color:var(--text-primary);text-decoration:none;letter-spacing:-.02em;line-height:1.2}.auth-callback-brand:hover{color:var(--accent-color)}.auth-callback-simple__status{margin:0;font-size:.9375rem;font-weight:600;color:var(--text-primary);line-height:1.4}.auth-callback-simple__spinner{width:26px;height:26px;border-radius:50%;border:2px solid var(--border-color);border-top-color:var(--accent-color);animation:spin .85s linear infinite;box-sizing:border-box;flex-shrink:0}.auth-callback-simple__hint{margin:0;font-size:.8125rem;color:var(--text-muted);line-height:1.45;max-width:16rem}.auth-callback-simple__link{display:inline-flex;align-items:center;gap:.35rem;margin-top:.25rem;font-size:.8125rem;font-weight:600;color:var(--text-secondary);text-decoration:none;transition:color var(--transition-normal)}.auth-callback-simple__link:hover{color:var(--accent-color)}.auth-callback-simple__link:focus-visible{outline:none;border-radius:var(--radius-sm);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent-color) 40%,transparent)}.auth-callback-simple--error{max-width:22rem;align-items:stretch;gap:.875rem}.auth-callback-simple--error .auth-callback-brand{align-self:center}.auth-callback-simple--error .auth-callback-simple__status{text-align:center}.auth-callback-simple__error{margin:0;font-size:.8125rem;color:var(--text-secondary);text-align:left;line-height:1.5;padding:.65rem .75rem;background:color-mix(in srgb,var(--error-color) 6%,var(--bg-primary));border-radius:var(--radius-md);border:1px solid color-mix(in srgb,var(--error-color) 18%,var(--border-color))}.auth-actions--callback-tight{margin-top:.125rem}.auth-actions{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem;position:relative;z-index:2}.auth-actions .btn-primary,.auth-actions .btn-outline{width:100%;padding:.875rem 1.25rem;font-size:.95rem;font-family:inherit;line-height:1.2;border-radius:var(--radius-lg);cursor:pointer;transition:border-color var(--transition-normal),background var(--transition-normal),color var(--transition-normal),filter var(--transition-normal),box-shadow var(--transition-normal);display:inline-flex;align-items:center;justify-content:center;gap:.5rem;text-align:center}.auth-actions .btn-primary{background:var(--accent-color);color:#fff;font-weight:700;border:none}.auth-actions .btn-primary:hover:not(:disabled){filter:brightness(1.05);box-shadow:var(--shadow-sm)}.auth-actions .btn-primary:disabled{opacity:.6;cursor:not-allowed}.auth-actions .btn-outline{border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);font-weight:600}.auth-actions .btn-outline:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--border-light)}.auth-actions .btn-primary:focus-visible,.auth-actions .btn-outline:focus-visible{outline:none;box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-color) 35%,transparent)}.auth-form{margin-bottom:1.25rem;display:grid;gap:1.25rem;position:relative;z-index:2}.form-group{position:relative}.form-group label{display:block;font-weight:600;color:var(--text-primary);margin-bottom:.5rem;font-size:.9rem;transition:all var(--transition-normal)}.form-group input{width:100%;padding:.875rem 1rem;border:2px solid var(--border-color);border-radius:var(--radius-lg);font-size:.95rem;transition:all var(--transition-normal);background:var(--bg-tertiary);color:var(--text-primary);font-family:inherit;position:relative;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.form-group input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 4px #3b82f626;background:var(--bg-secondary);transform:translateY(-1px)}.form-group input:focus+label{color:var(--accent-color)}.form-group input.error{border-color:var(--error-color);box-shadow:0 0 0 4px #ef444426}.form-group input:disabled{background:var(--border-color);cursor:not-allowed;opacity:.6}.form-group input::placeholder{color:var(--text-muted);opacity:.7}.error-text{color:var(--error-color);font-size:.8rem;margin-top:.375rem;display:flex;align-items:center;gap:.5rem;font-weight:500}.error-text:before{content:"⚠️";font-size:.75rem}.error-message{background:color-mix(in srgb,var(--error-color) 10%,var(--bg-card));color:var(--error-color);padding:.875rem 1rem;border-radius:var(--radius-lg);margin-bottom:1.25rem;font-size:.8rem;border:1px solid color-mix(in srgb,var(--error-color) 25%,var(--border-color));display:flex;align-items:center;gap:.75rem}.error-message:before{content:"🚨";font-size:1rem}.form-options{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;flex-wrap:wrap;gap:.75rem}.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-size:.8rem;color:var(--text-secondary);transition:all var(--transition-normal);padding:.5rem;border-radius:var(--radius-md)}.checkbox-label:hover{background:#ffffff0d;color:var(--text-primary)}.checkbox-label input[type=checkbox]{display:none}.checkmark{width:1.125rem;height:1.125rem;border:2px solid var(--border-color);border-radius:var(--radius-md);position:relative;transition:all var(--transition-normal);background:var(--bg-secondary)}.checkbox-label input[type=checkbox]:checked+.checkmark{background:var(--accent-color);border-color:var(--accent-color);transform:scale(1.1)}.checkbox-label input[type=checkbox]:checked+.checkmark:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:.75rem;font-weight:700}.forgot-password{color:var(--accent-color);text-decoration:none;font-size:.8rem;font-weight:600;transition:all var(--transition-normal);padding:.5rem .75rem;border-radius:var(--radius-md)}.forgot-password:hover{background:#3b82f61a;text-decoration:none;transform:translateY(-1px)}.auth-form .form-actions{display:flex;flex-direction:row;flex-wrap:wrap;gap:var(--space-md, .75rem);margin-top:var(--space-lg, 1.5rem)}.auth-form .form-actions>.btn-full{flex:1 1 100%;width:100%}.auth-form .form-actions>*:not(.btn-full){flex:1 1 0;width:auto;min-width:0}.auth-form .form-actions>.register-back-btn{flex:0 0 auto;min-width:6.75rem}.auth-form .form-actions>.btn-primary:not(.btn-full){flex:1 1 0;min-width:0}@media (max-width: 480px){.auth-form .form-actions>*:not(.btn-full){flex:1 1 100%;min-width:100%}.auth-form .form-actions>.register-back-btn{min-width:100%}}.auth-form .btn-outline{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.25rem;font-size:.95rem;font-weight:600;font-family:inherit;line-height:1.2;border-radius:var(--radius-lg);border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:border-color var(--transition-normal),background var(--transition-normal),color var(--transition-normal)}.auth-form .btn-outline:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--border-light);color:var(--text-primary)}.auth-form .btn-outline:focus-visible{outline:none;box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-color) 35%,transparent)}.auth-form .btn-outline:disabled{opacity:.55;cursor:not-allowed}.auth-form .btn-outline.register-back-btn svg{flex-shrink:0}.auth-form .btn-primary{background:var(--accent-color);color:#fff;box-shadow:none;position:relative;overflow:hidden;padding:.875rem 1.25rem;font-size:.95rem;font-weight:700;border-radius:var(--radius-lg);border:none;cursor:pointer;transition:all var(--transition-normal);width:100%;text-align:center;display:flex;align-items:center;justify-content:center;gap:.5rem}.auth-form .btn-primary:before{display:none}.auth-form .btn-primary:hover:not(:disabled){transform:none;box-shadow:var(--shadow-sm);filter:brightness(1.05)}.auth-form .btn-primary:active{transform:translateY(-1px)}.auth-form .btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-form .btn-primary:disabled:hover{transform:none;box-shadow:none}.loading-spinner{display:inline-block;width:16px;height:16px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}.auth-form .btn-primary .loading-spinner--btn-lead{box-sizing:border-box;flex-shrink:0;width:16px;height:16px;margin:0;visibility:hidden}.auth-form .btn-primary .loading-spinner--btn-lead.loading-spinner--btn-lead--active{visibility:visible}.auth-form .btn-primary .btn-primary-label{min-width:0}.auth-divider{text-align:center;margin:1.5rem 0;position:relative}.auth-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:var(--border-color)}.auth-divider span{background:var(--bg-card);padding:0 1.25rem;color:var(--text-secondary);font-size:.8rem;font-weight:600;position:relative;z-index:1}.social-login{margin-bottom:1.5rem;display:grid;gap:.875rem}.social-login .btn-social{width:100%;padding:.875rem 1.25rem;font-size:.9rem;font-weight:600;border-radius:var(--radius-lg);transition:all var(--transition-normal);position:relative;overflow:hidden;border:2px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);display:flex;align-items:center;justify-content:center;gap:.75rem;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.social-login .btn-social:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--accent-color);background:var(--bg-tertiary)}.social-login .btn-social:active{transform:translateY(0)}.social-login .btn-social:before{display:none}.social-icon{font-size:.9rem;font-weight:700;background:#3b82f61a;color:var(--accent-color);width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);border:1px solid rgba(59,130,246,.2);flex-shrink:0}.btn-social{position:relative;overflow:hidden}.btn-social:before{display:none}.auth-footer{text-align:center;color:var(--text-secondary);font-size:.8rem;padding-top:.875rem;border-top:1px solid var(--border-color);position:relative}.auth-footer:before{display:none}.link-primary{color:var(--accent-color);text-decoration:none;font-weight:600;transition:all var(--transition-normal)}.link-primary:hover{text-decoration:underline;color:var(--accent-hover)}.back-to-home{text-align:center;margin-bottom:1.25rem}.back-link{color:var(--text-secondary);text-decoration:none;font-size:.875rem;font-weight:600;transition:background var(--transition-normal),border-color var(--transition-normal),color var(--transition-normal);padding:.5rem 1rem;border-radius:var(--radius-lg);display:inline-flex;align-items:center;gap:.5rem;border:1px solid var(--border-color);background:var(--bg-secondary)}.back-link:hover{color:var(--text-primary);background:var(--bg-tertiary);border-color:var(--border-light);text-decoration:none}.back-link:focus-visible{outline:none;box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-color) 30%,transparent)}.register-terms-wrap{flex-direction:column;align-items:stretch;justify-content:flex-start;gap:.25rem;margin-bottom:0;width:100%}.register-terms-label{align-items:flex-start;width:100%;max-width:100%;padding:.5rem .25rem;gap:.625rem}.register-terms-label .checkmark{flex-shrink:0;margin-top:.15em}.register-terms-body{flex:1;min-width:0;text-align:left}.register-terms-line{font-size:.8125rem;line-height:1.5;color:var(--text-secondary)}.register-terms-sep{white-space:normal}.register-terms-link{font-weight:600;text-underline-offset:2px}.register-terms-error{margin:.125rem 0 0 1.75rem;display:block}.back-link:before{display:none}.checkbox-label:hover .checkmark{border-color:var(--accent-color);background:#3b82f61a}.password-toggle-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;transition:all var(--transition-normal);display:flex;align-items:center;justify-content:center}.password-toggle-btn:hover{color:var(--text-primary);background:#ffffff1a}.password-toggle-btn:focus{outline:none;box-shadow:0 0 0 2px var(--accent-color)}.form-group input.error:focus{border-color:var(--error-color);box-shadow:0 0 0 4px #ef444426}@media (max-width: 768px){.auth-container{padding:1rem;align-items:stretch}.auth-card{padding:1.75rem 1.25rem;margin:auto;max-width:100%;border-radius:var(--radius-xl)}.auth-header{margin-bottom:1.25rem}.auth-header .logo{font-size:1.25rem;padding:.5rem 1rem;margin-bottom:.75rem}.auth-header .logo-text{font-size:1.5rem}.auth-header h1{font-size:1.5rem;margin-bottom:.375rem}.auth-header p{font-size:.9rem;max-width:280px}.auth-form{gap:1rem;margin-bottom:1.25rem}.form-group input{padding:.875rem 1rem;font-size:1rem}.form-options{flex-direction:column;align-items:flex-start;gap:.75rem;margin-bottom:1.25rem}.auth-form .btn-primary{padding:1rem 1.25rem;font-size:1rem;border-radius:var(--radius-lg);justify-content:center;text-align:center}.auth-divider{margin:1.25rem 0}.social-login{gap:.75rem;margin-bottom:1.5rem}.social-login .btn-social{padding:1rem 1.25rem;font-size:1rem;border-radius:var(--radius-lg)}.auth-footer{padding-top:.75rem}}@media (max-width: 640px){.auth-container{padding:.75rem}.auth-card{padding:1.5rem 1rem;border-radius:var(--radius-lg)}.auth-header h1{font-size:1.375rem}.auth-header p{font-size:.85rem;max-width:260px}.auth-form{gap:.875rem}.form-group input{padding:.75rem .875rem}.auth-form .btn-primary{padding:.875rem 1rem;justify-content:center}.social-login .btn-social{padding:.875rem 1rem}}@media (max-width: 480px){.auth-container{padding:.5rem}.auth-card{padding:1.25rem .875rem;border-radius:var(--radius-md)}.auth-header{margin-bottom:1rem}.auth-header .logo{font-size:1.125rem;padding:.5rem .75rem;margin-bottom:.5rem}.auth-header .logo-text{font-size:1.375rem}.auth-header h1{font-size:1.25rem;margin-bottom:.25rem}.auth-header p{font-size:.8rem;max-width:240px}.auth-form{gap:.75rem;margin-bottom:1rem}.form-group label{font-size:.8rem;margin-bottom:.375rem}.form-group input{padding:.75rem .875rem;font-size:.95rem;border-radius:var(--radius-md)}.form-options{gap:.5rem;margin-bottom:1rem}.checkbox-label{font-size:.75rem;padding:.375rem}.checkmark{width:1rem;height:1rem}.forgot-password{font-size:.75rem;padding:.375rem .5rem}.auth-form .btn-primary{padding:.875rem 1rem;font-size:.95rem;border-radius:var(--radius-md);min-height:48px;justify-content:center;text-align:center}.auth-divider{margin:1rem 0}.auth-divider span{padding:0 .875rem;font-size:.75rem}.social-login{gap:.625rem;margin-bottom:1.25rem}.social-login .btn-social{padding:.875rem 1rem;font-size:.95rem;border-radius:var(--radius-md);min-height:48px}.social-icon{width:20px;height:20px;font-size:.8rem}.auth-footer{font-size:.75rem;padding-top:.625rem}.back-to-home{margin-bottom:1rem}.back-link{font-size:.75rem;padding:.375rem .75rem}}@media (max-width: 360px){.auth-container{padding:.25rem}.auth-card{padding:1rem .75rem;border-radius:var(--radius-md)}.auth-header h1{font-size:1.125rem}.auth-header p{font-size:.75rem;max-width:220px}.auth-form{gap:.625rem}.form-group input{padding:.625rem .75rem;font-size:.9rem}.auth-form .btn-primary{padding:.75rem .875rem;font-size:.9rem;min-height:44px;justify-content:center;text-align:center}.social-login .btn-social{padding:.75rem .875rem;font-size:.9rem;min-height:44px}.auth-divider{margin:.875rem 0}.social-login{gap:.5rem;margin-bottom:1rem}}@supports (padding: max(0px)){.auth-container{padding-left:max(2rem,env(safe-area-inset-left));padding-right:max(2rem,env(safe-area-inset-right));padding-top:max(2rem,env(safe-area-inset-top));padding-bottom:max(2rem,env(safe-area-inset-bottom))}@media (max-width: 768px){.auth-container{padding-left:max(1rem,env(safe-area-inset-left));padding-right:max(1rem,env(safe-area-inset-right));padding-top:max(1rem,env(safe-area-inset-top));padding-bottom:max(1rem,env(safe-area-inset-bottom))}}@media (max-width: 480px){.auth-container{padding-left:max(.5rem,env(safe-area-inset-left));padding-right:max(.5rem,env(safe-area-inset-right));padding-top:max(.5rem,env(safe-area-inset-top));padding-bottom:max(.5rem,env(safe-area-inset-bottom))}}}@media (prefers-reduced-motion: reduce){.auth-card,.auth-form .btn-primary,.social-login .btn-social,.form-group input,.checkbox-label,.forgot-password,.back-link{animation:none;transition:none}.auth-callback-simple__spinner{animation:none;border-color:color-mix(in srgb,var(--accent-color) 40%,var(--border-color));opacity:.9}}@media (prefers-color-scheme: dark){.auth-card{background:#111827f2;border-color:#4b556380}.form-group input{background:#1f2937cc;border-color:#4b556399}.form-group input:focus{background:#1f2937f2;border-color:var(--accent-color)}.social-login .btn-social{background:#1f2937cc;border-color:#4b556399}.social-login .btn-social:hover{background:#1f2937f2}}@media (max-width: 480px){.auth-form .btn-primary,.social-login .btn-social{min-height:48px;touch-action:manipulation;-webkit-tap-highlight-color:transparent;justify-content:center;text-align:center}.form-group input{min-height:44px;touch-action:manipulation}.checkbox-label,.forgot-password{min-height:44px;display:flex;align-items:center}.auth-form .btn-primary{margin:0 auto;display:flex;align-items:center;justify-content:center;text-align:center}}@media (max-width: 360px){.auth-form .btn-primary,.social-login .btn-social{min-height:44px;justify-content:center;text-align:center}.form-group input{min-height:40px}.auth-form .btn-primary{margin:0 auto;display:flex;align-items:center;justify-content:center;text-align:center}}@media (hover: none) and (pointer: coarse){.auth-form .btn-primary:hover,.social-login .btn-social:hover,.forgot-password:hover,.back-link:hover{transform:none;box-shadow:none}.auth-form .btn-primary:active,.social-login .btn-social:active{transform:scale(.98)}.form-group input:focus{transform:none}}.step-indicator{display:flex;justify-content:space-between;align-items:center;margin:2rem 0 2.5rem;padding:1.5rem;background:var(--bg-secondary);border-radius:var(--radius-xl);border:1px solid var(--border-color);position:relative;gap:2rem}.step-indicator:before{content:"";position:absolute;top:50%;left:2rem;right:2rem;height:2px;background:var(--border-color);transform:translateY(-50%);z-index:1}.step{display:flex;flex-direction:column;align-items:center;gap:.75rem;position:relative;z-index:2;transition:all var(--transition-normal);flex:1;max-width:140px}.step-number{width:48px;height:48px;border-radius:50%;background:var(--bg-tertiary);border:3px solid var(--border-color);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.125rem;transition:all var(--transition-normal);position:relative}.step.active .step-number{background:var(--accent-color);border-color:var(--accent-color);color:#fff;box-shadow:none;transform:none}.step-label{font-size:.875rem;font-weight:500;color:var(--text-secondary);text-align:center;max-width:120px;line-height:1.3;transition:color var(--transition-normal)}.step.active .step-label{color:var(--text-primary);font-weight:600}.step.current .step-number{transform:none;box-shadow:none;outline:2px solid color-mix(in srgb,var(--accent-color) 35%,transparent);outline-offset:2px}.step.current .step-label{color:var(--accent-color);font-weight:700}.step-status{position:absolute;top:-8px;right:-8px;background:var(--accent-color);color:#fff;font-size:.625rem;font-weight:600;padding:.25rem .5rem;border-radius:var(--radius-sm);white-space:nowrap;animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}}.step:not(:last-child):after{content:"";position:absolute;top:24px;left:calc(50% + 24px);width:calc(100% + 2rem);height:2px;background:var(--border-color);transition:background var(--transition-normal)}.step.active:not(:last-child):after{background:var(--accent-color)}@media (max-width: 768px){.step-indicator{margin:1.5rem 0 2rem;padding:1rem;gap:1rem}.step{gap:.5rem;max-width:120px}.step-number{width:40px;height:40px;font-size:1rem;border-width:2px}.step-label{font-size:.75rem;max-width:80px}.step:not(:last-child):after{top:20px;left:calc(50% + 20px);width:calc(100% + 1rem)}.step-indicator:after{left:1rem;right:1rem;height:3px}}@media (max-width: 480px){.step-indicator{margin:1rem 0 1.5rem;padding:.75rem;flex-direction:column;gap:1rem}.step-indicator:before{display:none}.step{flex-direction:row;gap:.75rem;width:100%;justify-content:flex-start;max-width:none}.step-number{width:36px;height:36px;font-size:.875rem;flex-shrink:0}.step-label{font-size:.75rem;max-width:none;text-align:left;flex:1}.step:not(:last-child):after{display:none}.step-status{top:-4px;right:-4px;font-size:.5rem;padding:.125rem .375rem}.step-indicator:after{left:.75rem;right:.75rem;height:2px}}@media (max-width: 360px){.step-indicator{padding:.5rem;gap:.75rem}.step-number{width:32px;height:32px;font-size:.75rem}.step-label{font-size:.625rem}.step-status{top:-2px;right:-2px;font-size:.5rem;padding:.125rem .25rem}}.auth-form{position:relative;min-height:300px}.auth-form>*{animation:fadeInUp .4s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.step-indicator{position:relative}.step-indicator:after{content:"";position:absolute;bottom:-1rem;left:1.5rem;right:1.5rem;height:3px;background:linear-gradient(90deg,var(--accent-color) 0%,var(--accent-color) calc((var(--current-step, 1) / 3) * 100%),var(--border-color) calc((var(--current-step, 1) / 3) * 100%),var(--border-color) 100%);border-radius:2px;transition:all .5s ease;box-shadow:none}.password-requirements{margin-top:1rem;padding:1rem;background:#ffffff05;border-radius:var(--radius-md);border:1px solid var(--border-light)}.password-requirements small{display:block;color:var(--text-secondary);font-size:.75rem;font-weight:500;margin-bottom:.75rem}.password-requirements ul{list-style:none;padding:0;margin:0;display:grid;gap:.5rem}.password-requirements li{display:flex;align-items:center;gap:.5rem;font-size:.75rem;padding:.25rem 0;transition:all var(--transition-normal)}.password-requirements li:before{content:"";width:16px;height:16px;border-radius:50%;flex-shrink:0;transition:all var(--transition-normal)}.password-requirements li.valid{color:var(--success-color)}.password-requirements li.valid:before{background:var(--success-color);box-shadow:none}.password-requirements li.invalid{color:var(--text-muted)}.password-requirements li.invalid:before{background:var(--text-muted);opacity:.5}.password-requirements--register{margin-top:.5rem;margin-bottom:.25rem;padding:.65rem .75rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md)}.password-requirements-hint{margin:0 0 .45rem;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.password-requirements--register .password-requirements-grid{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:.3rem .65rem}.password-requirements--register .password-requirements-grid li{font-size:.72rem;padding:.15rem 0;line-height:1.3}@media (max-width: 768px){.password-requirements{margin-top:.75rem;padding:.75rem}.password-requirements ul{gap:.375rem}.password-requirements li{font-size:.7rem}.password-requirements li:before{width:14px;height:14px}.password-requirements--register .password-requirements-grid{grid-template-columns:1fr;gap:.25rem}.password-requirements--register .password-requirements-grid li{font-size:.74rem}}@media (max-width: 480px){.password-requirements{padding:.5rem}.password-requirements small{font-size:.7rem;margin-bottom:.5rem}.password-requirements li{font-size:.65rem}.password-requirements li:before{width:12px;height:12px}.password-requirements--register{padding:.55rem .65rem}.password-requirements--register .password-requirements-grid li{font-size:.7rem}.password-requirements--register .password-requirements-grid li:before{width:11px;height:11px}}.plan-selection-label{display:block;font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.plan-selector-compact{display:grid;gap:1rem;margin-bottom:1rem}.plan-option-compact{display:block;cursor:pointer;transition:all var(--transition-normal);border-radius:var(--radius-lg);border:2px solid var(--border-color);background:var(--bg-secondary);overflow:hidden;position:relative}.plan-option-compact:hover:not(.disabled){border-color:var(--accent-color);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.plan-option-compact.selected{border-color:var(--accent-color);background:color-mix(in srgb,var(--accent-color) 8%,var(--bg-secondary));box-shadow:none}.plan-option-compact.disabled{opacity:.5;cursor:not-allowed;background:var(--bg-tertiary)}.plan-option-compact input[type=radio]{position:absolute;opacity:0;pointer-events:none}.plan-content-compact{padding:1.5rem}.plan-header-compact{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.plan-header-compact h4{margin:0;font-size:1.125rem;font-weight:700;color:var(--text-primary)}.plan-price-compact{font-size:1.25rem;font-weight:800;color:var(--accent-color);background:#3b82f61a;padding:.5rem 1rem;border-radius:var(--radius-lg)}.plan-description-compact{margin:0 0 1rem;color:var(--text-secondary);font-size:.875rem;line-height:1.5}.plan-features-compact{display:flex;flex-wrap:wrap;gap:.5rem}.feature-tag{background:var(--bg-tertiary);color:var(--text-secondary);padding:.375rem .75rem;border-radius:var(--radius-md);font-size:.75rem;font-weight:500;border:1px solid var(--border-light)}.maintenance-banner{background:#d97706;color:#fff;padding:1.5rem;border-radius:var(--radius-lg);margin-bottom:2rem;text-align:center;box-shadow:none}.maintenance-content h3{margin:0 0 .75rem;font-size:1.125rem;font-weight:700}.maintenance-content p{margin:0 0 .5rem;font-size:.875rem;opacity:.9}.maintenance-content small{font-size:.75rem;opacity:.8;font-style:italic}.register-maintenance-banner .maintenance-compact{display:none;margin:0}.register-maintenance-banner .maintenance-expanded{display:block}@media (max-width: 640px){.register-maintenance-banner{padding:.55rem .65rem;margin-bottom:.75rem;text-align:left}.register-maintenance-banner .maintenance-compact{display:block;font-size:.8125rem;font-weight:600;line-height:1.35;margin:0}.register-maintenance-banner .maintenance-expanded{display:none}}@media (min-width: 769px){.register-step3{display:flex;flex-direction:column;gap:.65rem}.register-maintenance-banner{margin-bottom:0;padding:.65rem .85rem;text-align:left}.register-maintenance-banner .maintenance-content--register{text-align:left}.register-maintenance-banner .maintenance-expanded h3{margin:0 0 .3rem;font-size:.95rem}.register-maintenance-banner .maintenance-expanded p{margin:0 0 .2rem;font-size:.8rem;line-height:1.35}.register-maintenance-banner .maintenance-expanded small{font-size:.7rem;line-height:1.35;display:block}.register-plan-group{margin-bottom:0}.register-step3 .plan-selection-label{margin-bottom:.35rem;font-size:.95rem}.register-step3 .plan-selector-compact{gap:.5rem;margin-bottom:0}.register-step3 .plan-content-compact{padding:.8rem 1rem}.register-step3 .plan-header-compact{margin-bottom:.3rem}.register-step3 .plan-description-compact{margin:0 0 .35rem;font-size:.8125rem;line-height:1.4}.register-step3 .plan-header-compact h4{font-size:1rem}.register-step3 .plan-price-compact{font-size:1.05rem;padding:.3rem .6rem}.register-step3 .plan-option-compact:hover:not(.disabled){transform:translateY(-1px);box-shadow:var(--shadow-sm)}.register-step3 .register-terms-wrap{margin-top:.15rem}.register-step3 .form-actions{margin-top:.35rem}}@media (max-width: 768px){.plan-selector-compact{gap:.75rem}.plan-content-compact{padding:1.25rem}.plan-header-compact h4{font-size:1rem}.plan-price-compact{font-size:1.125rem;padding:.375rem .75rem}.plan-description-compact{font-size:.8rem}.feature-tag{font-size:.7rem;padding:.25rem .5rem}.maintenance-banner{padding:1.25rem;margin-bottom:1.5rem}}@media (max-width: 480px){.plan-selector-compact{gap:.5rem}.plan-content-compact{padding:1rem}.plan-header-compact{flex-direction:column;align-items:flex-start;gap:.5rem}.plan-price-compact{align-self:flex-start}.plan-features-compact{gap:.375rem}.feature-tag{font-size:.65rem;padding:.25rem .5rem}.maintenance-banner{padding:1rem;margin-bottom:1rem}.maintenance-content h3{font-size:1rem}.maintenance-content p{font-size:.8rem}}.legal-page .legal-card{max-width:640px}.legal-subtitle{color:var(--text-muted);font-size:var(--font-size-sm);margin-top:.25rem}.legal-prose{text-align:left;padding:0 var(--space-lg) var(--space-xl);max-height:min(70vh,720px);overflow-y:auto;-webkit-overflow-scrolling:touch}.legal-section{margin-bottom:var(--space-2xl)}.legal-section:last-of-type{margin-bottom:var(--space-lg)}.legal-section h2{font-size:1.05rem;font-weight:700;color:var(--text-primary);margin:0 0 var(--space-md);line-height:1.35}.legal-section p{color:var(--text-secondary);font-size:var(--font-size-sm);line-height:1.65;margin:0 0 var(--space-md)}.legal-section p:last-child{margin-bottom:0}.legal-cross{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-lg) var(--space-md) var(--space-xl);border-top:1px solid var(--border-color);font-size:var(--font-size-sm)}.legal-cross a{color:var(--accent-color);font-weight:600;text-decoration:none}.legal-cross a:hover{text-decoration:underline}.legal-cross-sep{color:var(--text-muted);-webkit-user-select:none;user-select:none}@media (max-width: 480px){.legal-prose{padding-left:var(--space-md);padding-right:var(--space-md);max-height:none}}.avatar-3d-viewer-overlay{position:fixed;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.avatar-3d-viewer-modal{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;width:90vw;max-width:1200px;height:85vh;max-height:800px;display:flex;flex-direction:column;overflow:hidden;animation:viewerSlideIn .3s ease-out}@keyframes viewerSlideIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.viewer-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem;border-bottom:1px solid #e0e0e0;background:linear-gradient(135deg,#f8f9fa,#e9ecef)}.viewer-header h3{margin:0;color:#333;font-size:1.5rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.viewer-close{background:none;border:none;color:#666;cursor:pointer;padding:8px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease;width:40px;height:40px}.viewer-close:hover{background:#f0f0f0;color:#333;transform:scale(1.1)}.viewer-content{flex:1;position:relative;background:#f8f9fa;overflow:hidden}.viewer-canvas{width:100%;height:100%;cursor:grab;position:relative;background:#f0f0f0}.viewer-canvas:active{cursor:grabbing}.viewer-canvas.embedded{flex:1;min-height:0;width:100%;border-radius:inherit;cursor:grab;background:transparent;position:relative}.viewer-canvas.embedded:active{cursor:grabbing}.viewer-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:#666;z-index:10;background:#ffffffe6;padding:2rem;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.loading-spinner{width:48px;height:48px;border:4px solid #f3f3f3;border-top:4px solid #007bff;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.viewer-loading p{margin:0;font-size:1rem;color:#888}.viewer-error{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:#dc3545;z-index:10;background:#fffffff2;padding:2rem;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 20px #dc354533}.viewer-error svg{margin-bottom:1rem;opacity:.7}.viewer-error p{margin:0;font-size:1rem;color:#666}.viewer-warning{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:#ffc107;z-index:10;background:#fffffff2;padding:2rem;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 20px #ffc10733}.viewer-warning svg{margin-bottom:1rem;opacity:.7}.viewer-warning p{margin:0;font-size:1rem;color:#856404}.retry-btn{background:#007bff;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:.875rem;margin-top:1rem;transition:all .2s ease;font-weight:500}.retry-btn:hover{background:#0056b3;transform:translateY(-1px);box-shadow:0 4px 12px #007bff4d}.retry-btn:active{transform:translateY(0)}.viewer-controls{padding:1rem 2rem;border-top:1px solid #e0e0e0;background:#f8f9fa;display:flex;align-items:center;justify-content:space-between;gap:1rem}.control-info{flex:1}.control-info p{margin:0;font-size:.875rem;color:#666;font-style:italic}.webgl-info{font-size:.75rem!important;color:#007bff!important;font-weight:500!important;margin-top:.25rem!important}.control-buttons{display:flex;gap:.5rem}.control-btn{background:#fff;border:1px solid #e0e0e0;color:#333;padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:.875rem;display:flex;align-items:center;gap:.5rem;transition:all .2s ease}.control-btn:hover{background:#f8f9fa;border-color:#007bff;color:#007bff;transform:translateY(-1px);box-shadow:0 4px 12px #007bff26}.control-btn:active{transform:translateY(0)}.embedded-viewer{width:100%;height:100%;min-height:0;position:relative;border-radius:var(--radius-md, 8px);overflow:hidden}.embedded-viewer.embedded-viewer--stage{display:flex;flex-direction:column;flex:1;min-height:220px;background:radial-gradient(ellipse 78% 62% at 50% 36%,color-mix(in srgb,var(--accent-color, #3b82f6) 16%,var(--bg-secondary, #1e293b)) 0%,var(--bg-primary, #0f172a) 58%,var(--bg-primary, #0f172a) 100%);box-shadow:inset 0 0 48px color-mix(in srgb,var(--accent-color, #3b82f6) 8%,transparent)}[data-theme=light] .embedded-viewer.embedded-viewer--stage{background:radial-gradient(ellipse 78% 62% at 50% 36%,color-mix(in srgb,var(--accent-color) 12%,var(--bg-secondary)) 0%,var(--bg-primary) 72%);box-shadow:inset 0 0 40px color-mix(in srgb,var(--accent-color) 6%,transparent)}@media (max-width: 1024px){.avatar-3d-viewer-modal{width:92vw;height:88vh}}@media (max-width: 768px){.avatar-3d-viewer-modal{width:95vw;height:90vh;border-radius:12px}.viewer-header{padding:1rem 1.5rem}.viewer-header h3{font-size:1.25rem}.viewer-controls{padding:1rem 1.5rem;flex-direction:column;align-items:stretch;gap:.75rem}.control-info p{text-align:center;font-size:.8rem}.control-buttons{justify-content:center}.control-btn{padding:.75rem 1rem;font-size:.9rem}.viewer-loading,.viewer-error,.viewer-warning{padding:1.5rem;margin:0 1rem;width:calc(100% - 2rem);max-width:300px}}@media (max-width: 480px){.avatar-3d-viewer-modal{width:100vw;height:100vh;border-radius:0}.viewer-header,.viewer-controls{padding:1rem}.control-buttons{flex-direction:column}.viewer-loading,.viewer-error,.viewer-warning{padding:1rem;margin:0 .5rem;width:calc(100% - 1rem)}.loading-spinner{width:36px;height:36px;border-width:3px}.viewer-loading p,.viewer-error p,.viewer-warning p{font-size:.875rem}}.viewer-canvas:focus{outline:2px solid #007bff;outline-offset:2px}.control-btn:focus{outline:2px solid #007bff;outline-offset:2px}@media (prefers-color-scheme: dark){.avatar-3d-viewer-modal{background:#1a1a1a;color:#fff}.viewer-header{background:linear-gradient(135deg,#2d2d2d,#1a1a1a);border-bottom-color:#333}.viewer-header h3{color:#fff}.viewer-content{background:#0f0f0f}.viewer-controls{background:#2d2d2d;border-top-color:#333}.control-btn{background:#333;border-color:#555;color:#fff}.control-btn:hover{background:#444;border-color:#007bff}.control-info p{color:#aaa}.viewer-canvas{background:#1a1a1a}.viewer-canvas.embedded{background:transparent}.embedded-viewer:not(.embedded-viewer--stage){background:#2d2d2d}}@media (max-width: 768px){.viewer-canvas:not(.embedded){max-width:320px;max-height:240px;width:320px;height:240px;overflow:hidden}.avatar-3d-viewer{max-width:100vw;overflow:hidden}.embedded-viewer{max-width:100%;overflow:hidden}}.subscription-limits{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:20px;margin:20px 0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.subscription-limits.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px}.subscription-limits.error{background:#ff00001a;border-color:#ff00004d;color:#ff6b6b}.loading-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.1);border-top:3px solid #00d4ff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:10px}.subscription-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.subscription-header h3{margin:0;color:#fff;font-size:1.5rem}.plan-badge{padding:6px 12px;border-radius:20px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-free{background:linear-gradient(135deg,#6c757d,#495057);color:#fff}.badge-pro{background:linear-gradient(135deg,#007bff,#0056b3);color:#fff}.badge-advance{background:linear-gradient(135deg,gold,#ffb300);color:#333}.limits-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin-bottom:20px}.limit-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:16px;transition:all .3s ease}.limit-card:hover{background:#ffffff0d;border-color:#ffffff26;transform:translateY(-2px)}.limit-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.limit-header h4{margin:0;color:#fff;font-size:1rem;font-weight:500}.limit-usage{font-size:.9rem;color:#00d4ff;font-weight:600}.progress-bar{width:100%;height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;border-radius:4px;transition:width .3s ease}.progress-fill.success{background:linear-gradient(90deg,#28a745,#20c997)}.progress-fill.warning{background:linear-gradient(90deg,#ffc107,#fd7e14)}.progress-fill.danger{background:linear-gradient(90deg,#dc3545,#e83e8c)}.limit-details{display:flex;justify-content:space-between;font-size:.8rem;color:#ffffffb3}.monthly-usage{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:16px;margin-bottom:20px}.monthly-usage h4{margin:0 0 12px;color:#fff;font-size:1rem}.usage-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.usage-stat{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.usage-label{color:#fffc}.usage-value{color:#00d4ff;font-weight:600}.features-section{margin-bottom:20px}.features-section h4{margin:0 0 12px;color:#fff;font-size:1rem}.subscription-limits .features-grid{display:flex;flex-wrap:wrap;gap:8px}.feature-tag{background:#00d4ff33;border:1px solid rgba(0,212,255,.3);color:#00d4ff;padding:4px 8px;border-radius:12px;font-size:.8rem;font-weight:500}.upgrade-section{background:linear-gradient(135deg,#007bff1a,#00d4ff1a);border:1px solid rgba(0,212,255,.3);border-radius:8px;padding:16px;text-align:center;margin-bottom:20px}.upgrade-message{margin:0 0 12px;color:#fff;font-size:.9rem}.upgrade-button{background:linear-gradient(135deg,#007bff,#00d4ff);border:none;color:#fff;padding:10px 20px;border-radius:6px;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px}.upgrade-button:hover{background:linear-gradient(135deg,#0056b3,#09c);transform:translateY(-2px);box-shadow:0 4px 12px #007bff4d}.warnings-section{border-top:1px solid rgba(255,255,255,.1);padding-top:16px}.warning-message{background:#ffc1071a;border:1px solid rgba(255,193,7,.3);color:#ffc107;padding:8px 12px;border-radius:6px;margin-bottom:8px;font-size:.9rem}@media (max-width: 768px){.limits-grid,.usage-stats{grid-template-columns:1fr}.limit-details{flex-direction:column;gap:4px}.subscription-header{flex-direction:column;gap:10px;text-align:center}}.onboarding-container{--onboarding-pad-x: clamp(.65rem, 3vw, 1.5rem);--onboarding-pad-y: clamp(.5rem, 2vw, 1rem);background:var(--bg-primary);display:flex;flex-direction:column;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;min-height:100dvh;width:100%;position:relative;overflow-x:hidden}.onboarding-container:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;background:radial-gradient(ellipse 80% 50% at 50% -20%,color-mix(in srgb,var(--accent-color) 12%,transparent),transparent 55%),radial-gradient(circle at 100% 100%,color-mix(in srgb,var(--accent-color) 6%,transparent),transparent 45%)}.onboarding-container>*{position:relative;z-index:1}.onboarding-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:var(--onboarding-pad-x);color:var(--text-secondary);font-size:.875rem}.onboarding-container .onboarding-loading .loading-spinner{width:2.25rem;height:2.25rem;border:3px solid var(--border-color);border-top-color:var(--accent-color);border-radius:50%;animation:onboarding-spin .85s linear infinite}@keyframes onboarding-spin{to{transform:rotate(360deg)}}.onboarding-inline-loading{text-align:center;color:var(--text-secondary);font-size:.8125rem;padding:.75rem}.onboarding-inline-error{text-align:center;color:var(--error-color);font-size:.8125rem;padding:.75rem}.onboarding-card{background:var(--bg-card);width:100%;max-width:1120px;margin:0 auto;display:flex;flex-direction:column;flex:1;min-height:0;border:1px solid var(--border-color);border-radius:0;box-shadow:none}@media (min-width: 640px){.onboarding-card{margin-top:var(--onboarding-pad-y);margin-bottom:var(--onboarding-pad-y);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);overflow:hidden}}.onboarding-header{background:var(--chat-glass-bg);backdrop-filter:blur(10px) saturate(120%);-webkit-backdrop-filter:blur(10px) saturate(120%);color:var(--text-primary);padding:.65rem var(--onboarding-pad-x) .75rem;border-bottom:1px solid var(--chat-glass-border);position:relative}.onboarding-header-progress{height:3px;background:var(--border-color);border-radius:2px;margin-bottom:.65rem;overflow:hidden}.onboarding-header-progress:after{content:"";display:block;height:100%;width:0%;background:var(--gradient-accent);border-radius:inherit;transition:width var(--transition-normal) var(--ease-out)}.onboarding-header[data-onboarding-step="1"] .onboarding-header-progress:after{width:50%}.onboarding-header[data-onboarding-step="2"] .onboarding-header-progress:after{width:100%}.steps-indicator{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem .75rem;max-width:36rem;margin:0 auto}.step-indicator{text-align:center;transition:border-color var(--transition-normal),background var(--transition-normal);position:relative;padding:.55rem .45rem;border-radius:var(--radius-md);background:color-mix(in srgb,var(--bg-secondary) 88%,transparent);border:1px solid var(--border-color)}.step-indicator.active{border-color:color-mix(in srgb,var(--accent-color) 40%,var(--border-color))}.step-indicator.current{border-color:var(--accent-color);background:color-mix(in srgb,var(--accent-color) 10%,var(--bg-secondary));box-shadow:none}.step-indicator.current:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:28px;height:2px;background:var(--accent-color);border-radius:2px 2px 0 0}.step-number{width:2rem;height:2rem;background:var(--bg-tertiary);color:var(--text-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto .4rem;font-weight:700;font-size:.8125rem;border:1px solid var(--border-color);transition:border-color var(--transition-fast),background var(--transition-fast),color var(--transition-fast)}.step-indicator.current .step-number{background:var(--accent-color);border-color:var(--accent-color);color:#fff}.step-info h4{margin:0 0 .2rem;font-size:.8125rem;font-weight:600;line-height:1.2;color:var(--text-primary)}.step-info p{margin:0;font-size:.6875rem;line-height:1.3;color:var(--text-secondary)}.onboarding-limits-slot{width:100%;max-width:1120px;margin:0 auto;padding:0 var(--onboarding-pad-x) max(.75rem,env(safe-area-inset-bottom,0px))}.onboarding-limits-slot .subscription-limits{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1rem 1.1rem;margin:0;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.onboarding-limits-slot .subscription-header h3,.onboarding-limits-slot .limit-header h4,.onboarding-limits-slot .monthly-usage h4,.onboarding-limits-slot .features-section h4,.onboarding-limits-slot .upgrade-message{color:var(--text-primary)}.onboarding-limits-slot .limit-usage,.onboarding-limits-slot .usage-value{color:var(--accent-color)}.onboarding-limits-slot .limit-details,.onboarding-limits-slot .usage-label{color:var(--text-secondary)}.onboarding-limits-slot .limit-card{background:var(--bg-primary);border-color:var(--border-color)}.onboarding-limits-slot .limit-card:hover{background:var(--bg-tertiary);border-color:var(--border-light);transform:none}.onboarding-limits-slot .progress-bar{background:var(--border-color)}.onboarding-limits-slot .monthly-usage{background:var(--bg-primary);border-color:var(--border-color)}.onboarding-limits-slot .feature-tag{background:color-mix(in srgb,var(--accent-color) 18%,transparent);border-color:color-mix(in srgb,var(--accent-color) 35%,transparent);color:var(--accent-hover)}@media (min-width: 640px){.onboarding-limits-slot .subscription-limits{border-radius:var(--radius-xl)}}.onboarding-content{padding:.85rem var(--onboarding-pad-x) max(5rem,env(safe-area-inset-bottom));display:flex;flex-direction:column;flex:1;min-height:0;width:100%;box-sizing:border-box}@media (min-width: 769px){.onboarding-content{padding:1rem 1.25rem 1.25rem;padding-bottom:max(1.25rem,env(safe-area-inset-bottom))}}.onboarding-step{max-width:none;margin:0;display:flex;flex-direction:column;flex:1;min-height:0}.step-content{display:flex;flex-direction:column;flex:1;min-height:0}.onboarding-step-intro{margin-bottom:.75rem}.onboarding-step-intro h3{margin:0 0 .35rem;color:var(--text-primary);font-size:clamp(1.05rem,2.2vw,1.4rem);text-align:center;font-weight:700;line-height:1.2}@media (min-width: 769px){.onboarding-step-intro{text-align:left;max-width:38rem;margin-left:0;margin-right:auto;margin-bottom:.85rem}.onboarding-step-intro h3,.onboarding-step-intro p{text-align:left}}.onboarding-step-intro p{color:var(--text-secondary);font-size:clamp(.8125rem,1.6vw,.9375rem);text-align:center;line-height:1.45;max-width:34rem;margin:0 auto}@media (min-width: 769px){.onboarding-step-intro p{margin-left:0;margin-right:0}}.onboarding-option-card{border:1px solid var(--border-color);border-radius:var(--radius-md);padding:.65rem .75rem .8rem;background:var(--bg-secondary)}.onboarding-option-card>h4:first-child{margin-top:0}.onboarding-option-card--upload{background:var(--bg-primary)}.voice-controls-card{display:flex;flex-direction:column;gap:.65rem;padding:.65rem .75rem;margin-bottom:.75rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md)}.voice-controls-card .voice-category-tabs{margin-bottom:0}.voice-controls-card .voice-filters{margin-bottom:0;padding:.5rem .6rem;background:var(--bg-secondary)}.voice-controls-card .voice-results-info{margin-bottom:0}.avatar-selection-layout,.voice-selection-layout{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(240px,.92fr);gap:.85rem 1rem;margin-top:.15rem;align-items:start;flex:1;min-height:0}@media (max-width: 1024px){.avatar-selection-layout,.voice-selection-layout{grid-template-columns:1fr;gap:.75rem}.avatar-preview-panel,.voice-preview-panel{order:-1;margin-bottom:.35rem;position:static}}.avatar-selection-panel,.voice-selection-panel{display:flex;flex-direction:column;gap:1rem;flex:1;min-height:0}.avatar-preview-panel,.voice-preview-panel{background:var(--chat-glass-bg);backdrop-filter:blur(8px) saturate(120%);-webkit-backdrop-filter:blur(8px) saturate(120%);border-radius:var(--radius-md);padding:.65rem .75rem;border:1px solid var(--chat-glass-border);position:sticky;top:.5rem;height:fit-content;box-shadow:var(--shadow-sm);flex-shrink:0}.preview-content h4{margin:0 0 .5rem;color:var(--text-primary);font-size:.875rem;text-align:center;font-weight:600}.preview-3d-container{width:100%;max-width:100%;min-height:clamp(220px,32vh,300px);height:clamp(220px,32vh,300px);display:flex;flex-direction:column;background:var(--bg-primary);border-radius:var(--radius-md);overflow:hidden;margin:0 auto .4rem;border:1px solid var(--border-color);position:relative;box-sizing:border-box;min-width:0}.preview-3d-container .embedded-viewer.embedded-viewer--stage{flex:1;min-height:0;border-radius:calc(var(--radius-md) - 1px)}.preview-info p{margin:.25rem 0;color:var(--text-secondary);font-size:.75rem;text-align:left;padding:.25rem 0;border-bottom:1px solid var(--border-light)}.preview-info p:last-child{border-bottom:none}.preview-empty{text-align:center;padding:1rem;color:var(--text-secondary)}.preview-empty h4{margin:.5rem 0 .25rem;color:var(--text-primary);font-size:.875rem}.preview-empty p{margin:0;font-size:.75rem;line-height:1.4}.voice-category-tabs{display:flex;gap:.5rem;margin-bottom:.75rem;overflow-x:auto;padding-bottom:.25rem;scrollbar-width:thin;flex-wrap:wrap}.voice-category-tabs::-webkit-scrollbar{height:3px}.voice-category-tabs::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:2px}.voice-category-tabs::-webkit-scrollbar-thumb{background:var(--accent-color);border-radius:2px}.category-tab{padding:.375rem .75rem;border:1px solid var(--border-color);border-radius:16px;background:var(--bg-secondary);color:var(--text-secondary);font-weight:600;font-size:.75rem;cursor:pointer;transition:all var(--transition-normal);white-space:nowrap;min-width:fit-content;flex-shrink:0}.category-tab:hover{border-color:var(--accent-color);color:var(--accent-color);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.category-tab.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color);box-shadow:var(--shadow-sm)}.voice-filters{display:grid;grid-template-columns:minmax(10.5rem,13.5rem) minmax(0,1fr);gap:.5rem .75rem;align-items:end;margin-bottom:.75rem;padding:.65rem .75rem;background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color)}.filter-group,.search-group{display:flex;flex-direction:column;gap:.375rem;min-width:0}.filter-group label{font-weight:600;color:var(--text-primary);font-size:.75rem}.filter-group select,.voice-search-input{box-sizing:border-box;min-height:2.375rem;padding:.5rem .65rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-size:.8125rem;line-height:1.35;transition:border-color var(--transition-fast);width:100%;min-width:0}.voice-filters .filter-group select{width:100%;max-width:100%;cursor:pointer;appearance:auto}.filter-group select:focus,.voice-search-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #3b82f61a}.voice-results-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding:.5rem .75rem;background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-color);flex-wrap:wrap;gap:.5rem}.results-count{color:var(--text-primary);font-weight:600;font-size:.75rem}.page-info{color:#fff;background:var(--accent-color);padding:.25rem .5rem;border-radius:var(--radius-md);font-weight:500;font-size:.625rem}.avatar-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,118px),1fr));gap:.5rem;margin-bottom:.4rem}.voice-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,168px),1fr));gap:.5rem;margin-bottom:.55rem;max-height:min(360px,48vh);overflow-y:auto;padding:.1rem .35rem .25rem 0;scrollbar-width:thin}.voice-grid::-webkit-scrollbar{width:6px}.voice-grid::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:3px}.voice-grid::-webkit-scrollbar-thumb{background:var(--accent-color);border-radius:3px}.voice-grid::-webkit-scrollbar-thumb:hover{background:var(--accent-hover)}.avatar-option,.voice-option{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1rem;cursor:pointer;transition:all var(--transition-normal);text-align:center;position:relative;overflow:hidden;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.voice-option{text-align:left;display:flex;align-items:flex-start;gap:.75rem}.voice-info{min-width:0;flex:1}.avatar-option:hover,.voice-option:hover{border-color:var(--border-light);transform:none;box-shadow:var(--shadow-sm);background:var(--bg-tertiary)}.avatar-option.selected,.voice-option.selected{border-color:var(--accent-color);background:color-mix(in srgb,var(--accent-color) 10%,var(--bg-secondary));box-shadow:0 0 0 2px var(--accent-color);transform:none}.avatar-preview{width:48px;height:48px;background:var(--bg-tertiary);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto .75rem;color:var(--text-secondary);border:2px solid var(--border-light);flex-shrink:0;transition:all var(--transition-normal)}.avatar-option:hover .avatar-preview{border-color:var(--accent-color);background:var(--accent-color-light);color:var(--accent-color)}.voice-preview{width:40px;height:40px;background:var(--bg-tertiary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);flex-shrink:0;border:2px solid var(--border-light);transition:all var(--transition-normal)}.voice-option:hover .voice-preview{border-color:var(--accent-color);background:var(--accent-color-light);color:var(--accent-color)}.avatar-info h5,.voice-info h5{margin:0 0 .25rem;color:var(--text-primary);font-size:.75rem;font-weight:600;line-height:1.2}.avatar-info p,.voice-info p{margin:0 0 .25rem;color:var(--text-secondary);font-size:.625rem;line-height:1.3}.avatar-info .category{background:var(--accent-color);color:#fff;padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:.625rem;font-weight:500;text-transform:capitalize;display:inline-block}.voice-tags{display:flex;gap:.25rem;margin:.25rem 0;flex-wrap:wrap}.voice-language,.voice-category{background:var(--accent-color);color:#fff;padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:.625rem;font-weight:600;white-space:nowrap}.voice-description{color:var(--text-secondary);font-size:.625rem;margin:.25rem 0 0;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.play-button{width:24px;height:24px;border-radius:50%;border:none;background:var(--accent-color);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);flex-shrink:0}.play-button:hover{background:var(--accent-hover);transform:scale(1.05);box-shadow:var(--shadow-sm)}.preview-play-button{width:100%;padding:.5rem;border:none;border-radius:var(--radius-md);background:var(--accent-color);color:#fff;font-weight:600;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:.5rem;font-size:.75rem}.preview-play-button:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.preview-play-button.playing{background:var(--error-color)}.option-section{margin-bottom:.85rem}.option-section.onboarding-option-card{margin-bottom:1rem}.option-section h4{margin:0 0 .5rem;color:var(--text-primary);font-size:.875rem;font-weight:600;border-bottom:1px solid var(--border-color);padding-bottom:.375rem;position:relative}.option-section h4:after{content:"";position:absolute;bottom:-1px;left:0;width:40px;height:1px;background:var(--accent-color);border-radius:1px}.onboarding-voice-upload-meta.voice-upload-meta--inline{display:flex;flex-wrap:wrap;gap:.75rem 1.25rem;margin-bottom:.75rem;align-items:flex-end;text-align:left}.onboarding-voice-upload-meta .voice-upload-meta__field{display:flex;flex-direction:column;gap:.25rem;min-width:min(100%,11rem)}.onboarding-voice-upload-meta .voice-upload-meta__field label{font-size:.7rem;font-weight:600;color:var(--text-secondary)}.onboarding-voice-upload-meta .voice-upload-meta__field select{padding:.4rem .5rem;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-size:.8rem}.upload-section{text-align:center;padding:.75rem;background:var(--bg-secondary);border-radius:var(--radius-md);border:2px dashed var(--border-color);transition:all var(--transition-normal)}.upload-button{background:var(--accent-color);color:#fff;border:none;border-radius:var(--radius-md);padding:.375rem .75rem;font-size:.75rem;cursor:pointer;transition:all var(--transition-normal);display:inline-flex;align-items:center;gap:.5rem;font-weight:500}.upload-button:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.file-info{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:.5rem;margin-top:.5rem;display:flex;align-items:center;justify-content:space-between;gap:.5rem;flex-wrap:wrap}.file-info span{color:var(--text-primary);font-size:.75rem;min-width:0;flex:1}.file-size{color:var(--text-secondary);font-size:.625rem}.remove-file{background:var(--error-color);color:#fff;border:none;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.remove-file:hover{transform:scale(1.1);box-shadow:var(--shadow-sm)}.file-requirements{margin-top:.5rem;color:var(--text-secondary);font-size:.625rem;font-style:italic}.onboarding-navigation{padding:.65rem var(--onboarding-pad-x);padding-bottom:max(.65rem,env(safe-area-inset-bottom));background:var(--chat-glass-bg);backdrop-filter:blur(12px) saturate(120%);-webkit-backdrop-filter:blur(12px) saturate(120%);display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--chat-glass-border);flex-wrap:wrap;gap:.5rem}@media (max-width: 768px){.onboarding-navigation{position:sticky;bottom:0;z-index:30;margin-top:auto}}.navigation-right{display:flex;gap:.75rem}.onboarding-container .btn-primary,.onboarding-container .btn-secondary{padding:.6rem 1.15rem;border:none;border-radius:var(--radius-md);font-size:.8125rem;font-weight:600;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),opacity var(--transition-fast);min-width:5.5rem;position:relative;overflow:hidden;white-space:nowrap}.onboarding-container .btn-primary{background:var(--accent-color);color:#fff;box-shadow:var(--shadow-md)}.onboarding-container .btn-primary:hover:not(:disabled){background:var(--accent-hover);transform:none;box-shadow:var(--shadow-sm)}.onboarding-container .btn-primary:disabled{opacity:.6;cursor:not-allowed}.onboarding-container .btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.onboarding-container .btn-secondary:hover:not(:disabled){background:var(--bg-tertiary);transform:none;box-shadow:none}.error-message{background:var(--error-color-light);color:var(--error-color);padding:.5rem;border-radius:var(--radius-md);margin-top:.5rem;text-align:center;font-size:.75rem;border:1px solid var(--error-color)}.no-voices-found{text-align:center;padding:1rem;color:var(--text-secondary)}.no-voices-found p{margin:.5rem 0 0;font-size:.75rem}.reset-filters-btn{margin-top:.5rem;padding:.375rem .75rem;border:1px solid var(--accent-color);border-radius:var(--radius-md);background:transparent;color:var(--accent-color);cursor:pointer;transition:all var(--transition-normal);font-size:.75rem;font-weight:500}.reset-filters-btn:hover{background:var(--accent-color);color:#fff;transform:translateY(-1px)}.voice-pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem;padding:1rem;background:var(--bg-tertiary);border-radius:var(--radius-lg);border:1px solid var(--border-color);flex-wrap:wrap}.page-btn{padding:.75rem 1.25rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-primary);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-normal);min-width:80px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);position:relative;overflow:hidden}.page-btn:hover:not(:disabled){background:var(--accent-color);color:#fff;border-color:var(--accent-color);transform:translateY(-2px);box-shadow:var(--shadow-md)}.page-btn:disabled{opacity:.5;cursor:not-allowed;background:var(--bg-tertiary);color:var(--text-secondary)}.page-numbers{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;justify-content:center}.page-number{width:40px;height:40px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-primary);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-normal);display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);position:relative;overflow:hidden}.page-number:hover{background:var(--accent-color-light);border-color:var(--accent-color);transform:translateY(-2px);box-shadow:var(--shadow-md)}.page-number.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color);box-shadow:0 0 0 3px var(--accent-color-light);transform:scale(1.1)}.page-number.active:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.2) 0%,transparent 100%);pointer-events:none}.voice-preview-info{text-align:center}.voice-preview-header{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:.75rem;flex-wrap:wrap}.voice-preview-header h5{margin:0;color:var(--text-primary);font-size:.875rem;text-align:center}.voice-preview-details p{margin:.25rem 0;color:var(--text-secondary);font-size:.75rem;text-align:left;padding:.25rem 0;border-bottom:1px solid var(--border-light)}.voice-preview-details p:last-child{border-bottom:none}.voice-details{display:flex;gap:.5rem;margin:.5rem 0;flex-wrap:wrap}@media (max-width: 768px){.onboarding-header{padding:.55rem var(--onboarding-pad-x) .65rem}.steps-indicator{display:flex;flex-direction:row;gap:.5rem;max-width:100%}.step-indicator{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center;padding:.5rem .35rem;min-width:0}.step-number{width:38px;height:38px;font-size:.9rem;margin:0 0 .35rem}.step-info{width:100%;min-width:0}.step-info h4{font-size:.68rem;font-weight:600;line-height:1.25;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.step-info p{display:none}.onboarding-content{padding:.75rem var(--onboarding-pad-x) max(4.75rem,env(safe-area-inset-bottom));max-width:100%}.onboarding-step-intro h3{font-size:1.125rem;margin-bottom:.3rem}.onboarding-step-intro p{font-size:.8125rem}.avatar-selection-layout,.voice-selection-layout{grid-template-columns:1fr;gap:.65rem;margin-top:.35rem}.avatar-preview-panel,.voice-preview-panel{order:-1;margin-bottom:.5rem;position:static;padding:.55rem .65rem;max-width:100%;box-sizing:border-box}.preview-3d-container{height:clamp(150px,32vw,200px);max-width:100%;width:100%;overflow:hidden;box-sizing:border-box;min-width:0;margin:0 auto}.avatar-selection-panel,.voice-selection-panel{gap:.75rem}.avatar-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem}.voice-grid{grid-template-columns:1fr;gap:.5rem;max-height:min(48vh,340px)}.avatar-option,.voice-option{padding:.75rem}.avatar-preview{width:40px;height:40px;margin-bottom:.5rem}.voice-preview{width:36px;height:36px}.onboarding-navigation{padding:.75rem .85rem;padding-bottom:max(.75rem,env(safe-area-inset-bottom));flex-direction:row;flex-wrap:nowrap;gap:.65rem;justify-content:space-between;align-items:stretch}.navigation-right{flex:1;display:flex;justify-content:flex-end;min-width:0}.onboarding-navigation>.btn-secondary{flex:0 0 auto;min-width:6.5rem}.onboarding-container .btn-primary,.onboarding-container .btn-secondary{padding:.75rem 1rem;font-size:.875rem;min-width:0}.onboarding-navigation .navigation-right .btn-primary{flex:1;max-width:none}.voice-filters{grid-template-columns:1fr;gap:.75rem;padding:.75rem}.voice-category-tabs{flex-wrap:wrap;gap:.5rem;justify-content:center}.category-tab{padding:.5rem .75rem;font-size:.75rem;flex:1;min-width:0;text-align:center}.voice-pagination{flex-direction:row;flex-wrap:wrap;gap:.5rem;padding:.5rem .65rem;background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color);justify-content:center}.page-numbers{flex-wrap:wrap;justify-content:center;gap:.35rem}.page-number{width:2rem;height:2rem;font-size:.75rem;font-weight:600;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:border-color var(--transition-fast),background var(--transition-fast)}.page-number:hover,.page-number.active{transform:none;box-shadow:none}.page-btn{padding:.45rem .75rem;font-size:.75rem;font-weight:600;min-width:0;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-md)}.page-btn:hover:not(:disabled){transform:none;box-shadow:none;background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.voice-results-info{flex-direction:column;gap:.75rem;text-align:center;padding:.75rem}.preview-content h4{font-size:.8125rem;margin-bottom:.45rem}.preview-info p{font-size:.7rem;margin:.2rem 0;padding:.2rem 0}}@media (max-width: 480px){.onboarding-header{padding:.45rem var(--onboarding-pad-x) .55rem}.step-indicator{padding:.35rem .2rem}.step-number{width:30px;height:30px;font-size:.75rem}.step-info h4{font-size:.6rem}.onboarding-content{padding:.55rem var(--onboarding-pad-x) max(4.5rem,env(safe-area-inset-bottom))}.onboarding-step-intro h3{font-size:1.05rem}.onboarding-step-intro p{font-size:.78rem}.avatar-selection-layout,.voice-selection-layout{gap:.55rem;margin-top:.35rem}.avatar-selection-panel,.voice-selection-panel{gap:.45rem}.avatar-grid{grid-template-columns:repeat(auto-fill,minmax(min(100%,92px),1fr));gap:.4rem}.voice-grid{gap:.4rem;max-height:min(42vh,260px)}.avatar-option,.voice-option{padding:.45rem}.avatar-preview{width:30px;height:30px;margin-bottom:.3rem}.voice-preview{width:26px;height:26px}.avatar-preview-panel,.voice-preview-panel{padding:.5rem .55rem;margin-bottom:.45rem;max-width:100%;box-sizing:border-box}.preview-3d-container{height:clamp(140px,30vw,180px);max-width:100%;width:100%;overflow:hidden;box-sizing:border-box;min-width:0}.onboarding-navigation{padding:.65rem;padding-bottom:max(.65rem,env(safe-area-inset-bottom));gap:.5rem}.onboarding-container .btn-primary,.onboarding-container .btn-secondary{padding:.7rem .85rem;font-size:.8rem}.voice-filters{padding:.5rem;gap:.5rem}.category-tab{padding:.375rem .5rem;font-size:.625rem}}@media (max-width: 360px){.onboarding-header{padding:.4rem var(--onboarding-pad-x)}.step-indicator{padding:.375rem;gap:.5rem}.step-number{width:32px;height:32px;font-size:.75rem}.step-info h4{font-size:.625rem}.step-info p{font-size:.5rem}.onboarding-content{padding:.45rem var(--onboarding-pad-x) max(4.25rem,env(safe-area-inset-bottom))}.onboarding-step-intro h3{font-size:1rem}.onboarding-step-intro p{font-size:.68rem}.avatar-grid{grid-template-columns:repeat(auto-fill,minmax(min(100%,76px),1fr));gap:.3rem}.voice-grid{gap:.3rem;max-height:min(38vh,220px)}.avatar-option,.voice-option{padding:.35rem}.avatar-preview{width:26px;height:26px}.voice-preview{width:22px;height:22px}.avatar-selection-layout,.voice-selection-layout{gap:.45rem;margin-top:.2rem}.avatar-preview-panel,.voice-preview-panel{padding:.45rem .5rem;margin-bottom:.4rem;max-width:100%;box-sizing:border-box}.preview-3d-container{height:clamp(120px,28vw,150px);max-width:100%;width:100%;overflow:hidden;box-sizing:border-box;min-width:0}.onboarding-container .btn-primary,.onboarding-container .btn-secondary{max-width:none;padding:.55rem .7rem;font-size:.7rem;min-width:4.5rem}}.avatar-option,.voice-option,.category-tab,.upload-section{will-change:transform}.onboarding-container .btn-primary:focus,.onboarding-container .btn-secondary:focus,.upload-button:focus,.play-button:focus,.preview-play-button:focus,.category-tab:focus{outline:none;box-shadow:0 0 0 2px #3b82f64d}@media (prefers-reduced-motion: reduce){.avatar-option,.voice-option,.category-tab,.upload-section,.onboarding-container .btn-primary,.onboarding-container .btn-secondary{transition:none}.avatar-option:hover,.voice-option:hover,.category-tab:hover,.upload-section:hover,.onboarding-container .btn-primary:hover,.onboarding-container .btn-secondary:hover{transform:none}}.upload-success,.upload-error{display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:8px;margin:12px 0;font-weight:500;animation:slideIn .3s ease}.upload-success{background:linear-gradient(135deg,#d4edda,#c3e6cb);color:#155724;border:1px solid #c3e6cb}.upload-error{background:linear-gradient(135deg,#f8d7da,#f5c6cb);color:#721c24;border:1px solid #f5c6cb}.upload-success .icon,.upload-error .icon{flex-shrink:0}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.avatar-processing-status{margin:16px 0;border-radius:12px;overflow:hidden}.avatar-processing-status .status-header{background:#ffffff1a;padding:16px;border-bottom:1px solid rgba(255,255,255,.1)}.avatar-processing-status .status-details{padding:16px}@media (max-width: 768px){.upload-success,.upload-error{padding:10px 12px;font-size:.875rem}.avatar-processing-status{margin:12px 0}}.upload-button.disabled{opacity:.5;cursor:not-allowed;background:#ffffff0d;border-color:#ffffff1a}.upload-button.disabled:hover{background:#ffffff0d;border-color:#ffffff1a;transform:none}.upgrade-notice{margin-top:10px;padding:12px;background:#ffc1071a;border:1px solid rgba(255,193,7,.3);border-radius:6px;text-align:center}.upgrade-notice p{margin:0 0 8px;color:#ffc107;font-size:.9rem}.upgrade-button-small{background:linear-gradient(135deg,#ffc107,#ffb300);border:none;color:#333;padding:6px 12px;border-radius:4px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px}.upgrade-button-small:hover{background:linear-gradient(135deg,#ffb300,#ffa000);transform:translateY(-1px);box-shadow:0 2px 8px #ffc1074d}.error-message.subscription-error{background:linear-gradient(135deg,#ffc1071a,#ff98001a);border-color:#ffc10766;color:#ffc107}.subscription-loading{display:flex;align-items:center;justify-content:center;padding:20px;background:#ffffff0d;border-radius:8px;margin:10px 0}.subscription-loading .loading-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.1);border-top:2px solid #00d4ff;border-radius:50%;animation:spin 1s linear infinite;margin-right:10px}.subscription-loading span{color:#ffffffb3;font-size:.9rem}@media (max-width: 768px){.preview-3d-container{width:100%;max-width:100%;height:clamp(160px,34vh,220px)}.avatar-preview-panel,.voice-preview-panel,.avatar-selection-layout,.voice-selection-layout{max-width:100%;overflow-x:clip}}.dashboard-container{min-height:100svh;display:flex;flex-direction:column;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;background:var(--bg-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.dashboard-container .btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:.625rem 1rem;border-radius:var(--radius-lg);font-weight:600;font-size:var(--font-size-sm);font-family:inherit;line-height:1.2;text-decoration:none;transition:border-color var(--transition-normal),background var(--transition-normal),color var(--transition-normal),box-shadow var(--transition-normal),transform var(--transition-fast);border:2px solid transparent;cursor:pointer;white-space:nowrap}.dashboard-container .btn:focus-visible{outline:none;box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-color) 35%,transparent)}.dashboard-container .btn-primary{background:var(--accent-color);color:#fff;border-color:transparent}.dashboard-container .btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:var(--shadow-md)}.dashboard-container .btn-outline{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border-color)}.dashboard-container .btn-outline:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--border-light)}.dashboard-container .btn-ghost{background:transparent;color:var(--text-secondary);border-color:transparent;padding-inline:.75rem}.dashboard-container .btn-ghost:hover:not(:disabled){color:var(--text-primary);background:color-mix(in srgb,var(--bg-secondary) 80%,transparent)}.dashboard-header{flex-shrink:0;position:sticky;top:0;z-index:20;background:color-mix(in srgb,var(--bg-card) 94%,transparent);border-bottom:1px solid var(--border-color);padding:clamp(10px,2vw,14px) clamp(14px,3vw,var(--space-xl));backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}.dashboard-header-inner{max-width:1400px;margin:0 auto;display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-start;gap:var(--space-md) var(--space-lg)}.dashboard-header-headline{flex:1 1 12rem;min-width:0}.dashboard-logo{display:inline-flex;align-items:center;padding:.2rem .35rem;margin-left:-.35rem;font-weight:800;font-size:clamp(1rem,2.2vw,1.125rem);text-decoration:none;border-radius:var(--radius-md);border:none;background:transparent;color:var(--text-primary);transition:color var(--transition-fast),background var(--transition-fast);flex-shrink:0}.dashboard-logo:hover{background:color-mix(in srgb,var(--bg-secondary) 55%,transparent);color:var(--accent-color)}.dashboard-logo:focus-visible{outline:none;box-shadow:0 0 0 2px color-mix(in srgb,var(--accent-color) 45%,transparent)}.dashboard-logo-text{color:inherit;letter-spacing:-.03em}.dashboard-header__title{font-size:clamp(1.05rem,2.2vw,1.35rem);font-weight:800;color:var(--text-primary);margin:0;line-height:1.2;letter-spacing:-.02em}.dashboard-header__subtitle{color:var(--text-secondary);font-size:var(--font-size-xs);margin:.2rem 0 0;line-height:1.4;max-width:22rem}.dashboard-header-end{display:flex;flex-wrap:nowrap;align-items:center;gap:var(--space-sm) var(--space-md);flex-shrink:0;margin-left:auto;position:relative;z-index:3}.dashboard-user-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.2rem .45rem .2rem .2rem;margin-right:0;border-radius:var(--radius-lg);border:none;background:transparent;cursor:pointer;font-family:inherit;text-align:left;transition:background var(--transition-fast),box-shadow var(--transition-fast);max-width:min(100%,220px)}.dashboard-user-chip:hover{background:color-mix(in srgb,var(--bg-secondary) 65%,transparent)}.dashboard-user-chip:focus-visible{outline:none;box-shadow:0 0 0 2px color-mix(in srgb,var(--accent-color) 35%,transparent)}.dashboard-user-chip__avatar{width:2.25rem;height:2.25rem;border-radius:50%;flex-shrink:0;overflow:hidden;display:flex;align-items:stretch;justify-content:stretch;box-shadow:0 0 0 1px color-mix(in srgb,var(--border-color) 75%,transparent)}.dashboard-container .user-pfp__img{width:100%;height:100%;object-fit:cover;display:block}.dashboard-container .user-pfp__fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--gradient-accent);color:#fff;font-weight:700}.dashboard-container .user-pfp--chip .user-pfp__fallback{font-size:var(--font-size-sm)}.dashboard-container .user-pfp--hero .user-pfp__fallback{font-size:clamp(2rem,5vw,2.75rem)}.dashboard-user-chip__meta{display:flex;flex-direction:column;gap:.1rem;min-width:0}.dashboard-user-chip__name{font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary);line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dashboard-user-chip__plan{font-size:.7rem;font-weight:700;letter-spacing:.02em;text-transform:uppercase;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dashboard-header-divider{display:none;width:1px;height:1.75rem;background:var(--border-color);flex-shrink:0}@media (min-width: 720px){.dashboard-header-divider{display:block}}.dashboard-header-actions{display:flex;align-items:center;gap:var(--space-xs);position:relative}.dashboard-actions--expanded{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-xs);justify-content:flex-end}.dashboard-actions-compact{display:none;flex-direction:row;align-items:center;flex-shrink:0;gap:2px}.dashboard-container .dashboard-header .dashboard-header__icon-action{width:2.75rem;height:2.75rem;min-width:2.75rem;min-height:2.75rem;padding:0;border-radius:var(--radius-lg)}.dashboard-container .dashboard-header .dashboard-header__icon-action--chat{width:2.85rem;min-width:2.85rem}@media (max-width: 680px){.dashboard-header{padding-top:max(10px,env(safe-area-inset-top,0px));padding-left:max(12px,env(safe-area-inset-left,0px));padding-right:max(12px,env(safe-area-inset-right,0px));padding-bottom:clamp(8px,2vw,12px);background:var(--bg-card)}.dashboard-header-inner{display:grid;grid-template-columns:minmax(0,1fr) auto;grid-template-rows:auto auto;align-items:center;column-gap:10px;row-gap:6px}.dashboard-logo{grid-column:1;grid-row:1;justify-self:start}.dashboard-header-end{grid-column:2;grid-row:1;justify-self:end;margin-left:0;max-width:100%}.dashboard-header-headline{grid-column:1 / -1;grid-row:2;flex:unset;min-width:0}.dashboard-header__title{font-size:1.05rem;line-height:1.25}.dashboard-header__subtitle{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;line-clamp:2;overflow:hidden;max-width:none;margin-top:.15rem;line-height:1.35}.dashboard-user-chip{display:none}.dashboard-header-end{gap:4px}.dashboard-actions--expanded{display:none}.dashboard-actions-compact{display:flex}.dashboard-header-divider{display:none}}.dashboard-container .dashboard-header .btn{padding:.5rem .75rem;font-size:var(--font-size-sm)}.dashboard-container .dashboard-header .btn-primary{padding:.5rem .9rem}.dashboard-header__btn-chat .dashboard-header__btn-text{font-weight:700}.dashboard-content{flex:1 1 0;min-height:0;display:grid;grid-template-columns:minmax(220px,280px) 1fr;gap:0;align-items:stretch;overflow:hidden}.dashboard-content>.dashboard-sidebar,.dashboard-content>.dashboard-main{min-height:0}.dashboard-container,.dashboard-content,.dashboard-header,.dashboard-main,.dashboard-sidebar{max-width:100vw;overflow-x:hidden}.dashboard-content--collapsed{grid-template-columns:minmax(64px,100px) 1fr}.dashboard-sidebar{background:var(--bg-card);border-right:1px solid var(--border-color);padding:clamp(12px,3vw,var(--space-xl));backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}.dashboard-sidebar--collapsed{width:clamp(64px,8vw,100px);padding:clamp(12px,3vw,var(--space-xl)) var(--space-md)}.dashboard-sidebar--collapsed .sidebar-top{margin-right:0}.dashboard-sidebar--collapsed .nav-label{display:none}.dashboard-sidebar--collapsed .nav-item{justify-content:center}.dashboard-nav{display:flex;flex-direction:column;gap:var(--space-xs)}.nav-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border:none;background:transparent;color:var(--text-secondary);font-size:var(--font-size-base);font-weight:500;border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease;text-align:left;width:100%}.nav-item:hover{background:var(--bg-secondary);color:var(--text-primary)}.nav-item:focus-visible{outline:none;box-shadow:0 0 0 2px color-mix(in srgb,var(--accent-color) 45%,transparent)}.nav-item.active{background:color-mix(in srgb,var(--accent-color) 18%,var(--bg-secondary));color:var(--text-primary);border:1px solid color-mix(in srgb,var(--accent-color) 45%,var(--border-color));font-weight:600}[data-theme=light] .nav-item.active{background:color-mix(in srgb,var(--accent-color) 12%,var(--bg-secondary))}.dashboard-main{padding:clamp(12px,3vw,var(--space-xl));padding-bottom:clamp(2rem,5vw,3.5rem);min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.dashboard-main>.dashboard-tab{max-width:1100px;margin:0 auto}.dashboard-tab{max-width:100%}.dash-section{margin-bottom:clamp(1.75rem,4vw,2.75rem)}.dash-section:last-child{margin-bottom:0}.dash-section-header{margin-bottom:var(--space-lg)}.dash-section-header h3{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary);margin:0 0 var(--space-xs) 0;letter-spacing:-.02em}.dash-section-header .dash-section-lead{margin:0;font-size:var(--font-size-sm);line-height:1.5;color:var(--text-secondary);max-width:42rem}.dash-section-body{display:flex;flex-direction:column;gap:var(--space-lg)}.overview-strip,.overview-strip .overview-card{width:100%}.overview-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:clamp(12px,2.5vw,var(--space-xl))}.overview-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:clamp(12px,2vw,var(--space-xl));box-shadow:var(--shadow-lg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.overview-card.plan{grid-column:span 6}.overview-card.usage{grid-column:span 3}.overview-card.quick{grid-column:span 12}.overview-card.account{grid-column:span 6}.account-info{display:flex;flex-direction:column;gap:8px}.account-row{display:flex;justify-content:space-between;gap:12px;padding:8px 0;border-bottom:1px dashed var(--border-color)}.account-row:last-child{border-bottom:none}.account-row .label{color:var(--text-secondary);font-size:var(--font-size-sm)}.account-row .value{color:var(--text-primary);font-weight:600}.overview-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:var(--radius-full);font-size:var(--font-size-sm);background:var(--accent-color);color:#fff}.muted{color:var(--text-secondary)}.small{font-size:var(--font-size-sm)}.list{display:flex;flex-direction:column;gap:6px;margin:10px 0 0;padding:0;list-style:none}.kpi{display:flex;align-items:baseline;gap:6px}.kpi-value{font-size:var(--font-size-3xl);font-weight:800}.kpi-suffix{color:var(--text-secondary)}.progress{width:100%;height:8px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden;margin-top:8px}.progress-bar{height:100%;background:var(--gradient-accent);border-radius:var(--radius-full)}.overview-actions{display:flex;gap:var(--space-md);margin-top:var(--space-lg)}.quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--space-md)}.qa-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:10px 14px;border-radius:var(--radius-lg);border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);text-decoration:none;font-family:inherit;font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:background var(--transition-normal),border-color var(--transition-normal),transform var(--transition-fast)}.qa-btn:hover{background:var(--bg-tertiary);border-color:var(--border-light)}.qa-btn:focus-visible{outline:none;box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-color) 30%,transparent)}@media (max-width: 1280px){.overview-card.plan{grid-column:span 7}.overview-card.usage{grid-column:span 5}}@media (max-width: 1024px){.overview-grid{grid-template-columns:repeat(6,minmax(0,1fr))}.overview-card.plan{grid-column:span 6}.overview-card.usage{grid-column:span 3}.overview-card.quick{grid-column:span 6}}@media (max-width: 768px){.overview-grid{grid-template-columns:1fr}.overview-card{padding:clamp(12px,4vw,var(--space-lg))}}.tab-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-md);margin-bottom:clamp(16px,4vw,var(--space-2xl));padding-bottom:clamp(12px,2.5vw,var(--space-lg));border-bottom:1px solid var(--border-color)}.tab-header.sticky{position:sticky;top:0;z-index:5;margin-top:0;margin-bottom:clamp(16px,4vw,var(--space-2xl));padding-top:.35rem;padding-bottom:clamp(12px,2.5vw,var(--space-lg));background:var(--bg-primary);border-bottom:1px solid var(--border-color)}.tab-header.sticky:before{content:"";position:absolute;left:0;right:0;bottom:100%;height:14px;background:var(--bg-primary);pointer-events:none}.tab-title{display:inline-flex;align-items:center;gap:10px}.sidebar-top{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);margin-bottom:var(--space-lg)}.sidebar-collapse-btn{flex-shrink:0;color:var(--text-primary)}.sidebar-collapse-btn svg{display:block;flex-shrink:0}.dashboard-sidebar--collapsed .sidebar-top{justify-content:center}.dashboard-sidebar--collapsed .sidebar-title{display:none}.sidebar-title{display:inline-flex;align-items:center;gap:8px;color:var(--text-secondary);font-weight:600}.btn--icon{display:inline-flex;align-items:center;justify-content:center;padding:0;width:2.5rem;height:2.5rem;min-width:2.5rem;min-height:2.5rem}.tab-header h2{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary);margin:0}.dashboard-loading,.dashboard-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--space-lg);color:var(--text-secondary)}.dashboard-error{color:var(--error-color)}.animate-spin,.dashboard-loading .icon--loading{animation:spin 1s linear infinite}.dashboard-alert{padding:.875rem 1rem;border-radius:var(--radius-lg);font-size:var(--font-size-sm);line-height:1.45;margin-bottom:var(--space-lg);border:1px solid var(--border-color)}.dashboard-alert--error{background:color-mix(in srgb,var(--error-color) 10%,var(--bg-card));color:var(--error-color);border-color:color-mix(in srgb,var(--error-color) 28%,var(--border-color))}.profile-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:clamp(var(--space-lg),3vw,var(--space-2xl));box-shadow:var(--shadow-lg)}.profile-identity{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-xl);padding-bottom:var(--space-xl);margin-bottom:var(--space-xl);border-bottom:1px solid var(--border-color)}.profile-identity__avatar-wrap{flex-shrink:0}.profile-identity__avatar{width:112px;height:112px;border-radius:50%;overflow:hidden;box-shadow:var(--shadow-lg);border:3px solid color-mix(in srgb,var(--border-color) 85%,transparent);display:flex;align-items:stretch;justify-content:stretch}.profile-identity__name-block{flex:1 1 200px;min-width:0}.profile-identity__name{margin:0;font-size:clamp(1.25rem,3vw,1.6rem);font-weight:800;color:var(--text-primary);letter-spacing:-.02em;line-height:1.2}.profile-identity__email{margin:.4rem 0 0;font-size:var(--font-size-sm);color:var(--text-secondary);word-break:break-word}.profile-identity__meta{margin:.5rem 0 0;font-size:var(--font-size-xs);color:var(--text-secondary)}.profile-fields-heading-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--space-md);margin-bottom:var(--space-md)}.profile-fields-heading{margin:0;font-size:var(--font-size-sm);font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.profile-fields-actions{display:flex;flex-wrap:wrap;gap:var(--space-sm);align-items:center}.tab-header--title-only{justify-content:flex-start}.tab-header--title-only .tab-title{flex:1 1 auto}.profile-detail-list{display:flex;flex-direction:column;gap:var(--space-md)}.profile-detail-row{display:grid;grid-template-columns:2.25rem 1fr;gap:var(--space-md);align-items:start;padding:var(--space-md) var(--space-lg);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.profile-detail-row__icon{color:var(--text-secondary);display:flex;align-items:flex-start;justify-content:center;padding-top:.15rem}.profile-detail-row__body{min-width:0;display:flex;flex-direction:column;gap:var(--space-xs)}.profile-detail-row__body label{font-weight:600;color:var(--text-primary);font-size:var(--font-size-sm)}.profile-detail-row__hint{margin:0;font-size:var(--font-size-xs);color:var(--text-secondary);line-height:1.45}.profile-detail-row__body input,.profile-detail-row__body textarea{width:100%;max-width:100%;padding:var(--space-md);border:2px solid var(--border-color);border-radius:var(--radius-lg);background:var(--bg-card);color:var(--text-primary);font-size:var(--font-size-base);font-family:inherit;transition:var(--transition-normal)}.profile-detail-row__body input:focus,.profile-detail-row__body textarea:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #3b82f61a}.profile-detail-row__body input.error{border-color:var(--error-color)}.profile-value--plain{padding:0;background:transparent;margin:0;min-height:unset;line-height:1.5}.profile-value--email{font-size:var(--font-size-base);word-break:break-all}.profile-value--bio{white-space:pre-wrap}.profile-bio-empty{margin:0;padding:var(--space-lg);border:1px dashed var(--border-color);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:var(--font-size-sm);line-height:1.5;background:color-mix(in srgb,var(--bg-primary) 55%,var(--bg-secondary))}.form-group{display:flex;flex-direction:column;gap:var(--space-sm)}.form-group label{font-weight:600;color:var(--text-primary);font-size:var(--font-size-sm)}.form-group input,.form-group textarea,.form-group select{padding:var(--space-md);border:2px solid var(--border-color);border-radius:var(--radius-lg);background:var(--bg-secondary);color:var(--text-primary);font-size:var(--font-size-base);transition:var(--transition-normal)}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #3b82f61a}.form-group input.error{border-color:var(--error-color)}.profile-value{padding:var(--space-md);background:var(--bg-secondary);border-radius:var(--radius-lg);color:var(--text-primary);margin:0;min-height:20px}.subscription-section{display:grid;gap:var(--space-xl);align-items:start}@media (min-width: 960px){.subscription-section{grid-template-columns:1fr 1fr;gap:var(--space-2xl)}.subscription-section .upgrade-section{margin-top:0}}.current-plan{display:flex;justify-content:stretch;width:100%}.plan-card{background:var(--bg-card);border:2px solid;border-radius:var(--radius-xl);padding:clamp(16px,3vw,var(--space-2xl));max-width:100%;width:100%;box-shadow:var(--shadow-xl);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.plan-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}.plan-header h3{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary);margin:0}.plan-price{font-size:var(--font-size-lg);font-weight:700;color:var(--accent-color)}.plan-status{margin-bottom:var(--space-lg)}.status-badge{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600;text-transform:uppercase}.status-badge.active{background:var(--success-color);color:#fff}.plan-features{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-sm)}.plan-features li{display:flex;align-items:center;gap:var(--space-sm);color:var(--text-primary);font-size:var(--font-size-base)}.plan-features li svg{color:var(--success-color)}.upgrade-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-2xl);text-align:center;width:100%}.upgrade-section h3{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-sm)}.upgrade-section p{color:var(--text-secondary);margin-bottom:var(--space-xl)}.upgrade-options,.subscription-actions{display:flex;flex-direction:column;gap:var(--space-md);width:100%;max-width:320px;margin:0 auto}.canceled-notice{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-md);color:var(--text-secondary);font-size:var(--font-size-sm);text-align:center;margin-bottom:var(--space-md)}.subscription-actions .btn{display:flex;align-items:center;justify-content:center;gap:var(--space-sm)}.usage-section{display:flex;flex-direction:column;gap:var(--space-xl)}.usage-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:clamp(12px,3vw,var(--space-xl))}.usage-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-xl);box-shadow:var(--shadow-lg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.usage-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg)}.usage-header h4{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary);margin:0}.usage-stats{display:flex;align-items:baseline;gap:var(--space-xs);margin-bottom:var(--space-md)}.usage-current{font-size:var(--font-size-2xl);font-weight:700;color:var(--text-primary)}.usage-limit{font-size:var(--font-size-base);color:var(--text-secondary)}.usage-bar{width:100%;height:8px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.usage-progress{height:100%;background:var(--gradient-primary);border-radius:var(--radius-full);transition:width .3s ease}.usage-reset{text-align:center;color:var(--text-secondary);font-size:var(--font-size-sm);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-lg) var(--space-xl)}.usage-reset p{margin:0 0 var(--space-md) 0;line-height:1.5}.usage-reset .btn{margin-top:var(--space-sm)}.dashboard-tab--preferences{max-width:36rem}.dash-section--prefs .prefs-sync-error{margin-bottom:var(--space-md)}.prefs-panel{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-md)}.prefs-row{display:grid;grid-template-columns:1fr auto;gap:var(--space-md);align-items:center;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-color)}.prefs-row--block{grid-template-columns:1fr;align-items:stretch}.prefs-row--last{border-bottom:none}.prefs-row__main{min-width:0}.prefs-row__title{display:block;font-weight:600;color:var(--text-primary);font-size:var(--font-size-sm);line-height:1.3}.prefs-row__desc{display:block;margin-top:.2rem;font-size:var(--font-size-xs);color:var(--text-muted);line-height:1.35;max-width:22rem}.prefs-group-label{padding:var(--space-sm) var(--space-lg);font-size:var(--font-size-xs);font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted);background:color-mix(in srgb,var(--bg-secondary) 85%,var(--bg-card));border-bottom:1px solid var(--border-color)}.prefs-segment{display:inline-flex;padding:3px;border-radius:var(--radius-full);background:var(--bg-tertiary);border:1px solid var(--border-color);flex-shrink:0}.prefs-segment__btn{border:none;padding:.45rem 1rem;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600;font-family:inherit;cursor:pointer;color:var(--text-secondary);background:transparent;transition:color var(--transition-fast),background var(--transition-fast),box-shadow var(--transition-fast)}.prefs-segment__btn:hover{color:var(--text-primary)}.prefs-segment__btn--active{background:var(--bg-card);color:var(--accent-color);box-shadow:var(--shadow-sm)}.prefs-switch{width:3rem;height:1.7rem;border-radius:var(--radius-full);border:2px solid var(--border-color);background:var(--bg-tertiary);cursor:pointer;position:relative;flex-shrink:0;transition:background var(--transition-fast),border-color var(--transition-fast)}.prefs-switch:after{content:"";position:absolute;width:1.1rem;height:1.1rem;border-radius:50%;background:var(--text-primary);top:50%;left:3px;transform:translateY(-50%);transition:transform var(--transition-fast);box-shadow:var(--shadow-sm)}.prefs-switch--on{background:var(--accent-color);border-color:var(--accent-color)}.prefs-switch--on:after{transform:translate(1.15rem,-50%);background:#fff}.prefs-switch:focus-visible{outline:none;box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-color) 35%,transparent)}@media (max-width: 520px){.prefs-row{grid-template-columns:1fr;gap:var(--space-sm)}.prefs-segment{justify-self:start}.prefs-switch{justify-self:end}}.theme-picker{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-sm)}.theme-picker--compact{width:100%;margin-top:var(--space-sm)}@media (max-width: 520px){.theme-picker:not(.theme-picker--compact){grid-template-columns:1fr}.theme-picker--compact{grid-template-columns:repeat(3,minmax(0,1fr))}}.theme-option{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-xs);min-height:5.75rem;padding:var(--space-md) var(--space-sm);border-radius:var(--radius-lg);border:2px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;font-family:inherit;text-align:center;transition:border-color var(--transition-fast),background var(--transition-fast),box-shadow var(--transition-fast)}.theme-picker--compact .theme-option{min-height:4.1rem;padding:var(--space-sm) var(--space-xs)}.theme-picker--compact .theme-option__hint{font-size:.62rem;max-width:none;line-height:1.2}.theme-option:hover{border-color:var(--border-light);background:var(--bg-tertiary)}.theme-option:focus-visible{outline:none;box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-color) 35%,transparent)}.theme-option--active{border-color:var(--accent-color);background:color-mix(in srgb,var(--accent-color) 14%,var(--bg-secondary));box-shadow:0 0 0 1px color-mix(in srgb,var(--accent-color) 35%,transparent)}.theme-option__icon{display:flex;align-items:center;justify-content:center;color:var(--text-primary)}.theme-option--active .theme-option__icon{color:var(--accent-color)}.theme-option__label{font-size:var(--font-size-sm);font-weight:700;line-height:1.2}.theme-option__hint{font-size:var(--font-size-xs);font-weight:500;color:var(--text-muted);line-height:1.3;max-width:11rem}.form-actions{display:flex;gap:var(--space-md);margin-top:var(--space-lg)}.maintenance-banner{background:color-mix(in srgb,var(--warning-color) 16%,var(--bg-card));border:1px solid color-mix(in srgb,var(--warning-color) 45%,var(--border-color));border-radius:var(--radius-xl);padding:var(--space-lg);margin-bottom:var(--space-xl);display:flex;align-items:flex-start;gap:var(--space-md);color:var(--text-primary)}.maintenance-banner .icon{color:var(--warning-color);flex-shrink:0;margin-top:2px}.maintenance-content h3{font-size:var(--font-size-lg);font-weight:700;margin:0 0 var(--space-sm) 0;color:var(--text-primary)}.maintenance-content p{margin:0;color:var(--text-secondary);font-size:var(--font-size-base);line-height:1.5}.dashboard-container .btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.dashboard-container .btn-primary:disabled{background:var(--bg-tertiary);color:var(--text-muted)}.dashboard-container .btn-outline:disabled{background:var(--bg-secondary);color:var(--text-muted);border-color:var(--border-color)}.dashboard-container .btn:disabled:hover{transform:none;box-shadow:none}@media (max-width: 1024px){.dashboard-content{display:flex;flex-direction:column;flex:1 1 0;min-height:0;overflow:hidden}.dashboard-sidebar{border-right:none;border-bottom:1px solid var(--border-color);padding:var(--space-lg);overflow-x:hidden;overflow-y:visible;max-height:none;flex-shrink:0}.dashboard-main{flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.dashboard-nav{flex-direction:row;overflow-x:auto;padding-bottom:var(--space-sm)}.sidebar-top{margin-bottom:var(--space-md)}.dashboard-sidebar--collapsed .dashboard-nav{display:none}.dashboard-sidebar--collapsed .sidebar-top{margin-bottom:0}.dashboard-sidebar--collapsed{width:100%;padding:var(--space-md) var(--space-lg)}.dashboard-sidebar--collapsed .sidebar-top{justify-content:space-between}.dashboard-sidebar--collapsed .sidebar-title{display:inline-flex}.nav-item{white-space:nowrap;min-width:120px}}@media (max-width: 768px){.profile-identity{flex-direction:column;text-align:center}.profile-identity__name-block{text-align:center}.dashboard-tab{max-width:100%}.form-group input,.form-group textarea,.form-group select{width:100%}.usage-cards{grid-template-columns:1fr}.upgrade-options{flex-direction:column}}@media (max-width: 480px){.dashboard-header{padding-left:max(var(--space-md),env(safe-area-inset-left,0px));padding-right:max(var(--space-md),env(safe-area-inset-right,0px))}.dashboard-main,.dashboard-sidebar{padding:var(--space-md)}.nav-item{padding:var(--space-sm) var(--space-md);font-size:var(--font-size-sm)}.tab-header{flex-direction:column;gap:var(--space-md);align-items:flex-start}.plan-card,.usage-card,.preference-group{padding:var(--space-lg)}}@media (prefers-reduced-motion: reduce){.dashboard-container .btn,.nav-item,.qa-btn,.dashboard-loading .icon--loading,.prefs-switch,.prefs-switch:after,.prefs-segment__btn{transition:none;animation:none}}.avatar-selector-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.avatar-selector-modal{background:var(--bg-primary);border-radius:16px;padding:24px;max-width:980px;width:min(95vw,980px);max-height:min(90vh,880px);display:flex;flex-direction:column;overflow:hidden;box-shadow:0 25px 80px #00000026;border:1px solid var(--border-color)}.avatar-selector-modal>.avatar-selector-header{flex-shrink:0}.avatar-selector-modal>.avatar-selector-content{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.avatar-selector-modal>.avatar-selector-actions{flex-shrink:0}.avatar-selector-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border-color)}.avatar-selector-header h3{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary)}.avatar-selector-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;border-radius:8px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.avatar-selector-close:hover{background:var(--bg-secondary);color:var(--text-primary)}.avatar-categories{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}.category-filter{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);padding:8px 16px;border-radius:20px;cursor:pointer;transition:all .2s ease;font-size:.9rem;font-weight:500}.category-filter:hover,.category-filter.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.avatar-selector{padding:16px;background:var(--bg-primary);border-radius:12px;max-width:900px;margin:0 auto;border:1px solid var(--border-color)}.avatar-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin-bottom:16px}.avatar-selector-loading{text-align:center;padding:40px;color:var(--text-secondary);font-size:1.1rem}.error-message{background:var(--error-color-light);color:var(--error-color);padding:12px;border-radius:8px;margin-top:16px;text-align:center;font-size:.9rem}.avatar-selector-actions{display:flex;gap:12px;justify-content:flex-end;flex-wrap:wrap;padding:16px 0 0;border-top:1px solid var(--border-color);margin-top:16px}.avatar-selector-actions .btn{padding:10px 20px;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;min-width:100px}@media (max-width: 1023px){.avatar-selector-overlay{align-items:flex-end;justify-content:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:overlayFadeIn .18s ease-out}.avatar-selector-modal{width:100%;max-width:none;display:flex;flex-direction:column;overflow:hidden;padding:16px 12px 0;max-height:min(88vh,720px);border-radius:16px 16px 0 0;border:1px solid rgba(51,65,85,.7);background:#0f172ab3;backdrop-filter:blur(12px) saturate(120%);-webkit-backdrop-filter:blur(12px) saturate(120%);box-shadow:var(--shadow-2xl);animation:sheetSlideUp .22s var(--ease-out);overscroll-behavior:contain}.avatar-selector-modal>.avatar-selector-content{padding-bottom:8px}.avatar-selector-modal>.avatar-selector-actions{margin-top:0;padding:12px 0 calc(12px + env(safe-area-inset-bottom,0px));border-top:1px solid rgba(51,65,85,.7);background:inherit;backdrop-filter:inherit;-webkit-backdrop-filter:inherit}.avatar-selector-modal:before{content:"";display:block;width:36px;height:4px;border-radius:999px;background:#cbd5e199;margin:4px auto 8px}.avatar-selector-header{position:sticky;top:0;z-index:2;background:inherit;backdrop-filter:inherit;-webkit-backdrop-filter:inherit;margin:0 0 12px;padding:8px 4px 12px;border-bottom:1px solid rgba(51,65,85,.7)}.avatar-selector-header h3{font-size:1.125rem}.avatar-categories{display:flex;gap:8px;margin:12px -4px;padding:0 4px 4px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none}.avatar-categories::-webkit-scrollbar{display:none}.category-filter{padding:8px 14px;font-size:.85rem;white-space:nowrap;flex:0 0 auto}.avatar-selector--v2 .avatar-selector-toolbar{gap:.5rem;margin-bottom:.75rem}.avatar-selector--v2 .avatar-categories{flex-wrap:nowrap;justify-content:flex-start;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin:0 -8px;padding:2px 8px 6px;gap:8px}.avatar-selector--v2 .avatar-categories::-webkit-scrollbar{display:none}.avatar-selector--v2 .category-filter{flex:0 0 auto;min-height:40px;padding:10px 16px;align-self:center}.avatar-selector--v2 .avatar-search{min-height:3rem;padding:.35rem .85rem}.avatar-selector--v2 .avatar-search__input{font-size:1rem}.avatar-selector--v2 .avatar-selector-summary{padding:.75rem .85rem;margin-bottom:.5rem}.avatar-selector--v2 .avatar-selector-summary__hint{font-size:.8rem;padding:.55rem .65rem}.avatar-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.avatar-empty{grid-column:1 / -1;text-align:center;color:var(--text-secondary);padding:16px;border:1px dashed var(--border-color);border-radius:12px;background:var(--bg-secondary)}}@media (max-width: 480px){.avatar-grid{grid-template-columns:1fr}}@media (prefers-reduced-motion: reduce){@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}@keyframes sheetSlideUp{0%{transform:none;opacity:0}to{transform:none;opacity:1}}.avatar-selector-overlay{animation:overlayFadeIn 1ms linear}.avatar-selector-modal{animation:none}}.avatar-selector--v2{padding:0;margin:0;max-width:none;border:none;background:transparent}.avatar-selector-toolbar{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.avatar-selector--v2 .avatar-categories{display:flex;flex-wrap:wrap;gap:.5rem;margin:0;padding:0;justify-content:flex-start}.avatar-search{display:flex;align-items:center;gap:.5rem;margin-bottom:0;min-height:2.75rem;padding:.35rem .85rem;border-radius:var(--radius-lg);border:1px solid var(--border-color);background:var(--bg-secondary)}.avatar-search__icon{flex-shrink:0;color:var(--text-muted)}.avatar-search__input{flex:1;min-width:0;min-height:2.25rem;border:none;background:transparent;color:var(--text-primary);font-size:.9375rem;line-height:1.45;outline:none;padding:.25rem 0}.avatar-search__input::placeholder{color:var(--text-muted)}.avatar-search__clear{display:flex;align-items:center;justify-content:center;min-width:2.25rem;min-height:2.25rem;padding:.25rem;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);cursor:pointer}.avatar-search__clear:hover{background:var(--bg-tertiary);color:var(--text-primary)}.avatar-selector-layout-main{display:grid;grid-template-columns:1fr min(280px,32%);gap:1.25rem;align-items:start}.avatar-selector-section-title{margin:0 0 .75rem;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary)}.avatar-grid--cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(132px,1fr));gap:.75rem}.avatar-card{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;padding:.875rem .5rem .75rem;border:2px solid var(--border-color);border-radius:var(--radius-lg);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast);min-height:148px}.avatar-card:hover{border-color:color-mix(in srgb,var(--accent-color) 55%,var(--border-color));box-shadow:var(--shadow-md)}.avatar-card:focus-visible{outline:none;box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-color) 35%,transparent)}.avatar-card--selected{border-color:var(--accent-color);background:color-mix(in srgb,var(--accent-color) 10%,var(--bg-secondary));box-shadow:var(--shadow-md)}.avatar-card__check{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:50%;background:var(--accent-color);color:#fff;display:flex;align-items:center;justify-content:center}.avatar-card__badge{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;background:var(--gradient-accent);color:#fff;margin-bottom:.5rem;flex-shrink:0}.avatar-card__name{font-weight:600;font-size:.8rem;line-height:1.25;margin-bottom:.25rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.avatar-card__desc{font-size:.7rem;line-height:1.35;color:var(--text-secondary);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;flex:1}.avatar-card__cat{margin-top:.5rem;font-size:.65rem;font-weight:600;padding:.15rem .45rem;border-radius:999px;background:var(--bg-tertiary);color:var(--text-secondary);text-transform:capitalize}.avatar-selector-summary{position:sticky;top:.5rem;padding:1rem;border-radius:var(--radius-lg);border:1px solid var(--border-color);background:var(--bg-card);box-shadow:var(--shadow-sm)}.avatar-selector-summary__title{margin:0 0 .75rem;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.avatar-selector-summary__hero{display:flex;gap:.75rem;align-items:flex-start}.avatar-selector-summary__initial{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.125rem;background:var(--gradient-accent);color:#fff;flex-shrink:0}.avatar-selector-summary__meta{min-width:0;flex:1}.avatar-selector-summary__name{margin:0 0 .25rem;font-size:1rem;font-weight:700;color:var(--text-primary);line-height:1.2}.avatar-selector-summary__desc{margin:0 0 .5rem;font-size:.8rem;line-height:1.4;color:var(--text-secondary)}.avatar-selector-summary__pill{display:inline-block;font-size:.7rem;font-weight:600;padding:.2rem .5rem;border-radius:999px;background:var(--bg-tertiary);color:var(--text-secondary)}.avatar-selector-summary__hint{display:flex;align-items:flex-start;gap:.5rem;margin:1rem 0 0;padding:.65rem .75rem;border-radius:var(--radius-md);font-size:.75rem;line-height:1.4;color:var(--text-secondary);background:color-mix(in srgb,var(--accent-color) 8%,var(--bg-secondary));border:1px solid color-mix(in srgb,var(--accent-color) 22%,var(--border-color))}.avatar-selector-summary__hint svg{flex-shrink:0;margin-top:2px;color:var(--accent-color)}.avatar-selector-summary__empty{margin:0;font-size:.85rem;color:var(--text-muted);line-height:1.45}.avatar-empty--inline{padding:2rem 1rem;text-align:center;color:var(--text-secondary);border:1px dashed var(--border-color);border-radius:var(--radius-lg);background:var(--bg-secondary)}.avatar-empty--inline svg{margin-bottom:.5rem;opacity:.5}.avatar-empty--inline p{margin:0;font-size:.875rem}.avatar-selector-modal .avatar-selector-content--v2{padding:0 4px;min-height:min(52vh,420px)}@media (max-width: 900px){.avatar-selector-layout-main{grid-template-columns:1fr;gap:.85rem}.avatar-selector-summary{position:static;order:-1}}@media (max-width: 1023px){.avatar-grid--cards{grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem}.avatar-selector-modal .avatar-selector-content--v2{min-height:min(36vh,280px)}}@media (max-width: 480px){.avatar-grid--cards{grid-template-columns:1fr;gap:.5rem}.avatar-card{min-height:128px;padding:.7rem .6rem .65rem}.avatar-card__badge{width:40px;height:40px;font-size:.95rem;margin-bottom:.4rem}.avatar-card__name{font-size:.78rem}.avatar-card__desc{font-size:.68rem;-webkit-line-clamp:2}.avatar-card__cat{margin-top:.4rem;font-size:.62rem}}.voice-selector-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.voice-selector-modal{background:var(--bg-primary);border-radius:16px;padding:24px;max-width:980px;width:min(95vw,980px);max-height:min(90vh,880px);box-shadow:0 25px 80px #00000026;border:1px solid var(--border-color)}.voice-selector-modal--v2{display:flex;flex-direction:column;overflow:hidden}.voice-selector-modal--v2>.voice-selector-header{flex-shrink:0}.voice-selector-scroll{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;gap:1rem;padding:0 2px 8px}.voice-selector-modal--v2>.voice-selector-footer{flex-shrink:0}.voice-selector-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid var(--border-color)}.voice-selector-header h3{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary)}.voice-selector-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;border-radius:8px;transition:background .2s ease,color .2s ease;display:flex;align-items:center;justify-content:center}.voice-selector-close:hover{background:var(--bg-secondary);color:var(--text-primary)}.voice-filters--v2{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px 14px;padding:14px 16px;background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.filter-group{display:flex;flex-direction:column;gap:6px;min-width:0}.filter-group label{font-size:.8rem;font-weight:600;color:var(--text-secondary)}.filter-group select{min-height:2.75rem;padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-size:.9rem;cursor:pointer}.filter-group select:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent-color) 20%,transparent)}.voice-search-bar{grid-column:1 / -1;display:flex;align-items:center;gap:.5rem;min-height:2.75rem;margin-bottom:0;padding:.35rem .85rem;border-radius:var(--radius-lg);border:1px solid var(--border-color);background:var(--bg-primary)}.voice-search-bar__icon{flex-shrink:0;color:var(--text-muted)}.voice-search-bar__input{flex:1;min-width:0;min-height:2.25rem;border:none;background:transparent;color:var(--text-primary);font-size:.9375rem;line-height:1.45;outline:none;padding:.25rem 0}.voice-search-bar__input::placeholder{color:var(--text-muted)}.voice-search-bar__clear{display:flex;align-items:center;justify-content:center;min-width:2.25rem;min-height:2.25rem;padding:.25rem;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);cursor:pointer}.voice-search-bar__clear:hover{background:var(--bg-tertiary);color:var(--text-primary)}.voice-upload-section{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:16px 18px}.voice-upload-section h4{margin:0 0 12px;color:var(--text-primary);font-size:1.05rem;font-weight:600}.voice-upload-meta--inline{display:flex;flex-wrap:wrap;gap:12px 20px;margin-bottom:12px;align-items:flex-end}.voice-upload-meta__field{display:flex;flex-direction:column;gap:4px;min-width:min(100%,200px)}.voice-upload-meta__field label{font-size:.8rem;font-weight:600;color:var(--text-secondary)}.voice-upload-meta__field select{padding:8px 10px;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-size:.9rem}.voice-delete-confirm{flex-shrink:0;padding:12px 16px;margin:0 2px;border-radius:var(--radius-lg);border:1px solid var(--error-color);background:var(--bg-secondary)}.voice-delete-confirm__inner{max-width:640px;margin:0 auto}.voice-delete-confirm__title{margin:0 0 6px;font-size:.95rem;font-weight:700;color:var(--text-primary)}.voice-delete-confirm__body{margin:0 0 12px;font-size:.85rem;line-height:1.45;color:var(--text-secondary)}.voice-delete-confirm__actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.upload-section{background:var(--bg-secondary);border:2px dashed var(--border-color);border-radius:var(--radius-lg);padding:18px;text-align:center;transition:border-color .2s ease,background .2s ease;max-width:100%;box-sizing:border-box}.upload-section:hover{border-color:var(--accent-color);background:var(--bg-tertiary)}.upload-button{background:var(--accent-color);color:var(--text-on-accent);border:none;border-radius:var(--radius-md);padding:12px 16px;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .2s ease,transform .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:8px;max-width:100%;min-width:0;box-sizing:border-box}.upload-button__label{min-width:0;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left}.upload-button:hover{background:var(--accent-color-dark);transform:translateY(-1px)}.upload-button:active{transform:translateY(0)}.file-info{display:flex;align-items:center;justify-content:flex-start;flex-wrap:nowrap;gap:10px;margin:14px 0;padding:10px 12px;background:var(--bg-primary);border-radius:var(--radius-md);border:1px solid var(--border-color);max-width:100%;min-width:0;box-sizing:border-box}.file-info__name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-primary);font-size:.9rem;text-align:left}.file-info .file-size{flex-shrink:0}.file-size{color:var(--text-secondary);font-size:.8rem}.remove-file{background:var(--error-color);color:var(--text-on-error);border:none;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s ease,background .2s ease;flex-shrink:0}.remove-file:hover{background:var(--error-color-dark);transform:scale(1.08)}.custom-voice-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:14px}.preview-custom-voice-button{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:10px 16px;font-size:.9rem;font-weight:600;cursor:pointer;transition:border-color .2s ease,background .2s ease;display:inline-flex;align-items:center;gap:8px}.preview-custom-voice-button:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--accent-color)}.preview-custom-voice-button:disabled{opacity:.6;cursor:not-allowed}.submit-upload-button{background:var(--accent-color);color:var(--text-on-accent);border:none;border-radius:var(--radius-md);padding:10px 20px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s ease}.submit-upload-button:hover:not(:disabled){background:var(--accent-color-dark)}.submit-upload-button:disabled{background:var(--text-secondary);cursor:not-allowed}.file-requirements{color:var(--text-secondary);font-size:.8rem;margin-top:12px;font-style:italic}.voice-inline-error{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;margin-top:10px;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-primary);text-align:left;font-size:.82rem;line-height:1.35}.voice-inline-error__icon{flex-shrink:0;color:var(--error-color);margin-top:1px}.voice-inline-error__text{flex:1;min-width:0}.voice-inline-error--upload{margin-top:8px}.voices-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;padding:4px 2px 8px}.voices-loading,.voices-empty{grid-column:1 / -1;text-align:center;padding:2rem 1rem;color:var(--text-secondary);font-size:1rem}.voices-error.voice-inline-error{grid-column:1 / -1;justify-content:center;text-align:left;max-width:420px;margin-left:auto;margin-right:auto}.voice-option{display:flex;align-items:center;gap:12px;padding:12px 12px 12px 10px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease;position:relative;min-height:80px}.voice-option:hover{border-color:color-mix(in srgb,var(--accent-color) 55%,var(--border-color));box-shadow:var(--shadow-md);transform:translateY(-1px)}.voice-option.selected{border-color:var(--accent-color);background:color-mix(in srgb,var(--accent-color) 12%,var(--bg-secondary));box-shadow:0 0 0 2px color-mix(in srgb,var(--accent-color) 35%,transparent)}.voice-preview{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center}.play-button{width:40px;height:40px;border-radius:50%;border:none;background:var(--accent-color);color:var(--text-on-accent);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease,transform .2s ease}.play-button:hover{background:var(--accent-color-dark);transform:scale(1.06)}.play-button.playing{background:var(--error-color)}.voice-info{flex:1;min-width:0;text-align:left}.voice-info h5{margin:0 0 6px;color:var(--text-primary);font-size:.95rem;font-weight:600;line-height:1.2}.voice-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}.voice-language,.voice-category{background:color-mix(in srgb,var(--accent-color) 18%,var(--bg-primary));color:var(--accent-color);padding:2px 8px;border-radius:999px;font-size:.68rem;font-weight:600;text-transform:capitalize}.voice-option.selected .voice-language,.voice-option.selected .voice-category{background:color-mix(in srgb,var(--accent-color) 25%,transparent);color:var(--text-primary)}.voice-description{margin:0;color:var(--text-secondary);font-size:.8rem;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.delete-custom-voice{background:var(--error-color);color:var(--text-on-error);border:none;border-radius:50%;width:32px;height:32px;padding:0;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:opacity .2s ease,transform .2s ease,filter .2s ease;opacity:.92;flex-shrink:0}.delete-custom-voice:hover{opacity:1;filter:brightness(1.05);transform:scale(1.06)}.favorite-button{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;border-radius:50%;transition:background .2s ease,color .2s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.favorite-button:hover{background:var(--bg-tertiary);color:var(--accent-color)}.favorite-button.favorited{color:var(--accent-color)}.voice-volume-control{display:flex;align-items:center;gap:6px;flex-shrink:0}.volume-slider{width:64px;height:4px;border-radius:2px;background:var(--border-color);outline:none;cursor:pointer;-webkit-appearance:none;appearance:none}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent-color);cursor:pointer}.volume-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--accent-color);cursor:pointer;border:none}.voice-option.selected .volume-slider{background:color-mix(in srgb,var(--text-primary) 28%,var(--bg-primary));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--text-primary) 18%,transparent)}.voice-option.selected .volume-slider::-webkit-slider-thumb{background:var(--text-primary);box-shadow:0 0 0 2px var(--bg-primary)}.voice-option.selected .volume-slider::-moz-range-thumb{background:var(--text-primary);box-shadow:0 0 0 2px var(--bg-primary)}.voice-selector-footer{margin-top:12px;padding-top:14px;border-top:1px solid var(--border-color);animation:voiceFooterIn .22s var(--ease-out, ease-out)}.selected-voice-info{display:flex;align-items:center;flex-wrap:wrap;gap:8px 12px;margin-bottom:12px;padding:12px 14px;background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color)}.selected-label{font-weight:600;color:var(--text-secondary);font-size:.85rem}.selected-voice-name{font-weight:700;color:var(--accent-color);font-size:1rem}.confirmation-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.confirmation-actions .btn{padding:10px 20px;border-radius:var(--radius-md);font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s ease,transform .2s ease;border:none;min-width:100px}.btn--secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.btn--secondary:hover{background:var(--bg-tertiary);border-color:var(--accent-color)}.btn--primary{background:var(--accent-color);color:var(--text-on-accent)}.btn--primary:hover:not(:disabled){background:var(--accent-color-dark);transform:translateY(-1px)}.btn--primary:disabled{background:var(--text-secondary);cursor:not-allowed;transform:none}.btn--danger{background:var(--error-color);color:var(--text-on-error)}.btn--danger:hover:not(:disabled){filter:brightness(1.05);transform:translateY(-1px)}@keyframes voiceFooterIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}@keyframes sheetSlideUp{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 1023px){.voice-selector-overlay{align-items:flex-end;justify-content:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:overlayFadeIn .18s ease-out}.voice-selector-modal{width:100%;max-width:none;padding:16px 12px 0;max-height:min(88vh,720px);border-radius:16px 16px 0 0;border:1px solid rgba(51,65,85,.7);background:#0f172ab8;backdrop-filter:blur(12px) saturate(120%);-webkit-backdrop-filter:blur(12px) saturate(120%);box-shadow:var(--shadow-2xl);animation:sheetSlideUp .22s var(--ease-out, ease-out);overscroll-behavior:contain}.voice-selector-modal--v2>.voice-selector-scroll{padding-bottom:6px}.voice-selector-modal--v2>.voice-selector-footer{margin-top:0;padding:12px 0 calc(12px + env(safe-area-inset-bottom,0px));border-top:1px solid rgba(51,65,85,.7);background:inherit;backdrop-filter:inherit;-webkit-backdrop-filter:inherit}.voice-selector-modal:before{content:"";display:block;width:36px;height:4px;border-radius:999px;background:#cbd5e18c;margin:4px auto 10px}.voice-selector-header{position:sticky;top:0;z-index:2;background:inherit;backdrop-filter:inherit;-webkit-backdrop-filter:inherit;margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid rgba(51,65,85,.7)}.voice-selector-header h3{font-size:1.125rem}.voice-filters--v2{grid-template-columns:1fr;padding:12px;gap:10px}.filter-group select{min-height:3rem;font-size:1rem}.voice-search-bar{min-height:3rem}.voice-search-bar__input{font-size:1rem}.voices-list{grid-template-columns:1fr;gap:10px}.voice-option{padding:14px 12px;min-height:88px}.play-button{width:44px;height:44px}.volume-slider{width:72px}}@media (max-width: 480px){.voice-option{flex-wrap:wrap;align-items:flex-start;gap:10px}.voice-volume-control{width:100%;justify-content:flex-end;order:10}.volume-slider{flex:1;max-width:140px;width:auto}.confirmation-actions{flex-direction:column}.confirmation-actions .btn{width:100%}}@media (prefers-reduced-motion: reduce){.voice-selector-overlay{animation:overlayFadeIn 1ms linear}.voice-selector-modal,.voice-selector-footer{animation:none}}:root{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-card: #1e293b;--text-primary: #f8fafc;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--border-color: #334155;--border-light: #475569;--accent-color: #3b82f6;--accent-hover: #60a5fa;--accent-light: #1e40af;--accent-color-light: #1e3a8a;--success-color: #10b981;--error-color: #ef4444;--error-color-light: #7f1d1d;--warning-color: #f59e0b;--gradient-primary: linear-gradient(135deg, #374151 0%, #1f2937 100%);--gradient-secondary: linear-gradient(135deg, #6b7280 0%, #4b5563 100%);--gradient-accent: linear-gradient(135deg, #3b82f6 0%, #1d4ed8 100%);--gradient-success: linear-gradient(135deg, #10b981 0%, #059669 100%);--gradient-error: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);--shadow-sm: 0 1px 3px 0 rgb(0 0 0 / .4);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .4), 0 2px 4px -2px rgb(0 0 0 / .4);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .4), 0 4px 6px -4px rgb(0 0 0 / .4);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .4), 0 8px 10px -6px rgb(0 0 0 / .4);--shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / .5);--glow: 0 0 30px rgba(59, 130, 246, .4);--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 24px;--transition-fast: .15s ease-out;--transition-normal: .3s cubic-bezier(.4, 0, .2, 1);--transition-slow: .5s cubic-bezier(.4, 0, .2, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--ease-in: cubic-bezier(.4, 0, 1, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-size-5xl: 3rem;--font-size-6xl: 3.75rem;--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1280px;--breakpoint-2xl: 1536px;--chat-glass-bg: color-mix(in srgb, var(--bg-secondary) 78%, transparent);--chat-glass-border: color-mix(in srgb, var(--border-color) 55%, transparent);--chat-menu-bg: color-mix(in srgb, var(--bg-card) 94%, transparent)}[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--bg-card: #ffffff;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #64748b;--border-color: #e2e8f0;--border-light: #f1f5f9;--accent-color: #3b82f6;--accent-hover: #2563eb;--accent-light: #dbeafe;--accent-color-light: #dbeafe;--success-color: #10b981;--error-color: #ef4444;--error-color-light: #fef2f2;--warning-color: #f59e0b;--gradient-primary: linear-gradient(135deg, #e5e7eb 0%, #d1d5db 100%);--gradient-secondary: linear-gradient(135deg, #f3f4f6 0%, #e5e7eb 100%);--gradient-accent: linear-gradient(135deg, #3b82f6 0%, #1d4ed8 100%);--gradient-success: linear-gradient(135deg, #10b981 0%, #059669 100%);--gradient-error: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / .25);--glow: 0 0 20px rgba(59, 130, 246, .3);--chat-glass-bg: color-mix(in srgb, var(--bg-card) 88%, transparent);--chat-glass-border: color-mix(in srgb, var(--border-color) 45%, transparent);--chat-menu-bg: var(--bg-card)}*{margin:0;padding:0;box-sizing:border-box}html,body{height:auto;width:100%;margin:0;padding:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);transition:var(--transition-normal);line-height:1.6;font-size:var(--font-size-base);font-weight:400;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}#root{width:100%;display:flex;flex-direction:column}.app{min-height:100vh;display:grid;background:var(--bg-primary);position:relative;overflow:hidden;contain:layout style paint;will-change:auto}@media (min-width: 1024px){.app{grid-template-columns:1fr 600px;grid-template-rows:1fr;gap:0}}@media (max-width: 1023px){.app{grid-template-columns:1fr;grid-template-rows:1fr;gap:0}}.canvas-container{position:relative;background:var(--bg-primary);overflow:hidden;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;transition:background-color .5s ease}.canvas-container>*:first-child{flex:1;min-height:0;width:100%;position:relative}@media (min-width: 1024px){.canvas-container{min-height:100vh;border-right:1px solid var(--border-color);position:relative;z-index:1}}@media (max-width: 1023px){.canvas-container{height:100vh;min-height:100vh;border-bottom:none}}.canvas-container:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#f8fafccc,#f1f5f999,#e2e8f066),radial-gradient(circle at 25% 25%,rgba(59,130,246,.03) 0%,transparent 50%),radial-gradient(circle at 75% 75%,rgba(147,51,234,.03) 0%,transparent 50%),radial-gradient(circle at 50% 50%,rgba(6,182,212,.02) 0%,transparent 70%);pointer-events:none;z-index:1;transition:all .5s ease}.canvas-container--warm:before{background:linear-gradient(135deg,#fef3c7cc,#fde68a99,#fbbf2466),radial-gradient(circle at 25% 25%,rgba(245,158,11,.05) 0%,transparent 50%),radial-gradient(circle at 75% 75%,rgba(251,191,36,.05) 0%,transparent 50%)}.canvas-container--energetic:before{background:linear-gradient(135deg,#fee2e2cc,#fca5a599,#ef444466),radial-gradient(circle at 25% 25%,rgba(239,68,68,.08) 0%,transparent 50%),radial-gradient(circle at 75% 75%,rgba(220,38,38,.05) 0%,transparent 50%)}.canvas-container--serene:before{background:linear-gradient(135deg,#ecfeffcc,#cffafe99,#22d3ee66),radial-gradient(circle at 25% 25%,rgba(6,182,212,.05) 0%,transparent 50%),radial-gradient(circle at 75% 75%,rgba(34,211,238,.05) 0%,transparent 50%)}.canvas-container--melancholic:before{background:linear-gradient(135deg,#f1f5f9cc,#e2e8f099,#94a3b866),radial-gradient(circle at 25% 25%,rgba(100,116,139,.05) 0%,transparent 50%),radial-gradient(circle at 75% 75%,rgba(71,85,105,.05) 0%,transparent 50%)}.canvas-container--intense:before{background:linear-gradient(135deg,#fee2e2cc,#f8717199,#dc262666),radial-gradient(circle at 25% 25%,rgba(220,38,38,.1) 0%,transparent 50%),radial-gradient(circle at 75% 75%,rgba(185,28,28,.08) 0%,transparent 50%)}.canvas-container--tense:before{background:linear-gradient(135deg,#fef3c7cc,#fbbf2499,#f59e0b66),radial-gradient(circle at 25% 25%,rgba(245,158,11,.08) 0%,transparent 50%),radial-gradient(circle at 75% 75%,rgba(217,119,6,.05) 0%,transparent 50%)}.canvas-container--artistic:before{background:linear-gradient(135deg,#faf5ffcc,#f3e8ff99,#c4b5fd66),radial-gradient(circle at 25% 25%,rgba(147,51,234,.08) 0%,transparent 50%),radial-gradient(circle at 75% 75%,rgba(168,85,247,.05) 0%,transparent 50%)}.canvas-container--precise:before{background:linear-gradient(135deg,#f0f9ffcc,#dbeafe99,#3b82f666),radial-gradient(circle at 25% 25%,rgba(37,99,235,.08) 0%,transparent 50%),radial-gradient(circle at 75% 75%,rgba(59,130,246,.05) 0%,transparent 50%)}.canvas-container--professional:before{background:linear-gradient(135deg,#f8fafccc,#f1f5f999,#e2e8f066),radial-gradient(circle at 25% 25%,rgba(71,85,105,.05) 0%,transparent 50%),radial-gradient(circle at 75% 75%,rgba(100,116,139,.05) 0%,transparent 50%)}[data-theme=light] .canvas-container:before{background:linear-gradient(135deg,#f8fafccc,#f1f5f999,#e2e8f066),radial-gradient(circle at 25% 25%,rgba(59,130,246,.03) 0%,transparent 50%),radial-gradient(circle at 75% 75%,rgba(147,51,234,.03) 0%,transparent 50%),radial-gradient(circle at 50% 50%,rgba(6,182,212,.02) 0%,transparent 70%)}[data-theme=light] .canvas-container--warm:before{background:linear-gradient(135deg,#fef3c7cc,#fde68a99,#fbbf2466),radial-gradient(circle at 25% 25%,rgba(245,158,11,.05) 0%,transparent 50%),radial-gradient(circle at 75% 75%,rgba(251,191,36,.05) 0%,transparent 50%)}[data-theme=light] .canvas-container--energetic:before{background:linear-gradient(135deg,#fee2e2cc,#fca5a599,#ef444466),radial-gradient(circle at 25% 25%,rgba(239,68,68,.08) 0%,transparent 50%),radial-gradient(circle at 75% 75%,rgba(220,38,38,.05) 0%,transparent 50%)}[data-theme=light] .canvas-container--serene:before{background:linear-gradient(135deg,#ecfeffcc,#cffafe99,#22d3ee66),radial-gradient(circle at 25% 25%,rgba(6,182,212,.05) 0%,transparent 50%),radial-gradient(circle at 75% 75%,rgba(34,211,238,.05) 0%,transparent 50%)}.canvas-container:after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 0%,transparent 60%,rgba(0,0,0,.02) 100%);pointer-events:none;z-index:1}[data-theme=light] .canvas-container:after{background:radial-gradient(ellipse at center,transparent 0%,transparent 60%,rgba(0,0,0,.02) 100%)}.canvas-container canvas{position:relative;z-index:2;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f,0 0 0 1px #ffffff0d;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}[data-theme=light] .canvas-container canvas{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f,0 0 0 1px #ffffff0d}@keyframes subtleBreathingCanvas{0%,to{opacity:.92}50%{opacity:1}}.canvas-container canvas{animation:subtleBreathingCanvas 8s ease-in-out infinite}.canvas-container:before{animation:particleFloat 20s linear infinite}@keyframes particleFloat{0%{transform:translateY(0) rotate(0)}to{transform:translateY(-20px) rotate(360deg)}}.chat-panel{background:var(--bg-secondary);display:flex;flex-direction:column;position:relative;overflow:hidden;border-left:1px solid var(--border-color);box-shadow:var(--shadow-lg);contain:layout style;transform:translateZ(0)}@media (min-width: 1024px){.chat-panel{height:100vh;width:600px;flex-shrink:0;z-index:2}}.sessions-sidebar{width:220px;border-right:1px solid var(--border-color);display:flex;flex-direction:column;transition:width var(--transition-normal);position:relative;z-index:2;overflow:visible}.sessions-header{padding:10px 12px;font-weight:600;color:var(--text-secondary)}.sessions-new-row{display:flex;gap:6px;align-items:center;padding:8px 10px;border-bottom:1px solid var(--border-color)}.sessions-new-input{flex:1;min-width:0;height:34px;padding:0 10px;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);font-size:.8rem;outline:none}.sessions-new-input:focus{border-color:var(--accent-color);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent-color) 22%,transparent)}.sessions-new-input:disabled{opacity:.65}.sessions-new-submit{flex-shrink:0}.sessions-delete-confirm{padding:10px 12px;border-top:1px solid var(--border-color);background:color-mix(in srgb,var(--error-color) 8%,var(--bg-secondary))}.sessions-delete-confirm--inline{border-top:none;border-bottom:1px solid var(--border-color);margin:0}.sessions-delete-confirm__text{margin:0 0 8px;font-size:.75rem;line-height:1.35;color:var(--text-primary)}.sessions-delete-confirm__actions{display:flex;gap:8px;justify-content:flex-end}.sessions-delete-confirm__btn{padding:6px 12px;border-radius:var(--radius-md);font-size:.75rem;font-weight:600;cursor:pointer;border:1px solid transparent;font-family:inherit;transition:background var(--transition-fast),border-color var(--transition-fast)}.sessions-delete-confirm__btn:disabled{opacity:.55;cursor:not-allowed}.sessions-delete-confirm__btn--cancel{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-color)}.sessions-delete-confirm__btn--cancel:hover:not(:disabled){background:var(--bg-secondary)}.sessions-delete-confirm__btn--danger{background:var(--error-color);color:#fff}.sessions-delete-confirm__btn--danger:hover:not(:disabled){filter:brightness(1.05)}.session-item--editing{display:flex;align-items:center;gap:6px;width:100%;box-sizing:border-box;padding:8px 12px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.sessions-edit-input{flex:1;min-width:0;height:32px;padding:0 8px;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-size:.8rem;outline:none}.sessions-edit-input:focus{border-color:var(--accent-color)}.sessions-edit-btn{flex-shrink:0}.sessions-edit-btn--save{color:var(--success-color);border-color:color-mix(in srgb,var(--success-color) 45%,var(--border-color))}.sessions-list{overflow-y:auto;flex:1}.session-row{display:flex;align-items:center;width:100%;gap:2px;border-bottom:1px solid var(--border-color)}.session-row--active{background:color-mix(in srgb,var(--accent-color) 6%,transparent)}.session-row .session-actions-menu{flex-shrink:0;padding:4px 6px 4px 0}.session-item{width:100%;text-align:left;padding:8px 12px;background:transparent;border:none;color:var(--text-primary);cursor:pointer}.session-item--in-row{width:auto;flex:1;min-width:0;border-bottom:none}.session-item__label{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.session-item.active,.session-row--active .session-item.active{background:transparent}.session-row .session-item.active .session-item__label{font-weight:600}.sessions-actions{padding:8px;border-top:1px solid var(--border-color);display:flex;flex-wrap:wrap;gap:6px;align-items:center;justify-content:flex-start}.sessions-sidebar--collapsed{width:0px;border-right:none;overflow:hidden}.chat-layout{display:flex;height:100%;width:100%;overflow:visible}.chat-content{display:flex;flex-direction:column;flex:1;min-width:0}@media (max-width: 1023px){.chat-content{display:contents}}@media (max-width: 1023px){.chat-panel{position:fixed;inset:0;height:100vh;width:100vw;border:none;background:transparent;box-shadow:none;z-index:40;display:flex}.chat-panel>*{position:relative;z-index:1}.chat-layout{position:relative}.sessions-sidebar--mobile{position:absolute;top:env(safe-area-inset-top,0px);margin-top:var(--mobile-chat-header-height, 56px);left:0;bottom:0;width:80vw;max-width:320px;background:var(--chat-glass-bg);border-right:1px solid var(--chat-glass-border);box-shadow:var(--shadow-xl);transform:translate(0);transition:transform var(--transition-normal),opacity var(--transition-normal);z-index:2;backdrop-filter:blur(8px) saturate(120%);-webkit-backdrop-filter:blur(8px) saturate(120%)}.sessions-sidebar--mobile.sessions-sidebar--hidden{transform:translate(-100%);opacity:.96;pointer-events:none}.chat-layout{position:absolute;left:0;right:0;bottom:0;top:env(safe-area-inset-top,0px);height:100%;background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none;display:grid;grid-template-rows:auto 1fr auto auto}.sessions-backdrop{position:absolute;top:env(safe-area-inset-top,0px);margin-top:var(--mobile-chat-header-height, 56px);left:0;right:0;bottom:0;background:#02061759;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);z-index:1}.chat-panel--overlay{opacity:1;transform:translateY(0);transition:opacity var(--transition-normal),transform var(--transition-normal)}.chat-panel--hidden{pointer-events:none;opacity:0;transform:translateY(8px)}}.chat-messages{flex:1;padding:1rem;overflow-y:auto;display:flex;flex-direction:column;gap:.75rem;background:transparent;position:relative}@media (max-width: 1023px){.chat-messages{background:transparent;border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color)}}@media (max-width: 1023px){.chat-header{background:var(--chat-glass-bg)!important;backdrop-filter:blur(8px) saturate(120%);-webkit-backdrop-filter:blur(8px) saturate(120%);border-bottom:1px solid var(--chat-glass-border);box-shadow:var(--shadow-xl)}.chat-input,.status-bar{background:var(--chat-glass-bg)!important;backdrop-filter:blur(8px) saturate(120%);-webkit-backdrop-filter:blur(8px) saturate(120%);border-top:1px solid var(--chat-glass-border);box-shadow:var(--shadow-xl)}}@media (max-width: 1023px){.message-content{background:color-mix(in srgb,var(--bg-card) 82%,transparent)!important;border:1px solid var(--chat-glass-border)!important;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.message--user .message-content{background:color-mix(in srgb,var(--accent-color) 72%,var(--bg-card))!important;color:#fff!important;border-color:color-mix(in srgb,var(--accent-color) 55%,transparent)!important}}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:var(--radius-sm);margin:.5rem 0}.chat-messages::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-sm);transition:background .2s ease}.chat-messages::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.loading-message{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:.75rem 1rem;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:all .2s ease;min-width:140px;animation:messageSlideIn .2s ease-out;margin:.5rem 0}.loading-message:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gradient-accent);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.loading-message p{color:var(--text-primary);line-height:1.4;font-size:.85rem;font-weight:500;margin:0;word-wrap:break-word}.typing-indicator{display:flex;gap:.25rem;margin-bottom:.5rem}.typing-indicator span{width:5px;height:5px;border-radius:50%;background:var(--accent-color);animation:typing 1.4s infinite ease-in-out}.typing-indicator span:nth-child(1){animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}@keyframes typing{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1);opacity:1}}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes shimmer{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}.fade-in{animation:fadeIn var(--transition-normal) var(--ease-out)}.fade-in-up{animation:fadeInUp var(--transition-slow) var(--ease-out)}.fade-in-down{animation:fadeInDown var(--transition-slow) var(--ease-out)}.slide-in-left{animation:slideInLeft var(--transition-normal) var(--ease-out)}.slide-in-right{animation:slideInRight var(--transition-normal) var(--ease-out)}.scale-in{animation:scaleIn var(--transition-normal) var(--ease-out)}.float{animation:float 3s ease-in-out infinite}.pulse{animation:pulse 2s ease-in-out infinite}.animate-delay-100{animation-delay:.1s}.animate-delay-200{animation-delay:.2s}.animate-delay-300{animation-delay:.3s}.animate-delay-500{animation-delay:.5s}.hover-lift{transition:var(--transition-normal)}.hover-lift:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.hover-scale{transition:var(--transition-normal)}.hover-scale:hover{transform:scale(1.05)}.hover-glow{transition:var(--transition-normal)}.hover-glow:hover{box-shadow:var(--glow)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.glass{background:#ffffff1a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}[data-theme=light] .glass{background:#ffffff1a;border:1px solid rgba(255,255,255,.2)}.canvas-container canvas{z-index:1}.streaming-message{opacity:.9;border-left:3px solid var(--accent-color);background:linear-gradient(90deg,var(--accent-light) 0%,transparent 100%)}.streaming-message .message-text{color:var(--text-primary);font-weight:500}.streaming-cursor{color:var(--accent-color);font-weight:700;animation:blink 1s infinite}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.message-badge--streaming{background:var(--accent-color);color:#fff;font-size:10px;padding:2px 6px;border-radius:var(--radius-sm);display:flex;align-items:center;gap:4px;animation:pulse 2s infinite}@keyframes pulse{0%{opacity:1}50%{opacity:.7}to{opacity:1}}.icon--loading{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.floating-monitors{position:fixed;inset:0;pointer-events:none;z-index:50}.floating-monitors>*{pointer-events:auto}.floating-monitors .animation-performance-monitor,.floating-monitors .base-pose-monitor{position:absolute;top:1rem;right:1rem;z-index:51}.floating-monitors .base-pose-monitor{top:6rem}@media (max-width: 768px){.floating-monitors .animation-performance-monitor,.floating-monitors .base-pose-monitor{top:.5rem;right:.5rem}.floating-monitors .base-pose-monitor{top:4rem}}@media (max-width: 480px){.floating-monitors .animation-performance-monitor,.floating-monitors .base-pose-monitor{top:.25rem;right:.25rem}.floating-monitors .base-pose-monitor{top:3rem}}@media (max-width: 1023px){.chat-fab{position:fixed;right:16px;bottom:16px;z-index:50;width:56px;height:56px;border-radius:50%;border:1px solid var(--border-color);background:var(--gradient-accent);color:#fff;display:inline-flex;align-items:center;justify-content:center;box-shadow:var(--shadow-xl),var(--glow);transition:transform var(--transition-normal),box-shadow var(--transition-normal),opacity var(--transition-normal)}.chat-fab:hover{transform:translateY(-2px) scale(1.03);box-shadow:var(--shadow-2xl),var(--glow)}.chat-fab--active{background:var(--gradient-error)}}.toast-container{position:fixed;top:12px;right:12px;display:flex;flex-direction:column;gap:8px;z-index:60}.toast{display:flex;align-items:center;gap:8px;background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-primary);border-radius:10px;padding:10px 12px;box-shadow:var(--shadow-xl);min-width:240px;max-width:360px;animation:fadeIn var(--transition-normal) var(--ease-out)}.toast__icon{color:var(--text-secondary)}.toast__title{font-weight:700;font-size:.8rem}.toast__message{font-size:.75rem;opacity:.9}.toast__content{display:flex;flex-direction:column;gap:2px}.toast__close{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:6px}.toast__close:hover{background:var(--bg-secondary);color:var(--text-primary)}.toast--success{border-left:3px solid var(--success-color)}.toast--error{border-left:3px solid var(--error-color)}.toast--warning{border-left:3px solid var(--warning-color)}.toast--info{border-left:3px solid var(--accent-color)}.avatar-controls{position:absolute;left:50%;transform:translate(-50%);bottom:16px;display:flex;gap:8px;padding:8px;background:var(--chat-glass-bg, rgba(15, 23, 42, .55));backdrop-filter:blur(8px) saturate(120%);-webkit-backdrop-filter:blur(8px) saturate(120%);border:1px solid var(--chat-glass-border, var(--border-color));border-radius:12px;box-shadow:var(--shadow-xl);z-index:5}.avatar-control{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-secondary);border-radius:10px;cursor:pointer;transition:var(--transition-normal)}.avatar-control:hover{background:var(--bg-secondary);color:var(--text-primary);transform:translateY(-1px);box-shadow:var(--shadow-md)}.avatar-control--primary{background:var(--gradient-accent);color:#fff;border-color:transparent}.avatar-control--primary:hover{transform:translateY(-1px) scale(1.02)}.avatar-control--danger{background:var(--gradient-error);color:#fff;border-color:transparent}@media (min-width: 1024px){.avatar-controls{left:50%;transform:translate(-50%);bottom:24px}}.avatar-topbar{position:absolute;top:12px;left:50%;transform:translate(-50%);width:calc(100% - 24px);max-width:960px;display:flex;align-items:center;justify-content:space-between;padding:8px 10px;background:var(--chat-glass-bg, rgba(15, 23, 42, .72));backdrop-filter:blur(8px) saturate(120%);-webkit-backdrop-filter:blur(8px) saturate(120%);border:1px solid var(--chat-glass-border, var(--border-color));border-radius:12px;box-shadow:var(--shadow-xl);z-index:4}.avatar-topbar__btn{display:inline-flex;align-items:center;gap:6px;background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:10px;padding:6px 10px;cursor:pointer;transition:var(--transition-normal)}.avatar-topbar__btn:hover{background:var(--bg-secondary);color:var(--text-primary);transform:translateY(-1px);box-shadow:var(--shadow-md)}.avatar-topbar__btn--icon{padding:6px;min-width:36px;justify-content:center}.avatar-topbar__left,.avatar-topbar__right{display:flex;gap:8px}@media (max-width: 1023px){.avatar-topbar{top:10px;width:calc(100% - 16px)}.avatar-topbar__btn span{display:none}}.session-actions-menu{position:relative}.session-actions-menu__trigger{flex-shrink:0}.session-actions-menu__dropdown{padding:.35rem;background:var(--chat-menu-bg, var(--bg-card));border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-2xl);animation:session-actions-in .12s ease-out;backdrop-filter:blur(12px) saturate(120%);-webkit-backdrop-filter:blur(12px) saturate(120%)}.session-actions-menu__dropdown--portal{max-height:min(70vh,280px);overflow-y:auto}@keyframes session-actions-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.session-actions-menu__item{width:100%;display:flex;align-items:center;gap:.5rem;padding:.5rem .65rem;border:none;border-radius:var(--radius-md);background:transparent;color:var(--text-primary);font-size:.8rem;font-weight:500;cursor:pointer;text-align:left;transition:background var(--transition-fast)}.session-actions-menu__item:hover:not(:disabled){background:var(--bg-secondary)}.session-actions-menu__item:disabled{opacity:.45;cursor:not-allowed}.session-actions-menu__item--danger:hover:not(:disabled){background:color-mix(in srgb,var(--error-color) 12%,var(--bg-secondary));color:var(--error-color)}
