.dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease}.dialog-content{background-color:var(--background-light);border-radius:var(--radius-lg);box-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 10px 10px -5px rgba(0,0,0,.04);max-width:480px;width:100%;position:relative;padding:2rem;animation:slideUp .3s ease}.dialog-close{position:absolute;top:1rem;right:1rem;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:var(--radius-md);transition:all .2s ease;display:flex;align-items:center;justify-content:center}.dialog-close:hover{background-color:transparent;color:var(--text-primary)}.dialog-close:disabled{opacity:.5;cursor:not-allowed}.dialog-header{text-align:center;margin-bottom:2rem}.dialog-header svg{margin:0 auto 1rem}.dialog-title{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem}.dialog-subtitle{font-size:.875rem;color:var(--text-secondary);margin:0;line-height:1.5}.dialog-form{display:flex;flex-direction:column;gap:1rem}.dialog-form .form-group{display:flex;flex-direction:column;gap:.5rem}.dialog-form .form-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;color:var(--text-primary)}.dialog-form .form-input{width:100%;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background-color:var(--background);color:var(--text-primary);font-size:.875rem;transition:all .2s ease}.dialog-form .form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(241,90,34,.1)}.dialog-form .form-input:disabled{opacity:.6;cursor:not-allowed}.dialog-form .error-message{display:flex;align-items:center;gap:.5rem;padding:.75rem;background-color:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);color:#ef4444;font-size:.875rem}.dialog-submit-btn{width:100%;padding:.875rem 1.5rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.dialog-submit-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px rgba(241,90,34,.3)}.dialog-submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.dialog-footer-text{text-align:center;font-size:.875rem;color:var(--text-secondary);margin:0}.dialog-link-btn{background:none;border:none;color:var(--primary-color);font-weight:500;cursor:pointer;padding:0;text-decoration:none;transition:color .2s ease}.dialog-link-btn:hover:not(:disabled){text-decoration:underline}.dialog-link-btn:disabled{opacity:.6;cursor:not-allowed}.dialog-success{text-align:center;padding:2rem 1rem}@media (max-width: 480px){.dialog-content{padding:1.5rem}.dialog-title{font-size:1.25rem}.dialog-subtitle{font-size:.8rem}}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-md) var(--spacing-md) 2rem;background:var(--background)}.auth-card{background-color:var(--background-light);padding:var(--spacing-lg);border-radius:var(--radius-lg);width:100%;max-width:400px;box-shadow:0 4px 6px rgba(0,0,0,.1)}@media (min-width: 768px){.auth-card:not(.profile-complete){max-width:600px;padding:2.5rem 3rem}}@media (min-width: 1024px){.auth-card:not(.profile-complete){max-width:800px;padding:3rem 5rem}}@media (min-width: 1440px){.auth-card:not(.profile-complete){max-width:950px;padding:3.5rem 6rem}}.auth-card.profile-complete{max-width:600px}@media (min-width: 768px){.auth-card.profile-complete{max-width:800px;padding:3rem 4rem}}@media (min-width: 1024px){.auth-card.profile-complete{max-width:1000px;padding:3.5rem 5rem}}@media (min-width: 1440px){.auth-card.profile-complete{max-width:1200px;padding:4rem 6rem}}.progress-indicator{display:flex;align-items:center;justify-content:center;margin-bottom:3rem;gap:.75rem}.progress-step{width:1.75rem;height:1.75rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;color:var(--text-muted);background-color:var(--background);border:2px solid var(--border-color);transition:all .2s ease}.progress-step.active,.progress-step.completed{background-color:var(--primary-color);border-color:var(--primary-color);color:#fff}.progress-line{width:3rem;height:2px;background-color:var(--border-color);transition:all .2s ease}.progress-line.completed{background-color:var(--primary-color)}.form-navigation{display:flex;gap:.75rem;margin-top:2rem}.auth-container .auth-card .auth-button,.auth-container .auth-card .auth-button.btn,.auth-container .auth-card .auth-button.btn-primary,.auth-container .auth-card .auth-button.btn-secondary{padding:.75rem 1.5rem;border:1px solid transparent;border-radius:var(--radius-md);font-weight:500;font-size:.875rem;cursor:pointer;transition:opacity .2s ease;text-decoration:none;outline:none;min-height:2.75rem;display:inline-flex;align-items:center;justify-content:center;background-image:none;box-shadow:none;transform:none;position:static;overflow:visible}.auth-container .auth-card .auth-button:not(.secondary),.auth-container .auth-card .auth-button.btn-primary{background-color:var(--primary-color);color:#fff;border-color:var(--primary-color)}.auth-container .auth-card .auth-button:not(.secondary):hover,.auth-container .auth-card .auth-button.btn-primary:hover{background-color:var(--primary-color);opacity:.9;transform:none;box-shadow:none}.auth-container .auth-card .auth-button.secondary,.auth-container .auth-card .auth-button.btn-secondary{background-color:transparent;color:var(--text-secondary);border-color:var(--border-color)}.auth-container .auth-card .auth-button.secondary:hover,.auth-container .auth-card .auth-button.btn-secondary:hover{background-color:var(--background);color:var(--text-primary);border-color:var(--text-muted);transform:none;box-shadow:none}.auth-container .auth-card .auth-button:active,.auth-container .auth-card .auth-button:focus,.auth-container .auth-card .auth-button.btn:active,.auth-container .auth-card .auth-button.btn:focus{transform:none;box-shadow:none;background-image:none}.form-navigation .auth-button{flex:1}.auth-card.profile-complete .auth-title{font-size:1.5rem;font-weight:600;margin-bottom:2rem;text-align:center;color:var(--text-primary)}.auth-card.profile-complete .form-group{margin-bottom:1.5rem}.auth-card.profile-complete .form-label{font-size:.875rem;font-weight:500;color:var(--text-primary);margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.auth-card.profile-complete .form-input{padding:.75rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background-color:var(--background);color:var(--text-primary);font-size:.875rem;transition:border-color .2s ease}.auth-card.profile-complete .form-input:focus{border-color:var(--primary-color);outline:none}.language-option{padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background-color:var(--background);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:space-between;font-size:.875rem}.language-option:hover{border-color:var(--primary-color);background-color:var(--background-light)}.language-option.selected{border-color:var(--primary-color);background-color:var(--background-soft);color:var(--primary-color)}.language-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem}.error-message{background-color:#fff5f0;border:2px solid var(--orange-terracotta, #f15a22);color:var(--orange-terracotta, #f15a22);padding:.875rem 1rem;border-radius:var(--radius-md);margin:1rem 0;font-size:.875rem;font-weight:500;line-height:1.5;display:flex;align-items:center;gap:.5rem}.info-message{background:var(--background-light);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:1rem;margin-bottom:1rem;display:flex;align-items:flex-start;gap:.75rem;font-size:.875rem}.info-icon{width:1.25rem;height:1.25rem;border-radius:50%;background:var(--primary-color);color:#fff;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:.125rem}.toggle-languages-btn{color:var(--primary-color);background:none;border:none;cursor:pointer;font-size:.875rem;padding:.5rem 0;margin-top:.5rem;text-decoration:none;transition:opacity .2s ease}.toggle-languages-btn:hover{opacity:.8}.custom-language-input{margin-top:1rem;padding:1rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background-color:var(--background-light)}.custom-language-label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.875rem;color:var(--text-primary)}.custom-language-input-group{display:flex;gap:.5rem}.custom-language-text-input{flex:1;padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.875rem;background-color:var(--background);color:var(--text-primary);transition:border-color .2s ease}.custom-language-text-input:focus{border-color:var(--primary-color);outline:none}.custom-language-add-btn{padding:.5rem 1rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;cursor:pointer;transition:opacity .2s ease}.custom-language-add-btn:hover:not(.disabled){opacity:.9}.custom-language-add-btn.disabled{background-color:var(--text-muted);cursor:not-allowed;opacity:.6}.remove-custom-language{background:none;border:none;color:#ef4444;cursor:pointer;font-size:1rem;margin-left:.5rem;padding:0;line-height:1;transition:opacity .2s ease}.remove-custom-language:hover{opacity:.7}.auth-card h1{margin-bottom:var(--spacing-sm);color:var(--text-primary);font-size:2rem;font-weight:700}.auth-subtitle{color:var(--text-muted);margin-bottom:var(--spacing-md)}.auth-error{background-color:#fff5f0;color:var(--orange-terracotta, #f15a22);padding:var(--spacing-md);border:2px solid var(--orange-terracotta, #f15a22);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);font-weight:500}.auth-container .auth-card .auth-form{display:flex;flex-direction:column;gap:.5rem}.auth-container .auth-card .auth-form .form-group{display:flex;flex-direction:column;gap:.25rem}.auth-form label{color:var(--text-primary);font-weight:500}.auth-form .input{background-color:var(--background)}.auth-form .btn{margin-top:var(--spacing-md)}.auth-footer{margin-top:var(--spacing-md);text-align:center;color:var(--text-muted)}.auth-footer a{color:var(--primary-color);text-decoration:none;font-weight:500}.auth-footer a:hover{text-decoration:underline}.oauth-info{background:var(--background);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.oauth-user-info{display:flex;align-items:center;gap:var(--spacing-sm)}.oauth-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover}.oauth-name{font-weight:600;color:var(--text-primary);margin:0}.oauth-email{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.auth-loading{text-align:center;padding:var(--spacing-xl)}.auth-spinner{width:32px;height:32px;border:3px solid var(--border-light);border-top:3px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto var(--spacing-md)}.auth-error{text-align:center;padding:var(--spacing-xl)}.auth-error h2{color:var(--text-primary);margin-bottom:var(--spacing-sm)}.auth-error p{color:var(--text-secondary);margin-bottom:var(--spacing-md)}.auth-help{margin-top:20px;padding-top:20px;border-top:1px solid var(--border-color);font-size:.9rem;color:var(--text-secondary)}.auth-help p{margin:0 0 8px;font-weight:500}.auth-help ul{margin:0;padding-left:20px}.auth-help li{margin:4px 0}@media (max-width: 480px){.auth-container{padding:1rem}.auth-card{padding:1.5rem;padding-bottom:120px;margin:0}.auth-button{margin-bottom:2rem}.auth-card h1{font-size:1.75rem}}.auth-divider{margin:1rem 0;border-top:1px solid var(--border-color);position:relative}.auth-divider span{color:var(--text-secondary);background:var(--background-light);padding:0 1rem;position:absolute;top:-10px;left:50%;transform:translate(-50%);font-size:.875rem}.coming-soon-message{background:var(--background);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-lg);margin:var(--spacing-lg) 0}.coming-soon-message p{color:var(--text-primary);font-weight:500;margin-bottom:var(--spacing-md)}.coming-soon-message ul{color:var(--text-secondary);margin:0;padding-left:var(--spacing-lg)}.coming-soon-message li{margin:var(--spacing-xs) 0;color:var(--text-primary)}.auth-logo{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1rem}.auth-logo-main{height:200px;width:auto;object-fit:contain}.auth-logo-text{height:100px;width:auto;object-fit:contain}.auth-title{text-align:center;font-size:1.75rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem}.beta-badge{display:flex;justify-content:center;margin-bottom:.75rem}.beta-text{background-color:var(--primary-color);color:#fff;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.auth-subtitle{text-align:center;font-size:.875rem;color:var(--text-secondary);margin-bottom:1rem}@media (min-width: 768px){.auth-title{font-size:2.25rem;margin-bottom:.75rem}.auth-subtitle{font-size:1rem;margin-bottom:2.5rem}.form-label{font-size:1rem;margin-bottom:.75rem;line-height:1.5rem}.form-label-icon{width:1.5rem;height:1.5rem}.form-hint{font-size:.875rem;margin-bottom:1rem}}.auth-form-section-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:1.5rem;margin-top:0;line-height:1.5}@media (min-width: 768px){.auth-form-section-title{font-size:1.5rem;margin-bottom:2rem}}.auth-form input[type=radio]{width:1.25rem;height:1.25rem;margin:0;cursor:pointer;accent-color:var(--primary-color);flex-shrink:0}.auth-form input[type=radio]:focus{outline:2px solid var(--primary-color);outline-offset:2px}.auth-container .auth-card .form-group{margin-bottom:.625rem}@media (min-width: 768px){.form-group{margin-bottom:2rem}.auth-card.profile-complete .form-group:last-of-type{margin-bottom:2.5rem}}.form-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;color:var(--text-primary);margin-bottom:.5rem;line-height:1.5}.form-label-icon{width:1.25rem;height:1.25rem;flex-shrink:0;display:flex;align-items:center;justify-content:center}.form-hint{font-size:.75rem;color:var(--text-secondary);margin-bottom:.5rem;margin-top:.25rem;line-height:1.5}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:.75rem;width:1.25rem;height:1.25rem;color:var(--text-secondary);z-index:1}.form-input{width:100%;padding:.75rem .75rem .75rem 2.75rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background-color:var(--background);color:var(--text-primary);font-size:.875rem;transition:all .2s ease}@media (min-width: 768px){.form-input{padding:1rem 1rem 1rem 3rem;font-size:1rem}.input-icon{left:1rem;width:1.5rem;height:1.5rem}.password-toggle{right:1rem}.password-toggle svg{width:1.5rem;height:1.5rem}}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(139,105,20,.1)}.form-input::placeholder{color:var(--text-muted)}.password-toggle{position:absolute;right:.75rem;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center}.password-toggle svg{width:1.25rem;height:1.25rem}.password-toggle:hover{color:var(--text-primary)}.language-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.5rem;max-height:200px;overflow-y:auto;padding:.5rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background-color:var(--background)}@media (min-width: 640px){.language-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem;max-height:250px;padding:1rem}}@media (min-width: 768px){.language-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem;max-height:300px;padding:1.25rem}}@media (min-width: 1024px){.language-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;max-height:350px;padding:1.5rem}}.language-option{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;border:2px solid var(--border-color);border-radius:var(--radius-md);background-color:var(--background-light);cursor:pointer;transition:all .3s ease;font-size:.75rem;min-height:40px;box-shadow:0 1px 3px rgba(0,0,0,.1);position:relative;overflow:hidden}@media (min-width: 640px){.language-option{padding:.75rem 1rem;font-size:.875rem;min-height:44px}}@media (min-width: 768px){.language-option{padding:.875rem 1.25rem;font-size:.875rem;min-height:48px}}.language-option:hover{border-color:var(--primary-color);background-color:rgba(139,105,20,.08);transform:translateY(-1px);box-shadow:0 2px 6px rgba(0,0,0,.15)}.language-option.selected{border-color:var(--primary-color);background-color:var(--background-soft);color:var(--primary-color);font-weight:500}.language-option.main-language.selected{border:2px solid var(--primary-color);background-color:var(--background-hover);font-weight:600;color:var(--primary-color)}.language-option.main-language{border:1px solid var(--primary-color);background-color:var(--background-light);font-weight:500}.language-option.main-language:hover{border-color:var(--primary-color);background-color:var(--background-soft)}.language-name{font-weight:500}.language-check{width:1.25rem;height:1.25rem;color:var(--primary-color);background-color:rgba(255,255,255,.9);border-radius:50%;padding:.125rem;box-shadow:0 1px 3px rgba(0,0,0,.2);z-index:2}.error-message{display:flex;align-items:center;gap:.5rem;padding:.875rem 1rem;background-color:#fff5f0;border:2px solid var(--orange-terracotta, #f15a22);border-radius:var(--radius-md, 8px);color:var(--orange-terracotta, #f15a22);font-size:.875rem;margin-bottom:1rem;line-height:1.5;font-weight:500}.error-icon{width:1.25rem;height:1.25rem;flex-shrink:0;color:var(--orange-terracotta, #f15a22)}.success-message{padding:.875rem 1rem;background-color:var(--green-received, #d8e69c);border:2px solid var(--green-accent, #9cb847);border-radius:var(--radius-md, 8px);color:var(--text-primary, #1a1a1a);font-size:.875rem;margin-bottom:.75rem;line-height:1.5;display:flex;align-items:center;gap:.5rem;font-weight:500}.success-icon{color:var(--green-accent, #9cb847);flex-shrink:0;width:1.25rem;height:1.25rem}.auth-button{width:100%;padding:.875rem 1.5rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:1rem}@media (min-width: 768px){.auth-button{padding:1.125rem 2rem;font-size:1rem;margin-top:1.5rem}}.auth-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px rgba(139,105,20,.3)}.auth-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.profile-complete-info{margin-top:1.5rem;padding:1rem;background-color:rgba(139,105,20,.05);border:1px solid rgba(139,105,20,.1);border-radius:var(--radius-md);text-align:center}.profile-complete-info p{margin:0;font-size:.75rem;color:var(--text-secondary)}@media (max-width: 768px){.auth-card{padding-bottom:100px}.auth-button{margin-bottom:1.5rem}}@media (max-width: 480px){.auth-card{max-width:100%}.auth-logo{flex-direction:column;gap:.5rem}.auth-logo-main{height:160px;width:auto;object-fit:contain}.auth-logo-text{height:80px;width:auto;object-fit:contain}.language-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));max-height:150px}.language-option{font-size:.7rem;padding:.4rem .6rem}}.proficiency-grid{display:flex;flex-direction:column;gap:1.5rem;max-height:400px;overflow-y:auto;padding:1rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background-color:var(--background)}.proficiency-language-section{display:flex;flex-direction:column;gap:.75rem;padding:1rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background-color:var(--background-light)}.proficiency-language-name{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0;display:flex;align-items:center;gap:.5rem}.proficiency-levels{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.5rem}.proficiency-option{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);background-color:var(--background);cursor:pointer;transition:all .2s ease;font-size:.875rem;min-height:48px}.proficiency-option:hover{border-color:var(--primary-color);background-color:rgba(139,105,20,.05);transform:translateY(-1px)}.proficiency-option.selected{border-color:var(--primary-color);background-color:rgba(139,105,20,.1);color:var(--primary-color);font-weight:600;box-shadow:0 2px 4px rgba(139,105,20,.2)}.proficiency-input{width:1rem;height:1rem;accent-color:var(--primary-color);cursor:pointer}.proficiency-label{font-weight:500;cursor:pointer;flex:1}@media (min-width: 640px){.proficiency-levels{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.75rem}.proficiency-option{padding:1rem 1.25rem;font-size:.875rem}}@media (min-width: 768px){.proficiency-levels{grid-template-columns:repeat(2,1fr);gap:1rem}.proficiency-option{padding:1rem 1.5rem;font-size:.875rem}.proficiency-grid{max-height:500px;padding:1.5rem}.proficiency-language-section{padding:1.5rem}}@media (max-width: 480px){.proficiency-grid{gap:1rem;padding:.75rem}.proficiency-language-section{padding:.75rem}.proficiency-language-name{font-size:.875rem}.proficiency-levels{grid-template-columns:1fr;gap:.5rem}.proficiency-option{padding:.75rem;font-size:.8rem;min-height:40px}.proficiency-input{width:.875rem;height:.875rem}}.language-section{margin-bottom:1.5rem}.language-section-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 .75rem;padding:.5rem;background-color:var(--background);border-radius:var(--radius-sm);border:1px solid var(--border-color)}.proficiency-select{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);background-color:var(--background);color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all .2s ease}.proficiency-select:hover{border-color:var(--primary-color)}.proficiency-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px rgba(139,105,20,.2)}@media (min-width: 640px){.proficiency-select{padding:.875rem 1rem;font-size:.875rem}}@media (max-width: 480px){.language-section-title{font-size:.875rem;padding:.4rem}.proficiency-select{padding:.65rem;font-size:.8rem}}.proficiency-controls{display:flex;gap:.5rem;align-items:center;width:100%}.proficiency-select{flex:1}.quiz-button-inline{display:flex;align-items:center;gap:.375rem;padding:.5rem .875rem;background:var(--primary-50);border:1px solid var(--primary-200);border-radius:var(--radius-sm);color:var(--primary-700);font-size:.813rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.quiz-button-inline:hover{background:var(--primary-100);border-color:var(--primary-300);transform:translateY(-1px);box-shadow:0 2px 4px rgba(0,0,0,.1)}.quiz-icon-inline{width:16px;height:16px}.quiz-hint{display:flex;align-items:center;gap:.5rem;margin-top:1rem;padding:.75rem;background:var(--primary-50);border-radius:var(--radius-sm);color:var(--primary-800);font-size:.875rem;border:1px solid var(--primary-200)}.hint-icon{width:20px;height:20px;flex-shrink:0;color:var(--primary-600)}.auth-container .auth-card .consent-section{margin-top:.5rem;margin-bottom:.5rem;padding-top:.5rem;border-top:1px solid var(--border-light)}.auth-container .auth-card .consent-title{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:.375rem}.auth-container .auth-card .consent-item{margin-bottom:.25rem}.auth-container .auth-card .consent-notice{background-color:var(--background-light);border:1px solid var(--primary-300);border-radius:var(--radius-md);padding:.5rem;margin-bottom:.25rem}.auth-container .auth-card .consent-notice p{margin:0;line-height:1.3}.auth-container .auth-card .consent-label{display:flex;align-items:start;gap:.375rem;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;margin-bottom:0}.auth-container .auth-card .consent-checkbox{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:1.25rem;height:1.25rem;border:2px solid var(--border-color);border-radius:.25rem;background-color:var(--background);cursor:pointer;position:relative;flex-shrink:0;transition:all .2s ease;margin-top:.125rem}.auth-container .auth-card .consent-checkbox:hover{border-color:var(--primary-color);background-color:var(--background-light)}.auth-container .auth-card .consent-checkbox:checked{background-color:var(--primary-color);border-color:var(--primary-color)}.auth-container .auth-card .consent-checkbox:checked:after{content:"";position:absolute;left:.3rem;top:.1rem;width:.375rem;height:.625rem;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.auth-container .auth-card .consent-text{font-size:.875rem;color:var(--text-secondary);line-height:1.3;margin:0}.auth-container .auth-card .consent-text a{color:var(--primary-color);text-decoration:underline;font-weight:500}.auth-container .auth-card .consent-text a:hover{color:var(--primary-dark)}.oauth-section{margin:.75rem 0 .5rem}.oauth-button{width:100%;padding:.6rem 1rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;display:flex;align-items:center;justify-content:center;transition:all .2s ease;background-color:var(--background);margin-bottom:.25rem}.oauth-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,.1)}.oauth-loading-spinner{position:absolute;right:1rem;width:16px;height:16px;border:2px solid rgba(0,0,0,.1);border-top-color:var(--primary-600);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.home-container{min-height:100vh;min-height:100dvh;background:linear-gradient(180deg,#fffbf5 0%,var(--background-cream) 100%);overflow-x:hidden;width:100%;box-sizing:border-box}.home-container *{box-sizing:border-box}.home-header{position:fixed;top:0;left:0;right:0;background:#fffbf5;z-index:1000;padding:1rem 2rem;width:100%;box-sizing:border-box}.home-header-content{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:2rem}.home-nav{display:flex;align-items:center;gap:2rem}.section-content{max-width:1280px;margin:0 auto;padding:0 40px}.section-title{font-size:clamp(1.75rem,4vw,2.75rem);font-weight:800;color:var(--text-primary);text-align:center;margin:0 0 1.5rem;letter-spacing:-.02em}.section-subtitle{font-size:clamp(1rem,2vw,1.25rem);color:var(--text-secondary);text-align:center;max-width:700px;margin:0 auto 3rem;line-height:1.6}.hero-section{padding:140px 40px 80px;min-height:auto;display:flex;align-items:center;box-sizing:border-box;width:100%}.hero-content{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}.hero-text{z-index:2}.hero-title{font-size:clamp(2rem,5vw,3.5rem);font-weight:800;line-height:1.1;letter-spacing:-.02em;color:var(--text-primary);margin:0 0 1.5rem}.hero-title .highlight{color:var(--orange-primary)}.hero-subtitle{font-size:clamp(1rem,2vw,1.25rem);color:var(--text-secondary);line-height:1.5;margin:0 0 2rem;max-width:560px}.language-badges{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:2rem}.language-badge{background:var(--orange-light);color:var(--text-primary);padding:.625rem 1.25rem;border-radius:8px;font-size:1.0625rem;font-weight:600;border:1.5px solid rgba(241,90,34,.2);transition:all .2s ease}.language-badge:hover{background:rgba(241,90,34,.15);border-color:rgba(241,90,34,.3);transform:translateY(-1px)}.hero-cta-group{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem;align-items:flex-start}.cta-primary-group{display:flex;gap:1rem;flex-wrap:wrap;align-items:flex-start}.cta-with-link{display:flex;flex-direction:column;gap:.5rem;align-items:center}.pricing-link{font-size:.875rem;color:var(--text-secondary);font-weight:600;text-decoration:none;transition:all .2s ease}.pricing-link:hover{color:var(--orange-primary);text-decoration:underline}.btn-tutor{background:#9cb847;color:#fff;border:2px solid #9cb847;font-weight:600;padding:.875rem 1.75rem;border-radius:8px;text-decoration:none;transition:all .2s ease;display:inline-flex;align-items:center;gap:.5rem;box-shadow:0 2px 4px rgba(156,184,71,.2)}.btn-tutor:hover{background:#8aa93d;border-color:#8aa93d;transform:translateY(-1px);box-shadow:0 4px 8px rgba(156,184,71,.3)}.tutor-cta-wrapper{display:flex;flex-direction:column;gap:.5rem;align-items:center}.tutor-commission-badge{font-size:.8125rem;font-weight:700;color:#9cb847;background:rgba(156,184,71,.1);padding:.25rem .75rem;border-radius:6px;border:1.5px solid rgba(156,184,71,.3);letter-spacing:.02em}.btn-outline{background:transparent;color:var(--text-primary);border:2px solid var(--border-light);font-weight:600;padding:.875rem 1.75rem;border-radius:8px;text-decoration:none;transition:all .2s ease;display:inline-flex;align-items:center;gap:.5rem}.btn-outline:hover{border-color:var(--orange-primary);color:var(--orange-primary);background:rgba(241,90,34,.05)}.hero-image{display:flex;align-items:center;justify-content:center;position:relative}.teababe-hero{width:100%;max-width:500px;height:auto;filter:drop-shadow(0 20px 40px rgba(241,90,34,.15))}.hero-logos{width:100%;max-width:500px;display:flex;flex-direction:column;align-items:center;gap:0}.hero-logo-text{width:100%;max-width:400px;height:auto;filter:drop-shadow(0 20px 40px rgba(156,184,71,.2));object-fit:contain;object-position:center;margin:0;padding:0;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}.hero-logo-teabag{width:35%;height:auto;filter:drop-shadow(0 10px 20px rgba(156,184,71,.3));margin-top:.5rem}.languages-section{padding:80px 40px;background:var(--background-white)}.languages-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1.5rem;max-width:900px;margin:0 auto 2rem}.language-card{background:var(--orange-light);padding:2rem 1rem;border-radius:16px;text-align:center;transition:all .3s ease;border:2px solid transparent}.language-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--orange-primary)}.language-flag{font-size:3rem;display:block;margin-bottom:.75rem}.language-name{font-size:1rem;font-weight:600;color:var(--text-primary)}.coming-soon{text-align:center;color:var(--text-tertiary);font-size:.9rem;font-style:italic}.features-section{padding:80px 40px;background:linear-gradient(180deg,var(--background-white) 0%,var(--background-cream) 100%);overflow:hidden}.features-container{max-width:1600px;margin:0 auto;display:grid;grid-template-columns:250px 1fr 250px;gap:4rem;align-items:center}.teababe-left,.teababe-right{display:flex;align-items:center;justify-content:center}.teababe-side{width:100%;max-width:220px;height:auto;filter:drop-shadow(0 10px 30px rgba(241,90,34,.15));opacity:0;transition:opacity .6s ease}.teababe-side.visible{opacity:1;animation:slideInLeft .8s ease forwards}.teababe-right .teababe-side.visible{animation:slideInRight .8s ease forwards}.features-content{max-width:800px;margin:0 auto}.features-list{display:flex;flex-direction:column;gap:2rem;margin-top:3rem}.feature-card{background:var(--background-white);padding:2.5rem 2rem;border-radius:16px;text-align:center;transition:all .3s ease;border:2px solid var(--border-light);position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:center}.feature-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl)}.feature-card.accent-orange:hover{border-color:var(--orange-primary)}.feature-card.accent-blue:hover{border-color:var(--blue-learning)}.feature-card.accent-green:hover{border-color:var(--green-accent)}.feature-icon-wrapper{width:64px;height:64px;margin:0 auto 1rem;display:flex;align-items:center;justify-content:center;background:var(--background-light);border-radius:16px}.accent-orange .feature-icon-wrapper{background:rgba(241,90,34,.1);color:var(--orange-primary)}.accent-blue .feature-icon-wrapper{background:rgba(80,86,165,.1);color:var(--blue-learning)}.accent-green .feature-icon-wrapper{background:rgba(156,184,71,.1);color:var(--green-accent)}.feature-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 1rem}.feature-description{font-size:1.125rem;color:var(--text-secondary);line-height:1.6;margin:0;max-width:600px}.steps-section{padding:80px 40px;background:var(--background-light)}.steps-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:3rem;margin-top:3rem;position:relative}.step-card{background:var(--background-white);padding:2.5rem 2rem;border-radius:20px;text-align:center;position:relative;border:2px solid var(--border-light);transition:all .3s ease}.step-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--orange-primary)}.step-number{position:absolute;top:-20px;left:50%;transform:translate(-50%);width:56px;height:56px;background:var(--orange-primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.75rem;font-weight:700;box-shadow:0 4px 12px rgba(241,90,34,.3)}.step-image{width:80px;height:80px;margin:1.5rem auto 1rem;display:flex;align-items:center;justify-content:center}.step-image img{max-width:100%;max-height:100%;object-fit:contain}.step-icon{color:var(--blue-learning);margin:0 auto 1rem;display:flex;align-items:center;justify-content:center}.step-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0 0 .75rem}.step-description{font-size:.95rem;color:var(--text-secondary);line-height:1.6;margin:0}.community-section{padding:80px 40px;background:linear-gradient(135deg,rgba(251,193,132,.2),rgba(216,230,156,.2))}.community-section .section-content{text-align:center}.community-image{max-width:400px;margin:0 auto 2rem}.community-image img{width:100%;height:auto;filter:drop-shadow(0 10px 30px rgba(0,0,0,.1))}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;max-width:800px;margin:2rem auto 0}.home-stats-section{padding:0 40px 60px;background:var(--background-white)}.home-stats-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;max-width:900px;margin:0 auto}.home-stat-card{background:var(--background-white);padding:2.5rem 1.5rem;border-radius:16px;text-align:center;border:2px solid var(--border-light);box-shadow:var(--shadow-md)}.home-stat-number{font-size:3rem;font-weight:800;color:var(--orange-primary);margin:0 0 .5rem;line-height:1;letter-spacing:-.02em}.home-stat-label{font-size:1.125rem;color:var(--text-primary);font-weight:600}.screenshots-section{padding:80px 40px;background:var(--background-white)}.screenshots-container{max-width:1400px;margin:0 auto}.screenshots-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;margin-top:3rem}.screenshot-card{background:var(--background-cream);border-radius:16px;overflow:hidden;transition:all .3s ease;border:2px solid var(--border-light);display:flex;flex-direction:column}.screenshot-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl);border-color:var(--orange-primary)}.screenshot-image-wrapper{width:100%;aspect-ratio:16 / 9;overflow:hidden;background:var(--background-light);display:flex;align-items:center;justify-content:center}.screenshot-image{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.screenshot-card:hover .screenshot-image{transform:scale(1.05)}.screenshot-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:1.5rem 1.5rem .75rem;line-height:1.3}.screenshot-description{font-size:1rem;color:var(--text-secondary);line-height:1.6;margin:0 1.5rem 1.5rem;flex-grow:1}.screenshots-grid.visible .screenshot-card{animation:scaleIn .6s ease forwards}.testimonials-section{padding:80px 40px;background:linear-gradient(135deg,var(--background-cream) 0%,rgba(156,184,71,.1) 100%)}.testimonials-container{max-width:1200px;margin:0 auto}.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:2rem;margin-top:3rem}.testimonial-card{background:var(--background-white);padding:2rem;border-radius:16px;border:2px solid var(--border-light);transition:all .3s ease;display:flex;flex-direction:column;gap:1.5rem;position:relative}.testimonial-card:before{content:'"';position:absolute;top:1rem;left:1.5rem;font-size:4rem;font-weight:800;color:rgba(156,184,71,.15);line-height:1;font-family:Georgia,serif}.testimonial-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--green-accent)}.testimonial-content{flex-grow:1;position:relative;z-index:1}.testimonial-quote{font-size:1.125rem;color:var(--text-primary);line-height:1.7;margin:0;font-style:italic}.testimonial-original{font-size:.9375rem;color:var(--text-tertiary);line-height:1.6;margin:1rem 0 0;padding-top:1rem;border-top:1px solid rgba(0,0,0,.05)}.testimonial-author{display:flex;align-items:center;gap:1rem;padding-top:1rem;border-top:1px solid var(--border-light)}.testimonial-avatar{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--green-accent) 0%,var(--orange-primary) 100%);display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700;color:#fff;flex-shrink:0;box-shadow:0 2px 8px rgba(156,184,71,.3)}.testimonial-avatar-img{width:60px;height:60px;border-radius:50%;object-fit:cover;flex-shrink:0;box-shadow:0 2px 8px rgba(156,184,71,.3);border:2px solid var(--background-white)}.testimonial-info{display:flex;flex-direction:column;gap:.25rem}.testimonial-name{font-size:1.125rem;font-weight:700;color:var(--text-primary)}.testimonial-role{font-size:.9375rem;color:var(--text-secondary);line-height:1.4}.testimonials-grid.visible .testimonial-card{animation:scaleIn .6s ease forwards}.final-cta-section{padding:80px 40px;background:linear-gradient(135deg,var(--background-cream) 0%,var(--orange-light) 100%)}.cta-content{max-width:700px;margin:0 auto;text-align:center}.cta-image{max-width:350px;margin:0 auto 2rem}.cta-image img{width:100%;height:auto;filter:drop-shadow(0 10px 30px rgba(241,90,34,.2))}.cta-title{font-size:clamp(2rem,4vw,3rem);font-weight:800;color:var(--text-primary);margin:0 0 1rem;letter-spacing:-.02em}.cta-subtitle{font-size:1.25rem;color:var(--text-secondary);margin:0 0 2rem;line-height:1.5}.cta-button{font-size:1.125rem;padding:1rem 2.5rem;box-shadow:0 4px 16px rgba(241,90,34,.3)}.cta-button:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(241,90,34,.4)}.cta-notice{margin-top:1rem;font-size:.9rem;color:var(--text-tertiary);font-style:italic}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(50px)}to{opacity:1;transform:translate(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-50px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.animate-fade-in-up{opacity:0;animation:fadeInUp .8s ease forwards}.animate-fade-in-up.delay-100{animation-delay:.1s}.animate-fade-in-up.delay-150{animation-delay:.15s}.animate-fade-in-up.delay-200{animation-delay:.2s}.animate-slide-in-right{opacity:0;animation:slideInRight .8s ease forwards}.animate-slide-in-left{opacity:0;animation:slideInLeft .8s ease forwards}.section-title.visible,.section-subtitle.visible,.coming-soon.visible{animation:fadeInUp .6s ease forwards}.languages-grid.visible .language-card,.features-list.visible .feature-card,.steps-container.visible .step-card{animation:scaleIn .6s ease forwards}.community-section .section-content.visible,.cta-content.visible{animation:fadeInUp .8s ease forwards}.learning-paths-section{padding:4rem 2rem;background:#fff}@media (max-width: 768px){.home-container,.home-container>*,.home-container section,.home-container header,.home-container footer,.home-container div{max-width:100%;box-sizing:border-box}.home-container{width:100%;padding:0;overflow-x:hidden}.home-header,.hero-section,.screenshots-section,.home-stats-section,.testimonials-section,.features-section,.learning-paths-section,.final-cta-section,section,footer{width:100%;padding-left:1rem;padding-right:1rem;box-sizing:border-box}.home-header{padding-top:.75rem;padding-bottom:.75rem}.home-header-content{gap:.5rem;width:100%}.home-nav a:nth-child(3),.home-nav a:nth-child(4){display:none}.home-nav{gap:.75rem}.home-nav a,.home-nav>div{font-size:.875rem;white-space:nowrap}.home-header img[alt=FluenTea]{display:none}.hero-section{padding-top:100px;padding-bottom:60px}.hero-content{width:100%;padding:0}}@media (max-width: 480px){.home-header,.hero-section,section,footer{padding-left:.75rem;padding-right:.75rem}.home-nav a:not(:first-child):not(:nth-child(2)){display:none}.home-nav>div{display:none}.home-nav{gap:.5rem}.home-header img[alt=FluenTea]{display:none}}@media (max-width: 1280px){.features-container{grid-template-columns:180px 1fr 180px;gap:2rem}.teababe-side{max-width:160px}}@media (max-width: 1024px){.hero-content{grid-template-columns:1fr;gap:40px;text-align:center}.hero-text{order:2}.hero-image{order:1}.hero-subtitle{max-width:100%;margin-left:auto;margin-right:auto}.hero-cta-group{justify-content:center}.features-container{grid-template-columns:1fr;gap:2rem}.teababe-left,.teababe-right{display:none}.features-list,.steps-container{gap:2rem}.stats-grid{grid-template-columns:1fr}}@media (max-width: 768px){.home-language-selector{top:16px;right:16px}.hero-section{padding:80px .5rem 60px;min-height:auto;width:100%;max-width:100%;box-sizing:border-box}.hero-content{width:100%;max-width:100%;padding:0;box-sizing:border-box;gap:2rem}.hero-text,.hero-image{width:100%;max-width:100%}.section-content{padding:0 .5rem;width:100%;max-width:100%;box-sizing:border-box}.languages-section,.features-section,.steps-section,.community-section,.screenshots-section,.testimonials-section,.final-cta-section{padding:60px 24px}.home-stats-section{padding:0 24px 60px}.home-stats-container{grid-template-columns:1fr;gap:1.5rem}.home-stat-card{padding:2rem 1.5rem}.home-stat-number{font-size:2.5rem}.home-stat-label{font-size:1rem}.screenshots-grid,.testimonials-grid{grid-template-columns:1fr;gap:1.5rem}.testimonial-card{padding:1.5rem}.hero-title{font-size:2.25rem}.hero-subtitle{font-size:1.125rem}.language-badges{justify-content:center}.language-badge{font-size:1rem;padding:.5625rem 1.125rem}.hero-cta-group{align-items:center}.cta-primary-group{flex-direction:column;align-items:center;width:100%}.cta-with-link{align-items:center;width:100%}.btn-large{width:100%;max-width:280px}.btn-outline{width:100%;max-width:280px;justify-content:center}.tutor-cta-wrapper{width:100%;align-items:center}.btn-tutor{width:100%;max-width:280px;justify-content:center}.pricing-link{text-align:center}.teababe-hero{max-width:320px}.hero-logos,.hero-logo-text{max-width:300px}.hero-logo-teabag{width:32%;margin-top:.375rem}.languages-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem}.language-card{padding:1.5rem .75rem}.language-flag{font-size:2.5rem}.features-list{gap:1.5rem}.steps-container{gap:2rem}.community-image,.cta-image{max-width:280px}.cta-title{font-size:2rem}.cta-subtitle{font-size:1.125rem}}@media (max-width: 480px){.hero-section{padding:80px .5rem 60px}.section-content{padding:0 .5rem}.section-title{font-size:1.75rem}.hero-title{font-size:2rem}.teababe-hero{max-width:260px}.hero-logos,.hero-logo-text{max-width:240px}.hero-logo-teabag{width:30%;margin-top:.25rem}.languages-grid{grid-template-columns:repeat(2,1fr)}}.early-access-hero-link{margin-top:1.5rem;text-align:center}.early-access-hero-link p{font-size:.9375rem;color:var(--color-neutral-600);margin:0}.early-access-link{color:var(--color-primary);font-weight:600;text-decoration:none;transition:color .2s ease}.early-access-link:hover{color:var(--color-primary-dark);text-decoration:underline}.early-access-section{padding:2rem 1rem;background:#fff}.early-access-container{max-width:800px;margin:0 auto}.early-access-subtitle{text-align:center;font-size:1.0625rem;color:var(--color-neutral-600);margin:.75rem 0 1.5rem;line-height:1.5}.early-access-form-wrapper{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px rgba(0,0,0,.1)}.early-access-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:.75rem;margin:0 auto 1.5rem;max-width:800px;background:none}.early-access-option-card{background:none;border:2px solid var(--color-neutral-200);border-radius:8px;padding:1rem;transition:border-color .2s ease}.early-access-option-card:hover{border-color:var(--color-primary);background:none}.early-access-option-card .option-icon{margin:0 auto .5rem;display:block;background:none}.early-access-option-card .option-icon.heart-icon{color:#f97316;background:none}.early-access-option-card .option-icon.briefcase-icon{color:#3b82f6;background:none}.early-access-option-card h3{color:var(--color-primary);font-size:1.125rem;margin:0 0 .375rem;font-weight:600;text-align:center}.early-access-option-card p{color:var(--color-neutral-600);font-size:.875rem;line-height:1.4;margin:0;text-align:left}.early-access-form{display:flex;flex-direction:column;gap:1rem}.early-access-form .form-group{display:flex;flex-direction:column;gap:.375rem;margin-bottom:0!important}.early-access-form .form-group label{font-weight:600;color:var(--color-neutral-700);font-size:.875rem;margin-bottom:0!important}.form-input,.form-textarea{padding:.625rem .875rem;border:2px solid var(--color-neutral-300);border-radius:6px;font-size:.9375rem;font-family:inherit;transition:border-color .2s ease}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--color-primary)}.form-textarea{resize:vertical;min-height:70px}.early-access-form .interest-checkboxes{display:flex;gap:1rem;flex-wrap:wrap;align-items:center;margin:0!important}.early-access-form .checkbox-label{display:inline-flex!important;align-items:center!important;gap:.5rem!important;cursor:pointer;font-weight:400!important;color:var(--color-neutral-700);font-size:.9375rem!important;margin:0!important;padding:0!important}.early-access-form .checkbox-label input[type=checkbox]{width:1.125rem!important;height:1.125rem!important;cursor:pointer;accent-color:var(--color-primary)!important;flex-shrink:0!important;margin:0!important;position:static!important;opacity:1!important;pointer-events:auto!important}.early-access-form .checkbox-label span{-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1.2!important;white-space:nowrap}.form-actions{display:flex;flex-direction:column;gap:.75rem;margin-top:.5rem}.form-actions button{width:100%;justify-content:center}.early-access-form .btn-secondary{background:#9cb847!important;color:#fff!important;border:2px solid #9cb847!important;box-shadow:0 2px 4px rgba(156,184,71,.2)!important}.early-access-form .btn-secondary:hover:not(:disabled){background:#8aa33d!important;border-color:#8aa33d!important;box-shadow:0 4px 8px rgba(156,184,71,.3)!important;transform:translateY(-1px)}.priority-note{text-align:center;font-size:.8125rem;color:var(--color-neutral-600);margin:0;font-weight:500}.disclaimer-text{text-align:center;font-size:.6875rem;color:var(--color-neutral-500);margin:.375rem 0 0;font-style:italic;line-height:1.4;padding:.625rem;background:var(--color-neutral-50);border-radius:4px;border:1px solid var(--color-neutral-200)}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:.75rem 1rem;border-radius:6px;font-size:.9375rem}.early-access-success{background:#f0fdf4;border:2px solid #86efac;border-radius:8px;padding:2.5rem;text-align:center}.early-access-success h3{color:var(--color-success);font-size:1.5rem;margin:0 0 1rem}.early-access-success p{color:var(--color-neutral-600);font-size:1.125rem;margin:0 0 1.5rem;line-height:1.6}@media (max-width: 768px){.early-access-section{padding:1.5rem 1rem}.early-access-subtitle{font-size:1rem;margin:.5rem 0 1rem}.early-access-form-wrapper{padding:1rem}.early-access-options{grid-template-columns:1fr;gap:.625rem}.early-access-option-card{padding:.875rem}.early-access-option-card h3{font-size:1.0625rem}.early-access-option-card p{font-size:.8125rem}.interest-checkboxes{flex-direction:row;gap:.875rem}.form-actions{gap:.625rem;align-items:center}.disclaimer-text{font-size:.625rem;padding:.5rem}}.language-selector-v2{position:relative}.lang-btn{display:flex;align-items:center;justify-content:center;padding:6px 14px;background:var(--white);border:1px solid var(--gray-300);border-radius:6px;cursor:pointer;transition:all .15s ease;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;min-width:60px;height:32px;font-size:13px;font-weight:500;color:var(--gray-700);letter-spacing:.3px}.lang-btn:hover{background:var(--gray-50);border-color:var(--gray-400);color:var(--gray-900)}.lang-btn:focus{outline:none;border-color:var(--blue-500);box-shadow:0 0 0 2px rgba(59,130,246,.15)}.lang-btn.active{background:var(--gray-50);border-color:var(--gray-400)}.lang-btn.navbar{height:40px;padding:0 12px;font-size:13px;font-weight:700;min-width:55px;background:transparent;border:none;border-radius:10px;color:#6b7280;letter-spacing:.5px;transition:all .2s ease}.lang-btn.navbar:hover{background:rgba(156,184,71,.12);color:#9cb847;border:none;transform:scale(1.05)}.lang-btn.navbar.active{background:rgba(156,184,71,.12);color:#9cb847;border:none}.lang-btn.homepage{height:36px;padding:8px 16px;font-size:14px;min-width:72px}.lang-btn.mobile{height:32px;padding:6px 12px;font-size:12px;min-width:50px;background:var(--white);border:1px solid var(--gray-300);color:var(--gray-700)}.lang-menu{position:absolute;top:calc(100% + 4px);right:0;background:var(--white);border:1px solid var(--gray-200);border-radius:8px;box-shadow:var(--shadow-sm);padding:4px;min-width:180px;z-index:1000;animation:slideDown .12s ease-out}.lang-item{display:flex;align-items:center;gap:12px;width:100%;padding:8px 12px;background:transparent;border:none;border-radius:4px;cursor:pointer;transition:background .1s ease;font-family:inherit;text-align:left}.lang-item:hover{background:var(--gray-50)}.lang-item.selected{background:var(--blue-50)}.lang-item-code{font-weight:600;font-size:12px;color:var(--gray-700);min-width:24px;letter-spacing:.3px}.lang-item.selected .lang-item-code{color:var(--blue-700)}.lang-item-name{font-size:13px;color:var(--gray-600);flex:1}.lang-item.selected .lang-item-name{color:var(--blue-600)}@keyframes slideDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 640px){.lang-btn{height:30px;padding:5px 12px;font-size:12px;min-width:52px}.lang-menu{min-width:160px}.lang-item{padding:7px 10px}.lang-item-code{font-size:11px}.lang-item-name{font-size:12px}}.unsubscribe-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f5f7fa,#e9ecef);padding:2rem}.unsubscribe-container{background:#fff;border-radius:16px;box-shadow:0 10px 40px rgba(0,0,0,.1);max-width:600px;width:100%;padding:3rem;text-align:center}.unsubscribe-logo{margin-bottom:2rem}.unsubscribe-logo img{height:60px;width:auto}.unsubscribe-content{margin-bottom:2rem}.unsubscribe-content h1{font-size:2rem;font-weight:700;margin:1rem 0;color:#1a1a1a}.unsubscribe-content .message{font-size:1.1rem;color:#666;margin:1rem 0;line-height:1.6}.status-icon{margin:0 auto;display:block}.unsubscribe-content.success .status-icon{color:var(--primary-color, #9cb847)}.unsubscribe-content.error .status-icon{color:var(--red-500, #ef4444)}.loading-spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid var(--primary-color, #9cb847);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.info-box{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1.5rem;margin:1.5rem 0;text-align:left}.info-box p{margin:.5rem 0;color:#374151;font-size:.95rem}.info-box strong{font-weight:600;color:#1f2937}.actions{display:flex;flex-direction:column;gap:1rem;margin:2rem 0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none}.btn.primary{background:var(--primary-color, #9cb847);color:#fff}.btn.primary:hover{background:#8aa63d;transform:translateY(-2px);box-shadow:0 4px 12px rgba(156,184,71,.3)}.btn.secondary{background:#fff;color:#374151;border:1px solid #d1d5db}.btn.secondary:hover{background:#f9fafb;border-color:#9ca3af}.help-text{font-size:.9rem;color:#6b7280;font-style:italic;margin-top:1rem}.unsubscribe-footer{margin-top:3rem;padding-top:2rem;border-top:1px solid #e5e7eb;color:#9ca3af;font-size:.875rem}.unsubscribe-footer p{margin:.25rem 0}.unsubscribe-footer a{color:var(--primary-color, #9cb847);text-decoration:none}.unsubscribe-footer a:hover{text-decoration:underline}@media (max-width: 640px){.unsubscribe-page{padding:1rem}.unsubscribe-container{padding:2rem 1.5rem}.unsubscribe-content h1{font-size:1.5rem}.unsubscribe-content .message{font-size:1rem}.actions{flex-direction:column}}.message{display:flex;align-items:flex-start;margin:0;padding:0;animation:none;justify-content:flex-start}.message.sent{justify-content:flex-end}.message-bubble{max-width:75%;margin:0;padding:.5rem .75rem;border-radius:16px;position:relative;white-space:pre-wrap;overflow-wrap:break-word;-webkit-hyphens:none;hyphens:none;line-height:1.4;font-size:.95rem;box-shadow:var(--shadow-sm);transition:none;overflow:visible;display:inline-block}.message-bubble.own{background:var(--message-sent-bg);color:var(--text-primary);border-bottom-right-radius:4px;box-shadow:var(--shadow-md);border:none}.message-bubble.other{background:var(--message-received-bg);color:var(--text-primary);border-bottom-left-radius:4px;border:none;box-shadow:var(--shadow-sm)}.message-bubble.ai{background:var(--tea-green-600);color:#f0f4e6;border-bottom-left-radius:4px;box-shadow:var(--shadow-md)}.message-bubble.system{background:var(--primary-500);color:#fff;margin:0;text-align:center;border-radius:16px;font-style:italic;font-size:.85rem;max-width:95%;border:1px solid var(--orange-400)}.message-bubble.error{background:var(--red-500);color:#f0f4e6;margin:0;text-align:center;border-radius:16px;font-size:.85rem;max-width:95%}.message-bubble:hover{box-shadow:var(--shadow-sm)}.message-bubble.own:hover{box-shadow:var(--shadow-md);border-color:var(--primary-700)}.message-content{margin:0;white-space:pre-wrap;overflow-wrap:break-word;-webkit-hyphens:none;hyphens:none;word-spacing:normal;line-height:1.5;position:relative;z-index:1;display:inline}.message-time{font-size:.85rem;color:#4a5568;font-weight:500;margin-top:0;text-align:left;opacity:1;letter-spacing:.02em;flex-shrink:0;white-space:nowrap}.message-bubble.other .message-time{color:var(--text-secondary);text-align:left;opacity:1;font-weight:500}.message-bubble.system .message-time,.message-bubble.error .message-time{color:#e8f0d8;text-align:center;opacity:1;font-weight:500}.message-actions{display:flex;gap:.5rem;margin-top:0;justify-content:flex-end;opacity:1;transition:opacity .2s ease;flex-shrink:0}.message-bubble.other .message-actions{justify-content:flex-start}.message-bubble .action-btn{background:#fff;color:var(--text-primary);border:none;border-radius:8px;padding:.25rem .5rem;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.25rem;opacity:1;box-shadow:0 2px 4px rgba(0,0,0,.1);position:relative;z-index:10}.message-bubble .action-btn:hover{background:#fff;box-shadow:0 4px 8px rgba(0,0,0,.15);transform:translateY(-2px)}.action-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.message-bubble .action-btn.translate{background:#fff;color:var(--green-accent);border:none;font-weight:600}.message-bubble .action-btn.translate:hover{background:#fff;color:var(--green-700);box-shadow:0 4px 8px rgba(0,0,0,.15);transform:translateY(-2px)}.message-bubble .action-btn.suggestions{background:#fff;color:var(--orange-primary);border:none;font-weight:600}.message-bubble .action-btn.suggestions:hover{background:#fff;color:var(--orange-700);box-shadow:0 4px 8px rgba(0,0,0,.15);transform:translateY(-2px)}.action-btn.voice{background:var(--red-500);color:var(--text-on-primary);border-color:var(--red-500)}.action-btn.voice:hover{background:var(--red-600);border-color:var(--red-600)}.action-btn.loading{position:relative;color:transparent}.action-btn.loading:after{content:"";position:absolute;top:50%;left:50%;width:12px;height:12px;margin:-6px 0 0 -6px;border:2px solid var(--border-color);border-top:2px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}.message-bubble.error .message-content,.message-bubble.error .message-time,.message-bubble.error .action-btn{color:var(--red-500)}.message-bubble.ai .message-actions{justify-content:flex-start}.message-bubble.ai .action-btn{background:rgba(255,255,255,.1);color:var(--text-on-primary);border-color:rgba(255,255,255,.2)}.message-bubble.ai .action-btn:hover{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.3)}@media (max-width: 768px){.message-bubble{max-width:92%;font-size:.9rem;padding:.4rem .6rem}.message-actions{opacity:1;gap:.25rem}.action-btn{padding:.2rem .4rem;font-size:.7rem}.message-bubble.system,.message-bubble.error{max-width:95%;font-size:.8rem}}.action-btn:focus{outline:2px solid var(--primary-color);outline-offset:2px}@media (prefers-contrast: high){.message-bubble,.action-btn{border:2px solid var(--border-dark)}}.message-meta{display:inline-flex;align-items:center;gap:.5rem;margin-top:.125rem;font-size:.75rem;color:var(--text-secondary);float:right;clear:both}.message.sent .message-meta{justify-content:flex-end}.message-status{display:flex;align-items:center;gap:.25rem;opacity:1}.message-status .icon{font-size:.875rem}.message-avatar{width:32px;height:32px;border-radius:50%;background:var(--primary-500);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:500;font-size:.875rem;margin:0 .5rem}.message-user{margin-left:auto;margin-right:0}.message-ai{margin-right:auto;margin-left:0}.message-ai-tutor{max-width:95%;padding:.75rem 1rem;position:relative;color:#fff;line-height:1.4;background:rgba(45,45,55,.95);border:1px solid rgba(255,255,255,.1);margin-right:2rem;border-radius:1rem 1rem 1rem .25rem;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:none;hyphens:none}.message-ai-tutor .message-content{font-size:.95rem;white-space:pre-wrap;word-break:break-word;color:#fff}.message-timestamp{font-size:.75rem;color:rgba(255,255,255,.6);margin-top:4px;text-align:left;white-space:nowrap;display:block;width:100%}.message-user .message-timestamp{color:rgba(255,255,255,.8);text-align:right;white-space:nowrap}.typing-indicator{display:flex;align-items:center;gap:4px;padding:8px 0}.typing-indicator span{width:8px;height:8px;background-color:#4a90e2;border-radius:50%;display:inline-block;animation:bounce 1.4s infinite ease-in-out}.typing-indicator span:nth-child(1){animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.streaming .message-content{position:relative;overflow:visible}.message.streaming .message-content:after{content:"";position:absolute;top:0;right:0;bottom:0;width:2px;background:var(--primary-500);animation:streamingCursor 1s ease-in-out infinite}@keyframes streamingCursor{0%,50%{opacity:1}51%,to{opacity:0}}.message.streaming{animation:streamingPulse 2s ease-in-out infinite}@keyframes streamingPulse{0%,to{opacity:.9}50%{opacity:1}}.message-bubble .message-meta .message-actions .translate-btn,.message-bubble .message-meta .message-actions .suggestions-btn{background:#fff;background-color:#fff;border:none;border-radius:8px;padding:0;margin:0;cursor:pointer;opacity:1;transition:all .2s ease;flex-shrink:0;color:var(--orange-600);box-shadow:0 2px 4px rgba(0,0,0,.1);width:32px;height:32px;min-width:32px;max-width:32px;min-height:32px;max-height:32px;display:flex;align-items:center;justify-content:center;box-sizing:border-box;line-height:1;font-size:0;gap:0;position:relative;z-index:10;visibility:visible}.message-bubble .message-meta .message-actions .translate-btn{margin-left:.5rem;background:#fff;border:none;color:var(--green-accent, #98b344);box-shadow:0 2px 4px rgba(0,0,0,.1);font-weight:600}.message-bubble .message-meta .message-actions .suggestions-btn{margin-left:.25rem}.message-bubble .message-meta .message-actions .translate-btn .icon,.message-bubble .message-meta .message-actions .suggestions-btn .icon{width:20px;height:20px;flex-shrink:0}.message-bubble .message-meta .message-actions .translate-btn svg,.message-bubble .message-meta .message-actions .suggestions-btn svg{color:inherit}.message-bubble .message-meta .message-actions .translate-btn:hover{background:#fff;transform:translateY(-2px);box-shadow:0 4px 8px rgba(0,0,0,.15)}.message-bubble .message-meta .message-actions .suggestions-btn:hover{background:#fff;color:var(--orange-700);transform:translateY(-2px);box-shadow:0 4px 8px rgba(0,0,0,.15)}.message-bubble .message-meta .message-actions .translate-btn:active,.message-bubble .message-meta .message-actions .suggestions-btn:active{transform:translateY(0);box-shadow:0 1px 2px rgba(249,115,22,.3)}.message-bubble .message-meta .message-actions .translate-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:0 1px 2px rgba(0,0,0,.1);background:#fff;color:var(--green-accent, #98b344);animation:pulse 1.5s ease-in-out infinite}.message-bubble .message-meta .message-actions .suggestions-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:0 1px 2px rgba(0,0,0,.1);background:#fff;color:var(--orange-600);animation:pulse 1.5s ease-in-out infinite}.message-bubble .message-meta .message-actions .translate-btn:disabled:hover{transform:none;box-shadow:0 1px 2px rgba(0,0,0,.1);background:#fff;color:var(--green-accent, #98b344)}.message-bubble .message-meta .message-actions .suggestions-btn:disabled:hover{transform:none;box-shadow:0 1px 2px rgba(0,0,0,.1);background:#fff;color:var(--orange-600)}.message-sender{font-size:.75rem;color:rgba(255,255,255,.7);margin-bottom:.25rem;font-weight:500}.voice-note-info{margin-top:.5rem;font-size:.75rem;color:rgba(255,255,255,.7);font-style:italic}.translation-content{margin-top:.75rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.2)}.translation-header{display:flex;align-items:center;gap:.25rem;margin-bottom:.5rem;font-size:.75rem;color:rgba(255,255,255,.7)}.translation-text{font-size:.875rem;color:rgba(255,255,255,.9)}.message-error{margin-top:.5rem;padding:.5rem;background:rgba(255,77,77,.2);border:1px solid rgba(255,77,77,.3);border-radius:.5rem}.error-content{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:#ff4d4d}.retry-btn{background:none;border:none;color:#ff4d4d;text-decoration:underline;cursor:pointer;font-size:.75rem}.retry-btn:hover{color:#f66}.ai-indicator,.streaming-indicator{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;font-size:.75rem;color:rgba(255,255,255,.7)}.ai-pulse,.streaming-pulse{width:8px;height:8px;background-color:var(--primary-600);border-radius:50%;animation:pulse 2s infinite}.streaming-pulse{background-color:#3b82f6}.loading-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top:2px solid #ffffff;border-radius:50%;animation:spin 1s linear infinite}.streaming-cursor{display:inline-block;width:2px;height:1em;background-color:currentColor;animation:blink 1s infinite;margin-left:2px}.icon{width:16px;height:16px}.call-summary-indicator{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;padding:.5rem .75rem;background:rgba(156,180,113,.1);border:1px solid rgba(156,180,113,.2);border-radius:.5rem;font-size:.75rem;color:var(--primary-color);font-weight:500;cursor:pointer;transition:all .2s ease}.message-bubble.sent .call-summary-indicator{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.3);color:var(--text-on-primary)}.message-bubble.sent .call-summary-indicator:hover{background:rgba(255,255,255,.3);border-color:rgba(255,255,255,.5)}.message-bubble .message-meta .message-actions .improve-btn{background:#fff;background-color:#fff;border:none;border-radius:8px;padding:0;margin:0;margin-left:.25rem;cursor:pointer;opacity:1;transition:all .2s ease;flex-shrink:0;color:#fbbf24;box-shadow:0 2px 4px rgba(0,0,0,.1);width:32px;height:32px;min-width:32px;min-height:32px;display:flex;align-items:center;justify-content:center}.message-bubble .message-meta .message-actions .improve-btn:hover{background:#fff;color:#f59e0b;transform:translateY(-2px);box-shadow:0 4px 8px rgba(0,0,0,.15)}.message-bubble .message-meta .message-actions .improve-btn:active{transform:translateY(0);box-shadow:0 1px 2px rgba(251,191,36,.3)}.message-bubble .message-meta .message-actions .improve-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:0 1px 2px rgba(0,0,0,.1);background:#fff;color:#fbbf24;animation:pulse 1.5s ease-in-out infinite}.message-bubble .message-meta .message-actions .improve-btn:disabled:hover{transform:none;box-shadow:0 1px 2px rgba(0,0,0,.1);background:#fff;color:#fbbf24}.message-bubble .message-meta .message-actions .improve-btn .icon{width:20px;height:20px;flex-shrink:0}.message-bubble .message-meta .message-actions .improve-btn svg{color:inherit}.improvement-content{margin-top:.75rem;padding:1rem;background:rgba(255,255,255,.9);border:2px solid #f59e0b;border-radius:.5rem;font-size:.875rem;box-shadow:0 2px 8px rgba(0,0,0,.15)}.improvement-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:.8rem;font-weight:700;color:#d97706}.improvement-header .icon{width:1.1rem;height:1.1rem;color:#d97706}.close-improvement-btn{margin-left:auto;background:none;border:none;cursor:pointer;color:#6b7280;padding:.25rem;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:all .2s}.close-improvement-btn:hover{background:rgba(0,0,0,.05);color:#1f2937}.improved-text{margin-bottom:.75rem}.improved-text-label{font-size:.75rem;font-weight:700;color:#b45309;margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.5px}.improved-text-content{padding:.625rem .875rem;background:#fef3c7;border-radius:.375rem;color:#1f2937;line-height:1.5;font-weight:500}.improvement-explanation{margin-bottom:.75rem}.explanation-label{font-size:.75rem;font-weight:700;color:#b45309;margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.5px}.explanation-text{color:#374151;line-height:1.5;font-size:.8125rem}.improvement-suggestions{margin-top:.75rem}.suggestions-label{font-size:.75rem;font-weight:700;color:#b45309;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.suggestions-list{display:flex;flex-direction:column;gap:.375rem}.suggestion-item{color:#1f2937;line-height:1.4;font-size:.8125rem;padding-left:.25rem}.message-bubble .message-meta .message-actions .copy-btn{background:#fff;background-color:#fff;border:none;border-radius:8px;padding:0;margin:0;margin-left:.25rem;cursor:pointer;opacity:1;transition:all .2s ease;flex-shrink:0;color:#6366f1;box-shadow:0 2px 4px rgba(0,0,0,.1);width:32px;height:32px;min-width:32px;min-height:32px;display:flex;align-items:center;justify-content:center}.message-bubble .message-meta .message-actions .copy-btn:hover{background:#fff;color:#4f46e5;transform:translateY(-2px);box-shadow:0 4px 8px rgba(0,0,0,.15)}.message-bubble .message-meta .message-actions .copy-btn:active{transform:translateY(0);box-shadow:0 1px 2px rgba(99,102,241,.3)}.message-bubble .message-meta .message-actions .copy-btn .icon{width:20px;height:20px;flex-shrink:0}.message-bubble .message-meta .message-actions .copy-btn svg{color:inherit}.call-transcript-popup-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.call-transcript-popup{background:var(--background-light);border-radius:var(--radius-xl);width:100%;max-width:800px;max-height:90vh;box-shadow:var(--shadow-xl);border:1px solid var(--border-color);overflow:hidden;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:center;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border-light);position:relative;flex-shrink:0}.modal-header h3{margin:0;font-size:1.3rem;font-weight:600;color:var(--text-primary);text-align:center}.modal-close{position:absolute;right:1.5rem;background:none;border:none;font-size:1.5rem;color:var(--text-muted);cursor:pointer;padding:.25rem;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:var(--background-hover);color:var(--text-primary)}.call-details-bar{display:flex;align-items:center;justify-content:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-6);font-size:var(--text-sm);color:var(--text-secondary);background:var(--background-secondary);border-bottom:1px solid var(--border-light);flex-shrink:0}.call-type{background:var(--primary-color);color:var(--text-on-primary);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-sm);font-weight:500}.duration{display:flex;align-items:center;gap:var(--spacing-1)}.entries-count{color:var(--text-muted)}.popup-content{padding:var(--spacing-6);background:var(--background-light);overflow-y:auto;flex:1}.transcript-entries{display:flex;flex-direction:column;gap:var(--spacing-6);height:100%;overflow-y:auto;overflow-x:hidden}.participant-section{background:var(--background);border:1px solid var(--border-light);border-radius:var(--radius-lg);overflow:hidden}.participant-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-4);background:var(--background-secondary);border-bottom:1px solid var(--border-light)}.participant-info{display:flex;align-items:center;gap:var(--spacing-2);color:var(--text-primary);font-weight:600}.participant-name{font-size:var(--text-base)}.entry-count{font-size:var(--text-sm);color:var(--text-secondary);background:var(--background-light);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-sm)}.participant-entries{padding:var(--spacing-4);display:flex;flex-direction:column;gap:var(--spacing-3)}.transcript-entry{background:var(--background-light);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:var(--spacing-3);transition:all .2s ease}.transcript-entry:hover{border-color:var(--primary-color);box-shadow:var(--shadow-sm)}.entry-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-2);font-size:var(--text-xs);color:var(--text-secondary)}.entry-time{font-weight:500}.confidence{background:var(--primary-color);color:var(--text-on-primary);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-sm);font-weight:500}.entry-content{color:var(--text-primary);font-size:var(--text-sm);line-height:var(--leading-relaxed)}.no-transcript{text-align:center;padding:var(--spacing-8);color:var(--text-secondary)}.no-transcript p{margin:var(--spacing-2) 0}.text-muted{color:var(--text-muted);font-size:var(--text-sm)}.call-summary-indicator{display:flex;align-items:center;gap:var(--spacing-2);margin-top:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);background:rgba(156,180,113,.1);border:1px solid rgba(156,180,113,.2);border-radius:var(--radius-md);font-size:var(--text-xs);color:var(--primary-color);font-weight:500;cursor:pointer;transition:all .2s ease}.call-summary-indicator:hover{background:rgba(156,180,113,.2);border-color:rgba(156,180,113,.4);transform:translateY(-1px)}@media (max-width: 768px){.call-transcript-popup-overlay{padding:.5rem}.call-transcript-popup{max-width:100%;max-height:95vh;width:95vw;height:90vh}.modal-header{padding:1rem}.modal-header h3{font-size:var(--text-lg)}.modal-close{right:1rem}.popup-content{padding:var(--spacing-4)}.call-details-bar{flex-direction:column;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3)}.participant-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-2)}.entry-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-1)}.popup-content{overflow-y:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--primary-color) transparent}.popup-content::-webkit-scrollbar{width:4px}.popup-content::-webkit-scrollbar-track{background:var(--background-soft);border-radius:2px}.popup-content::-webkit-scrollbar-thumb{background:var(--primary-color);border-radius:2px}.popup-content::-webkit-scrollbar-thumb:hover{background:var(--primary-dark)}.modal-close{min-width:44px;min-height:44px}}.icon-sm{width:1rem;height:1rem}.icon-md{width:1.5rem;height:1.5rem}.word-hover-container{position:relative;display:inline-block;cursor:pointer;z-index:10000;padding:0;vertical-align:top}.word-hover-container ruby{ruby-position:over;line-height:2.2}.word-hover-container rt{font-size:.65em;color:#64748b;line-height:1.2}.word-hover-container rb{line-height:1}.word-hover-container:hover{text-decoration:underline;-webkit-text-decoration-style:dotted;text-decoration-style:dotted;text-underline-offset:2px}.word-hover-container:before{content:"";position:absolute;top:-30px;left:-10px;right:-10px;bottom:-10px;z-index:-1}.word-hover-actions{position:absolute;bottom:100%;left:50%;transform:translate(-50%);display:flex;gap:4px;padding:4px;background:rgba(0,0,0,.9);border-radius:6px;box-shadow:0 2px 8px rgba(0,0,0,.2);white-space:nowrap;z-index:9999;margin-bottom:2px}.word-hover-actions:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid rgba(0,0,0,.9)}.word-action-btn{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease;width:32px;height:32px;flex-shrink:0}.word-action-btn:hover{background-color:rgba(255,255,255,.2)}.word-action-btn:active{background-color:rgba(255,255,255,.3)}.word-hover-actions .word-hover-icon{width:20px;height:20px;flex-shrink:0}.word-hover-actions svg{display:block;width:20px;height:20px;color:inherit}.word-translation{position:absolute;top:100%;left:50%;transform:translate(-50%);background:var(--primary-600);color:var(--text-white);padding:4px 8px;border-radius:4px;font-size:.875rem;margin-top:1px;white-space:nowrap;z-index:9999;box-shadow:0 2px 6px rgba(0,0,0,.15)}@keyframes fadeInScale{0%{opacity:0;transform:translate(-50%) scale(.9)}to{opacity:1;transform:translate(-50%) scale(1)}}.word-translation{animation:fadeInScale .2s ease-out}.word-synonyms{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--olive-600);color:var(--text-white);padding:6px 12px;border-radius:6px;font-size:.875rem;max-width:300px;z-index:9999;box-shadow:0 2px 8px rgba(0,0,0,.2);animation:fadeInScale .2s ease-out;line-height:1.4}.synonym-label{font-weight:600;margin-right:6px;opacity:.95}.synonym-list{font-weight:400;word-wrap:break-word}.synonym-loading,.no-synonyms{font-style:italic;opacity:.9}.word-hover-container:has(.word-translation):has(.word-synonyms) .word-synonyms{top:calc(100% + 34px)}.word-grammatical-info{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--orange-600);color:var(--text-white);padding:6px 12px;border-radius:6px;font-size:.875rem;max-width:320px;z-index:9999;box-shadow:0 2px 8px rgba(0,0,0,.2);animation:fadeInScale .2s ease-out;line-height:1.4;display:flex;flex-direction:column;gap:4px}.grammatical-item{display:block;font-weight:400}.grammatical-label{font-weight:600;margin-right:4px;opacity:.95}.grammatical-loading,.no-grammatical-info{font-style:italic;opacity:.9}.word-hover-container:has(.word-translation):has(.word-synonyms) .word-grammatical-info{top:calc(100% + 60px)}.word-hover-container:has(.word-translation):has(.word-grammatical-info):not(:has(.word-synonyms)) .word-grammatical-info{top:calc(100% + 34px)}.word-hover-container:has(.word-synonyms):has(.word-grammatical-info):not(:has(.word-translation)) .word-grammatical-info{top:calc(100% + 34px)}.word-action-btn .loading-dots{font-size:18px;color:#fff;animation:word-hover-pulse 1.5s ease-in-out infinite}@keyframes word-hover-pulse{0%,to{opacity:1}50%{opacity:.4}}.word-action-btn:disabled{opacity:.7;cursor:not-allowed}.word-action-btn.added-to-deck{background:rgba(16,185,129,.3);border-color:rgba(16,185,129,.5)}.word-action-btn .check-mark{color:#10b981;font-size:18px;font-weight:700}.chinese-pinyin{display:inline-block;vertical-align:top;white-space:normal;word-wrap:break-word}.chinese-pinyin ruby{ruby-position:over;line-height:2.2}.chinese-pinyin rt{font-size:.65em;color:var(--text-secondary, #6b7280);font-weight:400;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1.2}.chinese-pinyin rb{font-weight:400;font-size:1em;line-height:1}.chinese-pinyin ruby+ruby{margin-left:.15em}@media (prefers-color-scheme: dark){.chinese-pinyin rt{color:var(--text-secondary, #9ca3af)}}.icebreaker-bubble{background:linear-gradient(135deg,#fef3c7,#fef9e7);border:2px solid #f59e0b;border-radius:12px;padding:1rem;max-width:520px;box-shadow:0 4px 6px -1px rgba(245,158,11,.1),0 2px 4px -1px rgba(245,158,11,.06)}.icebreaker-bubble.own{background:linear-gradient(135deg,#dbeafe,#eff6ff);border-color:#3b82f6;box-shadow:0 4px 6px -1px rgba(59,130,246,.1),0 2px 4px -1px rgba(59,130,246,.06)}.icebreaker-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.icebreaker-icon{color:#f59e0b}.icebreaker-bubble.own .icebreaker-icon{color:#3b82f6}.icebreaker-label{font-size:.875rem;font-weight:600;color:#92400e;text-transform:uppercase;letter-spacing:.05em}.icebreaker-bubble.own .icebreaker-label{color:#1e40af}.icebreaker-question{font-size:1rem;font-weight:500;color:#78350f;line-height:1.5;margin-bottom:1rem;padding:.5rem;background:rgba(255,255,255,.5);border-radius:6px}.icebreaker-bubble.own .icebreaker-question{color:#1e3a8a;background:rgba(255,255,255,.6)}.icebreaker-divider{height:1px;background:linear-gradient(90deg,transparent,#f59e0b,transparent);margin:1rem 0}.icebreaker-bubble.own .icebreaker-divider{background:linear-gradient(90deg,transparent,#3b82f6,transparent)}.icebreaker-answer-section{margin-bottom:1rem}.icebreaker-answer-label{font-size:.875rem;color:#92400e;margin-bottom:.5rem}.icebreaker-bubble.own .icebreaker-answer-label{color:#1e40af}.icebreaker-answer{font-size:1rem;color:#1f2937;line-height:1.6;padding:.75rem;background:#fff;border-radius:6px;border-left:3px solid #f59e0b}.icebreaker-bubble.own .icebreaker-answer{border-left-color:#3b82f6}.icebreaker-footer{display:flex;justify-content:space-between;align-items:center;font-size:.875rem;color:#6b7280}.icebreaker-encouragement{font-weight:500;color:#92400e}.icebreaker-bubble.own .icebreaker-encouragement{color:#1e40af}.icebreaker-time{font-size:.75rem;color:#9ca3af}@media (max-width: 768px){.icebreaker-bubble{max-width:100%;padding:.875rem}.icebreaker-question,.icebreaker-answer{font-size:.95rem}.icebreaker-footer{flex-direction:column;align-items:flex-start;gap:.5rem}}.recording-consent-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;padding:1rem;z-index:80000}.recording-consent-modal{background:#fff;border-radius:.5rem;box-shadow:0 25px 50px -12px rgba(0,0,0,.25);max-width:32rem;width:100%;max-height:90vh;overflow-y:auto;position:relative;z-index:1}.recording-consent-content{padding:1.5rem}.recording-consent-header{display:flex;align-items:center;margin-bottom:1rem}.recording-consent-icon{display:flex;align-items:center;justify-content:center;width:3rem;height:3rem;background-color:#dbeafe;border-radius:50%;margin-right:1rem}.recording-consent-icon svg{width:1.5rem;height:1.5rem;color:#2563eb}.recording-consent-title{font-size:1.5rem;font-weight:700;color:#111827}.recording-consent-description{color:#374151;margin-bottom:1rem}.recording-consent-info-box{background-color:#eff6ff;border:1px solid rgb(191,219,254);border-radius:.5rem;padding:1rem;margin-bottom:1rem}.recording-consent-info-header{display:flex;align-items:flex-start}.recording-consent-info-icon{width:1.25rem;height:1.25rem;color:#2563eb;margin-top:.125rem;margin-right:.5rem;flex-shrink:0}.recording-consent-info-content{font-size:.875rem;color:#1e3a8a}.recording-consent-info-title{font-weight:600;margin-bottom:.25rem}.recording-consent-info-list{list-style-type:disc;list-style-position:inside;margin-left:.5rem}.recording-consent-info-list li{margin-bottom:.25rem}.recording-consent-details-toggle{color:#2563eb;font-size:.875rem;font-weight:500;background:none;border:none;cursor:pointer;margin-bottom:1rem;transition:color .2s}.recording-consent-details-toggle:hover{color:#1d4ed8}.recording-consent-details{background-color:#f9fafb;border-radius:.5rem;padding:1rem;margin-bottom:1rem;font-size:.875rem;color:#374151}.recording-consent-details h4{font-weight:600;color:#111827;margin-bottom:.25rem}.recording-consent-details ul{list-style-type:disc;list-style-position:inside;margin-left:1rem;margin-bottom:.75rem}.recording-consent-details li{margin-bottom:.25rem}.recording-consent-checkboxes{margin-bottom:1.5rem}.recording-consent-checkbox-item{display:flex;align-items:flex-start;cursor:pointer;margin-bottom:.75rem}.recording-consent-checkbox{margin-top:.25rem;margin-right:.75rem}.recording-consent-checkbox-label{color:#374151}.recording-consent-buttons{display:flex;justify-content:flex-end;gap:.75rem}.recording-consent-btn{padding:.5rem 1rem;border-radius:.5rem;font-weight:500;transition:all .2s;display:flex;align-items:center;border:none;cursor:pointer}.recording-consent-btn svg{width:1rem;height:1rem;margin-right:.5rem}.recording-consent-btn-decline{color:#374151;background-color:#f3f4f6}.recording-consent-btn-decline:hover{background-color:#e5e7eb}.recording-consent-btn-accept{color:#fff;background-color:var(--olive-600)}.recording-consent-btn-accept:hover{background-color:var(--olive-700)}.recording-consent-btn-disabled{color:#9ca3af;background-color:#e5e7eb;cursor:not-allowed}.recording-consent-footer{font-size:.75rem;color:#6b7280;margin-top:1rem;text-align:center}.recording-consent-footer a{color:#2563eb;text-decoration:none}.recording-consent-footer a:hover{text-decoration:underline}.lesson-passage-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);display:flex;align-items:flex-start;justify-content:center;z-index:15000;padding:1rem;animation:fadeIn .2s ease-out;overflow-y:auto}.lesson-passage-modal-content{background:#fff;border-radius:12px;max-width:700px;width:100%;max-height:calc(100% - 2rem);display:flex;flex-direction:column;box-shadow:0 8px 32px rgba(0,0,0,.2);animation:slideUp .3s ease-out;margin-top:2rem;position:relative;z-index:15001}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.lesson-passage-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid #e5e7eb;background:linear-gradient(135deg,#f9fafb,#fff);border-radius:12px 12px 0 0}.lesson-passage-modal-title{display:flex;align-items:center;gap:.75rem;color:#111827}.lesson-passage-modal-title svg{color:#9cb847}.lesson-passage-modal-title h2{margin:0;font-size:1.25rem;font-weight:600}.lesson-passage-modal-close{background:none;border:none;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;color:#6b7280;border-radius:6px;transition:all .2s}.lesson-passage-modal-close:hover{background:#f3f4f6;color:#111827}.lesson-passage-modal-body{padding:2rem;overflow-y:auto;flex:1}.lesson-passage-text{font-size:1.0625rem;line-height:1.8;color:#374151;white-space:pre-wrap;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.lesson-passage-meta{display:flex;gap:1.5rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.meta-item{font-size:.875rem;color:#6b7280}.meta-item strong{color:#374151;margin-right:.25rem}.lesson-passage-modal-body::-webkit-scrollbar{width:8px}.lesson-passage-modal-body::-webkit-scrollbar-track{background:#f3f4f6;border-radius:4px}.lesson-passage-modal-body::-webkit-scrollbar-thumb{background:#9cb847;border-radius:4px}.lesson-passage-modal-body::-webkit-scrollbar-thumb:hover{background:#8aa63d}@media (max-width: 768px){.lesson-passage-modal-overlay{align-items:flex-end;padding:0;z-index:15000!important}.lesson-passage-modal-content{max-width:100%;max-height:90vh;width:100%;margin:0;border-radius:12px 12px 0 0;z-index:15001!important}.lesson-passage-modal-header{padding:1rem}.lesson-passage-modal-title h2{font-size:1.125rem}.lesson-passage-modal-body{padding:1.5rem}.lesson-passage-text{font-size:1rem;line-height:1.7}.lesson-passage-meta{flex-direction:column;gap:.5rem}}.ai-voice-call-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.8);display:flex;align-items:center;justify-content:center;padding:1rem}.ai-voice-improve-popup{z-index:99999!important;isolation:isolate!important}.ai-voice-call-container{background:var(--background-light);border-radius:16px;width:100%;max-width:600px;max-height:90vh;max-height:90dvh;overflow:hidden;box-shadow:0 20px 40px rgba(0,0,0,.3);border:1px solid var(--border-color);display:flex;flex-direction:column}.ai-voice-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border-color);background:var(--background)}.ai-info{display:flex;align-items:center;gap:1rem}.ai-icon{width:32px;height:32px;color:var(--primary-color)}.ai-avatar{width:48px;height:48px;border-radius:50%;overflow:hidden;flex-shrink:0}.ai-avatar img{width:100%;height:100%;object-fit:cover}.ai-details{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.ai-details h3{margin:0;color:var(--text-primary);font-size:1.25rem;font-weight:600;line-height:1.2}.ai-info h3{margin:0;color:var(--text-primary);font-size:1.25rem;font-weight:600}.session-status{margin:0;color:#374151;font-size:.875rem}.header-controls{display:flex;align-items:center;gap:1rem}.language-selector{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--gray-800);color:var(--gray-100);font-size:.875rem;cursor:pointer;transition:all .2s ease}.language-selector:hover{border-color:var(--primary-color);background:var(--gray-700)}.language-selector:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px rgba(139,105,20,.1)}.translation-toggle-btn{background:var(--background-light);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:50%;transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:36px;height:36px}.translation-toggle-btn:hover{background:var(--background);border-color:var(--primary-color);color:var(--primary-color)}.translation-toggle-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.lesson-passage-btn{background:none;border:1px solid var(--border-color);color:#9cb847;cursor:pointer;padding:.5rem;border-radius:8px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.lesson-passage-btn:hover{background:rgba(156,184,71,.1);border-color:#9cb847;transform:translateY(-1px);box-shadow:0 2px 4px rgba(0,0,0,.1)}.lesson-passage-btn svg{width:20px;height:20px}.ai-close-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:50%;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.ai-close-btn:hover{background:var(--background-light);color:var(--text-primary)}.ai-close-btn svg{width:20px;height:20px}.conversation-history{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;max-height:400px}.error-message{display:flex;align-items:center;gap:.75rem;padding:1rem;background:rgba(220,38,38,.1);color:var(--red-500);border:1px solid rgba(220,38,38,.3);border-radius:8px;margin-bottom:1rem}.error-icon{width:20px;height:20px;flex-shrink:0}.dismiss-error{background:none;border:none;color:var(--red-500);cursor:pointer;padding:.25rem;border-radius:4px;margin-left:auto}.dismiss-error:hover{background:rgba(220,38,38,.1)}.dismiss-error svg{width:16px;height:16px}.welcome-message{text-align:center;padding:2rem;color:#374151}.welcome-icon{width:48px;height:48px;color:var(--primary-color);margin:0 auto 1rem}.conversation-entry{padding:1rem;border-radius:12px;border:1px solid var(--border-color);background:var(--background)}.conversation-entry.user{background:var(--primary-color);color:#fff;margin-left:2rem}.conversation-entry.ai{background:var(--background-light);margin-right:2rem}.entry-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.improve-btn-inline{background:var(--olive-100);color:var(--olive-700);border:1px solid var(--olive-300);padding:.25rem .5rem;border-radius:6px;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.25rem;margin-left:auto}.improve-btn-inline:hover{background:var(--olive-200);border-color:var(--olive-500)}.improve-icon{width:12px;height:12px}.entry-type{font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.entry-time{font-size:.75rem;opacity:.7}.entry-message{line-height:1.5;word-wrap:break-word}.play-audio-btn{display:flex;align-items:center;gap:.5rem;background:var(--primary-color);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.875rem;transition:all .2s ease}.play-audio-btn:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px)}.play-audio-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.play-audio-btn svg{width:16px;height:16px}.ai-message-actions{display:flex;gap:.75rem;margin-top:.5rem;flex-wrap:wrap}.translate-btn{display:flex;align-items:center;gap:.5rem;background:var(--primary-500);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.875rem;transition:all .2s ease;white-space:nowrap;min-width:-webkit-fit-content;min-width:-moz-fit-content;min-width:fit-content}.translate-btn:hover:not(:disabled){background:var(--primary-600);transform:translateY(-1px)}.translate-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.translate-btn svg{width:16px;height:16px}.translate-btn .spinner{animation:spin 1s linear infinite}.message-translation{margin-top:.5rem;padding:.5rem;background:var(--background-light, #f8f8f8);border-radius:6px;font-size:.875rem}.translation-label{font-weight:600;color:var(--text-secondary);margin-right:.5rem}.translation-text{color:var(--text-primary)}.ai-voice-controls{padding:1.5rem;border-top:1px solid var(--border-color);background:var(--background)}.control-buttons{display:flex;justify-content:center;margin-bottom:1rem;gap:1rem}.ai-voice-call-container .record-btn{display:flex;align-items:center;gap:.75rem;background-color:var(--orange-primary);color:#fff;border:none;padding:1rem 2rem;border-radius:50px;cursor:pointer;font-size:1rem;font-weight:600;transition:background-color .2s ease,transform .2s ease,box-shadow .2s ease;min-width:200px;justify-content:center;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;position:relative;overflow:visible}.ai-voice-call-container .record-btn:before{display:none}.ai-voice-call-container .record-btn:hover:not(:disabled):not(.recording):not(.processing){background-color:var(--orange-terracotta);color:#fff;transform:translateY(-2px);box-shadow:0 8px 25px rgba(247,115,22,.3)}.ai-voice-call-container .record-btn:active:not(:disabled):not(.recording):not(.processing){background-color:var(--orange-terracotta);color:#fff;transform:translateY(0);box-shadow:0 4px 15px rgba(247,115,22,.4)}.ai-voice-call-container .record-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.ai-voice-call-container .record-btn.processing{background:var(--gray-600);animation:pulse 2s infinite}.ai-voice-call-container .record-btn.recording{background:var(--green-500);animation:pulse-recording 1.5s infinite;transform:scale(1.05);box-shadow:0 8px 25px rgba(16,185,129,.4)}.stop-btn{display:flex;align-items:center;gap:.75rem;background:var(--gray-600);color:#fff;border:none;padding:1rem 2rem;border-radius:50px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .2s ease;min-width:200px;justify-content:center}.stop-btn:hover{background:var(--gray-700);transform:translateY(-2px);box-shadow:0 8px 25px rgba(107,114,128,.3)}.record-btn svg,.stop-btn svg{width:24px;height:24px;flex-shrink:0}.record-btn,.record-btn:hover,.record-btn:active{color:#fff}.record-btn svg,.record-btn:hover:not(:disabled) svg,.record-btn:active:not(:disabled) svg{color:#fff;fill:currentColor}.chat-btn{width:50px;height:50px;border-radius:50%;background-color:var(--background-secondary);color:var(--text-primary);border:2px solid var(--border-color);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease}.chat-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px var(--shadow-color);background-color:var(--primary-color);color:var(--text-on-primary)}.chat-btn.active{background-color:var(--primary-color);color:var(--text-on-primary);box-shadow:0 0 20px rgba(99,102,241,.4)}.chat-btn svg{width:24px;height:24px}.processing-indicator{display:flex;align-items:center;justify-content:center;gap:.75rem;color:var(--text-secondary);font-size:.875rem}.processing-indicator svg{width:20px;height:20px}.spinning{animation:spin 1s linear infinite}@keyframes pulse{0%,to{opacity:.6}50%{opacity:.8}}@keyframes pulse-recording{0%,to{box-shadow:0 8px 25px rgba(16,185,129,.4);transform:scale(1.05)}50%{box-shadow:0 12px 35px rgba(16,185,129,.6);transform:scale(1.08)}}.conversation-history::-webkit-scrollbar{width:6px}.conversation-history::-webkit-scrollbar-track{background:var(--background)}.conversation-history::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.conversation-history::-webkit-scrollbar-thumb:hover{background:var(--primary-color)}@media (max-width: 768px){.ai-voice-call-overlay{padding:.5rem}.ai-voice-call-container{max-height:95vh;max-height:95dvh;max-width:100%}.ai-voice-header{padding:1rem;flex-wrap:wrap;gap:.75rem}.ai-info{flex:1;min-width:0;gap:.75rem}.ai-details{flex:1;min-width:0}.ai-avatar{width:40px;height:40px}.ai-details h3,.ai-info h3{font-size:1rem}.session-status{font-size:.75rem}.header-controls{gap:.5rem;flex-wrap:wrap}.language-selector{font-size:.75rem;padding:.4rem .75rem}.conversation-history{padding:1rem;max-height:300px}.ai-voice-controls{padding:1rem}.record-btn,.stop-btn{padding:.75rem 1.5rem;min-width:160px;font-size:.875rem}.record-btn.recording{color:#fff;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.2)}.ai-message-actions{flex-direction:column;gap:.5rem}.translate-btn,.play-audio-btn{width:100%;justify-content:center}.conversation-entry.user{margin-left:1rem}.conversation-entry.ai{margin-right:1rem}}@media (max-width: 480px){.ai-voice-header{padding:.75rem}.ai-info{width:100%}.header-controls{width:100%;justify-content:space-between}}.conversation-entry.ai .message .message-sender{color:var(--primary-600)}.thinking-indicator .dot{width:8px;height:8px;border-radius:50%;background-color:var(--primary-500);opacity:.4;animation:thinking-bounce 1.4s infinite ease-in-out both}.hoverable-text-container{position:relative;z-index:1}.hoverable-text{line-height:1.8;font-size:16px;color:var(--text-primary);letter-spacing:.05em;white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word}.punctuation-no-break{display:inline;margin-left:-.2em;padding-left:.2em}.punctuation-no-break:before{content:"\feff";font-size:0}.hoverable-word{cursor:pointer;padding:2px 4px;margin:0;border-radius:4px;transition:background-color .2s ease,color .2s ease;display:inline-block;box-sizing:border-box}.hoverable-word:hover{background-color:var(--background-soft, rgba(0, 0, 0, .05))}.hoverable-word.selected{background-color:var(--primary-300, #93c5fd);color:var(--primary-800, #1e40af)}.reading-word-tooltip{position:absolute;background:var(--white);border:1px solid var(--border-color);border-radius:8px;padding:12px;box-shadow:var(--shadow-lg);z-index:50;min-width:180px;transform:translate(-50%);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%) translateY(-5px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.reading-tooltip-word{font-weight:600;color:var(--text-primary);margin-bottom:8px;text-align:center}.reading-tooltip-translation{color:var(--text-secondary);font-size:14px;margin-bottom:8px;text-align:center;font-style:italic}.reading-tooltip-actions{display:flex;gap:8px;justify-content:center;margin-top:8px}.reading-tooltip-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;min-width:40px;min-height:40px;border:2px solid var(--border-color);background:var(--white);border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-sm);padding:0;overflow:hidden}.reading-tooltip-btn:hover:not(:disabled){background:var(--background-light);border-color:var(--primary-600);transform:translateY(-1px);box-shadow:var(--shadow-md)}.reading-tooltip-btn:disabled{opacity:.5;cursor:not-allowed}.reading-tooltip-icon{width:24px;height:24px;color:var(--text-secondary);display:block;flex-shrink:0}.reading-tooltip-btn svg.reading-tooltip-icon{width:24px;height:24px}.reading-tooltip-btn:hover:not(:disabled) .reading-tooltip-icon{color:var(--primary-600)}.hoverable-word[data-chinese=true]{padding:2px 3px;margin:0 1px;border-radius:2px;background-color:rgba(185,204,129,.1);border:1px solid rgba(185,204,129,.3)}.hoverable-word[data-chinese=true]:hover{background-color:rgba(185,204,129,.2);border-color:rgba(185,204,129,.5)}.hoverable-word[data-chinese=true].selected{background-color:rgba(185,204,129,.3);border-color:rgba(185,204,129,.7);color:var(--text-primary, #1f2937)}@media (max-width: 640px){.hoverable-text{font-size:15px}.hoverable-word{padding:4px 6px;min-height:32px;display:inline-flex;align-items:center}.hoverable-word:active{background-color:rgba(156,184,71,.2);transform:scale(1.05);transition:all .1s ease}.reading-word-tooltip{position:fixed;bottom:0;left:0;right:0;transform:none;border-radius:16px 16px 0 0;max-width:100%;min-width:100%;padding:20px 20px calc(20px + env(safe-area-inset-bottom));box-shadow:0 -4px 20px rgba(0,0,0,.15);animation:slideUpFromBottom .3s cubic-bezier(.4,0,.2,1)}@keyframes slideUpFromBottom{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.reading-tooltip-word{font-size:1.25rem;margin-bottom:12px}.reading-tooltip-translation{font-size:1rem;margin-bottom:12px}.reading-tooltip-btn{width:48px;height:48px;min-width:48px;min-height:48px}.reading-tooltip-icon{width:28px;height:28px}.reading-tooltip-btn svg.reading-tooltip-icon{width:28px;height:28px}.reading-word-tooltip:before{content:"";position:absolute;top:8px;left:50%;transform:translate(-50%);width:40px;height:4px;background:#d1d5db;border-radius:2px}}.highlightable-reading-text{line-height:2;font-size:1.125rem;color:var(--text-primary);padding:1.5rem;background:var(--background-soft);border-radius:8px;margin-bottom:1rem;word-wrap:break-word;overflow-wrap:break-word}.highlightable-reading-text .punctuation-no-break{display:inline;margin-left:-.2em;padding-left:.2em}.highlightable-reading-text .punctuation-no-break:before{content:"\feff";font-size:0}.reading-word{position:relative;transition:background-color .3s ease;padding:2px 4px;margin:-2px -4px;display:inline-block;border-radius:3px}.reading-word.highlighted{background-color:var(--orange-200, rgba(251, 191, 36, .3));color:var(--text-primary)}.reading-word.highlighted.already-read{background-color:var(--primary-200);animation:none}.reading-word.highlighted.current{background-color:var(--orange-300, rgba(251, 191, 36, .5))}.reading-word.highlighted:after{content:"";position:absolute;bottom:0;left:4px;right:4px;height:2px;background-color:var(--orange-600, rgba(234, 88, 12, .8));border-radius:1px;opacity:.8}.reading-passages-container{max-width:800px;margin:0 auto;padding:20px;position:relative;z-index:1}.reading-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.reading-title{display:flex;align-items:center;gap:8px;font-size:24px;font-weight:600;color:var(--text-primary);margin:0}.reading-title svg{width:24px;height:24px;flex-shrink:0}.reading-stats{display:flex;gap:16px;font-size:14px;color:var(--text-secondary)}.reading-controls{display:flex;gap:1rem;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap}.language-select{padding:.625rem 2.75rem .625rem 1rem;border:2px solid #e5e7eb;border-radius:10px;background:#fff;color:var(--text-primary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%239cb847' stroke-linecap='round' stroke-linejoin='round' stroke-width='2.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");background-position:right .75rem center;background-repeat:no-repeat;background-size:1.25rem;min-width:160px}.language-select:hover:not(:disabled){border-color:var(--olive-400);box-shadow:0 4px 6px rgba(156,184,71,.12),0 2px 4px rgba(156,184,71,.08);background-color:var(--olive-50);transform:translateY(-1px)}.language-select:focus{outline:none;border-color:var(--olive-600);box-shadow:0 0 0 3px rgba(156,184,71,.15),0 4px 6px rgba(156,184,71,.1);background-color:#fff}.level-filter{display:flex;align-items:center;gap:.625rem;font-size:.875rem;color:#374151;font-weight:500;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:.5rem;border-radius:8px;transition:background .2s ease}.level-filter:hover{background:var(--olive-50)}.level-filter input[type=checkbox]{width:1.125rem;height:1.125rem;cursor:pointer;border:2px solid #d1d5db;border-radius:4px;appearance:none;-webkit-appearance:none;-moz-appearance:none;background:#fff;transition:all .2s ease;position:relative}.level-filter input[type=checkbox]:checked{background:var(--olive-600);border-color:var(--olive-600)}.level-filter input[type=checkbox]:checked:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:.375rem;height:.625rem;border:solid white;border-width:0 2px 2px 0;transform:translate(-50%,-60%) rotate(45deg)}.level-filter input[type=checkbox]:focus{outline:none;box-shadow:0 0 0 3px rgba(156,184,71,.15)}.passages-list{display:flex;flex-direction:column;gap:16px}.passage-card{background:#fff;border:1px solid var(--border-color);border-radius:12px;overflow:hidden;transition:box-shadow .2s ease}.passage-card:hover{box-shadow:0 2px 8px rgba(0,0,0,.1)}.passage-header{padding:16px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.passage-header:hover{background-color:var(--background-soft)}.passage-header svg{width:20px;height:20px;flex-shrink:0}.passage-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 8px}.passage-meta{display:flex;gap:12px;align-items:center}.level-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:16px;font-size:.813rem;font-weight:600;border:1px solid currentColor;opacity:.9}.level-badge svg{width:16px;height:16px;flex-shrink:0}.level-badge.bg-green-100{background-color:var(--olive-50);color:var(--olive-800);border-color:var(--olive-500)}.level-badge.bg-blue-100{background-color:var(--olive-100);color:var(--olive-900);border-color:var(--olive-600)}.level-badge.bg-purple-100{background-color:#fff7ed;color:var(--orange-800);border-color:var(--orange-500)}.level-badge.bg-gray-100{background-color:var(--tea-green-100);color:var(--tea-green-800);border-color:var(--tea-green-600)}.word-count{font-size:14px;color:var(--text-secondary)}.passage-content{padding:0 16px 16px;border-top:1px solid var(--border-light);animation:fadeIn .2s ease-out;position:relative;z-index:1}.passage-text{margin:16px 0;line-height:1.8;color:var(--text-primary);font-size:16px;white-space:pre-wrap}.passage-source{font-size:12px;color:var(--text-secondary);font-style:italic;margin-bottom:16px}.recording-section{margin-top:16px;padding-top:16px;border-top:1px solid var(--border-light)}.record-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.record-btn svg{width:20px;height:20px;flex-shrink:0}.record-btn.start{background-color:var(--primary-600);color:#fff}.record-btn.start:hover{background-color:var(--primary-700);color:#fff}.record-btn.stop{background-color:#dc2626;color:#fff}.record-btn.stop:hover{background-color:#b91c1c;color:#fff}.recording-active-container{display:flex;align-items:center;gap:16px}.recording-status{display:flex;align-items:center;gap:8px;padding:8px 16px;background-color:var(--background-soft);border-radius:8px;border:1px solid var(--border-color)}.recording-indicator{width:12px;height:12px;background-color:#dc2626;border-radius:50%;animation:pulse 1.5s ease-in-out infinite}.recording-time{font-size:14px;font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.recording-actions{display:flex;flex-direction:column;gap:12px;margin-top:12px}.playback-controls{display:flex;align-items:center;gap:12px;padding:12px;background:var(--background-soft);border-radius:8px;border:1px solid var(--border-light)}.playback-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background-color:var(--primary-600);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.playback-btn:hover{background-color:var(--primary-700);transform:translateY(-1px)}.playback-btn:active{transform:translateY(0)}.playback-icon{width:18px;height:18px;flex-shrink:0}.recording-duration{margin-left:auto;font-size:14px;font-weight:500;color:var(--text-secondary);font-variant-numeric:tabular-nums}.action-buttons{display:flex;gap:12px}.analyze-btn{padding:10px 20px;background-color:var(--primary-600);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.analyze-btn:hover:not(:disabled){background-color:var(--primary-700)}.analyze-btn:disabled{opacity:.6;cursor:not-allowed}.analyze-spinner{width:18px;height:18px;animation:spin .8s linear infinite;flex-shrink:0}.analyze-btn:disabled{opacity:1;background-color:var(--primary-500);cursor:wait}.reset-btn{padding:10px 20px;background-color:transparent;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.reset-btn:hover{background-color:var(--background-soft)}.analysis-results{background-color:var(--background-soft);padding:16px;border-radius:8px;margin-top:16px}.analysis-results h4{margin:0 0 16px;font-size:16px;font-weight:600;color:var(--text-primary)}.scores{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:16px}.score-item{text-align:center;padding:12px;background:#fff;border-radius:8px;border:1px solid var(--border-light)}.score-label{display:block;font-size:12px;color:var(--text-secondary);margin-bottom:4px}.score-value{display:block;font-size:24px;font-weight:600;color:var(--primary-600)}.feedback{margin:16px 0;padding:12px;background:#fff;border-radius:8px;border:1px solid var(--border-light);color:var(--text-primary);line-height:1.6}.strengths{margin:16px 0}.strengths h5{margin:0 0 8px;font-size:14px;font-weight:600;color:var(--green-600)}.strengths ul{margin:0;padding-left:20px;list-style:none}.strengths li.strength-item{margin-bottom:6px;color:var(--green-700);font-size:14px;line-height:1.5}.areas-for-improvement{margin:16px 0}.areas-for-improvement h5{margin:0 0 8px;font-size:14px;font-weight:600;color:var(--orange-600)}.areas-for-improvement ul{margin:0;padding-left:20px;list-style:none}.areas-for-improvement li.improvement-item{margin-bottom:6px;color:var(--orange-700);font-size:14px;line-height:1.5}.suggestions{margin:16px 0}.suggestions h5{margin:0 0 8px;font-size:14px;font-weight:600;color:var(--text-primary)}.suggestions ul{margin:0;padding-left:20px}.suggestions li{margin-bottom:4px;color:var(--text-secondary);font-size:14px}.analysis-actions{display:flex;gap:12px;margin-top:16px;justify-content:center}.record-again-btn{padding:10px 20px;background-color:var(--primary-600);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.record-again-btn:hover{background-color:var(--primary-700)}.no-passages{text-align:center;padding:40px;color:var(--text-secondary)}.reading-title-icon{width:24px;height:24px}.level-badge-icon{width:16px;height:16px}.expand-icon{width:20px;height:20px}.record-button-icon{width:20px;height:20px;flex-shrink:0}.reference-audio-section{display:flex;align-items:center;gap:12px;margin:16px 0;padding:12px;background:var(--olive-50);border-radius:8px;border:1px solid var(--olive-200)}.reference-audio-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background-color:var(--olive-600);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.reference-audio-btn:hover{background-color:var(--olive-700);transform:translateY(-1px);box-shadow:0 2px 4px rgba(156,184,71,.2)}.reference-audio-btn:active{transform:translateY(0)}.reference-audio-icon{width:18px;height:18px;flex-shrink:0}.reference-audio-label{font-size:13px;color:var(--olive-800);font-weight:500}.word-analysis{margin:20px 0;padding:16px;background:#fff;border-radius:8px;border:1px solid var(--border-light)}.word-analysis h5{margin:0 0 16px;font-size:14px;font-weight:600;color:var(--text-primary)}.word-analysis-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.word-analysis-item{padding:12px;background:var(--background-soft);border-radius:8px;border:1px solid var(--border-light);transition:all .2s ease}.word-analysis-item:hover{box-shadow:0 2px 4px rgba(0,0,0,.08);border-color:var(--olive-300)}.word-analysis-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.word-text{font-size:16px;font-weight:600;color:var(--text-primary)}.word-score{padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600}.word-score.good{background-color:var(--green-100);color:var(--green-700)}.word-score.moderate{background-color:var(--orange-100);color:var(--orange-700)}.word-score.needs-work{background-color:#fee2e2;color:#991b1b}.word-issue{font-size:13px;color:var(--orange-700);margin:6px 0;line-height:1.4}.word-suggestion{font-size:13px;color:var(--primary-700);margin:6px 0;line-height:1.4}.word-audio-controls{margin-top:8px;display:flex;gap:6px}.word-audio-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 10px;border:1px solid;border-radius:5px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.word-audio-btn:disabled{opacity:.5;cursor:not-allowed}.word-audio-btn.user-pronunciation{background-color:#dbeafe;color:#1e40af;border-color:#93c5fd}.word-audio-btn.user-pronunciation:hover:not(:disabled){background-color:#3b82f6;color:#fff;border-color:#3b82f6;transform:translateY(-1px);box-shadow:0 1px 3px rgba(59,130,246,.3)}.word-audio-btn.user-pronunciation.playing{background-color:#3b82f6;color:#fff;border-color:#3b82f6;animation:pulse-blue 1.5s ease-in-out infinite}.word-audio-btn.reference-pronunciation{background-color:var(--olive-100);color:var(--olive-800);border-color:var(--olive-300)}.word-audio-btn.reference-pronunciation:hover{background-color:var(--olive-600);color:#fff;border-color:var(--olive-600);transform:translateY(-1px);box-shadow:0 1px 3px rgba(156,184,71,.2)}.word-audio-btn.reference-pronunciation.playing{background-color:var(--olive-600);color:#fff;border-color:var(--olive-600);animation:pulse-olive 1.5s ease-in-out infinite}.word-audio-btn:active:not(:disabled){transform:translateY(0)}@keyframes pulse-blue{0%,to{box-shadow:0 1px 3px rgba(59,130,246,.3)}50%{box-shadow:0 2px 8px rgba(59,130,246,.5)}}@keyframes pulse-olive{0%,to{box-shadow:0 1px 3px rgba(156,184,71,.2)}50%{box-shadow:0 2px 8px rgba(156,184,71,.4)}}@media (max-width: 768px){.word-analysis-grid{grid-template-columns:1fr}.reference-audio-section{flex-direction:column;align-items:flex-start}.reference-audio-label{order:-1;margin-bottom:8px}}.quiz-container{max-width:600px;width:100%;margin:0 auto;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 4px 6px rgba(0,0,0,.1);max-height:100%;overflow-y:auto;box-sizing:border-box;position:relative;z-index:1}:fullscreen .quiz-container{max-width:min(600px,90vw);max-height:90vh;max-height:90dvh}:-webkit-full-screen .quiz-container{max-width:min(600px,90vw);max-height:90vh;max-height:90dvh}:-moz-full-screen .quiz-container{max-width:min(600px,90vw);max-height:90vh;max-height:90dvh}:-ms-fullscreen .quiz-container{max-width:min(600px,90vw);max-height:90vh;max-height:90dvh}.quiz-header{text-align:center;margin-bottom:2rem}.quiz-icon{width:48px;height:48px;color:var(--primary-600);margin:0 auto 1rem}.quiz-header h2{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0 0 .5rem}.quiz-subtitle{color:var(--text-secondary);font-size:1rem}.quiz-progress{margin-bottom:2rem}.progress-bar{height:8px;background-color:var(--background-light);border-radius:4px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:var(--primary-500);transition:width .3s ease}.progress-text{font-size:.875rem;color:var(--text-secondary)}.question-container{margin-bottom:2rem}.question-text{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:1.5rem;line-height:1.5}.options-container{display:flex;flex-direction:column;gap:.75rem;position:relative;z-index:1}.option-button{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--background-light);border:2px solid transparent;border-radius:8px;text-align:left;cursor:pointer;transition:all .2s;pointer-events:auto;position:relative;z-index:2}.option-button:hover{background:var(--background-hover);border-color:var(--primary-300)}.option-button.selected{background:var(--primary-50);border-color:var(--primary-500)}.option-letter{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#fff;border-radius:50%;font-weight:600;color:var(--primary-600);flex-shrink:0}.option-button.selected .option-letter{background:var(--primary-600);color:#fff}.option-text{flex:1;color:var(--text-primary);font-size:1rem}.quiz-navigation{display:flex;justify-content:space-between;align-items:center;margin-top:2rem}.quiz-container .nav-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#fff;background-color:#fff;border:1px solid var(--border-color);border-radius:8px;font-size:1rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s;transform:none}.quiz-container .nav-button:hover:not(:disabled){background:var(--background-hover);background-color:var(--background-hover);color:var(--text-primary);transform:translateY(-1px)}.quiz-container .nav-button:active:not(:disabled){transform:translateY(0)}.quiz-container .nav-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.quiz-container .nav-button.primary{background:var(--primary-600);background-color:var(--primary-600);border-color:var(--primary-600);color:#fff}.quiz-container .nav-button.primary:hover:not(:disabled){background:var(--primary-700);background-color:var(--primary-700);border-color:var(--primary-700)}.nav-icon{width:20px;height:20px;flex-shrink:0}.quiz-container .quiz-cancel{display:block;margin:2rem auto 0;padding:.5rem 1rem;background:transparent;background-color:transparent;border:none;color:var(--text-secondary);font-size:.875rem;font-weight:400;text-decoration:underline;cursor:pointer;transition:color .2s;transform:none}.quiz-container .quiz-cancel:hover{background:transparent;background-color:transparent;color:var(--text-primary);transform:none}.quiz-container .quiz-cancel:active{transform:none}.quiz-results{text-align:center;padding:2rem 0 3rem;overflow:visible}.score-circle{width:120px;height:120px;margin:0 auto 2rem;background:var(--primary-500);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(185,204,129,.2)}.score-text{display:flex;align-items:baseline;gap:.25rem;color:#fff}.score-number{font-size:2.5rem;font-weight:700}.score-total{font-size:1.25rem;opacity:.9}.proficiency-result{font-size:1.125rem;color:var(--text-secondary);margin-bottom:1rem}.proficiency-level{display:block;font-size:2rem;font-weight:700;color:var(--primary-600);margin-top:.5rem}.level-description{max-width:400px;margin:0 auto 2rem;padding:1rem;background:var(--background-light);border-radius:8px;color:var(--text-secondary);font-size:.875rem;line-height:1.5}.quiz-actions{display:flex;gap:1rem;justify-content:center}.quiz-button{padding:.75rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;border:none}.quiz-button.primary{background:var(--primary-600);color:#fff}.quiz-button.primary:hover{background:var(--primary-700);transform:translateY(-1px)}.quiz-button.secondary{background:#fff;color:var(--text-primary);border:1px solid var(--border-color)}.quiz-button.secondary:hover{background:var(--background-hover)}.quiz-nav-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#fff;background-color:#fff;border:1px solid var(--border-color);border-radius:8px;font-size:1rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s;transform:none}.quiz-nav-button:hover:not(:disabled){background:var(--background-hover);background-color:var(--background-hover);color:var(--text-primary);transform:translateY(-1px)}.quiz-nav-button:active:not(:disabled){transform:translateY(0)}.quiz-nav-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.quiz-nav-button.quiz-nav-primary{background:var(--primary-600);background-color:var(--primary-600);border-color:var(--primary-600);color:#fff}.quiz-nav-button.quiz-nav-primary:hover:not(:disabled){background:var(--primary-700);background-color:var(--primary-700);border-color:var(--primary-700)}.quiz-cancel-button{display:block;margin:2rem auto 0;padding:.5rem 1rem;background:transparent;background-color:transparent;border:none;color:var(--text-secondary);font-size:.875rem;font-weight:400;text-decoration:underline;cursor:pointer;transition:color .2s;transform:none}.quiz-cancel-button:hover{background:transparent;background-color:transparent;color:var(--text-primary);transform:none}.quiz-cancel-button:active{transform:none}.question-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.question-icon{width:32px;height:32px;color:var(--primary-600)}.question-type-label{background:var(--primary-100);color:var(--primary-700);padding:.25rem .75rem;border-radius:16px;font-size:.75rem;font-weight:500}.adaptive-results-summary{margin-bottom:2rem;padding:1.5rem 1.5rem 2rem;background:var(--background-light);border-radius:12px;overflow:visible}.adaptive-results-summary h3{font-size:1rem;font-weight:600;color:var(--text-secondary);margin-bottom:1rem}.level-progression{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;position:relative}.level-step{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem;border-radius:8px;background:#fff;border:2px solid var(--border-color);min-width:50px;font-size:.875rem;position:relative;cursor:pointer;transition:all .2s ease}.level-step:hover{transform:translateY(-2px);box-shadow:0 4px 8px rgba(0,0,0,.1);z-index:10}.level-step.correct{border-color:var(--success-color, #22c55e);background:rgba(34,197,94,.05)}.level-step.incorrect{border-color:var(--error-color, #ef4444);background:rgba(239,68,68,.05)}.level-step.self-assessment{border-color:var(--primary-400, #9cb847);background:rgba(156,184,71,.05)}.step-level{font-weight:600;color:var(--text-primary)}.question-tooltip{display:none;position:absolute;top:calc(100% + 10px);left:50%;transform:translate(-50%);background:#fff;border:1px solid var(--border-color);border-radius:8px;padding:1rem;box-shadow:0 4px 12px rgba(0,0,0,.15);min-width:300px;max-width:400px;z-index:1000;text-align:left}.level-step:hover .question-tooltip{display:block}.question-tooltip:after{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:8px solid white}.tooltip-header{font-size:.75rem;font-weight:600;color:var(--primary-600);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.tooltip-question{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem;line-height:1.4}.tooltip-answers{display:flex;flex-direction:column;gap:.5rem}.tooltip-your-answer,.tooltip-correct-answer{font-size:.8125rem;padding:.5rem;border-radius:6px;background:var(--background-light)}.tooltip-your-answer strong,.tooltip-correct-answer strong{display:block;font-size:.75rem;color:var(--text-secondary);margin-bottom:.25rem}.tooltip-correct-answer.was-correct{background:rgba(34,197,94,.1);border-left:3px solid var(--success-color, #22c55e)}.tooltip-correct-answer.was-wrong{background:rgba(239,68,68,.1);border-left:3px solid var(--error-color, #ef4444)}.quiz-loading{display:flex;align-items:center;justify-content:center;min-height:400px;color:var(--text-secondary);font-size:1rem}@media (max-width: 640px){.quiz-container{padding:1.5rem;margin:0 auto}.question-text{font-size:1.125rem}.option-button{padding:.875rem}.quiz-container .nav-button{padding:.625rem 1rem;font-size:.875rem}.quiz-actions{flex-direction:column;width:100%}.quiz-button{width:100%}.level-progression{max-width:100%;overflow-x:auto}.level-step{min-width:45px;padding:.375rem;font-size:.75rem}.question-tooltip{min-width:280px;max-width:calc(100vw - 2rem);left:auto;right:auto;transform:translate(-50%)}.tooltip-question{font-size:.8125rem}.tooltip-your-answer,.tooltip-correct-answer{font-size:.75rem}}.quiz-dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background-color:rgba(0,0,0,.5);z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.quiz-dialog-wrapper{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1001;display:flex;align-items:center;justify-content:center;padding:20px;overflow-y:auto}.quiz-dialog-content{max-height:calc(100vh - 40px);max-height:calc(100dvh - 40px);max-width:min(600px,calc(100vw - 40px));width:100%;margin:auto}@media (max-height: 700px){.quiz-dialog-wrapper{padding:10px}.quiz-dialog-content{max-height:calc(100vh - 20px);max-height:calc(100dvh - 20px)}}@media (max-width: 640px){.quiz-dialog-wrapper{padding:10px;align-items:center;justify-content:center}.quiz-dialog-content{max-width:calc(100vw - 20px);max-height:calc(100vh - 20px);max-height:calc(100dvh - 20px);display:flex;align-items:center;justify-content:center}}.quiz-dialog::-webkit-scrollbar{width:8px}.quiz-dialog::-webkit-scrollbar-track{background:rgba(0,0,0,.05);border-radius:4px}.quiz-dialog::-webkit-scrollbar-thumb{background:rgba(0,0,0,.2);border-radius:4px}.quiz-dialog::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,.3)}.location-input-container{position:relative;width:100%}.location-input-wrapper{position:relative;display:flex;align-items:center;background:var(--background);border:2px solid var(--border-color);border-radius:var(--radius-md);transition:all .2s ease;overflow:hidden}.location-input-wrapper:focus-within{border-color:var(--primary-600);box-shadow:0 0 0 3px rgba(59,130,246,.1)}.location-input{flex:1;padding:12px 16px;border:none;background:transparent;font-size:16px;color:var(--text-primary);outline:none}.location-input::placeholder{color:var(--text-secondary)}.location-input:disabled{background:var(--background-soft);color:var(--text-muted);cursor:not-allowed}.location-input-icon{width:20px;height:20px;color:var(--text-secondary);flex-shrink:0}.location-clear-btn{padding:8px;background:none;border:none;cursor:pointer;color:var(--text-secondary);border-radius:var(--radius-sm);transition:all .2s ease;display:flex;align-items:center;justify-content:center}.location-clear-btn:hover{color:var(--text-primary);background:var(--background-hover)}.location-detect-btn{padding:8px 12px;background:var(--primary-50);border:none;cursor:pointer;color:var(--primary-600);transition:all .2s ease;display:flex;align-items:center;justify-content:center;border-left:1px solid var(--border-light)}.location-detect-btn:hover:not(:disabled){background:var(--primary-100);color:var(--primary-700)}.location-detect-btn:disabled{cursor:not-allowed;opacity:.6}.location-detect-btn.detecting{background:var(--primary-100)}.location-spinner{width:20px;height:20px;border:2px solid var(--primary-200);border-top:2px solid var(--primary-600);border-radius:50%;animation:location-spin 1s linear infinite}@keyframes location-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.location-suggestions{position:absolute;top:100%;left:0;right:0;background:var(--background);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:1000;max-height:200px;overflow-y:auto;margin-top:4px}.location-suggestion{display:flex;align-items:center;padding:12px 16px;cursor:pointer;border-bottom:1px solid var(--border-light);transition:background-color .2s ease;gap:12px}.location-suggestion:last-child{border-bottom:none}.location-suggestion:hover,.location-suggestion.selected{background:var(--background-hover)}.location-suggestion.loading{cursor:default;opacity:.7}.suggestion-icon{width:16px;height:16px;color:var(--text-secondary);flex-shrink:0}.suggestion-content{flex:1;min-width:0}.suggestion-name{font-weight:500;color:var(--text-primary);font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.suggestion-details{font-size:12px;color:var(--text-secondary);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.suggestion-spinner{width:16px;height:16px;border:2px solid var(--border-color);border-top:2px solid var(--primary-600);border-radius:50%;animation:location-spin 1s linear infinite}@media (max-width: 768px){.location-input{padding:10px 14px;font-size:16px}.location-suggestions{max-height:150px}.location-suggestion{padding:10px 14px}}@media (prefers-color-scheme: dark){.location-input-wrapper,.location-suggestions{background:var(--background-dark);border-color:var(--border-dark)}.location-suggestion{border-bottom-color:var(--border-dark)}.location-suggestion:hover,.location-suggestion.selected{background:var(--background-hover-dark)}}.talk-now-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:var(--z-talk-now-modal, 500)}.talk-now-modal{background:#fff;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.3);width:90%;max-width:500px;max-height:90vh;max-height:90dvh;overflow-y:auto;position:relative;color:#1f2937;font-family:inherit;font-size:16px;line-height:1.5}.talk-now-modal:has(.ai-interface-container){max-width:700px;max-height:95vh;max-height:95dvh}.ai-interface-container{margin:0;border-radius:0;overflow:hidden;background:transparent;border:none;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center}.ai-interface-container .ai-voice-call-container{background:transparent;border-radius:0;box-shadow:none;margin:0 auto;padding:16px;border:none;width:100%;max-width:500px;display:flex;flex-direction:column;align-items:center}.ai-interface-container .ai-voice-header{padding:12px 16px;border-bottom:none}.ai-interface-container .conversation-history{max-height:300px;overflow-y:auto;margin-bottom:16px;width:100%}.ai-interface-container .ai-voice-controls{border-top:none;padding-top:16px;margin-top:16px;width:100%;display:flex;flex-direction:column;align-items:center}.talk-now-close{position:absolute;top:16px;right:16px;background:none;border:none;cursor:pointer;color:#6b7280;z-index:10;padding:8px;border-radius:8px;transition:all .2s ease}.talk-now-close:hover{background:#f3f4f6;color:#374151}.talk-now-form{padding:32px}.talk-now-header{text-align:center;margin-bottom:32px;padding:1.5rem 0}.talk-now-header .header-icon{display:none}.talk-now-header h2{font-size:2.25rem;font-weight:800;color:var(--text-primary);margin:0 0 .5rem;line-height:1.2;letter-spacing:-.02em;padding-bottom:1rem;position:relative}.talk-now-header h2:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:100px;height:4px;background:var(--orange-600);border-radius:2px}.talk-now-header p{color:#374151;font-size:16px;margin:0;line-height:1.4}.form-group{margin-bottom:24px}.form-group label{display:block;font-weight:600;color:#374151;margin-bottom:8px;font-size:14px}.form-group select{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:12px;font-size:16px;transition:border-color .2s ease;background:#fff}.form-group select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(185,204,129,.1)}.language-toggles{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px}.language-toggle{padding:12px 16px;border:2px solid #e5e7eb;border-radius:12px;background:#fff;color:#374151;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;text-align:center;min-height:48px;display:flex;align-items:center;justify-content:center}.language-toggle:hover{border-color:#d1d5db;background:#f9fafb;transform:translateY(-1px)}.language-toggle.active{border-color:var(--primary-color);background:var(--primary-50);color:var(--primary-color);font-weight:600;box-shadow:0 2px 8px rgba(185,204,129,.15)}.language-hint{display:block;color:#4b5563;font-size:12px;margin-top:8px;font-style:italic;line-height:1.4}.no-native-languages{color:var(--text-secondary);font-style:italic;text-align:center;padding:20px;background:rgba(0,0,0,.05);border-radius:8px;margin:10px 0}.preference-toggles{display:grid;gap:12px}.preference-toggle{display:flex;align-items:center;gap:12px;padding:16px;border:2px solid #e5e7eb;border-radius:12px;background:#fff;color:#374151;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;text-align:left;width:100%;box-sizing:border-box}.preference-toggle:hover{border-color:#d1d5db;background:#f9fafb;transform:translateY(-1px)}.preference-toggle.active{border-color:var(--primary-color);background:var(--primary-50);color:var(--primary-color);font-weight:600;box-shadow:0 2px 8px rgba(185,204,129,.15);position:relative}.preference-toggle.active:after{content:"✓";position:absolute;top:8px;right:12px;font-size:16px;color:var(--primary-color);font-weight:700}.preference-icon{width:24px;height:24px;flex-shrink:0}.preference-content{display:flex;flex-direction:column;gap:4px;flex:1}.token-cost{display:flex;align-items:center;gap:4px;font-size:12px;color:#f97316;font-weight:600;margin-top:2px}.preference-toggle.active .token-cost{color:#ea580c}.token-warning-box{margin-top:12px;padding:12px;border-radius:8px;background:#fef3c7;border:1px solid #fcd34d}.token-loading{display:flex;align-items:center;gap:8px;font-size:14px;color:#78716c}.insufficient-tokens-warning{display:flex;gap:12px;align-items:flex-start}.insufficient-tokens-warning .warning-content{flex:1}.insufficient-tokens-warning strong{display:block;color:#dc2626;font-size:14px;font-weight:600;margin-bottom:4px}.insufficient-tokens-warning p{margin:0 0 8px;color:#78716c;font-size:13px;line-height:1.4}.insufficient-tokens-warning a{display:inline-block;color:#f97316;font-weight:600;font-size:13px;text-decoration:underline}.insufficient-tokens-warning a:hover{color:#ea580c}.token-info{display:flex;align-items:center;gap:8px;font-size:14px;color:#78716c;font-weight:500}.talk-now-submit{width:100%;background:var(--olive-600);color:#fff;border:none;padding:16px 24px;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:8px}.talk-now-submit:hover{transform:translateY(-1px);box-shadow:0 8px 25px rgba(59,130,246,.3)}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:8px;font-size:14px;margin-bottom:16px}.talk-now-searching{padding:0;display:flex;flex-direction:column;height:100%}.waiting-header{display:flex;justify-content:space-between;align-items:center;padding:16px 60px 16px 20px;border-bottom:1px solid var(--border-secondary)}.waiting-header-left{display:flex;align-items:center;gap:12px}.chacha-avatar{width:48px;height:48px;border-radius:50%;overflow:hidden;flex-shrink:0}.chacha-avatar img{width:100%;height:100%;object-fit:cover}.waiting-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.waiting-timer{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:var(--primary-color)}.searching-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px}.searching-message{color:var(--text-secondary);margin-bottom:40px;font-size:15px;line-height:1.5;text-align:center;max-width:400px}.searching-animation{margin-bottom:0;display:flex;align-items:center;justify-content:center}.searching-spinner{opacity:.8}.searching-dots{display:inline-block}.waiting-time{background:var(--background-secondary);padding:12px 20px;border-radius:8px;font-weight:600;color:var(--text-primary);margin-bottom:24px;display:inline-block}.searching-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;padding:16px 24px;background:var(--background-secondary);border-top:1px solid var(--border-secondary)}.minimize-button{background:var(--primary-color);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:14px}.minimize-button:hover{background:var(--olive-700);transform:translateY(-1px)}.cancel-button{background:var(--red-500);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:14px}.cancel-button:hover{background:var(--red-600)}.talk-now-bot{padding:0;text-align:center;display:flex;flex-direction:column;height:100%}.bot-indicator{margin-bottom:24px}.talk-now-bot h3{font-size:24px;font-weight:700;color:#1f2937;margin-bottom:8px}.talk-now-bot p{color:#374151;margin-bottom:24px}.bot-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;padding:16px 24px;background:var(--background-secondary);border-top:1px solid var(--border-secondary)}.end-practice-button{background:#6b7280;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.end-practice-button:hover{background:#4b5563}.timeout-options{margin-bottom:24px}.timeout-message{color:#f59e0b;font-weight:600;margin-bottom:16px;text-align:center}.timeout-buttons{display:flex;gap:12px;justify-content:center}.continue-ai-button{background:var(--primary-color);color:#fff;border:none;padding:12px 20px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:14px}.continue-ai-button:hover{background:var(--olive-700);transform:translateY(-1px)}.talk-now-ai-only{padding:48px 32px;text-align:center}.ai-only-indicator{margin-bottom:24px}.talk-now-ai-only h3{font-size:24px;font-weight:700;color:#1f2937;margin-bottom:8px}.talk-now-ai-only p{color:#374151;margin-bottom:24px}.ai-only-status{display:flex;justify-content:center;gap:24px;margin-bottom:24px;font-size:14px;font-weight:600;color:#374151}.ai-only-actions{display:flex;justify-content:center}.talk-now-matched{padding:32px 24px;text-align:center;display:flex;flex-direction:column;align-items:center;max-width:100%;overflow:hidden}.matched-animation{margin-bottom:20px;display:flex;justify-content:center}.matched-icon{display:flex;align-items:center;justify-content:center;width:72px;height:72px;background:var(--primary-color);border-radius:50%;border:3px solid var(--primary-color);box-shadow:0 4px 12px rgba(156,184,113,.3)}.talk-now-matched h3{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:16px;word-break:break-word}.match-info{margin-bottom:24px;width:100%;max-width:100%}.match-info>p{color:var(--text-secondary);margin-bottom:12px;font-size:15px;word-break:break-word}.participant-info{display:flex;align-items:center;justify-content:flex-start;gap:12px;padding:12px;background:var(--background-secondary);border-radius:10px;border:1px solid var(--border-secondary);max-width:100%;overflow:hidden}.participant-avatar{width:44px;height:44px;border-radius:50%;overflow:hidden;flex-shrink:0}.participant-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;background:var(--primary-color);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600}.participant-details{text-align:left;flex:1;min-width:0;overflow:hidden}.participant-details h4{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.participant-details p{font-size:13px;color:var(--text-secondary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.match-countdown{margin-bottom:12px;width:100%}.match-countdown>p{color:var(--text-secondary);margin-bottom:12px;font-size:14px}.countdown-circle{min-width:60px;height:48px;background:var(--primary-color);border-radius:24px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;font-weight:700;margin:0 auto;padding:0 20px;box-shadow:0 2px 8px rgba(156,184,113,.3);white-space:nowrap}.connecting-animation{display:flex;justify-content:center;gap:8px}.connecting-dot{width:12px;height:12px;background:#10b981;border-radius:50%}.ai-header{display:flex;align-items:center;gap:16px;padding:16px 24px;background:var(--background-secondary);border-bottom:1px solid var(--border-secondary);border-radius:16px 16px 0 0}.ai-info{flex:1}.ai-info h3{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 4px}.language-selector-container{margin-top:8px}.language-selector-container label{display:block;font-size:12px;font-weight:500;color:#64748b;margin-bottom:4px}.language-selector{padding:6px 12px;border:1px solid #e2e8f0;border-radius:6px;font-size:12px;background:#fff;color:#374151}.bot-avatar{position:relative;width:48px;height:48px;border-radius:50%;overflow:hidden;background:var(--primary-color);display:flex;align-items:center;justify-content:center}.bot-avatar img{width:100%;height:100%;object-fit:cover}.chacha-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#fff}.integrated-ai-voice{display:flex;flex-direction:column;height:400px;background:#fff;border-radius:0 0 16px 16px;overflow:hidden}.conversation-area{flex:1;overflow-y:auto;padding:16px;background:#f8fafc}.empty-conversation{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#64748b;text-align:center}.empty-icon{margin-bottom:16px;opacity:.6}.empty-conversation p{font-size:14px;margin:0}.conversation-messages{display:flex;flex-direction:column;gap:12px}.message{display:flex;align-items:flex-start;gap:8px;max-width:100%}.message.user{flex-direction:row-reverse}.message.ai{flex-direction:row}.message-content{flex:1;max-width:80%;padding:12px 16px;border-radius:18px;font-size:14px;line-height:1.4;word-wrap:break-word;word-break:normal}.message.user .message-content{background:var(--primary-500);color:var(--text-on-primary);border-bottom-right-radius:4px}.message.ai .message-content{background:var(--background-light);color:var(--text-primary);border:1px solid var(--border-color);border-bottom-left-radius:4px}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;font-size:11px;font-weight:600}.message.user .message-header{color:rgba(255,255,255,.8)}.message.ai .message-header{color:#64748b}.message-sender{text-transform:uppercase;letter-spacing:.5px}.message-sender.ai{color:var(--primary-color)}.message-time{opacity:.7}.message.user .message-time{opacity:1;color:var(--text-on-primary)}.message-text{margin:0}.play-button{background:var(--primary-500);color:#fff;border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;flex-shrink:0;margin-top:8px}.play-button:hover{transform:scale(1.1);box-shadow:0 4px 12px rgba(16,185,129,.3)}.play-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.voice-controls{padding:16px;background:#fff;border-top:1px solid #e2e8f0}.ai-error{background:#fef2f2;color:#dc2626;padding:8px 12px;border-radius:8px;font-size:12px;margin-bottom:12px;border:1px solid #fecaca}.control-buttons{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:8px}.record-button{background:var(--primary-500);color:#fff;border:none;border-radius:50%;width:64px;height:64px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px rgba(16,185,129,.3)}.record-button:hover:not(:disabled){transform:scale(1.05);box-shadow:0 6px 16px rgba(16,185,129,.4)}.record-button.recording{background:var(--primary-500);animation:pulse 1.5s infinite}.record-button:disabled{opacity:.6;cursor:not-allowed;transform:none}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.processing-indicator{display:flex;align-items:center;gap:8px;color:#64748b;font-size:12px;font-weight:500}.voice-status{text-align:center;font-size:12px;color:#64748b;font-weight:500}.bot-actions,.ai-only-actions{padding:16px 24px;background:#f8fafc;border-top:1px solid #e2e8f0;display:flex;gap:12px;justify-content:center}.continue-ai-btn{background:var(--primary-500);color:#fff;border:none;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.continue-ai-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(139,92,246,.3)}.end-practice-button{background:var(--gray-600);color:#fff;border:none;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.end-practice-button:hover{background:var(--gray-700);transform:translateY(-1px)}.ai-voice-container{padding:16px;background:#fafbfc;border-bottom:1px solid #e2e8f0}.ai-voice-container .ai-voice-overlay{position:static;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none}.ai-voice-container .ai-voice-modal{position:static;background:#fff;border-radius:12px;box-shadow:0 4px 12px rgba(0,0,0,.1);width:100%;max-width:none;margin:0;transform:none}.ai-voice-container .ai-voice-close{display:none}@media (max-width: 640px){.talk-now-modal{margin:16px;width:calc(100% - 32px)}.talk-now-modal:has(.ai-voice-container){max-width:calc(100% - 32px)}.talk-now-form,.talk-now-searching,.talk-now-bot,.talk-now-matched{padding:24px}.bot-header,.ai-header{padding:12px 16px}.ai-voice-container{padding:12px}.status-row{flex-direction:column;gap:12px}.integrated-ai-voice{height:350px}.conversation-area{padding:12px}.message-content{max-width:85%;padding:10px 14px;font-size:13px}.control-buttons{gap:12px}.record-button{width:56px;height:56px}.play-button{width:28px;height:28px}.bot-actions,.ai-only-actions{padding:12px 16px;flex-direction:column}.continue-ai-btn,.end-practice-button{width:100%;justify-content:center}}.step-info{margin-top:16px;padding:12px 16px;background:#f0f9ff;border-radius:8px;border:1px solid #e0f2fe}.preference-summary{font-size:14px;color:#0369a1;font-weight:500;line-height:1.4}.form-actions{display:flex;gap:12px;margin-top:24px}.talk-now-back{background:#f3f4f6;color:#374151;border:1px solid #d1d5db;padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;flex:1}.talk-now-back:hover{background:#e5e7eb;transform:translateY(-1px)}.form-actions .talk-now-submit{flex:2}.talk-now-submit:disabled{background:#d1d5db;color:#9ca3af;cursor:not-allowed;transform:none}.thinking-indicator{display:inline-flex;align-items:center;gap:4px;padding:4px 0}.thinking-indicator .dot{width:6px;height:6px;border-radius:50%;background-color:#9cb471;opacity:.4;animation:thinking-bounce 1.4s infinite ease-in-out both}.thinking-indicator .dot:nth-child(1){animation-delay:-.32s}.thinking-indicator .dot:nth-child(2){animation-delay:-.16s}@keyframes thinking-bounce{0%,80%,to{transform:scale(.8);opacity:.4}40%{transform:scale(1.2);opacity:1}}.background-mode-button{margin-top:1rem;padding:.75rem 1.5rem;background-color:var(--accent-color);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s;font-size:14px}.background-mode-button:hover{transform:translateY(-2px);box-shadow:0 4px 8px rgba(0,0,0,.2)}.talk-now-match-pending{text-align:center;padding:2rem}.match-pending-icon{margin-bottom:1.5rem;display:flex;justify-content:center}.talk-now-match-pending h3{font-size:24px;font-weight:700;color:#1f2937;margin-bottom:.5rem}.talk-now-match-pending p{color:#374151;margin-bottom:1.5rem}.match-partner-info{margin:1.5rem 0;padding:1rem;background-color:rgba(156,184,71,.1);border-radius:8px}.match-partner-info p{margin:.25rem 0;color:#374151;font-size:14px}.acceptance-countdown{margin:2rem 0}.countdown-circle.large{width:120px;height:120px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:700;background-color:var(--primary-color);color:#fff;margin:0 auto 1rem;box-shadow:0 4px 12px rgba(0,0,0,.15)}.acceptance-countdown p{color:#374151;font-size:14px;margin:0}.match-actions{display:flex;gap:1rem;justify-content:center;margin-top:2rem}.accept-match-button{padding:.75rem 2rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s;font-size:14px}.reject-match-button{padding:.75rem 2rem;background-color:var(--red-500);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s;font-size:14px}.accept-match-button:hover,.reject-match-button:hover{transform:translateY(-2px);box-shadow:0 4px 8px rgba(0,0,0,.2)}@media (max-width: 640px){.talk-now-match-pending{padding:1.5rem}.countdown-circle.large{width:100px;height:100px;font-size:2.5rem}.match-actions{flex-direction:column;gap:.75rem}.accept-match-button,.reject-match-button{width:100%}}.talk-now-info-box{display:flex;gap:12px;align-items:flex-start;background:rgba(156,184,113,.08);border:1px solid rgba(156,184,113,.3);border-radius:12px;padding:16px;margin-bottom:24px}.talk-now-info-box .info-content{flex:1}.talk-now-info-box .info-title{font-size:.95rem;font-weight:600;color:var(--primary-color);margin-bottom:8px}.talk-now-info-box .info-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}.talk-now-info-box .info-list li{font-size:.85rem;color:var(--text-secondary);line-height:1.4;padding-left:16px;position:relative}.talk-now-info-box .info-list li:before{content:"•";position:absolute;left:4px;color:var(--primary-color);font-weight:600}@media (max-width: 640px){.talk-now-info-box{padding:12px;margin-bottom:16px}.talk-now-info-box .info-title{font-size:.9rem}.talk-now-info-box .info-list li{font-size:.8rem}}.learning-studio-dropdown{position:relative}.learning-studio-dropdown .learning-studio-trigger{display:flex;align-items:center;gap:8px;padding:10px 20px;background-color:var(--primary-600);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:none;box-shadow:0 4px 15px rgba(99,102,241,.2)}.learning-studio-dropdown .learning-studio-trigger:hover{transform:none;box-shadow:0 4px 15px rgba(99,102,241,.2);background-color:var(--primary-600)}.learning-studio-dropdown.navigation-style .learning-studio-trigger{display:flex;align-items:center;justify-content:center;gap:0;width:40px;height:40px;padding:0;background:transparent;border:none;border-radius:10px;font-size:14px;font-weight:600;color:#9cb847;box-shadow:none;transition:all .2s ease;cursor:pointer}.learning-studio-dropdown.navigation-style .learning-studio-trigger:hover{background:rgba(156,184,71,.12);color:#7a9635;box-shadow:none;transform:scale(1.08)}.learning-studio-dropdown.navigation-style .chevron-icon{display:none}.learning-studio-dropdown .trigger-icon{width:22px;height:22px;flex-shrink:0}.learning-studio-dropdown .chevron-icon{width:14px;height:14px;transition:transform .2s ease;opacity:.7}.learning-studio-dropdown.navigation-style .learning-studio-trigger .chevron-icon{display:none!important}.learning-studio-dropdown .chevron-icon.open{transform:rotate(180deg)}.learning-studio-dropdown .learning-studio-menu{position:absolute;top:100%;left:0;margin-top:4px;background:var(--background-cream, #f1f8ee);border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,.1);min-width:280px;z-index:1000;overflow:hidden;animation:slideDown .2s ease-out;border:1.5px solid rgba(0,0,0,.08)}.learning-studio-dropdown .menu-header{display:none}.learning-studio-dropdown .menu-items{padding:8px}.learning-studio-dropdown .menu-item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 14px;background:transparent;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;text-align:left;box-shadow:none}.learning-studio-dropdown .menu-item:hover{background:rgba(80,86,165,.06);transform:none;box-shadow:none}.learning-studio-dropdown .menu-item-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border-radius:10px;color:#5056a5;flex-shrink:0;transition:all .2s ease}.learning-studio-dropdown .menu-item:hover .menu-item-icon{background-color:#5056a5;color:#fff;transform:scale(1.05)}.learning-studio-dropdown .menu-item-icon svg{width:20px;height:20px;stroke-width:2}.learning-studio-dropdown .menu-item-content h4{margin:0 0 1px;color:#111827;font-size:14px;font-weight:500;letter-spacing:-.01em}.learning-studio-dropdown .menu-item-content p{margin:0;color:#6b7280;font-size:12px;font-weight:400}@media (max-width: 640px){.learning-studio-dropdown .learning-studio-menu{position:fixed;top:auto;bottom:0;left:0;right:0;margin:0;border-radius:16px 16px 0 0;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}}.live-call-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:var(--z-live-call-assistant);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.live-call-modal{background:#fff;border-radius:20px;box-shadow:0 25px 80px rgba(0,0,0,.3);width:90%;max-width:600px;max-height:90vh;overflow-y:auto;position:relative}.live-call-header{display:flex;flex-direction:column;align-items:center;padding:1rem 1.5rem;background:#fff;border-bottom:none;border-radius:16px 16px 0 0;position:relative}.live-call-header .close-button{position:absolute;top:1.5rem;right:2rem;background:transparent;border:none;cursor:pointer;padding:8px;border-radius:8px;transition:background .2s}.live-call-header .close-button:hover{background:#f3f4f6}.live-call-header .close-icon{width:20px;height:20px;color:#6b7280}.live-call-header .header-title{font-size:2.25rem;font-weight:800;color:var(--text-primary);letter-spacing:-.02em;text-align:center;position:relative;padding-bottom:1rem;margin:0}.live-call-header .header-title:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:100px;height:4px;background:var(--orange-600);border-radius:2px}.live-call-modal .live-call-header .header-icon{display:none}.live-call-content{padding:32px}.scenario-selection h3{font-size:24px;font-weight:700;color:#1f2937;margin:0 0 8px;text-align:center}.scenario-selection p{color:#6b7280;text-align:center;margin:0 0 32px}.recording-disclaimer{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;background:#fffbeb;border:1px solid #fde68a;border-radius:8px;margin-bottom:24px}.disclaimer-icon{font-size:20px;line-height:1;flex-shrink:0}.disclaimer-text{flex:1}.disclaimer-text p{margin:0;font-size:14px;line-height:1.5;color:#92400e}.scenarios-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.speaker-selection h3{font-size:24px;font-weight:700;color:#1f2937;margin:0 0 8px;text-align:center}.speaker-selection p{color:#6b7280;text-align:center;margin:0 0 32px}.speaker-options{display:flex;flex-direction:column;gap:12px}.speaker-option-btn{display:flex;align-items:center;gap:16px;padding:16px 24px;background:#fff;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;transition:all .2s;font-size:16px;font-weight:500;color:#1f2937}.speaker-option-btn:hover{border-color:var(--primary-color);background:var(--primary-color-light, rgba(139, 105, 20, .05));transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.1)}.speaker-option-btn.analyze-all{border-color:#d1d5db;background:#f9fafb;margin-top:8px}.speaker-option-btn.analyze-all:hover{border-color:#9ca3af;background:#f3f4f6}.speaker-icon{font-size:24px}.speaker-label{flex:1;text-align:left}.scenario-card{background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;padding:20px;cursor:pointer;transition:all .3s;text-align:center}.scenario-card:hover{border-color:var(--olive-600);transform:translateY(-2px);box-shadow:0 4px 12px rgba(156,180,113,.2);background:var(--olive-50)}.scenario-icon{display:flex;align-items:center;justify-content:center;margin-bottom:12px;color:var(--olive-600)}.scenario-card h4{font-size:16px;font-weight:600;color:#1f2937;margin:0 0 8px}.scenario-card p{font-size:14px;color:#6b7280;margin:0}.custom-scenario-input{margin-top:2rem;padding:1.5rem;background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;animation:fadeIn .3s ease}.custom-scenario-input h4{margin:0 0 .5rem;color:#374151;font-size:1.125rem;font-weight:600}.custom-scenario-input p{margin:0 0 1rem;color:#6b7280;font-size:.875rem;line-height:1.5}.scenario-textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;line-height:1.5;color:#374151;background:#fff;resize:vertical;min-height:100px;font-family:inherit;transition:all .2s ease}.scenario-textarea:focus{outline:none;border-color:var(--olive-500);box-shadow:0 0 0 3px rgba(156,180,113,.1)}.scenario-textarea::placeholder{color:#9ca3af;font-style:italic}.custom-scenario-actions{display:flex;gap:1rem;margin-top:1rem;justify-content:flex-end}.scenario-action-btn{padding:.75rem 1.5rem;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:none;display:flex;align-items:center;justify-content:center;min-width:100px}.scenario-action-btn.cancel{background:#f3f4f6;color:#6b7280;border:1px solid #d1d5db}.scenario-action-btn.cancel:hover{background:#e5e7eb;color:#374151}.scenario-action-btn.continue{background:var(--olive-600);color:#fff}.scenario-action-btn.continue:hover:not(:disabled){background:var(--olive-600);transform:translateY(-1px)}.scenario-action-btn.continue:disabled{background:#d1d5db;color:#9ca3af;cursor:not-allowed;transform:none}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.recording-interface{text-align:center}.back-to-scenarios-link{background:none;border:none;color:var(--primary-color);font-size:14px;font-weight:500;cursor:pointer;padding:8px 0;margin-bottom:16px;display:inline-flex;align-items:center;gap:4px;transition:all .2s ease}.back-to-scenarios-link:hover{color:var(--primary-dark);text-decoration:underline}.recording-status{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;padding:20px;background:var(--cream-50);border-radius:12px;border:1px solid #e5e7eb}.status-title{font-size:24px;font-weight:600;color:#1f2937;margin:0;line-height:1.3}.scenario-badge{display:inline-flex;align-items:center;gap:10px;padding:10px 20px;background:#fff;border:2px solid var(--olive-200);border-radius:10px;font-size:15px;font-weight:600;color:#1f2937;box-shadow:0 1px 3px rgba(0,0,0,.08)}.scenario-badge .scenario-icon{display:flex;align-items:center;justify-content:center;color:var(--olive-600)}.scenario-name{color:#2d3a1a;font-weight:600}.live-call-modal .language-selection{margin-bottom:24px;display:flex;align-items:center;justify-content:center;gap:12px}.live-call-modal .language-selection label{font-weight:600;color:#4b5563}.live-call-modal select.language-select{padding:.625rem 2.75rem .625rem 1rem;border:2px solid #e5e7eb;border-radius:10px;font-size:.875rem;font-weight:500;background-color:#fff;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%239cb847' stroke-linecap='round' stroke-linejoin='round' stroke-width='2.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");background-position:right .75rem center;background-repeat:no-repeat;background-size:1.25rem;color:var(--text-primary);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);appearance:none;-webkit-appearance:none;-moz-appearance:none;min-width:140px}.live-call-modal select.language-select:hover:not(:disabled){border-color:var(--olive-400);box-shadow:0 4px 6px rgba(156,184,71,.12),0 2px 4px rgba(156,184,71,.08);background-color:var(--olive-50);transform:translateY(-1px)}.live-call-modal select.language-select:focus{outline:none;border-color:var(--olive-600);box-shadow:0 0 0 3px rgba(156,184,71,.15),0 4px 6px rgba(156,184,71,.1);background-color:#fff}.live-call-modal select.language-select:disabled{opacity:.5;cursor:not-allowed;background-color:#f3f4f6;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%239ca3af' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");background-position:right .75rem center;background-repeat:no-repeat;background-size:1.25rem;border-color:#e5e7eb;color:#9ca3af}.live-call-modal select.language-select option{padding:.5rem;background:#fff;color:var(--text-primary);font-weight:500}.live-transcription-dialog{margin:20px 0;border:1px solid #e5e7eb;border-radius:12px;background:#f9fafb;max-height:400px;display:flex;flex-direction:column}.dialog-header{padding:12px 16px;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center;background:#fff;border-radius:12px 12px 0 0}.dialog-header h4{margin:0;color:#111827;font-size:.9375rem;font-weight:600}.dialog-header-controls{display:flex;align-items:center;gap:8px}.translation-toggle-btn{background:var(--background-light, #f3f4f6);border:2px solid var(--border-color, #e5e7eb);color:var(--text-secondary, #6b7280);cursor:pointer;padding:6px;border-radius:8px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:36px;height:36px}.translation-toggle-btn:hover{background:var(--background, #fff);border-color:var(--primary-color);transform:translateY(-1px)}.translation-toggle-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff;box-shadow:0 2px 8px rgba(139,105,20,.3)}.toggle-icon{width:20px;height:20px;display:block;flex-shrink:0}.live-call-modal button.hint-button-prominent{background:var(--primary-500);color:#fff;border:none;padding:8px 16px;border-radius:8px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s;box-shadow:0 2px 4px rgba(251,191,36,.2)}.live-call-modal .hint-button-prominent:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px rgba(251,191,36,.3)}.live-call-modal .hint-button-prominent:disabled{opacity:.5;cursor:not-allowed}.live-call-modal button.hint-button-prominent .hint-text{color:#fff}.live-call-modal button.hint-button-prominent .hint-icon{width:20px;height:20px;color:#fff}.dialog-messages{padding:20px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:16px}.dialog-placeholder{text-align:center;color:#9ca3af;font-style:italic;padding:40px 0}.quota-exhausted-notice{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 24px;background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-radius:12px;text-align:center;animation:slideIn .3s ease-out}.quota-notice-icon{font-size:48px;line-height:1}.quota-notice-content{display:flex;flex-direction:column;gap:12px}.quota-notice-content h4{font-size:18px;font-weight:700;color:#92400e;margin:0}.quota-notice-content p{font-size:14px;color:#78350f;margin:0;line-height:1.5}.quota-upgrade-btn{display:inline-block;padding:10px 24px;background:var(--orange-600);color:#fff;font-weight:600;font-size:14px;border-radius:8px;text-decoration:none;transition:all .2s;margin-top:8px}.quota-upgrade-btn:hover{background:#ea580c;transform:translateY(-1px);box-shadow:0 4px 12px rgba(249,115,22,.3)}.dialog-message{animation:slideIn .3s ease-out}.dialog-message.user{background:#fff;padding:12px 16px;border-radius:8px;border:1px solid #e5e7eb}.dialog-message.user[data-interim=true]{opacity:.7;font-style:italic;border-style:dashed}.dialog-message.hint{background:transparent;padding:0;border:none}.dialog-message.system{background:#e0e7ff;padding:12px 16px;border-radius:8px;border:1px solid #c7d2fe;font-style:italic;text-align:center}.dialog-message.error{background:#fee2e2;padding:12px 16px;border-radius:8px;border:1px solid #fecaca;color:#dc2626;text-align:center}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:8px}.message-speaker{font-size:12px;font-weight:600;color:var(--primary-color);padding:2px 8px;background:var(--primary-color-light, rgba(139, 105, 20, .1));border-radius:4px}.message-time{font-size:12px;color:#6b7280;margin-left:auto}.live-call-modal button.improve-btn-inline{background:#eff6ff;color:#3b82f6;border:1px solid #dbeafe;padding:4px 12px;border-radius:6px;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .2s}.live-call-modal .improve-btn-inline:hover{background:#dbeafe;border-color:#3b82f6}.live-call-modal .improve-btn-inline .inline-icon{display:inline-block;vertical-align:middle;margin-right:4px}.message-text{margin:0;color:#111827;line-height:1.5}.message-translation{margin-top:8px;padding:8px 12px;background:var(--olive-50, #f8fafc);border-left:3px solid var(--primary-color, #8b6914);border-radius:4px}.message-translation .translation-arrow{font-size:12px;color:var(--text-secondary, #6b7280);margin-bottom:4px}.message-translation .translation-text{color:#374151;font-size:14px;line-height:1.5;font-style:italic}.recording-timer{margin:24px 0}.timer-text{font-size:36px;font-weight:300;color:#4b5563;font-variant-numeric:tabular-nums}.recording-controls{display:flex;gap:16px;justify-content:center;margin-top:24px}.live-call-modal button.control-btn{display:flex;align-items:center;gap:8px;padding:12px 24px;font-size:16px;font-weight:600;border-radius:12px;cursor:pointer;transition:all .2s ease;border:none;min-width:180px;justify-content:center;-webkit-appearance:none;-moz-appearance:none;appearance:none;text-decoration:none;outline:none}.control-icon{width:20px;height:20px}.live-call-modal button.control-btn.start-btn{background:var(--primary-500);color:#fff}.live-call-modal .start-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(156,180,113,.3)}.live-call-modal button.control-btn.pause-btn{background:var(--primary-500);color:#fff}.live-call-modal button.control-btn.stop-btn{background:#ef4444;color:#fff}.live-call-modal button.control-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.results-interface{text-align:center}.results-interface h3{font-size:24px;font-weight:700;color:#1f2937;margin:0 0 8px}.results-interface>p{color:#6b7280;margin:0 0 24px}.final-transcript{margin:24px 0;text-align:left}.final-transcript h4{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:#1f2937;margin:0 0 12px}.section-icon{width:20px;height:20px;color:var(--olive-600)}.transcript-content{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px;color:#4b5563;line-height:1.6}.action-buttons{margin-top:32px;display:flex;gap:16px;justify-content:center}.live-call-modal button.control-btn.reset-btn{background:var(--primary-500);color:#fff}.live-call-modal button.control-btn.analyze-btn{background:#f97316;color:#fff}.live-call-modal .analyze-btn:hover:not(:disabled){background:#ea580c;transform:translateY(-1px);box-shadow:0 4px 12px rgba(249,115,22,.3)}.live-call-modal .analyze-btn:disabled{opacity:.5;cursor:not-allowed}.call-analysis{margin-top:24px;padding:24px;background:#fafafa;border:1px solid #e5e7eb;border-radius:12px;text-align:left;box-shadow:0 2px 8px rgba(0,0,0,.04)}.call-analysis h4{margin:0 0 20px;color:#111827;font-size:20px;font-weight:700;display:flex;align-items:center;gap:10px;padding-bottom:16px;border-bottom:2px solid #e5e7eb}.analysis-content{color:#4b5563;line-height:1.8;white-space:pre-wrap;font-size:15px}.analysis-content:not(:has(.analysis-section)){display:block}.analysis-content:first-line{font-weight:600;color:#374151;font-size:16px;line-height:2}.analysis-content{text-align:left;padding:16px;background:#fff;border-radius:10px;border:1px solid #e5e7eb;word-spacing:.1em;letter-spacing:.02em}.analysis-section-modern{margin-bottom:20px;border-radius:16px;border:1px solid #e1e8ef;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,.04);transition:all .3s ease}.analysis-section-modern:last-child{margin-bottom:0}.analysis-section-modern:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(0,0,0,.08);border-color:#c7d2fe}.analysis-section-modern .section-header{background:#f8f9fa;border-bottom:1px solid #e1e8ef;padding:16px 20px}.section-header h5{margin:0;color:#1e293b;font-size:16px;font-weight:700;display:flex;align-items:center;gap:10px;letter-spacing:-.02em}.section-header .section-icon{color:#1e293b;flex-shrink:0}.section-content{padding:20px}.section-intro{margin:0 0 16px;color:#475569;font-size:15px;line-height:1.7;font-weight:500;padding:12px 16px;background:#f1f5f9;border-radius:8px;border-left:4px solid #cbd5e1}.section-text p{margin:0 0 12px;color:#475569;line-height:1.7;font-size:15px}.section-text p:last-child{margin-bottom:0}.analysis-list{margin:0;padding:0;list-style:none}.analysis-list li{position:relative;margin-bottom:12px;padding:12px 16px 12px 40px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0;color:#475569;line-height:1.6;font-size:15px;transition:all .2s ease}.analysis-list li:last-child{margin-bottom:0}.analysis-list li:hover{background:#f1f5f9;border-color:#cbd5e1;transform:translate(2px)}.analysis-list li:before{content:"▸";position:absolute;left:16px;top:12px;color:#64748b;font-weight:700;font-size:16px;line-height:1.6}.analysis-section{margin-bottom:24px;padding:16px;background:#fff;border-radius:10px;border:1px solid #e5e7eb;transition:all .2s ease}.analysis-section:last-child{margin-bottom:0}.analysis-section:hover{box-shadow:0 4px 12px rgba(0,0,0,.06);border-color:#d1d5db}.analysis-section h5{margin:0 0 12px;color:#374151;font-size:16px;font-weight:600;display:flex;align-items:center;gap:8px}.analysis-section p{margin:0;color:#4b5563;line-height:1.7;font-size:15px}.analysis-section ul{margin:0;padding-left:24px;list-style:none}.analysis-section ul li{position:relative;margin-bottom:8px;color:#4b5563;line-height:1.6;font-size:15px;padding-left:20px}.analysis-section ul li:before{content:"•";position:absolute;left:0;color:#64748b;font-weight:700;font-size:18px;line-height:1;top:2px}.analysis-section ul li:last-child{margin-bottom:0}.error-message{margin-top:16px;padding:12px;background:#fee2e2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:14px}.hint-container{background:#f8fafc;border-radius:12px;padding:16px;box-shadow:0 1px 3px rgba(0,0,0,.1);margin-top:8px;border:1px solid #e2e8f0;animation:fadeInScale .3s ease-out}.hint-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid #e2e8f0}.hint-icon{width:20px;height:20px;color:#475569;flex-shrink:0}.hint-title{font-weight:600;color:#475569;font-size:.8125rem;text-transform:capitalize;letter-spacing:0}.hint-options{display:flex;flex-direction:column;gap:10px}.hint-option{display:flex;align-items:flex-start;gap:12px;padding:10px 14px;background:#fff;border-radius:8px;border:1px solid #e2e8f0;transition:all .2s ease}.hint-option:hover{transform:translate(2px);border-color:#cbd5e1;box-shadow:0 2px 6px rgba(0,0,0,.08)}.hint-number{display:flex;align-items:center;justify-content:center;width:22px;height:22px;background:#64748b;color:#fff;border-radius:50%;font-weight:600;font-size:.75rem;flex-shrink:0;margin-top:2px}.hint-text{color:#475569;font-size:.9375rem;line-height:1.5;flex:1}.hint-content{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0}.hint-phrase{color:#1e293b;font-size:.9375rem;font-weight:600;line-height:1.5;word-break:break-word}.hint-phrase .chinese-pinyin{display:inline-block;vertical-align:top}.hint-phrase .chinese-pinyin ruby{ruby-position:over;line-height:2.2}.hint-phrase .chinese-pinyin rt{font-size:.65em;color:#64748b;font-weight:400;line-height:1.2}.hint-phrase .chinese-pinyin rb{font-weight:600;font-size:1em;line-height:1}.hint-translation{color:#64748b;font-size:.875rem;font-style:italic;opacity:.9;line-height:1.4}.improvement-container{background:#f0f9ff;border-radius:12px;padding:16px;box-shadow:0 1px 3px rgba(0,0,0,.1);margin-top:12px;border:1px solid #bae6fd;animation:fadeInScale .3s ease-out}.improvement-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid #bae6fd}.improvement-icon{width:20px;height:20px;color:#0369a1;flex-shrink:0}.improvement-title{font-weight:600;color:#0369a1;font-size:.8125rem;text-transform:capitalize;letter-spacing:0}.improvement-content{display:flex;flex-direction:column;gap:10px}.improvement-text{margin:0;color:#1e293b;font-size:.9375rem;font-weight:500;line-height:1.6;padding:12px 16px;background:#fff;border-radius:8px;border:1px solid #e0f2fe}.improvement-explanation{margin:0;color:#475569;font-size:.875rem;line-height:1.5;font-style:italic;padding-left:16px}.audio-player-section{margin:24px 0;padding:20px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;text-align:left}.audio-player-title{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:#1f2937;margin:0 0 16px}.audio-player-container{display:flex;flex-direction:column;gap:12px}.audio-player{width:100%;height:48px;border-radius:8px;background:#fff;border:1px solid #e5e7eb;outline:none;cursor:pointer}.audio-player:focus{border-color:var(--olive-600);box-shadow:0 0 0 3px rgba(156,180,113,.1)}.audio-player::-webkit-media-controls-panel{background:#fff;border-radius:8px}.audio-player::-webkit-media-controls-play-button,.audio-player::-webkit-media-controls-current-time-display,.audio-player::-webkit-media-controls-time-remaining-display{color:#4b5563}.audio-info{display:flex;align-items:center;gap:16px;font-size:14px;color:#6b7280}.audio-duration{display:inline-flex;align-items:center;gap:4px;font-weight:500}@media (max-width: 768px){.live-call-modal{width:95%;max-width:none;margin:20px auto}.live-call-header,.live-call-content{padding:20px}.recording-controls,.action-buttons{flex-wrap:wrap;gap:12px}.live-call-modal .recording-controls button.control-btn,.live-call-modal .action-buttons button.control-btn{min-width:160px;padding:12px 20px;font-size:15px;-webkit-appearance:none;-moz-appearance:none;appearance:none;display:flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:12px;font-weight:600;cursor:pointer;transition:all .2s ease;flex:1 1 auto;max-width:200px}.live-call-modal .recording-controls button.control-btn.start-btn{background:var(--green-500);color:#fff}.live-call-modal .recording-controls button.control-btn.pause-btn{background:var(--orange-600);color:#fff}.live-call-modal .recording-controls button.control-btn.stop-btn{background:#ef4444;color:#fff}.live-call-modal .action-buttons button.control-btn.reset-btn{background:var(--primary-500);color:#fff}.live-call-modal .action-buttons button.control-btn.analyze-btn{background:#f97316;color:#fff}.scenarios-grid{grid-template-columns:1fr;gap:12px}.live-transcription-dialog{max-height:300px}.hint-container{padding:12px}.hint-option{padding:8px 12px}.improvement-container{padding:12px}.action-buttons{flex-wrap:wrap}.call-analysis{padding:16px;margin-top:16px}.call-analysis h4{font-size:18px;margin-bottom:16px;padding-bottom:12px}.analysis-section-modern{margin-bottom:16px;border-radius:12px}.section-header{padding:12px 16px}.section-header h5{font-size:15px;gap:8px}.section-content{padding:16px}.section-intro{font-size:14px;padding:10px 12px;margin-bottom:12px}.section-text p{font-size:14px;margin-bottom:10px}.analysis-list li{font-size:14px;padding:10px 14px 10px 32px;margin-bottom:10px}.analysis-list li:before{left:12px;top:10px;font-size:14px}.analysis-section{margin-bottom:16px;padding:12px}.analysis-section h5{font-size:15px;margin-bottom:10px}.analysis-section p,.analysis-section ul li,.analysis-content{font-size:14px}}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95) translateY(5px)}to{opacity:1;transform:scale(1) translateY(0)}}.reading-practice-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.reading-practice-modal{background:#fff;border-radius:20px;box-shadow:0 25px 80px rgba(0,0,0,.3);width:90%;max-width:900px;max-height:90vh;max-height:90dvh;overflow-y:auto;position:relative}.reading-practice-header{display:flex;flex-direction:column;align-items:center;padding:1.5rem 2rem;background:#fff;border-bottom:none;border-radius:16px 16px 0 0;position:-webkit-sticky;position:sticky;top:0;z-index:10;position:relative}.reading-practice-header .close-button{position:absolute;top:1.5rem;right:2rem;background:transparent;border:none;cursor:pointer;padding:8px;border-radius:8px;transition:background .2s}.reading-practice-header .close-button:hover{background:#f3f4f6}.reading-practice-header .close-icon{width:20px;height:20px;color:#6b7280}.reading-practice-header .header-title{font-size:2.25rem;font-weight:800;color:var(--text-primary);letter-spacing:-.02em;text-align:center;position:relative;padding-bottom:1rem;margin:0}.reading-practice-header .header-title:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:100px;height:4px;background:var(--orange-600);border-radius:2px}.reading-practice-modal .header-icon{display:none}.reading-practice-content{padding:0}.reading-practice-modal .reading-header{display:none}.notification-bell{position:relative}.notification-bell-button{position:relative;width:40px;height:40px;padding:0;border-radius:10px;background-color:transparent;border:none;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.notification-bell-button:hover{background-color:rgba(156,184,71,.12);transform:scale(1.08)}.notification-bell-icon{width:22px;height:22px;color:#9cb847;transition:all .2s ease}.notification-bell-icon.active{color:#f97316;animation:ring .5s ease-in-out}@keyframes ring{0%,to{transform:rotate(0)}25%{transform:rotate(-12deg)}75%{transform:rotate(12deg)}}.notification-bell-button:hover .notification-bell-icon{color:#7a9635}.notification-badge{position:absolute;top:-.25rem;right:-.25rem;background-color:var(--red-500, #ef4444);color:#fff;font-size:.75rem;font-weight:700;border-radius:9999px;min-width:1.25rem;height:1.25rem;display:flex;align-items:center;justify-content:center;padding:0 .25rem;animation:badge-pulse 2s ease-in-out infinite}@keyframes badge-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.notification-dropdown{position:absolute;right:0;top:100%;margin-top:.5rem;width:20rem;background-color:var(--background-cream);border-radius:.5rem;box-shadow:0 10px 25px -5px rgba(0,0,0,.3);border:1px solid var(--border-color);z-index:50;max-height:32rem;display:flex;flex-direction:column;animation:dropdown-appear .2s ease-out}@keyframes dropdown-appear{0%{opacity:0;transform:translateY(-.5rem)}to{opacity:1;transform:translateY(0)}}.notification-dropdown-header{padding:1rem;border-bottom:1px solid var(--border-color)}.notification-dropdown-header h3{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem;padding-bottom:.5rem;border-bottom:3px solid var(--orange-primary);display:block;width:100%}.notification-empty{padding:2rem;text-align:center;color:var(--text-muted)}.notification-list{flex:1;overflow-y:auto;min-height:0}.notification-item{padding:1rem;transition:background-color .2s ease;cursor:pointer}.notification-item:hover{background-color:var(--background-hover)}.notification-item.unread{background-color:rgba(59,130,246,.1)}.notification-item-content{display:flex;align-items:flex-start;gap:.75rem}.notification-icon-wrapper{flex-shrink:0;width:2rem;height:2rem;border-radius:50%;display:flex;align-items:center;justify-content:center}.notification-icon-wrapper.friend-request{background-color:rgba(59,130,246,.2)}.notification-icon-wrapper.accepted{background-color:rgba(34,197,94,.2)}.notification-icon-wrapper.rejected{background-color:rgba(156,163,175,.2)}.notification-icon{width:1rem;height:1rem}.notification-icon.friend-request{color:var(--blue-600, #2563eb)}.notification-icon.accepted{color:var(--green-600, #16a34a)}.notification-icon.rejected{color:var(--gray-600, #4b5563)}.notification-text{flex:1;min-width:0}.notification-message{font-size:.875rem;color:var(--text-primary);margin-bottom:.25rem}.notification-timestamp{font-size:.75rem;color:var(--text-muted)}.notification-actions{display:flex;gap:.5rem;margin-top:.5rem}.notification-action-button{font-size:.75rem;font-weight:500;padding:.25rem .75rem;border-radius:.25rem;border:none;cursor:pointer;transition:all .2s ease}.notification-action-button.accept{background-color:var(--blue-600, #2563eb);color:#fff}.notification-action-button.accept:hover{background-color:var(--blue-700, #1d4ed8)}.notification-action-button.decline{background-color:var(--gray-300, #d1d5db);color:var(--gray-700, #374151)}.notification-action-button.decline:hover{background-color:var(--gray-400, #9ca3af)}@media (prefers-color-scheme: dark){.notification-action-button.decline{background-color:var(--gray-600, #4b5563);color:var(--gray-300, #d1d5db)}.notification-action-button.decline:hover{background-color:var(--gray-500, #6b7280)}}@media (max-width: 640px){.notification-dropdown{position:fixed;top:4rem;right:.5rem;left:.5rem;width:auto;max-width:calc(100vw - 1rem)}}.conversation-corner-dropdown{position:relative}.conversation-corner-dropdown .conversation-corner-trigger{display:flex;align-items:center;gap:8px;padding:10px 20px;background-color:var(--orange-600);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px rgba(255,140,0,.2)}.conversation-corner-dropdown .conversation-corner-trigger:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(255,140,0,.3);background-color:var(--orange-700)}.conversation-corner-dropdown.navigation-style .conversation-corner-trigger{display:flex;align-items:center;justify-content:center;gap:0;width:40px;height:40px;padding:0;background:transparent;border:none;border-radius:10px;font-size:14px;font-weight:600;color:#9cb847;box-shadow:none;transition:all .2s ease;cursor:pointer}.conversation-corner-dropdown.navigation-style .conversation-corner-trigger:hover{background:rgba(156,184,71,.12);color:#7a9635;box-shadow:none;transform:scale(1.08)}.conversation-corner-dropdown.navigation-style .chevron-icon{display:none}.conversation-corner-dropdown .trigger-icon{width:22px;height:22px;flex-shrink:0}.conversation-corner-dropdown .chevron-icon{width:14px;height:14px;transition:transform .2s ease;opacity:.7}.conversation-corner-dropdown.navigation-style .conversation-corner-trigger .chevron-icon{display:none!important}.conversation-corner-dropdown .chevron-icon.open{transform:rotate(180deg)}.conversation-corner-dropdown .conversation-corner-menu{position:absolute;top:100%;left:0;margin-top:4px;background:var(--background-cream, #f1f8ee);border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,.1);min-width:280px;z-index:1000;overflow:hidden;animation:slideDown .2s ease-out;border:1.5px solid rgba(0,0,0,.08)}.conversation-corner-dropdown .menu-header{display:none}.conversation-corner-dropdown .menu-items{padding:8px}.conversation-corner-dropdown .menu-item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 14px;background:transparent;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;text-align:left;text-decoration:none;color:inherit;box-shadow:none}.conversation-corner-dropdown .menu-item:hover{background:rgba(249,115,22,.06);transform:none;box-shadow:none}.conversation-corner-dropdown .menu-item.highlight{background:transparent}.conversation-corner-dropdown .menu-item.highlight:hover{background:rgba(249,115,22,.1);transform:none;box-shadow:none}.conversation-corner-dropdown .menu-item-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background-color:transparent;border-radius:10px;color:var(--orange-600);flex-shrink:0;transition:all .2s ease}.conversation-corner-dropdown .menu-item:hover .menu-item-icon{background-color:var(--orange-600);color:#fff;transform:scale(1.05)}.conversation-corner-dropdown .menu-item.highlight .menu-item-icon{background-color:transparent;color:var(--orange-600)}.conversation-corner-dropdown .menu-item-icon svg{width:20px;height:20px;stroke-width:2}.conversation-corner-dropdown .menu-item-content h4{margin:0 0 1px;color:#111827;font-size:14px;font-weight:500;letter-spacing:-.01em}.conversation-corner-dropdown .menu-item-content p{margin:0;color:#6b7280;font-size:12px;font-weight:400}.mobile-conversation-corner{width:100%}.mobile-conversation-corner .mobile-dropdown-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:1rem 1.25rem;background:transparent;border:none;color:var(--text-secondary);font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;min-height:56px;-webkit-tap-highlight-color:transparent}.mobile-conversation-corner .mobile-dropdown-trigger:hover{background:var(--background-hover)}.mobile-conversation-corner .mobile-dropdown-trigger.active{color:#f15a22}@media (max-width: 640px){.conversation-corner-dropdown .conversation-corner-menu{position:fixed;top:auto;bottom:0;left:0;right:0;margin:0;border-radius:16px 16px 0 0;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}}.profile-dropdown{position:relative;display:inline-block}.profile-dropdown-trigger{display:flex;align-items:center;gap:8px;padding:4px 10px 4px 4px;height:40px;background:transparent;border:none;border-radius:20px;cursor:pointer;transition:all .2s ease}.profile-dropdown-trigger:hover{background:rgba(156,184,71,.08);transform:scale(1.02)}.profile-dropdown-trigger.active{background:rgba(156,184,71,.12)}.profile-dropdown-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;border:2px solid #e5e7eb}.profile-dropdown-avatar-placeholder{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#9cb847,#a8c555);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;border:2px solid #e5e7eb}.profile-dropdown-user-info{display:flex;flex-direction:column;align-items:flex-start}.profile-dropdown-name{font-size:.95rem;font-weight:500;color:#1f2937;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-dropdown-caret{color:#9ca3af;transition:transform .15s ease;flex-shrink:0;width:14px;height:14px}.profile-dropdown-caret.open{transform:rotate(180deg)}.profile-dropdown-menu{position:absolute;top:calc(100% + .5rem);right:0;min-width:200px;background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05);padding:.5rem;z-index:1000;animation:slideDown .2s ease-out}.profile-dropdown-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;width:100%;text-align:left;color:#374151;text-decoration:none;border:none;background:transparent;border-radius:.5rem;cursor:pointer;transition:all .15s;font-size:.95rem}.profile-dropdown-item:hover{background:#f3f4f6;color:#1f2937}.profile-dropdown-item.active{background:#e8f5e9;color:#9cb847;font-weight:600}.profile-dropdown-item.feedback{color:#ec4899}.profile-dropdown-item.feedback:hover{background:#fce7f3;color:#db2777}.profile-dropdown-item.danger{color:#dc2626}.profile-dropdown-item.danger:hover{background:#fee2e2;color:#b91c1c}.profile-dropdown-item svg{flex-shrink:0}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.profile-dropdown-user-info{display:none}.profile-dropdown-trigger{padding:.5rem}.profile-dropdown-menu{min-width:180px}}.feedback-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);display:flex;align-items:flex-start;justify-content:center;z-index:9999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);padding:40px 20px;overflow-y:auto}.feedback-modal{background:#fff;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.2);width:90%;max-width:600px;max-height:calc(100vh - 80px);overflow-y:auto;position:relative;margin:auto}.feedback-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem;border-bottom:none}.feedback-header h2{margin:0;font-size:2.25rem;font-weight:800;color:var(--text-primary);letter-spacing:-.02em;padding-bottom:1rem;position:relative;flex:1;text-align:center}.feedback-header h2:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:100px;height:4px;background:var(--orange-600);border-radius:2px}.close-button{background:transparent;border:none;cursor:pointer;padding:8px;border-radius:8px;transition:background .2s}.close-button:hover{background:#f3f4f6}.close-icon{width:20px;height:20px;color:#6b7280}.feedback-content{padding:28px}.feedback-intro{margin:0 0 24px;font-size:16px;color:#4b5563;line-height:1.6}.category-selection{padding:0}.category-prompt{margin:0 0 24px;font-size:16px;color:var(--text-secondary);line-height:1.6;text-align:center}.category-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:24px}.category-card{border:2px solid #e5e7eb;border-radius:12px;padding:20px;cursor:pointer;transition:all .2s;background:#fafafa}.category-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.08)}.category-card.green:hover{border-color:var(--olive-600, #9cb471);background:var(--olive-50, #f8faef)}.category-card.blue:hover{border-color:var(--olive-500, #b9cc81);background:var(--olive-50, #f8faef)}.category-card.orange:hover{border-color:var(--orange-500, #ff9800);background:#fff7ed}.category-card.purple:hover{border-color:var(--olive-600, #9cb471);background:var(--olive-50, #f8faef)}.category-icon{width:32px;height:32px;margin-bottom:8px;color:#6b7280}.category-card.green:hover .category-icon{color:var(--olive-600, #9cb471)}.category-card.blue:hover .category-icon{color:var(--olive-500, #b9cc81)}.category-card.orange:hover .category-icon{color:var(--orange-500, #ff9800)}.category-card.purple:hover .category-icon{color:var(--olive-600, #9cb471)}.category-title{margin:0 0 4px;font-size:16px;font-weight:600;color:#111827}.category-description{margin:0;font-size:14px;color:#6b7280;line-height:1.4}.category-card h4{margin:0 0 4px;font-size:16px;font-weight:600;color:var(--text-primary)}.category-card p{margin:0;font-size:14px;color:var(--text-secondary);line-height:1.4}.selected-category{padding:16px;background:#f9fafb;border-radius:8px;margin-bottom:20px;display:flex;align-items:center;gap:12px}.selected-category .category-icon{width:24px;height:24px}.selected-category .category-icon.green{color:var(--olive-600, #9cb471)}.selected-category .category-icon.blue{color:var(--olive-500, #b9cc81)}.selected-category .category-icon.orange{color:var(--orange-500, #ff9800)}.selected-category .category-icon.purple{color:var(--olive-600, #9cb471)}.selected-category-text{font-size:14px;color:#4b5563}.selected-category-text strong{color:#111827;font-weight:600}.feedback-form{width:100%}.back-button{background:none;border:none;color:var(--olive-600);font-size:14px;font-weight:600;cursor:pointer;padding:0;margin-bottom:20px;transition:color .2s}.back-button:hover{color:var(--olive-700)}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px}.feedback-textarea{width:100%;min-height:120px;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:16px;line-height:1.5;resize:vertical;transition:border-color .2s;font-family:inherit}.feedback-textarea:focus{outline:none;border-color:var(--olive-600, #9cb471)}.feedback-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px}.cancel-btn,.submit-btn{padding:10px 20px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.cancel-btn{background:var(--white);color:var(--olive-700);border:2px solid var(--olive-500)}.cancel-btn:hover{background:var(--olive-50);border-color:var(--olive-600);color:var(--olive-800)}.submit-btn{background:var(--primary-600, #9cb847);color:#fff;border:2px solid var(--primary-600, #9cb847)}.submit-btn:hover{background:var(--primary-700, #88a438);border-color:var(--primary-700, #88a438);transform:translateY(-1px);box-shadow:0 4px 12px rgba(156,184,71,.3)}.submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.success-state,.success-message{text-align:center;padding:60px 40px}.success-icon{width:64px;height:64px;color:var(--olive-600, #9cb471);margin-bottom:20px}.success-state h3,.success-message h3{margin:0 0 12px;font-size:24px;font-weight:700;color:var(--text-primary)}.success-state p,.success-message p{margin:0;font-size:16px;color:var(--text-secondary);line-height:1.5}@media (max-width: 640px){.feedback-modal{width:95%;max-height:90vh}.feedback-header,.feedback-content{padding:20px}.category-grid{grid-template-columns:1fr;gap:12px}.category-card{padding:16px}.feedback-actions{flex-direction:column-reverse}.cancel-btn,.submit-btn{width:100%}}.nav-item-with-hint{position:relative}.discovery-hint-badge{position:absolute;top:8px;right:8px;width:10px;height:10px;background:#f97316;border:2px solid white;border-radius:50%;animation:hintPulse 2s infinite;z-index:1}@keyframes hintPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.7}}.mobile-nav-link.has-hint{position:relative}.mobile-nav-link.has-hint:after{content:"";position:absolute;top:50%;right:16px;transform:translateY(-50%);width:8px;height:8px;background:#f97316;border:2px solid white;border-radius:50%;animation:hintPulse 2s infinite}.mobile-nav-header{display:none}@media (max-width: 768px){.mobile-nav-header{display:flex;align-items:center;justify-content:flex-end}}.mobile-menu-toggle{padding:8px;background:transparent;border:none;cursor:pointer;color:var(--text-primary);border-radius:8px;transition:background-color .2s}.mobile-menu-toggle:hover{background-color:var(--background-hover)}.menu-icon{width:24px;height:24px}.mobile-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background-color:rgba(0,0,0,.5);z-index:998}.mobile-menu-panel{position:fixed;top:0;right:0;bottom:0;width:85%;max-width:320px;background-color:var(--background-cream, #f1f8ee);box-shadow:-2px 0 10px rgba(0,0,0,.1);z-index:999;overflow-y:auto;display:flex;flex-direction:column}.mobile-user-section{padding:20px;background-color:var(--background-cream, #f1f8ee);border-bottom:1px solid var(--border-color);overflow:visible}.mobile-user-profile{display:flex;align-items:center;gap:12px;text-decoration:none;margin-bottom:16px}.mobile-nav .user-avatar{width:48px;height:48px;border-radius:50%;border:2px solid var(--primary-color)}.mobile-nav .user-avatar-placeholder{width:48px;height:48px;border-radius:50%;background:var(--primary-600);display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;font-weight:600}.user-info{flex:1}.user-name{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:2px}.user-username{font-size:14px;color:var(--text-muted)}.mobile-user-section .user-actions{display:flex;gap:8px;justify-content:flex-end;align-items:center;position:relative;flex-wrap:nowrap}.mobile-user-section .help-tour-button{padding:8px;background:transparent;border:none;cursor:pointer;color:var(--text-primary);border-radius:8px;transition:all .2s;display:flex;align-items:center;justify-content:center;flex-shrink:0;z-index:1}.mobile-user-section .help-tour-button:hover{background-color:rgba(156,184,71,.1);color:var(--primary-500)}.mobile-user-section .feedback-button{flex-shrink:0;z-index:1}.mobile-user-section .feedback-button .feedback-button-text{display:block!important}.mobile-user-section .language-selector-v2{flex-shrink:0;z-index:1}.mobile-nav-items{flex:1;padding:8px}.nav-section{margin-bottom:12px;display:block;clear:both}.nav-section-link{width:100%;display:flex;align-items:center;gap:12px;padding:14px 16px;background:#fff;border:2px solid var(--primary-500, #9cb847);border-radius:8px;cursor:pointer;text-align:left;font-size:16px;font-weight:600;color:var(--primary-500, #9cb847);text-decoration:none;transition:all .2s ease;min-height:52px;box-sizing:border-box;margin-bottom:12px}.nav-section-link:hover{background:var(--primary-500, #9cb847);color:#fff;transform:translateY(-1px);box-shadow:0 2px 8px rgba(156,184,71,.3)}.nav-section-link.active{background:var(--primary-500, #9cb847);color:#fff;box-shadow:0 2px 8px rgba(156,184,71,.3)}.nav-section-link[href="/lessons"]{background:var(--orange-500, #f97316);border-color:var(--orange-500, #f97316);color:#fff;font-weight:700;box-shadow:0 2px 12px rgba(249,115,22,.25)}.nav-section-link[href="/lessons"]:hover{background:#ea580c;border-color:#ea580c;color:#fff;transform:translateY(-2px);box-shadow:0 4px 16px rgba(249,115,22,.4)}.nav-section-link[href="/lessons"].active{background:var(--orange-500, #f97316);color:#fff;box-shadow:0 4px 16px rgba(249,115,22,.4);transform:translateY(-1px)}.nav-section-link.feedback{background:#fff;border-color:#ec4899;color:#ec4899;font-weight:600}.nav-section-link.feedback:hover{background:#ec4899;border-color:#ec4899;color:#fff;transform:translateY(-1px);box-shadow:0 2px 8px rgba(236,72,153,.3)}.nav-section-link.feedback .section-icon{color:inherit}.nav-section-header{width:100%;display:flex;align-items:center;gap:12px;padding:14px 16px;background:transparent;border:none;border-radius:8px;cursor:pointer;text-align:left;font-size:16px;font-weight:500;color:var(--text-primary);transition:background-color .2s;min-height:52px;box-sizing:border-box}.nav-section-header:hover,.nav-section-header.expanded{background-color:var(--background-hover)}.section-icon{width:20px;height:20px;flex-shrink:0}.chevron-icon{width:16px;height:16px;margin-left:auto;transition:transform .2s}.chevron-icon.rotate{transform:rotate(180deg)}.nav-subitems{display:block;width:100%;padding-bottom:8px}.nav-subitem{display:flex;align-items:center;gap:12px;padding:14px 16px 14px 48px;text-decoration:none;color:var(--text-secondary);font-size:15px;background:transparent;border:none;width:100%;text-align:left;cursor:pointer;transition:background-color .2s,color .2s;touch-action:auto;-webkit-tap-highlight-color:rgba(0,0,0,.1);-moz-user-select:none;user-select:none;-webkit-user-select:none;min-height:48px;box-sizing:border-box;position:static;z-index:auto}.nav-subitem:hover{background-color:var(--background-light);color:var(--text-primary)}.nav-subitem.active{background-color:var(--primary-100);color:var(--primary-600);font-weight:500}.nav-subitem.highlight{color:var(--orange-500);font-weight:500}.nav-subitem.highlight:hover{background-color:var(--orange-100);color:var(--orange-600)}.nav-subitem.feedback{color:#ec4899}.nav-subitem.feedback:hover{background-color:#fce7f3;color:#db2777}.nav-subitem .subitem-icon{width:18px;height:18px;flex-shrink:0}.mobile-footer-links{padding:16px;border-top:1px solid var(--border-color);margin-top:auto}.footer-links-group{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.footer-link-item{padding:8px 12px;font-size:14px;color:var(--text-secondary);text-decoration:none;background:transparent;border:none;border-radius:6px;cursor:pointer;text-align:left;transition:all .2s;width:100%}.footer-link-item:hover{background-color:var(--background-hover);color:var(--text-primary)}.footer-link-item.cookie-settings-btn{font-family:inherit}.mobile-footer-copyright{font-size:12px;color:var(--text-muted);text-align:center;margin:12px 0 0;padding-top:12px;border-top:1px solid var(--border-color)}.mobile-logout-section{padding:16px;border-top:1px solid var(--border-color)}.logout-button{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;background:transparent;border:1px solid var(--border-color);border-radius:8px;cursor:pointer;font-size:16px;color:var(--text-secondary);transition:all .2s}.logout-button:hover{background-color:rgba(220,38,38,.1);border-color:var(--red-500);color:var(--red-600)}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.minimized-talk-now-banner{position:fixed;top:70px;left:50%;transform:translate(-50%);z-index:9999;display:flex;align-items:center;gap:8px;background:var(--background-white);border:2px solid var(--primary-color);border-radius:24px;padding:8px 16px;box-shadow:var(--shadow-lg);animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translate(-50%,-20px)}to{opacity:1;transform:translate(-50%)}}.minimized-banner-content{background:none;border:none;cursor:pointer;padding:4px 8px;display:flex;align-items:center;gap:8px;color:var(--text-primary);font-size:.9rem;font-weight:500;transition:all .2s ease}.minimized-banner-content:hover{opacity:.9}.banner-text{white-space:nowrap}.banner-time{display:flex;align-items:center;gap:4px;padding:2px 8px;background:var(--background-cream);border-radius:12px;font-size:.85rem;font-weight:600;color:var(--text-secondary)}.banner-close-btn{background:none;border:none;cursor:pointer;width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);font-size:24px;font-weight:300;line-height:1;border-radius:50%;transition:all .2s ease}.banner-close-btn:hover{background:var(--background-light);color:var(--text-primary)}@media (max-width: 768px){.minimized-talk-now-banner{top:60px;left:12px;right:12px;transform:none;width:auto}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.banner-text{font-size:.85rem}.banner-time{font-size:.8rem}}.react-joyride__tooltip{max-width:420px}.react-joyride__tooltip h3{font-size:1.25rem;font-weight:600;margin-bottom:.75rem;color:#1f2937}.react-joyride__tooltip p{font-size:1rem;line-height:1.5;color:#4b5563;margin-bottom:.5rem}.react-joyride__tooltip ul{margin-left:1rem}.react-joyride__tooltip li{font-size:.95rem;color:#4b5563;margin-bottom:.25rem}.react-joyride__tooltip em{font-style:italic;color:#10b981;font-weight:500}.react-joyride__spotlight{border-radius:.5rem}.react-joyride__progress{background-color:#e5e7eb;height:3px}.react-joyride__progressbar{background-color:#10b981}.react-joyride__button--primary{transition:all .2s ease}.react-joyride__button--primary:hover{background-color:#059669;transform:translateY(-1px)}.react-joyride__button--skip{transition:all .2s ease}.react-joyride__button--skip:hover{color:#374151}.react-joyride__beacon span{background-color:#10b981}.react-joyride__beacon span:nth-child(1){animation:joyride-beacon-pulse 1.2s infinite}@keyframes joyride-beacon-pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.5);opacity:.7}to{transform:scale(2);opacity:0}}nav.navigation-bar,.navigation-bar{position:fixed;top:0;left:0;right:0;width:100%;z-index:10000;background:var(--background-cream);background-color:var(--background-cream);border-bottom:none;box-shadow:0 2px 4px rgba(0,0,0,.1);height:64px;box-sizing:border-box;--nav-height: 64px;margin:0;padding:0}.nav-container{max-width:1280px;margin:0 auto;padding:0 20px}.nav-content{display:flex;align-items:center;justify-content:space-between;height:64px}.nav-logo{display:flex;align-items:center;text-decoration:none;margin-left:-4px}.logo-text{font-size:1.75rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.logo-main{height:40px;width:auto;object-fit:contain;object-position:center}.logo-icon{height:40px;width:auto;margin-left:12px}.desktop-nav-items{display:flex;align-items:center;gap:8px;margin-left:40px}.nav-link{display:flex;align-items:center;gap:6px;padding:8px 12px;text-decoration:none;color:var(--text-primary);font-size:14px;font-weight:500;border-radius:4px;transition:background-color .15s ease}.nav-link:hover{background-color:rgba(241,90,34,.1);color:var(--text-primary)}.nav-link.active{background-color:var(--background-white);color:var(--text-primary);font-weight:600;box-shadow:var(--shadow-sm)}.nav-icon{width:20px;height:20px}.desktop-actions{display:flex;align-items:center;gap:6px;margin-left:auto}.desktop-actions>.language-selector-wrapper,.desktop-actions .language-selector-v2{margin-right:10px}.desktop-actions>.learning-studio-dropdown{margin-right:10px}.navigation-bar .feedback-button{background:var(--background-white);color:var(--pink-feedback);border:1px solid var(--pink-feedback)}.navigation-bar .feedback-button:hover{background:var(--pink-feedback);color:#fff;border-color:var(--pink-feedback);box-shadow:var(--button-hover-shadow)}.user-profile-link{display:flex;align-items:center;gap:8px;padding:6px 12px;text-decoration:none;border-radius:8px;transition:background-color .2s}.user-profile-link:hover{background-color:rgba(0,0,0,.05)}.icon-nav-btn{padding:8px;background:transparent;border:none;cursor:pointer;color:var(--text-primary);border-radius:8px;transition:all .2s;display:flex;align-items:center;justify-content:center;text-decoration:none}.icon-nav-btn:hover{background-color:rgba(156,184,71,.1);color:var(--primary-500)}.icon-nav-btn.active{background-color:var(--background-white);color:var(--primary-500);box-shadow:var(--shadow-sm)}.help-btn{width:40px;height:40px;padding:0;background:transparent;border:none;cursor:pointer;color:#9cb847;border-radius:10px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.help-btn:hover{background-color:rgba(156,184,71,.12);color:#7a9635;transform:scale(1.08)}.help-btn svg{width:22px;height:22px}.logout-btn{padding:8px;background:transparent;border:none;cursor:pointer;color:var(--text-primary);border-radius:8px;transition:all .2s}.logout-btn:hover{background-color:rgba(220,38,38,.1);color:#dc2626}.logout-icon{width:20px;height:20px}.user-profile-link{display:flex;align-items:center;gap:8px;transition:all .2s;text-decoration:none}.user-profile-link:hover{opacity:.8}.nav-container .user-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;border:2px solid var(--border-color);box-sizing:border-box}.nav-container .user-avatar-placeholder{width:32px;height:32px;border-radius:50%;background:var(--primary-500);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;border:2px solid var(--border-color)}.user-display-name{font-size:14px;font-weight:600;color:var(--text-primary)}@media (max-width: 768px){nav.navigation-bar,.navigation-bar{padding-top:env(safe-area-inset-top);height:calc(56px + env(safe-area-inset-top));--nav-height: calc(56px + env(safe-area-inset-top)) ;z-index:9999}.nav-container{padding:0 max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right))}.nav-content{height:56px}.nav-logo{margin-left:0}.logo-main{height:36px}.logo-icon{height:32px;margin-left:8px}.desktop-nav-items,.desktop-actions{display:none}.mobile-nav-actions{display:flex;align-items:center;gap:8px}}.token-balance-display{display:flex;align-items:center;gap:6px;padding:6px 12px;background:rgba(156,184,71,.1);border:1px solid rgba(156,184,71,.2);border-radius:20px;color:var(--primary-color);text-decoration:none;transition:all .2s ease;cursor:pointer}.token-balance-display:hover{background:rgba(156,184,71,.15);border-color:rgba(156,184,71,.3);transform:translateY(-1px)}.token-balance-amount{font-size:14px;font-weight:600;color:var(--text-primary)}.token-balance-display.loading{opacity:.6;cursor:default;pointer-events:none}.dashboard-nav-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:transparent;border:none;border-radius:10px;color:#9cb847;text-decoration:none;transition:all .2s ease;cursor:pointer}.dashboard-nav-btn:hover{background:rgba(156,184,71,.12);color:#8ba73d;transform:scale(1.08)}.dashboard-nav-btn.active{background:#9cb847;color:#fff}.dashboard-nav-btn svg{width:22px;height:22px;flex-shrink:0}.lessons-nav-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;padding:0;background:transparent;border:none;border-radius:10px;color:#f97316;text-decoration:none;transition:all .2s ease;cursor:pointer}.lessons-nav-btn:hover{background:rgba(249,115,22,.12);color:#ea580c;transform:scale(1.08)}.lessons-nav-btn.active{background:#f97316;color:#fff}.lessons-nav-btn svg{width:24px;height:24px;flex-shrink:0}.feedback-nav-btn{display:flex;align-items:center;justify-content:center;gap:8px;height:40px;padding:0 16px;background:transparent;border:none;border-radius:10px;color:#ec4899;text-decoration:none;transition:all .2s ease;cursor:pointer;font-size:15px;font-weight:500;white-space:nowrap}.feedback-nav-btn:hover{background:rgba(236,72,153,.12);color:#db2777;transform:translateY(-1px)}.feedback-nav-btn.active{background:#ec4899;color:#fff}.feedback-nav-btn svg{width:20px;height:20px;flex-shrink:0}.feedback-nav-btn .feedback-text{font-size:15px;font-weight:500}.error-boundary-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--background-primary);padding:48px 16px}@media (min-width: 640px){.error-boundary-container{padding:48px 24px}}@media (min-width: 1024px){.error-boundary-container{padding:48px 32px}}.error-content{text-align:center;max-width:600px}.error-icon{margin:0 auto 24px;width:48px;height:48px;color:var(--error-color, #dc2626)}.error-title{margin-top:24px;font-size:1.875rem;font-weight:800;color:var(--text-primary);line-height:1.2}.error-description{margin-top:8px;font-size:.875rem;color:var(--text-secondary)}.error-details{margin-top:16px;text-align:left}.error-details-summary{cursor:pointer;font-size:.875rem;color:var(--text-muted);transition:color .2s ease}.error-details-summary:hover{color:var(--text-secondary)}.error-stack{margin-top:8px;font-size:.75rem;color:var(--text-secondary);background-color:var(--background-secondary);padding:8px;border-radius:6px;overflow:auto;max-height:256px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;white-space:pre-wrap}.error-actions{margin-top:24px;display:flex;flex-direction:column;gap:12px}@media (min-width: 640px){.error-actions{flex-direction:row;justify-content:center}}.error-btn-primary{width:100%;display:flex;justify-content:center;padding:8px 16px;border:none;border-radius:6px;box-shadow:0 1px 2px rgba(0,0,0,.05);font-size:.875rem;font-weight:500;color:#fff;background-color:var(--orange-500, #f97316);cursor:pointer;transition:background-color .2s ease}.error-btn-primary:hover{background-color:var(--orange-600, #ea580c)}.error-btn-primary:focus{outline:none;box-shadow:0 0 0 2px rgba(249,115,22,.5)}.error-btn-secondary{width:100%;display:flex;justify-content:center;padding:8px 16px;border:1px solid var(--border-color);border-radius:6px;box-shadow:0 1px 2px rgba(0,0,0,.05);font-size:.875rem;font-weight:500;color:var(--text-primary);background-color:var(--background-primary);cursor:pointer;transition:background-color .2s ease}.error-btn-secondary:hover{background-color:var(--background-secondary)}.error-btn-secondary:focus{outline:none;box-shadow:0 0 0 2px rgba(249,115,22,.5)}@media (min-width: 640px){.error-btn-primary,.error-btn-secondary{width:auto;min-width:120px}}.toast-container{position:fixed;top:1rem;right:1rem;z-index:50400;max-width:24rem;width:100%;pointer-events:none}.toast-wrapper{pointer-events:auto}.toast-item{border-radius:.5rem;box-shadow:var(--shadow-lg);padding:1rem;margin-bottom:1rem;display:flex;align-items:center;justify-content:space-between;transform:translate(0);transition:all .3s ease-in-out;color:#fff}.toast-item:hover{transform:scale(1.05)}.toast-success{background-color:var(--green-500, #10b981)}.toast-error{background-color:var(--red-500)}.toast-warning{background-color:var(--yellow-500, #f59e0b)}.toast-info{background-color:var(--blue-500, #3b82f6)}.toast-content{display:flex;align-items:center}.toast-icon-wrapper{flex-shrink:0}.toast-icon{width:1.25rem;height:1.25rem}.toast-message{margin-left:.75rem}.toast-text{font-size:var(--text-sm);font-weight:500}.toast-dismiss{margin-left:1rem;flex-shrink:0;border-radius:.5rem;padding:.375rem;display:inline-flex;color:#fff;background-color:transparent;border:none;cursor:pointer;transition:background-color .2s}.toast-dismiss:hover{background-color:rgba(255,255,255,.2)}.toast-dismiss:focus{outline:none;box-shadow:0 0 0 2px rgba(255,255,255,.5)}.toast-dismiss-icon{width:1rem;height:1rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@keyframes slideOutRight{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}.toast-item{animation:slideInRight .3s ease-out}.toast-item.toast-removing{animation:slideOutRight .3s ease-in}@media (max-width: 640px){.toast-container{right:.5rem;left:.5rem;max-width:none}.toast-item{margin-left:.5rem;margin-right:.5rem}}.footer-container{background-color:var(--background-soft);border-top:1px solid var(--primary-300);padding:.25rem 0;width:100%;position:fixed;bottom:0;left:0;right:0;z-index:50;min-height:28px;box-shadow:0 -1px 3px rgba(0,0,0,.05)}.footer-content{max-width:1200px;margin:0 auto;padding:0 1rem;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem}.footer-section{display:flex;align-items:center;gap:.25rem;flex-wrap:wrap}.footer-copyright{font-size:.75rem;color:var(--text-secondary);margin:0;line-height:1.2}.footer-link{font-size:.75rem;color:var(--text-secondary);text-decoration:none;transition:color .2s ease;line-height:1.2}.footer-link:hover{color:var(--primary-600);text-decoration:underline}.footer-divider{color:var(--text-muted);font-size:.75rem;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1.2}@media (max-width: 768px){.footer-container{display:none}}:root{--z-base: 1;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-popover: 600;--z-tooltip: 700;--z-notification: 800;--z-critical: 900;--z-maximum: 999;--z-navigation: 1000;--z-chat-header: 50;--z-chat-sidebar: var(--z-base);--z-message-input: var(--z-base);--z-user-discovery-elements: 5;--z-below-video: 1;--z-video-call-overlay: var(--z-modal);--z-ai-voice-call: var(--z-modal);--z-talk-now-modal: var(--z-modal);--z-settings-modal: var(--z-modal);--z-profile-modal: var(--z-modal);--z-loading-overlay: var(--z-notification);--z-video-overlay: 50000;--z-video-controls: 50100;--z-ice-breakers: 50200;--z-call-suggestions: 50200;--z-live-transcription: 50200;--z-live-translation: 50200;--z-video-settings: 50300;--z-live-call-assistant: 50400;--z-mobile-navigation: 50150;--z-improve-modal: 50500;--z-call-ending: 50600;--z-incoming-call: 70000;--z-voice-recorder: 9999;--z-recording-consent: 70002;--z-emergency-modal: 70003}.z-base{z-index:var(--z-base)}.z-dropdown{z-index:var(--z-dropdown)}.z-sticky{z-index:var(--z-sticky)}.z-fixed{z-index:var(--z-fixed)}.z-modal-backdrop{z-index:var(--z-modal-backdrop)}.z-modal{z-index:var(--z-modal)}.z-popover{z-index:var(--z-popover)}.z-tooltip{z-index:var(--z-tooltip)}.z-notification{z-index:var(--z-notification)}.friend-notifications-container{position:fixed;top:calc(64px + 1rem);right:1rem;z-index:var(--z-notification)}.friend-notifications-list{display:flex;flex-direction:column;gap:.5rem}.friend-notification-item{background-color:#fff;border:1px solid var(--gray-200);border-radius:.5rem;box-shadow:0 2px 4px rgba(0,0,0,.1);padding:1rem;max-width:20rem;transform:translate(0);transition:all .3s ease;animation:slideInRight .3s ease-out}@media (prefers-color-scheme: dark){.friend-notification-item{background-color:var(--gray-800);border-color:var(--gray-700)}}.friend-notification-content{display:flex;align-items:flex-start;gap:.75rem}.friend-notification-icon-wrapper{flex-shrink:0}.friend-notification-icon{width:2rem;height:2rem;border-radius:50%;display:flex;align-items:center;justify-content:center}.friend-notification-icon.request{background-color:var(--orange-100)}.friend-notification-icon.accepted{background-color:var(--olive-100)}.friend-notification-icon.rejected{background-color:var(--gray-100)}@media (prefers-color-scheme: dark){.friend-notification-icon.request{background-color:var(--orange-800)}.friend-notification-icon.accepted{background-color:var(--olive-800)}.friend-notification-icon.rejected{background-color:var(--gray-700)}}.friend-notification-icon svg{width:1rem;height:1rem}.friend-notification-icon.request svg{color:var(--orange-600)}.friend-notification-icon.accepted svg{color:var(--olive-600)}.friend-notification-icon.rejected svg{color:var(--gray-600)}@media (prefers-color-scheme: dark){.friend-notification-icon.request svg{color:var(--orange-400)}.friend-notification-icon.accepted svg{color:var(--olive-400)}.friend-notification-icon.rejected svg{color:var(--gray-400)}}.friend-notification-body{flex:1;min-width:0}.friend-notification-header{display:flex;align-items:center;justify-content:space-between}.friend-notification-name{font-size:var(--text-sm);font-weight:500;color:var(--gray-900);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (prefers-color-scheme: dark){.friend-notification-name{color:var(--gray-100)}}.friend-notification-dismiss{margin-left:.5rem;color:var(--gray-400);background:none;border:none;cursor:pointer;padding:.25rem;border-radius:.25rem;transition:color .2s}.friend-notification-dismiss:hover{color:var(--gray-600)}@media (prefers-color-scheme: dark){.friend-notification-dismiss:hover{color:var(--gray-300)}}.friend-notification-dismiss svg{width:1rem;height:1rem}.friend-notification-message{font-size:var(--text-sm);color:var(--gray-600);margin-top:.25rem}@media (prefers-color-scheme: dark){.friend-notification-message{color:var(--gray-400)}}.friend-notification-actions{display:flex;gap:.5rem;margin-top:.75rem}.friend-notification-btn{flex:1;font-size:var(--text-xs);font-weight:500;padding:.375rem .75rem;border-radius:.25rem;border:none;cursor:pointer;transition:all .2s;text-align:center}.friend-notification-btn.accept{background-color:#9cb847;color:#fff}.friend-notification-btn.accept:hover{background-color:#8aa33d}.friend-notification-btn.decline{background-color:var(--gray-200);color:var(--gray-700);border:1px solid var(--gray-300)}.friend-notification-btn.decline:hover{background-color:var(--gray-300);border-color:var(--gray-400)}.friend-notification-btn.chat{background-color:#f97316;color:#fff;display:flex;align-items:center;justify-content:center;gap:.375rem}.friend-notification-btn.chat:hover{background-color:#ea580c}.friend-notification-btn.chat .chat-icon{width:1rem;height:1rem}@media (prefers-color-scheme: dark){.friend-notification-btn.accept{background-color:#9cb847}.friend-notification-btn.accept:hover{background-color:#b0cc5a}.friend-notification-btn.decline{background-color:var(--gray-700);color:var(--gray-300);border-color:var(--gray-600)}.friend-notification-btn.decline:hover{background-color:var(--gray-600);border-color:var(--gray-500)}.friend-notification-btn.chat{background-color:#f97316}.friend-notification-btn.chat:hover{background-color:#fb923c}}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 640px){.friend-notifications-container{top:calc(56px + 1rem);left:1rem;right:1rem}.friend-notification-item{max-width:100%;background-color:#fff;border:1px solid var(--gray-200);box-shadow:0 2px 4px rgba(0,0,0,.1)}@media (prefers-color-scheme: dark){.friend-notification-item{background-color:var(--gray-800);border-color:var(--gray-700)}}}.app-loading-container{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center}.app-wrapper{min-height:100vh;min-height:100dvh;background-color:var(--gray-50);transition:colors .3s;display:flex;flex-direction:column;position:relative;overflow-x:hidden}.app-content-wrapper{flex:1;display:flex;align-items:center;justify-content:center}.app-loading-content{text-align:center}.app-loading-spinner{animation:spin 1s linear infinite;border-radius:50%;height:3rem;width:3rem;border:2px solid transparent;border-bottom-color:var(--orange-500);margin:0 auto 1rem}.app-loading-text{color:var(--gray-600);font-size:var(--text-base);margin-bottom:1rem}.app-loading-reset-link{margin-top:1rem;font-size:var(--text-sm);color:var(--blue-600);text-decoration:underline;background:none;border:none;cursor:pointer;padding:0;transition:color .2s}.app-loading-reset-link:hover{color:var(--blue-800)}.app-wrapper{min-height:100vh;background-color:var(--gray-50);transition:colors .3s;display:flex;flex-direction:column;position:relative;overflow-x:hidden}.app-content-wrapper{flex:1;display:flex;flex-direction:column}.main-content{flex:1;padding-top:var(--nav-height);padding-bottom:40px}.main-content[data-page="/chat"]{padding-bottom:0}.main-content-no-nav{flex:1;display:flex;flex-direction:column;padding-bottom:40px}@media (prefers-color-scheme: dark){.app-wrapper{background-color:var(--gray-900)}}.app-debug-tools{position:fixed;bottom:1rem;left:1rem;z-index:50}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.main-content,.main-content-no-nav{padding-bottom:50px}}.pwa-install-prompt.pwa-install-prompt{position:fixed;bottom:8rem;left:1rem;right:1rem;z-index:900;background-color:#fff;border-radius:.5rem;box-shadow:var(--shadow-sm);border:1px solid #e5e7eb;padding:1rem 3rem 1rem 1rem;max-width:100%}@media (min-width: 768px){.pwa-install-prompt.pwa-install-prompt{left:auto;right:1rem;max-width:24rem}}.pwa-install-prompt .pwa-install-prompt-close{position:absolute;top:.75rem;right:.75rem;color:#9ca3af;background:none;border:none;cursor:pointer;padding:.25rem;border-radius:.25rem;z-index:10;transition:color .2s}.pwa-install-prompt .pwa-install-prompt-close:hover{color:#4b5563}.pwa-install-prompt .pwa-install-prompt-close svg{width:1rem;height:1rem}.pwa-install-prompt .pwa-install-prompt-content{display:flex;align-items:flex-start;gap:.75rem}.pwa-install-prompt .pwa-install-prompt-icon{flex-shrink:0;width:2.5rem;height:2.5rem;background-color:#ffedd5;border-radius:.5rem;display:flex;align-items:center;justify-content:center}.pwa-install-prompt .pwa-install-prompt-icon svg,.pwa-install-prompt .pwa-install-prompt-icon img,.pwa-install-prompt .pwa-install-prompt-icon div{width:1.5rem;height:1.5rem;flex-shrink:0}.pwa-install-prompt .pwa-install-prompt-text{flex:1;padding-right:.5rem}.pwa-install-prompt .pwa-install-prompt-title{font-size:.875rem;font-weight:600;color:#111827;margin:0 0 .25rem}.pwa-install-prompt .pwa-install-prompt-description{font-size:.75rem;color:#6b7280;margin:0 0 .75rem;line-height:1.4}.pwa-install-prompt .pwa-install-prompt-button{display:inline-flex;align-items:center;padding:.375rem .75rem;font-size:.75rem;font-weight:500;color:#fff;background-color:#ff9800;border:none;border-radius:.375rem;cursor:pointer;transition:background-color .2s;text-decoration:none}.pwa-install-prompt .pwa-install-prompt-button:hover:not(:disabled){background-color:#e67c00}.pwa-install-prompt .pwa-install-prompt-button:disabled{background-color:#9ca3af;cursor:not-allowed}.pwa-install-prompt .pwa-install-prompt-button svg{width:1rem;height:1rem;margin-right:.25rem}.pwa-install-prompt .pwa-install-prompt-debug{margin-left:.5rem;display:inline-flex;align-items:center;padding:.25rem .5rem;font-size:.75rem;font-weight:500;color:#6b7280;background-color:#f3f4f6;border:none;border-radius:.375rem;cursor:pointer;transition:background-color .2s}.pwa-install-prompt .pwa-install-prompt-debug:hover{background-color:#e5e7eb}.pwa-install-prompt .pwa-install-prompt-ios-description{margin-top:.25rem;margin-bottom:.5rem}.notification-permission-container{animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}.notification-permission-container{--white: #ffffff;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--emerald-500: #10b981;--emerald-600: #059669;--emerald-700: #047857}@media (prefers-color-scheme: dark){.notification-permission-container{background-color:var(--gray-800);border-color:var(--gray-700)}.notification-permission-container p{color:var(--gray-300)}.notification-permission-container .tip-section{background-color:var(--gray-900);border-color:var(--gray-700)}.notification-permission-container [style*=gray-50] p{color:var(--gray-400)}}@media (max-width: 640px){.notification-permission-container{right:10px;width:calc(100vw - 20px);max-width:none}}
