.app-shell{min-height:100vh}.ui-page-container{max-width:1200px;margin:0 auto;padding:0 20px}.auth-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:#666}.auth-loading-spinner{width:32px;height:32px;border:3px solid #eee;border-top-color:#ffc515;border-radius:50%;animation:auth-spin .8s linear infinite}@keyframes auth-spin{to{transform:rotate(360deg)}}.results-buttons .certificate-btn{background:#ffc515;color:#1a1a1a;font-weight:600;padding:10px 18px;border-radius:10px;border:none;cursor:pointer;margin-left:.5rem}.results-buttons .certificate-btn:hover{opacity:.9}.main-content{margin-top:0!important}.user-avatar-wrap{position:relative}.user-avatar{width:40px;height:40px;border-radius:50%;background:#ffc515;color:#fff;font-weight:700;font-size:1.1rem;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;transition:background .15s ease}.user-avatar:hover{background:#e6b013}.user-avatar-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:120px;background:#fff;border-radius:10px;box-shadow:0 4px 16px #0000001f;padding:4px 0;z-index:100}.user-avatar-dropdown-item{display:block;width:100%;padding:10px 14px;text-align:left;font-size:.9rem;color:#333;background:none;border:none;cursor:pointer;transition:background .15s ease}.user-avatar-dropdown-item:hover{background:#f0f0f0}.user-avatar-header{display:flex;align-items:center}.user-avatar-sidebar{display:none}@media(max-width:768px){.user-avatar-header{display:none}.sidebar-signout{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:12px}.sidebar-signout .user-avatar-sidebar{display:flex;align-items:center}.sidebar-signout .sidebar-signout-btn{width:auto}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background-image:url(/assets/gradient-background.png);background-size:cover;background-position:center}.login-card{width:100%;max-width:420px;padding:1.25rem 2rem 2.25rem;border-radius:22px;background:#fff;box-shadow:0 4px 24px #0000000f,0 2px 8px #0000000a}.login-logo-wrap{display:flex;justify-content:center}.login-logo-circle{width:140px;height:140px;border-radius:50%;display:flex;align-items:center;justify-content:center;overflow:hidden}.login-logo-img{width:90px;height:90px;object-fit:contain}.login-title{font-size:24px;font-weight:700;color:#1a1d29;text-align:center;letter-spacing:-.02em}.login-subtitle{margin:0 0 1.5rem;font-size:.95rem;color:#6b7280;text-align:center}.login-form{display:flex;flex-direction:column;gap:1.1rem}.login-label{display:flex;flex-direction:column;gap:.4rem;font-size:.9rem;font-weight:600;color:#374151}.login-input{padding:14px 16px;font-size:1rem;border:1px solid #e0e0e0;border-radius:13px;background:#f8f7f5;outline:none}.login-input::placeholder{color:#9ca3af}.login-input:focus{border-color:#c4a84a;background:#fff;outline:2px solid rgba(245,180,0,.3);outline-offset:0}.login-input:disabled{opacity:.7;cursor:not-allowed}.login-error{margin:0;padding:.6rem .85rem;font-size:.875rem;color:#b91c1c;background:#fef2f2;border-radius:10px}.login-submit{margin-top:.25rem;width:100%;padding:14px 16px;font-size:1rem;font-weight:700;color:#fff;background:#f5a623;border:none;border-radius:13px;cursor:pointer;transition:background .2s ease,transform .05s ease}.login-submit:hover:not(:disabled){background:#e0951a}.login-submit:active:not(:disabled){transform:scale(.99)}.login-submit:disabled{opacity:.75;cursor:not-allowed}.login-footer{margin:1.5rem 0 0;text-align:center;font-size:.9rem;color:#6b7280}.login-link{color:#f5a623;font-weight:600;text-decoration:none}.login-link:hover{text-decoration:underline;color:#e0951a}.logout-page{min-height:100vh;display:flex;align-items:center;justify-content:center;font-size:1rem;color:#666}.results-screen{display:none;text-align:center;background:#fff;border-radius:12px;padding:80px 60px;box-shadow:0 4px 24px #00000014;width:100%;max-width:600px;min-height:400px;position:relative}.results-icons{display:flex;justify-content:center;align-items:center;gap:20px;margin-bottom:40px}.result-icon{width:80px;height:80px;border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0000001a}.check-result-icon,.wrong-result-icon{background:#ffc515}.result-icon svg{width:40px;height:40px;stroke:#fff;stroke-width:3}.results-title{font-size:24px;font-weight:500;color:#777;margin-bottom:10px;line-height:1.3}.results-subtitle{font-size:18px;font-weight:400;color:#777;margin-bottom:20px}.results-score{font-size:17px;font-weight:500;color:#666;margin-bottom:40px}.results-buttons{display:flex;flex-direction:row;gap:16px;justify-content:center;align-items:center;flex-wrap:nowrap;margin-top:40px;position:absolute;bottom:30px;left:50%;transform:translate(-50%)}.results-buttons .continue-btn,.results-buttons .done-btn{position:static;bottom:auto;right:auto;left:auto;min-width:160px;border-radius:8px;box-sizing:border-box}.results-screen .continue-btn{background:#fff;color:#ffc515;border:2px solid #ffc515;padding:14px 28px;border-radius:8px;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s;text-transform:uppercase;letter-spacing:1px}.results-screen .continue-btn:hover{background:#fff8e1}.results-screen .done-btn{background:#ffc515;color:#fff;border:2px solid transparent;padding:14px 28px;border-radius:8px;font-size:16px;font-weight:700;cursor:pointer;transition:background .2s;text-transform:uppercase;letter-spacing:1px}.results-screen .done-btn:hover{background:#ffb300}.writing-practice-complete.results-screen{display:none;flex-direction:column;align-items:center;padding:60px 60px 80px}.writing-practice-complete .results-icons{margin-bottom:32px}.writing-practice-complete .results-title{font-weight:600;color:#333;margin-bottom:12px}.writing-practice-complete .results-subtitle{color:#555;margin-bottom:16px}.writing-practice-complete .results-score{margin-bottom:32px;min-height:0}.writing-practice-complete .results-buttons{position:static;transform:none;margin-top:0}.writing-practice-complete .results-buttons #writingPcContinueBtn,.writing-practice-complete .results-buttons .done-btn{display:inline-block;position:static;min-width:160px;border-radius:8px;padding:14px 28px;font-size:16px;font-weight:700;cursor:pointer;text-transform:uppercase;letter-spacing:1px;background:#ffc515;color:#fff;border:2px solid transparent}.writing-practice-complete .results-buttons #writingPcContinueBtn:hover,.writing-practice-complete .results-buttons .done-btn:hover{background:#ffb300}@media(max-width:768px){.results-screen{max-width:500px;padding:60px 40px}.result-icon{width:70px;height:70px}.result-icon svg{width:35px;height:35px}.results-title{font-size:22px}.results-subtitle{font-size:16px}.results-buttons .continue-btn,.results-buttons .done-btn{padding:12px 24px;font-size:14px}}@media(max-width:480px){.results-screen{max-width:100%;padding:50px 30px;min-height:350px}.result-icon{width:60px;height:60px}.result-icon svg{width:30px;height:30px}.results-title{font-size:20px}.results-subtitle{font-size:16px}}@media(max-width:320px){.results-screen{padding:30px 15px;min-height:300px}.results-icons{gap:15px;margin-bottom:30px}.result-icon{width:50px;height:50px}.result-icon svg{width:25px;height:25px}.results-title{font-size:18px}.results-subtitle{font-size:14px}.results-buttons .continue-btn,.results-buttons .done-btn{padding:12px 24px;font-size:13px}}.loading-screen{position:fixed;top:0;left:0;width:100%;height:100%;background:#fff;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:1000}.question-card{background:#fff;border-radius:12px 12px 0 0;padding:50px 60px;box-shadow:0 2px 12px #00000026;width:100%;max-width:1200px;text-align:center;position:relative;min-height:500px;display:flex;flex-direction:column;justify-content:center;margin:0 auto;box-sizing:border-box;z-index:1}.timer-circle{width:8px;height:8px;border-radius:50%;background:#999;display:inline-block;margin-right:8px}.close-btn{position:absolute;top:25px;right:25px;background:none;border:none;cursor:pointer;padding:8px;border-radius:4px;transition:background .2s;color:#000;font-size:14px;font-weight:400;display:flex;align-items:center;gap:4px}.close-btn:hover{color:#000}.close-btn svg{display:none}.question-title{font-size:20px;font-weight:400;color:#666;margin-bottom:30px;line-height:1.4}.word-display{font-size:48px;font-weight:600;color:#333;margin-bottom:50px;letter-spacing:0;line-height:1.2}.answer-buttons{display:flex;justify-content:center;gap:50px;margin-bottom:0}.answer-btn{width:120px;height:120px;border:1px solid #ddd;border-radius:50%;background:#fff;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;font-size:14px;font-weight:400;color:#666;padding:0}.answer-btn:hover{border-color:#999}.answer-btn.selected{border-color:#4caf50;border-width:2px}.answer-btn.correct{border-color:#4caf50;border-width:2px;color:#333}.answer-btn.incorrect{border-color:#666;border-width:2px;color:#333}.answer-btn.selected .x-icon,.answer-btn.correct .x-icon,.answer-btn.selected .check-icon,.answer-btn.correct .check-icon{color:#4caf50}.answer-btn.disabled{pointer-events:none;opacity:.8}.answer-icon{width:24px;height:24px;stroke-width:2}.check-icon,.x-icon{color:#333}.feedback-section{background:#ffcdd2;border-radius:0 0 12px 12px;padding:18px 60px;margin:0 auto;border:none;display:none;position:relative;width:100%;max-width:1200px;box-sizing:border-box;flex-direction:row;align-items:center;justify-content:space-between;box-shadow:0 2px 12px #00000026;z-index:1}.feedback-section.correct{background:#c8e6c9}.feedback-header{display:flex;align-items:center;gap:8px;margin:0}.feedback-icon circle{fill:#2e7d32;stroke:none}.feedback-icon polyline,.feedback-icon line{stroke:#fff;stroke-width:2.5}.feedback-title{font-size:16px;font-weight:600;margin:0}.feedback-title.correct{color:#2e7d32;font-weight:700}.feedback-content{color:#c62828;font-size:16px;margin:0}.feedback-content.correct{color:#2e7d32}.correct-answer{font-weight:700;margin:0;font-size:16px;line-height:1.4}.correct-answer.correct-text{color:#2e7d32}.correct-answer.incorrect-text{color:#c62828}.next-btn{background:#4caf50;color:#fff;border:none;padding:10px 20px;border-radius:9999px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s;text-transform:none;letter-spacing:0;position:static;margin:0;flex-shrink:0}.next-btn:hover{background:#45a049}.next-btn.correct{background:#4caf50}.next-btn.correct:hover{background:#45a049}.progress-indicator{position:absolute;bottom:30px;right:30px;font-size:14px;color:#bbb;font-weight:400}@media(min-width:1440px){.quiz-container{padding:50px}.question-card{max-width:1200px;padding:50px 60px;min-height:500px;border-radius:12px 12px 0 0}.feedback-section{max-width:1200px;border-radius:0 0 12px 12px;padding:18px 60px}.question-title{font-size:30px;margin-bottom:70px}.word-display{font-size:68px;margin-bottom:90px}.answer-btn{width:180px;height:180px;font-size:22px}.answer-icon{width:44px;height:44px}.feedback-section{max-width:1200px;padding:18px 60px}}@media(min-width:1024px)and (max-width:1439px){.quiz-container{padding:40px}.question-card{max-width:1200px;padding:50px 60px;border-radius:12px 12px 0 0}.feedback-section{max-width:1200px;border-radius:0 0 12px 12px;padding:18px 60px;box-shadow:0 2px 12px #00000026}}@media(min-width:768px)and (max-width:1023px){.quiz-container{padding:30px}.question-card{max-width:100%;padding:40px 50px;min-height:500px;border-radius:12px 12px 0 0}.feedback-section{max-width:100%;border-radius:0 0 12px 12px;padding:18px 50px}.question-title{font-size:24px;margin-bottom:50px}.word-display{font-size:56px;margin-bottom:60px}.answer-buttons{gap:30px}.answer-btn{width:140px;height:140px;font-size:18px}.answer-icon{width:36px;height:36px}.feedback-section{padding:18px 50px}.feedback-title,.feedback-content,.correct-answer{font-size:15px}.next-btn{bottom:20px;right:20px}}@media(min-width:481px)and (max-width:767px){.quiz-container{padding:20px}.question-card{max-width:100%;padding:35px 40px;min-height:450px;border-radius:12px 12px 0 0}.feedback-section{border-radius:0 0 12px 12px;padding:18px 40px}.timer{top:25px;left:25px;font-size:14px}.timer-icon{width:18px;height:18px}.close-btn{top:20px;right:20px}.question-title{font-size:22px;margin-bottom:30px}.word-display{font-size:48px;margin-bottom:40px}.answer-buttons{gap:40px;margin-bottom:0}.answer-btn{width:120px;height:120px;font-size:16px;gap:12px}.answer-icon{width:32px;height:32px}.feedback-section{padding:18px 40px}.feedback-title,.feedback-content,.correct-answer{font-size:14px}.next-btn{padding:12px 20px;font-size:13px;bottom:18px;right:30px}.progress-indicator{bottom:25px;right:25px;font-size:13px}.stage-progress-bar{gap:10px;max-width:350px;margin-bottom:25px}.progress-track{height:7px}.progress-text{font-size:13px;min-width:40px}}@media(max-width:480px){.quiz-container{padding:16px}.question-card{padding:30px 25px;min-height:400px;border-radius:12px 12px 0 0}.feedback-section{border-radius:0 0 12px 12px;padding:18px 25px}.timer{top:20px;left:20px;font-size:13px}.timer-icon{width:16px;height:16px}.close-btn{top:15px;right:15px}.question-title{font-size:18px;margin-bottom:25px}.word-display{font-size:36px;margin-bottom:35px}.answer-buttons{gap:30px;flex-direction:row;align-items:center}.answer-btn{width:100px;height:100px;flex-direction:column;font-size:14px;gap:8px}.answer-icon{width:28px;height:28px}.feedback-section{padding:16px 25px}.feedback-header{gap:6px;margin-bottom:6px}.feedback-icon{width:16px;height:16px}.feedback-title,.feedback-content,.correct-answer{font-size:13px}.next-btn{padding:10px 18px;font-size:12px;bottom:16px;right:16px}.progress-indicator{bottom:20px;right:20px;font-size:12px}.stage-progress-bar{gap:8px;max-width:100%;margin-bottom:20px}.progress-track{height:6px}.progress-text{font-size:12px;min-width:35px}.loading-spinner{width:32px;height:32px;border-width:3px}.loading-screen>div{gap:16px}.loading-text{font-size:14px}}@media(max-width:319px){.quiz-container{padding:12px}.question-card{padding:25px 20px;min-height:350px;border-radius:12px 12px 0 0}.feedback-section{border-radius:0 0 12px 12px;padding:18px 20px}.question-title{font-size:18px;margin-bottom:30px}.word-display{font-size:36px;margin-bottom:40px}.answer-btn{width:180px;height:90px;font-size:16px}.answer-icon{width:24px;height:24px}.feedback-section{width:calc(100% + 40px);margin-left:-20px;margin-right:-20px}}.sentence-container{font-size:32px;font-weight:300;color:#333;margin-bottom:80px;line-height:1.4;max-width:800px;margin-left:auto;margin-right:auto}.sentence-text{display:inline}.blank-input{display:inline-block;width:45px;height:45px;padding:0;margin:0 3px;border:2px solid #ffc515;border-radius:8px;background:#fff;font-size:24px;font-weight:600;color:#333;text-align:center;outline:none;transition:all .3s ease;vertical-align:middle;text-transform:uppercase}.input-container{display:inline-flex;gap:3px;margin:0 8px;align-items:center}.blank-input:focus{border-color:#1976d2;background:#1cb0f60d;box-shadow:0 0 0 3px #1cb0f61a}.blank-input.correct{border-color:#ffc515;background:#4caf501a;color:#2e7d32}.blank-input.incorrect{border-color:#f44336;background:#f443361a;color:#c62828}.blank-input.prefilled{background:#f0f8ff;color:#1976d2;font-weight:700;border-color:#90caf9;cursor:default}.blank-input.prefilled:focus{background:#f0f8ff;border-color:#90caf9;box-shadow:none}.continue-btn.submitted{background:#ffc515;color:#fff;cursor:default}.correct-answer-text{color:#2e7d32;font-size:16px;margin:8px 0 0;font-weight:500}@media(max-width:480px){.quiz-container{padding:16px}.question-card{padding:25px 20px;border-radius:12px 12px 0 0}.feedback-section{border-radius:0 0 12px 12px;padding:18px 20px}.sentence-container{font-size:20px;margin-bottom:50px}.blank-input{font-size:18px;width:35px;height:35px;margin:0 1px}.input-container{gap:1px;margin:0 4px}.question-title{font-size:20px}}@media(max-width:319px){.quiz-container{padding:12px}.question-card{padding:20px 15px;border-radius:12px 12px 0 0}.feedback-section{border-radius:0 0 12px 12px;padding:16px 15px}.stage-progress-bar{gap:8px;max-width:100%;margin-bottom:20px}.progress-track{height:6px}.progress-text{font-size:12px;min-width:35px}.loading-spinner{width:32px;height:32px;border-width:3px}.loading-screen>div{gap:16px}.loading-text{font-size:14px}}.loading-spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top:4px solid #ffc515;border-radius:50%;animation:spin 1s linear infinite;flex-shrink:0}.question-card{background:#fff;border-radius:12px 12px 0 0;padding:50px 60px;box-shadow:0 2px 12px #00000026;width:100%;max-width:1200px;text-align:center;position:relative;min-height:600px;display:flex;flex-direction:column;justify-content:center;margin:0 auto;box-sizing:border-box}.question-title{font-size:28px;font-weight:400;color:#6b7280;margin-bottom:60px;line-height:1.2}.passage-section{margin-bottom:40px;max-width:800px;margin-left:auto;margin-right:auto}.passage-title{font-size:22px;font-weight:600;color:#333;margin-bottom:30px;text-align:center}.passage-container{font-size:18px;line-height:1.8;color:#333;text-align:left;padding:30px;border:1px solid #e0e0e0;border-radius:12px;background:#fafafa}.word-input{display:inline-block;position:relative;margin:0 1px;vertical-align:baseline}.letter-input{display:inline-block;width:30px;height:30px;padding:0;margin:0 1px;border:1px solid #ccc;border-radius:4px;background:#fff;font-size:16px;font-weight:600;color:#333;text-align:center;outline:none;transition:all .3s ease;vertical-align:middle;text-transform:lowercase}.letter-input:focus{border-color:#ffc515;background:#1cb0f60d;box-shadow:0 0 0 2px #1cb0f61a}.letter-input.correct{border-color:#ffc515;background:#4caf501a;color:#2e7d32}.letter-input.incorrect{border-color:#f44336;background:#f443361a;color:#c62828}.letter-input.submitted{cursor:default}.letter-input.prefilled{background:#f5f5f5;color:#333;border-color:#ddd;cursor:default}.feedback-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.feedback-icon{width:24px;height:24px;flex-shrink:0}.feedback-title{font-size:18px;font-weight:700;margin:0}.correct-answer-text{color:#2e7d32;font-size:16px;margin:0;font-weight:500;line-height:1.8;padding-right:120px}.correct-answer-text br{line-height:2}.next-btn{background:#ff4757;color:#fff;border:none;padding:16px 28px;border-radius:9999px;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:1px;position:absolute;bottom:28px;right:28px;box-shadow:0 2px 8px #ff475733}@media(min-width:768px)and (max-width:1023px){.quiz-container{padding:30px}.question-card{max-width:100%;padding:40px 50px;border-radius:12px 12px 0 0}.feedback-section{max-width:100%;border-radius:0 0 12px 12px;padding:18px 50px}}@media(max-width:480px){.quiz-container{padding:16px}.question-card{padding:30px 25px;border-radius:12px 12px 0 0}.feedback-section{padding:18px 25px;margin:0 auto;border-radius:0 0 12px 12px}.stage-progress-bar{gap:8px;max-width:100%;margin-bottom:20px}.progress-track{height:6px}.progress-text{font-size:12px;min-width:35px}.loading-spinner{width:32px;height:32px;border-width:3px}.loading-screen>div{gap:16px}.loading-text{font-size:14px}.feedback-header{gap:8px;margin-bottom:12px;flex-wrap:wrap}.feedback-icon{width:20px;height:20px}.feedback-title{font-size:16px}.correct-answer-text{font-size:14px;line-height:1.6;padding-right:0;margin-bottom:60px}.next-btn{position:relative;display:block;margin:20px auto 0;padding:12px 20px;font-size:13px;width:auto;min-width:120px}}@media(max-width:319px){.quiz-container{padding:12px}.question-card{padding:25px 20px;border-radius:12px 12px 0 0}.feedback-section{border-radius:0 0 12px 12px;padding:16px 20px}}.listen-and-type-page .loading-screen{position:fixed;top:0;left:0;width:100%;height:100%;background:#f8f9fa;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:1000}.listen-and-type-page .loading-screen>div{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px}.listen-and-type-page .loading-spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top:4px solid #ffc515;border-radius:50%;animation:spin 1s linear infinite;flex-shrink:0}.listen-and-type-page .loading-text{font-size:16px;color:#6b7280;text-align:center;margin:0}.listen-and-type-page .quiz-container{max-width:100%;margin:0 auto;padding:40px;min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;background:transparent}.listen-and-type-page .question-card{background:#fff;border-radius:12px 12px 0 0;padding:50px 60px;box-shadow:0 2px 12px #00000026;width:100%;max-width:1200px;text-align:center;position:relative;min-height:600px;display:flex;margin:0 auto;box-sizing:border-box;flex-direction:column;justify-content:center}.listen-and-type-page .timer{position:absolute;top:30px;left:30px;background:transparent;padding:0;border-radius:0;font-weight:400;color:#888;font-size:16px;display:flex;align-items:center;gap:8px}.listen-and-type-page .timer-icon{width:20px;height:20px;fill:currentColor}.listen-and-type-page .timer.warning{color:#f44336;font-weight:600}.listen-and-type-page .timer-suffix{color:#999;margin-left:6px}.listen-and-type-page .close-btn{position:absolute;top:25px;right:25px;background:none;border:none;cursor:pointer;padding:8px;border-radius:4px;transition:background .2s;color:#ddd}.listen-and-type-page .close-btn:hover{background:#f8f8f8}.listen-and-type-page .stage-progress-bar{display:flex;align-items:center;gap:12px;width:100%;max-width:400px;margin-left:auto;margin-right:auto}.listen-and-type-page .progress-track{flex:1;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden}.listen-and-type-page .progress-fill{height:100%;background:#ffc515;border-radius:4px;transition:width .3s ease;width:0%}.listen-and-type-page .progress-text{font-size:14px;color:#666;font-weight:500;min-width:45px;text-align:right}.listen-and-type-page .question-title{font-size:28px;font-weight:400;color:#4a4a4a;margin-bottom:40px;line-height:1.2}.listen-and-type-page .audio-player{margin-bottom:60px;display:flex;justify-content:center;position:relative}.listen-and-type-page .audio-player-bar{width:100%;max-width:600px;height:80px;background:#f5f5f5;border-radius:40px;display:flex;align-items:center;padding:0 20px;gap:20px;position:relative}.listen-and-type-page .play-button{width:48px;height:48px;background:transparent;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:none;flex-shrink:0;position:absolute;left:5%;top:50%;transform:translateY(-50%)}.listen-and-type-page .play-button:hover,.listen-and-type-page .play-button:active{background:transparent;transform:translateY(-50%)}.listen-and-type-page .play-button.playing{background:transparent}.listen-and-type-page .play-icon-triangle{width:0;height:0;border-left:16px solid #ffb300;border-top:12px solid transparent;border-bottom:12px solid transparent;margin-left:4px}.listen-and-type-page .pause-icon{display:none;width:18px;height:18px;position:relative}.listen-and-type-page .pause-icon:before,.listen-and-type-page .pause-icon:after{content:"";position:absolute;width:5px;height:18px;background:#ffb300;border-radius:2px}.listen-and-type-page .pause-icon:before{left:0}.listen-and-type-page .pause-icon:after{right:0}.listen-and-type-page .play-button.playing .play-icon-triangle{display:none}.listen-and-type-page .play-button.playing .pause-icon{display:block}.listen-and-type-page .waveform-container{flex:1;height:40px;display:flex;align-items:center;justify-content:center;gap:2px;padding:0 10px}.listen-and-type-page .waveform-bar{width:3px;background:#999;border-radius:2px;transition:none}.listen-and-type-page .waveform-bar:nth-child(1){height:12px}.listen-and-type-page .waveform-bar:nth-child(2){height:20px}.listen-and-type-page .waveform-bar:nth-child(3){height:28px}.listen-and-type-page .waveform-bar:nth-child(4){height:16px}.listen-and-type-page .waveform-bar:nth-child(5){height:24px}.listen-and-type-page .waveform-bar:nth-child(6){height:18px}.listen-and-type-page .waveform-bar:nth-child(7){height:30px}.listen-and-type-page .waveform-bar:nth-child(8){height:14px}.listen-and-type-page .waveform-bar:nth-child(9){height:22px}.listen-and-type-page .waveform-bar:nth-child(10){height:26px}.listen-and-type-page .waveform-bar:nth-child(11){height:19px}.listen-and-type-page .waveform-bar:nth-child(12){height:32px}.listen-and-type-page .waveform-bar:nth-child(13){height:15px}.listen-and-type-page .waveform-bar:nth-child(14){height:25px}.listen-and-type-page .waveform-bar:nth-child(15){height:21px}.listen-and-type-page .waveform-bar:nth-child(16){height:17px}.listen-and-type-page .waveform-bar:nth-child(17){height:29px}.listen-and-type-page .waveform-bar:nth-child(18){height:13px}.listen-and-type-page .waveform-bar:nth-child(19){height:23px}.listen-and-type-page .waveform-bar:nth-child(20){height:27px}.listen-and-type-page .waveform-bar:nth-child(21){height:14px}.listen-and-type-page .waveform-bar:nth-child(22){height:24px}.listen-and-type-page .waveform-bar:nth-child(23){height:18px}.listen-and-type-page .waveform-bar:nth-child(24){height:30px}.listen-and-type-page .waveform-bar:nth-child(25){height:16px}.listen-and-type-page .waveform-bar:nth-child(26){height:22px}.listen-and-type-page .waveform-bar:nth-child(27){height:28px}.listen-and-type-page .waveform-bar:nth-child(28){height:13px}.listen-and-type-page .waveform-bar:nth-child(29){height:25px}.listen-and-type-page .waveform-bar:nth-child(30){height:19px}.listen-and-type-page .waveform-bar:nth-child(31){height:31px}.listen-and-type-page .waveform-bar:nth-child(32){height:15px}.listen-and-type-page .waveform-bar:nth-child(33){height:23px}.listen-and-type-page .waveform-bar:nth-child(34){height:17px}.listen-and-type-page .waveform-bar:nth-child(35){height:29px}.listen-and-type-page .waveform-bar:nth-child(36){height:12px}.listen-and-type-page .waveform-bar:nth-child(37){height:26px}.listen-and-type-page .waveform-bar:nth-child(38){height:20px}.listen-and-type-page .waveform-bar:nth-child(39){height:32px}.listen-and-type-page .waveform-bar:nth-child(40){height:12px}.listen-and-type-page .waveform-bar:nth-child(41){height:12px}.listen-and-type-page .speed-control{width:48px;height:32px;background:#ffc515;border:none;border-radius:16px;color:#000;font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.listen-and-type-page .speed-control:hover{background:#ffb300}.listen-and-type-page .audio-tooltip{position:absolute;top:-35px;left:-40px;background:#f0f0f0;padding:6px 10px;border-radius:6px;font-size:11px;color:#666;white-space:nowrap;display:flex;align-items:center;gap:6px;opacity:0;visibility:hidden;transition:all .3s ease;pointer-events:none;z-index:10}.listen-and-type-page .audio-tooltip.show{opacity:1;visibility:visible}.listen-and-type-page .audio-tooltip:after{content:"";position:absolute;bottom:-6px;right:8px;width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid #f0f0f0}.listen-and-type-page .text-input-container{max-width:600px;margin-left:auto;margin-right:auto}.listen-and-type-page .text-input{width:100%;min-height:120px;padding:20px;border:2px solid #e0e0e0;border-radius:12px;font-size:16px;font-family:inherit;color:#333;background:#f8f9fa;resize:vertical;outline:none;transition:all .3s ease}.listen-and-type-page .text-input:focus{border-color:#ffc515;background:#fff;box-shadow:0 0 0 3px #1cb0f61a}.listen-and-type-page .text-input.submitted{background:#f5f5f5;border-color:#ccc;color:#6b7280}.listen-and-type-page .text-input.correct{border-color:#ffc515;background:#4caf500d}.listen-and-type-page .text-input.incorrect{border-color:#f44336;background:#f443360d}.listen-and-type-page .submit-btn{background:#e0e0e0;color:#999;border:none;padding:14px 28px;border-radius:8px;font-size:16px;font-weight:700;cursor:not-allowed;transition:all .2s;text-transform:uppercase;letter-spacing:1px;position:absolute;bottom:30px;right:30px}.listen-and-type-page .submit-btn.active{background:#ffc515;color:#fff;cursor:pointer}.listen-and-type-page .submit-btn.active:hover{background:#ffb300}.listen-and-type-page .submit-btn.submitted{background:#ffc515;color:#fff;cursor:default}.listen-and-type-page .feedback-section{background:#ffcdd2;border-radius:0 0 12px 12px;padding:18px 60px;margin:0 auto;border:none;display:none;position:relative;width:100%;max-width:1200px;box-sizing:border-box;box-shadow:0 2px 12px #00000026;text-align:left}.listen-and-type-page .feedback-section.correct{background:#ffe8b0}.listen-and-type-page .feedback-section.incorrect{background:#ffcdd2}.listen-and-type-page .feedback-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.listen-and-type-page .feedback-icon{width:20px;height:20px;flex-shrink:0}.listen-and-type-page .feedback-title{font-size:16px;font-weight:700;margin:0}.listen-and-type-page .feedback-title.correct{color:#2e7d32}.listen-and-type-page .feedback-title.incorrect{color:#c62828}.listen-and-type-page .correct-answer-text{color:#c62828;font-size:16px;margin:8px 0 0;font-weight:500}.listen-and-type-page .correct-answer-text.correct-feedback{color:#2e7d32}.listen-and-type-page .next-btn{background:#ff4757;color:#fff;border:none;padding:14px 24px;border-radius:9999px;font-size:14px;font-weight:700;cursor:pointer;transition:background .2s;text-transform:uppercase;letter-spacing:1px;position:absolute;bottom:24px;right:24px}.listen-and-type-page .next-btn:hover{background:#ff3742}.listen-and-type-page .next-btn.correct{background:#ffc515}.listen-and-type-page .next-btn.correct:hover{background:#ffb300}@media(max-width:768px){.listen-and-type-page .quiz-container{padding:20px}.listen-and-type-page .question-card{padding:35px 30px;min-height:500px;border-radius:12px 12px 0 0}.listen-and-type-page .feedback-section{border-radius:0 0 12px 12px;padding:18px 50px}.listen-and-type-page .question-title{font-size:24px;margin-bottom:40px}.listen-and-type-page .audio-player-bar{height:70px;padding:0 15px;gap:15px}.listen-and-type-page .play-button{width:44px;height:44px}.listen-and-type-page .play-icon-triangle{border-left-width:12px;border-top-width:8px;border-bottom-width:8px}.listen-and-type-page .speed-control{width:42px;height:28px;font-size:11px}.listen-and-type-page .waveform-container{gap:2px}.listen-and-type-page .waveform-bar{width:2.5px}.listen-and-type-page .audio-tooltip{top:-40px;left:10px;font-size:10px;padding:5px 8px}.listen-and-type-page .text-input{min-height:100px;padding:16px;font-size:15px}.listen-and-type-page .submit-btn{bottom:20px;right:20px;padding:12px 24px;font-size:14px}.listen-and-type-page .timer{top:20px;left:20px;font-size:14px}.listen-and-type-page .close-btn{top:15px;right:15px}}@media(max-width:480px){.listen-and-type-page .question-card{padding:25px 20px;border-radius:12px 12px 0 0}.listen-and-type-page .feedback-section{border-radius:0 0 12px 12px;padding:18px 40px}.listen-and-type-page .question-title{font-size:20px}.listen-and-type-page .audio-player-bar{height:60px;padding:0 12px;gap:12px}.listen-and-type-page .play-button{width:40px;height:40px}.listen-and-type-page .play-icon-triangle{border-left-width:10px;border-top-width:7px;border-bottom-width:7px}.listen-and-type-page .speed-control{width:38px;height:26px;font-size:10px}.listen-and-type-page .waveform-container{gap:2px;padding:0 8px}.listen-and-type-page .waveform-bar{width:2px}.listen-and-type-page .audio-tooltip{top:-35px;left:-30px;font-size:9px;padding:4px 6px}.listen-and-type-page .text-input{min-height:80px;padding:12px;font-size:14px}.listen-and-type-page .stage-progress-bar{gap:8px;max-width:100%;margin-bottom:20px}.listen-and-type-page .progress-track{height:6px}.listen-and-type-page .progress-text{font-size:12px;min-width:35px}.listen-and-type-page .loading-spinner{width:32px;height:32px;border-width:3px}.listen-and-type-page .loading-screen>div{gap:16px}.listen-and-type-page .loading-text{font-size:14px}}.listen-and-type-page .audio-status{margin-bottom:20px;padding:10px;border-radius:8px;font-size:14px;text-align:center}.listen-and-type-page .audio-status.error{background:#ffcdd2;color:#c62828}.listen-and-type-page .audio-status.warning{background:#fff3cd;color:#856404}.listen-and-type-page .audio-status.success{background:#ffe8b0;color:#2e7d32}.question-card{background:#fff;border-radius:12px 12px 0 0;padding:50px 60px;box-shadow:0 2px 12px #00000026;width:100%;max-width:1200px;text-align:center;position:relative;min-height:600px;display:flex;margin:0 auto;box-sizing:border-box;flex-direction:column;justify-content:flex-start}.question-title{font-size:24px;font-weight:400;color:#6b7280;margin-bottom:40px;margin-top:40px;line-height:1.2}.content-container{display:flex;gap:40px;align-items:flex-start;justify-content:center;flex:1;margin-bottom:40px}.photo-container{flex:0 0 350px;width:350px;height:280px}.photo-image{width:100%;height:100%;object-fit:cover;border-radius:8px;box-shadow:0 2px 12px #0000001a}.text-input-container{flex:0 0 350px;width:350px;height:280px;display:flex;flex-direction:column;position:relative}.response-textarea{width:100%;height:100%;padding:16px;border:1px solid #ddd;border-radius:8px;font-size:16px;font-family:inherit;line-height:1.5;resize:none;outline:none;transition:border-color .2s;background:#fafafa;box-sizing:border-box}.response-textarea:focus{border-color:#ffc515;background:#fff}.response-textarea::placeholder{color:#999;font-style:italic}.char-counter{position:absolute;bottom:8px;right:12px;font-size:12px;color:#6b7280;background:#ffffffe6;padding:2px 6px;border-radius:4px;pointer-events:none}.char-counter.warning{color:#f44336}.continue-btn{background:#e0e0e0;color:#999;border:none;padding:14px 28px;border-radius:9999px;font-size:16px;font-weight:700;cursor:not-allowed;transition:all .2s;text-transform:uppercase;letter-spacing:1px;position:absolute;bottom:30px;right:30px;display:block}.feedback-section{background:#ffe8b0;border-radius:0 0 12px 12px;padding:18px 60px;margin:0 auto;border:none;display:none;position:relative;width:100%;max-width:1200px;box-sizing:border-box;box-shadow:0 2px 12px #00000026;text-align:left;min-height:120px}.feedback-title{font-size:16px;font-weight:700;margin:0;color:#2e7d32}.sample-answer-text{color:#2e7d32;font-size:16px;margin:8px 0 0;font-weight:500;line-height:1.6;max-width:950px;padding-bottom:60px}.next-btn{background:#ffc515;color:#fff;border:none;padding:14px 24px;border-radius:9999px;font-size:14px;font-weight:700;cursor:pointer;transition:background .2s;text-transform:uppercase;letter-spacing:1px;position:absolute;bottom:24px;right:24px}.next-btn:hover{background:#ffb300}.continue-btn:hover{background:#fff8e1}.done-btn{background:#ffc515;color:#fff;border:2px solid transparent;padding:14px 28px;border-radius:8px;font-size:16px;font-weight:700;cursor:pointer;transition:background .2s;text-transform:uppercase;letter-spacing:1px}.done-btn:hover{background:#ffb300}@media(max-width:1024px){.content-container{flex-direction:column;align-items:center;gap:30px}.photo-container,.text-input-container{flex:0 0 320px;width:320px;height:240px}}@media(max-width:768px){.quiz-container{padding:20px}.question-card{padding:30px 25px;min-height:500px;border-radius:12px 12px 0 0}.feedback-section{border-radius:0 0 12px 12px;padding:18px 50px}.question-title{font-size:20px;margin-bottom:30px}.photo-container,.text-input-container{flex:0 0 280px;width:280px;height:200px}.continue-btn{bottom:20px;right:20px;padding:12px 24px;font-size:14px}.timer{top:20px;left:20px;font-size:14px}.close-btn{top:15px;right:15px}.feedback-section{padding:20px 25px;min-height:140px}.sample-answer-text{padding-bottom:70px;max-width:100%;font-size:15px}.next-btn{bottom:15px;right:15px;padding:12px 20px;font-size:13px}}@media(max-width:480px){.question-card{padding:25px 20px;border-radius:12px 12px 0 0}.feedback-section{border-radius:0 0 12px 12px;padding:18px 40px}.photo-container,.text-input-container{flex:0 0 240px;width:240px;height:180px}.question-title{font-size:18px}.feedback-section{padding:15px 20px;min-height:150px}.sample-answer-text{padding-bottom:75px;font-size:14px;line-height:1.5}.next-btn{bottom:12px;right:12px;padding:10px 18px;font-size:12px}.stage-progress-bar{gap:8px;max-width:100%;margin-bottom:20px}.progress-track{height:6px}.progress-text{font-size:12px;min-width:35px}.loading-spinner{width:32px;height:32px;border-width:3px}.loading-screen>div{gap:16px}.loading-text{font-size:14px}}img{width:450px;height:300px}.mic-icon{margin-right:8px}.timer-label{color:#999;margin-left:6px}.photo-container{margin-bottom:40px;display:flex;justify-content:center;align-items:center;width:100%}.photo-image{display:block;max-width:100%;max-height:300px;width:auto;height:auto;margin:0 auto;border-radius:12px;box-shadow:0 4px 12px #0000001a;object-fit:contain}.audio-visualizer{margin:20px 0;display:none;justify-content:center;align-items:center;gap:4px}.audio-bar{width:4px;background:#ffc515;border-radius:2px;animation:audioWave 1s ease-in-out infinite}.continue-btn{background:#ffc515;color:#fff;border:none;padding:14px 28px;border-radius:9999px;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s;text-transform:uppercase;letter-spacing:1px}.review-icon{width:20px;height:20px;flex-shrink:0;fill:#ffc515}.review-title{font-size:16px;font-weight:700;margin:0;color:#ffc515}@media(max-width:768px){.quiz-container{padding:15px}.question-card{padding:30px 25px;min-height:500px;max-width:100%;border-radius:12px 12px 0 0}.question-title{font-size:22px;margin-bottom:16px;line-height:1.3}.question-subtitle{font-size:15px;margin-bottom:30px}.photo-container{margin-bottom:30px;padding:0 15px}.photo-image{max-height:250px;border-radius:10px}.record-button{padding:14px 28px;font-size:15px;min-width:160px;gap:6px}.mic-icon svg{width:20px;height:20px}.audio-visualizer{margin:18px 0}.audio-bar{width:3px}.review-section{padding:24px 25px 75px;margin:15px auto 0;border-radius:10px}.review-buttons{gap:10px;justify-content:center}.sample-btn,.recording-btn{padding:9px 16px;font-size:13px;min-width:110px}.continue-btn,.continue-review-btn,.done-btn{bottom:20px;right:20px;padding:12px 24px;font-size:14px}.timer{top:20px;left:20px;font-size:14px}.close-btn{top:15px;right:15px}}@media(max-width:480px){.quiz-container{padding:10px}.question-card{padding:25px 20px;min-height:450px;border-radius:12px 12px 0 0}.question-title{font-size:20px;margin-bottom:14px;line-height:1.2}.question-subtitle{font-size:14px;margin-bottom:25px}.photo-container{margin-bottom:25px;padding:0 10px}.photo-image{max-height:200px;border-radius:8px;width:100%;max-width:280px}.record-button{padding:12px 24px;font-size:14px;min-width:140px;gap:4px}.mic-icon svg{width:18px;height:18px}.audio-visualizer{margin:16px 0;gap:3px}.audio-bar{width:2px}.audio-bar:nth-child(1){height:16px}.audio-bar:nth-child(2){height:24px}.audio-bar:nth-child(3){height:20px}.audio-bar:nth-child(4){height:28px}.audio-bar:nth-child(5){height:16px}.audio-bar:nth-child(6){height:24px}.review-section{padding:20px 18px 70px;margin:12px 8px 0;border-radius:8px}.review-header{gap:8px;margin-bottom:14px}.review-icon{width:18px;height:18px}.review-title{font-size:15px}.review-buttons{gap:8px;flex-direction:column;align-items:stretch}.sample-btn,.recording-btn{padding:12px 16px;font-size:13px;min-width:auto;width:100%;justify-content:center}.play-icon,.stop-icon{width:12px;height:12px}.continue-btn,.done-btn{bottom:18px;right:18px;left:18px;width:calc(100% - 36px);padding:14px 20px;font-size:14px;text-align:center}.continue-review-btn{position:relative;bottom:auto;right:auto;left:auto;width:100%;margin:20px 0 0;padding:14px 20px;font-size:14px}.timer{top:18px;left:18px;font-size:13px}.timer-icon{width:16px;height:16px}.close-btn{top:12px;right:12px;padding:6px}.close-btn svg{width:16px;height:16px}}@media(max-width:360px){.question-card{padding:20px 15px}.question-title{font-size:18px}.photo-image{max-height:180px;max-width:260px}.record-button{padding:10px 20px;font-size:13px;min-width:120px}.review-section{padding:18px 15px 65px}}@media(max-width:768px)and (orientation:landscape){.photo-image{max-height:160px}.question-card{min-height:400px}.photo-container{margin-bottom:20px}.stage-progress-bar{gap:8px;max-width:100%;margin-bottom:20px}.progress-track{height:6px}.progress-text{font-size:12px;min-width:35px}.loading-spinner{width:32px;height:32px;border-width:3px}.loading-screen>div{gap:16px}.loading-text{font-size:14px}}@media(-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.photo-image{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}}.topic-container{margin-bottom:40px;padding:30px;background:#f8f9fa;border-radius:12px;border:2px solid #e9ecef;text-align:left;max-width:100%;width:100%;margin-left:auto;margin-right:auto;box-sizing:border-box}.topic-questions{list-style:none;padding:0;margin:0}.topic-questions li{font-size:14px;color:#6c757d;margin-bottom:12px;padding-left:20px;position:relative;line-height:1.6;word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.topic-questions li:before{content:"•";color:#6c757d;position:absolute;left:0;font-weight:700;top:0}.audio-visualizer{margin:20px 0;display:none;justify-content:center;align-items:center;gap:3px;flex-wrap:wrap;overflow:hidden}.audio-bar{width:4px;background:#ffc515;border-radius:2px;animation:audioWave 1s ease-in-out infinite;min-height:15px}.audio-bar:nth-child(1){height:20px;animation-delay:0s}.audio-bar:nth-child(2){height:30px;animation-delay:.1s}.audio-bar:nth-child(3){height:25px;animation-delay:.2s}.audio-bar:nth-child(4){height:35px;animation-delay:.3s}.audio-bar:nth-child(5){height:20px;animation-delay:.4s}.audio-bar:nth-child(6){height:30px;animation-delay:.5s}.audio-bar:nth-child(7){height:25px;animation-delay:.6s}.audio-bar:nth-child(8){height:30px;animation-delay:.7s}.audio-bar:nth-child(9){height:20px;animation-delay:.8s}.audio-bar:nth-child(10){height:25px;animation-delay:.9s}.audio-bar:nth-child(11){height:35px;animation-delay:1s}.audio-bar:nth-child(12){height:20px;animation-delay:1.1s}.audio-bar:nth-child(13){height:30px;animation-delay:1.2s}.audio-bar:nth-child(14){height:25px;animation-delay:1.3s}.audio-bar:nth-child(15){height:20px;animation-delay:1.4s}@keyframes audioWave{0%,to{transform:scaleY(1)}50%{transform:scaleY(.5)}}.continue-btn{background:#ffc515;color:#fff;border:none;padding:14px 28px;border-radius:9999px;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s;text-transform:uppercase;letter-spacing:1px;position:absolute;bottom:30px;right:30px}@media(max-width:768px){.quiz-container{padding:15px}.question-card{padding:30px 25px;min-height:500px;max-width:100%;border-radius:12px 12px 0 0}.question-title{font-size:22px;margin-bottom:16px;line-height:1.3}.question-subtitle{font-size:15px;margin-bottom:30px}.topic-container{padding:25px;margin-bottom:30px;max-width:100%;border-radius:10px}.topic-text{font-size:15px;line-height:1.6;margin-bottom:18px}.topic-questions li{font-size:13px;margin-bottom:10px;padding-left:18px}.record-button{padding:14px 28px;font-size:15px;min-width:160px;gap:6px}.record-icon{width:18px;height:18px}.recording-status{font-size:15px;margin:18px 0;gap:10px}.audio-visualizer{margin:18px 0;gap:2px}.audio-bar{width:3px}.review-section{padding:24px 25px 75px;margin:15px auto 0;border-radius:10px}.review-buttons{gap:10px;justify-content:center}.sample-btn,.recording-btn{padding:9px 16px;font-size:13px;min-width:110px}.continue-btn,.continue-review-btn,.done-btn{bottom:20px;right:20px;padding:12px 24px;font-size:14px}.timer{top:20px;left:20px;font-size:14px}.close-btn{top:15px;right:15px}}@media(max-width:480px){.quiz-container{padding:10px}.question-card{padding:25px 20px;min-height:450px;border-radius:12px 12px 0 0}.question-title{font-size:20px;margin-bottom:14px;line-height:1.2}.question-subtitle{font-size:14px;margin-bottom:25px}.topic-container{padding:20px 18px;margin-bottom:25px;border-radius:8px;border-width:1px}.topic-text{font-size:14px;line-height:1.6;margin-bottom:16px;font-weight:500}.topic-questions{margin:0}.topic-questions li{font-size:12px;margin-bottom:10px;padding-left:16px;line-height:1.5}.topic-questions li:before{font-size:12px}.record-button{padding:12px 24px;font-size:14px;min-width:140px;gap:4px}.record-icon{width:16px;height:16px}.recording-status{font-size:14px;margin:16px 0;gap:8px}.recording-dot{width:6px;height:6px}.audio-visualizer{margin:16px 0;gap:2px}.audio-bar{width:2px}.audio-bar:nth-child(1){height:16px}.audio-bar:nth-child(2){height:24px}.audio-bar:nth-child(3){height:20px}.audio-bar:nth-child(4){height:28px}.audio-bar:nth-child(5){height:16px}.audio-bar:nth-child(6){height:24px}.audio-bar:nth-child(7){height:20px}.audio-bar:nth-child(8){height:24px}.audio-bar:nth-child(9){height:16px}.audio-bar:nth-child(10){height:20px}.audio-bar:nth-child(11){height:28px}.audio-bar:nth-child(12){height:16px}.audio-bar:nth-child(13){height:24px}.audio-bar:nth-child(14){height:20px}.audio-bar:nth-child(15){height:16px}.review-section{padding:20px 18px 70px;margin:12px 8px 0;border-radius:8px}.review-header{gap:8px;margin-bottom:14px}.review-icon{width:18px;height:18px}.review-title{font-size:15px}.review-buttons{gap:8px;flex-direction:column;align-items:stretch}.sample-btn,.recording-btn{padding:12px 16px;font-size:13px;min-width:auto;width:100%;justify-content:center}.play-icon,.stop-icon{width:12px;height:12px}.continue-btn,.done-btn{bottom:18px;right:18px;left:18px;width:calc(100% - 36px);padding:14px 20px;font-size:14px;text-align:center}.continue-review-btn{position:relative;bottom:auto;right:auto;left:auto;width:100%;margin:20px 0 0;padding:14px 20px;font-size:14px}.timer{top:18px;left:18px;font-size:13px}.timer-icon{width:16px;height:16px}.close-btn{top:12px;right:12px;padding:6px}.close-btn svg{width:16px;height:16px}.stage-progress-bar{gap:8px;max-width:100%;margin-bottom:20px}.progress-track{height:6px}.progress-text{font-size:12px;min-width:35px}.loading-spinner{width:32px;height:32px;border-width:3px}.loading-screen>div{gap:16px}.loading-text{font-size:14px}}.question-card{background:#fff;border-radius:12px 12px 0 0;padding:50px 60px;box-shadow:0 2px 12px #00000026;width:100%;max-width:1200px;text-align:center;position:relative;min-height:600px;display:flex;flex-direction:column;justify-content:flex-start;margin:0 auto;box-sizing:border-box}.main-content{display:flex;gap:60px;width:100%;max-width:1000px;margin:40px auto 0;flex:1;align-items:flex-start}.passage-section{flex:1;text-align:left;min-width:0}.passage-title{font-size:14px;font-weight:600;color:#888;margin-bottom:20px;text-transform:uppercase;letter-spacing:1px}.passage-container{font-size:16px;line-height:1.7;color:#333;text-align:left;padding:25px;border:none;border-radius:8px;background:#f9f9f9;max-height:350px;overflow-y:auto;word-wrap:break-word;overflow-wrap:break-word;-webkit-overflow-scrolling:touch}.passage-text{display:inline}.answer-blank{display:inline-block;border-bottom:2px solid #ccc;min-width:80px;height:20px;margin:0 3px;vertical-align:baseline;position:relative;word-wrap:break-word;text-align:center}.blank-number{display:inline-block;width:18px;height:18px;background:#888;color:#fff;text-align:center;line-height:18px;border-radius:50%;font-size:11px;font-weight:700;margin:0 3px 0 0;vertical-align:baseline;flex-shrink:0}.questions-section{flex:1;display:flex;flex-direction:column;gap:20px;padding-left:0;min-width:0}.questions-title{font-size:16px;font-weight:500;color:#555;margin-bottom:25px;text-align:left;line-height:1.4;word-wrap:break-word}.question-item{margin-bottom:24px}.question-number{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}.question-circle{width:22px;height:22px;background:#fff;border:2px solid #ffc515;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#ffc515;flex-shrink:0}.question-label{color:#777;font-size:13px;font-weight:400;word-wrap:break-word}.question-dropdown{width:100%;max-width:280px}.dropdown-select{width:100%;background:#fff;border:1px solid #d0d0d0;border-radius:4px 9999px 9999px 4px;padding:11px 35px 11px 14px;font-size:14px;color:#999;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 12px center;background-size:14px;transition:all .2s ease;box-sizing:border-box}.dropdown-select:focus{outline:none;border-color:#ffc515;color:#333}.dropdown-select:hover{border-color:#ffc515}.dropdown-select.selected{border-color:#ffc515;color:#333;background-color:#1cb0f608}.dropdown-select.correct{border-color:#ffc515;background-color:#4caf501a;color:#2e7d32}.dropdown-select.incorrect{border-color:#f44336;background-color:#f443361a;color:#c62828}.dropdown-select.submitted{cursor:default;pointer-events:none}.dropdown-select option{padding:8px;background:#fff;color:#333}.dropdown-select option:hover{background:#f0f0f0}.continue-btn{background:#e0e0e0;color:#999;border:none;padding:12px 24px;border-radius:9999px;font-size:14px;font-weight:600;cursor:not-allowed;transition:all .2s;text-transform:uppercase;letter-spacing:.5px;position:absolute;bottom:25px;right:25px;display:block}.feedback-section{background:#ffcdd2;border-radius:0 0 12px 12px;padding:18px 60px;margin:0 auto;border:none;display:none;position:relative;width:100%;max-width:1200px;box-sizing:border-box;text-align:left;box-shadow:0 2px 12px #00000026}.feedback-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.correct-answer-text{color:#2e7d32;font-size:16px;margin:8px 0 0;font-weight:500;line-height:1.6}.correct-answer-text.incorrect-feedback{color:#c62828}@media(min-width:1024px)and (max-width:1439px){.quiz-container{padding:40px}.question-card{max-width:1200px;padding:50px 60px;border-radius:12px 12px 0 0}.feedback-section{max-width:1200px;border-radius:0 0 12px 12px;padding:18px 60px}}@media(min-width:768px)and (max-width:1023px){.quiz-container{padding:30px}.question-card{max-width:100%;padding:40px 50px;border-radius:12px 12px 0 0}.feedback-section{max-width:100%;border-radius:0 0 12px 12px;padding:18px 50px}.main-content{flex-direction:column;gap:30px}.questions-section{padding-left:0;padding-top:20px;border-top:1px solid #e0e0e0}.passage-container{max-height:300px}}@media(min-width:481px)and (max-width:767px){.quiz-container{padding:20px}.question-card{max-width:100%;padding:35px 40px;border-radius:12px 12px 0 0}.feedback-section{border-radius:0 0 12px 12px;padding:18px 40px}}@media(max-width:768px){.quiz-container{padding:20px}.question-card{padding:30px 25px;min-height:500px;border-radius:12px 12px 0 0}.feedback-section{border-radius:0 0 12px 12px;padding:18px 40px}.main-content{gap:25px;margin-top:30px}.passage-container{padding:20px;font-size:15px;max-height:250px}.questions-section{padding-left:0}.dropdown-select{font-size:13px;padding:10px 12px}.continue-btn{bottom:20px;right:20px;padding:11px 20px;font-size:13px}.timer{top:20px;left:20px;font-size:14px}.close-btn{top:15px;right:15px}}@media(max-width:480px){.quiz-container{padding:16px}.question-card{padding:25px 20px;border-radius:12px 12px 0 0}.feedback-section{border-radius:0 0 12px 12px;padding:18px 20px}.passage-container{padding:15px;font-size:14px;max-height:200px}.dropdown-select{font-size:12px;padding:8px 10px}.answer-blank{min-width:60px}.stage-progress-bar{gap:8px;max-width:100%;margin-bottom:20px}.progress-track{height:6px}.progress-text{font-size:12px;min-width:35px}.loading-spinner{width:32px;height:32px;border-width:3px}.loading-screen>div{gap:16px}.loading-text{font-size:14px}}.close-btn{position:absolute;top:25px;right:25px;background:none;border:none;cursor:pointer;padding:8px;border-radius:4px;transition:background .2s;color:#000}.question-title{font-size:28px;font-weight:400;color:#6b7280;margin-bottom:40px;line-height:1.2}.audio-player{margin-bottom:40px;display:flex;justify-content:center;position:relative}.audio-player-bar{width:100%;max-width:600px;height:80px;background:#f5f5f5;border-radius:40px;display:flex;align-items:center;padding:0 20px;gap:20px;position:relative}.audio-tooltip{position:absolute;top:-35px;left:-40px;background:#f0f0f0;padding:6px 10px;border-radius:6px;font-size:11px;color:#666;white-space:nowrap;display:flex;align-items:center;gap:6px;opacity:0;transition:all .3s ease;pointer-events:none;z-index:10}.audio-tooltip.show{opacity:1}.play-button{width:48px;height:48px;background:transparent;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:none;flex-shrink:0;position:absolute;left:5%;top:50%;transform:translateY(-50%)}.play-button:hover,.play-button:active{background:transparent;transform:translateY(-50%)}.play-button.playing{background:transparent}.play-icon-triangle{width:0;height:0;border-left:16px solid #ffb300;border-top:12px solid transparent;border-bottom:12px solid transparent;margin-left:4px}.pause-icon{display:none;width:18px;height:18px;position:relative}.pause-icon:before,.pause-icon:after{content:"";position:absolute;width:5px;height:18px;background:#ffb300;border-radius:2px}.pause-icon:before{left:0}.pause-icon:after{right:0}.play-button.playing .play-icon-triangle{display:none}.play-button.playing .pause-icon{display:block}.waveform-container{flex:1;height:40px;display:flex;align-items:center;justify-content:center;gap:2px;padding:0 10px}.waveform-bar{width:3px;background:#999;border-radius:2px;transition:none}.waveform-bar:nth-child(1){height:12px}.waveform-bar:nth-child(2){height:20px}.waveform-bar:nth-child(3){height:28px}.waveform-bar:nth-child(4){height:16px}.waveform-bar:nth-child(5){height:24px}.waveform-bar:nth-child(6){height:18px}.waveform-bar:nth-child(7){height:30px}.waveform-bar:nth-child(8){height:14px}.waveform-bar:nth-child(9){height:22px}.waveform-bar:nth-child(10){height:26px}.waveform-bar:nth-child(11){height:19px}.waveform-bar:nth-child(12){height:32px}.waveform-bar:nth-child(13){height:15px}.waveform-bar:nth-child(14){height:25px}.waveform-bar:nth-child(15){height:21px}.waveform-bar:nth-child(16){height:17px}.waveform-bar:nth-child(17){height:29px}.waveform-bar:nth-child(18){height:13px}.waveform-bar:nth-child(19){height:23px}.waveform-bar:nth-child(20){height:27px}.waveform-bar:nth-child(21){height:14px}.waveform-bar:nth-child(22){height:24px}.waveform-bar:nth-child(23){height:18px}.waveform-bar:nth-child(24){height:30px}.waveform-bar:nth-child(25){height:16px}.waveform-bar:nth-child(26){height:22px}.waveform-bar:nth-child(27){height:28px}.waveform-bar:nth-child(28){height:13px}.waveform-bar:nth-child(29){height:25px}.waveform-bar:nth-child(30){height:19px}.waveform-bar:nth-child(31){height:31px}.waveform-bar:nth-child(32){height:15px}.waveform-bar:nth-child(33){height:23px}.waveform-bar:nth-child(34){height:17px}.waveform-bar:nth-child(35){height:29px}.waveform-bar:nth-child(36){height:12px}.waveform-bar:nth-child(37){height:26px}.waveform-bar:nth-child(38){height:20px}.waveform-bar:nth-child(39){height:32px}.waveform-bar:nth-child(40){height:12px}.waveform-bar.playing-animation{animation:waveformPulse 1.5s ease-in-out infinite}@keyframes waveformPulse{0%,to{transform:scaleY(1);background:#e0e0e0}50%{transform:scaleY(1.5);background:#ffc515}}.speed-control{width:48px;height:32px;background:#ffc515;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;color:#333;flex-shrink:0;position:absolute;right:5%;top:50%;transform:translateY(-50%)}.speed-control:hover{background:#ffb300}.questions-section{margin-bottom:40px;text-align:left;max-width:800px;margin-left:auto;margin-right:auto}.question-item{margin-bottom:25px}.question-text{font-size:16px;font-weight:500;color:#333;margin-bottom:8px}.question-input{width:100%;padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;font-family:inherit;color:#333;background:#f8f9fa;outline:none;transition:all .3s ease}.question-input:focus{border-color:#ffc515;background:#fff;box-shadow:0 0 0 3px #1cb0f61a}.question-input.correct{border-color:#ffc515;background:#4caf500d}.question-input.incorrect{border-color:#f44336;background:#f443360d}.question-input.submitted{background:#f5f5f5;border-color:#ccc;color:#6b7280}.submit-btn{background:#e0e0e0;color:#999;border:none;padding:14px 28px;border-radius:8px;font-size:16px;font-weight:700;cursor:not-allowed;transition:all .2s;text-transform:uppercase;letter-spacing:1px;position:absolute;bottom:30px;right:30px}.submit-btn.active{background:#ffc515;color:#fff;cursor:pointer}.submit-btn.active:hover{background:#ffb300}.submit-btn.submitted{background:#ffc515;color:#fff;cursor:default}.feedback-section{background:#ffcdd2;border-radius:0 0 12px 12px;padding:18px 60px;margin:0 auto;border:none;display:none;position:relative;width:100%;max-width:1200px;box-sizing:border-box;box-shadow:0 2px 12px #00000026;text-align:left}.feedback-section.correct{background:#ffe8b0}.feedback-section.incorrect{background:#ffcdd2}.feedback-header{display:flex;align-items:center;gap:8px;margin-bottom:16px}.feedback-icon{width:20px;height:20px;flex-shrink:0}.feedback-title{font-size:16px;font-weight:700;margin:0}.feedback-title.correct{color:#2e7d32}.feedback-title.incorrect{color:#c62828}.feedback-details{margin-top:16px}.feedback-answer{margin-bottom:12px;font-size:14px}.feedback-answer .question-label{font-weight:600;color:#333;margin-bottom:4px}.feedback-answer .user-answer{color:#c62828;font-style:italic}.feedback-answer .correct-answer{color:#2e7d32;font-weight:600}.next-btn{background:#ff4757;color:#fff;border:none;padding:14px 24px;border-radius:9999px;font-size:14px;font-weight:700;cursor:pointer;transition:background .2s;text-transform:uppercase;letter-spacing:1px;position:absolute;bottom:24px;right:24px}.next-btn:hover{background:#ff3742}.next-btn.correct{background:#ffc515}.next-btn.correct:hover{background:#ffb300}@media(max-width:768px){.quiz-container{padding:20px}.question-card{padding:35px 30px;min-height:500px;border-radius:12px 12px 0 0}.feedback-section{border-radius:0 0 12px 12px;padding:18px 50px}.question-title{font-size:24px;margin-bottom:30px}.audio-container{max-width:100%;padding:12px 20px;min-height:60px}.play-button{width:40px;height:40px}.speaker-icon{width:24px;height:24px}.audio-waveform{height:28px;gap:2px}.waveform-bar{width:2px}.submit-btn{bottom:20px;right:20px;padding:12px 24px;font-size:14px}.timer{top:20px;left:20px;font-size:14px}.close-btn{top:15px;right:15px}}@media(max-width:480px){.question-card{padding:25px 20px;border-radius:12px 12px 0 0}.feedback-section{border-radius:0 0 12px 12px;padding:18px 40px}.question-title{font-size:20px}.audio-container{padding:10px 16px;min-height:55px;gap:12px}.play-button{width:36px;height:36px}.speaker-icon{width:16px;height:16px}.audio-waveform{height:24px;gap:1px}.waveform-bar{width:2px}.stage-progress-bar{gap:8px;max-width:100%;margin-bottom:20px}.progress-track{height:6px}.progress-text{font-size:12px;min-width:35px}.loading-spinner{width:32px;height:32px;border-width:3px}.loading-screen>div{gap:16px}.loading-text{font-size:14px}}.audio-status{margin-bottom:20px;padding:10px;border-radius:8px;font-size:14px;text-align:center}.audio-status.error{background:#ffcdd2;color:#c62828}.audio-status.warning{background:#fff3cd;color:#856404}.audio-status.success{background:#ffe8b0;color:#2e7d32}.scenario-text{display:none;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;padding:20px;margin-bottom:30px;text-align:left;font-size:16px;line-height:1.6;color:#555}.retry-btn{background:#ffc515;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s;margin-right:10px}.retry-btn:hover{background:#ffb300}.question-card{background:#fff;border-radius:12px 12px 0 0;padding:50px 60px;box-shadow:0 2px 12px #00000026;width:100%;max-width:1200px;text-align:center;position:relative;min-height:500px;display:flex;margin:0 auto;box-sizing:border-box;flex-direction:column;justify-content:flex-start}.timer{position:absolute;top:25px;left:25px;background:transparent;padding:0;border-radius:0;font-weight:400;color:#888;font-size:15px;display:flex;align-items:center;gap:6px}.timer-icon{width:18px;height:18px;fill:currentColor}.close-btn{position:absolute;top:20px;right:20px;background:none;border:none;cursor:pointer;padding:8px;border-radius:4px;transition:background .2s;color:#ccc}.close-btn:hover{background:#f8f8f8;color:#999}.preparation-stage{text-align:center;padding:60px 40px}.preparation-title{font-size:28px;font-weight:500;color:#333;margin-bottom:20px}.preparation-subtitle{font-size:16px;color:#6b7280;margin-bottom:40px}.topic-card{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;padding:30px;margin:40px auto;max-width:600px;text-align:left}.topic-text{font-size:16px;line-height:1.6;color:#333}.writing-stage{text-align:center;padding:40px}.writing-title{font-size:24px;font-weight:500;color:#333;margin-bottom:20px}.writing-topic{font-size:16px;color:#6b7280;margin-bottom:30px;line-height:1.6}.writing-area{width:100%;max-width:1200px;height:300px;border:1px solid #ddd;border-radius:8px;padding:20px;font-size:16px;font-family:inherit;resize:none;outline:none;background:#fafafa;margin-bottom:30px}.writing-area:focus{border-color:#ffc515;background:#fff}.writing-area::placeholder{color:#aaa}.results-stage{text-align:left;padding:40px}.results-title{font-size:24px;font-weight:500;color:#333;margin-bottom:20px;text-align:center}.results-topic{font-size:16px;color:#6b7280;margin-bottom:20px;text-align:center;line-height:1.6}.user-response{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;padding:20px;margin-bottom:20px;font-size:16px;line-height:1.6;color:#333;min-height:100px}.sample-answer{background:#fff3e0;border:1px solid #ffc515;border-radius:8px;padding:20px;margin-bottom:30px}.sample-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.sample-icon{width:20px;height:20px;color:#ffc515}.sample-title{font-size:16px;font-weight:600;color:#2e7d32;margin:0}.sample-text{font-size:16px;line-height:1.6;color:#2e7d32}.continue-btn{background:#e0e0e0;color:#999;border:none;padding:12px 24px;border-radius:9999px;font-size:14px;font-weight:600;cursor:not-allowed;transition:all .2s;text-transform:uppercase;letter-spacing:.5px;position:absolute;bottom:25px;right:25px}.continue-btn.active{background:#ffc515;color:#fff;cursor:pointer}.continue-btn.active:hover{background:#ffb300}.continue-btn.yellow{background:#ffc515;color:#fff;cursor:pointer}.continue-btn.yellow:hover{background:#ffb300}.continue-btn.outline{background:#fff;color:#ffc515;border:2px solid #ffc515}.continue-btn.outline:hover{background:#fff8e1}@media(max-width:768px){.quiz-container{padding:20px}.question-card{padding:30px 25px;min-height:400px;border-radius:12px 12px 0 0}.preparation-stage,.writing-stage,.results-stage{padding:30px 20px}.writing-area{height:250px}.timer{top:20px;left:20px;font-size:14px}.close-btn{top:15px;right:15px}.continue-btn,.done-btn{bottom:20px;right:20px;padding:11px 20px;font-size:13px}}@media(max-width:480px){.question-card{padding:25px 20px;border-radius:12px 12px 0 0}.preparation-title{font-size:24px}.writing-title{font-size:20px}.writing-area{height:200px}.stage-progress-bar{gap:8px;max-width:100%;margin-bottom:20px}.progress-track{height:6px}.progress-text{font-size:12px;min-width:35px}.loading-spinner{width:32px;height:32px;border-width:3px}.loading-screen>div{gap:16px}.loading-text{font-size:14px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#f8f9fa;min-height:100vh;line-height:1.6;color:#334155}.loading-screen{position:fixed;top:0;left:0;width:100%;height:100%;background:#f8f9fa;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:1000}.loading-screen>div{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px}.loading-spinner{width:40px;height:40px;border:4px solid #e0e0e0;border-top:4px solid #ffc515;border-radius:50%;animation:spin 1s linear infinite;flex-shrink:0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-text{font-size:16px;color:#6b7280;text-align:center;margin:0}.error-screen{display:none;text-align:center;padding:40px;background-color:#ffebee;border-radius:12px;border:1px solid #f44336;margin:20px}.error-title{font-size:24px;font-weight:600;color:#f44336;margin-bottom:10px}.error-message{color:#6b7280;margin-bottom:20px}.retry-data-btn{background:#ffc515;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.retry-data-btn:hover{background:#ffb300}.quiz-container{max-width:100%;margin:0 auto;padding:40px;min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;background:transparent}.question-card{background:#fff;border-radius:12px 12px 0 0;padding:50px 60px;box-shadow:0 2px 12px #00000026;width:100%;max-width:1200px;text-align:center;position:relative;min-height:600px;display:flex;margin:0 auto;box-sizing:border-box;flex-direction:column;justify-content:center}.timer{position:absolute;top:30px;left:30px;background:transparent;padding:0;border-radius:0;font-weight:400;color:#888;font-size:16px;display:flex;align-items:center;gap:8px}.timer-icon{width:20px;height:20px;fill:currentColor}.timer.warning{color:#f44336;font-weight:600}.close-btn{position:absolute;top:25px;right:25px;background:none;border:none;cursor:pointer;padding:8px;border-radius:4px;transition:background .2s;color:#ddd}.close-btn:hover{background:#f8f8f8}.stage-progress-bar{display:flex;align-items:center;gap:12px;margin-bottom:30px;width:100%;max-width:400px;margin-left:auto;margin-right:auto}.progress-track{flex:1;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:#ffc515;border-radius:4px;transition:width .3s ease;width:0%}.progress-text{font-size:14px;color:#666;font-weight:500;min-width:45px;text-align:right}.question-title{font-size:28px;font-weight:400;color:#6b7280;margin-bottom:20px;line-height:1.2}.question-subtitle{font-size:16px;color:#888;margin-bottom:40px}.topic-text{font-size:16px;color:#495057;line-height:1.7;margin-bottom:20px;font-weight:500;word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.record-button{background:#ffc515;color:#fff;border:none;padding:16px 32px;border-radius:8px;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s;text-transform:uppercase;letter-spacing:1px;display:flex;align-items:center;gap:8px;justify-content:center;margin:0 auto;min-width:180px;white-space:nowrap}.record-button:hover{background:#ffb300;transform:translateY(-2px)}.record-button.recording{background:#f44336;animation:pulse 1.5s infinite}@keyframes pulse{0%{box-shadow:0 4px 20px #f443364d}50%{box-shadow:0 4px 30px #f4433699}to{box-shadow:0 4px 20px #f443364d}}.record-icon{width:20px;height:20px;fill:currentColor;flex-shrink:0}.recording-status{display:none;align-items:center;justify-content:center;gap:12px;margin:20px 0;color:#ffc515;font-size:16px;font-weight:600;flex-wrap:wrap}.recording-dot{width:8px;height:8px;background:#ffc515;border-radius:50%;animation:blink 1s infinite}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:.3}}.continue-btn{background:#ffc515;color:#fff;border:none;padding:14px 28px;border-radius:9999px;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s;text-transform:uppercase;letter-spacing:1px;position:absolute;bottom:30px;right:30px;display:none;opacity:.5;pointer-events:none}.continue-btn.active{display:block;opacity:1;pointer-events:auto}.continue-btn:hover{background:#ffb300}.continue-btn:disabled{background:#e0e0e0;color:#999;cursor:not-allowed}.review-section{background:#ffe8b0;border-radius:12px;padding:28px 40px 80px;margin:20px auto 0;border:none;display:none;position:relative;width:100%;max-width:900px;box-sizing:border-box;text-align:left;box-shadow:0 2px 12px #00000014}.review-header{display:flex;align-items:center;gap:8px;margin-bottom:16px}.review-icon{width:20px;height:20px;flex-shrink:0;fill:#2e7d32}.review-title{font-size:16px;font-weight:700;margin:0;color:#2e7d32}.review-buttons{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px;justify-content:flex-start}.sample-btn,.recording-btn{background:#fff;color:#ffc515;border:2px solid #ffc515;padding:10px 18px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px;white-space:nowrap;min-width:120px;justify-content:center}.sample-btn:hover,.recording-btn:hover{background:#ffc515;color:#fff}.sample-btn.playing,.recording-btn.playing{background:#f44336;border-color:#f44336;color:#fff}.play-icon,.stop-icon{width:14px;height:14px;fill:currentColor}.continue-review-btn{background:#ffc515;color:#fff;border:none;padding:14px 24px;border-radius:9999px;font-size:14px;font-weight:700;cursor:pointer;transition:background .2s;text-transform:uppercase;letter-spacing:1px;position:absolute;bottom:24px;right:24px}.continue-review-btn:hover{background:#ffb300}@media(max-width:768px){.quiz-container{padding:20px}.question-card{padding:35px 30px;min-height:500px;border-radius:12px 12px 0 0}.question-title{font-size:24px;margin-bottom:16px}.topic-container{padding:20px;margin-bottom:30px}.continue-btn,.continue-review-btn,.done-btn{bottom:20px;right:20px;padding:12px 24px;font-size:14px}.timer{top:20px;left:20px;font-size:14px}.close-btn{top:15px;right:15px}}@media(max-width:480px){.quiz-container{padding:10px}.question-card{padding:25px 20px;min-height:450px;border-radius:12px 12px 0 0}.question-title{font-size:20px;margin-bottom:14px;line-height:1.2}.question-subtitle{font-size:14px;margin-bottom:25px}.topic-container{padding:20px 18px;margin-bottom:25px;border-radius:8px;border-width:1px}.topic-text{font-size:14px;line-height:1.6;margin-bottom:16px;font-weight:500}.record-button{padding:12px 24px;font-size:14px;min-width:140px;gap:4px}.record-icon{width:16px;height:16px}.recording-status{font-size:14px;margin:16px 0;gap:8px}.recording-dot{width:6px;height:6px}.review-section{padding:20px 18px 70px;margin:12px 8px 0;border-radius:8px}.review-header{gap:8px;margin-bottom:14px}.review-icon{width:18px;height:18px}.review-title{font-size:15px}.review-buttons{gap:8px;flex-direction:column;align-items:stretch}.sample-btn,.recording-btn{padding:12px 16px;font-size:13px;min-width:auto;width:100%;justify-content:center}.play-icon,.stop-icon{width:12px;height:12px}.continue-btn,.done-btn{bottom:15px;right:15px;left:15px;width:calc(100% - 30px);padding:14px 20px;font-size:14px;text-align:center}.continue-review-btn{position:relative;bottom:auto;right:auto;left:auto;width:100%;margin:20px 0 0;padding:14px 20px;font-size:14px}.timer{top:15px;left:15px;font-size:13px}.timer-icon{width:16px;height:16px}.close-btn{top:10px;right:10px;padding:6px}.close-btn svg{width:16px;height:16px}.stage-progress-bar{gap:8px;max-width:100%;margin-bottom:20px}.progress-track{height:6px}.progress-text{font-size:12px;min-width:35px}.loading-spinner{width:32px;height:32px;border-width:3px}.loading-screen>div{gap:16px}.loading-text{font-size:14px}}.certificate-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background-image:url(/assets/gradient-background.png);background-size:cover;background-position:center}.certificate-page-processing{position:relative;flex-direction:column;align-items:center;justify-content:flex-start;padding:clamp(1.5rem,4vw,3rem) clamp(2rem,6vw,4rem)}.certificate-processing-logo{position:absolute;top:clamp(1.5rem,4vw,3rem);left:clamp(2rem,6vw,4rem);width:48px;height:48px;object-fit:contain}.certificate-processing-content{width:100%;max-width:min(720px,95vw);padding:0;margin-top:4rem}.certificate-processing-header{margin-bottom:2rem}.certificate-processing-title-row{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;margin-bottom:.5rem}.certificate-countdown-inline{display:flex;flex-direction:column;align-items:flex-end}.certificate-countdown-inline .certificate-countdown{font-size:1.75rem;text-align:right}.certificate-countdown-inline .certificate-countdown-label{font-size:.8rem;text-align:right;margin:.15rem 0 0}.certificate-card{width:100%;max-width:480px;padding:2rem;border-radius:22px;background:#fff;box-shadow:0 4px 24px #00000014}.certificate-error{color:#c00;margin-bottom:1rem}.certificate-processing-title{margin:0;font-size:clamp(1.5rem,3vw,1.85rem);font-weight:700;color:#1a1d29;letter-spacing:-.02em}.certificate-stage{font-size:1.1rem;color:#1a1d29bf;margin:0}.certificate-processing-footer{margin-top:2rem}.cert-process-steps{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.cert-process-step{display:flex;flex-direction:column;gap:.35rem}.cert-process-step-header{display:flex;justify-content:space-between;align-items:center}.cert-process-label{font-size:.95rem;font-weight:500;color:#333}.cert-process-step.cert-process-active .cert-process-label{font-weight:600}.cert-process-step.cert-process-complete .cert-process-label{color:#888}.cert-process-spinner{display:inline-block;width:18px;height:18px;border:2px solid #e8e8e8;border-top-color:#ffc515;border-radius:50%;animation:cert-spinner-rotate .8s linear infinite}@keyframes cert-spinner-rotate{to{transform:rotate(360deg)}}.cert-process-check{color:#22c55e;font-size:1.1rem;font-weight:700}.cert-process-bar{height:8px;background:#e8e8e8;border-radius:4px;overflow:hidden}.cert-process-fill{height:100%;background:#ffc515;border-radius:4px;transition:width .5s ease-out}.certificate-countdown{font-size:2.5rem;font-weight:700;color:#ffc515;text-align:center;margin:0;font-variant-numeric:tabular-nums}.certificate-countdown-label{text-align:center;font-size:.9rem;color:#666;margin:.5rem 0 0}.certificate-ready .certificate-ready-title{margin:0 0 1.25rem;font-size:1.25rem;font-weight:700;color:#1a1d29;text-align:center}.certificate-pdf-preview{width:100%;height:420px;border:1px solid #e0e0e0;border-radius:12px;overflow:hidden;margin-bottom:1.25rem;background:#f8f7f5}.certificate-pdf-preview iframe{width:100%;height:100%;border:none}.certificate-actions{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;margin-bottom:1.25rem}.certificate-btn{padding:12px 20px;font-size:.95rem;font-weight:600;border-radius:12px;border:none;cursor:pointer;text-decoration:none;display:inline-block;text-align:center;transition:opacity .2s}.certificate-btn.primary{background:#ffc515;color:#1a1a1a}.certificate-btn.primary:hover{opacity:.9}.certificate-btn.secondary{background:#f0f0f0;color:#333}.certificate-btn.secondary:hover{background:#e0e0e0}.certificate-nav{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.certificate-link{background:none;border:none;color:#06c;font-size:.9rem;cursor:pointer;text-decoration:underline}.certificate-link:hover{color:#049}.certificate-form-card{max-width:420px}.certificate-form-header{text-align:center;margin-bottom:1.5rem}.certificate-form-bird{width:64px;height:64px;object-fit:contain;margin-bottom:.75rem}.certificate-form-title{margin:0 0 .35rem;font-size:1.35rem;font-weight:700;color:#1a1d29}.certificate-form-subtitle{margin:0;font-size:.9rem;color:#666}.certificate-form{display:flex;flex-direction:column;gap:1rem}.certificate-field{display:flex;flex-direction:column;gap:.35rem}.certificate-label{font-size:.9rem;font-weight:600;color:#333}.certificate-label .required{color:#c00}.certificate-input{padding:10px 12px;font-size:1rem;border:1px solid #ddd;border-radius:10px;background:#fff}.certificate-input:focus{outline:none;border-color:#ffc515;box-shadow:0 0 0 2px #ffc51540}.certificate-file{font-size:.9rem}.certificate-hint{font-size:.8rem;color:#666}.certificate-field-error{margin:0;font-size:.85rem;color:#c00}.certificate-photo-preview{margin-top:.5rem}.certificate-photo-preview img{display:block;max-width:160px;max-height:160px;object-fit:cover;border-radius:10px;border:1px solid #e0e0e0}.certificate-form-actions{display:flex;gap:.75rem;justify-content:flex-start;margin-top:.5rem}@media(max-width:768px){.certificate-card.certificate-processing{padding:1.5rem}.cert-process-steps{gap:.85rem}.cert-process-label{font-size:.9rem}}@media(max-width:480px){.certificate-page{padding:16px}.certificate-card.certificate-processing{padding:1.25rem}.certificate-processing-title{font-size:1.2rem}.certificate-stage{font-size:1rem}.cert-process-steps{gap:.75rem;margin-bottom:1.25rem}.cert-process-label{font-size:clamp(.85rem,2.5vw,.95rem)}.certificate-countdown{font-size:2rem}}
