@import"https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800&family=Roboto+Mono:wght@400;500;600&display=swap";.app-footer{background:linear-gradient(180deg,transparent 0%,var(--bg-tertiary) 100%);border-top:1px solid var(--border-color);padding:12px 24px;margin-top:auto;font-size:.8125rem;color:var(--text-muted)}.footer-content{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;gap:24px}.footer-left{flex:1}.footer-mission{font-style:italic;color:var(--text-secondary);font-size:.8125rem}.footer-center{display:flex;align-items:center;gap:12px}.dnai-logo-link{display:flex;align-items:center;transition:opacity .2s ease}.dnai-logo-link:hover{opacity:.8}.dnai-logo{height:28px;width:auto}.footer-founded{font-weight:500;color:var(--text-secondary);padding-left:12px;border-left:1px solid var(--border-color)}.footer-right{flex:1;display:flex;align-items:center;justify-content:flex-end;gap:16px}.footer-link{display:flex;align-items:center;gap:4px;color:var(--text-secondary);text-decoration:none;transition:color .2s ease;font-size:.8125rem}.footer-link:hover{color:var(--accent-primary)}.footer-bottom{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:8px;padding-top:8px;border-top:1px solid var(--border-color);font-size:.75rem;color:var(--text-muted);flex-wrap:wrap}.footer-motto{color:var(--accent-primary);font-style:italic}.footer-disclosure,.footer-copyright{color:var(--text-muted)}.app-footer-minimal{background:transparent;border-top:none;padding:16px 24px}.app-footer-minimal .footer-content{flex-direction:row;justify-content:center;align-items:center;gap:24px}.app-footer-minimal .footer-tagline{color:var(--text-muted);font-size:.8125rem}.app-footer-minimal .footer-links{display:flex;gap:16px}@media (max-width: 768px){.app-footer{padding:12px 16px}.footer-content{flex-direction:column;gap:12px;text-align:center}.footer-left,.footer-right{justify-content:center}.footer-founded{border-left:none;padding-left:0}.footer-center{flex-direction:column;gap:8px}.footer-bottom{flex-direction:column;gap:4px}.app-footer-minimal .footer-content{gap:12px}}.cookie-consent-overlay{position:fixed;bottom:0;left:0;right:0;z-index:9999;padding:16px;animation:slideUp .4s ease-out}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.cookie-consent-banner{max-width:800px;margin:0 auto;background:var(--bg-secondary, #1a1a2e);border:1px solid var(--border-color, #333);border-radius:12px;padding:20px 24px;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px;box-shadow:0 -4px 20px #0000004d}.cookie-content{flex:1;min-width:280px}.cookie-content h3{margin:0 0 8px;font-size:1rem;color:var(--text-primary, #fff)}.cookie-content p{margin:0 0 8px;font-size:.875rem;color:var(--text-secondary, #aaa);line-height:1.5}.cookie-details{font-size:.75rem!important;opacity:.7}.cookie-details a{color:var(--accent-color, #4ecdc4);text-decoration:none}.cookie-details a:hover{text-decoration:underline}.cookie-jurisdiction{color:var(--text-muted, #888)}.cookie-actions{display:flex;gap:12px;flex-shrink:0}.cookie-btn{padding:10px 20px;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:none}.cookie-btn-essential{background:transparent;color:var(--text-secondary, #aaa);border:1px solid var(--border-color, #444)}.cookie-btn-essential:hover{background:var(--bg-tertiary, #252540);color:var(--text-primary, #fff)}.cookie-btn-accept{background:var(--accent-color, #4ecdc4);color:var(--bg-primary, #0a0a0f)}.cookie-btn-accept:hover{background:var(--accent-hover, #3dbdb5);transform:translateY(-1px)}@media (max-width: 600px){.cookie-consent-banner{flex-direction:column;text-align:center}.cookie-actions{width:100%;justify-content:center}.cookie-btn{flex:1}}.intake-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.intake-modal{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:20px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px #00000080;border:1px solid rgba(255,255,255,.1)}.intake-header{padding:28px 32px 20px;border-bottom:1px solid rgba(255,255,255,.1);text-align:center}.intake-header h2{margin:0 0 8px;font-size:1.75rem;font-weight:600;background:linear-gradient(135deg,#10b981,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.intake-subtitle{color:#9ca3af;margin:0 0 24px;font-size:.95rem}.intake-progress{display:flex;justify-content:center;gap:8px;flex-wrap:wrap}.progress-step{display:flex;flex-direction:column;align-items:center;gap:6px;opacity:.4;transition:all .3s ease}.progress-step.active,.progress-step.completed{opacity:1}.progress-step .step-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;transition:all .3s ease}.progress-step .step-label{font-size:.7rem;color:#9ca3af;font-weight:500}.progress-step.active .step-label{color:#fff}.intake-content{padding:28px 32px;min-height:380px}.intake-step h3{display:flex;align-items:center;gap:10px;margin:0 0 8px;font-size:1.25rem;font-weight:600;color:#f3f4f6}.step-title-icon{color:#10b981}.step-description{color:#9ca3af;margin:0 0 24px;font-size:.9rem;line-height:1.5}.intake-fields{display:flex;flex-direction:column;gap:20px}.intake-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.intake-field{display:flex;flex-direction:column;gap:8px}.intake-field label{font-size:.9rem;font-weight:500;color:#e5e7eb}.intake-field input,.intake-field textarea,.intake-field select{background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:10px;padding:12px 16px;color:#fff;font-size:.95rem;transition:all .2s ease}.intake-field input:focus,.intake-field textarea:focus,.intake-field select:focus{outline:none;border-color:#10b981;background:#ffffff14;box-shadow:0 0 0 3px #10b98126}.intake-field input::placeholder,.intake-field textarea::placeholder{color:#9ca3af;opacity:1}.intake-field select{cursor:pointer}.intake-field select option{background:#1a1a2e;color:#fff}.field-hint{font-size:.8rem;color:#a1a1aa;font-style:italic}.intake-options{display:flex;gap:10px;flex-wrap:wrap}.option-button{padding:10px 18px;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:#ffffff0d;color:#d1d5db;font-size:.9rem;cursor:pointer;transition:all .2s ease}.option-button:hover{background:#ffffff1a;border-color:#ffffff40}.option-button.selected{background:linear-gradient(135deg,#10b981,#059669);border-color:transparent;color:#fff;font-weight:500}.intake-field.primary-question label{font-size:1rem;color:#f59e0b;font-weight:600}.intake-field.primary-question textarea{border-color:#f59e0b4d}.intake-field.primary-question textarea:focus{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b26}.intake-footer{display:flex;justify-content:space-between;align-items:center;padding:20px 32px;border-top:1px solid rgba(255,255,255,.1);gap:12px}.intake-button{display:flex;align-items:center;gap:8px;padding:12px 24px;border-radius:10px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:none}.intake-button.primary{background:linear-gradient(135deg,#10b981,#059669);color:#fff;margin-left:auto}.intake-button.primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}.intake-button.secondary{background:transparent;border:1px solid rgba(255,255,255,.2);color:#9ca3af}.intake-button.secondary:hover{background:#ffffff0d;color:#fff}.intake-privacy{padding:16px 32px;text-align:center}.intake-privacy.prominent{background:linear-gradient(135deg,#10b9811a,#3b82f61a);border:1px solid rgba(16,185,129,.3);border-radius:12px;margin:0 24px 16px;padding:16px 20px}.intake-privacy .privacy-icon{font-size:1.5rem;margin-bottom:8px}.intake-privacy p{font-size:.85rem;color:#9ca3af;margin:0;line-height:1.5}.intake-privacy.prominent p{color:#d1d5db}.intake-privacy strong{color:#10b981}.skip-explanation{background:#3b82f61a;border:1px solid rgba(59,130,246,.2);border-radius:8px;padding:12px 16px;margin-bottom:16px}.skip-explanation p{font-size:.85rem;color:#93c5fd;margin:0;line-height:1.5}.skip-explanation strong{color:#60a5fa}@media (max-width: 600px){.intake-modal{max-height:100vh;border-radius:0}.intake-row{grid-template-columns:1fr}.intake-options{flex-direction:column}.option-button{width:100%;text-align:center}.intake-progress{gap:4px}.progress-step .step-label{display:none}}.intake-modal::-webkit-scrollbar{width:6px}.intake-modal::-webkit-scrollbar-track{background:transparent}.intake-modal::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.intake-modal::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.required{color:#f43f5e;margin-left:4px}.required-field{border-color:#f43f5e80!important}.validation-error{width:100%;padding:12px 16px;background:#f43f5e26;border:1px solid rgba(244,63,94,.3);border-radius:8px;color:#f87171;font-size:.9rem;text-align:center;margin-bottom:12px}.intake-buttons{display:flex;gap:12px;justify-content:flex-end;width:100%}.age-display{color:#10b981;font-size:.85rem;margin-top:4px;display:block}.terms-page{min-height:100vh;background:var(--bg-primary, #f8f9fa);padding:2rem 1rem}.terms-container{max-width:800px;margin:0 auto;background:var(--bg-secondary, #ffffff);padding:2rem 3rem;border-radius:12px;box-shadow:0 2px 12px #00000014}.terms-back-btn{display:flex;align-items:center;gap:.5rem;background:none;border:none;color:var(--accent-primary, #2d9596);font-size:1rem;cursor:pointer;padding:.5rem 0;margin-bottom:1.5rem;transition:opacity .2s}.terms-back-btn:hover{opacity:.7}.terms-container h1{color:var(--text-primary, #1a1a1a);font-size:2rem;margin-bottom:.5rem;font-weight:700}.terms-subtitle{color:var(--accent-primary, #2d9596);font-size:1.1rem;margin-bottom:.25rem}.terms-meta{color:var(--text-secondary, #666);font-size:.9rem;margin-bottom:1.5rem}.terms-divider{border:none;border-top:1px solid var(--border-color, #e0e0e0);margin:2rem 0}.terms-container section{margin-bottom:2rem}.terms-container h2{color:var(--text-primary, #1a1a1a);font-size:1.4rem;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--accent-primary, #2d9596)}.terms-container h3{color:var(--text-primary, #1a1a1a);font-size:1.1rem;margin:1.25rem 0 .75rem;font-weight:600}.terms-container p{color:var(--text-secondary, #444);line-height:1.7;margin-bottom:.75rem}.terms-container ul{margin-left:1.5rem;margin-bottom:1rem;color:var(--text-secondary, #444)}.terms-container li{line-height:1.6;margin-bottom:.4rem}.terms-warning{background:#fff8e1;border-left:4px solid #ffc107;padding:1rem 1.25rem;border-radius:0 8px 8px 0;margin:1rem 0}.terms-warning p,.terms-warning ul{color:#5d4e00}.terms-emergency{background:#ffebee;border-left:4px solid #f44336;padding:1rem 1.25rem;border-radius:0 8px 8px 0;margin:1rem 0}.terms-emergency p{color:#b71c1c}.terms-note{background:var(--bg-tertiary, #f5f5f5);padding:.75rem 1rem;border-radius:6px;font-size:.9rem;color:var(--text-secondary, #666)}.terms-footer{text-align:center;font-style:italic;color:var(--text-secondary, #666);margin-top:2rem}@media (prefers-color-scheme: dark){.terms-page{background:#121212}.terms-container{background:#1e1e1e;box-shadow:0 2px 12px #0000004d}.terms-container h1,.terms-container h2,.terms-container h3{color:#fff}.terms-container p,.terms-container li{color:#b0b0b0}.terms-warning{background:#332d00}.terms-warning p,.terms-warning ul{color:#ffc107}.terms-emergency{background:#2d0a0a}.terms-emergency p{color:#ff8a80}}@media (max-width: 600px){.terms-container{padding:1.5rem}.terms-container h1{font-size:1.5rem}.terms-container h2{font-size:1.2rem}}.language-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;margin:1.5rem 0;padding:1rem;background:var(--bg-tertiary, #f5f5f5);border-radius:8px}.language-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--bg-secondary, #ffffff);border-radius:6px;box-shadow:0 1px 3px #00000014}.lang-flag{font-size:1.5rem}.lang-name{font-size:.95rem;color:var(--text-primary)}.note{background:var(--color-primary-light, #e8f5f5);border-left:4px solid var(--color-primary, #2d9596);padding:1rem 1.5rem;margin:1.5rem 0;border-radius:0 8px 8px 0}@media (max-width: 600px){.language-grid{grid-template-columns:1fr}}.pricing-page{min-height:100vh;background:linear-gradient(180deg,var(--bg-primary, #0a0a0f) 0%,var(--bg-secondary, #1a1a2e) 100%);color:var(--text-primary, #fff)}.pricing-page-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid var(--border-color, #333)}.pricing-back-link{display:flex;align-items:center;gap:8px;color:var(--text-secondary, #aaa);text-decoration:none;font-size:.9rem;transition:color .2s}.pricing-back-link:hover{color:var(--accent-color, #4ecdc4)}.pricing-logo-img{height:32px;width:auto}.pricing-container{max-width:1200px;margin:0 auto;padding:40px 24px 60px}.pricing-hero{text-align:center;margin-bottom:48px}.pricing-hero h1{font-size:2.5rem;font-weight:700;margin:0 0 12px;background:linear-gradient(135deg,var(--text-primary, #fff) 0%,var(--accent-color, #4ecdc4) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.pricing-subtitle{font-size:1.1rem;color:var(--text-secondary, #aaa);margin:0 0 8px}.pricing-guarantee{color:var(--accent-color, #4ecdc4);font-size:.9rem;font-weight:500;margin:0 0 24px}.billing-toggle{display:inline-flex;background:var(--bg-tertiary, #252540);border-radius:10px;padding:4px;gap:4px}.toggle-option{padding:10px 24px;border:none;background:transparent;color:var(--text-secondary, #888);cursor:pointer;border-radius:8px;font-size:.9rem;font-weight:500;transition:all .2s;display:flex;align-items:center;gap:8px}.toggle-option:hover{color:var(--text-primary, #fff)}.toggle-option.active{background:var(--accent-color, #4ecdc4);color:var(--bg-primary, #0a0a0f)}.toggle-badge{background:var(--success-color, #4caf50);color:#fff;font-size:.7rem;padding:2px 8px;border-radius:10px;font-weight:600}.toggle-option.active .toggle-badge{background:var(--bg-primary, #0a0a0f);color:var(--success-color, #4caf50)}.pricing-error{background:#ff64641a;border:1px solid rgba(255,100,100,.3);color:#ff6b6b;padding:12px 20px;border-radius:8px;margin-bottom:24px;text-align:center;max-width:600px;margin-left:auto;margin-right:auto}.pricing-grid{display:grid;grid-template-columns:repeat(2,minmax(280px,380px));gap:24px;margin-bottom:48px;justify-content:center}@media (max-width: 800px){.pricing-grid{grid-template-columns:1fr;max-width:400px;margin-left:auto;margin-right:auto;gap:32px}.pricing-hero h1{font-size:1.8rem}.pricing-card.popular{transform:scale(1.02);box-shadow:0 4px 40px #4ecdc440}.pricing-card.popular .popular-badge{font-size:.75rem;padding:6px 20px;animation:pulse-badge 2s ease-in-out infinite}.pricing-card:not(.popular){opacity:.85;transform:scale(.98)}.pricing-card:not(.popular):hover{opacity:1;transform:scale(1)}}@keyframes pulse-badge{0%,to{box-shadow:0 0 #4ecdc466}50%{box-shadow:0 0 0 8px #4ecdc400}}.pricing-card{background:var(--bg-secondary, #1a1a2e);border:1px solid var(--border-color, #333);border-radius:16px;padding:24px;display:flex;flex-direction:column;position:relative;transition:transform .2s,border-color .2s,box-shadow .2s}.pricing-card:hover{transform:translateY(-4px);border-color:var(--tier-color, var(--border-color))}.pricing-card.popular{border-color:var(--accent-color, #4ecdc4);box-shadow:0 0 30px #4ecdc426}.pricing-card.current{border-color:var(--success-color, #4caf50)}.popular-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:var(--accent-color, #4ecdc4);color:var(--bg-primary, #0a0a0f);padding:4px 16px;border-radius:20px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.tier-icon{width:48px;height:48px;border-radius:12px;background:rgba(var(--tier-color-rgb, 78, 205, 196),.1);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:var(--tier-color, var(--accent-color))}.tier-name{font-size:1.25rem;font-weight:700;margin:0 0 4px;text-align:center;color:var(--text-primary, #fff)}.tier-tagline{font-size:.85rem;color:var(--text-secondary, #888);text-align:center;margin:0 0 20px;min-height:2.4em}.tier-price{text-align:center;margin-bottom:4px}.price-amount{font-size:2.25rem;font-weight:700;color:var(--text-primary, #fff)}.price-period{font-size:.9rem;color:var(--text-secondary, #888)}.savings-badge{text-align:center;background:#4caf5026;color:var(--success-color, #4caf50);padding:4px 12px;border-radius:20px;font-size:.75rem;font-weight:600;margin:0 auto 4px;width:fit-content}.yearly-total{text-align:center;color:var(--text-secondary, #888);font-size:.75rem;margin:0 0 4px}.trial-note{text-align:center;color:var(--accent-color, #4ecdc4);font-size:.8rem;margin:0 0 16px}.tier-features{list-style:none;padding:0;margin:0 0 20px;flex:1}.feature-item{display:flex;align-items:flex-start;gap:10px;padding:6px 0;font-size:.85rem;color:var(--text-secondary, #ccc)}.feature-item.included .feature-icon{color:var(--success-color, #4caf50);flex-shrink:0;margin-top:2px}.feature-item.excluded{opacity:.5}.feature-item.excluded .feature-icon{color:var(--text-muted, #666);flex-shrink:0;margin-top:2px}.tier-cta{padding:12px 20px;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;border:none;width:100%;margin-top:auto}.tier-cta:disabled{cursor:not-allowed;opacity:.6}.cta-free{background:transparent;color:var(--text-primary, #fff);border:1px solid var(--border-color, #444)}.cta-free:not(:disabled):hover{background:var(--bg-tertiary, #252540);border-color:var(--text-secondary, #888)}.cta-paid{background:var(--accent-color, #4ecdc4);color:var(--bg-primary, #0a0a0f)}.cta-paid:not(:disabled):hover{background:#3dbdb5;transform:translateY(-2px)}.enterprise-section{margin-bottom:48px}.enterprise-card{background:linear-gradient(135deg,var(--bg-tertiary, #252540) 0%,var(--bg-secondary, #1a1a2e) 100%);border:1px solid var(--border-color, #333);border-radius:16px;padding:32px;display:flex;justify-content:space-between;align-items:center;gap:32px}@media (max-width: 768px){.enterprise-card{flex-direction:column;text-align:center}}.enterprise-content{display:flex;gap:24px;align-items:flex-start}@media (max-width: 768px){.enterprise-content{flex-direction:column;align-items:center}}.enterprise-icon{width:64px;height:64px;border-radius:16px;background:#e74c3c1a;display:flex;align-items:center;justify-content:center;color:#e74c3c;flex-shrink:0}.enterprise-text h3{font-size:1.5rem;margin:0 0 8px}.enterprise-text p{color:var(--text-secondary, #aaa);margin:0 0 16px}.enterprise-features{display:flex;flex-wrap:wrap;gap:8px 24px;list-style:none;padding:0;margin:0}.enterprise-features li{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--text-secondary, #ccc)}.enterprise-features li svg{color:var(--success-color, #4caf50)}.enterprise-cta{background:transparent;border:2px solid #e74c3c;color:#e74c3c;padding:14px 32px;border-radius:8px;font-size:1rem;font-weight:600;text-decoration:none;transition:all .2s;white-space:nowrap}.enterprise-cta:hover{background:#e74c3c;color:#fff}.pricing-footer{text-align:center;padding-top:32px;border-top:1px solid var(--border-color, #333)}.pricing-payment{color:var(--text-muted, #666);font-size:.85rem;margin:0 0 4px}.pricing-tax-note{color:var(--text-muted, #666);font-size:.8rem;font-style:italic;margin:0 0 16px}.pricing-legal-links{display:flex;justify-content:center;gap:16px;margin-bottom:12px}.pricing-legal-links a{color:var(--text-secondary, #888);text-decoration:none;font-size:.85rem;transition:color .2s}.pricing-legal-links a:hover{color:var(--accent-color, #4ecdc4)}.pricing-legal-links span{color:var(--border-color, #444)}.pricing-disclosure{color:var(--text-muted, #666);font-size:.75rem;margin:0}.pricing-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000e6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;overflow-y:auto;padding:20px}.pricing-overlay .pricing-container{background:var(--bg-secondary, #1a1a2e);border:1px solid var(--border-color, #333);border-radius:16px;max-width:1200px;margin:20px auto;padding:32px;position:relative}.pricing-close{position:absolute;top:16px;right:16px;background:transparent;border:none;color:var(--text-secondary, #888);font-size:28px;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.pricing-close:hover{background:var(--bg-tertiary, #252540);color:var(--text-primary, #fff)}.profile-page{min-height:100vh;background:var(--bg-primary, #0a0a0f);color:var(--text-primary, #fff)}.profile-page.loading,.profile-page.not-authenticated{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color, #333);border-top-color:var(--accent-color, #4ecdc4);border-radius:50%;animation:spin 1s linear infinite}.profile-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid var(--border-color, #333);background:var(--bg-secondary, #1a1a2e);flex-wrap:wrap;gap:12px}@media (max-width: 768px){.profile-header{flex-direction:column;align-items:stretch;gap:12px;padding:12px 16px;overflow-x:hidden;max-width:100vw;box-sizing:border-box}.back-link{align-self:flex-start}.profile-actions{display:flex!important;justify-content:flex-end;width:100%;flex-wrap:wrap;gap:8px}.action-btn{padding:10px 16px;font-size:.9rem;min-width:100px}.action-btn.edit{display:flex!important;visibility:visible!important;background:#0d9488!important;color:#fff!important;border:none!important;padding:12px 20px!important;font-weight:600;box-shadow:0 2px 8px #0d94884d}.action-btn.edit:hover,.action-btn.edit:active{background:#0f766e!important}}@media (max-width: 480px){.profile-page{overflow-x:hidden;max-width:100vw;box-sizing:border-box}.profile-header{padding:10px 12px}.profile-actions{justify-content:center}.action-btn.edit{width:100%;justify-content:center;padding:14px 24px!important}.profile-content,.profile-section,.form-grid{max-width:100%;overflow-x:hidden;padding-left:12px;padding-right:12px;box-sizing:border-box}}.back-link{display:flex;align-items:center;gap:8px;color:var(--text-secondary, #aaa);text-decoration:none;font-size:.9rem;transition:color .2s}.back-link:hover{color:var(--accent-color, #4ecdc4)}.profile-actions{display:flex;gap:12px}.action-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.action-btn.edit{background:var(--bg-tertiary, #252540);color:var(--text-primary, #fff);border:1px solid var(--border-color, #444)}.action-btn.edit:hover{background:var(--bg-secondary, #1a1a2e);border-color:var(--accent-color, #4ecdc4)}.action-btn.save{background:var(--accent-color, #4ecdc4);color:var(--bg-primary, #0a0a0f)}.action-btn.save:hover{background:#3dbdb5}.action-btn.save:disabled{opacity:.6;cursor:not-allowed}.action-btn.cancel{background:transparent;color:var(--text-secondary, #888)}.action-btn.cancel:hover{color:var(--text-primary, #fff)}.save-message{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;margin:16px 24px 0;border-radius:8px;font-size:.9rem}.save-message.success{background:#4caf501a;border:1px solid rgba(76,175,80,.3);color:#4caf50}.save-message.error{background:#ff64641a;border:1px solid rgba(255,100,100,.3);color:#ff6b6b}.profile-content{max-width:800px;margin:0 auto;padding:24px}.profile-card{background:var(--bg-secondary, #1a1a2e);border:1px solid var(--border-color, #333);border-radius:12px;padding:24px;margin-bottom:20px}.account-header{display:flex;align-items:center;gap:16px}.account-avatar{width:64px;height:64px;border-radius:50%;overflow:hidden;background:var(--bg-tertiary, #252540);display:flex;align-items:center;justify-content:center;color:var(--text-secondary, #888)}.account-avatar img{width:100%;height:100%;object-fit:cover}.account-info h2{font-size:1.25rem;margin:0 0 4px}.account-email{display:flex;align-items:center;gap:6px;color:var(--text-secondary, #888);font-size:.9rem}.verified-badge{display:inline-flex;align-items:center;gap:4px;background:#4caf501a;color:#4caf50;padding:2px 8px;border-radius:12px;font-size:.75rem;margin-left:8px}.account-edit-name{margin-top:16px;padding-top:16px;border-top:1px solid var(--border-color, #333)}.account-edit-name label{display:block;font-size:.85rem;color:var(--text-secondary, #888);margin-bottom:8px}.account-edit-name input{width:100%;padding:10px 14px;background:var(--bg-tertiary, #252540);border:1px solid var(--border-color, #444);border-radius:8px;color:var(--text-primary, #fff);font-size:.95rem}.account-edit-name input:focus{outline:none;border-color:var(--accent-color, #4ecdc4)}.section-tabs{display:flex;gap:8px;margin-bottom:20px;overflow-x:auto;padding:4px 0}.section-tab{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--bg-secondary, #1a1a2e);border:1px solid var(--border-color, #333);border-radius:8px;color:var(--text-secondary, #888);font-size:.9rem;cursor:pointer;transition:all .2s;white-space:nowrap}.section-tab:hover{color:var(--text-primary, #fff);border-color:var(--tab-color, var(--border-color))}.section-tab.active{background:var(--bg-tertiary, #252540);color:var(--text-primary, #fff);border-color:var(--tab-color, var(--accent-color))}.section-tab.active svg{color:var(--tab-color, var(--accent-color))}.section-card{min-height:300px}.section-content h3{display:flex;align-items:center;gap:10px;font-size:1.1rem;margin:0 0 8px}.section-description{color:var(--text-secondary, #888);font-size:.9rem;margin:0 0 24px}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}@media (max-width: 600px){.form-grid{grid-template-columns:1fr}}.form-field{display:flex;flex-direction:column;gap:8px}.form-field.full-width{grid-column:1 / -1}.form-field label{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--text-secondary, #888)}.form-field input,.form-field textarea,.form-field select{width:100%;padding:10px 14px;background:var(--bg-tertiary, #252540);border:1px solid var(--border-color, #444);border-radius:8px;color:var(--text-primary, #fff);font-size:.95rem;font-family:inherit}.form-field input:focus,.form-field textarea:focus,.form-field select:focus{outline:none;border-color:var(--accent-color, #4ecdc4)}.form-field textarea{resize:vertical;min-height:80px}.form-field select{cursor:pointer}.field-value{color:var(--text-primary, #fff);padding:10px 0;font-size:.95rem}.privacy-card{background:rgba(var(--accent-color-rgb, 78, 205, 196),.05);border-color:rgba(var(--accent-color-rgb, 78, 205, 196),.2)}.privacy-card h3{display:flex;align-items:center;gap:8px;font-size:1rem;margin:0 0 12px;color:var(--accent-color, #4ecdc4)}.privacy-card p{color:var(--text-secondary, #888);font-size:.85rem;line-height:1.6;margin:0 0 12px}.privacy-links{display:flex;gap:12px;font-size:.85rem}.privacy-links a{color:var(--accent-color, #4ecdc4);text-decoration:none}.privacy-links a:hover{text-decoration:underline}.privacy-links span{color:var(--border-color, #444)}.caregiving-field{background:#3b82f60d;border-left:3px solid var(--accent-color, #3b82f6);padding:16px;border-radius:8px;margin-top:8px}.caregiving-field label{color:var(--accent-color, #3b82f6)!important;font-weight:600}.field-hint{font-size:.75rem;color:var(--text-secondary, #888);margin-top:8px;font-style:italic;line-height:1.5}.subscription-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%);padding:20px}.subscription-content{background:var(--bg-secondary);border-radius:16px;padding:48px;max-width:500px;width:100%;text-align:center;box-shadow:0 20px 60px #0000004d}.subscription-content.success .success-icon{color:#4ecdc4;margin-bottom:24px;animation:scaleIn .5s ease-out}.subscription-content h1{color:var(--text-primary);font-size:2rem;margin-bottom:16px;font-weight:700}.success-message,.canceled-message{color:var(--text-secondary);font-size:1.1rem;margin-bottom:32px;line-height:1.6}.trial-info{background:#4ecdc41a;border:1px solid rgba(78,205,196,.3);border-radius:12px;padding:16px;margin-bottom:32px}.trial-info p{color:var(--text-primary);margin:0}.features-unlocked,.free-tier-info{text-align:left;margin-bottom:32px}.features-unlocked h3,.free-tier-info h3{color:var(--text-primary);font-size:1rem;margin-bottom:12px;font-weight:600}.features-unlocked ul,.free-tier-info ul{list-style:none;padding:0;margin:0}.features-unlocked li,.free-tier-info li{color:var(--text-secondary);padding:8px 0;font-size:.95rem}.features-unlocked li{color:#4ecdc4}.subscription-content.canceled .canceled-icon{color:#ef4444;margin-bottom:24px;animation:scaleIn .5s ease-out}.action-buttons{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.primary-btn,.secondary-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.primary-btn{background:linear-gradient(135deg,#4ecdc4,#3ab0b7);color:var(--bg-primary);border:none}.primary-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #4ecdc44d}.secondary-btn{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color)}.secondary-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.help-text{color:var(--text-muted);font-size:.875rem}.help-text a{color:#4ecdc4;text-decoration:none}.help-text a:hover{text-decoration:underline}@media (max-width: 480px){.subscription-content{padding:32px 24px}.subscription-content h1{font-size:1.5rem}.success-message,.canceled-message{font-size:1rem}}.subscription-content .spinner{animation:spin 1s linear infinite;color:#4ecdc4;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}:root{color-scheme:light dark;--color-primary: #0d9488;--color-primary-dark: #0f766e;--color-primary-light: #14b8a6;--color-secondary: #06b6d4;--color-accent: #0891b2;--color-success: #059669;--color-warning: #d97706;--color-error: #dc2626;--bg-primary: #fafaf9;--bg-secondary: #ffffff;--bg-tertiary: #f5f5f4;--bg-hover: #e7e5e4;--bg-input: #ffffff;--bg-gradient: linear-gradient(135deg, var(--color-primary) 0%, var(--color-secondary) 100%);--text-primary: #1c1917;--text-secondary: #44403c;--text-muted: #78716c;--text-light: #a8a29e;--text-inverse: #ffffff;--border-color: #e7e5e4;--border-color-strong: #d6d3d1;--border-color-light: #f5f5f4;--border-radius: 16px;--border-radius-sm: 12px;--border-radius-lg: 24px;--border-radius-xl: 32px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .08), 0 2px 4px -1px rgba(0, 0, 0, .04);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -2px rgba(0, 0, 0, .04);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .08), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .12);--shadow-glow: 0 0 40px rgba(13, 148, 136, .15);--spacing-xs: .5rem;--spacing-sm: .75rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--spacing-4xl: 6rem;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", sans-serif;--font-family-display: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-family-mono: "JetBrains Mono", "Fira Code", "Courier New", monospace;--font-size-base: clamp(.9375rem, .875rem + .25vw, 1rem);--font-size-lg: clamp(1.0625rem, 1rem + .25vw, 1.125rem);--font-size-xl: clamp(1.25rem, 1rem + .5vw, 1.5rem);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--transition-spring: .5s linear(0, .006, .025 2.8%, .101 6.1%, .539 18.9%, .721 25.3%, .849 31.5%, .937 38.1%, .968 41.8%, .991 45.7%, 1.006 50.1%, 1.015 55%, 1.017 59.7%, 1.01 67.7%, 1.001 82.2%, 1)}@supports (color: oklch(65% .14 175)){:root{--color-primary: oklch(52% .14 175);--color-primary-dark: oklch(45% .12 175);--color-primary-light: oklch(62% .15 175);--color-secondary: oklch(65% .12 195);--color-accent: oklch(55% .13 195);--color-success: oklch(50% .14 155);--shadow-glow: 0 0 40px oklch(52% .14 175 / .2)}}[data-theme=dark]{--color-primary: #14b8a6;--color-primary-dark: #0d9488;--color-primary-light: #2dd4bf;--color-secondary: #22d3ee;--color-accent: #06b6d4;--color-success: #10b981;--color-warning: #f59e0b;--color-error: #ef4444;--bg-primary: #0f0f0f;--bg-secondary: #1a1a1a;--bg-tertiary: #262626;--bg-hover: #333333;--bg-input: #1f1f1f;--bg-gradient: linear-gradient(135deg, #0f766e 0%, #0891b2 100%);--text-primary: #f5f5f5;--text-secondary: #d4d4d4;--text-muted: #a3a3a3;--text-light: #737373;--text-inverse: #0f0f0f;--border-color: #333333;--border-color-strong: #404040;--border-color-light: #262626;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -1px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .4), 0 4px 6px -2px rgba(0, 0, 0, .3);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .4), 0 10px 10px -5px rgba(0, 0, 0, .3);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .5);--shadow-glow: 0 0 40px rgba(20, 184, 166, .2)}*{margin:0;padding:0;box-sizing:border-box}html{overflow-x:hidden;max-width:100vw}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);overflow-x:hidden;max-width:100vw;position:relative;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"liga" 1,"calt" 1;text-rendering:optimizeLegibility}#root{min-height:100vh;display:flex;flex-direction:column}.app{display:flex;flex-direction:column;min-height:100vh;background:var(--bg-primary)}.app-main{flex:1;display:flex;overflow-x:hidden;overflow-y:auto;position:relative}.app-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:var(--spacing-lg) var(--spacing-2xl);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:100;flex-shrink:0}.header-content{max-width:1600px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.header-left{display:flex;align-items:center;gap:var(--spacing-lg)}.logo{display:flex;align-items:center;gap:var(--spacing-sm);font-weight:600;transition:all var(--transition-base)}.logo:hover{opacity:.8;transform:translateY(-1px)}.logo:active{transform:translateY(0)}.logo-icon{width:40px;height:40px;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(58,176,183,.3))}.logo-text{font-size:1.5rem;font-weight:600;color:var(--text-primary);letter-spacing:-.02em}.logo-separator{color:var(--color-primary);margin:0 .25rem}.header-subtitle{font-size:.875rem;color:var(--text-muted);font-weight:400;letter-spacing:.01em}.header-right{display:flex;align-items:center;gap:var(--spacing-md);position:relative}.role-selector{position:relative}.role-button{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-base)}.role-button:hover{background:var(--bg-hover);border-color:var(--border-color-strong);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.role-icon{font-size:1.125rem}.role-arrow{font-size:.75rem;color:var(--text-muted);transition:transform var(--transition-base)}.role-button:hover .role-arrow{transform:translateY(2px)}.role-menu{position:absolute;top:calc(100% + var(--spacing-xs));right:0;min-width:200px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);box-shadow:var(--shadow-lg);padding:var(--spacing-xs);z-index:1000;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.role-menu-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border:none;background:transparent;border-radius:var(--border-radius-sm);color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);width:100%;text-align:left}.role-menu-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.role-menu-item.active{background:var(--bg-tertiary);color:var(--color-primary)}.role-menu-item .check{margin-left:auto;color:var(--color-primary);font-weight:600}.header-icon-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-base)}.header-icon-button:hover{background:var(--bg-tertiary);border-color:var(--border-color-strong);color:var(--text-primary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.header-menu{position:absolute;top:calc(100% + var(--spacing-xs));right:0;min-width:220px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);box-shadow:var(--shadow-lg);padding:var(--spacing-xs);z-index:1000;animation:slideDown .2s ease-out}.menu-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border:none;background:transparent;border-radius:var(--border-radius-sm);color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);width:100%;text-align:left}.menu-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.menu-item.about-asha{color:var(--color-primary)}.menu-item.about-asha:hover{background:#0d948814}.menu-item.danger{color:var(--color-error)}.menu-item.danger:hover{background:#dc262614}.chat-interface{flex:1;display:flex;flex-direction:column;min-height:0;max-width:1200px;margin:0 auto;width:100%}.chat-messages{flex:1;overflow-y:auto;padding:var(--spacing-2xl);display:flex;flex-direction:column;gap:var(--spacing-xl)}.chat-messages:has(.chat-welcome){overflow-y:auto}.chat-messages::-webkit-scrollbar{width:8px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background:var(--border-color-strong);border-radius:4px}.chat-messages::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.chat-welcome{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;min-height:auto;padding:var(--spacing-2xl) var(--spacing-2xl) var(--spacing-3xl);padding-top:var(--spacing-xl);gap:var(--spacing-xl)}.welcome-hero{text-align:center;max-width:700px;animation:fadeInUp .6s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.welcome-logo-container{display:flex;justify-content:center;margin-bottom:var(--spacing-xl)}.welcome-logo{width:120px;height:120px;object-fit:contain;filter:drop-shadow(0 4px 16px rgba(58,176,183,.25));animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.welcome-title{display:flex;flex-direction:column;align-items:center;gap:.25rem;margin-bottom:var(--spacing-md);line-height:1.1}.welcome-greeting{display:block;font-size:2.25rem;font-weight:500;color:var(--text-primary);letter-spacing:-.01em}.welcome-name{display:block;font-size:3rem;font-weight:700;color:var(--text-primary);letter-spacing:-.03em}.welcome-subtitle{font-size:1.5rem;font-weight:400;color:var(--color-primary);margin-bottom:var(--spacing-lg);letter-spacing:.01em}.welcome-description{font-size:1.125rem;color:var(--text-secondary);line-height:1.7;max-width:600px;margin:0 auto;text-align:center}.welcome-mission{font-size:1.25rem;color:var(--text-primary);font-weight:500;margin-bottom:var(--spacing-md);letter-spacing:.02em}.welcome-mission .text-teal{color:var(--color-primary);font-weight:600}.welcome-mission-detail{font-size:1.4rem;color:var(--text-primary);font-weight:600;line-height:1.5;max-width:520px;margin:var(--spacing-md) auto;letter-spacing:.01em;background:linear-gradient(135deg,var(--color-primary) 0%,#0d9488 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.welcome-languages,.welcome-languages-link{font-size:.8rem;color:var(--text-muted);margin-top:var(--spacing-sm);opacity:.8;letter-spacing:.3px;text-decoration:none;display:inline-flex;align-items:center;gap:5px;white-space:nowrap;transition:color .2s,opacity .2s}.welcome-languages-link:hover{color:var(--color-primary);opacity:1;text-decoration:underline}.language-globe-icon{color:var(--color-primary, #4ecdc4);stroke:var(--color-primary, #4ecdc4);flex-shrink:0}.welcome-input-section{width:100%;max-inline-size:800px;display:flex;flex-direction:column;gap:var(--spacing-2xl);animation:fadeInUp .6s ease-out .2s backwards;container-type:inline-size;container-name:input-section}.welcome-input-form{width:100%}.welcome-input-wrapper{position:relative;display:flex;align-items:flex-end;gap:var(--spacing-sm);padding-block:12px;padding-inline:16px;background:color-mix(in srgb,var(--bg-secondary),transparent 5%);backdrop-filter:blur(12px) saturate(180%);-webkit-backdrop-filter:blur(12px) saturate(180%);border:2px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-xl);transition:border-color var(--transition-spring),box-shadow var(--transition-spring),transform var(--transition-spring);min-block-size:56px}.welcome-input-wrapper:focus-within{border-color:var(--color-primary);box-shadow:var(--shadow-xl),0 0 0 4px color-mix(in srgb,var(--color-primary),transparent 85%);transform:translateY(-1px)}.welcome-input-wrapper .file-upload-container{order:0;flex-shrink:0}.welcome-input-wrapper .welcome-chat-input{order:1;flex:1}.welcome-input-wrapper .welcome-send-button,.welcome-input-wrapper .welcome-stop-button,.welcome-input-wrapper .voice-input-button{order:2;flex-shrink:0}.welcome-chat-input{flex:1;border:none;background:transparent;color:var(--text-primary);font-size:clamp(1rem,.9rem + .25vw,1.0625rem);font-family:var(--font-family);line-height:1.6;resize:none;outline:none;padding:12px 4px;min-height:24px;max-height:200px;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;-webkit-appearance:none;-moz-appearance:none;appearance:none}.welcome-chat-input::placeholder{color:var(--text-muted);font-weight:400}@keyframes blink-cursor{0%,50%{opacity:1}51%,to{opacity:0}}.welcome-chat-input:placeholder-shown:after{content:"|";animation:blink-cursor 1s step-end infinite;color:var(--color-primary);font-weight:400}.welcome-send-button{display:flex;align-items:center;justify-content:center;inline-size:40px;block-size:40px;background:var(--bg-gradient);border:none;border-radius:50%;color:var(--text-inverse);cursor:pointer;transition:transform var(--transition-spring),box-shadow var(--transition-spring);flex-shrink:0}.welcome-send-button:hover:not(:disabled){transform:translateY(-2px) scale(1.05);box-shadow:var(--shadow-lg),var(--shadow-glow)}.welcome-send-button:active:not(:disabled){transform:translateY(0) scale(.98)}.welcome-send-button:disabled{opacity:.4;cursor:not-allowed}.welcome-voice-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--bg-gradient);border:none;border-radius:var(--border-radius-sm);color:var(--text-inverse);cursor:pointer;transition:all var(--transition-base);flex-shrink:0}.welcome-voice-button:hover:not(:disabled){transform:translateY(-2px) scale(1.05);box-shadow:var(--shadow-lg)}.welcome-voice-button:active:not(:disabled){transform:translateY(0) scale(.98)}.welcome-voice-button:disabled{opacity:.4;cursor:not-allowed}.welcome-stop-button{display:flex;align-items:center;justify-content:center;width:56px;height:56px;background:linear-gradient(135deg,#dc2626,#991b1b);border:none;border-radius:var(--border-radius-sm);color:#fff;cursor:pointer;transition:all var(--transition-base);flex-shrink:0;animation:pulse-stop 1.5s ease-in-out infinite}.welcome-stop-button:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 4px 12px #dc262666}.welcome-stop-button:active{transform:translateY(0) scale(.98)}@container input-section (max-width: 500px){.welcome-input-wrapper{padding-inline:8px;gap:4px}.welcome-send-button{inline-size:36px;block-size:36px}}@container input-section (max-width: 400px){.welcome-chat-input{font-size:.9375rem}}.welcome-examples{display:flex;flex-direction:column;gap:var(--spacing-lg);animation:fadeInUp .6s ease-out .3s backwards}.examples-label{font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;text-align:center}.examples-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md)}.example-card{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-lg);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);text-align:left;cursor:pointer;transition:all var(--transition-base);min-height:120px}.example-card:hover{border-color:var(--color-primary);transform:translateY(-4px);box-shadow:var(--shadow-lg);background:var(--bg-secondary)}.example-category{font-size:.75rem;font-weight:600;color:var(--color-primary);text-transform:uppercase;letter-spacing:.05em}.example-question{font-size:.875rem;font-weight:400;color:var(--text-secondary);line-height:1.5}.welcome-features{display:flex;justify-content:center;align-items:center;gap:var(--spacing-lg);flex-wrap:wrap;animation:fadeInUp .6s ease-out .4s backwards}.feature-badge{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius);font-size:.875rem;font-weight:500;color:var(--text-secondary);transition:all var(--transition-base)}.feature-badge:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.welcome-disclaimer{text-align:center;font-size:.8125rem;color:var(--text-muted);line-height:1.6;padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-secondary);border-radius:var(--border-radius-sm);border:1px solid var(--border-color-light);animation:fadeInUp .6s ease-out .5s backwards;margin:0 auto;max-width:600px}.landing-disclaimer{text-align:center;font-size:.8125rem;color:var(--text-muted);line-height:1.6;padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-secondary);border-radius:var(--border-radius-sm);border:1px solid var(--border-color-light);margin:0 auto;max-width:600px}.message-bubble{display:flex;gap:var(--spacing-md);animation:slideInMessage .3s ease-out;max-width:100%}@keyframes slideInMessage{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message-bubble.user{flex-direction:row-reverse}.message-avatar{width:48px;height:48px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.message-avatar .avatar-logo{width:100%;height:100%;object-fit:contain}.message-content{flex:1;max-width:calc(100% - 64px);display:flex;flex-direction:column;gap:var(--spacing-sm)}.message-header{display:flex;align-items:center;justify-content:flex-end;padding:var(--spacing-xs) 0;margin-bottom:var(--spacing-xs)}.message-bubble.user .message-content{align-items:flex-end}.message-text{padding:var(--spacing-lg) var(--spacing-xl);background:var(--bg-gradient);color:var(--text-inverse);border-radius:20px;font-size:.9375rem;line-height:1.6;word-wrap:break-word;overflow-wrap:break-word;box-shadow:var(--shadow-md)}.message-markdown{padding:var(--spacing-lg) var(--spacing-xl);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;font-size:.9375rem;line-height:1.7;color:var(--text-primary);word-wrap:break-word;overflow-wrap:break-word;box-shadow:var(--shadow-sm)}.message-bubble.error .message-markdown{border-color:var(--color-error);background:#dc26260d}.error-retry-section{display:flex;justify-content:center;margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--border-secondary)}.retry-button{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:.9rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.retry-button:hover{background:var(--color-primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.retry-button svg{width:16px;height:16px}.streaming-status{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);margin-bottom:var(--spacing-sm);background:linear-gradient(135deg,#00808014,#00808008);border-left:3px solid var(--color-primary);border-radius:0 var(--radius-md) var(--radius-md) 0;font-size:.9rem;font-weight:500;color:var(--color-primary);animation:statusPulse 2s ease-in-out infinite}@keyframes statusPulse{0%,to{opacity:.85}50%{opacity:1}}.streaming-status svg{color:var(--color-primary);animation:spin 1.2s linear infinite}.streaming-status span{background:linear-gradient(90deg,var(--color-primary),var(--text-primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.message-markdown h1,.message-markdown h2,.message-markdown h3{color:var(--text-primary);font-weight:600;margin-top:var(--spacing-lg);margin-bottom:var(--spacing-md);line-height:1.3}.message-markdown h1{font-size:1.5rem}.message-markdown h2{font-size:1.25rem}.message-markdown h3{font-size:1.125rem}.message-markdown p{margin-bottom:var(--spacing-md)}.message-markdown ul,.message-markdown ol{margin-bottom:var(--spacing-md);padding-left:var(--spacing-xl)}.message-markdown li{margin-bottom:var(--spacing-xs)}.message-markdown code{background:var(--bg-tertiary);padding:.125rem .375rem;border-radius:4px;font-family:var(--font-family-mono);font-size:.875em;color:var(--color-primary)}.message-markdown pre{background:var(--bg-tertiary);padding:var(--spacing-md);border-radius:var(--border-radius-sm);overflow-x:auto;margin-bottom:var(--spacing-md);border:1px solid var(--border-color)}.message-markdown pre code{background:transparent;padding:0;color:var(--text-primary)}.message-markdown a{color:var(--color-primary);text-decoration:none;font-weight:500;transition:all var(--transition-fast)}.message-markdown a:hover{text-decoration:underline;color:var(--color-primary-dark)}.message-markdown p a[href*="pubmed.ncbi.nlm.nih.gov"],.message-markdown li a[href*="pubmed.ncbi.nlm.nih.gov"]{color:var(--color-primary);text-decoration:none;font-weight:600;font-size:.85em;vertical-align:super;padding:0 .125rem;transition:all var(--transition-fast)}.message-markdown p a[href*="pubmed.ncbi.nlm.nih.gov"]:hover,.message-markdown li a[href*="pubmed.ncbi.nlm.nih.gov"]:hover{color:var(--color-primary-dark);text-decoration:none;background:#0d94881a;border-radius:3px}.message-markdown h2+p a[href*="pubmed.ncbi.nlm.nih.gov"],.message-markdown a[href*="pubmed.ncbi.nlm.nih.gov"]:only-child{display:block;font-size:1em;vertical-align:baseline;font-weight:500;padding:.25rem 0;margin-bottom:.25rem}.message-markdown a[href*="pubmed.ncbi.nlm.nih.gov"]:only-child:hover{background:#0d94880d;border-radius:4px;padding-left:.5rem}.compact-sources-section{margin-top:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm)}.sources-header{font-size:.875rem;font-weight:600;color:var(--text-secondary);margin:0 0 var(--spacing-xs) 0;display:flex;align-items:center;gap:.5rem}.associations-disclaimer{font-size:.85rem;color:var(--text-primary);background:rgba(var(--accent-rgb, 0, 150, 136),.15);border-left:4px solid var(--accent);padding:.75rem 1rem;margin:.75rem 0;border-radius:0 8px 8px 0;line-height:1.5;font-weight:500}.sources-list-compact{list-style:decimal;margin:0;padding-left:var(--spacing-lg);font-size:.8125rem}.source-item-compact{margin-bottom:.375rem;line-height:1.4;color:var(--text-secondary)}.source-item-compact a{color:var(--color-primary);text-decoration:none;transition:color .2s}.source-item-compact a:hover{color:var(--color-primary-dark);text-decoration:underline}.show-more-sources-btn{margin-top:var(--spacing-sm);padding:.375rem .75rem;font-size:.8125rem;color:var(--color-primary);background:transparent;border:1px solid var(--color-primary);border-radius:var(--border-radius-sm);cursor:pointer;transition:all .2s}.show-more-sources-btn:hover{background:var(--color-primary);color:#fff}.message-markdown blockquote{border-left:3px solid var(--color-primary);padding-left:var(--spacing-md);margin:var(--spacing-md) 0;color:var(--text-secondary);font-style:italic}.message-markdown table{width:100%;border-collapse:collapse;margin-bottom:var(--spacing-md);overflow-x:auto;display:block}.message-markdown th,.message-markdown td{padding:var(--spacing-sm) var(--spacing-md);text-align:left;border:1px solid var(--border-color)}.message-markdown th{background:var(--bg-tertiary);font-weight:600;color:var(--text-primary)}.message-timestamp{font-size:.75rem;color:var(--text-light);padding:0 var(--spacing-sm)}.loading-indicator{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-lg) var(--spacing-xl);color:var(--text-secondary);font-size:.9375rem}.spinner{animation:spin 1s linear infinite;color:var(--color-primary)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.message-metadata{margin-top:var(--spacing-sm);padding:0 var(--spacing-sm)}.metadata-toggle{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.metadata-toggle:hover{background:var(--bg-hover);border-color:var(--border-color-strong);color:var(--text-primary)}.metadata-content{margin-top:var(--spacing-sm);padding:var(--spacing-lg);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);display:flex;flex-direction:column;gap:var(--spacing-lg)}.metadata-section{display:flex;flex-direction:column;gap:var(--spacing-sm)}.metadata-section h4{font-size:.875rem;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em}.metadata-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md)}.metadata-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.metadata-item .label{font-size:.75rem;color:var(--text-muted);font-weight:500}.metadata-item .value{font-size:.875rem;color:var(--text-primary);font-weight:600}.metadata-item .value.success{color:var(--color-success)}.metadata-item .value.warning{color:var(--color-warning)}.evidence-list{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.evidence-link{padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--color-primary);font-size:.8125rem;font-weight:500;text-decoration:none;transition:all var(--transition-fast)}.evidence-link:hover{background:var(--color-primary);color:var(--text-inverse);border-color:var(--color-primary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.metadata-section.emergency{display:flex;flex-direction:row;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:#dc262614;border:1px solid var(--color-error);border-radius:var(--border-radius-sm);color:var(--color-error);font-weight:600}.thinking-loading{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-xl);color:var(--text-secondary)}.thinking-interpretation{padding:var(--spacing-lg);background:var(--bg-tertiary);border-radius:var(--border-radius-sm);font-size:.9375rem;line-height:1.7;color:var(--text-primary);margin-bottom:var(--spacing-md)}.thinking-interpretation h3{font-size:1rem;font-weight:600;margin-top:var(--spacing-md);margin-bottom:var(--spacing-sm);color:var(--text-primary)}.thinking-interpretation h3:first-child{margin-top:0}.thinking-interpretation p{margin-bottom:var(--spacing-md)}.thinking-interpretation ul,.thinking-interpretation ol{margin-left:var(--spacing-lg);margin-bottom:var(--spacing-md)}.thinking-interpretation li{margin-bottom:var(--spacing-xs)}.thinking-interpretation strong{font-weight:600;color:var(--text-primary)}.thinking-pathway{display:flex;flex-direction:column;gap:var(--spacing-sm)}.pathway-step{display:flex;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-tertiary);border-radius:var(--border-radius-sm);border-left:3px solid var(--color-primary);transition:all var(--transition-fast)}.pathway-step:hover{background:var(--bg-hover);transform:translate(2px)}.step-number{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--color-primary);color:var(--text-inverse);border-radius:50%;font-size:.75rem;font-weight:600;flex-shrink:0}.step-content{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs)}.step-action{font-size:.875rem;font-weight:500;color:var(--text-primary)}.step-layer{font-size:.75rem;color:var(--text-muted);font-family:var(--font-family-mono)}.thinking-footer{padding-top:var(--spacing-md);margin-top:var(--spacing-md);border-top:1px solid var(--border-color);text-align:center}.transparency-score{font-size:.8125rem;color:var(--text-muted);font-weight:500}.thinking-error{padding:var(--spacing-lg);text-align:center;color:var(--text-muted)}.about-intro{padding:var(--spacing-lg);background:var(--bg-tertiary);border-radius:var(--border-radius-sm);margin-bottom:var(--spacing-lg)}.about-intro p{font-size:1rem;line-height:1.7;color:var(--text-secondary);margin:0}.capabilities-accordion{display:flex;flex-direction:column;gap:var(--spacing-sm)}.capability-accordion-item{border:1px solid var(--border-color);border-radius:var(--border-radius-sm);overflow:hidden;transition:all var(--transition-base)}.capability-accordion-item:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.capability-accordion-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-tertiary);border:none;cursor:pointer;transition:all var(--transition-fast);text-align:left}.capability-accordion-header:hover{background:var(--bg-hover)}.capability-title{font-size:.9375rem;font-weight:600;color:var(--text-primary)}.capability-accordion-content{padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-secondary);border-top:1px solid var(--border-color);animation:slideDown .2s ease-out}.capability-accordion-content p{margin:0;font-size:.875rem;line-height:1.6;color:var(--text-secondary)}.how-it-works{display:flex;flex-direction:column;gap:var(--spacing-md)}.work-step{display:flex;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-tertiary);border-radius:var(--border-radius-sm)}.work-step-number{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--color-primary);color:var(--text-inverse);border-radius:50%;font-size:1rem;font-weight:700;flex-shrink:0}.work-step-content{flex:1}.work-step-content h4{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-xs) 0}.work-step-content p{font-size:.875rem;color:var(--text-secondary);margin:0;line-height:1.5}.safety-reminders{display:flex;flex-direction:column;gap:var(--spacing-md)}.safety-reminder{padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-tertiary);border-radius:var(--border-radius-sm);border-left:3px solid var(--color-primary)}.reminder-title{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.safety-reminder p{font-size:.875rem;color:var(--text-secondary);margin:0;line-height:1.6}.chat-input-form{padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-secondary);border-top:1px solid var(--border-color);box-shadow:var(--shadow-sm);position:sticky;bottom:0;z-index:10;flex-shrink:0;max-height:120px}.input-container{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:var(--spacing-sm)}.input-wrapper,.chat-input-wrapper{display:flex;align-items:flex-end;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-input);border:2px solid var(--border-color);border-radius:var(--border-radius-sm);transition:all var(--transition-base)}.input-wrapper:focus-within,.chat-input-wrapper:focus-within{box-shadow:var(--shadow-sm)}.chat-input{flex:1;border:none;background:transparent;color:var(--text-primary);font-size:1rem;font-family:var(--font-family);line-height:1.6;resize:vertical;outline:none;max-height:400px;min-height:44px;padding:var(--spacing-sm);border-radius:var(--border-radius-sm);overflow-y:auto}.chat-input::placeholder{color:var(--text-muted)}.chat-input:disabled{opacity:.5;cursor:not-allowed}.send-button{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--bg-gradient);border:none;border-radius:var(--border-radius-sm);color:var(--text-inverse);cursor:pointer;transition:all var(--transition-base);flex-shrink:0}.send-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-md)}.send-button:active:not(:disabled){transform:translateY(0) scale(.95)}.send-button:disabled{opacity:.4;cursor:not-allowed}.stop-button{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:#0d94881a;border:1px solid var(--color-primary);border-radius:var(--border-radius-sm);color:var(--color-primary);cursor:pointer;transition:all var(--transition-base);flex-shrink:0;animation:pulse-stop 1.5s ease-in-out infinite}@keyframes pulse-stop{0%,to{box-shadow:0 0 #dc262666}50%{box-shadow:0 0 0 8px #dc262600}}.stop-button:hover{background:#0d948833;border-color:var(--color-primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #0d948833}.stop-button:active{transform:translateY(0) scale(.98);background:#0d948840}.input-hints{display:flex;justify-content:space-between;align-items:center;padding:.25rem .5rem 0;gap:1rem}.hint{font-size:.7rem;color:var(--text-light);font-weight:400;opacity:.6}.medical-watermark{font-size:.65rem;color:var(--text-light);font-weight:400;opacity:.4;font-style:italic;white-space:nowrap}.message-actions{display:flex;align-items:center;gap:.25rem;margin-top:.5rem;opacity:0;transition:opacity .2s}.message-bubble:hover .message-actions{opacity:1}.action-button{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:transparent;border:1px solid var(--border-color);border-radius:6px;color:var(--text-muted);cursor:pointer;transition:all .15s}.action-button:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-color-strong)}.action-button.copied{color:var(--color-success);border-color:var(--color-success)}.action-button.active{color:var(--color-primary);border-color:var(--color-primary);background:#0d94881a}.action-button.active.negative{color:var(--color-error);border-color:var(--color-error);background:#dc26261a}.header-user-info{display:flex;align-items:center;gap:var(--spacing-md)}.theme-toggle-button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:50%;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-base)}.theme-toggle-button:hover{background:var(--bg-hover);color:var(--color-primary);border-color:var(--color-primary);transform:rotate(15deg)}.header-user-name{font-size:.9375rem;font-weight:500;color:var(--text-primary)}@media (max-width: 768px){.header-user-name{display:none}}.auth-loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-primary);padding:2rem 1rem;overflow-y:auto}.auth-loading-content{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg);text-align:center;max-height:calc(100vh - 4rem);overflow-y:auto;width:100%;max-width:480px}.auth-logo{width:80px;height:80px;opacity:.9}.auth-wall{min-height:100vh;min-height:100dvh;background:var(--bg-primary);display:flex;align-items:center;justify-content:flex-start;flex-direction:column;padding:max(2rem,env(safe-area-inset-top,2rem)) var(--spacing-xl) 2rem;overflow-y:auto;overflow-x:hidden;box-sizing:border-box;-webkit-overflow-scrolling:touch}.auth-wall-content{max-width:600px;width:100%;display:flex;flex-direction:column;gap:var(--spacing-2xl)}.auth-hero{text-align:center}.auth-wall-logo{width:120px;height:120px;margin:0 auto var(--spacing-xl);filter:drop-shadow(var(--shadow-sm))}.auth-wall-title{font-size:3rem;font-weight:700;color:var(--text-primary);margin:0 0 var(--spacing-md) 0;letter-spacing:-.02em}.auth-wall-subtitle{font-size:1.25rem;color:var(--text-secondary);margin:0}.auth-wall-message{display:flex;justify-content:center}.auth-wall-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:var(--spacing-2xl);box-shadow:var(--shadow-lg);text-align:center}.auth-wall-card h2{font-size:1.75rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-md) 0}.auth-wall-card p{font-size:1rem;color:var(--text-secondary);line-height:1.6;margin:0 0 var(--spacing-xl) 0}.auth-features{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);text-align:left}.auth-feature{display:flex;align-items:center;gap:var(--spacing-md);font-size:.9375rem;color:var(--text-primary)}.auth-feature svg{flex-shrink:0;color:var(--color-primary)}.auth-wall-button{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);background:var(--bg-gradient);color:var(--text-inverse);border:none;border-radius:var(--border-radius-sm);font-size:1rem;font-weight:500;cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-md)}.auth-wall-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.auth-wall-button:active{transform:translateY(0)}.auth-wall-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.auth-wall-button:disabled:hover{transform:none;box-shadow:var(--shadow-md)}.auth-terms{margin-bottom:var(--spacing-lg);text-align:left}.auth-terms-checkbox{display:flex;align-items:flex-start;gap:var(--spacing-sm);font-size:.875rem;line-height:1.6;color:var(--text-secondary);cursor:pointer}.auth-terms-checkbox input[type=checkbox]{margin-top:.25rem;width:18px;height:18px;cursor:pointer;flex-shrink:0}.auth-terms-checkbox a{color:var(--color-primary);text-decoration:none;font-weight:500}.auth-terms-checkbox a:hover{text-decoration:underline}.auth-wall-footer{text-align:center;padding-top:var(--spacing-xl);border-top:1px solid var(--border-color)}.auth-disclaimer{font-size:.875rem;color:var(--text-muted);margin:0}@media (max-width: 768px){.auth-wall{align-items:flex-start;justify-content:flex-start;padding-top:env(safe-area-inset-top,1rem);min-height:auto;height:auto}.auth-wall-content{padding-top:1rem;padding-bottom:2rem}.auth-wall-title{font-size:2rem}.auth-wall-subtitle{font-size:1rem}.auth-wall-card{padding:var(--spacing-xl)}.auth-wall-logo{width:80px;height:80px}}.role-selector{display:flex;flex-direction:column;gap:var(--spacing-sm)}.role-option{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);font-size:.9375rem;cursor:pointer;transition:all var(--transition-base);text-align:left;width:100%}.role-option:hover{background:var(--bg-hover);border-color:var(--color-primary)}.role-option.active{background:var(--color-primary);color:var(--text-inverse);border-color:var(--color-primary);font-weight:500}.role-option svg{flex-shrink:0}@media (max-width: 768px){.input-hints{display:none}}.file-upload-container{display:flex;align-items:center;gap:.5rem}.file-input-hidden{display:none}.file-upload-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:transparent;border:none;border-radius:50%;color:var(--color-primary);cursor:pointer;transition:all var(--transition-base);flex-shrink:0;font-size:.8rem;font-weight:500}.file-upload-button:hover:not(.disabled){background:#4ecdc41a;color:var(--color-primary);transform:scale(1.1)}.file-upload-button.disabled{opacity:.5;cursor:not-allowed}.file-upload-button.uploading{border-color:var(--color-primary)}.file-upload-button .spinner{animation:spin 1s linear infinite}.phi-protection-notice{background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%);border:1px solid var(--color-primary);border-radius:12px;padding:1rem;max-width:400px;animation:fadeIn .3s ease-out}.phi-protection-main{display:flex;align-items:flex-start;gap:.75rem;color:var(--text-primary);font-size:.9rem;line-height:1.5;margin-bottom:.75rem}.phi-protection-main .spinner{flex-shrink:0;color:var(--color-primary);animation:spin 1s linear infinite}.phi-protection-detail{font-size:.75rem;color:var(--text-muted);line-height:1.4;padding-left:2rem}.phi-protection-detail a{color:var(--color-primary);text-decoration:underline}.phi-protection-detail a:hover{color:var(--color-primary-light)}@media (max-width: 480px){.phi-protection-notice{max-width:100%;padding:.75rem;margin:.5rem}.phi-protection-main{font-size:.85rem}.phi-protection-detail{font-size:.7rem;padding-left:1.5rem}}.upload-text{white-space:nowrap}.uploaded-file-badge{display:flex;align-items:center;gap:.5rem;padding:.35rem .5rem;background:#0d94881a;border:1px solid var(--color-primary);border-radius:var(--border-radius-sm);font-size:.75rem;color:var(--text-primary)}.file-info{display:flex;align-items:center;gap:.35rem}.file-name{font-weight:500;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{color:var(--text-light);font-size:.7rem}.phi-warning{color:#f59e0b;display:flex;align-items:center}.remove-file-button{display:flex;align-items:center;justify-content:center;padding:.2rem;background:transparent;border:none;color:var(--text-light);cursor:pointer;border-radius:4px;transition:all .2s}.remove-file-button:hover{background:#ef44441a;color:#ef4444}.upload-error{display:flex;align-items:center;gap:.35rem;padding:.35rem .5rem;background:#ef44441a;border:1px solid #ef4444;border-radius:var(--border-radius-sm);font-size:.75rem;color:#ef4444}.voice-input-container{position:relative;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm)}.voice-button{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);cursor:pointer;transition:all var(--transition-base);flex-shrink:0}.voice-button:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.voice-button:active:not(:disabled){transform:translateY(0) scale(.95)}.voice-button:disabled{opacity:.4;cursor:not-allowed}.voice-button.connecting{border-color:var(--color-warning)}.voice-button.recording{background:var(--color-error);border-color:var(--color-error);color:#fff;animation:pulse-recording 1.5s ease-in-out infinite}.voice-button.recording:hover:not(:disabled){background:#dc2626;border-color:#dc2626}.voice-icon{transition:transform var(--transition-base)}.voice-button:hover .voice-icon{transform:scale(1.1)}@keyframes pulse-recording{0%,to{box-shadow:0 0 #ef4444b3}50%{box-shadow:0 0 0 8px #ef444400}}.interim-transcript{position:absolute;bottom:calc(100% + var(--spacing-sm));left:0;right:0;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);padding:var(--spacing-sm) var(--spacing-md);box-shadow:var(--shadow-md);animation:fadeIn .2s ease-in-out}.interim-text{font-size:.875rem;color:var(--text-muted);font-style:italic}.voice-error{position:absolute;bottom:calc(100% + var(--spacing-sm));left:0;right:0;background:#ef44441a;border:1px solid var(--color-error);border-radius:var(--border-radius-sm);padding:var(--spacing-sm) var(--spacing-md);animation:fadeIn .2s ease-in-out}.error-text{font-size:.875rem;color:var(--color-error)}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.login-button,.logout-button{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-base)}.login-button:hover,.logout-button:hover{background:var(--bg-primary);border-color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.login-button{background:var(--bg-gradient);border:none;color:var(--text-inverse)}.login-button:hover{box-shadow:var(--shadow-md)}.logout-button{color:var(--text-muted)}.profile-menu-button{width:40px;height:40px;border-radius:var(--border-radius-sm);border:1px solid var(--border-color);background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-base);overflow:hidden}.profile-menu-button:hover{background:var(--bg-primary);border-color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.profile-menu-avatar{width:100%;height:100%;object-fit:cover}.profile-menu-placeholder{color:var(--text-muted)}.user-profile{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);cursor:pointer;transition:all var(--transition-base)}.user-profile:hover{background:var(--bg-primary);border-color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.user-profile.loading{min-width:180px;height:40px}.profile-skeleton{width:100%;height:100%;background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-primary) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--border-radius-sm)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.profile-avatar{width:32px;height:32px;border-radius:50%;overflow:hidden;flex-shrink:0}.profile-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-gradient);color:var(--text-inverse)}.profile-info{display:flex;flex-direction:column;gap:2px}.profile-name{font-size:.875rem;font-weight:600;color:var(--text-primary);line-height:1.2}.profile-email,.profile-verified{display:flex;align-items:center;gap:4px;font-size:.75rem;color:var(--text-muted);line-height:1.2}.profile-verified{color:var(--color-success)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:var(--spacing-lg);animation:fadeIn .2s ease-in-out}.profile-modal{background:var(--bg-primary);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);max-width:600px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease-out}.profile-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.profile-modal-header h2{display:flex;align-items:center;gap:var(--spacing-md);margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary)}.modal-close-button{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:var(--spacing-sm);border-radius:var(--border-radius-sm);transition:all var(--transition-base)}.modal-close-button:hover{background:var(--bg-secondary);color:var(--text-primary)}.profile-modal-content{flex:1;overflow-y:auto;padding:var(--spacing-lg)}.profile-section{margin-bottom:var(--spacing-xl)}.profile-section:last-child{margin-bottom:0}.profile-section h3{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-md) 0}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.section-header h3{margin:0}.edit-button,.save-button{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius-sm);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-base)}.edit-button{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary)}.edit-button:hover{background:var(--bg-primary);border-color:var(--color-primary)}.save-button{background:var(--bg-gradient);border:none;color:var(--text-inverse)}.save-button:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.profile-field-group{display:flex;flex-direction:column;gap:var(--spacing-lg)}.profile-field{display:flex;flex-direction:column;gap:var(--spacing-sm)}.profile-field.readonly{opacity:.8}.profile-field label{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.875rem;font-weight:500;color:var(--text-primary)}.profile-field input,.profile-field textarea{padding:var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;font-family:inherit;transition:all var(--transition-base)}.profile-field input:focus,.profile-field textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #7877c61a}.profile-field textarea{resize:vertical;min-height:80px}.field-value{padding:var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);font-size:.875rem;display:flex;align-items:center;gap:var(--spacing-sm)}.verified-badge{display:flex;align-items:center;gap:4px;padding:2px 8px;background:#10b9811a;color:var(--color-success);border-radius:var(--border-radius-sm);font-size:.75rem;font-weight:500;margin-left:auto}.profile-picture-preview{width:64px;height:64px;border-radius:50%;object-fit:cover}.profile-note{font-size:.75rem;color:var(--text-muted);margin:var(--spacing-sm) 0 0 0;font-style:italic}.field-note{font-size:.75rem;color:var(--text-muted);margin:0}.profile-checkbox{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);transition:all var(--transition-base)}.profile-checkbox:hover{background:var(--bg-primary)}.profile-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer}.profile-checkbox label{flex:1;font-size:.875rem;color:var(--text-primary);cursor:pointer;margin:0}.privacy-notice{background:var(--bg-secondary);padding:var(--spacing-lg);border-radius:var(--border-radius-sm);border:1px solid var(--border-color)}.privacy-notice h3{margin-bottom:var(--spacing-md)}.privacy-notice p{margin:0 0 var(--spacing-md) 0;font-size:.875rem;color:var(--text-primary);line-height:1.6}.privacy-notice ul{margin:0 0 var(--spacing-md) 0;padding-left:var(--spacing-lg)}.privacy-notice li{margin-bottom:var(--spacing-sm);font-size:.875rem;color:var(--text-primary);line-height:1.6}.privacy-notice li:last-child{margin-bottom:0}.profile-picture-upload{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md)}.profile-picture-preview-container{position:relative;width:120px;height:120px;border-radius:50%;overflow:hidden;border:2px solid var(--border-color);transition:all var(--transition-base)}.profile-picture-preview-container.editable{cursor:pointer}.profile-picture-preview-container.editable:hover{border-color:var(--color-primary);transform:scale(1.05)}.profile-picture-preview{width:100%;height:100%;object-fit:cover}.profile-picture-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);color:var(--text-muted)}.profile-picture-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-sm);color:#fff;opacity:0;transition:opacity var(--transition-base)}.profile-picture-preview-container.editable:hover .profile-picture-overlay{opacity:1}.profile-picture-overlay span{font-size:.75rem;font-weight:500}.sidebar-profile-section{padding:var(--spacing-md);border-bottom:1px solid var(--border-color)}.sidebar-profile-section .user-profile{cursor:pointer;padding:var(--spacing-md);border-radius:var(--border-radius-sm);transition:all var(--transition-base)}.sidebar-profile-section .user-profile:hover{background:var(--bg-secondary)}.sidebar-user-greeting{padding:var(--spacing-md);border-bottom:1px solid var(--border-color);text-align:center}.sidebar-user-greeting .greeting-text{color:var(--text-secondary);font-size:.875rem;font-weight:500}.sidebar-actions{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md);border-top:1px solid var(--border-color)}.sidebar-action-button{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all var(--transition-base);text-align:left}.sidebar-action-button:hover{background:var(--bg-primary);border-color:var(--color-primary)}.sidebar-action-button.danger{color:var(--color-error)}.sidebar-action-button.danger:hover{border-color:var(--color-error);background:#ef44441a}.sidebar-action-button.logout{color:var(--text-muted)}.sidebar-action-button.logout:hover{border-color:var(--color-primary)}.sidebar-action-button.profile{color:#f43f5e}.sidebar-action-button.profile:hover{border-color:#f43f5e;background:#f43f5e1a}.profile-modal-footer{padding:var(--spacing-lg);border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:var(--spacing-md)}.modal-button{padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--border-radius-sm);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-base)}.modal-button.secondary{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary)}.modal-button.secondary:hover{background:var(--bg-primary);border-color:var(--color-primary)}@media (max-width: 768px){.modal-overlay{padding:0}.profile-modal{max-width:100%;max-height:100vh;border-radius:0}.profile-modal-header,.profile-modal-content,.profile-modal-footer{padding:var(--spacing-md)}.profile-picture-preview-container{width:100px;height:100px}}.first-time-setup-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:15000;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);animation:fadeIn .3s ease-in-out}.first-time-setup-modal{background:var(--bg-primary);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);max-width:600px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .4s ease-out}.setup-header{padding:var(--spacing-xl);text-align:center;border-bottom:1px solid var(--border-color)}.setup-header h2{font-size:2rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-sm) 0}.setup-subtitle{font-size:1rem;color:var(--text-muted);margin:0 0 var(--spacing-xl) 0}.setup-steps{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);margin-top:var(--spacing-lg)}.setup-step{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm)}.step-number{width:40px;height:40px;border-radius:50%;background:var(--bg-secondary);border:2px solid var(--border-color);display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--text-muted);transition:all var(--transition-base)}.setup-step.active .step-number{background:var(--bg-gradient);border-color:var(--color-primary);color:var(--text-inverse)}.step-label{font-size:.75rem;color:var(--text-muted);font-weight:500}.setup-step.active .step-label{color:var(--text-primary)}.setup-step-line{width:60px;height:2px;background:var(--border-color)}.setup-content{flex:1;overflow-y:auto;padding:var(--spacing-xl)}.setup-step-content h3{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-md) 0}.step-description{font-size:.875rem;color:var(--text-muted);line-height:1.6;margin:0 0 var(--spacing-xl) 0}.setup-fields{display:flex;flex-direction:column;gap:var(--spacing-lg)}.setup-field{display:flex;flex-direction:column;gap:var(--spacing-sm)}.setup-field label{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.875rem;font-weight:500;color:var(--text-primary)}.setup-field input{padding:var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;font-family:inherit;transition:all var(--transition-base)}.setup-field input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #7877c61a}.setup-picture-upload{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg)}.picture-upload-label{cursor:pointer}.picture-upload-preview{width:200px;height:200px;border-radius:50%;overflow:hidden;border:3px solid var(--border-color);transition:all var(--transition-base)}.picture-upload-preview:hover{border-color:var(--color-primary);transform:scale(1.05)}.picture-preview-image{width:100%;height:100%;object-fit:cover}.picture-upload-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-secondary);color:var(--text-muted);gap:var(--spacing-md)}.picture-upload-placeholder span{font-size:.875rem;font-weight:500}.setup-footer{display:flex;justify-content:space-between;padding:var(--spacing-xl);border-top:1px solid var(--border-color);gap:var(--spacing-md)}.setup-button{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--border-radius-sm);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-base)}.setup-button.secondary{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary)}.setup-button.secondary:hover{background:var(--bg-primary);border-color:var(--color-primary)}.setup-button.primary{background:var(--bg-gradient);border:none;color:var(--text-inverse)}.setup-button.primary:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.setup-privacy-note{padding:var(--spacing-md) var(--spacing-xl);background:var(--bg-secondary);text-align:center}.setup-privacy-note p{font-size:.75rem;color:var(--text-muted);margin:0;line-height:1.5}@media (max-width: 768px){.first-time-setup-overlay{padding:0}.first-time-setup-modal{max-width:100%;max-height:100vh;border-radius:0}.setup-header,.setup-content,.setup-footer{padding:var(--spacing-md)}.picture-upload-preview{width:150px;height:150px}.setup-button{font-size:.813rem}}@media (max-width: 768px){.profile-info{display:none}.user-profile{padding:var(--spacing-sm)}.login-button span,.logout-button span{display:none}.login-button,.logout-button{width:40px;height:40px;justify-content:center;padding:0}}.voice-mode-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:20000;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease-in-out}.voice-mode-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(180deg,#0f172af7,#1e293bf2);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.voice-mode-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;max-width:800px;padding:var(--spacing-xl);animation:slideUp .4s ease-out}.voice-mode-close{position:absolute;top:var(--spacing-lg);right:var(--spacing-lg);background:#0d94881a;border:1px solid rgba(13,148,136,.3);border-radius:50%;width:48px;height:48px;display:flex;align-items:center;justify-content:center;color:#fffc;cursor:pointer;transition:all var(--transition-base)}.voice-mode-close:hover{background:#0d948833;border-color:#0d948880;color:var(--color-primary-light);transform:scale(1.05)}.voice-mode-logo-container{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:240px;height:240px;z-index:10}.voice-mode-logo{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;border-radius:16px;background:transparent;z-index:2}.voice-logo-image{width:100%;height:100%;object-fit:contain;border-radius:16px}.pulse-ring{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border:1px solid rgba(13,148,136,.25);border-radius:16px;pointer-events:none;opacity:.6}.pulse-ring-1{width:100%;height:100%;animation:pulseMinimal 3s ease-out infinite}.pulse-ring-2{width:100%;height:100%;animation:pulseMinimal 3s ease-out infinite 1s}.pulse-ring-3{width:100%;height:100%;animation:pulseMinimal 3s ease-out infinite 2s}.voice-mode-logo.listening .pulse-ring{border-color:#0d948859}.voice-mode-logo.responding .voice-logo-image{filter:drop-shadow(0 0 20px rgba(13,148,136,.3))}.voice-mode-logo.responding .pulse-ring{border-color:#0d948866;animation:pulseMinimal 2.5s ease-in-out infinite}@keyframes pulseMinimal{0%{transform:translate(-50%,-50%) scale(1);opacity:.5}50%{transform:translate(-50%,-50%) scale(1.15);opacity:.2}to{transform:translate(-50%,-50%) scale(1.3);opacity:0}}@keyframes pulse{0%{transform:translate(-50%,-50%) scale(1);opacity:1}to{transform:translate(-50%,-50%) scale(1.8);opacity:0}}@keyframes pulseFast{0%{transform:translate(-50%,-50%) scale(1);opacity:1}50%{transform:translate(-50%,-50%) scale(1.3);opacity:.5}to{transform:translate(-50%,-50%) scale(1);opacity:1}}@keyframes logoGlow{0%,to{box-shadow:0 20px 60px #0d948859}50%{box-shadow:0 20px 80px #06b6d473}}.voice-mode-status{position:fixed;top:calc(50% + 140px);left:50%;transform:translate(-50%);text-align:center;z-index:10}.voice-status-text{font-size:1.25rem;font-weight:500;color:#fffc;margin:0;letter-spacing:.02em}.voice-status-text.listening{color:#0d9488}.voice-status-text.responding{color:#06b6d4}.voice-error-text{font-size:1.25rem;font-weight:500;color:var(--color-error);margin:0}.voice-mode-transcript{position:fixed;bottom:40px;left:50%;transform:translate(-50%);width:90%;max-width:600px;padding:var(--spacing-lg);background:#0d948814;border:1px solid rgba(13,148,136,.2);border-radius:var(--border-radius-lg);animation:fadeIn .3s ease-in-out;z-index:5}.transcript-content{color:#fff;font-size:1.125rem;line-height:1.6;text-align:center}.final-text{color:#fff;font-weight:500}.interim-text{color:#fff9;font-style:italic}.voice-mode-hint{position:fixed;top:calc(50% + 180px);left:50%;transform:translate(-50%);text-align:center;z-index:5}.voice-mode-hint p{color:#fff9;font-size:.875rem;margin:0}.voice-mode-conversation{position:fixed;bottom:140px;left:50%;transform:translate(-50%);width:90%;max-width:600px;max-height:150px;overflow-y:auto;padding:var(--spacing-sm);display:flex;flex-direction:column;gap:var(--spacing-sm);z-index:5}.voice-msg{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius-sm);animation:fadeIn .3s ease-in-out}.voice-msg-user{background:#0d948833;border:1px solid rgba(13,148,136,.3);align-self:flex-end;max-width:85%}.voice-msg-assistant{background:#ffffff14;border:1px solid rgba(255,255,255,.15);align-self:flex-start;max-width:85%}.voice-msg-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;opacity:.7;display:block;margin-bottom:4px}.voice-msg-user .voice-msg-label{color:var(--color-primary-light)}.voice-msg-assistant .voice-msg-label{color:#fffc}.voice-msg-content{color:#ffffffe6;font-size:.875rem;line-height:1.4;margin:0}@media (max-width: 768px){.voice-mode-logo-container{width:180px;height:180px}.voice-status-text{font-size:1.25rem}.transcript-content{font-size:1rem}.voice-mode-close{width:40px;height:40px;top:var(--spacing-md);right:var(--spacing-md)}}.voice-button{background:var(--bg-gradient);border:none;color:var(--text-inverse);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.voice-button:hover{transform:scale(1.1);box-shadow:var(--shadow-md)}.voice-button:active{transform:scale(.95)}.voice-button:disabled{opacity:.5;cursor:not-allowed}.voice-icon{width:20px;height:20px}.voice-output-container{display:flex;align-items:center;gap:var(--spacing-sm)}.audio-button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:transparent;border:1px solid var(--border-subtle);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-base);flex-shrink:0}.audio-button:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.audio-button.enabled{color:var(--color-primary);border-color:var(--color-primary)}.audio-button.playing{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.audio-button:disabled{opacity:.5;cursor:not-allowed}.audio-toggle-button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-muted);cursor:pointer;transition:all var(--transition-base);flex-shrink:0}.audio-toggle-button:hover{background:var(--bg-secondary);border-color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.audio-toggle-button.enabled{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.audio-toggle-button.enabled:hover{background:#0d9488;border-color:#0d9488}.audio-icon{transition:transform var(--transition-base)}.audio-toggle-button:hover .audio-icon{transform:scale(1.1)}.playback-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);cursor:pointer;transition:all var(--transition-base);flex-shrink:0}.playback-button:hover:not(:disabled){background:var(--bg-primary);border-color:var(--color-primary);transform:scale(1.05)}.playback-button:disabled{opacity:.5;cursor:not-allowed}.playback-button.playing{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.playback-icon{transition:transform var(--transition-base)}.audio-wave{display:flex;align-items:center;justify-content:center;gap:2px;height:16px}.wave-bar{width:3px;background:#fff;border-radius:2px;animation:wave 1s ease-in-out infinite}.wave-bar:nth-child(1){height:8px;animation-delay:0s}.wave-bar:nth-child(2){height:12px;animation-delay:.2s}.wave-bar:nth-child(3){height:8px;animation-delay:.4s}@keyframes wave{0%,to{transform:scaleY(.5)}50%{transform:scaleY(1)}}.voice-output-error{position:absolute;bottom:calc(100% + var(--spacing-xs));left:0;background:#ef44441a;border:1px solid var(--color-error);border-radius:var(--border-radius-sm);padding:var(--spacing-xs) var(--spacing-sm);white-space:nowrap;animation:fadeIn .2s ease-in-out;z-index:10}.voice-output-error .error-text{font-size:.75rem;color:var(--color-error)}.app-footer{background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:0;font-size:.8125rem;position:relative}.footer-toggle{width:100%;padding:var(--spacing-sm);background:transparent;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base)}.footer-toggle:hover{background:var(--bg-tertiary);color:var(--text-secondary)}.footer-content{max-width:1200px;margin:0 auto;display:flex;justify-content:flex-start;align-items:center;flex-wrap:wrap;gap:var(--spacing-lg);padding:var(--spacing-md) var(--spacing-2xl);animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.footer-section{display:flex;align-items:center;gap:var(--spacing-sm)}.footer-logo-section{margin-right:var(--spacing-md)}.dnai-logo-link{display:inline-block;transition:transform var(--transition-base)}.dnai-logo-link:hover{transform:translateY(-2px)}.footer-label{color:var(--text-muted);font-weight:400}.footer-value{color:var(--text-secondary);font-weight:500}.status-indicator{display:flex;align-items:center;gap:var(--spacing-sm)}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--text-muted);transition:all var(--transition-base)}.status-dot.active{background:var(--color-success);box-shadow:0 0 12px #05966980;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.footer-section.copyright{margin-left:auto;display:flex;flex-direction:column;align-items:flex-end;gap:var(--spacing-xs);font-size:.75rem;color:var(--text-light)}.footer-text{display:flex;flex-direction:column;align-items:flex-end;gap:var(--spacing-xs)}.footer-product{font-size:.75rem;color:var(--text-muted);font-weight:500}.dnai-logo{height:36px;width:auto;object-fit:contain;transition:opacity var(--transition-base)}.dnai-logo-link:hover .dnai-logo{opacity:.8}@media (max-width: 768px){.footer-content{padding:var(--spacing-md);flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.footer-section{width:100%}.footer-section.copyright{margin-left:0;align-items:flex-start}.footer-text{align-items:flex-start}.dnai-logo{height:28px}}.system-status-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-2xl);animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.system-status-panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-2xl);max-width:900px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.system-status-panel::-webkit-scrollbar{width:8px}.system-status-panel::-webkit-scrollbar-track{background:transparent}.system-status-panel::-webkit-scrollbar-thumb{background:var(--border-color-strong);border-radius:4px}.status-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xl) var(--spacing-2xl);border-bottom:1px solid var(--border-color);position:sticky;top:0;background:var(--bg-secondary);z-index:10}.status-header h2{font-size:1.5rem;font-weight:600;color:var(--text-primary);letter-spacing:-.02em}.close-button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:transparent;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-base)}.close-button:hover{background:var(--bg-tertiary);border-color:var(--border-color-strong);color:var(--text-primary);transform:rotate(90deg)}.status-content{padding:var(--spacing-2xl);display:flex;flex-direction:column;gap:var(--spacing-2xl)}.status-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.status-section h3{font-size:1rem;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-sm)}.status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-md)}.status-item{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm)}.status-label{font-size:.75rem;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.status-value{font-size:.9375rem;color:var(--text-primary);font-weight:600}.capabilities-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.capability-item{display:flex;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);transition:all var(--transition-base)}.capability-item:hover{border-color:var(--color-primary);transform:translate(4px)}.capability-icon{color:var(--color-primary);flex-shrink:0;margin-top:2px}.capability-content{flex:1}.capability-name{font-size:.9375rem;font-weight:600;color:var(--text-primary);text-transform:capitalize;margin-bottom:var(--spacing-xs)}.capability-description{font-size:.8125rem;color:var(--text-secondary);line-height:1.5}.axioms-grid{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.axiom-badge{padding:var(--spacing-sm) var(--spacing-md);background:#0d948814;border:1px solid var(--color-primary);border-radius:var(--border-radius-sm);color:var(--color-primary);font-weight:600;font-family:var(--font-family-mono);font-size:.8125rem;transition:all var(--transition-fast)}.axiom-badge:hover{background:#0d948826;transform:translateY(-2px)}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--spacing-md)}.metric-card{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-xl);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);text-align:center;transition:all var(--transition-base)}.metric-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--color-primary)}.metric-icon{font-size:2rem;margin-bottom:var(--spacing-sm)}.metric-value{font-size:1.75rem;font-weight:700;color:var(--color-primary);margin-bottom:var(--spacing-xs);line-height:1}.metric-label{font-size:.75rem;color:var(--text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.safety-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.safety-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);font-size:.875rem;color:var(--text-secondary);transition:all var(--transition-fast)}.safety-item:hover{border-color:var(--color-success);background:#0596690d}.safety-icon{flex-shrink:0}.safety-icon.success{color:var(--color-success)}.status-footer{padding-top:var(--spacing-lg);margin-top:var(--spacing-lg);border-top:1px solid var(--border-color);text-align:center}.status-timestamp{font-size:.75rem;color:var(--text-light);font-weight:400}.mission-section{background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-secondary) 100%);border-radius:var(--border-radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.mission-statement{margin-bottom:var(--spacing-md)}.mission-statement h3{color:var(--color-primary);margin-bottom:var(--spacing-sm);font-size:1rem;text-transform:uppercase;letter-spacing:.05em}.mission-text{font-size:1.1rem;line-height:1.6;color:var(--text-primary);font-style:italic}.team-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.team-member{background:var(--bg-tertiary);padding:var(--spacing-md);border-radius:var(--border-radius-sm);border-left:3px solid var(--color-primary)}.team-role{font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.team-description{font-size:.9rem;color:var(--text-secondary);line-height:1.5;margin:0}.contact-section{background:var(--bg-tertiary);border-radius:var(--border-radius-sm);padding:var(--spacing-lg)}.contact-info{display:flex;flex-wrap:wrap;gap:var(--spacing-lg)}.contact-link{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--color-primary);text-decoration:none;font-size:.95rem;transition:color var(--transition-base)}.contact-link:hover{color:var(--color-primary-hover);text-decoration:underline}.disclosure-section{margin-top:var(--spacing-lg)}.disclosure-box{background:rgba(var(--color-primary-rgb),.05);border:1px solid rgba(var(--color-primary-rgb),.2);border-radius:var(--border-radius-sm);padding:var(--spacing-md)}.disclosure-box p{font-size:.85rem;color:var(--text-secondary);line-height:1.6;margin:0}.disclosure-box strong{color:var(--text-primary)}.footer-mission{text-align:center;padding:var(--spacing-sm) 0}.footer-mission-text{font-size:.85rem;color:var(--text-secondary);font-style:italic}.footer-links{display:flex;align-items:center;gap:var(--spacing-sm)}.footer-link{display:flex;align-items:center;gap:4px;color:var(--text-secondary);text-decoration:none;font-size:.8rem;transition:color var(--transition-base)}.footer-link:hover{color:var(--color-primary)}.footer-divider{color:var(--border-color)}.footer-motto{font-style:italic}.footer-disclosure{font-size:.75rem!important;color:var(--text-light)!important;opacity:.8}.footer-version{font-size:.7rem!important;color:var(--text-light)!important}@media (max-width: 1024px){:root{--spacing-2xl: 2rem;--spacing-3xl: 3rem;--spacing-4xl: 4rem}.chat-interface,.welcome-input-section{max-width:100%}.examples-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){:root{--spacing-xl: 1.5rem;--spacing-2xl: 1.5rem;--spacing-3xl: 2rem}.app-header{padding:var(--spacing-md) var(--spacing-lg)}.header-content{flex-wrap:wrap}.header-subtitle{display:none}.logo-text{font-size:1.25rem}.welcome-title{font-size:2.25rem}.welcome-subtitle{font-size:1.25rem}.welcome-description{font-size:1rem}.welcome-logo{width:100px;height:100px}.welcome-logo svg{width:80px;height:80px}.examples-grid{grid-template-columns:1fr}.welcome-features{flex-direction:column;gap:var(--spacing-sm)}.chat-messages{padding:var(--spacing-lg)}.message-content{max-width:calc(100% - 56px)}.message-text,.message-markdown{padding:var(--spacing-md) var(--spacing-lg);font-size:.875rem}.chat-input-form{padding:var(--spacing-md) var(--spacing-lg)}.input-container{max-width:100%}.welcome-chat-input{font-size:1rem}.welcome-input-wrapper{padding:0;border:none;background:transparent;box-shadow:none}.welcome-chat-input{padding:12px 48px 12px 44px;border:1.5px solid var(--border-color);border-radius:24px;background:var(--bg-secondary);box-shadow:0 2px 8px #0000000f}.welcome-chat-input:focus{border-color:var(--color-primary);box-shadow:none;outline:none}.file-upload-container,.welcome-input-wrapper .file-upload-container{position:absolute;left:10px;bottom:10px;z-index:2}.welcome-send-button,.welcome-stop-button,.welcome-voice-button{position:absolute;right:8px;bottom:8px;z-index:2}.footer-content{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.footer-section{width:100%}.footer-section.axioms{min-width:100%}.system-status-overlay{padding:var(--spacing-lg)}.status-content{padding:var(--spacing-lg);gap:var(--spacing-xl)}.status-header{padding:var(--spacing-lg)}.status-grid{grid-template-columns:1fr}.metrics-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.welcome-title{font-size:2rem}.welcome-subtitle{font-size:1.125rem}.welcome-input-section{width:100%;padding:0 16px;margin:0 0 60px}.welcome-input-form{width:100%;padding:0}.welcome-input-wrapper{position:relative;display:flex;align-items:flex-end;padding:0;margin:0;gap:8px;width:100%;box-sizing:border-box;background:transparent}.welcome-chat-input{font-size:16px;min-height:48px;max-height:150px;line-height:1.5;flex:1;min-width:0;width:100%;padding:14px 48px 14px 42px;border-radius:24px;border:1.5px solid var(--border-color);background:var(--bg-secondary);box-shadow:0 2px 8px #0000000f;transition:border-color .2s ease,box-shadow .2s ease;overflow-y:auto!important;overflow-x:hidden;word-wrap:break-word;overflow-wrap:break-word;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;scroll-padding-bottom:16px;scroll-padding-top:16px;box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}.welcome-chat-input:focus{outline:none;border-color:var(--color-primary);box-shadow:none}.welcome-chat-input::placeholder{color:var(--text-muted);font-weight:400}.file-upload-button{position:absolute;left:6px;bottom:10px;width:26px;height:26px;padding:0;border-radius:13px;background:transparent;color:var(--text-muted);z-index:2}.voice-input-button{display:none}.welcome-send-button,.welcome-stop-button,.welcome-voice-button{position:absolute;right:8px;bottom:10px;width:28px;height:28px;border-radius:14px;z-index:2}.welcome-voice-button svg{width:18px;height:18px}.file-upload-button .upload-text{display:none}.file-upload-button svg,.voice-input-button svg{width:18px;height:18px}.file-upload-button{padding:.5rem;flex-shrink:0}.welcome-send-button{width:48px;height:48px;flex-shrink:0}.voice-input-button{flex-shrink:0}.welcome-input-section{padding:0 var(--spacing-sm);width:100%;max-width:100%;box-sizing:border-box}.chat-input-wrapper{padding:var(--spacing-md)}.chat-input{font-size:1rem;min-height:44px}.role-selector{position:static}.role-menu,.header-menu{left:0;right:0;min-width:100%}.metrics-grid{grid-template-columns:1fr}.chat-welcome{padding:var(--spacing-xl) var(--spacing-lg);gap:var(--spacing-xl)}.file-upload-container{position:relative;flex-shrink:0;max-width:160px}.uploaded-file-badge{padding:4px 8px;font-size:.7rem;border-radius:16px;max-width:150px;overflow:hidden}.uploaded-file-badge .file-info{gap:4px;flex-wrap:nowrap;overflow:hidden}.uploaded-file-badge .file-name{max-width:60px;font-size:.65rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.uploaded-file-badge .file-size{font-size:.6rem;white-space:nowrap}.uploaded-file-badge .clear-file-button{width:16px;height:16px;padding:2px;flex-shrink:0}.app-container,.main-content{padding-bottom:env(safe-area-inset-bottom,0);overflow-x:hidden;max-width:100vw}.chat-input-container,.welcome-input-section{position:sticky;bottom:0;left:0;right:0;background:var(--bg-primary);z-index:100;padding-bottom:env(safe-area-inset-bottom,8px);overflow-x:hidden;max-width:100vw;box-sizing:border-box}.messages-container,.chat-messages{overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding-bottom:100px}.welcome-chat-input,.chat-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;scroll-margin-bottom:100px}html,body{overflow-x:hidden;max-width:100vw;position:relative}}@media (min-width: 1200px){.chat-interface{max-width:1000px}.welcome-input-section{max-width:700px}.welcome-title{font-size:3rem}.welcome-logo{width:120px;height:120px}.examples-grid{grid-template-columns:repeat(3,1fr)}.chat-welcome{padding:var(--spacing-2xl) var(--spacing-3xl) var(--spacing-3xl);gap:var(--spacing-xl)}}@media (min-width: 1440px){.chat-interface{max-width:1100px}.welcome-input-section{max-width:750px}.welcome-title{font-size:3.25rem}.welcome-subtitle{font-size:1.5rem}.welcome-logo{width:130px;height:130px}.chat-welcome{padding:var(--spacing-3xl) var(--spacing-3xl) var(--spacing-4xl);gap:var(--spacing-2xl)}.header-content{max-width:1800px}}@media (min-width: 1920px){.chat-interface{max-width:1200px}.welcome-input-section{max-width:800px}.welcome-title{font-size:3.5rem}.welcome-subtitle{font-size:1.625rem}.welcome-logo{width:140px;height:140px}.chat-welcome{padding:var(--spacing-4xl) var(--spacing-4xl) var(--spacing-4xl);gap:var(--spacing-2xl)}.example-card{padding:var(--spacing-xl);min-height:130px}}@media (min-width: 2560px){.chat-interface{max-width:1400px}.welcome-input-section{max-width:900px}.welcome-title{font-size:4rem}.welcome-logo{width:160px;height:160px}}@media (max-height: 800px){.chat-welcome{padding-top:var(--spacing-md);padding-bottom:var(--spacing-xl);gap:var(--spacing-md)}.welcome-logo{width:80px;height:80px}.welcome-title{font-size:2rem;margin-bottom:var(--spacing-xs)}.welcome-subtitle{font-size:1.125rem;margin-bottom:var(--spacing-sm)}.welcome-description{font-size:.9375rem}.welcome-input-section{gap:var(--spacing-lg)}.example-card{min-height:90px;padding:var(--spacing-md)}.welcome-features{gap:var(--spacing-sm)}.feature-badge{padding:var(--spacing-xs) var(--spacing-sm);font-size:.8125rem}}@media (max-height: 700px){.chat-welcome{padding-top:var(--spacing-sm);gap:var(--spacing-sm)}.welcome-logo{width:60px;height:60px}.welcome-title{font-size:1.75rem}.welcome-subtitle{font-size:1rem}.welcome-features{display:none}.example-card{min-height:70px}}@media print{.app-header,.app-footer,.chat-input-form,.welcome-input-section,.message-metadata,.header-icon-button,.role-selector{display:none!important}.chat-messages{overflow:visible}.message-bubble{page-break-inside:avoid}}.landing-page{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;min-height:100vh;padding:var(--spacing-3xl) var(--spacing-lg);background:#fafaf9;gap:var(--spacing-2xl);overflow-x:hidden;overflow-y:auto;width:100%;box-sizing:border-box}.landing-hero{display:flex;flex-direction:column;align-items:center;text-align:center;max-width:700px;animation:fadeInUp .8s ease-out}.landing-logo-container{display:flex;justify-content:center;margin-bottom:var(--spacing-2xl)}.landing-logo{width:180px;height:180px;object-fit:cover;box-shadow:var(--shadow-xl);animation:float 3s ease-in-out infinite}.landing-title{font-size:4rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-md);letter-spacing:-.04em;line-height:1}.landing-subtitle{font-size:1.25rem;font-weight:400;color:var(--text-secondary);line-height:1.6;max-width:600px;margin-bottom:var(--spacing-2xl)}.get-to-know-btn{margin-top:var(--spacing-xl);padding:var(--spacing-lg) var(--spacing-3xl);font-size:1.125rem;font-weight:600;color:var(--text-inverse);background:linear-gradient(135deg,#0d9488,#06b6d4);border:none;border-radius:var(--border-radius);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-lg);letter-spacing:-.01em}.get-to-know-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-xl)}.get-to-know-btn:active{transform:translateY(0)}.landing-role-selection{width:100%;max-width:800px;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xl);animation:fadeInUp .8s ease-out .2s backwards;padding:0 var(--spacing-md);box-sizing:border-box}.role-selection-title{font-size:1.5rem;font-weight:600;color:var(--text-primary);letter-spacing:-.02em}.role-cards{width:100%;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-lg);align-items:stretch}.role-card{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-lg);padding:var(--spacing-2xl);background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--border-radius-lg);cursor:pointer;transition:all var(--transition-base);text-align:center;overflow:hidden;height:100%}.role-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--role-color, var(--color-primary));transform:scaleX(0);transition:transform var(--transition-base)}.role-card:hover{border-color:var(--role-color, var(--color-primary));transform:translateY(-8px);box-shadow:var(--shadow-xl)}.role-card:hover:before{transform:scaleX(1)}.role-card.selected{border-color:var(--role-color, var(--color-primary));background:linear-gradient(135deg,#0d948808,#06b6d408);box-shadow:var(--shadow-xl);transform:translateY(-8px) scale(1.02)}.role-card.selected:before{transform:scaleX(1)}.role-card-default{animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:var(--shadow-lg)}50%{box-shadow:var(--shadow-xl),0 0 0 4px #0d94881a}}.role-card-content{display:flex;flex-direction:column;gap:var(--spacing-sm);flex:1;justify-content:center}.role-card-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.role-card-description{font-size:.9375rem;font-weight:400;color:var(--text-secondary);line-height:1.5}.landing-footer{text-align:center;max-width:600px;animation:fadeInUp .8s ease-out .4s backwards}.landing-disclaimer{font-size:.8125rem;color:var(--text-muted);line-height:1.6;padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-secondary);border-radius:var(--border-radius-sm);border:1px solid var(--border-color-light)}@media (max-width: 1024px){.landing-page{padding:var(--spacing-2xl) var(--spacing-lg);gap:var(--spacing-xl)}.landing-role-selection{max-width:600px}.role-cards{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-md)}}@media (max-width: 768px){.landing-page{padding:var(--spacing-xl) var(--spacing-md);gap:var(--spacing-lg);justify-content:flex-start}.landing-title{font-size:2.5rem}.landing-subtitle{font-size:1rem}.landing-logo{width:140px;height:140px}.landing-role-selection{max-width:100%;padding:0}.role-cards{grid-template-columns:1fr;gap:var(--spacing-md);width:100%}.role-card{padding:var(--spacing-lg);min-height:120px;width:100%}.role-card-title{font-size:1.25rem}.role-card-description{font-size:.9375rem}.role-selection-title{font-size:1.125rem}.get-to-know-btn{padding:var(--spacing-md) var(--spacing-xl);font-size:1rem;width:100%;max-width:400px}}@media (max-width: 480px){.landing-title{font-size:2rem}.landing-subtitle{font-size:.9375rem}.landing-logo{width:120px;height:120px}.role-card{padding:var(--spacing-lg)}.role-card-title{font-size:1.25rem}.role-card-description{font-size:.9375rem}}.sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:999;animation:fadeIn .2s ease-out}.chat-sidebar{position:fixed;right:0;top:0;bottom:0;width:320px;background:var(--bg-secondary);border-left:1px solid var(--border-color);overflow-y:auto;z-index:1000;transform:translate(320px);transition:transform var(--transition-base);box-shadow:var(--shadow-xl);display:flex;flex-direction:column}.chat-sidebar.open{transform:translate(0)}.sidebar-header{padding:var(--spacing-xl) var(--spacing-lg);border-bottom:1px solid var(--border-color);background:var(--bg-tertiary)}.sidebar-header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.sidebar-header h3{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.sidebar-close-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.sidebar-close-button:hover{background:var(--bg-hover);color:var(--text-primary)}.new-session-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-gradient);color:var(--text-inverse);border:none;border-radius:var(--border-radius-sm);font-weight:600;font-size:.9375rem;cursor:pointer;transition:all var(--transition-base)}.new-session-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.sidebar-content{flex:1;overflow-y:auto}.sidebar-content::-webkit-scrollbar{width:6px}.sidebar-content::-webkit-scrollbar-track{background:transparent}.sidebar-content::-webkit-scrollbar-thumb{background:var(--border-color-strong);border-radius:3px}.sidebar-section{border-bottom:1px solid var(--border-color)}.section-header{display:flex;align-items:center;gap:var(--spacing-md);width:100%;padding:var(--spacing-lg);background:transparent;border:none;color:var(--text-primary);font-weight:600;font-size:.9375rem;text-align:left;cursor:pointer;transition:all var(--transition-fast)}.section-header:hover{background:var(--bg-tertiary)}.section-header span{flex:1}.section-chevron{color:var(--text-muted);transition:transform var(--transition-fast)}.section-content{padding:var(--spacing-md) var(--spacing-lg) var(--spacing-lg)}.session-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.session-list::-webkit-scrollbar{width:6px}.session-list::-webkit-scrollbar-track{background:transparent}.session-list::-webkit-scrollbar-thumb{background:var(--border-color-strong);border-radius:3px}.session-group{margin-bottom:var(--spacing-xl)}.session-group h4{margin:0 0 var(--spacing-sm) 0;font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.session-item{display:flex;align-items:flex-start;gap:var(--spacing-sm);width:100%;padding:var(--spacing-md);margin-bottom:var(--spacing-xs);background:transparent;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);text-align:left;cursor:pointer;transition:all var(--transition-fast)}.session-item:hover{border-color:var(--color-primary);background:var(--bg-tertiary);transform:translate(-2px)}.session-item.current{border-color:var(--color-primary);background:#0d948814}.session-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--bg-tertiary);border-radius:var(--border-radius-sm);color:var(--color-primary);flex-shrink:0}.session-item.current .session-icon{background:var(--color-primary);color:var(--text-inverse)}.session-content{flex:1;min-width:0}.session-title{font-weight:600;font-size:.875rem;color:var(--text-primary);margin-bottom:var(--spacing-xs);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.session-meta{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;color:var(--text-muted);gap:var(--spacing-xs)}.session-time{display:flex;align-items:center;gap:4px}.session-messages{font-size:.6875rem}.empty-sessions{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl) var(--spacing-md);text-align:center}.empty-icon{color:var(--text-light);margin-bottom:var(--spacing-sm)}.empty-text{margin:0;font-weight:500;color:var(--text-muted);font-size:.8125rem}.role-list,.theme-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.role-option,.theme-option{display:flex;align-items:center;gap:var(--spacing-md);width:100%;padding:var(--spacing-md);background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--border-radius-sm);text-align:left;cursor:pointer;transition:all var(--transition-fast)}.role-option:hover,.theme-option:hover{border-color:var(--color-primary);transform:translate(-2px)}.role-option.active,.theme-option.active{border-color:var(--color-primary);background:#0d948814}.role-option-content,.theme-option-content{flex:1;min-width:0}.role-option-label,.theme-option-label{font-weight:600;font-size:.875rem;color:var(--text-primary);margin-bottom:2px}.role-option-description,.theme-option-description{font-size:.75rem;color:var(--text-muted)}.role-section-hint{font-size:.8rem;color:var(--text-muted);margin-bottom:var(--spacing-sm);padding:0 var(--spacing-xs);font-style:italic}.role-check,.theme-check{color:var(--color-primary);flex-shrink:0}.theme-preview{width:40px;height:40px;border-radius:var(--border-radius-sm);border:2px solid var(--border-color);flex-shrink:0}.settings-group{margin-bottom:var(--spacing-lg)}.settings-group:last-child{margin-bottom:0}.settings-group-label{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.sidebar-upgrade-cta{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border-color)}.upgrade-card{background:linear-gradient(135deg,#0d94881a,#14b8a60d);border:1px solid rgba(13,148,136,.3);border-radius:var(--border-radius-lg);padding:var(--spacing-md);text-align:center}.upgrade-header{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-xs)}.upgrade-icon{color:var(--color-primary)}.upgrade-title{font-weight:600;color:var(--color-primary);font-size:.95rem}.upgrade-description{font-size:.8rem;color:var(--text-secondary);margin-bottom:var(--spacing-sm);line-height:1.4}.upgrade-button{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);background:var(--bg-gradient);color:#fff;border:none;border-radius:var(--border-radius-sm);padding:var(--spacing-sm) var(--spacing-md);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;width:100%}.upgrade-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0d94884d}.sidebar-footer{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border-color);background:var(--bg-tertiary)}.sidebar-stats{display:flex;justify-content:center}.stat-item{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.75rem;color:var(--text-muted)}@media (max-width: 768px){.chat-sidebar{width:280px;transform:translate(280px)}}@media (max-width: 480px){.chat-sidebar{width:100%;max-width:100vw;transform:translate(100%)}}.terms-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px}.terms-modal{background:#fff;border-radius:16px;max-width:800px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.terms-header{padding:32px 32px 24px;border-bottom:1px solid #e5e7eb}.terms-header h2{font-size:28px;font-weight:600;margin:0 0 8px;color:#111827}.terms-subtitle{font-size:16px;color:#6b7280;margin:0}.terms-content{padding:32px}.terms-section{margin-bottom:32px}.terms-section h3{font-size:20px;font-weight:600;margin:0 0 16px;color:#111827}.terms-section p{font-size:15px;line-height:1.6;color:#374151;margin:0 0 12px}.terms-section ul{margin:12px 0;padding-left:24px}.terms-section li{font-size:15px;line-height:1.6;color:#374151;margin-bottom:8px}.motto{font-style:italic;color:#047857;font-size:16px;font-weight:500}.epistemic-notice{background:#fef3c7;border-left:4px solid #f59e0b;padding:16px;border-radius:8px}.testing-notice{background:#dbeafe;border-left:4px solid #3b82f6;padding:16px;border-radius:8px;font-size:15px}.agreement-section{background:#f9fafb;padding:20px;border-radius:8px}.terms-checkbox{display:flex;align-items:flex-start;gap:12px;cursor:pointer;font-size:15px;line-height:1.6;color:#374151}.terms-checkbox input[type=checkbox]{margin-top:4px;width:18px;height:18px;cursor:pointer}.terms-actions{padding:24px 32px;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:12px}.btn-primary,.btn-secondary{padding:12px 24px;border-radius:8px;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s;border:none}.btn-primary{background:#047857;color:#fff}.btn-primary:hover:not(:disabled){background:#065f46}.btn-primary:disabled{background:#d1d5db;cursor:not-allowed}.btn-secondary{background:transparent;color:#374151;border:1px solid #d1d5db}.btn-secondary:hover{background:#f3f4f6}.role-card{background:#fff;border:2px solid #e5e7eb;border-radius:16px;padding:32px;cursor:pointer;transition:all .3s}.role-card:hover{border-color:#047857;box-shadow:0 8px 24px #0478571a;transform:translateY(-4px)}.role-icon{font-size:48px;margin-bottom:16px}.role-title{font-size:22px;font-weight:600;margin:0 0 12px;color:#111827}.role-description{font-size:15px;line-height:1.6;color:#6b7280;margin:0 0 20px}.role-features{list-style:none;padding:0;margin:0}.role-features li{font-size:14px;color:#047857;padding:6px 0 6px 20px;position:relative}.role-features li:before{content:✓;position:absolute;left:0;font-weight:700}.role-note{margin-top:16px;padding-top:16px;border-top:1px solid #e5e7eb}.role-note-bottom{margin-top:32px;padding:24px;background:#f9fafb;border-radius:12px;text-align:center}.auth-note{margin-top:12px;color:#6b7280}.message-actions{display:flex;align-items:center;gap:12px;margin-top:12px;padding-top:12px;border-top:1px solid #e5e7eb}.feedback-button{display:flex;align-items:center;gap:6px;padding:6px 12px;background:transparent;border:1px solid #d1d5db;border-radius:6px;font-size:13px;color:#6b7280;cursor:pointer;transition:all .2s}.feedback-button:hover{background:#f3f4f6;border-color:#9ca3af;color:#374151}.feedback-button svg{flex-shrink:0}.auth-modal{width:100%;max-width:420px;margin:0 auto;animation:slideUp .4s cubic-bezier(.16,1,.3,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-form{background:linear-gradient(145deg,#fffffff2,#f8fafcfa);border-radius:24px;padding:2.5rem;box-shadow:0 4px 6px -1px #0000001a,0 10px 40px -3px #00000026,0 0 0 1px #ffffff80 inset;border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.auth-form-logo{width:64px;height:64px;margin:0 auto 1.5rem;display:block;filter:drop-shadow(0 4px 12px rgba(58,176,183,.3))}.auth-form-title{font-size:1.875rem;font-weight:800;color:#1a1a2e;margin-bottom:.5rem;text-align:center;letter-spacing:-.025em}.auth-form-subtitle{color:#64748b;text-align:center;margin-bottom:2rem;font-size:.95rem}.auth-error{background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fca5a5;color:#b91c1c;padding:.875rem 1rem;border-radius:12px;margin-bottom:1.25rem;font-size:.875rem;display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;animation:shake .5s cubic-bezier(.36,.07,.19,.97)}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-4px)}20%,40%,60%,80%{transform:translate(4px)}}.auth-error-help{display:block;width:100%;margin-top:.5rem;padding-top:.5rem;border-top:1px solid #fca5a5;font-size:.85rem}.auth-error-link{background:none;border:none;color:#3ab0b7;font-weight:600;cursor:pointer;padding:0;text-decoration:underline;font-size:inherit}.auth-error-link:hover{color:#2d8f94}.auth-input-group{position:relative;margin-bottom:1.25rem}.auth-input-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#94a3b8;transition:color .2s;z-index:1}.auth-input-group:focus-within .auth-input-icon{color:#3ab0b7}.auth-input{width:100%;padding:1rem 1rem 1rem 3rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;background:#fff;color:#1e293b;transition:all .25s ease;box-shadow:0 1px 2px #0000000d}.auth-input::placeholder{color:#94a3b8}.auth-input:hover{border-color:#cbd5e1}.auth-input:focus{outline:none;border-color:#3ab0b7;box-shadow:0 0 0 4px #3ab0b726,0 1px 2px #0000000d}.auth-input:disabled{opacity:.6;cursor:not-allowed;background:#f8fafc}.auth-password-toggle{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;color:#94a3b8;cursor:pointer;padding:.5rem;border-radius:8px;transition:all .2s;display:flex;align-items:center;justify-content:center}.auth-password-toggle:hover{color:#64748b;background:#f1f5f9}.auth-submit-btn{width:100%;padding:1rem 1.5rem;background:linear-gradient(135deg,#3ab0b7,#2d9a9f);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .25s ease;margin-top:.75rem;box-shadow:0 4px 14px #3ab0b759,0 1px 3px #0000001a;text-transform:none;letter-spacing:0}.auth-submit-btn:hover:not(:disabled){background:linear-gradient(135deg,#2d9a9f,#248a8f);transform:translateY(-2px);box-shadow:0 6px 20px #3ab0b766,0 2px 4px #0000001a}.auth-submit-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #3ab0b74d,0 1px 2px #0000001a}.auth-submit-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.auth-divider{display:flex;align-items:center;margin:1.5rem 0;gap:1rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,#e2e8f0,transparent)}.auth-divider span{color:#94a3b8;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}.auth-switch-text{text-align:center;margin-top:1.75rem;color:#64748b;font-size:.9rem}.auth-switch-btn{background:none;border:none;color:#3ab0b7;font-weight:600;cursor:pointer;padding:0;transition:color .2s}.auth-switch-btn:hover{color:#2d9a9f;text-decoration:underline}.auth-password-strength{display:flex;gap:4px;margin-top:.5rem}.auth-password-strength-bar{height:4px;flex:1;border-radius:2px;background:#e2e8f0;transition:background .3s}.auth-password-strength-bar.weak{background:#ef4444}.auth-password-strength-bar.medium{background:#f59e0b}.auth-password-strength-bar.strong{background:#10b981}.auth-password-requirements{margin-top:.5rem;margin-bottom:.75rem}.auth-requirements-list{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.5rem}.auth-requirements-list span{font-size:.7rem;padding:.2rem .5rem;border-radius:4px;background:#f1f5f9;color:#94a3b8;transition:all .2s}.auth-requirements-list span.met{background:#dcfce7;color:#16a34a}.auth-success{text-align:center;padding:2rem}.auth-success-icon{width:64px;height:64px;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;color:#fff;animation:scaleIn .4s cubic-bezier(.16,1,.3,1)}@keyframes scaleIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.auth-form-inline{background:transparent;box-shadow:none;border:none;padding:1.5rem 0 0;border-top:1px solid #e2e8f0;margin-top:1.5rem;border-radius:0}.auth-form-header{font-size:1.125rem;font-weight:600;color:#1a1a2e;margin-bottom:1.25rem;text-align:center}.asha-highlight{color:#3ab0b7;font-weight:600}.social-login-section-top{display:flex;flex-direction:column;gap:.625rem;margin-bottom:1rem;width:100%}.social-login-section-top .social-login-btn{margin:0}.auth-divider{display:flex;align-items:center;gap:1rem;margin:1rem 0;color:#6b7280;font-size:.85rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#e5e7eb}.auth-email-toggle{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.875rem 1rem;background:transparent;border:1px dashed #d1d5db;border-radius:12px;color:#6b7280;font-size:.95rem;cursor:pointer;transition:all .2s ease}.auth-email-toggle:hover{border-color:#3ab0b7;color:#3ab0b7;background:#3ab0b70d}.auth-email-form{display:flex;flex-direction:column;gap:.875rem}.auth-terms-compact{display:flex;align-items:center;gap:.625rem;padding:.75rem 1rem;background:#3ab0b714;border-radius:10px;font-size:.85rem;color:#4b5563;margin-bottom:1rem;cursor:pointer;text-align:left}.auth-terms-compact input[type=checkbox]{margin-top:2px;width:16px;height:16px;accent-color:#3ab0b7;flex-shrink:0}.auth-terms-compact a{color:#3ab0b7;font-weight:600;text-decoration:none}.auth-terms-compact a:hover{text-decoration:underline}.auth-feature-badges{display:flex;justify-content:center;gap:.75rem;flex-wrap:wrap;margin-top:1rem;padding-top:1rem;border-top:1px solid #f3f4f6}.auth-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .65rem;background:#f9fafb;border-radius:20px;font-size:.75rem;color:#6b7280;font-weight:500}.auth-badge svg{color:#3ab0b7}.auth-password-strength-mini{display:flex;gap:4px;margin-top:-.5rem;margin-bottom:.5rem}.auth-password-strength-mini .strength-bar{flex:1;height:3px;background:#e5e7eb;border-radius:2px;transition:background .2s ease}.auth-password-strength-mini .strength-bar.weak{background:#ef4444}.auth-password-strength-mini .strength-bar.medium{background:#f59e0b}.auth-password-strength-mini .strength-bar.strong{background:#10b981}.social-login-section{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-color, #e5e7eb)}.social-login-divider{display:flex;align-items:center;margin-bottom:1rem;gap:1rem}.social-login-divider:before,.social-login-divider:after{content:"";flex:1;height:1px;background:var(--border-color, #e5e7eb)}.social-login-divider span{font-size:.875rem;color:var(--text-muted, #6b7280);white-space:nowrap}.social-login-buttons{display:flex;flex-direction:column;gap:.75rem}.social-login-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:.875rem 1rem;border:1px solid var(--border-color, #e5e7eb);border-radius:.5rem;background:#fff;font-size:.9375rem;font-weight:500;color:#374151;cursor:pointer;transition:all .15s ease}.social-login-btn:hover:not(:disabled){background:#f9fafb;border-color:#d1d5db;transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.social-login-btn:disabled{opacity:.6;cursor:not-allowed}.social-login-btn svg{flex-shrink:0}.social-login-google:hover:not(:disabled){border-color:#4285f4}.social-login-facebook:hover:not(:disabled){border-color:#1877f2}.social-login-linkedin:hover:not(:disabled){border-color:#0a66c2}.social-login-terms-note{margin-top:.75rem;font-size:.75rem;color:var(--text-muted, #6b7280);text-align:center}.quota-warning-banner{background:linear-gradient(135deg,#fbbf2426,#f59e0b1a);border:1px solid rgba(251,191,36,.4);border-radius:12px;padding:.75rem 1rem;margin:.75rem 1rem;animation:quotaSlideIn .3s ease-out}@keyframes quotaSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.quota-warning-content{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.quota-warning-icon{font-size:1.2rem;animation:quotaPulse 2s infinite}@keyframes quotaPulse{0%,to{opacity:1}50%{opacity:.6}}.quota-warning-text{flex:1;min-width:200px;color:var(--text-primary);font-size:.9rem}.quota-warning-text strong{color:#f59e0b;font-weight:600}.quota-summarize-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.quota-summarize-btn:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857);transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.quota-summarize-btn:disabled{opacity:.7;cursor:wait}.quota-upgrade-link{background:linear-gradient(135deg,var(--accent-primary),var(--accent-hover));color:#fff;padding:.5rem 1rem;border-radius:8px;font-size:.85rem;font-weight:500;text-decoration:none;transition:all .2s ease}.quota-upgrade-link:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.quota-dismiss-btn{background:transparent;border:none;color:var(--text-muted);font-size:1rem;cursor:pointer;padding:.25rem;opacity:.6;transition:opacity .2s}.quota-dismiss-btn:hover{opacity:1}.message.session-summary{background:linear-gradient(135deg,#10b9811a,#06b6d41a);border:1px solid rgba(16,185,129,.3)}@media (max-width: 768px){.quota-warning-banner{margin:.5rem;padding:.5rem .75rem}.quota-warning-content{gap:.5rem}.quota-warning-text{font-size:.8rem;min-width:150px}.quota-summarize-btn,.quota-upgrade-link{padding:.4rem .75rem;font-size:.75rem}}.inactivity-warning-banner{background:linear-gradient(135deg,#ef444426,#dc26261a);border:1px solid rgba(239,68,68,.4);border-radius:12px;padding:.75rem 1rem;margin:.75rem 1rem;animation:inactivitySlideIn .3s ease-out}@keyframes inactivitySlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.inactivity-warning-content{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap}.inactivity-warning-icon{font-size:1.2rem}.inactivity-warning-text{color:var(--text-primary);font-size:.9rem}.inactivity-warning-text strong{color:var(--color-error);font-weight:600}.inactivity-stay-button{background:var(--color-primary);color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .2s}.inactivity-stay-button:hover{background:var(--color-primary-dark)}@media (max-width: 768px){.inactivity-warning-banner{margin:.5rem;padding:.5rem .75rem}.inactivity-warning-content{gap:.5rem}.inactivity-warning-text{font-size:.8rem}}.auth-forgot-password-btn{background:transparent;border:none;color:var(--accent-primary);font-size:.9rem;font-weight:500;cursor:pointer;padding:.75rem;margin-top:.75rem;text-decoration:underline;text-underline-offset:3px;transition:color .2s,opacity .2s;width:100%;text-align:center}.auth-forgot-password-btn:hover{color:var(--accent-hover);opacity:.85}.auth-form-subtitle{color:var(--text-muted);font-size:.9rem;margin-bottom:1.5rem;text-align:center}.auth-success-message{text-align:center;padding:1.5rem;background:#10b9811a;border-radius:12px;margin-bottom:1.5rem}.auth-success-icon{color:#10b981;margin-bottom:1rem}.auth-success-message p{margin:.5rem 0;color:var(--text-primary)}.auth-success-note{color:var(--text-muted);font-size:.85rem}.auth-back-btn{background:transparent;border:none;color:var(--text-muted);font-size:.9rem;cursor:pointer;padding:.75rem;margin-top:1rem;transition:color .2s;width:100%;text-align:center}.auth-back-btn:hover{color:var(--text-primary)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{margin:0;font-family:Montserrat,-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;background:ivory;color:#353839;overflow-x:hidden}code,pre{font-family:Roboto Mono,Courier New,monospace}#root{width:100%;min-height:100vh}html{scroll-behavior:smooth}button{font-family:inherit;border:none;outline:none;background:none;cursor:pointer}input,textarea,select{font-family:inherit;border:none;outline:none}a{color:inherit;text-decoration:none}ul,ol{list-style:none}img{max-width:100%;height:auto;display:block}::selection{background:#3ab0b74d;color:#353839}::-moz-selection{background:#3ab0b74d;color:#353839}*:focus-visible{outline:2px solid #3ab0b7;outline-offset:2px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}
