@import url(https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&display=swap);.dashboard{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}.dashboard-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;padding:1rem 2rem}.header-content{align-items:center;display:flex;justify-content:space-between;max-width:900px}.header-content h1{color:#fff;font-size:1.5rem;font-weight:700;margin:0}.user-section{align-items:center;display:flex;gap:1rem}.user-name{color:#fff;font-weight:500}.logout-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;font-family:inherit;padding:.5rem 1rem;transition:all .2s ease}.logout-btn:hover{background:#ffffff4d}.settings-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;font-size:1.1rem;padding:.5rem .75rem;transition:all .2s ease}.settings-btn:hover{background:#ffffff4d}.dashboard-main{margin:0 auto;max-width:700px;padding:2rem 1.5rem}.welcome-section{margin-bottom:2.5rem;text-align:center}.welcome-section h2{color:#fff;font-size:2rem;font-weight:700;margin:0 0 .5rem}.welcome-section p{color:#ffffffd9;font-size:1.1rem;margin:0}.stats-section{align-items:center;display:flex;flex-direction:column;margin-bottom:2rem}.stats-section h3{color:#fff;font-size:1.25rem;font-weight:600;margin:0 0 1.25rem;text-align:center}.stats-grid{grid-gap:1rem;gap:1rem;max-width:400px;width:100%}.stat-card{box-shadow:0 4px 15px #0000001a;cursor:pointer;flex-direction:column;justify-content:center;min-height:120px;overflow:hidden;padding:1.25rem;position:relative;transition:all .3s ease}.stat-card:before{content:"";height:4px;left:0;position:absolute;right:0;top:0}.stat-card:first-child:before{background:linear-gradient(90deg,#667eea,#764ba2)}.stat-card:nth-child(2):before{background:linear-gradient(90deg,#ec407a,#d81b60)}.stat-card:nth-child(3):before{background:linear-gradient(90deg,#66bb6a,#43a047)}.stat-card:nth-child(4):before{background:linear-gradient(90deg,#ffa726,#fb8c00)}.stat-card:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-4px)}.stat-icon{font-size:1.75rem;margin-bottom:.5rem}.stat-number{font-size:2rem;font-weight:800;margin-bottom:.25rem}.stat-card:first-child .stat-number{color:#667eea}.stat-card:nth-child(2) .stat-number{color:#ec407a}.stat-card:nth-child(3) .stat-number{color:#43a047}.stat-card:nth-child(4) .stat-number{color:#fb8c00}.stat-label{font-size:.9rem;font-weight:500}.total-section{display:flex;justify-content:center;margin-bottom:2rem}.total-card{background:#ffffff26;border:1px solid #fff3;border-radius:16px;max-width:400px;padding:1.5rem;text-align:center;width:100%}.total-info{align-items:center;display:flex;flex-direction:column;gap:.25rem}.total-number{color:#fff;font-size:3rem;font-weight:800}.total-label{color:#ffffffd9;font-size:1rem}.action-section{text-align:center}.start-practice-btn{background:#fff;border:none;border-radius:50px;box-shadow:0 4px 20px #00000026;color:#667eea;cursor:pointer;font-family:inherit;font-size:1.25rem;font-weight:700;padding:1rem 3rem;transition:all .3s ease}.start-practice-btn:hover{box-shadow:0 8px 30px #0003;transform:translateY(-3px)}@media (max-width:768px){.dashboard-header{padding:1rem}.header-content{flex-direction:column;gap:1rem;text-align:center}.dashboard-main{padding:1.5rem 1rem}.welcome-section h2{font-size:1.5rem}.stats-grid{max-width:100%}.stat-card{min-height:100px;padding:1rem}.stat-number{font-size:1.75rem}.total-card{max-width:100%}.total-number{font-size:2.5rem}.start-practice-btn{font-size:1.1rem;padding:.875rem 2rem}}.exam-type-badge{background:#fff3;border-radius:20px;font-size:12px;margin-left:10px;padding:4px 12px}.target-section{margin:20px 0}.target-section h3{color:#fff;font-size:1.3rem;margin-bottom:15px;text-align:center}.target-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(4,1fr)}.target-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:15px;text-align:center}.skill-name{color:#333;display:block;font-weight:600;margin-bottom:10px}.score-display{align-items:center;gap:8px;margin-bottom:8px}.current-score{color:#667eea;font-size:1.5rem;font-weight:700}.target-arrow{color:#999}.target-score{color:#999;font-size:1.2rem}.gap-indicator{color:#e67e22;display:block;font-size:.85rem;font-weight:500}.gap-indicator.achieved{color:#27ae60}@media (max-width:768px){.target-grid{grid-template-columns:repeat(2,1fr)}}.usage-section{margin:20px 0}.usage-section h3{color:#fff;font-size:1.3rem;margin-bottom:15px;text-align:center}.usage-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin:0 auto;max-width:400px;padding:20px;text-align:center}.usage-info{align-items:center;display:flex;gap:10px;justify-content:center;margin-bottom:15px}.usage-icon{font-size:1.5rem}.usage-label{color:#333;font-weight:600}.usage-count{color:#667eea;font-size:1.2rem;font-weight:700}.usage-bar{background:#e0e0e0;border-radius:10px;height:10px;margin-bottom:15px;overflow:hidden}.usage-progress{background:linear-gradient(90deg,#667eea,#764ba2);border-radius:10px;height:100%;transition:width .3s ease}.usage-warning{color:#e74c3c;font-size:.9rem;margin-bottom:15px}.upgrade-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:25px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 30px;transition:transform .2s,box-shadow .2s}.upgrade-btn:hover{box-shadow:0 4px 15px #667eea66;transform:translateY(-2px)}.premium-badge{background:linear-gradient(135deg,#f5af19,#f12711);border-radius:20px;color:#fff;display:inline-block;font-weight:600;padding:8px 20px}.writing-practice-container{background:linear-gradient(135deg,#667eea,#764ba2);margin:0 auto;max-width:900px;min-height:100vh;padding:20px}.back-btn{display:inline-block;font-size:16px;opacity:.9;transition:opacity .2s}.back-btn:hover{opacity:1}.task-selection{padding:20px;text-align:center}.task-selection h1{color:#fff;font-size:2.5rem;margin-bottom:10px}.selection-subtitle{color:#fff;font-size:1.3rem;font-weight:600;margin-bottom:40px;text-shadow:2px 2px 4px #0006}.task-options{display:flex;flex-wrap:wrap;gap:30px;justify-content:center}.task-card{background:#fff;border-radius:20px;cursor:pointer;padding:30px;text-align:left;transition:transform .3s,box-shadow .3s;width:320px}.task-card:hover{box-shadow:0 20px 40px #0003;transform:translateY(-10px)}.task-icon{font-size:3rem;margin-bottom:15px}.task-card h2{color:#333;font-size:1.8rem;margin-bottom:10px}.task-time,.task-words{color:#666;font-size:.95rem;margin:5px 0}.task-description{color:#555;font-size:1rem;line-height:1.5;margin:15px 0}.task-types{display:flex;flex-wrap:wrap;gap:8px;list-style:none;margin:15px 0;padding:0}.task-types li{background:#f0f0f0;border-radius:15px;color:#555;font-size:.85rem;padding:5px 12px}.start-task-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;margin-top:15px;padding:15px;transition:opacity .2s;width:100%}.start-task-btn:hover{opacity:.9}.header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.header h1{color:#fff;font-size:1.8rem;margin:0}.timer{background:#fff;border-radius:10px;color:#333;font-size:1.3rem;padding:10px 20px}.timer-warning{background:#ff6b6b;color:#fff}.question-section{border-radius:15px;margin-bottom:20px;padding:25px}.question-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.question-label{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;color:#fff;font-size:.85rem;padding:5px 15px;text-transform:uppercase}.new-question-btn{background:none;border:2px solid #667eea;border-radius:8px;color:#667eea;cursor:pointer;font-size:.9rem;padding:8px 15px;transition:all .2s}.new-question-btn:hover{background:#667eea;color:#fff}.question-title{color:#333;font-size:1.3rem;margin-bottom:10px}.question-description{color:#555;font-size:1rem;line-height:1.6;margin-bottom:15px}.question-prompt{background:#f8f9fa;border-left:4px solid #667eea;border-radius:10px;color:#333;font-style:italic;font-weight:600;padding:15px}.question-text{color:#333;line-height:1.7}.chart-container{background:#f8f9fa;border-radius:10px;margin:20px 0;overflow-x:auto;padding:20px}.chart-legend{display:flex;flex-wrap:wrap;gap:20px;margin-bottom:15px}.legend-item{align-items:center;display:flex;font-size:.9rem;gap:8px}.legend-color{border-radius:4px;height:20px;width:20px}.data-table{border-collapse:collapse;font-size:.95rem;width:100%}.data-table td,.data-table th{border:1px solid #ddd;padding:12px;text-align:center}.data-table th{background:#667eea;color:#fff;font-weight:600}.data-table tr:nth-child(2n){background:#f0f0f0}.pie-chart-visual{display:flex;flex-wrap:wrap;gap:15px;justify-content:center}.pie-segment{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 5px #0000001a;display:flex;gap:10px;padding:10px 15px}.segment-color{border-radius:50%;height:24px;width:24px}.segment-label{color:#333;font-weight:500}.segment-value{color:#667eea;font-weight:700}.process-visual{gap:5px}.process-step,.process-visual{align-items:center;display:flex;flex-direction:column}.process-step{text-align:center}.step-number{height:35px;margin-bottom:8px;width:35px}.step-text{background:#fff;border-radius:8px;box-shadow:0 2px 5px #0000001a;max-width:300px;padding:12px 20px}.step-arrow{font-size:1.5rem;margin:5px 0}.map-visual{align-items:stretch;display:flex;flex-wrap:wrap;gap:20px;justify-content:center}.map-panel{background:#fff;border-radius:10px;box-shadow:0 2px 5px #0000001a;flex:1 1;min-width:250px;padding:20px}.map-panel h4{border-bottom:2px solid #667eea;color:#667eea;font-size:1.3rem;margin-bottom:15px;padding-bottom:10px;text-align:center}.map-panel ul{list-style:none;margin:0;padding:0}.map-panel li{border-bottom:1px solid #eee;color:#555;padding:8px 0}.map-panel li:last-child{border-bottom:none}.map-arrow{align-items:center;color:#667eea;display:flex;font-size:2rem}.essay-section{background:#fff;border-radius:15px;padding:25px}.word-count{color:#666;font-size:.95rem;margin-bottom:10px}.count-good{color:#4caf50;font-weight:700}.count-low{color:#ff6b6b;font-weight:700}.min-words{color:#999;font-size:.85rem}.essay-input{border:2px solid #e0e0e0;border-radius:10px;font-family:inherit;font-size:1rem;line-height:1.8;min-height:300px;padding:20px;resize:vertical;transition:border-color .2s;width:100%}.essay-input:focus{border-color:#667eea;outline:none}.essay-input::placeholder{color:#aaa}.error-message{background:#fff0f0;border-left:4px solid #d32f2f;color:#d32f2f;margin:15px 0;padding:12px}.button-group{display:flex;gap:15px;margin-top:20px}.back-to-selection{background:#f0f0f0;border:none;border-radius:10px;color:#666;cursor:pointer;font-size:1rem;padding:15px 25px;transition:background .2s}.back-to-selection:hover{background:#e0e0e0}.submit-btn{flex:1 1;font-size:1.1rem;padding:15px 30px;transition:opacity .2s}.submit-btn:hover:not(:disabled){opacity:.9}.submit-btn:disabled{opacity:.6}.feedback-container{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:20px}.band-score{border-radius:20px}.band-score .score{font-size:4rem}.band-score .score-label{color:#666;font-size:1.1rem}.criteria-scores{margin-bottom:20px}.criteria{align-items:center;background:#fff;border-radius:12px;display:flex;justify-content:space-between;padding:20px}.criteria-label{font-size:.95rem}.criteria-score{font-size:1.5rem}.feedback-sections{display:flex;flex-direction:column;gap:15px;margin-bottom:20px}.feedback-section{border-radius:12px;padding:20px}.feedback-section h3{color:#333}.feedback-section ul{list-style:none;margin:0;padding:0}.feedback-section li{border-bottom:1px solid #eee;color:#555;padding:10px 0}.feedback-section li:last-child{border-bottom:none}.feedback-section p{color:#555;line-height:1.6}.rewrite-btn{background:linear-gradient(135deg,#f093fb,#f5576c);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;margin-bottom:20px;padding:18px;transition:opacity .2s;width:100%}.rewrite-btn:hover:not(:disabled){opacity:.9}.rewrite-btn:disabled{cursor:not-allowed;opacity:.7}.rewritten-section{background:#fff;border-radius:12px;margin-bottom:20px;padding:25px}.rewritten-section h3{color:#333;margin-bottom:15px}.rewritten-essay{color:#444}.history-btn,.new-essay-btn{border:none;border-radius:10px;cursor:pointer;flex:1 1;font-size:1rem;font-weight:600;padding:15px;transition:opacity .2s}.new-essay-btn{background:#fff;color:#667eea}.history-btn{background:#fff3;color:#fff}.history-btn:hover,.new-essay-btn:hover{opacity:.9}@media (max-width:768px){.task-options{align-items:center;flex-direction:column}.task-card{max-width:350px;width:100%}.header{flex-direction:column;gap:15px;text-align:center}.criteria-scores{grid-template-columns:1fr}.map-visual{flex-direction:column}.map-arrow{justify-content:center;transform:rotate(90deg)}.action-buttons,.button-group{flex-direction:column}}.essay-history{background:linear-gradient(135deg,#f8fafc,#e2e8f0);font-family:DM Sans,sans-serif;min-height:100vh;padding-bottom:4rem}.history-header{background:linear-gradient(135deg,#1e3a5f,#2d5a87 50%,#1e3a5f);position:relative}.header-content{margin:0 auto;max-width:1200px}.back-btn{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;cursor:pointer;margin-bottom:1rem;padding:.5rem 1rem}.history-header h1{font-size:2.5rem}.subtitle{color:#fffc;font-size:1.1rem;margin:0}.stats-section{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin:-2rem auto 2rem;max-width:1200px;padding:0 1.5rem}.stat-card{align-items:center;box-shadow:0 4px 20px #00000014;display:flex;gap:1rem;padding:1.5rem}.stat-icon{font-size:2rem}.stat-value{color:#1e3a5f;font-size:1.75rem}.stat-label{color:#64748b}.stat-info{display:flex;flex-direction:column}.filters-section{display:flex;flex-wrap:wrap;gap:1rem;margin:0 auto 1.5rem;max-width:1200px;padding:0 1.5rem}.filter-group{align-items:center;display:flex;gap:.5rem}.filter-group label{color:#64748b;font-weight:500}.filter-group select{background:#fff;border:2px solid #e2e8f0;border-radius:10px;cursor:pointer;padding:.6rem 1rem}.essays-section{margin:0 auto;max-width:1200px;padding:0 1.5rem}.essays-list{display:flex;flex-direction:column;gap:1rem}.essay-card{border:1px solid #0000;box-shadow:0 2px 12px #0000000f;overflow:hidden}.essay-card.expanded{border-color:#2d5a87}.essay-card-header{align-items:center;cursor:pointer;display:flex;justify-content:space-between;padding:1.25rem 1.5rem}.essay-main-info{display:flex;flex:1 1;flex-direction:column;gap:.5rem}.task-type-badge{background:linear-gradient(135deg,#e8f4fd,#d0e8f7);border-radius:20px;color:#1e3a5f;display:inline-block;font-size:.75rem;font-weight:600;padding:.25rem .75rem;width:-webkit-fit-content;width:fit-content}.essay-topic{color:#1e293b;font-size:1rem;font-weight:600;margin:0}.essay-date{color:#94a3b8;font-size:.85rem}.essay-score-section{align-items:center;display:flex;gap:1rem}.score-badge{align-items:center;border-radius:12px;display:flex;flex-direction:column;padding:.5rem 1rem}.score-label{font-size:.65rem;font-weight:600;text-transform:uppercase}.score-value{font-size:1.5rem}.score-high{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#166534}.score-medium{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.score-low{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b}.score-pending{background:#f1f5f9;color:#64748b}.expand-icon{color:#94a3b8}.essay-card-body{border-top:1px solid #f1f5f9;padding:0 1.5rem 1.5rem}.essay-content-section,.feedback-section,.rewrite-section{margin-top:1.5rem}.essay-content-section h4,.feedback-section h4,.rewrite-section h4{color:#1e3a5f;font-size:.9rem;font-weight:600;margin:0 0 .75rem;text-transform:uppercase}.essay-text,.rewrite-text{background:#f8fafc;border-left:4px solid #2d5a87;border-radius:12px;color:#374151;font-size:.95rem;line-height:1.7;padding:1.25rem;white-space:pre-wrap}.rewrite-text{background:#f0fdf4;border-left-color:#10b981}.word-count{color:#64748b;font-size:.85rem;margin-top:.75rem}.feedback-content{background:#fffbeb;border-left:4px solid #f59e0b;border-radius:12px;padding:1.25rem}.feedback-category{border-bottom:1px solid #f59e0b33;display:flex;justify-content:space-between;padding:.5rem 0}.category-label{color:#92400e}.category-score{color:#92400e;font-weight:700}.essay-actions{margin-top:1.5rem}.action-btn{border:none;border-radius:10px;cursor:pointer;font-weight:600;padding:.75rem 1.25rem}.practice-again{background:linear-gradient(135deg,#2d5a87,#1e3a5f);color:#fff}.empty-state{border-radius:20px;padding:4rem 2rem}.empty-state h2{color:#1e3a5f}.empty-state p{color:#64748b}.start-btn{background:linear-gradient(135deg,#2d5a87,#1e3a5f);border-radius:12px;padding:1rem 2rem}.loading-container{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:60vh}.loading-spinner{border:4px solid #e2e8f0;border-top-color:#2d5a87}.error-container{padding:4rem 2rem;text-align:center}.error-icon{font-size:3rem;margin-bottom:1rem}.retry-btn{background:#fee2e2;border:none;border-radius:10px;color:#991b1b;cursor:pointer;padding:.75rem 1.5rem}.speaking-practice{background:linear-gradient(135deg,#faf5ff,#ede9fe);font-family:DM Sans,sans-serif;min-height:100vh;padding-bottom:4rem}.speaking-header{background:linear-gradient(135deg,#7c3aed,#5b21b6 50%,#4c1d95);padding:2rem 1.5rem 3rem}.speaking-header .header-content{margin:0 auto;max-width:1200px}.speaking-header .back-btn{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;color:#fff;cursor:pointer;font-family:inherit;margin-bottom:1rem;padding:.5rem 1rem}.speaking-header .back-btn:hover{background:#fff3}.speaking-header h1{color:#fff;font-size:2.5rem;margin:0 0 .5rem}.speaking-header .subtitle{color:#fffc;font-size:1.1rem;margin:0}.speaking-main{margin:-2rem auto 0;max-width:900px;padding:0 1.5rem;position:relative}.part-selection{background:#fff;border-radius:20px;box-shadow:0 4px 20px #00000014;padding:2rem}.part-selection h2{color:#4c1d95;margin:0 0 2rem;text-align:center}.parts-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.part-card{background:linear-gradient(135deg,#f5f3ff,#ede9fe);border:2px solid #0000;border-radius:16px;cursor:pointer;padding:1.5rem;transition:all .3s ease}.part-card:hover{border-color:#7c3aed;box-shadow:0 8px 25px #7c3aed33;transform:translateY(-4px)}.part-number{background:#7c3aed;border-radius:20px;color:#fff;display:inline-block;font-size:.8rem;font-weight:600;margin-bottom:.75rem;padding:.25rem .75rem}.part-card h3{color:#4c1d95;font-size:1.1rem;margin:0 0 .5rem}.part-duration{color:#7c3aed;font-size:.9rem;font-weight:600;margin:0 0 .5rem}.part-description{color:#6b7280;font-size:.9rem;margin:0}.question-section{box-shadow:0 4px 20px #00000014;padding:2rem}.part-badge{background:#7c3aed;display:inline-block;margin-bottom:.5rem;padding:.25rem 1rem}.topic-badge{background:#ede9fe;color:#5b21b6;margin-bottom:1.5rem;padding:.25rem 1rem}.question-card{background:linear-gradient(135deg,#f5f3ff,#ede9fe);margin-bottom:1.5rem;padding:2rem}.question-card h2{color:#4c1d95;margin:0 0 1rem}.question-text{font-size:1.2rem;margin:0}.prep-note{color:#7c3aed;font-style:italic;margin-top:1rem}.recording-section{background:#fff;border-radius:20px;box-shadow:0 4px 20px #00000014;padding:2rem;text-align:center}.question-reminder{background:#f5f3ff;border-radius:12px;color:#4c1d95;font-size:.95rem;margin:1rem 0 2rem;padding:1rem}.recording-indicator{align-items:center;display:flex;height:120px;justify-content:center;margin:0 auto 1rem;position:relative;width:120px}.pulse-ring{animation:pulse 1.5s ease-out infinite;background:#ef444433;border-radius:50%;height:100%;position:absolute;width:100%}.mic-icon{font-size:3rem;z-index:1}.timer{color:#ef4444;font-size:3rem;font-weight:700;margin-bottom:.5rem}.recording-status{color:#ef4444;font-weight:600;margin-bottom:1.5rem}.live-transcript{background:#f9fafb;border-radius:12px;margin-bottom:1.5rem;max-height:200px;overflow-y:auto;padding:1.5rem;text-align:left}.live-transcript h4{color:#4c1d95;font-size:.9rem;margin:0 0 .75rem}.live-transcript p{color:#374151;line-height:1.6;margin:0}.btn-stop{background:#ef4444;border-radius:12px;font-family:inherit;padding:1rem 2rem;transition:all .2s ease}.btn-stop:hover{background:#dc2626;transform:translateY(-2px)}.review-section{background:#fff;border-radius:20px;box-shadow:0 4px 20px #00000014;padding:2rem}.review-section h2{color:#4c1d95;margin:0 0 1.5rem;text-align:center}.stats-row{display:flex;gap:2rem;justify-content:center;margin-bottom:1.5rem}.stat{text-align:center}.stat-label{display:block;font-size:.85rem;margin-bottom:.25rem}.stat-value{color:#7c3aed;display:block;font-size:1.5rem}.transcript-review{background:#f5f3ff;border-radius:12px;margin-bottom:1.5rem;padding:1.5rem}.transcript-review h4{color:#4c1d95;margin:0 0 .75rem}.transcript-review p{color:#374151;line-height:1.6;margin:0}.feedback-section{box-shadow:0 4px 20px #00000014;padding:2rem}.feedback-section h2{color:#4c1d95;margin:0 0 2rem}.overall-score{margin-bottom:2rem;text-align:center}.score-circle{background:linear-gradient(135deg,#7c3aed,#5b21b6);display:inline-flex}.score-circle.score-high{background:linear-gradient(135deg,#10b981,#059669)}.score-number{font-size:2.5rem;line-height:1}.score-circle .score-label{font-size:.75rem;opacity:.9}.criteria-scores{grid-gap:1rem;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.criterion{align-items:center;background:#f5f3ff;border-radius:12px;display:flex;justify-content:space-between;padding:1rem}.criterion-name{color:#4c1d95;font-weight:500}.criterion-score{border-radius:8px;font-size:1.25rem;font-weight:700;padding:.25rem .75rem}.criterion-score.score-high{background:#d1fae5;color:#059669}.criterion-score.score-medium{background:#fef3c7;color:#d97706}.criterion-score.score-low{background:#fee2e2;color:#dc2626}.feedback-details{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:1.5rem}.feedback-card{border-radius:12px;padding:1.5rem}.feedback-card.strengths{background:#d1fae5}.feedback-card.improvements{background:#fef3c7}.feedback-card h4{color:#1f2937;margin:0 0 1rem}.feedback-card ul{margin:0;padding-left:1.25rem}.feedback-card li{color:#374151;margin-bottom:.5rem}.summary-card{background:#f5f3ff;border-radius:12px;margin-bottom:1.5rem;padding:1.5rem}.summary-card h4{color:#4c1d95;margin:0 0 .75rem}.summary-card p{color:#374151;line-height:1.6;margin:0}.btn-primary{background:linear-gradient(135deg,#7c3aed,#5b21b6)}.btn-primary:hover:not(:disabled){box-shadow:0 6px 20px #7c3aed4d;transform:translateY(-2px)}.btn-secondary{border:2px solid #7c3aed;color:#7c3aed}.btn-secondary:hover{background:#f5f3ff}.loading-spinner{border:4px solid #ede9fe;border-top-color:#7c3aed}.model-answer-prompt{background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:16px;margin:2rem 0;padding:1.5rem;text-align:center}.btn-model-answer{background:linear-gradient(135deg,#f59e0b,#d97706);border:none;border-radius:12px;color:#fff;cursor:pointer;font-family:inherit;font-size:1.1rem;font-weight:600;padding:1rem 2rem;transition:all .2s ease}.btn-model-answer:hover:not(:disabled){box-shadow:0 6px 20px #f59e0b66;transform:translateY(-2px)}.btn-model-answer:disabled{cursor:not-allowed;opacity:.7}.model-answer-hint{color:#92400e;font-size:.9rem;margin-bottom:0;margin-top:.75rem}.model-answer-section{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:2px solid #10b981;border-radius:16px;margin:2rem 0;padding:1.5rem}.model-answer-section h3{color:#065f46;margin:0 0 1rem;text-align:center}.model-answer-content{background:#fff;border-radius:12px;margin-bottom:1.5rem;padding:1.5rem}.model-answer-content p{color:#1f2937;font-size:1.05rem;line-height:1.8;margin:0}.key-vocabulary{margin-bottom:1.5rem}.key-vocabulary h4{color:#065f46;margin:0 0 .75rem}.vocab-tags{display:flex;flex-wrap:wrap;gap:.5rem}.vocab-tag{background:#fff;border:1px solid #10b981;border-radius:20px;color:#059669;font-size:.9rem;font-weight:500;padding:.5rem 1rem}.improvement-tips{background:#fff;border-radius:12px;padding:1rem 1.5rem}.improvement-tips h4{color:#065f46;margin:0 0 .5rem}.improvement-tips p{color:#374151;line-height:1.6;margin:0}@media (max-width:768px){.speaking-header h1{font-size:1.75rem}.parts-grid{grid-template-columns:1fr}.question-text{font-size:1.1rem}.timer{font-size:2.5rem}.criteria-scores{grid-template-columns:1fr}.action-buttons{flex-direction:column}.btn-primary,.btn-secondary{width:100%}.vocab-tags{justify-content:center}}.part-card.featured{border:3px solid #667eea;position:relative}.part-badge{padding:5px 15px;position:absolute;right:20px;top:-12px}.part-highlight{border-top:1px solid #eee;display:flex;gap:15px;justify-content:center;margin-top:15px;padding-top:15px}.part-highlight span{background:#f0f4ff;border-radius:8px;color:#667eea;font-size:.85rem;font-weight:600;padding:8px 12px}.cue-card{background:#f8f9fa;border-left:4px solid #667eea;border-radius:12px;margin-top:20px;padding:20px}.cue-card h3{color:#333;font-size:1rem;margin-bottom:12px}.bullet-points{list-style:disc;margin:0;padding-left:20px}.bullet-points li{color:#555;line-height:1.5;padding:6px 0}.prep-note{background:linear-gradient(135deg,#667eea15,#764ba215);border:1px solid #667eea30;border-radius:10px;color:#555;font-size:.95rem;margin-top:20px;padding:15px 20px}.prep-note strong{color:#667eea}.preparation-section{background:#fff;border-radius:20px;margin:0 auto;max-width:700px;padding:30px}.prep-timer-container{display:flex;justify-content:center;margin:20px 0 30px}.prep-timer{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:15px;color:#fff;padding:20px 40px;text-align:center}.prep-timer .timer-label{display:block;font-size:.9rem;margin-bottom:5px;opacity:.9}.prep-timer .timer-value{font-size:3rem;font-weight:700}.prep-timer.timer-warning{animation:pulse 1s infinite;background:linear-gradient(135deg,#ff6b6b,#ee5a5a)}.notes-section{margin-top:25px}.notes-section h3{color:#333;margin-bottom:12px}.notes-input{border:2px solid #e0e0e0;border-radius:12px;font-family:inherit;font-size:1rem;min-height:150px;padding:15px;resize:vertical;transition:border-color .2s;width:100%}.notes-input:focus{border-color:#667eea;outline:none}.notes-input::placeholder{color:#999}.recording-section .timer{background:#fff;border-radius:15px;box-shadow:0 4px 15px #0000001a;margin:20px 0;padding:20px 40px;text-align:center}.recording-section .timer .timer-label{color:#666;display:block;font-size:.9rem;margin-bottom:5px}.recording-section .timer .timer-value{color:#333;font-size:2.5rem;font-weight:700}.recording-section .timer.timer-warning .timer-value{color:#ff6b6b}.btn-primary{border-radius:10px;padding:15px 30px;transition:all .3s}.btn-primary:hover{box-shadow:0 5px 20px #667eea66}.btn-secondary{background:#f0f0f0;border:none;border-radius:10px;color:#333;padding:15px 30px;transition:all .2s}.btn-secondary:hover{background:#e0e0e0}.btn-stop{background:#ff6b6b;border:none;border-radius:30px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;margin-top:20px;padding:15px 40px;transition:all .3s}.btn-stop:hover{background:#ee5a5a;transform:scale(1.05)}.btn-model{background:#fff;border:2px solid #667eea;border-radius:10px;color:#667eea;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 25px;transition:all .2s}.btn-model:hover{background:#667eea;color:#fff}.action-buttons{gap:15px;margin-top:30px}.question-section{background:#fff;border-radius:20px;margin:0 auto;max-width:700px;padding:30px;text-align:center}.question-section .part-badge{display:inline-block;margin-bottom:10px;position:static}.topic-badge{background:#e8f5e9;border-radius:20px;color:#2e7d32;display:inline-block;font-size:.85rem;font-weight:500;margin-bottom:20px;padding:5px 15px}.question-card{background:#f8f9fa;border-radius:15px;padding:25px;text-align:left}.question-card h2{color:#333;font-size:1.2rem;margin-bottom:15px}.question-text{color:#444;font-size:1.1rem}.feedback-section{border-radius:20px;margin:0 auto;max-width:800px;padding:30px}.feedback-section h2{color:#333;margin-bottom:25px;text-align:center}.score-display{display:flex;justify-content:center;margin-bottom:30px}.score-circle{height:120px;width:120px}.score-circle.score-high{background:linear-gradient(135deg,#4caf50,#45a049)}.score-circle.score-medium{background:linear-gradient(135deg,#ff9800,#f57c00)}.score-circle.score-low{background:linear-gradient(135deg,#f44336,#d32f2f)}.score-value{font-size:2.5rem;font-weight:700}.score-label{font-size:.9rem;opacity:.9}.criteria-scores{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(2,1fr);margin-bottom:30px}.criteria-item{align-items:center;background:#f8f9fa;border-radius:10px;display:flex;justify-content:space-between;padding:15px}.criteria-label{color:#555;font-size:.9rem}.criteria-score{color:#667eea;font-size:1.2rem;font-weight:700}.feedback-details{margin-top:25px}.feedback-text,.model-answer,.suggestions,.transcript-section{background:#f8f9fa;border-radius:12px;margin-bottom:15px;padding:20px}.feedback-text h3,.model-answer h3,.suggestions h3,.transcript-section h3{color:#333;font-size:1rem;margin-bottom:12px}.feedback-text p,.model-answer p,.transcript-section p{color:#555;line-height:1.6}.duration{color:#888;display:block;font-size:.85rem;margin-top:10px}.suggestions ul{list-style:disc;margin:0;padding-left:20px}.suggestions li{color:#555;padding:5px 0}.model-answer-section{margin:25px 0;text-align:center}@media (max-width:768px){.criteria-scores{grid-template-columns:1fr}.action-buttons,.part-highlight{flex-direction:column}.part-highlight{gap:10px}.prep-timer .timer-value{font-size:2.5rem}}.reading-practice{background:linear-gradient(135deg,#f0fdf4,#dcfce7);font-family:DM Sans,sans-serif;min-height:100vh;padding-bottom:4rem}.reading-header{background:linear-gradient(135deg,#22c55e,#16a34a 50%,#15803d);padding:2rem 1.5rem 3rem}.reading-header .header-content{margin:0 auto;max-width:1200px}.reading-header .back-btn{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;color:#fff;cursor:pointer;font-family:inherit;margin-bottom:1rem;padding:.5rem 1rem}.reading-header .back-btn:hover{background:#fff3}.reading-header h1{color:#fff;font-size:2.5rem;margin:0 0 .5rem}.reading-header .subtitle{color:#fffc;font-size:1.1rem;margin:0}.reading-main{margin:-2rem auto 0;max-width:1400px;padding:0 1.5rem;position:relative}.passage-selection{background:#fff;border-radius:20px;box-shadow:0 4px 20px #00000014;padding:2rem}.passage-selection h2{color:#15803d;margin:0 0 .5rem;text-align:center}.passages-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.passage-card{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:2px solid #0000;border-radius:16px;cursor:pointer;padding:1.5rem;transition:all .3s ease}.passage-card:hover{border-color:#22c55e;box-shadow:0 8px 25px #22c55e33;transform:translateY(-4px)}.passage-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.question-count{color:#6b7280}.passage-card h3{color:#15803d;font-size:1.2rem;margin:0 0 .5rem}.passage-topic{color:#6b7280;font-size:.9rem;margin:0 0 1rem}.start-btn{background:#22c55e;padding:.75rem 1.5rem;width:100%}.start-btn:hover{background:#16a34a}.reading-section{background:#fff;border-radius:20px;box-shadow:0 4px 20px #00000014;overflow:hidden}.reading-toolbar{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-bottom:1px solid #d1fae5;justify-content:space-between;padding:1rem 1.5rem}.passage-info,.reading-toolbar{align-items:center;display:flex}.passage-info{gap:1rem}.passage-info h2{color:#15803d;font-size:1.25rem;margin:0}.timer-display{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;gap:.5rem;padding:.5rem 1rem}.timer-icon,.timer-value{font-size:1.25rem}.timer-value{color:#15803d;font-weight:700}.reading-content{grid-gap:0;display:grid;gap:0;grid-template-columns:1fr 1fr}@media (max-width:1024px){.reading-content{grid-template-columns:1fr}}.passage-container{border-right:1px solid #e5e7eb;max-height:70vh;overflow-y:auto;padding:1.5rem}@media (max-width:1024px){.passage-container{border-bottom:1px solid #e5e7eb;border-right:none;max-height:50vh}}.passage-container h3{color:#15803d;font-size:1.1rem;margin:0 0 1rem}.passage-text{color:#374151;line-height:1.8}.passage-text p{margin:0 0 1rem;text-align:justify}.questions-container{max-height:70vh;overflow-y:auto}@media (max-width:1024px){.questions-container{max-height:none}}.questions-container h3{color:#15803d}.question-item{background:#f9fafb;border:1px solid #e5e7eb}.question-number{background:#22c55e}.option-label{border:1px solid #e5e7eb}.option-label:hover{background:#f0fdf4;border-color:#22c55e}.tfng-options{display:flex;flex-wrap:wrap;gap:1rem}.tfng-label{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;display:flex;gap:.5rem;padding:.75rem 1rem;transition:all .2s ease}.tfng-label:hover{background:#f0fdf4;border-color:#22c55e}.tfng-text{color:#374151;font-weight:500}.fill-blank-input{border:2px solid #e5e7eb}.fill-blank-input:focus{border-color:#22c55e}.submit-section{border-top:1px solid #e5e7eb}.btn-submit{background:linear-gradient(135deg,#22c55e,#16a34a)}.btn-submit:hover:not(:disabled){box-shadow:0 6px 20px #22c55e4d}.results-section h2{color:#15803d}.score-overview{background:linear-gradient(135deg,#f0fdf4,#dcfce7)}@media (max-width:768px){.score-overview{flex-direction:column;gap:1.5rem}}.band-score,.time-taken{background:#fff;border-radius:12px;padding:1rem 2rem;text-align:center}.band-label,.time-label{color:#6b7280;display:block;font-size:.85rem;margin-bottom:.25rem}.band-value,.time-value{color:#15803d;display:block;font-size:1.5rem;font-weight:700}.results-breakdown h3{color:#15803d}.btn-primary{background:linear-gradient(135deg,#22c55e,#16a34a)}.btn-primary:hover{box-shadow:0 6px 20px #22c55e4d}.btn-secondary{border:2px solid #22c55e;color:#22c55e}.btn-secondary:hover{background:#f0fdf4}.loading-overlay{align-items:center;background:#ffffffe6;bottom:0;display:flex;flex-direction:column;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:100}.loading-spinner{border:4px solid #dcfce7;border-top-color:#22c55e}@media (max-width:768px){.reading-header h1{font-size:1.75rem}.passages-grid{grid-template-columns:1fr}.reading-toolbar{flex-direction:column;gap:1rem;text-align:center}.passage-info{flex-direction:column;gap:.5rem}.submit-section{gap:1rem}.action-buttons,.submit-section{flex-direction:column}.btn-primary,.btn-secondary{width:100%}}.test-passages{background:#f8f9fa;border-radius:10px;margin:15px 0;padding:15px}.test-passage-item{align-items:center;border-bottom:1px solid #eee;display:flex;font-size:.9rem;gap:8px;padding:8px 0}.test-passage-item:last-child{border-bottom:none}.passage-number{color:#667eea;font-weight:600}.passage-title{color:#333;flex:1 1}.passage-questions{color:#888;font-size:.85rem}.passage-tabs{background:#fff;border-radius:10px;display:flex;gap:10px;justify-content:center;margin-bottom:20px;padding:15px 20px}.passage-tab{background:#f0f0f0;border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;padding:12px 25px;transition:all .2s}.passage-tab:hover{background:#e0e0e0}.passage-tab.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.passage-results{border-top:1px solid #eee;margin-top:25px;padding-top:25px}.passage-results h3{color:#333;margin-bottom:15px}.passage-result-item{align-items:center;background:#f8f9fa;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:10px;padding:12px 15px}.pr-title{color:#555;font-size:.95rem}.pr-score{color:#667eea;font-weight:600}@media (max-width:768px){.mode-options{align-items:center;flex-direction:column}.mode-card{max-width:350px;width:100%}.passage-tabs{flex-wrap:wrap}.passage-tab{flex:1 1;min-width:100px}}.passage-card.locked{cursor:not-allowed;opacity:.7;position:relative}.passage-card.locked:before{background:#ffffff80;border-radius:12px;bottom:0;content:"";left:0;position:absolute;right:0;top:0;z-index:1}.passage-card.locked>*{position:relative;z-index:2}.passage-card .upgrade-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:20px;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px;transition:transform .2s,box-shadow .2s}.passage-card .upgrade-btn:hover{box-shadow:0 5px 15px #667eea66;transform:translateY(-2px)}.listening-practice{background:linear-gradient(135deg,#fef3c7,#fde68a);font-family:DM Sans,sans-serif;min-height:100vh;padding-bottom:4rem}.listening-header{background:linear-gradient(135deg,#f59e0b,#d97706 50%,#b45309);padding:2rem 1.5rem 3rem}.listening-header .header-content{margin:0 auto;max-width:1200px}.listening-header .back-btn{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;color:#fff;cursor:pointer;font-family:inherit;margin-bottom:1rem;padding:.5rem 1rem}.listening-header .back-btn:hover{background:#fff3}.listening-header h1{color:#fff;font-size:2.5rem;margin:0 0 .5rem}.listening-header .subtitle{color:#fffc;font-size:1.1rem;margin:0}.listening-main{margin:-2rem auto 0;max-width:1000px;padding:0 1.5rem;position:relative}.error-banner{align-items:center;background:#fef2f2;border:1px solid #fecaca;border-radius:12px;color:#dc2626;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding:1rem}.error-banner button{background:none;border:none;color:#dc2626;cursor:pointer;font-size:1.5rem}.section-selection{background:#fff;border-radius:20px;box-shadow:0 4px 20px #00000014;padding:2rem}.section-selection h2{color:#b45309;margin:0 0 .5rem;text-align:center}.selection-subtitle{color:#6b7280;margin:0 0 2rem;text-align:center}.sections-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.section-card{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #0000;border-radius:16px;cursor:pointer;padding:1.5rem;transition:all .3s ease}.section-card:hover{border-color:#f59e0b;box-shadow:0 8px 25px #f59e0b33;transform:translateY(-4px)}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.part-badge{background:#f59e0b;font-size:.8rem}.difficulty-badge{border-radius:20px;font-size:.8rem;font-weight:600;padding:.25rem .75rem}.difficulty-easy{background:#d1fae5;color:#059669}.difficulty-medium{background:#fef3c7;color:#d97706}.difficulty-hard{background:#fee2e2;color:#dc2626}.section-card h3{color:#b45309;font-size:1.2rem;margin:0 0 .5rem}.section-description{color:#6b7280;font-size:.9rem;margin:0 0 1rem}.section-footer{align-items:center;display:flex;justify-content:space-between}.question-count{color:#92400e;font-size:.85rem}.start-btn{background:#f59e0b;border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:inherit;font-weight:600;padding:.5rem 1rem;transition:background .2s ease}.start-btn:hover{background:#d97706}.listening-section{background:#fff;border-radius:20px;box-shadow:0 4px 20px #00000014;overflow:hidden}.listening-toolbar{background:linear-gradient(135deg,#fef3c7,#fde68a);border-bottom:1px solid #fde68a;padding:1.5rem}.section-info h2{color:#b45309;font-size:1.25rem;margin:0 0 .5rem}.badges{display:flex;gap:.5rem}.audio-player{background:linear-gradient(135deg,#1f2937,#111827);border-radius:16px;margin:1.5rem;padding:1.5rem}.player-content{gap:1.5rem}.player-content,.player-icon{align-items:center;display:flex}.player-icon{background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:50%;flex-shrink:0;font-size:3rem;height:80px;justify-content:center;width:80px}.player-icon.playing{animation:pulse-glow 1.5s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px #f59e0b80}50%{box-shadow:0 0 40px #f59e0bcc}}.player-info{flex:1 1}.player-info h3{color:#fff;margin:0 0 .25rem}.player-info p{color:#9ca3af;font-size:.9rem;margin:0}.player-controls{display:flex;gap:.5rem}.play-btn,.stop-btn{border:none;border-radius:30px;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s ease}.play-btn{background:linear-gradient(135deg,#f59e0b,#d97706)}.play-btn:hover{box-shadow:0 4px 15px #f59e0b66}.stop-btn{background:#ef4444;color:#fff}.stop-btn:hover{background:#dc2626}.playing-indicator{border-top:1px solid #374151;gap:.5rem;margin-top:1rem;padding-top:1rem}.wave{animation:wave .5s ease-in-out infinite;background:#f59e0b;border-radius:2px;height:20px;width:4px}.wave:nth-child(2){animation-delay:.1s}.wave:nth-child(3){animation-delay:.2s}.wave:nth-child(4){animation-delay:.3s}.wave:nth-child(5){animation-delay:.4s}@keyframes wave{0%,to{height:10px}50%{height:30px}}.playing-indicator span{color:#f59e0b;font-weight:500;margin-left:.5rem}.audio-note{color:#9ca3af;font-size:.85rem;margin:1rem 0 0;text-align:center}.questions-container{padding:1.5rem}.questions-container h3{color:#b45309;font-size:1.1rem;margin:0 0 1rem}.questions-list{display:flex;flex-direction:column;gap:1.5rem}.question-item{background:#fffbeb;border:1px solid #fde68a;border-radius:12px;padding:1.25rem}.question-number{background:#f59e0b;border-radius:20px;color:#fff;display:inline-block;font-size:.8rem;font-weight:600;margin-bottom:.75rem;padding:.25rem .75rem}.question-text{font-weight:500;margin:0 0 1rem}.options-list{display:flex;flex-direction:column;gap:.5rem}.option-label{align-items:flex-start;background:#fff;border:1px solid #fde68a;border-radius:8px;cursor:pointer;display:flex;gap:.75rem;padding:.75rem;transition:all .2s ease}.option-label:hover{background:#fef3c7;border-color:#f59e0b}.option-label input{margin-top:.25rem}.option-text{color:#374151;line-height:1.4}.fill-blank-input{border:2px solid #fde68a;border-radius:8px;font-family:inherit;font-size:1rem;padding:.75rem 1rem;transition:border-color .2s ease;width:100%}.fill-blank-input:focus{border-color:#f59e0b;outline:none}.submit-section{align-items:center;border-top:1px solid #fde68a;display:flex;justify-content:space-between;margin-top:2rem;padding-top:1.5rem}.answered-count{color:#6b7280;font-weight:500;margin:0}.btn-submit{background:linear-gradient(135deg,#f59e0b,#d97706);border:none;border-radius:12px;color:#fff;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:600;padding:1rem 2rem;transition:all .2s ease}.btn-submit:hover:not(:disabled){box-shadow:0 6px 20px #f59e0b4d;transform:translateY(-2px)}.btn-submit:disabled{cursor:not-allowed;opacity:.6}.results-section{background:#fff;border-radius:20px;box-shadow:0 4px 20px #00000014;padding:2rem}.results-section h2{color:#b45309;margin:0 0 2rem;text-align:center}.score-overview{background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:16px;gap:3rem;margin-bottom:2rem;padding:2rem}.score-circle,.score-overview{align-items:center;display:flex;justify-content:center}.score-circle{border-radius:50%;color:#fff;flex-direction:column;height:150px;width:150px}.score-circle.score-high{background:linear-gradient(135deg,#22c55e,#16a34a)}.score-circle.score-medium{background:linear-gradient(135deg,#f59e0b,#d97706)}.score-circle.score-low{background:linear-gradient(135deg,#ef4444,#dc2626)}.score-number{font-size:2rem;font-weight:700}.score-percentage{font-size:1.25rem;opacity:.9}.score-details{display:flex;flex-direction:column;gap:1rem}.band-score{border-radius:12px;padding:1rem 2rem}.band-label{color:#6b7280;display:block;font-size:.85rem;margin-bottom:.25rem}.band-value{color:#b45309;display:block;font-size:2rem;font-weight:700}.results-breakdown{margin-bottom:2rem}.results-breakdown h3{color:#b45309;margin:0 0 1rem}.result-item{border-left:4px solid;border-radius:12px;margin-bottom:1rem;padding:1.25rem}.result-item.correct{background:#f0fdf4;border-color:#22c55e}.result-item.incorrect{background:#fef2f2;border-color:#ef4444}.result-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.result-number{color:#374151;font-weight:700}.result-badge{border-radius:20px;font-size:.8rem;font-weight:600;padding:.25rem .75rem}.badge-correct{background:#d1fae5;color:#059669}.badge-incorrect{background:#fee2e2;color:#dc2626}.result-question{color:#1f2937;font-weight:500;margin:0 0 .75rem}.result-answers{margin-bottom:.75rem}.result-answers p{color:#374151;margin:.25rem 0}.result-explanation{background:#fff;border-radius:8px;color:#6b7280;font-size:.9rem;padding:.75rem 1rem}.action-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.btn-primary{background:linear-gradient(135deg,#f59e0b,#d97706);border:none;border-radius:12px;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:600;padding:1rem 2rem;transition:all .2s ease}.btn-primary:hover{box-shadow:0 6px 20px #f59e0b4d}.btn-secondary{border:2px solid #f59e0b;border-radius:12px;color:#f59e0b;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:600;padding:1rem 2rem;transition:all .2s ease}.btn-secondary:hover{background:#fef3c7}.loading-container{padding:3rem;text-align:center}.loading-spinner{border:4px solid #fde68a;border-top-color:#f59e0b}@media (max-width:768px){.listening-header h1{font-size:1.75rem}.sections-grid{grid-template-columns:1fr}.player-content{flex-direction:column;text-align:center}.player-controls{justify-content:center;width:100%}.score-overview{flex-direction:column;gap:1.5rem}.submit-section{gap:1rem}.action-buttons,.submit-section{flex-direction:column}.btn-primary,.btn-secondary{width:100%}}.mode-selection{padding:20px;text-align:center}.mode-selection h2{font-size:2rem;margin-bottom:10px}.mode-selection .selection-subtitle,.mode-selection h2{color:#fff;text-shadow:2px 2px 8px #000c,0 0 20px #00000080}.mode-selection .selection-subtitle{font-size:1.1rem;margin-bottom:40px}.mode-options{display:flex;flex-wrap:wrap;gap:30px;justify-content:center}.mode-card{background:#fff;border-radius:20px;cursor:pointer;padding:30px;position:relative;text-align:left;transition:transform .3s,box-shadow .3s;width:320px}.mode-card:hover{box-shadow:0 20px 40px #0003;transform:translateY(-10px)}.mode-card.featured{border:3px solid #667eea}.mode-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;color:#fff;font-size:.8rem;font-weight:600;padding:5px 15px;position:absolute;right:20px;top:-12px}.mode-icon{font-size:3rem;margin-bottom:15px}.mode-card h3{color:#333;font-size:1.5rem;margin-bottom:10px}.mode-time{color:#667eea;font-size:1rem;font-weight:600;margin-bottom:10px}.mode-description{color:#666;font-size:.95rem;line-height:1.5;margin-bottom:15px}.mode-features{list-style:none;margin:0 0 20px;padding:0}.mode-features li{border-bottom:1px solid #eee;color:#555;font-size:.9rem;padding:8px 0}.mode-features li:last-child{border-bottom:none}.mode-features li:before{color:#4caf50;content:"✓";font-weight:700;margin-right:10px}.mode-btn{background:#f0f0f0;border:none;border-radius:10px;color:#333;cursor:pointer;font-size:1rem;font-weight:600;padding:15px;transition:all .2s;width:100%}.mode-btn.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.mode-btn:hover{opacity:.9;transform:scale(1.02)}.fulltest-card{max-width:400px;width:100%}.test-sections{background:#f8f9fa;border-radius:10px;margin:15px 0;padding:15px}.test-section-item{align-items:center;border-bottom:1px solid #eee;display:flex;font-size:.9rem;gap:8px;padding:8px 0}.test-section-item:last-child{border-bottom:none}.section-number{color:#667eea;font-weight:600}.section-title{color:#333;flex:1 1}.section-questions{color:#888;font-size:.85rem}.section-tabs{background:#fff;border-radius:10px;display:flex;gap:10px;justify-content:center;margin-bottom:20px;padding:15px 20px}.section-tab{background:#f0f0f0;border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;padding:12px 25px;transition:all .2s}.section-tab:hover{background:#e0e0e0}.section-tab.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.section-results{border-top:1px solid #eee;margin-top:25px;padding-top:25px}.section-results h3{color:#333;margin-bottom:15px}.section-result-item{align-items:center;background:#f8f9fa;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:10px;padding:12px 15px}.sr-title{color:#555;font-size:.95rem}.sr-score{color:#667eea;font-weight:600}.audio-player{background:#fff;border-radius:15px;margin-bottom:20px;padding:25px;text-align:center}.audio-controls{margin-bottom:15px}.play-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:30px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:15px 40px;transition:all .3s}.play-btn:hover{box-shadow:0 5px 20px #667eea66;transform:scale(1.05)}.play-btn.playing{background:#ff6b6b}.played-message{color:#4caf50;font-size:1.1rem;font-weight:600}.playing-indicator{align-items:center;color:#667eea;display:flex;font-weight:500;gap:10px;justify-content:center}.playing-indicator .pulse{animation:pulse 1s infinite;background:#667eea;border-radius:50%;height:12px;width:12px}.part-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:15px;color:#fff;padding:4px 12px}@media (max-width:768px){.mode-options{align-items:center;flex-direction:column}.mode-card{max-width:350px;width:100%}.section-tabs{flex-wrap:wrap}.section-tab{flex:1 1;min-width:100px}}.completed-badge{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border-radius:20px;box-shadow:0 2px 4px #10b9814d;color:#fff;display:inline-flex;font-size:12px;font-weight:600;gap:4px;padding:4px 12px}.fulltest-card.completed,.passage-card.completed,.section-card.completed{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:2px solid #10b981;position:relative}.fulltest-card.completed:after,.passage-card.completed:after,.section-card.completed:after{border-color:#0000 #10b981 #0000 #0000;border-radius:0 12px 0 0;border-style:solid;border-width:0 40px 40px 0;content:"";height:0;position:absolute;right:0;top:0;width:0}.fulltest-card.completed:hover,.passage-card.completed:hover,.section-card.completed:hover{box-shadow:0 8px 25px #10b98140;transform:translateY(-4px)}.progress-indicator{align-items:center;color:#10b981;display:flex;font-size:14px;font-weight:500;gap:8px}.progress-indicator svg{height:16px;width:16px}.progress-bar-container{background:#e5e7eb;border-radius:10px;height:8px;margin-top:8px;overflow:hidden}.progress-bar-fill{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;height:100%;transition:width .5s ease}.completion-stats{display:flex;flex-wrap:wrap;gap:16px;margin-top:12px}.completion-stat{align-items:center;color:#6b7280;display:flex;font-size:13px;gap:6px}.completion-stat.completed{color:#10b981}@keyframes completedPulse{0%{box-shadow:0 0 0 0 #10b98166}70%{box-shadow:0 0 0 10px #10b98100}to{box-shadow:0 0 0 0 #10b98100}}.passage-card.just-completed,.section-card.just-completed{animation:completedPulse 1s ease-out}.section-card.locked{cursor:not-allowed;opacity:.7;position:relative}.section-card.locked:before{background:#ffffff80;border-radius:12px;bottom:0;content:"";left:0;position:absolute;right:0;top:0;z-index:1}.section-card.locked>*{position:relative;z-index:2}.locked-badge{border-radius:12px;font-size:.75rem;padding:4px 10px}.locked-badge,.section-card .upgrade-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:600}.section-card .upgrade-btn{border:none;border-radius:20px;cursor:pointer;padding:10px 20px;transition:transform .2s,box-shadow .2s}.section-card .upgrade-btn:hover{box-shadow:0 5px 15px #667eea66;transform:translateY(-2px)}:root{--primary:#667eea;--primary-dark:#764ba2;--background:#f8f9fa;--card-bg:#fff;--text:#1f2937;--text-light:#6b7280;--border:#e5e7eb;--success:#10b981;--error:#ef4444;--warning:#f59e0b}*{box-sizing:border-box;margin:0;padding:0}body{background:linear-gradient(135deg,#667eea,#764ba2);background:linear-gradient(135deg,var(--primary) 0,var(--primary-dark) 100%);color:#1f2937;color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.container,body{min-height:100vh}.container{display:flex;flex-direction:column;justify-content:center;margin:0 auto;max-width:500px;padding:40px 20px}.card{background:#fff;background:var(--card-bg);border-radius:20px;box-shadow:0 10px 40px #0003;padding:40px 30px}.header{color:#fff;margin-bottom:30px;text-align:center}.header h1{font-size:28px;margin-bottom:8px}.header p{font-size:16px;opacity:.9}.form-group{margin-bottom:20px}.form-group label{color:#1f2937;color:var(--text);margin-bottom:8px}.form-group input,.form-group textarea{border:2px solid #e5e7eb;border:2px solid var(--border);border-radius:12px;font-size:16px;padding:14px 16px;transition:all .3s;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#667eea;border-color:var(--primary);box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group textarea{min-height:200px;resize:vertical}.btn{border:none;border-radius:12px;cursor:pointer;font-size:16px;font-weight:600;padding:16px;transition:all .3s;width:100%}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);background:linear-gradient(135deg,var(--primary) 0,var(--primary-dark) 100%);color:#fff}.btn-primary:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.btn-primary:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-secondary{background:#fff;border:2px solid #fff;color:#667eea;color:var(--primary)}.btn-secondary:hover{background:#ffffffe6;color:#764ba2;color:var(--primary-dark)}.link{color:#667eea;color:var(--primary);font-weight:600;text-decoration:none}.link:hover{text-decoration:underline}.text-center{text-align:center}.mt-20{margin-top:20px}.error-message{background:#fef2f2;color:#ef4444;color:var(--error)}.error-message,.success-message{border-radius:8px;font-size:14px;margin-bottom:20px;padding:12px 16px}.success-message{background:#ecfdf5;color:#10b981;color:var(--success)}.loading-screen{align-items:center;color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:100vh}.spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:50px;margin-bottom:20px;width:50px}.dashboard{margin:0 auto;max-width:900px;padding:40px 20px}.dashboard-header{align-items:center;color:#fff;display:flex;justify-content:space-between;margin-bottom:30px}.dashboard-header h1{font-size:28px}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(2,1fr);margin-bottom:30px}.stat-card{background:#fff;background:var(--card-bg);border-radius:16px;box-shadow:0 4px 6px #0000001a;padding:30px;text-align:center}.stat-value{color:#667eea;color:var(--primary);font-size:36px;font-weight:700;margin-bottom:8px}.stat-label{color:#6b7280;color:var(--text-light);font-size:14px}.modules-card{background:#fff;border-radius:16px;box-shadow:0 4px 6px #0000001a;padding:30px}.modules-card h2{color:#1f2937;color:var(--text);margin-bottom:20px}.module-item{align-items:center;border:2px solid #e5e7eb;border:2px solid var(--border);border-radius:12px;cursor:pointer;display:flex;gap:16px;margin-bottom:12px;padding:20px;transition:all .3s}.module-item:hover{border-color:#667eea;border-color:var(--primary);transform:translateX(4px)}.module-item.disabled{cursor:not-allowed;opacity:.5}.module-item.disabled:hover{border-color:#e5e7eb;border-color:var(--border);transform:none}.module-icon{font-size:32px}.module-info h3{color:#1f2937;color:var(--text);margin-bottom:4px}.module-info p{color:var(--text-light);font-size:14px}.writing-container{margin:0 auto;max-width:800px;padding:40px 20px}.back-btn{align-items:center;color:#fff;display:inline-flex;font-weight:500;gap:8px;margin-bottom:20px;text-decoration:none}.back-btn:hover{opacity:.8}.question-card{background:#fff;border-radius:16px;box-shadow:0 4px 6px #0000001a;margin-bottom:20px;padding:30px}.question-label{color:#667eea;color:var(--primary);font-size:14px;font-weight:600;margin-bottom:12px}.question-text{color:#1f2937;color:var(--text);font-size:16px;line-height:1.6}.essay-card{background:#fff;border-radius:16px;box-shadow:0 4px 6px #0000001a;padding:30px}.word-count{color:#6b7280;color:var(--text-light);font-size:14px;margin-top:10px;text-align:right}.feedback-container{margin:0 auto;max-width:800px;padding:40px 20px}.band-score{background:#fff;border-radius:16px;margin-bottom:20px;padding:30px;text-align:center}.band-score .score{color:#667eea;color:var(--primary);font-size:64px;font-weight:700}.band-score .label{color:#6b7280;color:var(--text-light)}.scores-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(2,1fr);margin-bottom:20px}.score-item{background:#fff;border-radius:12px;padding:20px;text-align:center}.score-item .value{color:#667eea;color:var(--primary);font-size:24px;font-weight:700}.score-item .name{color:#6b7280;color:var(--text-light);font-size:12px;margin-top:4px}.feedback-section{background:#fff;border-radius:16px;margin-bottom:20px;padding:25px}.feedback-section h3{color:#1f2937;color:var(--text);margin-bottom:15px}.feedback-section ul{padding-left:20px}.feedback-section li{line-height:1.5;margin-bottom:8px}.rewrite-section{background:#fff;border-radius:16px;margin-top:20px;padding:25px}.rewrite-section h3{color:#1f2937;color:var(--text);margin-bottom:15px}.rewritten-essay{background:#f8f9fa;border-radius:12px;line-height:1.8;padding:20px;white-space:pre-wrap}.onboarding-container{margin:0 auto;max-width:500px;padding:40px 20px}.progress-dots{display:flex;gap:8px;justify-content:center;margin-bottom:30px}.dot{background:#ffffff4d;border-radius:50%;height:10px;width:10px}.dot.active{background:#fff;border-radius:5px;width:24px}.option-card{background:#fff;border:2px solid #e5e7eb;border:2px solid var(--border);border-radius:12px;cursor:pointer;margin-bottom:12px;padding:20px;transition:all .3s}.option-card.selected,.option-card:hover{border-color:#667eea;border-color:var(--primary)}.option-card.selected{background:#667eea0d}.option-card h3{margin-bottom:4px}.option-card p{color:#6b7280;color:var(--text-light);font-size:14px}@media (max-width:600px){.stats-grid{grid-template-columns:1fr}.scores-grid{grid-template-columns:1fr 1fr}.dashboard-header{flex-direction:column;gap:15px;text-align:center}}.forgot-link{color:#667eea;display:block;font-size:.9rem;margin:1rem 0;text-align:center;text-decoration:none}.forgot-link:hover{text-decoration:underline}.speaking-history{background:linear-gradient(135deg,#fce4ec,#f8bbd9);font-family:DM Sans,sans-serif;min-height:100vh;padding-bottom:4rem}.history-header{background:linear-gradient(135deg,#ec407a,#d81b60 50%,#ad1457);padding:2rem 1.5rem 3rem}.history-header .header-content{margin:0 auto;max-width:800px}.history-header .back-btn{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;color:#fff;cursor:pointer;font-family:inherit;margin-bottom:1rem;padding:.5rem 1rem}.history-header .back-btn:hover{background:#fff3}.history-header h1{color:#fff;font-size:2rem;margin:0 0 .5rem}.history-header .subtitle{color:#fffc;font-size:1rem;margin:0}.history-main{margin:-2rem auto 0;max-width:800px;padding:0 1.5rem}.error-container,.loading-container{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;padding:3rem;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f8bbd9;border-radius:50%;border-top-color:#ec407a;height:50px;margin:0 auto 1rem;width:50px}@keyframes spin{to{transform:rotate(1turn)}}.error-container button{background:#ec407a;border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:inherit;margin-top:1rem;padding:.75rem 1.5rem}.empty-state{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;padding:3rem;text-align:center}.empty-icon{display:block;font-size:4rem;margin-bottom:1rem}.empty-state h2{color:#ad1457;margin:0 0 .5rem}.empty-state p{color:#6b7280;margin:0 0 1.5rem}.empty-state button{background:linear-gradient(135deg,#ec407a,#d81b60);border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:inherit;font-weight:600;padding:.75rem 1.5rem}.sessions-list{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;overflow:hidden}.list-header{background:#fce4ec;border-bottom:1px solid #f8bbd9;padding:1rem 1.5rem}.total-count{color:#ad1457;font-weight:600}.session-card{border-bottom:1px solid #f3e5f5;padding:1.5rem}.session-card:last-child{border-bottom:none}.session-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.part-badge{background:#fce4ec;color:#ad1457}.band-badge,.part-badge{border-radius:20px;font-size:.85rem;font-weight:600;padding:.25rem .75rem}.band-high{background:#d1fae5;color:#059669}.band-medium{background:#fef3c7;color:#d97706}.band-low{background:#fee2e2;color:#dc2626}.session-question{color:#374151;line-height:1.5;margin-bottom:1rem}.session-meta{align-items:center;display:flex;justify-content:space-between}.date{color:#9ca3af;font-size:.85rem}.session-feedback{border-top:1px solid #f3e5f5;margin-top:1rem;padding-top:1rem}.feedback-scores{display:flex;flex-wrap:wrap;gap:1rem}.feedback-scores span{background:#fce4ec;border-radius:8px;color:#ad1457;font-size:.85rem;padding:.25rem .75rem}@media (max-width:768px){.history-header h1{font-size:1.5rem}.feedback-scores{flex-direction:column;gap:.5rem}}.reading-history{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);font-family:DM Sans,sans-serif;min-height:100vh;padding-bottom:4rem}.reading-history .history-header{background:linear-gradient(135deg,#66bb6a,#43a047 50%,#2e7d32);padding:2rem 1.5rem 3rem}.reading-history .header-content{margin:0 auto;max-width:800px}.reading-history .back-btn{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;color:#fff;cursor:pointer;font-family:inherit;margin-bottom:1rem;padding:.5rem 1rem}.reading-history .back-btn:hover{background:#fff3}.reading-history h1{color:#fff;font-size:2rem;margin:0 0 .5rem}.reading-history .subtitle{color:#fffc;font-size:1rem;margin:0}.reading-history .history-main{margin:-2rem auto 0;max-width:800px;padding:0 1.5rem}.reading-history .error-container,.reading-history .loading-container{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;padding:3rem;text-align:center}.reading-history .loading-spinner{animation:spin 1s linear infinite;border:4px solid #c8e6c9;border-radius:50%;border-top-color:#43a047;height:50px;margin:0 auto 1rem;width:50px}.reading-history .error-container button{background:#43a047;border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:inherit;margin-top:1rem;padding:.75rem 1.5rem}.reading-history .empty-state{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;padding:3rem;text-align:center}.reading-history .empty-icon{display:block;font-size:4rem;margin-bottom:1rem}.reading-history .empty-state h2{color:#2e7d32;margin:0 0 .5rem}.reading-history .empty-state p{color:#6b7280;margin:0 0 1.5rem}.reading-history .empty-state button{background:linear-gradient(135deg,#66bb6a,#43a047);border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:inherit;font-weight:600;padding:.75rem 1.5rem}.reading-history .sessions-list{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;overflow:hidden}.reading-history .list-header{background:#e8f5e9;border-bottom:1px solid #c8e6c9;padding:1rem 1.5rem}.reading-history .total-count{color:#2e7d32;font-weight:600}.reading-history .session-card{border-bottom:1px solid #e8f5e9;padding:1.5rem}.reading-history .session-card:last-child{border-bottom:none}.reading-history .session-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1rem}.reading-history .passage-title{color:#1f2937;flex:1 1;font-size:1.1rem;margin:0}.reading-history .band-badge{border-radius:20px;font-size:.85rem;font-weight:600;padding:.25rem .75rem;white-space:nowrap}.reading-history .band-high{background:#d1fae5;color:#059669}.reading-history .band-medium{background:#fef3c7;color:#d97706}.reading-history .band-low{background:#fee2e2;color:#dc2626}.reading-history .session-stats{display:flex;gap:2rem;margin-bottom:1rem}.reading-history .stat-item{align-items:center;display:flex;flex-direction:column}.reading-history .stat-value{color:#2e7d32;font-size:1.25rem;font-weight:700}.reading-history .stat-label{color:#6b7280;font-size:.8rem}.reading-history .session-meta{display:flex;justify-content:flex-end}.reading-history .date{color:#9ca3af;font-size:.85rem}@media (max-width:768px){.reading-history h1{font-size:1.5rem}.reading-history .session-header{align-items:flex-start;flex-direction:column}.reading-history .session-stats{gap:1rem}}.listening-history{background:linear-gradient(135deg,#fff8e1,#ffecb3);font-family:DM Sans,sans-serif;min-height:100vh;padding-bottom:4rem}.listening-history .history-header{background:linear-gradient(135deg,#ffa726,#fb8c00 50%,#ef6c00);padding:2rem 1.5rem 3rem}.listening-history .header-content{margin:0 auto;max-width:800px}.listening-history .back-btn{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;color:#fff;cursor:pointer;font-family:inherit;margin-bottom:1rem;padding:.5rem 1rem}.listening-history .back-btn:hover{background:#fff3}.listening-history h1{color:#fff;font-size:2rem;margin:0 0 .5rem}.listening-history .subtitle{color:#fffc;font-size:1rem;margin:0}.listening-history .history-main{margin:-2rem auto 0;max-width:800px;padding:0 1.5rem}.listening-history .error-container,.listening-history .loading-container{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;padding:3rem;text-align:center}.listening-history .loading-spinner{animation:spin 1s linear infinite;border:4px solid #ffecb3;border-radius:50%;border-top-color:#fb8c00;height:50px;margin:0 auto 1rem;width:50px}.listening-history .error-container button{background:#fb8c00;border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:inherit;margin-top:1rem;padding:.75rem 1.5rem}.listening-history .empty-state{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;padding:3rem;text-align:center}.listening-history .empty-icon{display:block;font-size:4rem;margin-bottom:1rem}.listening-history .empty-state h2{color:#ef6c00;margin:0 0 .5rem}.listening-history .empty-state p{color:#6b7280;margin:0 0 1.5rem}.listening-history .empty-state button{background:linear-gradient(135deg,#ffa726,#fb8c00);border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:inherit;font-weight:600;padding:.75rem 1.5rem}.listening-history .sessions-list{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;overflow:hidden}.listening-history .list-header{background:#fff8e1;border-bottom:1px solid #ffecb3;padding:1rem 1.5rem}.listening-history .total-count{color:#ef6c00;font-weight:600}.listening-history .session-card{border-bottom:1px solid #fff8e1;padding:1.5rem}.listening-history .session-card:last-child{border-bottom:none}.listening-history .session-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1rem}.listening-history .section-title{color:#1f2937;flex:1 1;font-size:1.1rem;margin:0}.listening-history .band-badge{border-radius:20px;font-size:.85rem;font-weight:600;padding:.25rem .75rem;white-space:nowrap}.listening-history .band-high{background:#d1fae5;color:#059669}.listening-history .band-medium{background:#fef3c7;color:#d97706}.listening-history .band-low{background:#fee2e2;color:#dc2626}.listening-history .session-stats{display:flex;gap:2rem;margin-bottom:1rem}.listening-history .stat-item{align-items:center;display:flex;flex-direction:column}.listening-history .stat-value{color:#ef6c00;font-size:1.25rem;font-weight:700}.listening-history .stat-label{color:#6b7280;font-size:.8rem}.listening-history .session-meta{display:flex;justify-content:flex-end}.listening-history .date{color:#9ca3af;font-size:.85rem}@media (max-width:768px){.listening-history h1{font-size:1.5rem}.listening-history .session-header{align-items:flex-start;flex-direction:column}.listening-history .session-stats{gap:1rem}}.practice-modules{background:linear-gradient(135deg,#667eea,#764ba2);font-family:DM Sans,sans-serif;min-height:100vh}.modules-header{padding:2rem 1.5rem 3rem}.modules-header .header-content{margin:0 auto;max-width:800px;text-align:center}.modules-header .back-btn{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;color:#fff;cursor:pointer;font-family:inherit;margin-bottom:1.5rem;padding:.5rem 1rem;transition:all .2s ease}.modules-header .back-btn:hover{background:#fff3}.modules-header h1{color:#fff;font-size:2.25rem;font-weight:700;margin:0 0 .5rem}.modules-header .subtitle{color:#ffffffd9;font-size:1.1rem;margin:0}.modules-main{margin:0 auto;max-width:800px;padding:0 1.5rem 3rem}.modules-grid{display:flex;flex-direction:column;gap:1.25rem}.module-card{align-items:center;background:#fff;border-left:5px solid var(--module-color);border-radius:20px;box-shadow:0 4px 20px #0000001a;cursor:pointer;display:flex;gap:1.5rem;padding:1.75rem;transition:all .3s ease}.module-card:hover{box-shadow:0 8px 30px #00000026;transform:translateX(8px)}.module-icon{align-items:center;background:#f8fafc;border-radius:16px;display:flex;flex-shrink:0;font-size:3rem;height:80px;justify-content:center;width:80px}.module-info{flex:1 1}.module-info h2{color:#1f2937;font-size:1.35rem;font-weight:700;margin:0 0 .5rem}.module-info p{color:#6b7280;font-size:1rem;line-height:1.5;margin:0}.module-arrow{color:var(--module-color);font-size:1.5rem;font-weight:700;opacity:0;transform:translateX(-10px);transition:all .3s ease}.module-card:hover .module-arrow{opacity:1;transform:translateX(0)}@media (max-width:768px){.modules-header h1{font-size:1.75rem}.module-card{gap:1rem;padding:1.25rem}.module-icon{font-size:2.25rem;height:60px;width:60px}.module-info h2{font-size:1.15rem}.module-info p{font-size:.9rem}.module-arrow{display:none}}.profile-settings{background:linear-gradient(135deg,#667eea,#764ba2);font-family:DM Sans,sans-serif;min-height:100vh}.settings-header{padding:2rem 1.5rem 3rem}.settings-header .header-content{margin:0 auto;max-width:600px;text-align:center}.settings-header .back-btn{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;color:#fff;cursor:pointer;font-family:inherit;margin-bottom:1.5rem;padding:.5rem 1rem;transition:all .2s ease}.settings-header .back-btn:hover{background:#fff3}.settings-header h1{color:#fff;font-size:2rem;font-weight:700;margin:0 0 .5rem}.settings-header .subtitle{color:#ffffffd9;font-size:1rem;margin:0}.settings-main{margin:-1.5rem auto 0;max-width:600px;padding:0 1.5rem 3rem}.tabs{background:#ffffff1a;border-radius:12px;display:flex;gap:.5rem;margin-bottom:1.5rem;padding:.5rem}.tab{background:#0000;border:none;border-radius:8px;color:#ffffffb3;cursor:pointer;flex:1 1;font-family:inherit;font-size:.9rem;font-weight:500;padding:.75rem 1rem;transition:all .2s ease}.tab:hover{background:#ffffff1a;color:#fff}.tab.active{background:#fff;color:#667eea}.message{font-weight:500;padding:1rem}.tab-content{background:#fff;border-radius:16px;box-shadow:0 4px 20px #0000001a;padding:2rem}.settings-form{gap:1.5rem}.form-group,.settings-form{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-group label{font-size:.95rem}.save-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:600;margin-top:.5rem;padding:1rem;transition:all .3s ease}.save-btn:hover{box-shadow:0 4px 15px #667eea66;transform:translateY(-2px)}.save-btn:disabled{cursor:not-allowed;opacity:.7;transform:none}.band-selector{display:flex;flex-wrap:wrap;gap:.5rem}.band-option{background:#f3f4f6;border:2px solid #0000;border-radius:8px;color:#374151;cursor:pointer;font-family:inherit;font-weight:600;padding:.5rem 1rem;transition:all .2s ease}.band-option:hover{background:#e5e7eb}.band-option.selected{background:#667eea;border-color:#667eea;color:#fff}.goal-selector{display:flex;flex-wrap:wrap;gap:.5rem}.goal-option{background:#f3f4f6;border:2px solid #0000;border-radius:8px;color:#374151;cursor:pointer;font-family:inherit;font-weight:500;padding:.5rem 1rem;transition:all .2s ease}.goal-option:hover{background:#e5e7eb}.goal-option.selected{background:#667eea;border-color:#667eea;color:#fff}.focus-areas{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(2,1fr)}.focus-option{align-items:center;background:#f3f4f6;border:2px solid #0000;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;font-family:inherit;gap:.5rem;padding:1rem;transition:all .2s ease}.focus-option:hover{background:#e5e7eb}.focus-option.selected{background:#ede9fe;border-color:#667eea}.focus-icon{font-size:1.5rem}.focus-label{color:#374151;font-size:.9rem;font-weight:500}.focus-option.selected .focus-label{color:#667eea}.toggle-label{align-items:center;display:flex;justify-content:space-between}.toggle{background:#e5e7eb;border-radius:14px;cursor:pointer;height:28px;position:relative;transition:all .2s ease;width:50px}.toggle.active{background:#667eea}.toggle-knob{background:#fff;border-radius:50%;box-shadow:0 2px 4px #0000001a;height:24px;left:2px;position:absolute;top:2px;transition:all .2s ease;width:24px}.toggle.active .toggle-knob{left:24px}.helper-text{color:#6b7280;margin:0}@media (max-width:768px){.settings-header h1{font-size:1.5rem}.tabs{flex-direction:column}.tab-content{padding:1.5rem}.focus-areas{grid-template-columns:1fr 1fr}.band-selector,.goal-selector{justify-content:center}}.exam-type-selector{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr;margin-top:8px}.exam-type-option{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;padding:20px 16px;text-align:center;transition:all .3s ease}.exam-type-option:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.exam-type-option.selected{background:linear-gradient(135deg,#667eea1a,#764ba21a);border-color:#667eea;box-shadow:0 4px 12px #667eea33}.exam-type-option .exam-icon{font-size:32px;margin-bottom:8px}.exam-type-option .exam-label{color:#1f2937;font-size:16px;font-weight:600;margin-bottom:4px}.exam-type-option .exam-desc{color:#6b7280;font-size:12px}.exam-type-option.selected .exam-label{color:#667eea}@media (max-width:480px){.exam-type-selector{grid-template-columns:1fr}}.forgot-password{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;font-family:DM Sans,sans-serif;justify-content:center;min-height:100vh;padding:2rem}.forgot-container{max-width:420px;width:100%}.forgot-card{background:#fff;border-radius:20px;box-shadow:0 10px 40px #0003;padding:2.5rem;text-align:center}.forgot-card h1{color:#1f2937;font-size:1.75rem;margin:0 0 .5rem}.forgot-card .subtitle{color:#6b7280;margin:0 0 1.5rem}.message{border-radius:10px;font-size:.9rem;margin-bottom:1.5rem;padding:.875rem}.message.success{background:#d1fae5;color:#059669}.message.error{background:#fee2e2;color:#dc2626}.form-group{margin-bottom:1.25rem;text-align:left}.form-group label{color:#374151;display:block;font-size:.9rem;font-weight:600;margin-bottom:.5rem}.form-group input{border:2px solid #e5e7eb;border-radius:10px;box-sizing:border-box;font-family:inherit;font-size:1rem;padding:.875rem 1rem;transition:all .2s ease;width:100%}.form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.submit-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:600;margin-bottom:1.5rem;padding:1rem;transition:all .3s ease;width:100%}.submit-btn:hover{box-shadow:0 4px 15px #667eea66;transform:translateY(-2px)}.submit-btn:disabled{cursor:not-allowed;opacity:.7;transform:none}.success-state{padding:1rem 0}.success-icon{display:block;font-size:4rem;margin-bottom:1rem}.success-state h2{color:#1f2937;margin:0 0 .5rem}.success-state p{color:#6b7280;margin:.5rem 0}.email-sent{color:#667eea!important;font-weight:600}.helper-text{font-size:.85rem;margin-top:1rem!important}.try-again-btn{background:#f3f4f6;border:none;border-radius:8px;color:#374151;cursor:pointer;font-family:inherit;font-size:.9rem;font-weight:500;margin-top:1rem;padding:.75rem 1.5rem;transition:all .2s ease}.try-again-btn:hover{background:#e5e7eb}.back-link{color:#667eea;display:inline-block;font-weight:500;margin-top:1rem;text-decoration:none}.back-link:hover{text-decoration:underline}@media (max-width:480px){.forgot-password{padding:1rem}.forgot-card{padding:2rem 1.5rem}.forgot-card h1{font-size:1.5rem}}.reset-password{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;font-family:DM Sans,sans-serif;justify-content:center;min-height:100vh;padding:2rem}.reset-container{max-width:420px;width:100%}.reset-card{background:#fff;border-radius:20px;box-shadow:0 10px 40px #0003;padding:2.5rem;text-align:center}.reset-card h1{color:#1f2937;font-size:1.75rem;margin:0 0 .5rem}.reset-card .subtitle{color:#6b7280;margin:0 0 1.5rem}.reset-card .message{border-radius:10px;font-size:.9rem;margin-bottom:1.5rem;padding:.875rem}.reset-card .message.success{background:#d1fae5;color:#059669}.reset-card .message.error{background:#fee2e2;color:#dc2626}.reset-card .form-group{margin-bottom:1.25rem;text-align:left}.reset-card .form-group label{color:#374151;display:block;font-size:.9rem;font-weight:600;margin-bottom:.5rem}.reset-card .form-group input{border:2px solid #e5e7eb;border-radius:10px;box-sizing:border-box;font-family:inherit;font-size:1rem;padding:.875rem 1rem;transition:all .2s ease;width:100%}.reset-card .form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.reset-card .submit-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:600;margin-bottom:1.5rem;padding:1rem;transition:all .3s ease;width:100%}.reset-card .submit-btn:hover{box-shadow:0 4px 15px #667eea66;transform:translateY(-2px)}.reset-card .submit-btn:disabled{cursor:not-allowed;opacity:.7;transform:none}.reset-card .success-state{padding:1rem 0}.reset-card .success-icon{display:block;font-size:4rem;margin-bottom:1rem}.reset-card .success-state h2{color:#1f2937;margin:0 0 .5rem}.reset-card .success-state p{color:#6b7280;margin:.5rem 0 1.5rem}.reset-card .login-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:600;padding:.875rem 2rem;transition:all .3s ease}.reset-card .login-btn:hover{box-shadow:0 4px 15px #667eea66;transform:translateY(-2px)}.reset-card .back-link{color:#667eea;display:inline-block;font-weight:500;margin-top:1rem;text-decoration:none}.reset-card .back-link:hover{text-decoration:underline}@media (max-width:480px){.reset-password{padding:1rem}.reset-card{padding:2rem 1.5rem}.reset-card h1{font-size:1.5rem}}.timer-warning{animation:pulse 1s infinite;background:#ff6b6b!important}.timer-warning,.timer-warning .timer-value{color:#fff!important}.timer-alert{display:block;font-size:.75rem;margin-top:2px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.upgrade-page{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:20px}.upgrade-header{padding:20px 0 40px;text-align:center}.upgrade-header .back-btn{background:#fff3;border:none;border-radius:25px;color:#fff;cursor:pointer;font-size:1rem;left:20px;padding:10px 20px;position:absolute;top:20px}.upgrade-header h1{color:#fff;font-size:2.5rem;margin-bottom:10px}.upgrade-header .subtitle{color:#ffffffe6;font-size:1.2rem}.upgrade-main{margin:0 auto;max-width:800px}.plans-container{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(2,1fr);margin-bottom:40px}.plan-card{background:#fff;border:3px solid #0000;border-radius:16px;cursor:pointer;padding:30px;position:relative;text-align:center;transition:transform .2s,box-shadow .2s}.plan-card:hover{box-shadow:0 10px 30px #0003;transform:translateY(-5px)}.plan-card.selected{border-color:#667eea;box-shadow:0 10px 30px #667eea4d}.plan-card h2{color:#333;margin-bottom:15px}.plan-card .price{margin-bottom:10px}.plan-card .amount{color:#667eea;font-size:3rem;font-weight:700}.plan-card .period{color:#666;font-size:1.2rem}.plan-card .billing-info{color:#888;font-size:.9rem}.plan-card .savings{color:#27ae60;font-weight:600;margin-top:10px}.best-value{background:linear-gradient(135deg,#f5af19,#f12711);border-radius:20px;color:#fff;font-size:.85rem;font-weight:600;left:50%;padding:5px 20px;position:absolute;top:-12px;transform:translateX(-50%)}.features-list{background:#fff;border-radius:16px;margin-bottom:30px;padding:30px}.features-list h3{color:#333;margin-bottom:20px;text-align:center}.features-list ul{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(2,1fr);list-style:none;padding:0}.features-list li{color:#555;font-size:1rem;padding:5px 0}.checkout-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:30px;color:#fff;cursor:pointer;display:block;font-size:1.2rem;font-weight:600;margin:0 auto 20px;max-width:400px;padding:18px 40px;transition:transform .2s,box-shadow .2s;width:100%}.checkout-btn:hover:not(:disabled){box-shadow:0 5px 20px #667eea66;transform:translateY(-2px)}.checkout-btn:disabled{cursor:not-allowed;opacity:.7}.guarantee{color:#fffc;font-size:.9rem;text-align:center}@media (max-width:768px){.features-list ul,.plans-container{grid-template-columns:1fr}.upgrade-header .back-btn{margin-bottom:20px;position:static}}.success-container{background:#fff;border-radius:20px;margin:50px auto;max-width:500px;padding:50px 40px;text-align:center}.success-icon{font-size:5rem;margin-bottom:20px}.success-container h1{color:#333;margin-bottom:15px}.success-container>p{color:#666;font-size:1.1rem;margin-bottom:30px}.success-features{background:#f8f9fa;border-radius:12px;margin-bottom:30px;padding:20px}.success-features p{color:#27ae60;font-size:1rem;margin:10px 0}.redirect-text{color:#888;font-size:.9rem;margin-top:15px}.landing-page{background:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;min-height:100vh}.landing-nav{align-items:center;background:#fff;box-shadow:0 2px 10px #0000000d;display:flex;justify-content:space-between;padding:20px 5%;position:-webkit-sticky;position:sticky;top:0;z-index:100}.nav-logo{color:#667eea;font-size:1.5rem;font-weight:700}.nav-buttons{display:flex;gap:15px}.nav-login{background:#0000;border:2px solid #667eea;border-radius:25px;color:#667eea;cursor:pointer;font-weight:600;padding:10px 25px;transition:all .2s}.nav-login:hover{background:#667eea;color:#fff}.nav-signup{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:25px;color:#fff;cursor:pointer;font-weight:600;padding:10px 25px;transition:transform .2s}.nav-signup:hover{transform:translateY(-2px)}.hero-section{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:space-between;min-height:80vh;padding:80px 5%}.hero-content{color:#fff;flex:1 1;max-width:600px}.hero-content h1{font-size:3rem;line-height:1.2;margin-bottom:20px}.hero-subtitle{font-size:1.25rem;line-height:1.6;margin-bottom:30px;opacity:.95}.hero-buttons{display:flex;gap:15px;margin-bottom:20px}.hero-cta-primary{background:#fff;border:none;border-radius:30px;color:#667eea;cursor:pointer;font-size:1.1rem;font-weight:600;padding:15px 35px;transition:transform .2s,box-shadow .2s}.hero-cta-primary:hover{box-shadow:0 10px 30px #0003;transform:translateY(-3px)}.hero-cta-secondary{background:#0000;border:2px solid #fff;border-radius:30px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:15px 35px;transition:all .2s}.hero-cta-secondary:hover{background:#fff;color:#667eea}.hero-note{font-size:.9rem;opacity:.9}.hero-image{display:flex;flex:1 1;justify-content:center}.hero-mockup{background:#fff;border-radius:15px;box-shadow:0 20px 60px #0000004d;overflow:hidden;padding:0;width:350px}.mockup-header{background:#f1f1f1;display:flex;gap:8px;padding:12px 15px}.mockup-dot{border-radius:50%;height:12px;width:12px}.mockup-dot.red{background:#ff5f56}.mockup-dot.yellow{background:#ffbd2e}.mockup-dot.green{background:#27c93f}.mockup-content{padding:30px;text-align:center}.mockup-score{color:#667eea;font-size:3rem;font-weight:700;margin-bottom:25px}.mockup-bars{display:flex;flex-direction:column;gap:12px}.mockup-bar{background:linear-gradient(90deg,#667eea,#764ba2);border-radius:6px;height:12px}.features-section{background:#f8f9ff;padding:100px 5%}.faq-section h2,.features-section h2,.how-it-works-section h2,.pricing-section h2,.testimonials-section h2{color:#333;font-size:2.5rem;margin-bottom:10px;text-align:center}.section-subtitle{color:#666;font-size:1.2rem;margin-bottom:50px;text-align:center}.features-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(3,1fr);margin:0 auto;max-width:1200px}.feature-card{background:#fff;border-radius:15px;box-shadow:0 5px 20px #0000000d;padding:35px;text-align:center;transition:transform .3s,box-shadow .3s}.feature-card:hover{box-shadow:0 15px 40px #0000001a;transform:translateY(-5px)}.feature-icon{display:block;font-size:3rem;margin-bottom:20px}.feature-card h3{color:#333;font-size:1.3rem;margin-bottom:15px}.feature-card p{color:#666;line-height:1.6}.how-it-works-section{background:#fff;padding:100px 5%}.steps-container{align-items:center;display:flex;flex-wrap:wrap;gap:20px;justify-content:center;margin:0 auto;max-width:1200px}.step{max-width:220px;text-align:center}.step-number{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;font-size:1.5rem;font-weight:700;height:60px;justify-content:center;margin:0 auto 20px;width:60px}.step h3{color:#333;margin-bottom:10px}.step p{color:#666;font-size:.95rem;line-height:1.5}.step-arrow{color:#667eea;font-size:2rem}.testimonials-section{background:#f8f9ff;padding:100px 5%}.testimonials-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(3,1fr);margin:0 auto;max-width:1200px}.testimonial-card{background:#fff;border-radius:15px;box-shadow:0 5px 20px #0000000d;padding:30px}.testimonial-header{align-items:center;display:flex;gap:15px;margin-bottom:20px}.testimonial-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;font-size:1.2rem;font-weight:600;height:50px;justify-content:center;width:50px}.testimonial-info{display:flex;flex:1 1;flex-direction:column}.testimonial-name{color:#333;font-weight:600}.testimonial-country{color:#888;font-size:.85rem}.testimonial-score{background:#e8f5e9;border-radius:15px;color:#27ae60;font-size:.9rem;font-weight:600;padding:5px 12px}.testimonial-text{color:#555;font-style:italic;line-height:1.6}.testimonials-placeholder{background:#fff;border-radius:20px;box-shadow:0 10px 40px #00000014;margin:0 auto;max-width:600px;padding:60px 40px;text-align:center}.placeholder-icon{font-size:4rem;margin-bottom:20px}.testimonials-placeholder h3{color:#333;font-size:1.5rem;margin-bottom:15px}.testimonials-placeholder p{color:#666;font-size:1.1rem;line-height:1.6;margin-bottom:25px}.placeholder-cta{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:30px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:15px 35px;transition:transform .2s,box-shadow .2s}.placeholder-cta:hover{box-shadow:0 10px 30px #667eea66;transform:translateY(-3px)}.pricing-section{background:#fff;padding:100px 5%}.pricing-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(2,1fr);margin:0 auto;max-width:800px}.pricing-card{background:#fff;border:2px solid #eee;border-radius:20px;padding:40px;position:relative;text-align:center;transition:transform .3s,box-shadow .3s}.pricing-card:hover{box-shadow:0 15px 40px #0000001a;transform:translateY(-5px)}.pricing-card.popular{border-color:#667eea;box-shadow:0 10px 40px #667eea33}.popular-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;color:#fff;font-size:.85rem;font-weight:600;left:50%;padding:5px 20px;position:absolute;top:-12px;transform:translateX(-50%)}.pricing-card h3{color:#333;font-size:1.5rem;margin-bottom:20px}.pricing-amount{margin-bottom:10px}.pricing-amount .price{color:#667eea;font-size:3rem;font-weight:700}.pricing-amount .period{color:#888;font-size:1.1rem}.yearly-option{color:#27ae60;font-weight:600;margin-bottom:25px}.pricing-features{list-style:none;margin:0 0 30px;padding:0;text-align:left}.pricing-features li{border-bottom:1px solid #f0f0f0;color:#555;padding:10px 0}.pricing-features li:last-child{border-bottom:none}.pricing-cta{border-radius:30px;cursor:pointer;font-size:1.1rem;font-weight:600;padding:15px 30px;transition:all .2s;width:100%}.pricing-cta.primary{background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff}.pricing-cta.primary:hover{box-shadow:0 5px 20px #667eea66;transform:translateY(-2px)}.pricing-cta.secondary{background:#fff;border:2px solid #667eea;color:#667eea}.pricing-cta.secondary:hover{background:#667eea;color:#fff}.faq-section{background:#f8f9ff;padding:100px 5%}.faq-grid{display:flex;flex-direction:column;gap:20px;margin:0 auto;max-width:800px}.faq-item{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000000d;padding:25px 30px}.faq-item h3{color:#333;font-size:1.1rem;margin-bottom:10px}.faq-item p{color:#666;line-height:1.6}.cta-section{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:100px 5%;text-align:center}.cta-section h2{color:#fff;font-size:2.5rem;margin-bottom:15px}.cta-section p{font-size:1.2rem;margin-bottom:30px;opacity:.95}.cta-button{background:#fff;border:none;border-radius:30px;color:#667eea;cursor:pointer;font-size:1.2rem;font-weight:600;padding:18px 50px;transition:transform .2s,box-shadow .2s}.cta-button:hover{box-shadow:0 10px 30px #0003;transform:translateY(-3px)}.cta-note{font-size:.95rem;margin-top:20px;opacity:.9}.landing-footer{background:#1a1a2e;color:#fff;padding:60px 5% 30px}.footer-content{display:flex;flex-wrap:wrap;gap:40px;justify-content:space-between;margin:0 auto 40px;max-width:1200px}.footer-brand h3{font-size:1.5rem;margin-bottom:10px}.footer-brand p{color:#888;max-width:300px}.footer-links{display:flex;gap:60px}.footer-column h4{color:#fff;margin-bottom:15px}.footer-column a{color:#888;cursor:pointer;display:block;margin-bottom:10px;text-decoration:none;transition:color .2s}.footer-column a:hover{color:#667eea}.footer-bottom{border-top:1px solid #333;color:#666;padding-top:30px;text-align:center}@media (max-width:968px){.hero-section{flex-direction:column;padding:60px 5%;text-align:center}.hero-content{margin-bottom:50px}.hero-content h1{font-size:2.2rem}.hero-buttons{justify-content:center}.features-grid,.testimonials-grid{grid-template-columns:repeat(2,1fr)}.steps-container{flex-direction:column}.step-arrow{transform:rotate(90deg)}.pricing-grid{grid-template-columns:1fr;max-width:400px}}@media (max-width:600px){.landing-nav{padding:15px 5%}.nav-logo{font-size:1.2rem}.nav-buttons{gap:10px}.nav-login,.nav-signup{font-size:.9rem;padding:8px 15px}.hero-content h1{font-size:1.8rem}.hero-subtitle{font-size:1rem}.hero-buttons{flex-direction:column}.hero-mockup{width:280px}.features-grid,.testimonials-grid{grid-template-columns:1fr}.cta-section h2,.faq-section h2,.features-section h2,.how-it-works-section h2,.pricing-section h2,.testimonials-section h2{font-size:1.8rem}.footer-links{flex-direction:column;gap:30px}}.legal-page{background:#f8f9ff;min-height:100vh}.legal-nav{align-items:center;background:#fff;box-shadow:0 2px 10px #0000000d;display:flex;justify-content:space-between;padding:20px 5%}.legal-nav .nav-logo{color:#667eea;cursor:pointer;font-size:1.5rem;font-weight:700}.nav-back{background:#0000;border:2px solid #667eea;border-radius:25px;color:#667eea;cursor:pointer;font-weight:600;padding:10px 20px;transition:all .2s}.nav-back:hover{background:#667eea;color:#fff}.legal-content{background:#fff;margin:0 auto;max-width:800px;min-height:calc(100vh - 200px);padding:50px 20px}.legal-content h1{color:#333;font-size:2.5rem;margin-bottom:10px;text-align:center}.last-updated{color:#888;margin-bottom:40px;text-align:center}.legal-content section{margin-bottom:35px}.legal-content h2{border-bottom:2px solid #f0f0f0;color:#667eea;font-size:1.4rem;margin-bottom:15px;padding-bottom:10px}.legal-content h3{color:#444;font-size:1.1rem;margin:20px 0 10px}.legal-content p{color:#555;line-height:1.8;margin-bottom:15px}.legal-content ul{color:#555;line-height:1.8;margin:15px 0;padding-left:25px}.legal-content li{margin-bottom:10px}.legal-content strong{color:#333}.legal-footer{background:#1a1a2e;color:#888;padding:30px;text-align:center}@media (max-width:600px){.legal-content{padding:30px 15px}.legal-content h1{font-size:1.8rem}.legal-content h2{font-size:1.2rem}}
/*# sourceMappingURL=main.6eb974a4.css.map*/