:root{--accent:#4f46e5;--accent-light:#eef2ff;--bg:#f8fafc;--bg-card:#fff;--border:#e2e8f0;--text-primary:#0f172a;--text-secondary:#64748b;--success:#22c55e;--warning:#f59e0b;--danger:#ef4444;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,system-ui,-apple-system,sans-serif}body{background:var(--bg);color:var(--text-primary);margin:0}#root{min-height:100vh}.login-page{background:var(--bg);grid-template-columns:minmax(0,1fr) minmax(420px,1fr);min-height:100vh;display:grid}.login-brand-panel{background:linear-gradient(135deg,#4f46e5 0%,#2563eb 55%,#0f766e 100%);flex-direction:column;justify-content:center;gap:28px;padding:64px;display:flex}.login-brand-name{color:#fff;font-size:48px;font-weight:700;line-height:1.1}.login-brand-title{color:#fff;font-size:36px;font-weight:700;line-height:1.15}.login-brand-description{color:#ffffffd1;max-width:420px;font-size:16px;line-height:1.8}.login-feature-list{flex-direction:column;gap:16px;margin-top:16px;display:flex}.login-feature-item{align-items:center;gap:12px;display:flex}.login-feature-dot{background:#fff;border-radius:50%;flex-shrink:0;width:8px;height:8px}.login-feature-title{color:#fff;font-size:14px;font-weight:600}.login-feature-desc{color:#ffffffb8;font-size:12px;line-height:1.5}.login-form-panel{place-items:center;min-width:0;padding:32px;display:grid}.login-card{border:1px solid var(--border);background:#fff;border-radius:16px;width:min(100%,380px);padding:40px;box-shadow:0 4px 24px #0f172a0f}.login-card-title{color:var(--text-primary);margin-bottom:4px;font-size:24px;font-weight:700}.login-card-subtitle{color:var(--text-secondary);margin-bottom:28px;font-size:14px}.login-activate-row{border-top:1px solid var(--border);text-align:center;padding-top:16px}.app-layout--student .app-content{padding:0!important}.student-list-page{padding:32px}.student-bottom-nav{display:none}.student-test-page{width:100%}.fixed-reading-panel{flex-direction:column;width:100%;min-height:0;display:flex}.fixed-reading-text-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;min-height:160px;margin-bottom:16px;padding:16px}.reading-scroll-box{width:100%}.reading-text-flow{letter-spacing:0;text-align:justify;padding:12px 2px;font-family:Inter,-apple-system,sans-serif;font-size:24px;line-height:1.9}.reading-sentence{transition:opacity .18s;display:inline}.reading-sentence--active{opacity:1}.reading-word{color:#374151;border-bottom:3px solid #0000;border-radius:4px;margin:0 1px;padding:1px 3px;font-weight:500;transition:color .2s,background-color .2s,box-shadow .2s,transform .2s,border-color .2s}.reading-word--filled{color:#4338ca;background-color:#e0e7ff;border-bottom-color:#a5b4fc}.reading-word--current{color:#fff;z-index:10;background-color:#3b82f6;border-bottom-color:#0000;border-radius:4px;animation:1.2s ease-in-out infinite word-pulse;position:relative;transform:scale(1.1);box-shadow:0 4px 6px #3b82f64d}@keyframes word-pulse{0%,to{transform:scale(1.08);box-shadow:0 2px 4px #3b82f633}50%{transform:scale(1.15);box-shadow:0 6px 12px #3b82f666}}.fixed-reading-timer{text-align:center;margin-bottom:12px}.fixed-reading-time{color:#0f172a;font-family:Inter,sans-serif;font-size:34px;font-weight:700;line-height:1}.fixed-reading-max-time{color:#64748b;margin-top:4px;font-family:Inter,sans-serif;font-size:12px}.fixed-reading-waveform{background:#f1f5f9;border-radius:12px;justify-content:center;align-items:center;gap:2px;width:100%;height:56px;margin-bottom:14px;display:flex;overflow:hidden}.fixed-reading-control{flex-direction:column;align-items:center;gap:8px;display:flex}.fixed-reading-control span{color:#64748b;font-family:Inter,sans-serif;font-size:12px}.fixed-reading-record-button{cursor:pointer;background:#4f46e5;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;transition:transform .15s;display:flex;box-shadow:0 4px 16px #4f46e54d}.fixed-reading-record-button--stop{background:#ef4444;animation:1.5s infinite pulse-rec;box-shadow:0 4px 16px #ef44444d}@keyframes pulse-rec{0%{transform:scale(1);box-shadow:0 0 #ef444480}70%{transform:scale(1.05);box-shadow:0 0 0 16px #ef444400}to{transform:scale(1);box-shadow:0 0 #ef444400}}.fixed-reading-uploading{text-align:center;color:#64748b;font-family:Inter,sans-serif;font-size:14px;animation:2s ease-in-out infinite alternate statusPulse}.live-transcript-box{-webkit-backdrop-filter:blur(8px);text-align:left;background:#ffffffd9;border:1px solid #e2e8f0;border-radius:14px;margin:0 0 20px;padding:16px 20px;animation:.3s ease-out fadeIn;box-shadow:0 4px 12px #0000000a}.live-transcript-label{color:#4f46e5;text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:6px;margin-bottom:8px;font-size:11px;font-weight:600;display:flex}.live-transcript-label:before{content:"";background:#22c55e;border-radius:50%;width:6px;height:6px;animation:1.5s infinite pulse-dot;display:inline-block}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.3}}.live-transcript-text{color:#1e293b;word-break:break-word;font-family:Inter,-apple-system,sans-serif;font-size:15px;line-height:1.7}.open-recording-panel{text-align:center;width:100%}.open-recording-alert{text-align:left;margin-bottom:16px}.open-recording-timer{margin-bottom:20px}.open-recording-time{color:#0f172a;font-size:36px;font-weight:700;line-height:1}.open-recording-max-time{color:#64748b;margin-top:4px;font-size:12px}.open-recording-waveform{background:#f1f5f9;border-radius:12px;justify-content:center;align-items:center;width:100%;height:64px;margin-bottom:20px;display:flex;overflow:hidden}.open-recording-control,.open-recording-review{flex-direction:column;align-items:center;gap:8px;display:flex}.open-recording-control span{color:#64748b;font-size:12px}.open-recording-button{cursor:pointer;-webkit-tap-highlight-color:transparent;background:#4f46e5;border:0;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;transition:transform .15s,opacity .15s;display:inline-flex;box-shadow:0 4px 16px #4f46e54d}.open-recording-button:disabled{cursor:wait;opacity:.7}.open-recording-button--stop{background:#ef4444;box-shadow:0 4px 16px #ef44444d}.open-recording-review{gap:16px}.open-recording-review audio{width:100%}.open-recording-actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.open-recording-uploading-card{border:1px solid var(--border);-webkit-backdrop-filter:blur(12px);background:#ffffffd9;border-radius:20px;flex-direction:column;align-items:center;gap:20px;max-width:480px;margin:24px auto;padding:32px 24px;animation:.4s ease-out fadeIn;display:flex;box-shadow:0 10px 30px #4f46e514}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.open-recording-loading-spinner{justify-content:center;align-items:center;width:80px;height:80px;margin-bottom:8px;display:flex;position:relative}.pulse-ring{background:#4f46e526;border-radius:50%;width:100%;height:100%;animation:2.4s cubic-bezier(.215,.61,.355,1) infinite pulseOuter;position:absolute}.ring-2{animation-delay:.8s}.ring-3{animation-delay:1.6s}@keyframes pulseOuter{0%{opacity:.8;transform:scale(.6)}50%{opacity:.4}to{opacity:0;transform:scale(1.4)}}.spinner-core{background:linear-gradient(135deg, var(--accent) 0%, #2563eb 100%);border-radius:50%;width:40px;height:40px;animation:2s ease-in-out infinite alternate floatCore;box-shadow:0 4px 12px #4f46e54d}@keyframes floatCore{0%{transform:translateY(-2px)scale(.95)}to{transform:translateY(2px)scale(1.05)}}.open-recording-uploading-status{color:var(--text-primary);text-align:center;min-height:24px;font-size:15px;font-weight:600;line-height:1.6;transition:all .3s;animation:2s ease-in-out infinite alternate statusPulse}@keyframes statusPulse{0%{opacity:.85}to{opacity:1}}.open-recording-progress-bar{background:#f1f5f9;border-radius:10px;width:80%;height:6px;overflow:hidden}.open-recording-progress-fill{background:linear-gradient(90deg, var(--accent) 0%, #2563eb 100%);border-radius:10px;width:10%;height:100%;transition:width .8s cubic-bezier(.4,0,.2,1)}.open-recording-progress-fill.step-waiting{width:20%}.open-recording-progress-fill.step-azure_speech{width:45%}.open-recording-progress-fill.step-vocab_matching{width:70%}.open-recording-progress-fill.step-llm_evaluation{width:90%}.assessment-result{background:#fff;border:1px solid #d9d9d9;border-radius:8px;flex-direction:column;gap:0;width:100%;max-width:100%;display:flex;overflow:hidden}.assessment-player{background:#fff;border-bottom:1px solid #e5e5e5;padding:20px}.assessment-audio{width:100%}.assessment-script-panel{background:#fff;border-bottom:1px solid #e5e5e5;min-height:120px;padding:20px 16px}.assessment-script-text{color:#111;flex-wrap:wrap;align-content:flex-start;gap:6px 4px;font-size:15px;line-height:1.7;display:flex}.assessment-script-inline{white-space:pre-wrap;word-wrap:break-word;color:#111;letter-spacing:.01em;text-align:justify;font-family:Inter,-apple-system,sans-serif;font-size:14px;line-height:1.9}.assessment-script-word{cursor:pointer;-webkit-user-select:none;user-select:none;border:1px solid #0000;border-radius:5px;padding:1px 4px;font-family:Inter,-apple-system,sans-serif;font-size:13px;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-block}.assessment-script-word:hover{transform:translateY(-1.5px);box-shadow:0 4px 12px #0f172a14}.assessment-script-word--high{color:#047857;background-color:#d1fae5;border-bottom:3px solid #10b981}.assessment-script-word--medium{color:#b45309;background-color:#fef3c7;border-bottom:3px solid #f59e0b}.assessment-script-word--low,.assessment-script-word--mispronounced,.assessment-script-word--replaced,.assessment-script-word--inserted{color:#b91c1c;background-color:#fee2e2;border-bottom:3px solid #ef4444;-webkit-text-decoration:line-through #ef4444;text-decoration:line-through #ef4444}.assessment-script-word--omitted{color:#b91c1c;opacity:.6;background-color:#fee2e2;border-bottom:3px solid #ef4444;text-decoration:line-through}.assessment-script-word--missing{color:#9ca3af;opacity:.5;border-bottom:2px dotted #d1d5db}.assessment-score-panel{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;grid-template-columns:120px minmax(0,1fr);gap:16px;margin-top:12px;padding:16px;display:grid}.assessment-score-overview{flex-direction:column;align-items:center;min-width:0;display:flex}.assessment-score-title{color:#334155;text-align:center;margin-bottom:8px;font-size:13px;font-weight:600}.assessment-primary-ring{box-sizing:border-box;border-radius:50%;place-items:center;width:86px;height:86px;padding:6px;display:grid}.assessment-primary-ring>div{text-align:center;background:#fff;border-radius:50%;place-items:center;width:100%;height:100%;display:grid;box-shadow:inset 0 0 0 1px #e2e8f0}.assessment-primary-ring strong{color:#0f172a;font-size:26px;font-weight:700;line-height:1;display:block}.assessment-score-details{min-width:0}.assessment-score-bars{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px 24px;display:grid}.assessment-score-bar-row{min-width:0}.assessment-score-bar-head{color:#475569;justify-content:space-between;gap:8px;margin-bottom:4px;font-size:12px;display:flex}.assessment-score-bar-head strong{white-space:nowrap;font-weight:600}.assessment-score-bar-track{background:#e2e8f0;border-radius:4px;height:8px;overflow:hidden}.assessment-score-bar-track i{border-radius:5px;height:100%;display:block}.assessment-band-legend{color:#475569;flex-wrap:wrap;grid-column:1/-1;gap:16px;margin-top:16px;font-size:13px;display:flex}.assessment-band-legend span{align-items:center;gap:6px;display:inline-flex}.assessment-band-legend i{border-radius:3px;width:12px;height:12px}.assessment-panel{background:#fff;border:1px solid #e1dfdd;border-radius:8px;padding:14px}.assessment-panel-title{color:#111827;margin-bottom:10px;font-size:13px;font-weight:700}.assessment-word-cloud{flex-wrap:wrap;gap:5px;font-size:13px;line-height:1.6;display:flex}.assessment-word-chip{border-radius:4px;padding:1px 5px;font-weight:600}.assessment-legend{color:#605e5c;flex-wrap:wrap;gap:10px;margin-top:12px;font-size:11px;display:flex}.assessment-legend span{align-items:center;gap:4px;display:inline-flex}.assessment-legend i{border-radius:2px;width:9px;height:9px}.assessment-transcript{color:#374151;margin:0;font-size:14px;line-height:1.8}.assessment-actions{text-align:center}@media (width<=820px){.login-page{flex-direction:column;min-height:100svh;display:flex}.login-brand-panel{flex:none;gap:8px;padding:28px 22px 22px}.login-brand-name{font-size:30px}.login-brand-title{font-size:22px}.login-brand-description{max-width:none;font-size:13px;line-height:1.6}.login-feature-list{display:none}.login-form-panel{padding:18px 16px calc(18px + env(safe-area-inset-bottom));flex:1;align-items:start}.login-card{box-sizing:border-box;border-radius:14px;width:100%;padding:24px 18px}.login-card-title{font-size:22px}.login-card-subtitle{margin-bottom:20px}.app-layout--student-assessment{min-height:100svh!important}.app-layout--student .app-sidebar{display:none!important}.app-layout--student .app-header{height:52px!important;padding:0 16px!important}.app-layout--student .app-content{padding:0 0 calc(76px + env(safe-area-inset-bottom))!important}.app-layout--student-assessment .app-header{display:none!important}.app-layout--student-assessment .app-content{padding:0!important}.student-bottom-nav{z-index:50;padding:8px 14px calc(8px + env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff5;border-top:1px solid #e2e8f0;grid-template-columns:repeat(2,1fr);gap:6px;display:grid;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -8px 24px #0f172a14}.student-bottom-nav button{color:#64748b;background:0 0;border:0;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:2px;min-width:0;height:48px;display:flex}.student-bottom-nav button.active{color:#4f46e5;background:#eef2ff}.student-bottom-nav strong{font-size:11px;line-height:1.2}.student-list-page{padding:16px}.student-list-page h2{margin:0 0 14px;font-size:20px}.student-test-page{max-width:none!important;min-height:100svh!important}.student-test-nav{z-index:5;position:sticky;top:0;height:48px!important;padding:0 14px!important}.student-test-content{gap:8px!important;padding:8px!important}.student-test-question-card{border-radius:12px!important;gap:6px!important;padding:10px!important}.student-test-question-card>div:first-child{font-size:16px!important;line-height:1.3!important}.student-test-question-card>div:nth-child(2){flex-wrap:wrap!important;gap:8px!important}.fixed-reading-session-card{border-radius:12px!important;padding:8px!important}.fixed-reading-text-card{min-height:0;margin-bottom:8px;padding:8px}.reading-text-flow{padding:8px 2px;font-size:20px;line-height:1.72}.fixed-reading-timer{margin-bottom:6px}.fixed-reading-time{font-size:26px}.fixed-reading-waveform{height:38px;margin-bottom:8px}.fixed-reading-control{gap:4px}.fixed-reading-record-button{width:62px;height:62px}.ielts-topic-card,.ielts-recording-card{border-radius:12px!important;gap:10px!important;padding:12px!important}.ielts-topic-card{-webkit-overflow-scrolling:touch;max-height:clamp(180px,32svh,260px);overflow-y:auto}.ielts-topic-card .ant-typography{font-size:14px!important;line-height:1.7!important}.open-recording-timer{margin-bottom:10px}.open-recording-time{font-size:28px}.open-recording-waveform{height:42px;margin-bottom:12px}.open-recording-button{width:64px;height:64px}.open-recording-actions{width:100%}.open-recording-actions .ant-btn{flex:1;min-width:120px}.assessment-script-panel{min-height:220px;padding:24px 18px}.assessment-script-text{gap:7px 4px;font-size:16px;line-height:1.7}.assessment-script-inline{font-size:15px;line-height:1.9}.assessment-script-word{text-underline-offset:8px}.assessment-score-panel{grid-template-columns:1fr;gap:22px;padding:22px 18px 28px}.assessment-primary-ring{width:150px;height:150px;margin:0 auto}.assessment-primary-ring strong{font-size:54px}.assessment-score-title{margin-bottom:16px;font-size:20px}.assessment-score-bars{grid-template-columns:1fr;gap:20px}.assessment-score-bar-head{font-size:17px}.assessment-score-bar-track{height:16px}.assessment-band-legend{gap:14px;font-size:15px}.assessment-band-legend i{width:18px;height:18px}.assessment-word-cloud{font-size:15px}}@keyframes recordingPulse{0%{box-shadow:0 0 #ef444499}70%{box-shadow:0 0 0 16px #ef444400}to{box-shadow:0 0 #ef444400}}.fixed-reading-record-button--stop,.open-recording-button--stop{background:#ef4444!important;animation:1.6s infinite recordingPulse!important}@media (width<=820px){.assessment-script-word{-webkit-tap-highlight-color:transparent;margin:1.5px .5px!important;padding:2.5px 6px!important;font-size:16px!important}.assessment-word-chip{-webkit-tap-highlight-color:transparent;margin:2px!important;padding:4px 10px!important}.fixed-reading-record-button,.open-recording-button{-webkit-tap-highlight-color:transparent;transition:transform .1s!important}.fixed-reading-record-button:active,.open-recording-button:active{transform:scale(.95)!important}}.student-mobile-shell{background:#f8fafc;flex-direction:column;max-width:480px;min-height:100vh;margin:0 auto;display:flex;position:relative;box-shadow:0 0 40px #0f172a0a}.student-mobile-header{z-index:100;-webkit-backdrop-filter:blur(20px);background:#ffffffd9;border-bottom:1px solid #e2e8f0cc;justify-content:space-between;align-items:center;height:60px;padding:0 20px;display:flex;position:sticky;top:0}.student-mobile-header h1{color:#0f172a;letter-spacing:-.02em;margin:0;font-size:18px;font-weight:700}.student-filter-tabs{white-space:nowrap;gap:8px;padding:16px 20px 8px;display:flex;overflow-x:auto}.student-filter-tabs::-webkit-scrollbar{display:none}.student-filter-tab{color:#64748b;cursor:pointer;background:#f1f5f9;border:none;border-radius:20px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1)}.student-filter-tab:hover{color:#475569;background:#e2e8f0}.student-filter-tab.active{color:#fff;background:#4f46e5;box-shadow:0 4px 12px #4f46e533}.student-card-list{padding:12px 20px calc(80px + env(safe-area-inset-bottom));flex-direction:column;gap:16px;display:flex}.student-mobile-card{background:#fff;border:1px solid #e2e8f0b3;border-radius:20px;flex-direction:column;padding:20px;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden;box-shadow:0 4px 20px #0f172a05}.student-mobile-card:hover{border-color:#4f46e533;transform:translateY(-2px);box-shadow:0 10px 25px #4f46e50d,0 1px 3px #00000003}.card-header-row{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px;display:flex}.card-title{color:#0f172a;letter-spacing:-.01em;margin:0;font-size:17px;font-weight:700;line-height:1.35}.card-meta-row{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px;display:flex}.modern-pill{border-radius:30px;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.modern-pill--type{color:#4f46e5;background:#eef2ff}.modern-pill--attempt{color:#475569;background:#f1f5f9}.modern-pill--score{color:#059669;background:#ecfdf5;font-size:12px;font-weight:700}.card-deadline{color:#64748b;align-items:center;gap:4px;font-size:12px;display:flex}.card-deadline.close{color:#ef4444;font-weight:600}.card-actions-row{border-top:1px solid #f1f5f9;gap:10px;margin-top:auto;padding-top:14px;display:flex}.btn-mobile-primary{color:#fff;cursor:pointer;background:#4f46e5;border:none;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:6px;height:40px;font-size:13px;font-weight:700;transition:all .2s;display:inline-flex;box-shadow:0 4px 12px #4f46e526}.btn-mobile-primary:hover{background:#4338ca;transform:translateY(-1px);box-shadow:0 6px 16px #4f46e540}.btn-mobile-primary:active{transform:translateY(0)}.btn-mobile-secondary{color:#4f46e5;cursor:pointer;background:#fff;border:1px solid #4f46e540;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:6px;height:40px;font-size:13px;font-weight:700;transition:all .2s;display:inline-flex}.btn-mobile-secondary:hover{background:#eef2ff;border-color:#4f46e5}.btn-mobile-disabled{color:#94a3b8;cursor:not-allowed;background:#f1f5f9;border:none;border-radius:12px;flex:1;justify-content:center;align-items:center;height:40px;font-size:13px;font-weight:600;display:inline-flex}.card-score-wrapper{background:#f8fafc;border:1px solid #eef2ff;border-radius:16px;justify-content:space-between;align-items:center;margin-bottom:16px;padding:12px 16px;display:flex}.card-score-item{flex-direction:column;display:flex}.card-score-item span{color:#64748b;margin-bottom:2px;font-size:11px;font-weight:500}.card-score-item strong{color:#0f172a;font-size:16px;font-weight:700}.card-score-badge{color:#059669;background:#ecfdf5;border:2px solid #a7f3d0;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:15px;font-weight:800;display:flex}.card-score-badge--low{color:#dc2626;background:#fef2f2;border-color:#fca5a5}.card-score-badge--medium{color:#d97706;background:#fffbeb;border-color:#fcd34d}.student-bottom-nav{z-index:200!important;padding:10px 24px calc(10px + env(safe-area-inset-bottom))!important;-webkit-backdrop-filter:blur(24px)!important;background:#ffffffd1!important;border-top:1px solid #e2e8f0cc!important;grid-template-columns:repeat(2,1fr)!important;gap:12px!important;display:grid!important;position:fixed!important;bottom:0!important;left:0!important;right:0!important;box-shadow:0 -10px 30px #0f172a0f!important}.student-bottom-nav button{color:#64748b!important;cursor:pointer!important;background:0 0!important;border:0!important;border-radius:14px!important;flex-direction:column!important;justify-content:center!important;align-items:center!important;gap:3px!important;min-width:0!important;height:48px!important;transition:all .2s cubic-bezier(.4,0,.2,1)!important;display:flex!important}.student-bottom-nav button:hover{color:#475569!important;background:#f1f5f999!important}.student-bottom-nav button.active{transform:translateY(-1px);color:#4f46e5!important;background:#eef2ff!important}.student-bottom-nav strong{letter-spacing:-.01em!important;font-size:11px!important;font-weight:700!important;line-height:1.2!important}.student-bottom-nav button span{font-size:18px!important}.pulsing-record-btn{animation:2s infinite accentPulse;box-shadow:0 0 #4f46e566}@keyframes accentPulse{0%{box-shadow:0 0 #4f46e566}70%{box-shadow:0 0 0 12px #4f46e500}to{box-shadow:0 0 #4f46e500}}.premium-report,.premium-report *,.assessment-result,.assessment-result *{box-sizing:border-box}.premium-report{background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;max-width:100%;font-family:Inter,-apple-system,sans-serif;overflow:hidden;box-shadow:0 10px 30px #0f172a0a}.premium-header{color:#fff;background:linear-gradient(135deg,#1e1b4b 0%,#312e81 40%,#0f766e 100%);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:24px;padding:32px 40px;display:flex}.premium-header-left{flex:1;min-width:280px}.premium-header-title{color:#fff;letter-spacing:-.02em;align-items:center;gap:10px;margin-bottom:8px;font-size:26px;font-weight:800;display:flex}.premium-header-subtitle{color:#fffc;font-size:14px;line-height:1.6}.premium-band-badge{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff14;border:1px solid #fff3;border-radius:20px;align-items:center;gap:20px;padding:16px 28px;display:flex;box-shadow:0 8px 32px #00000026}.premium-band-circle{background:radial-gradient(circle,#f59e0b 0%,#d97706 100%);border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:80px;height:80px;display:flex;box-shadow:0 4px 14px #d9770666}.premium-band-circle.high-band{background:radial-gradient(circle,#10b981 0%,#059669 100%);box-shadow:0 4px 14px #05966966}.premium-band-num{color:#fff;font-size:34px;font-weight:900;line-height:1}.premium-band-label{color:#ffffffe6;letter-spacing:.05em;text-transform:uppercase;font-size:10px;font-weight:700}.premium-band-info{flex-direction:column;gap:4px;display:flex}.premium-band-range{color:#ffffffb3;font-size:13px}.premium-band-desc{color:#fff;font-size:15px;font-weight:600}.premium-content{flex-direction:column;gap:32px;padding:32px;display:flex}.premium-criteria-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px;display:grid}.premium-criterion-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;flex-direction:column;justify-content:space-between;padding:24px;transition:all .25s;display:flex;box-shadow:0 4px 16px #0f172a05}.premium-criterion-card:hover{border-color:#cbd5e1;transform:translateY(-2px);box-shadow:0 8px 24px #0f172a0d}.premium-criterion-head{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.premium-criterion-title{color:#1e293b;align-items:center;gap:8px;font-size:16px;font-weight:700;display:flex}.premium-criterion-band{color:#fff;border-radius:8px;padding:4px 12px;font-size:14px;font-weight:800;box-shadow:0 2px 6px #0000000d}.premium-criterion-desc{color:#475569;word-break:break-word;overflow-wrap:anywhere;flex-grow:1;margin-bottom:16px;font-size:14px;line-height:1.7}.premium-criterion-bullets{background:#f8fafc;border:1px solid #f1f5f9;border-radius:12px;flex-direction:column;gap:8px;padding:14px 16px;display:flex}.premium-bullet-item{color:#475569;align-items:flex-start;gap:8px;font-size:13px;line-height:1.5;display:flex}.premium-bullet-icon{flex-shrink:0;margin-top:2px}.premium-section-title{color:#1e293b;align-items:center;gap:8px;margin-bottom:16px;font-size:18px;font-weight:700;display:flex}.target-hits-panel{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:24px;box-shadow:0 4px 16px #0f172a05}.target-hits-grid{grid-template-columns:1fr 1fr;gap:24px;display:grid}.premium-feedback-grid{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px;display:grid}@media (width<=768px){.premium-criteria-grid{grid-template-columns:1fr}.premium-report{border-radius:12px;overflow:hidden}.premium-header{flex-direction:column;align-items:flex-start;gap:16px;padding:20px 16px}.premium-header-left{width:100%;min-width:0}.premium-header-title{flex-wrap:wrap;font-size:18px}.premium-header-subtitle{font-size:13px;line-height:1.5}.premium-band-badge{box-sizing:border-box;gap:14px;width:100%;padding:12px 16px}.premium-band-circle{flex-shrink:0;width:56px;height:56px}.premium-band-num{font-size:22px}.premium-band-desc{font-size:13px}.premium-band-range{font-size:12px}.premium-content{gap:16px;padding:12px}.premium-criterion-card{padding:14px}.premium-criterion-title{flex-wrap:wrap;font-size:14px}.premium-criterion-band{flex-shrink:0;padding:3px 10px;font-size:12px}.premium-criterion-desc{word-break:break-word;overflow-wrap:anywhere;-webkit-hyphens:auto;hyphens:auto;font-size:13px;line-height:1.6}.premium-criterion-bullets{padding:10px 12px}.premium-bullet-item{word-break:break-word;overflow-wrap:anywhere;font-size:12px}.premium-section-title{font-size:16px}.target-hits-grid{grid-template-columns:1fr}.premium-feedback-grid{grid-template-columns:1fr;gap:16px}.improved-answer-box,.grammar-board{padding:14px}.grammar-error-card{padding:12px}.assessment-score-panel{grid-template-columns:1fr;gap:12px;padding:14px}.assessment-score-bars{grid-template-columns:1fr;gap:10px}.assessment-script-panel{min-height:80px;padding:16px 12px}.assessment-script-inline{font-size:13px;line-height:1.8}.assessment-script-word{padding:1px 3px;font-size:12px}}.target-hit-column{background:#f8fafc;border:1px solid #f1f5f9;border-radius:12px;padding:16px}.target-hit-column-title{color:#475569;align-items:center;gap:6px;margin-bottom:12px;font-size:14px;font-weight:700;display:flex}.target-tag-container{flex-wrap:wrap;gap:8px;display:flex}.target-tag{border-radius:8px;align-items:center;gap:6px;padding:5px 12px;font-size:13px;font-weight:600;transition:all .2s;display:inline-flex}.target-tag.hit{color:#16a34a;background:#effaf2;border:1px solid #bbf7d0;box-shadow:0 2px 6px #16a34a0d}.target-tag.miss{color:#94a3b8;background:#fff;border:1px dashed #cbd5e1}.grammar-board{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:24px;box-shadow:0 4px 16px #0f172a05}.grammar-error-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;gap:12px;margin-bottom:16px;padding:18px;display:flex}.grammar-error-card:last-child{margin-bottom:0}.grammar-error-row{align-items:flex-start;gap:10px;font-size:14px;line-height:1.6;display:flex}.grammar-error-tag{text-transform:uppercase;border-radius:6px;flex-shrink:0;padding:2px 8px;font-size:11px;font-weight:700}.grammar-error-original{color:#991b1b;background:#fee2e2;border-left:4px solid #ef4444;border-radius:4px;flex-grow:1;padding:8px 12px}.grammar-error-correction{color:#166534;background:#dcfce7;border-left:4px solid #22c55e;border-radius:4px;flex-grow:1;padding:8px 12px}.grammar-error-explanation{color:#64748b;border-left:2px solid #cbd5e1;margin-top:4px;padding-left:8px;font-size:13px}.improved-answer-box{background:linear-gradient(135deg,#faf5ff 0%,#f5f3ff 100%);border:1px solid #e9d5ff;border-radius:16px;padding:28px;box-shadow:0 4px 18px #8b5cf605}.improved-answer-text{color:#4b5563;white-space:pre-wrap;letter-spacing:.01em;font-family:Georgia,serif;font-size:16px;line-height:1.95}.premium-bottom-bar{-webkit-backdrop-filter:blur(12px);z-index:100;background:#fffffffa;border-top:1px solid #e2e8f0cc;border-top-left-radius:20px;border-top-right-radius:20px;flex-direction:column;justify-content:flex-end;width:100%;max-width:430px;padding:12px 24px 20px;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%);box-shadow:0 -8px 32px #0f172a14}.bottom-bar-waveform{width:100%;height:40px;margin-bottom:12px}.bottom-bar-controls{justify-content:space-between;align-items:center;width:100%;height:48px;display:flex;position:relative}.bottom-bar-mic-btn{color:#fff;cursor:pointer;z-index:10;background:linear-gradient(135deg,#4f46e5 0%,#6366f1 100%);border:none;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;font-size:24px;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;position:absolute;top:-24px;left:50%;transform:translate(-50%);box-shadow:0 8px 24px #4f46e559}.bottom-bar-mic-btn:hover{transform:translate(-50%)scale(1.05);box-shadow:0 10px 28px #4f46e573}.bottom-bar-mic-btn:active{transform:translate(-50%)scale(.95)}.bottom-bar-mic-btn.recording{background:#ef4444;animation:1.5s infinite pulse-red-mic;box-shadow:0 8px 24px #ef444459}@keyframes pulse-red-mic{0%{transform:translate(-50%)scale(1);box-shadow:0 0 #ef444499}70%{transform:translate(-50%)scale(1.1);box-shadow:0 0 0 18px #ef444400}to{transform:translate(-50%)scale(1);box-shadow:0 0 #ef444400}}.bottom-bar-status{color:#64748b;text-overflow:ellipsis;white-space:nowrap;max-width:150px;font-size:13px;font-weight:500;overflow:hidden}.bottom-bar-timer{color:#4f46e5;font-family:monospace;font-size:16px;font-weight:700}
