.input-wrapper{display:flex;flex-direction:column;gap:4px;margin-bottom:20px;position:relative}.input-container{position:relative;display:flex;align-items:center}.input-icon-wrapper{position:absolute;left:16px;z-index:1;color:#6b7280;display:flex;align-items:center;pointer-events:none;transition:color .2s ease}.input-wrapper.input-focused .input-icon-wrapper{color:var(--color-primary)}.input-wrapper.input-error .input-icon-wrapper{color:#dc2626}.input-icon{width:20px;height:20px}.input-field{width:100%;padding:16px 16px 16px 48px;border:2px solid #d1d5db;border-radius:8px;font-size:16px;transition:all .2s ease;background:#fff;font-family:inherit;color:#111827}.input-field::placeholder{color:transparent}.input-field:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #60b5ff1a}.input-label{position:absolute;left:48px;top:16px;font-size:16px;color:#6b7280;pointer-events:none;transition:all .2s ease;background:#fff;padding:0 4px;transform-origin:left top}.input-label-floating{top:-10px;left:44px;font-size:12px;color:var(--color-primary);transform:scale(.85)}.input-wrapper.input-focused .input-label-floating{color:var(--color-primary)}.input-wrapper.input-error .input-label-floating{color:#dc2626}.input-required{color:#dc2626;margin-left:2px}.input-success-icon{position:absolute;right:16px;color:#10b981;display:flex;align-items:center;pointer-events:none}.input-wrapper.input-success .input-field{border-color:#10b981}.input-wrapper.input-error .input-field{border-color:#dc2626}.input-wrapper.input-error .input-field:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}.input-error-message{display:flex;align-items:center;gap:6px;color:#dc2626;font-size:12px;margin-top:4px;animation:fadeIn .2s ease}.input-error-icon{flex-shrink:0;width:16px;height:16px}@media (max-width: 768px){.input-field{padding:14px 14px 14px 46px;font-size:16px;min-height:48px}.input-label{left:46px;top:14px;font-size:16px}.input-label-floating{top:-10px;left:42px;font-size:12px}.input-icon-wrapper{left:14px}.input-icon{width:18px;height:18px}}.password-input-wrapper{display:flex;flex-direction:column;gap:4px;margin-bottom:20px;position:relative}.password-input-container{position:relative;display:flex;align-items:center}.password-input-icon-wrapper{position:absolute;left:16px;z-index:1;color:#6b7280;display:flex;align-items:center;pointer-events:none;transition:color .2s ease}.password-input-wrapper.password-input-focused .password-input-icon-wrapper{color:var(--color-primary)}.password-input-wrapper.password-input-error .password-input-icon-wrapper{color:#dc2626}.password-input-icon{width:20px;height:20px}.password-input-field{width:100%;padding:16px 48px;border:2px solid #d1d5db;border-radius:8px;font-size:16px;transition:all .2s ease;background:#fff;font-family:inherit;color:#111827}.password-input-field::placeholder{color:transparent}.password-input-field:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #60b5ff1a}.password-input-label{position:absolute;left:48px;top:16px;font-size:16px;color:#6b7280;pointer-events:none;transition:all .2s ease;background:#fff;padding:0 4px;transform-origin:left top}.password-input-label-floating{top:-10px;left:44px;font-size:12px;color:var(--color-primary);transform:scale(.85)}.password-input-wrapper.password-input-focused .password-input-label-floating{color:var(--color-primary)}.password-input-wrapper.password-input-error .password-input-label-floating{color:#dc2626}.password-input-required{color:#dc2626;margin-left:2px}.password-toggle-button{position:absolute;right:16px;background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;color:#6b7280;transition:color .2s ease;z-index:1}.password-toggle-button:hover{color:var(--color-primary)}.password-toggle-button:focus{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:4px}.password-input-wrapper.password-input-error .password-input-field{border-color:#dc2626}.password-input-wrapper.password-input-error .password-input-field:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}.password-input-error-message{display:flex;align-items:center;gap:6px;color:#dc2626;font-size:12px;margin-top:4px;animation:fadeIn .2s ease}.password-input-error-icon{flex-shrink:0;width:16px;height:16px}.password-strength-indicator{margin-top:8px;padding:12px;background:#f9fafb;border-radius:6px;animation:fadeIn .2s ease}.password-strength-bar{width:100%;height:4px;background:#e5e7eb;border-radius:2px;overflow:hidden;margin-bottom:8px}.password-strength-fill{height:100%;transition:width .3s ease,background-color .3s ease;border-radius:2px}.password-strength-weak .password-strength-fill{background:#ef4444;width:33%}.password-strength-medium .password-strength-fill{background:#f59e0b;width:66%}.password-strength-strong .password-strength-fill{background:#10b981;width:100%}.password-strength-text{font-size:12px;font-weight:600;margin-bottom:8px}.password-strength-weak .password-strength-text{color:#ef4444}.password-strength-medium .password-strength-text{color:#f59e0b}.password-strength-strong .password-strength-text{color:#10b981}.password-requirements{display:flex;flex-direction:column;gap:6px;margin-top:8px}.password-requirement{display:flex;align-items:center;gap:8px;font-size:12px;color:#6b7280;transition:color .2s ease}.password-requirement.requirement-met{color:#10b981}.requirement-icon{width:16px;height:16px;flex-shrink:0;color:#10b981}.requirement-dot{width:6px;height:6px;border-radius:50%;background:#d1d5db;flex-shrink:0}.requirement-met .requirement-dot{display:none}@media (max-width: 768px){.password-input-field{padding:14px 46px;font-size:16px;min-height:48px}.password-input-label{left:46px;top:14px;font-size:16px}.password-input-label-floating{top:-10px;left:42px;font-size:12px}.password-input-icon-wrapper{left:14px}.password-input-icon{width:18px;height:18px}.password-toggle-button{right:14px}}.btn{padding:12px 24px;border:2px solid var(--color-primary);border-radius:var(--radius-button);font-size:16px;font-family:var(--font-english);font-weight:500;letter-spacing:.5px;cursor:pointer;transition:all .3s ease}.btn-primary{background-color:var(--color-cta);border-color:var(--color-cta);color:#fff}.btn-primary:hover:not(:disabled){background-color:#e88a2e;border-color:#e88a2e;transform:translateY(-2px);box-shadow:0 4px 8px #0003}.btn-secondary{background-color:#fff;color:var(--color-primary)}.btn-secondary:hover:not(:disabled){background-color:#f8f9fa}.btn-danger{background-color:var(--color-error);color:#fff;border-color:var(--color-error)}.btn-danger:hover:not(:disabled){background-color:#e94a52;border-color:#e94a52}.btn-small{padding:8px 16px;font-size:14px}.btn-medium{padding:12px 24px;font-size:16px}.btn-large{padding:16px 32px;font-size:18px}.btn-disabled,.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-loading{position:relative;color:transparent}.btn-loading:after{content:"";position:absolute;width:16px;height:16px;top:50%;left:50%;margin-left:-8px;margin-top:-8px;border:2px solid white;border-radius:50%;border-top-color:transparent;animation:spin .6s linear infinite}.btn-secondary.btn-loading:after{border-color:var(--color-primary);border-top-color:transparent}@media (max-width: 768px){.btn{padding:14px 20px;font-size:16px;min-height:44px}.btn-small{padding:10px 16px;font-size:14px;min-height:40px}.btn-large{padding:16px 24px;font-size:18px;min-height:48px}}.language-switcher{display:flex;align-items:center;gap:10px;padding:10px;background:#fff;border-radius:8px;border:2px solid var(--color-primary);position:relative;z-index:5}.language-label{font-size:14px;font-weight:600;color:var(--color-primary);flex-shrink:0}.language-buttons{display:flex;gap:0;border-radius:6px;overflow:hidden;border:2px solid var(--color-primary)}.language-btn{padding:8px 14px;font-size:14px;font-family:inherit;border:none;background:#fff;color:var(--color-primary);cursor:pointer;transition:all .2s ease;min-height:40px;border-right:1px solid var(--color-primary)}.language-btn:last-child{border-right:none}.language-btn:hover{background:#60b5ff14}.language-btn-active{background:var(--color-primary);color:#fff;font-weight:600}.language-btn:focus{outline:none;box-shadow:inset 0 0 0 2px #ffffff80}.language-btn-active:focus{box-shadow:inset 0 0 0 2px #fff}@media (max-width: 768px){.language-switcher{flex-direction:column;gap:8px;padding:12px;width:100%;max-width:300px}.language-label{font-size:13px}.language-buttons{width:100%}.language-btn{flex:1;padding:12px 16px;font-size:16px;min-height:44px}}.auth-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:20px;background-color:#add8e6;position:relative}.auth-card{background:#fff;border-radius:12px;padding:40px;width:100%;max-width:450px;box-shadow:0 4px 6px #0000001a;border:2px solid var(--color-primary)}.auth-title{font-family:var(--font-english);font-size:var(--text-main-title);font-weight:700;color:var(--text-primary);margin-bottom:8px;text-align:center}.auth-subtitle{font-family:var(--font-english);font-size:var(--text-body);color:var(--text-secondary);margin-bottom:15px;text-align:center}.auth-info-text{font-family:var(--font-english);color:var(--text-secondary);margin-bottom:30px;font-size:var(--text-small);font-style:italic;padding:10px;background-color:#f8f9fa;border-radius:5px;border-left:3px solid var(--color-primary);text-align:center}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:600;color:var(--color-primary);font-size:14px}.form-group input,.form-group select{padding:12px;border:2px solid var(--color-primary);border-radius:8px;font-size:16px;transition:all .3s ease;background:#fff}.form-group input:focus,.form-group select:focus{outline:none;border-color:#4682b4;box-shadow:0 0 0 3px #60b5ff1a}.form-select{cursor:pointer}.auth-button{padding:14px;background-color:var(--color-primary);color:#fff;border:2px solid var(--color-primary);border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:10px}.auth-button:hover:not(:disabled){background-color:#4682b4;border-color:#4682b4;transform:translateY(-2px);box-shadow:0 4px 8px #0003}.auth-button:disabled{opacity:.6;cursor:not-allowed}.error-message{background-color:#fee;color:#c33;padding:12px;border-radius:8px;border:2px solid #c33;margin-bottom:20px;font-size:14px;text-align:center}.error-banner{background-color:#fef2f2;border:2px solid #dc2626;border-radius:8px;padding:16px;margin-bottom:20px;animation:fadeIn .2s ease}.error-banner-content{display:flex;flex-direction:column;gap:12px}.error-banner-message{color:#dc2626;font-size:14px;line-height:1.5}.error-banner-message strong{font-weight:600}.email-exists-banner{background-color:#fef3c7;border-color:#f59e0b}.email-exists-banner .error-banner-message{color:#92400e}.error-retry-button{background-color:var(--color-primary);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .2s ease;align-self:flex-start}.error-retry-button:hover:not(:disabled){background-color:#4682b4}.error-retry-button:disabled{opacity:.6;cursor:not-allowed}.error-action-link{color:var(--color-primary);text-decoration:none;font-weight:600;font-size:14px;padding:8px 16px;background-color:#fff;border:2px solid var(--color-primary);border-radius:6px;display:inline-block;transition:all .2s ease;align-self:flex-start}.error-action-link:hover{background-color:var(--color-primary);color:#fff}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.verification-success-message{text-align:center;padding:40px 20px}.success-icon-large{width:80px;height:80px;border-radius:50%;background-color:#10b981;color:#fff;display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:700;margin:0 auto 30px}.verification-title{font-size:24px;font-weight:600;margin:0 0 15px;color:#333}.verification-message{font-size:16px;color:#666;margin:0 0 10px;line-height:1.6}.verification-note{font-size:14px;color:#999;margin:0 0 30px;font-style:italic}.verification-actions{margin-top:30px}@media (max-width: 768px){.verification-success-message{padding:30px 15px}.success-icon-large{width:60px;height:60px;font-size:36px}.verification-title{font-size:20px}.verification-message{font-size:14px}}.resend-verification-section{margin-top:20px;padding:20px;background-color:#fef3c7;border:2px solid #f59e0b;border-radius:8px;text-align:center}.resend-verification-message{font-size:14px;color:#92400e;margin:0 0 15px}.resend-verification-button{margin-bottom:10px}.resend-message{font-size:14px;margin-top:10px;padding:8px;border-radius:4px}.resend-message.success{color:#10b981;background-color:#d1fae5}.resend-message.error{color:#ef4444;background-color:#fee2e2}.auth-footer{margin-top:30px;text-align:center;color:#666;font-size:14px}.auth-link{color:var(--color-primary);text-decoration:none;font-weight:600;transition:color .3s ease}.auth-link:hover{color:#4682b4;text-decoration:underline}.auth-options{display:flex;justify-content:flex-end;margin-top:-10px;margin-bottom:10px}.forgot-password-link{font-size:14px}@media (max-width: 768px){.auth-container{padding:10px;min-height:100vh}.language-switcher-container{position:relative;top:auto;right:auto;margin-bottom:20px;width:100%;display:flex;justify-content:center}.auth-card{padding:25px 20px;max-width:100%;margin:0;border-radius:8px}.auth-title{font-size:24px;margin-bottom:10px}.auth-subtitle{font-size:14px;margin-bottom:10px}.auth-info-text{font-size:11px;padding:8px;margin-bottom:20px}.auth-form{gap:15px}.form-group input,.form-group select{padding:14px;font-size:16px}.auth-button{padding:16px;font-size:16px;min-height:44px}.auth-footer{margin-top:20px;font-size:13px}}@media (max-width: 480px){.auth-container{padding:5px}.auth-card{padding:20px 15px;border-radius:6px}.auth-title{font-size:22px}.auth-subtitle{font-size:13px}.auth-info-text{font-size:10px;padding:6px}}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;background-color:#add8e6}.loading-spinner{display:inline-flex;flex-direction:column;justify-content:center;align-items:center;transform:none!important;isolation:isolate}.loading-spinner-small{padding:0}.loading-spinner-small .spinner{width:16px;height:16px;border-width:2px}.loading-spinner-medium{padding:20px}.loading-spinner-medium .spinner{width:50px;height:50px;border-width:4px}.loading-spinner-large{padding:40px}.loading-spinner-large .spinner{width:80px;height:80px;border-width:6px}.spinner{border:4px solid var(--color-primary);border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite;display:block;flex-shrink:0;transform-origin:center center;will-change:transform}.loading-message{margin-top:20px;font-size:18px;color:var(--color-primary);font-weight:600;display:block;transform:none!important;animation:none!important}@media (max-width: 768px){.loading-container{padding:20px}.loading-spinner{width:40px;height:40px;border-width:3px}.loading-message{font-size:16px;margin-top:15px}}.profile-section{display:flex;gap:20px;padding:20px;background-color:#f8f9fa;border-radius:8px;border:2px solid var(--color-primary);align-items:flex-start}.profile-section-clickable{cursor:pointer;transition:all .3s ease}.profile-section-clickable:hover{background-color:#e9ecef;transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.profile-section-clickable:active{transform:translateY(0)}.profile-picture-container{flex-shrink:0}.profile-picture{width:80px;height:80px;border-radius:50%;overflow:hidden;border:3px solid var(--color-primary);background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .3s ease}.profile-picture:hover{transform:scale(1.05)}.profile-picture img{width:100%;height:100%;object-fit:cover}.profile-picture-placeholder{font-size:32px;font-weight:700;color:var(--color-primary)}.profile-info{flex:1;display:flex;flex-direction:column;gap:10px}.profile-name{font-size:24px;font-weight:600;color:var(--color-primary)}.profile-progress{display:flex;align-items:center;gap:10px;font-size:18px}.progress-label{color:#666;font-weight:500}.progress-value{color:var(--color-primary);font-weight:600}.profile-meta{display:flex;flex-wrap:wrap;gap:15px;font-size:14px;color:#666}.meta-item-streak{color:var(--color-urgent);font-weight:600}@media (max-width: 768px){.profile-section{flex-direction:column;align-items:center;text-align:center}.profile-picture{width:100px;height:100px}.profile-name{font-size:20px}.profile-progress{justify-content:center;font-size:16px}.profile-meta{justify-content:center}}.next-lesson-section{padding:20px;background-color:#f8f9fa;border-radius:8px;border:2px solid var(--color-primary)}.primary-lesson-card{padding:25px;background:#fff;border-radius:8px;border:2px solid var(--color-primary);box-shadow:0 2px 4px #0000001a;margin-bottom:20px}.lesson-header{margin-bottom:15px}.lesson-name{font-family:var(--font-english);font-size:var(--text-lesson-title);font-weight:500;color:var(--text-primary);margin:0}.lesson-meta{display:flex;flex-wrap:wrap;gap:15px;margin-bottom:20px;font-size:14px;color:var(--text-secondary)}.meta-item{display:flex;align-items:center;gap:5px}.lesson-action-button{width:100%;padding:14px 20px;font-size:16px;font-weight:600;min-height:48px;background-color:var(--color-cta);color:#fff;border:2px solid var(--color-cta);border-radius:8px;cursor:pointer;transition:all .3s ease}.lesson-action-button:hover{filter:brightness(1.05);transform:translateY(-2px);box-shadow:0 4px 8px #f79d6566}.other-lessons{padding-top:15px;border-top:1px solid #ddd}.other-lessons-label{font-size:14px;color:var(--text-secondary);margin-bottom:10px;display:block}.other-lesson-item{padding:12px 15px;background:#fff;border-radius:6px;border:1px solid #ddd;margin-bottom:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.other-lesson-item:hover{border-color:var(--color-primary);background-color:#f8f9fa}.other-lesson-name{font-size:14px;font-weight:500;color:var(--color-primary);flex:1}.other-lesson-duration{font-size:12px;color:var(--text-disabled)}@media (max-width: 768px){.primary-lesson-card{padding:20px}.lesson-name{font-size:18px}.lesson-meta{font-size:12px;gap:10px}.lesson-action-button{font-size:14px;padding:12px 16px}.other-lesson-item{padding:10px 12px}.other-lesson-name{font-size:13px}}.last-submitted-section{padding:20px;background-color:#f8f9fa;border-radius:8px;border:2px solid var(--color-primary)}.section-title{font-family:var(--font-english);font-size:var(--text-section-header);font-weight:600;color:var(--text-primary);margin-bottom:15px;display:flex;align-items:center;gap:10px}.section-icon{font-size:24px}.last-submitted-list{display:flex;flex-direction:column;gap:12px}.last-submitted-item{padding:15px;background:#fff;border-radius:6px;border:1px solid #ddd;transition:all .2s ease}.last-submitted-item-clickable{cursor:pointer}.last-submitted-item-clickable:hover{border-color:var(--color-primary);box-shadow:0 2px 4px #0000001a}.last-submitted-item-clickable:focus{outline:2px solid var(--color-primary);outline-offset:2px}.last-submitted-item:hover{border-color:var(--color-primary);box-shadow:0 2px 4px #0000001a}.submitted-lesson-name{font-size:16px;font-weight:600;color:var(--color-primary);margin-bottom:8px}.submitted-lesson-meta{display:flex;flex-wrap:wrap;gap:15px;font-size:14px;color:var(--text-secondary)}.submitted-score{font-weight:500}.submitted-time{color:var(--text-disabled)}.submitted-status{font-weight:600}.submitted-status.passed{color:var(--color-success)}.submitted-status.failed{color:var(--color-error)}.submitted-view-hint{margin-left:auto;color:var(--color-primary);font-weight:500}@media (max-width: 768px){.section-title{font-size:20px}.submitted-lesson-name{font-size:14px}.submitted-lesson-meta{font-size:12px;gap:10px}}.options-section{padding:20px;background-color:#f8f9fa;border-radius:8px;border:2px solid var(--color-primary)}.options-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:15px}.option-card{position:relative}.option-card.optional{opacity:.9}.option-card.disabled{opacity:.6;pointer-events:none}.option-button{width:100%;padding:15px 20px;border-radius:8px;border:2px solid var(--color-primary);background-color:#fff;color:var(--color-primary);font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:12px;text-align:left;min-height:60px}.option-button:hover:not(:disabled){background-color:var(--color-primary);color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #0003}.option-button:disabled{cursor:not-allowed;opacity:.6}.option-icon{font-size:24px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;color:inherit}.option-content{flex:1;display:flex;flex-direction:column;gap:4px}.option-label{font-weight:600;line-height:1.3}.option-preview{font-size:12px;color:#666;font-weight:400}.optional-badge{position:absolute;top:-8px;right:-8px;background-color:#ffc107;color:#856404;font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;border:1px solid #ffc107}.option-card.optional .option-button{background-color:#f8f9fa;border-color:#ddd;color:#666}.option-card.optional .option-button:hover:not(:disabled){background-color:#e9ecef;border-color:var(--color-primary);color:var(--color-primary)}@media (max-width: 768px){.options-grid{grid-template-columns:1fr;gap:12px}.option-button{padding:12px 16px;min-height:56px}.option-icon{font-size:20px}.option-label{font-size:13px}.option-preview{font-size:11px}}.section-icon-chart,.section-icon-svg{display:inline-flex;align-items:center;justify-content:center;color:var(--color-primary)}.stats-section{padding:20px;background-color:#f8f9fa;border-radius:8px;border:2px solid var(--color-primary)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:20px}.stat-item{text-align:center;padding:20px;background:#fff;border-radius:8px;border:1px solid #ddd;transition:all .2s ease}.stat-item:hover{border-color:var(--color-primary);box-shadow:0 2px 4px #0000001a}.stat-value{font-size:32px;font-weight:700;color:var(--color-primary);margin-bottom:8px}.stat-label{font-family:var(--font-english);font-size:var(--text-small);color:var(--text-secondary);font-weight:500}@media (max-width: 768px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:15px}.stat-item{padding:15px}.stat-value{font-size:24px}.stat-label{font-size:12px}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}}.section-icon-svg{display:inline-flex;align-items:center;justify-content:center;color:var(--color-primary)}.dashboard-container{min-height:100vh;padding:40px 20px;background-color:var(--bg-main);position:relative}.dashboard-card{max-width:1200px;margin:0 auto;background:#fff;border-radius:12px;padding:40px;box-shadow:0 4px 6px #0000001a;border:2px solid var(--color-primary)}.dashboard-header{margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid var(--color-primary)}.dashboard-header-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:15px}.dashboard-header h1{font-family:var(--font-english);font-size:var(--text-main-title);font-weight:700;color:var(--text-primary);margin:0;flex:1;min-width:200px}.dashboard-header-actions{display:flex;gap:10px;flex-wrap:wrap}.refresh-button,.logout-button{padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;min-height:44px}.logout-button{background-color:var(--color-primary);color:#fff;border:2px solid var(--color-primary)}.logout-button:hover{background-color:#3498db;border-color:#3498db;transform:translateY(-2px);box-shadow:0 4px 8px #0003}.dashboard-error-banner{background-color:#fff3cd;border:1px solid #ffc107;border-radius:8px;padding:12px 16px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center;gap:15px}.dashboard-error-banner span{color:#856404;flex:1}.error-retry-link{background:none;border:none;color:var(--color-primary);text-decoration:underline;cursor:pointer;font-size:14px;padding:0}.error-retry-link:hover{color:#4682b4}.dashboard-error{text-align:center;padding:60px 20px;background:#fff;border-radius:12px;border:2px solid var(--color-primary);max-width:600px;margin:0 auto}.dashboard-error h2{color:var(--color-primary);margin-bottom:15px}.dashboard-error p{color:#666;margin-bottom:20px}.dashboard-content{display:flex;flex-direction:column;gap:30px}.no-lessons-message{padding:30px;text-align:center;background-color:#f8f9fa;border-radius:8px;border:2px solid var(--color-primary)}.no-lessons-message p{color:#666;font-size:16px;margin:0}@media (max-width: 768px){.dashboard-container{padding:20px 10px}.language-switcher-container{position:relative;top:auto;right:auto;margin-bottom:20px;width:100%;display:flex;justify-content:center}.dashboard-card{padding:25px 20px;max-width:100%;border-radius:8px}.dashboard-header-content{flex-direction:column;align-items:flex-start}.dashboard-header h1{font-size:24px;width:100%}.dashboard-header-actions{width:100%}.refresh-button,.logout-button{width:100%;padding:14px;font-size:16px}.dashboard-content{gap:20px}}@media (max-width: 480px){.dashboard-container{padding:10px 5px}.dashboard-card{padding:20px 15px;border-radius:6px}.dashboard-header h1{font-size:20px}}.coming-soon-view{min-height:100vh;padding:40px 20px;position:relative;display:flex;align-items:center;justify-content:center}.coming-soon-lang-switcher{position:absolute;top:20px;right:20px;background:var(--bg-card);display:flex;align-items:center;justify-content:center}.coming-soon-card{max-width:480px;width:100%;background:#fff;border-radius:16px;padding:48px 40px;text-align:center;box-shadow:0 8px 32px #60b5ff26;border:2px solid var(--color-primary)}.coming-soon-icon{font-size:64px;margin-bottom:24px;line-height:1;display:flex;align-items:center;justify-content:center}.coming-soon-icon-svg{color:var(--color-primary)}.coming-soon-title{font-size:28px;color:var(--color-primary);margin:0 0 16px;font-weight:700}.coming-soon-message{font-size:17px;color:var(--text-primary);line-height:1.6;margin:0 0 24px}.coming-soon-stats{background:#60b5ff14;border-radius:12px;padding:16px 20px;margin:0 0 24px}.coming-soon-personalized{font-size:15px;color:var(--color-primary);margin:0;font-weight:500}.coming-soon-subtext{font-size:14px;color:var(--text-secondary);margin:0 0 32px}.coming-soon-back-btn{min-width:200px}@media (max-width: 480px){.coming-soon-card{padding:32px 24px}.coming-soon-title{font-size:22px}.coming-soon-message{font-size:15px}}.course-selector{display:flex;align-items:center;gap:.65rem;flex-wrap:wrap;margin-bottom:1rem;padding:.75rem 1rem;background:var(--color-surface-elevated, #f4f7fb);border-radius:8px;border:1px solid var(--color-border, #e0e6ed)}.course-selector__label{font-size:.9rem;font-weight:600;color:var(--color-text-secondary, #444)}.course-selector__select{min-width:12rem;padding:.45rem .65rem;border-radius:6px;border:1px solid var(--color-border, #ccc);background:var(--color-surface, #fff);font-size:.95rem;color:var(--color-text, #222)}.course-selector__select:focus{outline:2px solid var(--color-primary, #4682b4);outline-offset:1px}.course-info-view{min-height:100vh;padding:1rem;background:var(--color-bg, #f0f4f8)}.course-info-lang{display:flex;justify-content:flex-end;max-width:720px;margin:0 auto .5rem}.course-info-card{max-width:720px;margin:0 auto;padding:1.75rem 1.5rem 2rem;background:var(--color-surface, #fff);border-radius:12px;box-shadow:0 4px 24px #0000000f;border:1px solid var(--color-border, #e0e6ed)}.course-info-title{margin:0 0 .5rem;font-size:1.5rem;color:var(--color-text, #1a1a1a)}.course-info-intro{margin:0 0 1.25rem;color:var(--color-text-secondary, #555);line-height:1.5}.course-info-switcher-block{margin-bottom:1.75rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-border, #e8e8e8)}.course-info-subtitle{margin:0 0 .35rem;font-size:1.1rem}.course-info-hint{margin:0 0 .75rem;font-size:.9rem;color:var(--color-text-secondary, #666)}.course-info-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1rem}.course-info-staff-note{color:var(--color-text-secondary, #666);margin-bottom:1.5rem}.course-info-grid{display:grid;gap:1rem;margin-bottom:1.5rem}@media (min-width: 600px){.course-info-grid{grid-template-columns:1fr 1fr}}.course-info-panel{padding:1rem 1.1rem;border-radius:8px;background:var(--color-surface-elevated, #f8fafc);border:1px solid var(--color-border, #e8e8e8)}.course-info-panel h3{margin:0 0 .5rem;font-size:1rem}.course-info-panel p{margin:0;font-size:.9rem;line-height:1.45;color:var(--color-text-secondary, #555)}.course-info-footer-back{width:100%;max-width:280px}.lesson-list-item{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:#fff;border-bottom:1px solid #e0e0e0;cursor:pointer;transition:background-color .2s ease}.lesson-list-item:hover{background:#f5f5f5}.lesson-list-item:focus{outline:2px solid var(--color-primary);outline-offset:-2px}.lesson-list-item:last-child{border-bottom:none}.lesson-list-item__number{font-size:.95rem;font-weight:600;color:var(--color-primary);min-width:50px;flex-shrink:0}.lesson-list-item__title{flex:1;font-family:var(--font-english);font-size:var(--text-lesson-title);font-weight:500;color:var(--text-primary)}.lesson-list-item__status{flex-shrink:0}.status-badge{display:inline-block;padding:.35rem .8rem;border-radius:16px;font-size:.8rem;font-weight:500;white-space:nowrap}.status-badge--completed{background:#e8f5e9;color:#2e7d32;border:1px solid #4caf50}.status-badge--in-progress{background:#fff3e0;color:#e65100;border:1px solid #ff9800}.status-badge--not-started{background:#f5f5f5;color:#757575;border:1px solid #bdbdbd}@media (max-width: 768px){.lesson-list-item{padding:.75rem 1rem;gap:.75rem}.lesson-list-item__number{font-size:.9rem;min-width:45px}.lesson-list-item__title{font-size:.85rem}.status-badge{padding:.3rem .65rem;font-size:.75rem}}.lesson-filter{background:#fff;padding:1rem;border-radius:8px;margin-bottom:1.5rem;box-shadow:0 2px 4px #0000000d}.filter-group{display:flex;align-items:center;gap:1rem}.filter-group label{font-weight:500;color:#333;font-size:.9rem}.filter-select{padding:.5rem 1rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;background:#fff;cursor:pointer;min-width:150px}.filter-select:focus{outline:2px solid var(--color-primary);outline-offset:2px}@media (max-width: 768px){.filter-group{flex-direction:column;align-items:flex-start}.filter-select{width:100%}}.error-message{padding:1rem;background-color:#fee;border:1px solid #fcc;border-radius:4px;color:#c33;margin:1rem 0}.error-title{margin:0 0 .5rem;font-size:1.1rem;font-weight:600}.error-text{margin:0;font-size:.9rem}.lessons-list-view{max-width:1200px;margin:0 auto;padding:2rem}.lessons-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:1rem}.lessons-header-left{display:flex;align-items:center;gap:1rem;flex:1}.lessons-header h1{margin:0;font-family:var(--font-english);font-size:var(--text-section-header);font-weight:600;color:var(--text-primary)}.back-button{min-width:auto;white-space:nowrap}.refresh-button{min-width:100px}.lessons-course-row{margin-bottom:1.25rem}.lessons-summary{background:#f8f9fa;padding:1rem 1.5rem;border-radius:8px;margin-bottom:1.5rem}.summary-stats{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:1rem}.stat-item{font-family:var(--font-english);font-size:var(--text-body);color:var(--text-secondary)}.stat-item strong{color:var(--text-primary);font-weight:600}.stat-divider{color:var(--text-disabled);font-weight:300;margin:0 .25rem}.lessons-error-banner{background:#fff3cd;border:1px solid #ffc107;padding:1rem;border-radius:4px;margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center}.error-retry-link{background:none;border:none;color:#856404;text-decoration:underline;cursor:pointer;font-size:.9rem}.lessons-list{background:#fff;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:2rem;overflow:hidden}.lessons-empty{text-align:center;padding:3rem;color:#666}.lessons-pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:2rem;padding:1rem 0}.pagination-button{min-width:100px;padding:.5rem 1.5rem}.pagination-info{font-size:.95rem;color:#666;font-weight:500;min-width:120px;text-align:center}.retry-button{margin-top:1rem}@media (max-width: 768px){.lessons-list-view{padding:1rem}.lessons-header{flex-direction:column;align-items:flex-start;gap:1rem}.lessons-header-left{flex-direction:column;align-items:flex-start;gap:.5rem;width:100%}.back-button{width:100%}.summary-stats{flex-direction:column;gap:.5rem}.lessons-pagination{flex-direction:column;gap:.75rem}.pagination-info{min-width:auto}.pagination-button{width:100%;max-width:200px}}.section-tab-content{padding:2rem;background:#fff;width:100%;box-sizing:border-box}.section-tab-content__instructions{margin-bottom:1.5rem;padding:1rem;background:#f8f9fa;border-left:4px solid var(--color-primary);border-radius:4px}.section-tab-content__instructions p{margin:0;color:#555;font-size:.95rem;line-height:1.6}.section-tab-content__references{margin-bottom:2rem}.reference-display{margin-bottom:1.5rem}.grammar-box{padding:1.5rem;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:1rem}.grammar-box h3{margin:0 0 1rem;font-size:1.1rem;font-weight:600;color:var(--color-primary)}.grammar-box>div{color:#555;line-height:1.6}.section-tab-content__manager-container{width:100%}.section-tab-content .section-header{display:none!important;height:0;margin:0;padding:0;overflow:hidden}.section-tab-content .reference-display{margin-bottom:1.5rem}.section-tab-content .grammar-box{padding:1.5rem;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:1rem}.section-tab-content .lesson-section{margin:0;padding:0;border:none;background:transparent}.section-tab-content .section-content{display:block;width:100%}.section-tab-content .text-exercise{margin:0;padding:0;display:block;width:100%}.section-tab-content .exercise-content{display:block;width:100%}.section-tab-content .exercise-instructions{display:block!important;visibility:visible!important}.section-tab-content__loading,.section-tab-content__error{padding:2rem;text-align:center;color:#666}.section-tab-content__error{color:#dc3545;background:#fff3cd;border:1px solid #ffc107;border-radius:4px}@media (max-width: 768px){.section-tab-content{padding:1.5rem 1rem}.section-tab-content__title{font-size:1.3rem}.section-tab-content__instructions{padding:.75rem}.grammar-box{padding:1rem}}@media (max-width: 480px){.section-tab-content{padding:1rem .75rem}.section-tab-content__title{font-size:1.2rem}}.section-status-circle{display:inline-flex;align-items:center;gap:6px;flex-shrink:0}.section-status-circle__svg{transition:all .3s ease-in-out}.section-status-circle--empty .section-status-circle__circle{fill:transparent;stroke:#94a3b8;stroke-width:2}.section-status-circle--partial .section-status-circle__bg,.section-status-circle--partial .section-status-circle__circle{fill:transparent;stroke:#f59e0b;stroke-width:2}.section-status-circle--partial .section-status-circle__fill{fill:#f59e0b;stroke:none}.section-status-circle--complete .section-status-circle__circle{fill:#22c55e;stroke:#22c55e;stroke-width:2}.section-status-circle--complete .section-status-circle__check{fill:none;stroke:#fff}.section-status-circle__label{font-size:12px;font-weight:500;white-space:nowrap}.section-status-circle__label--empty{color:#64748b}.section-status-circle__label--partial{color:#d97706}.section-status-circle__label--complete{color:#16a34a}.section-status-circle--size-16 .section-status-circle__svg{width:16px;height:16px}.section-status-circle--size-20 .section-status-circle__svg{width:20px;height:20px}.section-status-circle--size-24 .section-status-circle__svg{width:24px;height:24px}.section-status-circle--size-32 .section-status-circle__svg{width:32px;height:32px}@keyframes circleFill{0%{transform:scale(.8);opacity:.5}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.section-status-circle--complete .section-status-circle__svg{animation:circleFill .3s ease-out}@keyframes circlePulse{0%,to{opacity:1}50%{opacity:.8}}.section-status-circle--partial .section-status-circle__fill{animation:circlePulse 2s ease-in-out infinite}.lesson-tabs{max-width:1024px;width:100%;margin:0 auto;display:flex;flex-direction:column;box-sizing:border-box}.lesson-tabs__bar{border-bottom:2px solid #e0e0e0;background:#fff;position:sticky;top:0;z-index:10;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.lesson-tabs__bar-scroll{display:flex;min-width:max-content;gap:0}.lesson-tabs__tab{padding:1rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:1.1rem;font-weight:600;color:#666;white-space:nowrap;transition:all .2s ease;position:relative;min-height:48px;display:flex;align-items:center;gap:8px}.lesson-tabs__tab-label{display:inline-block}.lesson-tabs__tab:hover{color:var(--color-primary);background-color:#f5f5f5}.lesson-tabs__tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:700;background-color:#f8f9fa}.lesson-tabs__tab:focus{outline:2px solid var(--color-primary);outline-offset:-2px}.lesson-tabs__tab:focus:not(:focus-visible){outline:none}.lesson-tabs__content{position:relative;min-height:400px}.lesson-tabs__panel{width:100%}.lesson-tabs__panel--hidden{display:none}.lesson-tabs__panel--active{display:block;animation:fadeIn .2s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.lesson-tabs-empty{padding:3rem;text-align:center;color:#666}.lesson-tabs__tab--complete:not(.lesson-tabs__tab--active){color:#16a34a}.lesson-tabs__tab--partial:not(.lesson-tabs__tab--active){color:#d97706}.lesson-tabs__tab--empty:not(.lesson-tabs__tab--active){color:#64748b}@media (max-width: 768px){.lesson-tabs__tab{padding:.75rem 1rem;font-size:1rem;min-height:44px;gap:6px}.lesson-tabs__bar{overflow-x:auto;-webkit-overflow-scrolling:touch}.lesson-tabs__bar-scroll{padding:0 .5rem}}@media (max-width: 480px){.lesson-tabs__tab{padding:.65rem .85rem;font-size:.95rem;gap:4px}.lesson-tabs__tab .section-status-circle__svg{width:16px;height:16px}}.lesson-tabs__bar::-webkit-scrollbar{height:6px}.lesson-tabs__bar::-webkit-scrollbar-track{background:#f1f1f1}.lesson-tabs__bar::-webkit-scrollbar-thumb{background:#888;border-radius:3px}.lesson-tabs__bar::-webkit-scrollbar-thumb:hover{background:#555}.lesson-review-view{min-height:100vh;background:linear-gradient(to bottom right,#dbeafe,#bfdbfe);padding:1rem}.lesson-review-view-loading{display:flex;justify-content:center;align-items:center;height:100vh;padding:0}@media (min-width: 768px){.lesson-review-view{padding:2rem}}.review-header{max-width:1024px;width:100%;margin:0 auto 1.5rem;background:#fff;padding:1.5rem;border-radius:20px;box-shadow:0 4px 6px #0000001a,0 2px 4px #0000000f;box-sizing:border-box}@media (min-width: 768px){.review-header{padding:2rem}}.review-header-content{display:flex;align-items:center;gap:1rem}.review-title h1{margin:0;font-size:2.25rem;font-weight:700;color:#111827;line-height:1.2}@media (min-width: 768px){.review-title h1{font-size:2.5rem}}.review-title-chinese{margin:.25rem 0 0;font-size:1.125rem;color:#4b5563;font-weight:400;line-height:1.5}@media (min-width: 768px){.review-title-chinese{font-size:1.25rem}}.review-subtitle{margin:.75rem 0 0;color:#6b7280;font-size:.875rem;line-height:1.5}.review-submission-info{max-width:1024px;width:100%;margin:0 auto 1.5rem;background:#f8f9fa;padding:.75rem 1rem;border-radius:8px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;box-sizing:border-box}.submission-badge{padding:.35rem .75rem;background:var(--color-primary);color:#fff;border-radius:16px;font-size:.8rem;font-weight:500}.submission-stats{display:flex;gap:1.5rem;flex-wrap:wrap}.submission-stats .stat{font-size:.9rem;color:#666}.submission-stats .stat strong{color:#333;font-weight:600}.submission-stats .stat.status.passed{color:#2e7d32;font-weight:600}.submission-stats .stat.status.failed{color:#c62828;font-weight:600}.review-audio-placeholder{max-width:1024px;width:100%;margin:0 auto 2rem;background:#f0f0f0;padding:2rem;border-radius:8px;text-align:center;color:#888;font-style:italic;box-sizing:border-box}.review-sections{max-width:1024px;width:100%;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem;box-sizing:border-box}.review-navigation{max-width:1024px;width:100%;margin:0 auto 2rem;display:flex;justify-content:space-between;padding-top:2rem;border-top:1px solid #e0e0e0;box-sizing:border-box}.review-submit-section{max-width:1024px;width:100%;margin:0 auto;text-align:center;padding-top:2rem;border-top:1px solid #e0e0e0;box-sizing:border-box}.submit-success-indicator{max-width:1024px;width:100%;margin:0 auto;display:flex;align-items:center;gap:16px;padding:16px 24px;background:linear-gradient(135deg,#27ae60,#229954);border-radius:8px;color:#fff;box-shadow:0 4px 12px #27ae604d;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.submit-success-checkmark{font-size:32px;line-height:1;flex-shrink:0}.submit-success-message{display:flex;flex-direction:column;gap:4px}.submit-success-message strong{font-size:16px;font-weight:600}.submit-success-score{font-size:14px;opacity:.9}.save-status-indicator{max-width:1024px;width:100%;margin:1rem auto 0;padding:.75rem 1.5rem;background:#fff;border-radius:8px;text-align:center;font-size:.875rem;font-weight:500;box-shadow:0 1px 3px #0000001a}.save-status-saving{color:#3b82f6}.save-status-saving:before{content:"⏳ ";margin-right:.25rem}.save-status-saved{color:#10b981}.save-status-saved:before{content:"✓ ";margin-right:.25rem}.save-status-error{color:#ef4444}.save-status-error:before{content:"⚠ ";margin-right:.25rem}.lesson-controls{max-width:1024px;width:100%;margin:2rem auto 0;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;border-top:2px solid #e5e7eb}.submit-button-wrapper{width:100%}.lesson-controls__hint{margin:0;font-size:.875rem;color:#64748b;text-align:center}.btn-submit-lesson{width:100%;display:inline-flex!important;flex-wrap:wrap;align-items:center;justify-content:center;gap:.5rem .75rem;background:#2196f3!important;color:#fff!important;font-weight:600!important;padding:1rem 2rem!important;font-size:1.125rem!important;border-radius:8px!important;border:none!important;box-shadow:0 2px 4px #2196f34d!important;transition:background-color .2s ease,transform .1s ease,box-shadow .2s ease}.btn-submit-lesson__badge{display:inline-block;padding:.2rem .55rem;font-size:.75rem;font-weight:600;line-height:1.2;color:#1e3a5f;background:#ffffffeb;border-radius:999px;box-shadow:0 1px 2px #0000001f}.btn-submit-lesson:hover:not(:disabled){background:#1976d2!important;transform:translateY(-1px);box-shadow:0 4px 6px #2196f366!important}.btn-submit-lesson:disabled{background:#9ca3af!important;color:#e5e7eb!important;box-shadow:none!important;cursor:not-allowed;transform:none}@media (max-width: 768px){.lesson-controls{padding:1rem}.btn-submit-lesson{padding:.875rem 1.5rem!important;font-size:1rem!important}}.submit-button-disabled{opacity:.6;cursor:not-allowed}.back-button{min-width:120px;background:#f3f4f6!important;color:#374151!important;font-weight:500!important;border:none!important;transition:background-color .2s ease}.back-button:hover{background:#e5e7eb!important}@media (max-width: 768px){.lesson-review-view,.review-header{padding:1rem}.review-header-content,.review-submission-info{flex-direction:column;align-items:flex-start}.submission-stats{flex-direction:column;gap:.5rem}.review-navigation{flex-direction:column;gap:1rem}}.confirmation-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.confirmation-modal{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp .2s ease-out}.confirmation-modal--wide{max-width:640px}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.confirmation-modal__header{padding:1.5rem 1.5rem 1rem;border-bottom:1px solid #e5e7eb}.confirmation-modal__title{margin:0;font-size:1.25rem;font-weight:600;color:#111827}.confirmation-modal__body{padding:1.5rem}.confirmation-modal__warning{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.75rem;background:#fef3c7;border-left:4px solid #f59e0b;border-radius:4px}.confirmation-modal__warning-icon{font-size:1.25rem}.confirmation-modal__warning-text{font-weight:600;color:#92400e}.confirmation-modal__message{margin:0;color:#4b5563;line-height:1.6;font-size:.95rem;white-space:pre-line}.confirmation-modal__footer{padding:1rem 1.5rem 1.5rem;display:flex;gap:.75rem;justify-content:flex-end;border-top:1px solid #e5e7eb}.confirmation-modal__button{padding:.625rem 1.25rem;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;border:none;min-width:100px}.confirmation-modal__button--cancel{background:#f3f4f6;color:#374151}.confirmation-modal__button--cancel:hover{background:#e5e7eb}.confirmation-modal__button--secondary{background:#e0f2fe;color:#0369a1}.confirmation-modal__button--secondary:hover{background:#bae6fd}.confirmation-modal__button--confirm{background:#2196f3;color:#fff}.confirmation-modal__button--confirm:hover{background:#1976d2;transform:translateY(-1px)}.confirmation-modal__button--destructive{background:#f44336;color:#fff}.confirmation-modal__button--destructive:hover{background:#d32f2f}.confirmation-modal__button--warning{background:#f59e0b;color:#fff}.confirmation-modal__button--warning:hover{background:#d97706}.confirmation-modal--destructive .confirmation-modal__title{color:#dc2626}.confirmation-modal--warning .confirmation-modal__title{color:#d97706}@media (max-width: 640px){.confirmation-modal{max-width:100%;margin:1rem}.confirmation-modal__footer{flex-direction:column-reverse}.confirmation-modal__button{width:100%}}.submission-summary--minimal{text-align:left}.submission-summary__line{margin:0;color:#374151;font-size:.95rem;line-height:1.5}.toast{position:fixed;top:20px;right:20px;min-width:300px;max-width:500px;padding:16px 20px;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:10000;display:flex;align-items:center;justify-content:space-between;animation:slideIn .3s ease-out;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast--error{background-color:#fee;border-left:4px solid #e74c3c;color:#c0392b}.toast--success{background-color:#efe;border-left:4px solid #27ae60;color:#229954}.toast__content{display:flex;align-items:center;gap:12px;flex:1}.toast__icon{font-size:20px;flex-shrink:0}.toast__message{font-size:14px;line-height:1.5;flex:1}.toast__close{background:none;border:none;font-size:24px;line-height:1;cursor:pointer;padding:0;margin-left:12px;color:inherit;opacity:.7;transition:opacity .2s;flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.toast__close:hover{opacity:1}.toast__close:focus{outline:2px solid currentColor;outline-offset:2px;border-radius:4px}.review-dashboard{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a;margin-bottom:1.5rem}.review-dashboard.loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:#6b7280}.review-dashboard h2{margin:0 0 1.5rem;font-size:1.5rem;color:#111827}.dashboard-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.metric-card{padding:1.5rem;border-radius:8px;border:2px solid #E5E7EB;transition:all .2s;cursor:pointer}.metric-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.metric-awaiting{border-color:#3b82f6;background:#dbeafe}.metric-under-review{border-color:#f59e0b;background:#fef3c7}.metric-approved{border-color:#10b981;background:#d1fae5}.metric-rejected{border-color:#ef4444;background:#fee2e2}.metric-students{border-color:#8b5cf6;background:#ede9fe;cursor:default}.metric-value{font-size:2rem;font-weight:700;color:#111827;margin-bottom:.5rem}.metric-label{font-size:.875rem;color:#6b7280;font-weight:500}.metric-card.active{border-width:3px;box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.metric-card.active .metric-value{color:var(--color-primary)}.active-indicator{font-size:.75rem;color:var(--color-primary);font-weight:600;margin-top:.5rem;text-align:center}.submissions-table-view{width:100%;background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a}.submissions-filters{display:flex;gap:1rem;margin-bottom:1.5rem;align-items:flex-end}.filter-group{display:flex;flex-direction:column;gap:.5rem;min-width:150px}.submissions-table-container{overflow-x:auto;margin-bottom:1rem}.submissions-table{width:100%;border-collapse:collapse;font-size:.875rem}.submissions-table thead{background:#f9fafb;border-bottom:2px solid #E5E7EB}.submissions-table th{padding:.75rem 1rem;text-align:left;font-weight:600;color:#374151;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.submissions-table td{padding:.75rem 1rem;border-bottom:1px solid #E5E7EB;color:#111827}.submission-row{cursor:pointer;transition:background-color .2s}.submission-row:hover{background-color:#f9fafb}.student-name-cell{display:inline-flex;align-items:baseline;gap:.5rem}.student-id-badge{font-size:.75rem;color:#6b7280;font-weight:400;flex-shrink:0}.submissions-pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem}.pagination-info{font-size:.875rem;color:#6b7280}.submissions-table-loading{padding:3rem;text-align:center;color:#6b7280}.active-filters-bar{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#f3f4f6;border-radius:6px;margin-bottom:1rem;flex-wrap:wrap}.active-filters-label{font-size:.875rem;font-weight:600;color:#374151}.filter-chips{display:flex;gap:.5rem;flex-wrap:wrap;flex:1}.filter-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .75rem;background:#fff;border:1px solid #D1D5DB;border-radius:16px;font-size:.875rem;color:#374151}.filter-chip-label{font-weight:500}.filter-chip-remove{background:none;border:none;color:#6b7280;cursor:pointer;font-size:1.25rem;line-height:1;padding:0;width:18px;height:18px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.filter-chip-remove:hover{background:#f3f4f6;color:#111827}.clear-all-filters-btn{padding:.375rem .75rem;background:#fff;border:1px solid #D1D5DB;border-radius:6px;font-size:.875rem;color:#374151;cursor:pointer;transition:all .2s;font-weight:500}.clear-all-filters-btn:hover{background:#f9fafb;border-color:#9ca3af}.results-info{margin-bottom:1rem;padding:.75rem 1rem;background:#f9fafb;border-radius:6px;border-left:3px solid var(--color-primary)}.results-count{font-size:.875rem;color:#374151;font-weight:500}.results-context{color:#6b7280;font-weight:400}.no-results-message{font-size:.875rem;color:#6b7280;font-style:italic}.submission-detail-panel{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a;height:100%;overflow-y:auto}.submission-detail-panel.empty,.submission-detail-panel.loading{display:flex;align-items:center;justify-content:center;min-height:400px;color:#6b7280;font-style:italic}.detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #E5E7EB}.detail-header h2{margin:0;font-size:1.5rem;color:#111827}.detail-metadata,.metadata-section{margin-bottom:1.5rem}.metadata-section h3{margin:0 0 .75rem;font-size:1rem;font-weight:600;color:#374151}.metadata-item{display:flex;margin-bottom:.5rem;font-size:.875rem}.metadata-label{font-weight:500;color:#6b7280;min-width:120px}.metadata-value{color:#111827}.student-id-inline{font-size:.8125rem;color:#6b7280;font-weight:400}.detail-actions{margin-bottom:1.5rem;padding-top:1rem;border-top:1px solid #E5E7EB}.action-buttons{display:flex;gap:.75rem}.detail-lesson-content{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #E5E7EB}.detail-lesson-content h3{margin:0 0 1rem;font-size:1rem;font-weight:600;color:#374151}.lesson-content-preview{background:#f9fafb;padding:1rem;border-radius:6px}.lesson-grammar{font-weight:600;color:var(--color-primary);margin:0 0 .5rem}.lesson-title-chinese{font-size:1.125rem;color:#111827;margin:0 0 .5rem}.lesson-note{font-size:.875rem;color:#6b7280;font-style:italic;margin:0}.badge-submitted{background:#dbeafe;color:#1e40af}.badge-under-review{background:#fef3c7;color:#92400e}.badge-approved{background:#d1fae5;color:#065f46}.badge-rejected{background:#fee2e2;color:#991b1b}.badge-resubmitting{background:#e0e7ff;color:#3730a3}.score{font-weight:600}.score-passed{color:#059669}.score-failed{color:#dc2626}.detail-submission-content{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #E5E7EB}.detail-submission-content h3{margin:0 0 1rem;font-size:1rem;font-weight:600;color:#374151}.submission-field-item{padding:1rem;margin-bottom:1rem;border:1px solid #E5E7EB;border-radius:6px;background:#f9fafb}.field-header{margin-bottom:.75rem}.field-section-label{display:block;font-size:.75rem;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.field-label{display:block;font-weight:600;font-size:.875rem;color:#374151}.field-content{margin-top:.75rem}.field-dialogue{display:flex;gap:.5rem;font-size:.875rem;color:#111827;margin-bottom:.5rem}.field-speaker{font-weight:600;color:var(--color-primary);flex-shrink:0}.field-prompt,.field-prompt-text{font-size:.875rem;color:#111827;line-height:1.5;margin-bottom:.5rem}.field-student-answer .no-answer{color:#9ca3af;font-style:italic}.field-answer-slots{margin-top:.75rem}.field-answer-slot{display:flex;flex-wrap:wrap;align-items:baseline;gap:.75rem 1.5rem;margin-bottom:.5rem;padding:.5rem 0;border-bottom:1px solid #E5E7EB}.field-answer-slot:last-child{border-bottom:none;margin-bottom:0}.field-answer-slot .answer-slot-label{font-weight:600;color:#374151;min-width:4.5rem}.field-answer-slot .field-answer-inline{margin-top:0;padding:.35rem .5rem;flex:1;min-width:0}.field-answer-slot .field-student-answer.field-answer-inline{background:#eff6ff;border-left:3px solid #3B82F6}.field-answer-slot .field-correct-answer.field-answer-inline{background:#f0fdf4;border-left:3px solid #10B981}.review-mode-panel{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a;height:100%;overflow-y:auto}.review-mode-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:2px solid #E5E7EB}.review-mode-header h2{margin:0;font-size:1.5rem;color:#111827}.review-progress{font-size:.875rem;color:#6b7280;font-weight:500}.review-instructions{margin-bottom:1.5rem;padding:1rem;background:#fef3c7;border-left:4px solid #F59E0B;border-radius:4px}.review-instructions p{margin:0;color:#92400e;font-size:.875rem}.review-fields-list{margin-bottom:1.5rem;max-height:400px;overflow-y:auto}.review-field-item{padding:1rem;margin-bottom:.75rem;border:1px solid #E5E7EB;border-radius:6px;transition:all .2s}.review-field-item.flagged{border-color:#f59e0b;background:#fffbeb}.review-field-checkbox{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;cursor:pointer}.review-field-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer}.checkbox-label{font-weight:500;color:#374151;font-size:.875rem}.review-field-content{margin-left:28px}.field-section{font-size:.75rem;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.field-dialogue{display:flex;gap:.5rem;font-size:.875rem;color:#111827}.field-speaker{font-weight:600;color:var(--color-primary);min-width:60px}.field-prompt,.field-prompt-text{font-size:.875rem;color:#111827;line-height:1.5}.field-prompt-text{margin-top:.5rem;color:#374151;font-size:.875rem}.field-prompt-text em{font-style:italic;color:#1d4ed8;text-decoration:underline;text-decoration-style:dotted;text-underline-offset:3px;text-decoration-color:#93c5fd}.field-prompt-text strong{font-weight:700}.field-prompt-text u{text-decoration:underline;text-underline-offset:3px}.field-student-answer{margin-top:.75rem;padding:.75rem;background:#eff6ff;border-left:3px solid #3B82F6;border-radius:4px}.field-student-answer .answer-label{display:block;font-weight:600;font-size:.75rem;color:#1e40af;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.field-student-answer .answer-value{display:block;color:#1e3a8a;font-size:.875rem;font-weight:500}.field-correct-answer{margin-top:.5rem;padding:.75rem;background:#f0fdf4;border-left:3px solid #10B981;border-radius:4px}.field-correct-answer .answer-label{display:block;font-weight:600;font-size:.75rem;color:#065f46;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.field-correct-answer .answer-value{display:block;color:#047857;font-size:.875rem;font-weight:500}.review-feedback{margin-bottom:1.5rem}.review-feedback label{display:block;margin-bottom:.5rem;font-weight:500;color:#374151;font-size:.875rem}.feedback-textarea{width:100%;padding:.75rem;border:1px solid #D1D5DB;border-radius:6px;font-size:.875rem;font-family:inherit;resize:vertical;min-height:100px}.feedback-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #60b5ff1a}.review-actions{display:flex;gap:.75rem;justify-content:flex-end;padding-top:1rem;border-top:1px solid #E5E7EB}.resubmission-comparison{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a;height:100%;overflow-y:auto}.resubmission-comparison.empty{display:flex;align-items:center;justify-content:center;min-height:400px;color:#6b7280;font-style:italic}.comparison-header{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #E5E7EB}.comparison-header h2{margin:0 0 .5rem;font-size:1.5rem;color:#111827}.comparison-description{margin:0;font-size:.875rem;color:#6b7280}.comparison-content{margin-bottom:1.5rem}.comparison-row{padding:1rem;margin-bottom:1rem;border:1px solid #E5E7EB;border-radius:6px;background:#fff}.comparison-row.flagged{border-color:#f59e0b;background:#fffbeb}.comparison-row.changed{border-left:4px solid #10B981}.comparison-field-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.field-name{font-weight:500;color:#374151;font-size:.875rem}.flagged-badge{padding:.25rem .5rem;background:#f59e0b;color:#fff;border-radius:4px;font-size:.75rem;font-weight:600}.comparison-values{display:grid;grid-template-columns:1fr auto 1fr;gap:1rem;align-items:center}.comparison-value{padding:.75rem;border-radius:6px;background:#f9fafb}.comparison-value.previous{background:#f3f4f6}.comparison-value.current{background:#f9fafb}.value-label{font-size:.75rem;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.value-content{font-size:.875rem;color:#111827;word-break:break-word}.value-content.highlight-change{background:#d1fae5;padding:.25rem .5rem;border-radius:4px;font-weight:500}.comparison-arrow{font-size:1.5rem;color:#6b7280;font-weight:600}.comparison-actions{display:flex;gap:.75rem;justify-content:flex-end;padding-top:1rem;border-top:1px solid #E5E7EB}.submission-review-view{padding:2rem;max-width:1600px;margin:0 auto}.review-layout{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;align-items:start}.review-left-panel{min-height:600px}.review-right-panel{position:sticky;top:2rem;max-height:calc(100vh - 4rem);overflow-y:auto}.verify-email-card{max-width:500px;text-align:center}.verify-status{padding:40px 20px}.verify-status.verifying,.verify-status.success,.verify-status.error{display:flex;flex-direction:column;align-items:center;gap:20px}.loading-spinner-large{width:60px;height:60px;border:5px solid rgb(173,216,230);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}.success-icon{width:80px;height:80px;border-radius:50%;background-color:#10b981;color:#fff;display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:700;margin-bottom:20px}.error-icon{width:80px;height:80px;border-radius:50%;background-color:#ef4444;color:#fff;display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:700;margin-bottom:20px}.status-title{font-size:24px;font-weight:600;margin:0 0 10px;color:#333}.status-message{font-size:16px;color:#666;margin:0 0 30px;line-height:1.5}.verify-actions{display:flex;flex-direction:column;gap:15px;width:100%;max-width:300px}.verify-message{margin-top:20px;padding:15px;background-color:#f3f4f6;border-radius:8px;color:#666;font-size:14px}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.verify-email-card{padding:20px}.verify-status{padding:30px 15px}.success-icon,.error-icon{width:60px;height:60px;font-size:36px}.status-title{font-size:20px}.status-message{font-size:14px}}.admin-navigation{background:#fff;border-radius:8px;padding:1rem;margin-bottom:2rem;box-shadow:0 2px 4px #0000001a;border:1px solid #E5E7EB}.admin-nav-list{display:flex;list-style:none;margin:0;padding:0;gap:.5rem;flex-wrap:wrap}.admin-nav-item{margin:0}.admin-nav-link{display:block;padding:.75rem 1.5rem;color:#374151;text-decoration:none;border-radius:6px;font-weight:500;font-size:.875rem;transition:all .2s ease;border:1px solid transparent}.admin-nav-link:hover{background-color:#f3f4f6;color:var(--color-primary)}.admin-nav-link.active{background-color:var(--color-primary);color:#fff;border-color:var(--color-primary)}.admin-nav-link.active:hover{background-color:#4682b4;border-color:#4682b4}.admin-dashboard-container{min-height:100vh;padding:40px 20px;background-color:#add8e6;position:relative}.language-switcher-container{position:absolute;top:20px;right:20px;z-index:10}.admin-dashboard-card{max-width:1400px;margin:0 auto;background:#fff;border-radius:12px;padding:40px;box-shadow:0 4px 6px #0000001a;border:2px solid var(--color-primary)}.admin-dashboard-header{margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid var(--color-primary)}.admin-dashboard-header-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:15px}.admin-dashboard-header h1{font-size:32px;color:var(--color-primary);margin:0;flex:1;min-width:200px}.admin-dashboard-header-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.admin-user-info{color:#374151;font-size:.875rem;font-weight:500}.admin-dashboard-content{width:100%}.students-table-container{overflow-x:auto;margin-bottom:1rem}.students-table{width:100%;border-collapse:collapse;font-size:.875rem;background:#fff}.students-table thead{background:#f9fafb;border-bottom:2px solid #E5E7EB}.students-table th{padding:.75rem 1rem;text-align:left;font-weight:600;color:#374151;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.students-table td{padding:.75rem 1rem;border-bottom:1px solid #E5E7EB;color:#111827}.student-row{cursor:pointer;transition:background-color .2s}.student-row:hover{background-color:#f9fafb}.student-row--unassigned{background-color:#fef2f2}.student-row--unassigned:hover{background-color:#fee2e2}.table-empty{text-align:center;padding:2rem;color:#6b7280;font-style:italic}.group-badge{display:inline-block;padding:.25rem .75rem;border-radius:6px;background:#dbeafe;color:#1e40af;font-weight:500;font-size:.875rem}.teacher-name{font-weight:500;color:#111827}.teacher-email{font-size:.75rem;color:#6b7280;font-weight:400}.missing-assignment{display:inline-block;padding:.25rem .75rem;border-radius:6px;background:#fef3c7;color:#92400e;font-weight:500;font-size:.875rem}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.status-active{background:#d1fae5;color:#065f46}.status-inactive{background:#fee2e2;color:#991b1b}.students-table-loading{padding:2rem;text-align:center;color:#6b7280}.students-list-view{width:100%}.students-list-header{margin-bottom:2rem}.students-list-header h2{font-size:24px;color:var(--color-primary);margin:0;font-weight:600}.students-filters{width:100%;margin-bottom:1.5rem;background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 4px #0000001a;display:flex;gap:1.5rem;align-items:flex-end}.filter-group{display:flex;flex-direction:column;gap:.5rem;min-width:200px;flex:1}.filter-group label{font-size:.875rem;font-weight:500;color:#374151}.filter-select,.filter-input{padding:.5rem .75rem;border:1px solid #D1D5DB;border-radius:6px;font-size:.875rem;background:#fff}.filter-select:focus,.filter-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #60b5ff1a}.students-table-wrapper{width:100%;margin-bottom:1.5rem;background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 4px #0000001a}.students-pagination{width:100%;margin-top:2rem;display:flex;justify-content:center;align-items:center;gap:1rem;padding:1rem;background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a}.pagination-button{padding:.5rem 1rem;border:1px solid #D1D5DB;border-radius:6px;background:#fff;color:#374151;font-size:.875rem;cursor:pointer;transition:all .2s}.pagination-button:hover:not(:disabled){background:#f9fafb;border-color:var(--color-primary);color:var(--color-primary)}.pagination-button:disabled{opacity:.5;cursor:not-allowed}.pagination-info{font-size:.875rem;color:#6b7280;font-weight:500}.teachers-table-container{overflow-x:auto;margin-bottom:1rem}.teachers-table{width:100%;border-collapse:collapse;font-size:.875rem;background:#fff}.teachers-table thead{background:#f9fafb;border-bottom:2px solid #E5E7EB}.teachers-table th{padding:.75rem 1rem;text-align:left;font-weight:600;color:#374151;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.teachers-table td{padding:.75rem 1rem;border-bottom:1px solid #E5E7EB;color:#111827}.teacher-row{cursor:pointer;transition:background-color .2s}.teacher-row:hover{background-color:#f9fafb}.teachers-table .table-empty{text-align:center;padding:2rem;color:#6b7280;font-style:italic}.teachers-table .status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.teachers-table .status-active{background:#d1fae5;color:#065f46}.teachers-table .status-inactive{background:#fee2e2;color:#991b1b}.teachers-table-loading{padding:2rem;text-align:center;color:#6b7280}.teachers-list-view{width:100%}.teachers-list-header{margin-bottom:2rem}.teachers-list-header h2{font-size:24px;color:var(--color-primary);margin:0;font-weight:600}.teachers-content{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 4px #0000001a}.teachers-content p{color:#6b7280;font-size:1rem;margin:0}.groups-list-view{width:100%}.groups-list-header{margin-bottom:2rem}.groups-list-header h2{font-size:24px;color:var(--color-primary);margin:0;font-weight:600}.groups-content{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 4px #0000001a}.groups-table-container{overflow-x:auto}.groups-table{width:100%;border-collapse:collapse;font-size:.875rem}.groups-table thead{background:#f9fafb;border-bottom:2px solid #E5E7EB}.groups-table th{padding:.75rem 1rem;text-align:left;font-weight:600;color:#374151;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.groups-table td{padding:.75rem 1rem;border-bottom:1px solid #E5E7EB;color:#111827}.groups-table tbody tr:hover{background-color:#f9fafb}.groups-content p{color:#6b7280;font-size:1rem;margin:0}.admin-submissions-list-view{width:100%}.admin-submissions-header{margin-bottom:2rem}.admin-submissions-header h2{font-size:24px;color:var(--color-primary);margin:0;font-weight:600}.submission-detail-view{width:100%}.submission-detail-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--color-primary)}.submission-detail-header h2{font-size:24px;color:var(--color-primary);margin:0;font-weight:600}.submission-detail-back-btn{margin-left:.25rem}.submission-status-dropdown{margin-left:auto;display:flex;align-items:center;gap:10px}.submission-status-dropdown label{font-weight:500;color:#333;white-space:nowrap}.submission-status-dropdown select{padding:8px 12px;font-size:14px;border:1px solid #ddd;border-radius:4px;backgroundColor:#fff;cursor:pointer;min-width:150px;transition:border-color .2s}.submission-status-dropdown select:hover:not(:disabled){border-color:var(--color-primary)}.submission-status-dropdown select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #60b5ff1a}.submission-status-dropdown select:disabled{cursor:not-allowed;opacity:.6;background-color:#f5f5f5}.submission-detail-content{width:100%}.submission-detail-actions{margin-top:2rem}.teacher-profile-view{width:100%;max-width:1200px;margin:0 auto;padding:2rem}.teacher-profile-view .profile-header{display:flex;align-items:flex-start;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.teacher-profile-view .back-button{flex-shrink:0}.teacher-profile-view .profile-header-content{display:flex;justify-content:space-between;align-items:center;flex:1;gap:1rem;min-width:0}.teacher-profile-view .profile-header h1{font-size:28px;color:var(--color-primary);margin:0;font-weight:600}.teacher-profile-view .profile-error-banner{margin-bottom:1.5rem}.teacher-profile-view .profile-content{display:flex;flex-direction:column;gap:1.5rem}.teacher-profile-view .profile-section-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 4px #0000001a}.teacher-profile-view .profile-section-card h2{font-size:20px;color:var(--color-primary);margin:0 0 1.5rem;font-weight:600;border-bottom:2px solid var(--color-primary);padding-bottom:.5rem}.teacher-profile-view .profile-field{margin-bottom:1.5rem}.teacher-profile-view .profile-field:last-child{margin-bottom:0}.teacher-profile-view .profile-field label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.teacher-profile-view .profile-value{font-size:1rem;color:#111827;padding:.5rem 0}.teacher-profile-view .profile-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.teacher-profile-view .stat-item{text-align:center;padding:1rem;background:#f8f9fa;border-radius:8px}.teacher-profile-view .stat-label{font-size:.875rem;color:#6b7280;margin-bottom:.5rem;font-weight:500}.teacher-profile-view .stat-value{font-size:24px;font-weight:600;color:var(--color-primary)}.teacher-profile-view .status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:500}.teacher-profile-view .status-active{background:#d1fae5;color:#065f46}.teacher-profile-view .status-inactive{background:#fee2e2;color:#991b1b}.teacher-profile-view .assigned-list{list-style:none;margin:0;padding:0}.teacher-profile-view .assigned-list li{padding:.5rem 0;border-bottom:1px solid #E5E7EB}.teacher-profile-view .link-button{background:none;border:none;color:var(--color-primary);cursor:pointer;text-decoration:underline;font-size:1rem;padding:0}.teacher-profile-view .link-button:hover{color:#4682b4}.teacher-profile-view .list-truncated{margin-top:.5rem;font-size:.875rem;color:#6b7280}@media (max-width: 768px){.teacher-profile-view{padding:1rem}.teacher-profile-view .profile-header{flex-direction:column;align-items:stretch}.teacher-profile-view .back-button{width:100%}.teacher-profile-view .profile-stats-grid{grid-template-columns:repeat(2,1fr)}}.palette-switcher{padding:20px 0}.palette-switcher__title{font-family:var(--font-english);font-size:var(--text-section-header);font-weight:600;color:var(--text-primary);margin:0 0 8px}.palette-switcher__subtitle{font-family:var(--font-english);font-size:var(--text-body);color:var(--text-secondary);margin:0 0 20px}.palette-switcher__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:16px}.palette-card{display:flex;flex-direction:column;align-items:center;padding:16px 12px;background:var(--bg-main);border:2px solid var(--divider);border-radius:var(--radius-card);cursor:pointer;transition:all .3s ease;position:relative;min-height:120px}.palette-card:hover{border-color:var(--color-accent);box-shadow:var(--shadow-hover);transform:translateY(-2px)}.palette-card--selected{border-color:var(--color-accent);box-shadow:var(--shadow-card);background:var(--bg-card)}.palette-card__emoji{font-size:28px;margin-bottom:8px;line-height:1}.palette-card__name{font-family:var(--font-english);font-size:var(--text-small);font-weight:500;color:var(--text-primary);text-align:center;margin-bottom:10px;line-height:1.2}.palette-card__swatches{display:flex;gap:4px;width:100%;justify-content:center;flex-wrap:wrap}.palette-card__swatch{width:20px;height:20px;border-radius:4px;flex-shrink:0}.palette-card__check{position:absolute;top:8px;right:8px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--color-success);color:#fff;border-radius:50%}.palette-card__check-icon{width:14px;height:14px}.palette-switcher--compact .palette-switcher__grid{grid-template-columns:repeat(5,1fr);gap:12px}.palette-switcher--compact .palette-card{min-height:100px;padding:12px 8px}.palette-switcher--compact .palette-card__emoji{font-size:24px;margin-bottom:4px}.palette-switcher--compact .palette-card__name{font-size:11px;margin-bottom:6px}.palette-switcher--compact .palette-card__swatch{width:16px;height:16px}@media (max-width: 768px){.palette-switcher__grid{grid-template-columns:repeat(2,1fr)}.palette-switcher--compact .palette-switcher__grid{grid-template-columns:repeat(3,1fr)}}.student-profile-view{width:100%;max-width:1200px;margin:0 auto;padding:2rem}.profile-header{display:flex;align-items:flex-start;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.back-button{flex-shrink:0}.profile-header-content{display:flex;justify-content:space-between;align-items:center;flex:1;gap:1rem;min-width:0}.profile-header h1{font-size:28px;color:var(--color-primary);margin:0;font-weight:600}.profile-actions{display:flex;gap:.5rem}.profile-error-banner{margin-bottom:1.5rem}.profile-content{display:flex;flex-direction:column;gap:1.5rem}.profile-section-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 4px #0000001a}.profile-section-card h2{font-size:20px;color:var(--color-primary);margin:0 0 1.5rem;font-weight:600;border-bottom:2px solid var(--color-primary);padding-bottom:.5rem}.profile-field{margin-bottom:1.5rem}.profile-field:last-child{margin-bottom:0}.profile-field label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.profile-value{font-size:1rem;color:#111827;padding:.5rem 0}.profile-input,.profile-textarea{width:100%;padding:.75rem;border:1px solid #D1D5DB;border-radius:6px;font-size:1rem;font-family:inherit;transition:border-color .2s}.profile-input:focus,.profile-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #60b5ff1a}.profile-textarea{resize:vertical;min-height:80px}.profile-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.stat-item{text-align:center;padding:1rem;background:#f8f9fa;border-radius:8px}.stat-label{font-size:.875rem;color:#6b7280;margin-bottom:.5rem;font-weight:500}.stat-value{font-size:24px;font-weight:600;color:var(--color-primary)}.subscription-status{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:500}.subscription-free{background:#e5e7eb;color:#374151}.subscription-trial{background:#dbeafe;color:#1e40af}.subscription-paid{background:#d1fae5;color:#065f46}.subscription-expired{background:#fee2e2;color:#991b1b}@media (max-width: 768px){.student-profile-view{padding:1rem}.profile-header{flex-direction:column;align-items:stretch}.back-button{order:-1;width:100%}.profile-header-content{flex-direction:column;align-items:stretch}.profile-actions{width:100%}.profile-actions button{flex:1}.profile-stats-grid{grid-template-columns:repeat(2,1fr)}}.app{min-height:100vh;background:var(--bg-main)}.loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:18px;color:var(--color-primary)}:root{--bg-main: #FFFFFF;--bg-card: #FAFBFC;--bg-input: #FFFFFF;--divider: #E8EAED;--shadow-card: 0 2px 8px rgba(0, 0, 0, .04);--shadow-hover: 0 4px 16px rgba(0, 0, 0, .08);--shadow-active: 0 1px 3px rgba(0, 0, 0, .12);--text-primary: #2D3436;--text-secondary: #636E72;--text-muted: #95A5A6;--text-disabled: #B2BEC3;--font-english: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-chinese: "Noto Sans SC", "PingFang SC", "Microsoft YaHei", sans-serif;--text-main-title: 32px;--text-section-header: 24px;--text-lesson-title: 18px;--text-body: 15px;--text-small: 13px;--radius-button: 12px;--radius-card: 16px;--color-primary: #FC5C65;--color-secondary: #FD9644;--color-success: #26DE81;--color-accent: #FD79A8;--color-info: #45AAF2;--color-cta: var(--color-primary);--color-error: var(--color-primary);--color-urgent: var(--color-primary);--color-link: var(--color-info);--color-link-hover: #3498DB}html[lang=zh]{--text-main-title: 34px;--text-section-header: 26px;--text-lesson-title: 20px;--text-body: 16px;--text-small: 14px}:root[data-palette="1"],:root:not([data-palette]){--color-primary: #FC5C65;--color-secondary: #FD9644;--color-success: #26DE81;--color-accent: #FD79A8;--color-info: #45AAF2}:root[data-palette="2"]{--color-primary: #F79D65;--color-secondary: #FFE588;--color-success: #5EF2D5;--color-accent: #F35252;--color-info: #60B5FF}:root[data-palette="3"]{--color-primary: #5F27CD;--color-secondary: #00D2FF;--color-success: #A29BFE;--color-accent: #FD79A8;--color-info: #2D3436}:root[data-palette="4"]{--color-primary: #38ADA9;--color-secondary: #78E08F;--color-success: #B8E994;--color-accent: #F8B500;--color-info: #079992}:root[data-palette="5"]{--color-primary: #FF6B6B;--color-secondary: #FFA502;--color-success: #FFD32A;--color-accent: #FF4757;--color-info: #FF6348}:root[data-palette="6"]{--color-primary: #FFB3BA;--color-secondary: #FFDFBA;--color-success: #BAFFC9;--color-accent: #BAE1FF;--color-info: #E0BBE4}:root[data-palette="7"]{--color-primary: #C0392B;--color-secondary: #F39C12;--color-success: #27AE60;--color-accent: #8E44AD;--color-info: #2C3E50}:root[data-palette="8"]{--color-primary: #0984E3;--color-secondary: #74B9FF;--color-success: #00CEC9;--color-accent: #81ECEC;--color-info: #6C5CE7}:root[data-palette="9"]{--color-primary: #8B4513;--color-secondary: #D2691E;--color-success: #F4A460;--color-accent: #DEB887;--color-info: #CD853F}:root[data-palette="10"]{--color-primary: #FF00FF;--color-secondary: #00FFFF;--color-success: #7FFF00;--color-accent: #FF1493;--color-info: #FF4500}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-english);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-main);min-height:100vh;color:var(--text-primary);font-size:var(--text-body);font-weight:400}html[lang=zh] body{font-family:var(--font-chinese)}.font-main-title{font-family:var(--font-english);font-size:var(--text-main-title);font-weight:700;color:var(--text-primary)}.font-section-header{font-family:var(--font-english);font-size:var(--text-section-header);font-weight:600;color:var(--text-primary)}.font-lesson-title{font-family:var(--font-english);font-size:var(--text-lesson-title);font-weight:500;color:var(--text-primary)}.font-body{font-family:var(--font-english);font-size:var(--text-body);font-weight:400;color:var(--text-primary)}.font-body-secondary{font-family:var(--font-english);font-size:var(--text-body);font-weight:400;color:var(--text-secondary)}.font-small{font-family:var(--font-english);font-size:var(--text-small);font-weight:400;color:var(--text-secondary)}.font-button{font-family:var(--font-english);font-weight:500;letter-spacing:.5px}html[lang=zh] .font-main-title,html[lang=zh] .font-section-header,html[lang=zh] .font-lesson-title{font-family:var(--font-chinese)}a,.link{color:var(--color-link);transition:color .2s}a:hover,.link:hover{color:var(--color-link-hover)}#root{min-height:100vh;width:100%;overflow-x:hidden}@media (max-width: 768px){body{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}*{-webkit-tap-highlight-color:transparent}}
