.auth-form-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:var(--bg-modal);padding:20px}.auth-form{background:var(--bg-modal);border-radius:12px;padding:40px;max-width:420px;width:100%;box-shadow:var(--shadow-lg);border:1px solid var(--border-accent)}.auth-form h2{margin:0 0 30px;text-align:center;color:var(--text-primary);font-size:28px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:var(--text-secondary);font-weight:500;font-size:14px}.form-group input{width:100%;padding:12px;background:var(--bg-input);border:1px solid var(--border-light);border-radius:6px;font-size:14px;color:var(--text-primary);transition:all .3s;box-sizing:border-box}.form-group input::placeholder{color:var(--text-muted)}.form-group input:focus{outline:none;border-color:var(--accent-secondary);background:var(--bg-hover);box-shadow:0 0 0 3px #667eea1a}.form-group small{display:block;margin-top:5px;color:var(--text-muted);font-size:12px}.error-message{background:#e74c3c26;color:var(--error);padding:12px;border-radius:6px;margin-bottom:20px;font-size:14px;border:1px solid rgba(231,76,60,.3)}.primary-button{width:100%;padding:14px;background:var(--accent-gradient);color:var(--text-on-accent);border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s,opacity .2s}.primary-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 20px #667eea66}.primary-button:disabled{opacity:.6;cursor:not-allowed}.auth-switch{margin-top:30px;text-align:center}.auth-switch p{color:var(--text-secondary);margin-bottom:10px;font-size:14px}.link-button{background:none;border:none;color:var(--accent-secondary);font-size:14px;font-weight:600;cursor:pointer;text-decoration:underline}.link-button:hover{color:var(--accent-hover)}.turnstile-container{margin-bottom:20px;display:flex;justify-content:center;align-items:center;min-height:65px}.turnstile-container>div{width:100%;display:flex;justify-content:center}.consent-section{margin:24px 0;padding:16px;background:var(--bg-input);border-radius:8px;border:1px solid var(--border-accent)}.consent-section.compact{margin:20px 0;padding:12px 14px}.consent-group{margin-bottom:16px}.consent-section.compact .consent-group{margin-bottom:12px}.consent-group:last-child{margin-bottom:0}.consent-group.optional{opacity:.9}.consent-label{display:flex;align-items:flex-start;gap:10px;cursor:pointer;font-size:14px;line-height:1.5;color:var(--text-primary)}.consent-label input[type=checkbox]{margin-top:2px;width:18px;height:18px;cursor:pointer;flex-shrink:0;accent-color:var(--accent-secondary)}.consent-label span{flex:1}.consent-label a{color:var(--accent-secondary);text-decoration:none;font-weight:600}.consent-label a:hover{text-decoration:underline;color:var(--accent-hover)}.required-badge{display:inline-block;background:#e74c3ccc;color:var(--text-on-accent);padding:2px 6px;border-radius:3px;font-size:10px;font-weight:600;text-transform:uppercase;margin-left:4px}.optional-badge{display:inline-block;background:#95a5a699;color:var(--text-on-accent);padding:2px 6px;border-radius:3px;font-size:10px;font-weight:600;text-transform:uppercase;margin-left:4px}.consent-description{margin:6px 0 0 28px;font-size:12px;color:var(--text-secondary);line-height:1.4}.consent-section.compact .consent-description{margin:4px 0 0 28px;font-size:11px;color:var(--text-muted)}@media (max-width: 600px){.auth-form-container{padding:10px}.auth-form{padding:30px 20px}.auth-form h2{font-size:24px}.consent-section{padding:12px}.consent-label{font-size:13px}.consent-description{font-size:11px;margin-left:0;margin-top:4px}}.login-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:var(--backdrop-blur);backdrop-filter:var(--backdrop-blur)}.login-modal-content{position:relative;background:transparent;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.login-modal-close{position:absolute;top:10px;right:50px;background:var(--bg-hover);border:1px solid var(--border-light);font-size:24px;line-height:1;cursor:pointer;color:var(--text-primary);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease;z-index:10;font-weight:300}.login-modal-close:hover{background:var(--bg-active);border-color:var(--border-color);transform:scale(1.1)}.login-modal-content .auth-form-container{min-height:auto;background:transparent;padding:0;position:relative}.login-modal-content .auth-form{box-shadow:var(--shadow-lg);margin:0;position:relative}.login-modal-content::-webkit-scrollbar{width:8px}.login-modal-content::-webkit-scrollbar-track{background:var(--scrollbar-track);border-radius:4px}.login-modal-content::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:4px}.login-modal-content::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}.settings-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000c;display:flex;justify-content:center;align-items:center;z-index:10000;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.settings-modal-content{background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid rgba(102,126,234,.3);border-radius:12px;max-width:500px;width:100%;max-height:80vh;overflow:visible;box-shadow:0 8px 32px #00000080;position:relative}.settings-modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 30px;border-bottom:1px solid rgba(255,255,255,.1)}.settings-modal-header h2{margin:0;font-size:24px;color:#fff;font-weight:600}.settings-modal-close{background:none;border:none;font-size:32px;color:#fff9;cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.settings-modal-close:hover{background-color:#ffffff1a;color:#fff}.settings-modal-body{padding:30px;overflow-y:auto;max-height:calc(80vh - 80px)}.settings-section{margin-bottom:30px}.settings-section:last-child{margin-bottom:0}.settings-label{display:block;font-weight:600;color:#b0b0c3;margin-bottom:12px;font-size:15px}.settings-description{margin:8px 0 0;font-size:13px;color:#8a8a9e;line-height:1.5}.language-selector-compact{position:relative;display:inline-block;width:100%;max-width:280px}.language-selector-button{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;cursor:pointer;transition:all .2s;font-size:15px;color:#fff}.language-selector-button:hover{background:#ffffff14;border-color:#667eea80}.language-flag{font-size:20px;line-height:1}.language-name{flex:1;text-align:left;color:#fff;font-weight:500}.language-arrow{color:#ffffff80;font-size:12px;transition:transform .2s}.language-selector-compact:hover .language-arrow{transform:translateY(2px)}.language-dropdown{position:fixed;background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid rgba(102,126,234,.3);border-radius:8px;box-shadow:0 8px 24px #00000080;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .2s;z-index:10001;max-height:280px;overflow-y:auto}.language-selector-compact:hover .language-dropdown{opacity:1;visibility:visible;transform:translateY(0)}.language-option{display:flex;align-items:center;gap:10px;padding:10px 16px;background:transparent;border:none;text-align:left;cursor:pointer;transition:background-color .2s;position:relative;white-space:nowrap}.language-option:hover{background:#ffffff0d}.language-option.active{background:#667eea33}.language-option .language-flag{font-size:18px;flex-shrink:0}.language-option .language-name{font-size:14px;font-weight:500;color:#fff;flex-shrink:0}.language-check{color:#667eea;font-size:14px;font-weight:700;margin-left:8px;flex-shrink:0}.theme-selector{display:flex;gap:12px;flex-wrap:wrap}.theme-option{flex:1;min-width:120px;display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 12px;background:var(--bg-input);border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s;font-size:14px;color:var(--text-primary)}.theme-option:hover{background:var(--bg-hover);border-color:var(--border-accent)}.theme-option.active{background:var(--bg-active);border-color:var(--accent-secondary)}.theme-icon{font-size:28px;line-height:1}.theme-name{font-weight:500;text-align:center}@media (max-width: 768px){.settings-modal-overlay{padding:10px}.settings-modal-content{max-height:90vh}.settings-modal-header{padding:20px}.settings-modal-header h2{font-size:20px}.settings-modal-body{padding:20px}.language-selector-compact{max-width:100%}.theme-selector{flex-direction:column}.theme-option{min-width:auto;flex-direction:row;justify-content:flex-start;gap:12px;padding:12px 16px}.theme-icon{font-size:24px}}.chat-layout{display:flex;flex-direction:column;width:100%;height:100vh;background-color:var(--bg-primary);color:var(--text-primary);overflow:hidden}.chat-header{display:flex;justify-content:space-between;align-items:center;padding:12px 24px;background-color:var(--bg-secondary);border-bottom:1px solid var(--bg-tertiary);height:60px;flex-shrink:0}.header-left{display:flex;align-items:center;gap:16px}.hamburger-menu{width:40px;height:40px;background:transparent;border:none;cursor:pointer;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;padding:8px;border-radius:6px;transition:background-color .2s ease}.hamburger-menu:hover{background-color:var(--bg-tertiary)}.hamburger-line{width:24px;height:2px;background-color:var(--text-primary);border-radius:2px;transition:all .3s ease}.header-right{display:flex;align-items:center;gap:12px}.user-menu-container{position:relative}.user-avatar-button{width:40px;height:40px;border-radius:50%;background:var(--accent-gradient);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;color:var(--text-on-accent);cursor:pointer;transition:all .2s ease;border:2px solid transparent}.user-avatar-button:hover{border-color:var(--accent-secondary);transform:scale(1.05);box-shadow:0 4px 12px var(--border-accent)}.header-login-button{padding:8px 20px;background:var(--accent-gradient);color:var(--text-on-accent);border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-sm)}.header-login-button:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;box-shadow:var(--shadow-md);z-index:1000;overflow:hidden;animation:dropdownFadeIn .2s ease}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{padding:12px 16px;font-size:14px;color:var(--text-primary);background:none;border:none;width:100%;text-align:left;cursor:pointer;transition:background-color .2s ease;display:block}.dropdown-item:hover{background-color:var(--bg-hover)}.user-email-item{color:var(--text-secondary);cursor:default;font-weight:500}.user-email-item:hover{background-color:transparent}.dropdown-divider{height:1px;background-color:var(--border-color);margin:4px 0}.logout-item{color:var(--error)}.logout-item:hover{background-color:#ef44441a}.header-button{padding:8px 16px;background-color:transparent;border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px}.header-button:hover{background-color:var(--bg-tertiary);border-color:var(--border-color)}.header-button.secondary{color:var(--text-secondary)}.header-button.logout{color:var(--error);border-color:var(--error)}.header-button.logout:hover{background-color:#ef44441a}.header-button .icon{font-size:16px;font-weight:600}.chat-main{flex:1;display:flex;background-color:var(--bg-primary);position:relative;overflow:hidden}.welcome-screen-split{flex:1;display:flex;overflow:hidden}.welcome-conversations-panel{background-color:var(--bg-secondary);border-right:1px solid var(--bg-tertiary);display:flex;flex-direction:column;padding:32px 24px;overflow-y:auto;transition:all .3s ease}.welcome-conversations-panel.sidebar-desktop{position:relative;width:35%;min-width:300px;max-width:500px}.welcome-conversations-panel.sidebar-desktop.sidebar-closed{width:0;min-width:0;padding:0;border-right:none;overflow:hidden}.welcome-conversations-panel.sidebar-mobile{position:fixed;top:60px;left:0;bottom:0;width:80%;max-width:350px;z-index:1500;box-shadow:4px 0 12px #0000004d;transform:translate(-100%)}.welcome-conversations-panel.sidebar-mobile.sidebar-open{transform:translate(0)}.sidebar-overlay{position:fixed;top:60px;left:0;right:0;bottom:0;background-color:#00000080;z-index:1400;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.sidebar-new-conversation-btn{width:100%;padding:12px 16px;background:var(--accent-gradient);border:none;border-radius:8px;color:var(--text-on-accent);font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:24px;transition:all .2s ease}.sidebar-new-conversation-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.sidebar-new-conversation-btn:active{transform:translateY(0)}.sidebar-new-conversation-btn .icon{font-size:18px;font-weight:700}.welcome-conversations-panel h2{font-size:20px;font-weight:600;color:var(--text-primary);margin-bottom:24px}.no-conversations-message{text-align:center;padding:48px 16px;color:var(--text-muted)}.no-conversations-message p{margin:0;font-size:14px}.no-conversations-message .hint{margin-top:8px;font-size:13px;color:var(--text-muted)}.conversations-list-welcome{display:flex;flex-direction:column;gap:8px}.conversation-item-welcome{padding:16px;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s ease}.conversation-item-welcome:hover{background-color:var(--bg-hover);border-color:var(--border-color);transform:translate(4px)}.conversation-title-welcome{font-size:15px;font-weight:500;color:var(--text-primary);margin-bottom:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conversation-meta-welcome{font-size:12px;color:var(--text-muted)}.welcome-main-panel{flex:1;display:flex;align-items:center;justify-content:center;padding:48px;overflow-y:auto}.welcome-content-centered{max-width:700px;width:100%;text-align:center}.welcome-content-centered h1{font-size:56px;font-weight:700;margin-bottom:16px;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.welcome-subtitle{font-size:18px;color:var(--text-secondary);margin-bottom:48px}.example-prompts{margin-bottom:40px}.prompts-label{font-size:14px;color:var(--text-muted);margin-bottom:16px}.prompt-suggestions{display:flex;flex-direction:column;gap:12px}.prompt-suggestion{padding:16px 24px;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;color:var(--text-primary);font-size:14px;cursor:pointer;transition:all .2s ease;text-align:left}.prompt-suggestion:hover{background-color:var(--bg-hover);border-color:var(--border-color);transform:translateY(-2px)}.welcome-input-centered{margin-top:48px}.message-list{display:flex;flex-direction:column;gap:16px}.message-list-empty{text-align:center;padding:48px 24px;color:var(--text-muted);font-size:14px}.message{padding:16px;border-radius:12px;max-width:85%;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.user{background-color:var(--bg-tertiary);border:1px solid var(--border-color);align-self:flex-end;margin-left:auto}.message.assistant{background-color:var(--bg-message-ai);border:1px solid var(--border-light);align-self:flex-start}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:12px}.message-role{font-weight:600;color:var(--accent-primary)}.message.user .message-role{color:var(--accent-secondary)}.message-timestamp{color:var(--text-muted);font-size:11px}.message-content{color:var(--text-primary);font-size:14px;line-height:1.6;white-space:pre-wrap;word-wrap:break-word}.model-indicator{margin-top:12px;padding:6px 10px;background-color:var(--bg-message-ai);border:1px solid var(--border-light);border-radius:6px;font-size:11px;color:var(--accent-primary);display:block;text-align:right;width:fit-content;margin-left:auto}.message-input{display:flex;gap:12px;align-items:flex-end}.message-input textarea{flex:1;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;padding:12px 16px;color:var(--text-primary);font-size:14px;font-family:inherit;resize:none;min-height:50px;max-height:200px;transition:border-color .2s ease}.message-input textarea:focus{outline:none;border-color:var(--accent-primary)}.message-input textarea:disabled{opacity:.5;cursor:not-allowed}.message-input textarea::placeholder{color:var(--text-muted)}.message-input button{padding:12px 24px;background:var(--accent-gradient);border:none;border-radius:12px;color:var(--text-on-accent);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;height:50px}.message-input button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-md)}.message-input button:disabled{opacity:.5;cursor:not-allowed;transform:none}.typing-indicator{display:flex;align-items:center;gap:4px;padding:4px 0}.typing-indicator span{width:8px;height:8px;background-color:var(--accent-primary);border-radius:50%;animation:bounce 1.4s infinite ease-in-out both}.typing-indicator span:nth-child(1){animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(0);opacity:.5}40%{transform:scale(1);opacity:1}}.conversation-view-container{flex:1;display:flex;overflow:hidden;position:relative}.conversations-sidebar{background-color:var(--bg-secondary);border-right:1px solid var(--bg-tertiary);display:flex;flex-direction:column;padding:32px 24px;overflow-y:auto;transition:all .3s ease}.conversations-sidebar.sidebar-desktop{position:relative;width:280px;min-width:280px;flex-shrink:0}.conversations-sidebar.sidebar-desktop.sidebar-closed{width:0;min-width:0;padding:0;border-right:none;overflow:hidden}.conversations-sidebar.sidebar-mobile{position:fixed;top:60px;left:0;bottom:0;width:80%;max-width:350px;z-index:1500;box-shadow:4px 0 12px #0000004d;transform:translate(-100%)}.conversations-sidebar.sidebar-mobile.sidebar-open{transform:translate(0)}.conversations-sidebar .conversation-item-welcome.active{background-color:var(--bg-active);border-color:var(--accent-secondary)}.chat-with-viewer-container{flex:1;display:flex;overflow:hidden}.chat-messages-panel{width:35%;min-width:400px;max-width:650px;display:flex;flex-direction:column;border-right:1px solid var(--bg-tertiary);overflow:hidden;flex-shrink:0}.chat-messages-area{flex:1;overflow-y:auto;padding:20px}.chat-input-container{padding:16px 20px 20px;border-top:1px solid var(--bg-tertiary);background-color:var(--bg-primary);flex-shrink:0}.model-viewer-panel{flex:1;background-color:var(--bg-secondary);display:flex;flex-direction:column}.viewer-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid var(--bg-tertiary);flex-shrink:0}.viewer-header h3{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.export-dropdown-container{position:relative}.export-button{padding:8px 16px;background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.export-button:hover{background-color:var(--bg-hover);border-color:var(--border-color)}.export-dropdown-menu{position:absolute;top:calc(100% + 4px);right:0;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;box-shadow:var(--shadow-md);min-width:150px;z-index:1000;overflow:hidden}.export-dropdown-item{width:100%;padding:10px 16px;background:none;border:none;color:var(--text-primary);font-size:14px;text-align:left;cursor:pointer;transition:background-color .2s ease;display:block}.export-dropdown-item:hover{background-color:var(--bg-hover)}.viewer-content{flex:1;overflow:hidden}.viewer-placeholder{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:14px}.loading-state{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:16px}.error-banner{position:absolute;top:16px;left:50%;transform:translate(-50%);padding:12px 24px;background-color:#ef44441a;border:1px solid var(--error);border-radius:8px;color:var(--error);font-size:14px;z-index:1000;max-width:80%;text-align:center}.welcome-conversations-panel::-webkit-scrollbar,.welcome-main-panel::-webkit-scrollbar,.chat-messages-area::-webkit-scrollbar{width:8px}.welcome-conversations-panel::-webkit-scrollbar-track,.welcome-main-panel::-webkit-scrollbar-track,.chat-messages-area::-webkit-scrollbar-track{background:transparent}.welcome-conversations-panel::-webkit-scrollbar-thumb,.welcome-main-panel::-webkit-scrollbar-thumb,.chat-messages-area::-webkit-scrollbar-thumb{background-color:var(--scrollbar-thumb);border-radius:4px}.welcome-conversations-panel::-webkit-scrollbar-thumb:hover,.welcome-main-panel::-webkit-scrollbar-thumb:hover,.chat-messages-area::-webkit-scrollbar-thumb:hover{background-color:var(--scrollbar-thumb-hover)}@media (max-width: 1200px){.chat-messages-panel{width:40%;min-width:350px}}.mobile-chat-toggle{display:none}@media (max-width: 768px){.chat-header{padding:12px 16px}.header-right{gap:8px}.header-button{padding:6px 12px;font-size:13px}.user-avatar-button{width:36px;height:36px;font-size:14px}.chat-with-viewer-container{flex-direction:column;position:relative}.model-viewer-panel{width:100%;height:100%;border-top:none;flex:1;z-index:1;transition:opacity .3s ease}.chat-messages-panel.mobile-expanded~.model-viewer-panel{opacity:.3}.chat-messages-panel{position:absolute;bottom:0;left:0;right:0;width:100%;min-width:auto;max-width:none;border-right:none;border-top:1px solid var(--bg-tertiary);background-color:var(--bg-primary);z-index:100;transition:height .3s ease,max-height .3s ease;box-shadow:var(--shadow-md)}.chat-messages-panel.mobile-collapsed{height:auto;max-height:140px}.chat-messages-panel.mobile-collapsed .chat-messages-area{visibility:hidden;opacity:0;height:0;overflow:hidden;transition:opacity .2s ease,visibility .2s ease}.chat-messages-panel.mobile-expanded{height:70vh;max-height:70vh}.chat-messages-panel.mobile-expanded .chat-messages-area{visibility:visible;opacity:1;height:auto;display:flex;transition:opacity .3s ease .1s,visibility .3s ease .1s}.mobile-chat-toggle{display:flex;align-items:center;justify-content:center;padding:8px 16px;background-color:var(--bg-tertiary);border-bottom:1px solid var(--border-color);cursor:pointer;gap:8px;-webkit-user-select:none;user-select:none}.mobile-chat-toggle:active{background-color:var(--bg-hover)}.toggle-handle{width:40px;height:4px;background-color:var(--text-muted);border-radius:2px}.toggle-text{font-size:13px;color:var(--text-secondary);font-weight:500}.chat-messages-panel .chat-input-container{padding:12px 16px 16px}.welcome-screen-split{position:relative}.welcome-main-panel{width:100%;padding:24px 16px;flex:1}.welcome-content-centered{max-width:100%;padding:0}.welcome-content-centered h1{font-size:32px}.welcome-subtitle{font-size:16px;margin-bottom:32px}.example-prompts{margin-bottom:32px}.prompt-suggestion{padding:14px 18px;font-size:13px}}.cookie-consent-overlay{position:fixed;bottom:20px;right:20px;z-index:9999;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100px);opacity:0}to{transform:translateY(0);opacity:1}}.cookie-consent-banner{background:var(--bg-primary);border-radius:12px;padding:16px 20px;max-width:420px;box-shadow:var(--shadow-lg);border:1px solid var(--border-color)}.cookie-consent-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px}.cookie-icon{font-size:24px;flex-shrink:0}.cookie-text{flex:1}.cookie-text strong{display:block;font-size:16px;color:var(--text-primary);margin-bottom:4px}.cookie-text p{margin:0;color:var(--text-secondary);font-size:13px;line-height:1.4}.cookie-consent-actions{display:flex;gap:8px;justify-content:flex-end}.cookie-btn{padding:8px 16px;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.cookie-btn-accept{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.cookie-btn-accept:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.cookie-btn-reject{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-light)}.cookie-btn-reject:hover{background:var(--bg-hover);color:var(--text-primary)}.cookie-btn-customize{background:transparent;color:var(--accent-secondary);border:1px solid var(--accent-secondary)}.cookie-btn-customize:hover{background:var(--bg-active);border-color:var(--accent-secondary)}.cookie-btn-back{background:var(--bg-tertiary);color:var(--text-secondary)}.cookie-btn-back:hover{background:var(--bg-hover)}.cookie-btn-save{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.cookie-btn-save:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.cookie-consent-details{margin-top:16px;max-height:400px;overflow-y:auto;padding-right:4px}.cookie-consent-details::-webkit-scrollbar{width:6px}.cookie-consent-details::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:3px}.cookie-consent-details::-webkit-scrollbar-thumb{background:var(--accent-secondary);opacity:.5;border-radius:3px}.cookie-consent-details::-webkit-scrollbar-thumb:hover{opacity:.7}.cookie-category{margin-bottom:16px;padding:12px;background:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border-light)}.cookie-category-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.cookie-category-header input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--accent-secondary)}.cookie-category-header input[type=checkbox]:disabled{cursor:not-allowed;opacity:.5}.cookie-category-header label{cursor:pointer;-webkit-user-select:none;user-select:none;font-size:14px;color:var(--text-primary)}.cookie-category-header label strong{color:var(--text-primary)}.cookie-category-description{margin:6px 0 8px 28px;color:var(--text-secondary);font-size:12px;line-height:1.5}.cookie-list{margin:6px 0 0 28px;padding-left:18px;color:var(--text-muted);font-size:11px}.cookie-list li{margin-bottom:3px}.cookie-consent-links{margin-top:12px;text-align:center;font-size:11px}.cookie-consent-links a{color:var(--accent-secondary);text-decoration:none}.cookie-consent-links a:hover{text-decoration:underline}.cookie-consent-links span{margin:0 6px;color:var(--text-muted)}@media (max-width: 600px){.cookie-consent-overlay{bottom:0;right:0;left:0}.cookie-consent-banner{border-radius:12px 12px 0 0;max-width:100%;max-height:90vh;overflow-y:auto}.cookie-consent-actions{flex-wrap:wrap}.cookie-btn{flex:1;min-width:80px}.cookie-category-description,.cookie-list{margin-left:0}}@media (max-width: 768px) and (min-width: 601px){.cookie-consent-banner{max-width:380px}}.app{display:flex;width:100%;height:100vh;overflow:hidden}.sidebar{width:250px;background-color:var(--bg-primary);color:var(--text-primary);padding:20px;overflow-y:auto;border-right:1px solid var(--border-color)}.sidebar h1{font-size:24px;margin-bottom:16px;color:var(--accent-primary)}.user-info{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;padding:12px;background-color:var(--bg-tertiary);border-radius:6px}.user-email{font-size:12px;color:var(--text-secondary);word-break:break-all}.logout-button{padding:6px 12px;background-color:transparent;color:var(--error);border:1px solid var(--error);border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s ease}.logout-button:hover{background-color:#ef44441a;border-color:var(--error);color:var(--error)}.loading-screen{display:flex;justify-content:center;align-items:center;height:100vh;background-color:var(--bg-primary);color:var(--text-primary);font-size:18px}.sidebar-nav{display:flex;flex-direction:column;gap:10px;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--border-color)}.nav-button{padding:10px 16px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;text-align:center}.nav-button.primary{background-color:var(--accent-primary);color:var(--text-on-accent)}.nav-button.primary:hover{background-color:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.nav-button.secondary{background-color:transparent;color:var(--accent-primary);border:1px solid var(--accent-primary)}.nav-button.secondary:hover{background-color:var(--bg-hover);border-color:var(--accent-hover);color:var(--accent-hover)}.status{color:var(--text-muted);font-size:14px;padding:10px}.error{color:var(--error);font-size:14px;padding:10px;background-color:#ef44441a;border-radius:4px}.model-list{list-style:none}.model-item{padding:15px;margin-bottom:10px;background-color:var(--bg-tertiary);border-radius:8px;cursor:pointer;transition:all .2s ease}.model-item:hover{background-color:var(--bg-hover);transform:translate(5px)}.model-item.active{background-color:var(--accent-primary);color:var(--text-on-accent)}.model-item h3{font-size:16px;margin-bottom:5px}.model-item p{font-size:12px;opacity:.8}.viewer-container{flex:1;position:relative;background:var(--accent-gradient)}.placeholder{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-on-accent);font-size:18px}.loading-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--text-on-accent);font-size:18px;background-color:#000000b3;padding:20px 40px;border-radius:8px}.details-panel{width:500px;background-color:var(--bg-primary);color:var(--text-primary);padding:20px;overflow-y:auto;border-right:1px solid var(--border-color)}.details-panel h2{font-size:20px;margin-bottom:20px;color:var(--accent-primary)}.detail-section{margin-bottom:25px}.detail-section h3{font-size:16px;color:var(--accent-primary);margin-bottom:10px;padding-bottom:5px;border-bottom:1px solid var(--border-color)}.detail-content{background-color:var(--bg-tertiary);padding:15px;border-radius:6px;font-size:14px;line-height:1.6}.detail-content p{margin:0;color:var(--text-secondary)}.code-block{background-color:var(--bg-secondary);font-family:Courier New,monospace;overflow-x:auto}.code-block pre{margin:0;color:var(--text-secondary);white-space:pre-wrap;word-wrap:break-word}.user-credits{font-size:.875rem;color:var(--text-muted);margin-top:4px}[data-theme=dark]{--bg-primary: #1e1e1e;--bg-secondary: #171717;--bg-tertiary: #2d2d2d;--bg-input: rgba(255, 255, 255, .05);--bg-message-user: rgba(102, 126, 234, .1);--bg-message-ai: rgba(97, 218, 251, .05);--bg-modal: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);--bg-hover: rgba(255, 255, 255, .05);--bg-active: rgba(102, 126, 234, .2);--text-primary: #ffffff;--text-secondary: #aaaaaa;--text-muted: #888888;--text-link: #61dafb;--text-on-accent: #ffffff;--accent-primary: #61dafb;--accent-secondary: #667eea;--accent-hover: #7ea8ff;--accent-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--border-color: rgba(255, 255, 255, .1);--border-light: rgba(255, 255, 255, .05);--border-accent: rgba(102, 126, 234, .3);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--success: #4ade80;--success-bg: rgba(74, 222, 128, .15);--error: #ef4444;--error-bg: rgba(239, 68, 68, .15);--error-border: rgba(239, 68, 68, .3);--warning: #f59e0b;--warning-bg: rgba(245, 158, 11, .15);--info: #3b82f6;--info-bg: rgba(59, 130, 246, .15);--focus-ring: rgba(59, 130, 246, .1);--backdrop-blur: blur(4px);--scrollbar-track: #2d2d2d;--scrollbar-thumb: #4a4a4a;--scrollbar-thumb-hover: #5a5a5a}[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f5f7fa;--bg-tertiary: #f0f2f5;--bg-input: #ffffff;--bg-message-user: rgba(59, 130, 246, .1);--bg-message-ai: rgba(156, 163, 175, .1);--bg-modal: linear-gradient(135deg, #ffffff 0%, #f5f7fa 100%);--bg-hover: rgba(0, 0, 0, .05);--bg-active: rgba(59, 130, 246, .15);--text-primary: #1f2937;--text-secondary: #6b7280;--text-muted: #9ca3af;--text-link: #3b82f6;--text-on-accent: #ffffff;--accent-primary: #3b82f6;--accent-secondary: #667eea;--accent-hover: #2563eb;--accent-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--border-color: rgba(0, 0, 0, .1);--border-light: rgba(0, 0, 0, .05);--border-accent: rgba(102, 126, 234, .3);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .1);--shadow-md: 0 4px 16px rgba(0, 0, 0, .15);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .2);--success: #22c55e;--success-bg: rgba(34, 197, 94, .15);--error: #ef4444;--error-bg: rgba(239, 68, 68, .15);--error-border: rgba(239, 68, 68, .3);--warning: #f59e0b;--warning-bg: rgba(245, 158, 11, .15);--info: #3b82f6;--info-bg: rgba(59, 130, 246, .15);--focus-ring: rgba(59, 130, 246, .1);--backdrop-blur: blur(4px);--scrollbar-track: #f0f2f5;--scrollbar-thumb: #cbd5e1;--scrollbar-thumb-hover: #94a3b8}*{transition:background-color .2s ease,border-color .2s ease,color .2s ease,box-shadow .2s ease}.theme-transitioning *{transition:none!important}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--scrollbar-track)}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}*{scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-track)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100vw;height:100vh}
