.comprehension-island{background:white;border-radius:12px;padding:20px;border:1px solid var(--color-border,#e5e7eb);max-width:720px;margin:0 auto}.comprehension-island__empty{background:white;border-radius:12px;padding:24px;text-align:center;color:var(--color-text-muted,#64748b)}.comprehension-island__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.comprehension-island__counter{font-size:13px;color:var(--color-text-muted,#64748b);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.comprehension-island__nav{display:flex;gap:8px}.comprehension-island__nav button{background:var(--color-bg-secondary,#f1f5f9);border:1px solid var(--color-border,#e5e7eb);border-radius:8px;padding:6px 10px;font-size:14px;cursor:pointer}.comprehension-island__nav button:disabled{cursor:not-allowed;opacity:.4}.comprehension-island__stepper{display:flex;gap:6px;margin-bottom:18px;overflow-x:auto}.comprehension-island__step{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;background:var(--color-bg-secondary,#f1f5f9);border:1px solid var(--color-border,#e5e7eb);cursor:pointer;font-size:13px;color:var(--color-text-muted,#64748b);white-space:nowrap}.comprehension-island__step.is-active{background:var(--color-primary,#667eea);border-color:var(--color-primary,#667eea);color:white}.comprehension-island__step.is-done{color:var(--color-success-text,#065f46);border-color:var(--color-success-light,#ecfdf5)}.comprehension-island__step-num{display:inline-flex;width:22px;height:22px;align-items:center;justify-content:center;border-radius:50%;background:white;color:var(--color-text-primary,#1e293b);font-weight:700;font-size:12px}.comprehension-island__step.is-active .comprehension-island__step-num{background:white;color:var(--color-primary,#667eea)}.comprehension-island__phase{display:flex;flex-direction:column;gap:12px}.comprehension-island__phase-title{margin:0;font-size:18px;font-weight:700;color:var(--color-text-primary,#1e293b)}.comprehension-island__phase-desc{margin:0;font-size:14px;color:var(--color-text-muted,#64748b);line-height:1.5}.comprehension-island__phase-shortcuts{margin:0;font-size:12px;color:var(--color-text-muted,#64748b);font-style:italic}.comprehension-island__audio-row{display:flex;align-items:center;gap:8px}.comprehension-island__play-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;background:var(--color-primary-light,#eef2ff);color:var(--color-primary,#667eea);border:1px solid var(--color-primary,#667eea);border-radius:10px;font-weight:600;font-size:14px;cursor:pointer}.comprehension-island__words{display:flex;flex-wrap:wrap;gap:6px;padding:14px;background:var(--color-bg-secondary,#f8fafc);border-radius:10px;border:1px solid var(--color-border,#e5e7eb)}.comprehension-island__punct{align-self:end;padding:0 2px;color:var(--color-text-muted,#64748b);font-size:16px}.comprehension-island__word-input{font:inherit;font-size:16px;padding:6px 8px;border-radius:8px;border:1px solid var(--color-border,#e5e7eb);background:white;text-align:center;outline:none;transition:border-color .12s ease,background-color .12s ease}.comprehension-island__word-input.is-active{border-color:var(--color-primary,#667eea);box-shadow:0 0 0 2px rgba(102,126,234,.18)}.comprehension-island__word-input.is-correct{background:var(--color-success-light,#ecfdf5);border-color:var(--color-success,#16a34a);color:var(--color-success-text,#065f46);font-weight:600}.comprehension-island__word-input.is-wrong{background:var(--color-error-light,#fef2f2);border-color:var(--color-error,#dc2626);color:var(--color-error,#991b1b);font-weight:600}.comprehension-island__accuracy{font-size:14px}.comprehension-island__accuracy,.comprehension-island__sentence{margin:0;font-weight:600;color:var(--color-text-primary,#1e293b)}.comprehension-island__sentence{font-size:18px;line-height:1.5}.comprehension-island__translation{margin:0;font-size:14px;line-height:1.5;color:var(--color-text-muted,#64748b)}.comprehension-island__label{display:block;font-size:13px;font-weight:600;color:var(--color-text-primary,#1e293b)}.comprehension-island__textarea{width:100%;box-sizing:border-box;border-radius:10px;border:1px solid var(--color-border,#e5e7eb);padding:10px;font-family:inherit;font-size:15px;resize:vertical;min-height:80px}.comprehension-island__phase-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:4px}.comprehension-island__btn{padding:10px 18px;border-radius:10px;font-weight:600;font-size:14px;cursor:pointer;border:1px solid transparent}.comprehension-island__btn--primary{background:var(--color-primary,#667eea);color:white}.comprehension-island__btn--primary:disabled{opacity:.5;cursor:not-allowed}.comprehension-island__eval-result{display:flex;flex-direction:column;gap:12px;padding:16px;background:var(--color-bg-secondary,#f8fafc);border-radius:12px;border:1px solid var(--color-border,#e5e7eb)}.comprehension-island__score{display:inline-flex;align-items:baseline;gap:6px;padding:10px 16px;border-radius:999px;font-weight:700;align-self:flex-start}.comprehension-island__score strong{font-size:24px}.comprehension-island__score--good{background:var(--color-success-light,#ecfdf5);color:var(--color-success-text,#065f46)}.comprehension-island__score--ok{background:#fef9c3;color:#854d0e}.comprehension-island__score--low{background:var(--color-error-light,#fef2f2);color:var(--color-error,#991b1b)}.comprehension-island__vocab-bonus{margin:0;font-size:13px;font-weight:600;color:var(--color-success-text,#065f46)}.comprehension-island__feedback{margin:0;font-size:14px;line-height:1.5;color:var(--color-text-primary,#1e293b)}.comprehension-island__errors h4{margin:0 0 6px;font-size:13px;font-weight:700;color:var(--color-text-primary,#1e293b)}.comprehension-island__errors ul{margin:0;padding-left:18px;font-size:13px;line-height:1.5;color:var(--color-text-primary,#1e293b)}.comprehension-island__reference{padding:10px 12px;background:white;border:1px dashed var(--color-border,#e5e7eb);border-radius:10px}.comprehension-island__reference-label{display:block;font-size:12px;font-weight:600;color:var(--color-text-muted,#64748b);margin-bottom:4px}.comprehension-island__reference p{margin:0;font-size:14px;color:var(--color-text-primary,#1e293b)}.shadowing-island{background:white;border-radius:12px;padding:20px;border:1px solid var(--color-border,#e5e7eb)}.shadowing-island__empty{background:white;border-radius:12px;padding:24px;text-align:center;color:var(--color-text-muted,#64748b)}.shadowing-island__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.shadowing-island__counter{font-size:13px;color:var(--color-text-muted,#64748b);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.shadowing-island__nav{display:flex;gap:8px}.shadowing-island__nav button{background:var(--color-bg-secondary,#f1f5f9);border:1px solid var(--color-border,#e5e7eb);border-radius:8px;padding:6px 10px;font-size:14px;cursor:pointer}.shadowing-island__nav button:disabled{cursor:not-allowed;opacity:.4}.shadowing-island__sentence{margin:0 0 6px;font-size:17px;line-height:1.5;font-weight:600;color:var(--color-text-primary,#1e293b)}.shadowing-island__translation{margin:0 0 16px;font-size:13px;line-height:1.5;color:var(--color-text-muted,#64748b)}.shadowing-island__controls{display:flex;gap:10px;flex-wrap:wrap}.shadowing-island__btn{flex:1 1 200px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:10px;padding:12px;font-size:14px;font-weight:600;cursor:pointer;border:none}.shadowing-island__btn--reference{background:var(--color-primary-light,#eef2ff);color:var(--color-primary,#667eea);border:1px solid var(--color-primary,#667eea)}.shadowing-island__btn--reference:disabled{opacity:.5;cursor:not-allowed}.shadowing-island__btn--record{background:var(--color-primary,#667eea);color:white}.shadowing-island__btn--record:disabled{opacity:.5;cursor:not-allowed}.shadowing-island__btn--record.is-recording{background:var(--color-error,#dc2626)}.shadowing-island__rec-dot{width:10px;height:10px;border-radius:50%;background:white;animation:shadowing-island-pulse 1s ease-in-out infinite}@keyframes shadowing-island-pulse{0%,to{opacity:.4}50%{opacity:1}}@media (prefers-reduced-motion:reduce){.shadowing-island__rec-dot{animation:none}}.shadowing-island__error{margin:12px 0 0;font-size:13px;color:var(--color-error,#dc2626)}.shadowing-island__assessing{margin:12px 0 0;font-size:13px;color:var(--color-text-muted,#64748b);font-style:italic}.shadowing-island__playback{margin-top:16px;padding:12px;background:var(--color-bg-secondary,#f1f5f9);border-radius:10px;display:flex;flex-direction:column;gap:8px}.shadowing-island__playback span{font-size:13px;font-weight:600;color:var(--color-text-primary,#1e293b)}.shadowing-island__playback audio{width:100%}.coaching-panel--loading .coaching-panel__loading{color:var(--color-text-muted,#64748b);font-size:13px;padding:12px 0}.word-practice-modal__delta--highlight{background:var(--color-success-light,#ecfdf5);border-radius:10px;padding:8px 10px}.scan-page{max-width:880px;margin:0 auto;padding:32px 20px 80px;display:flex;flex-direction:column;gap:24px}.scan-header{text-align:center}.scan-title{font-size:28px;font-weight:700;color:var(--color-text-primary);margin:0 0 8px}.scan-subtitle{font-size:15px;color:var(--color-text-secondary);margin:0;line-height:1.6}.scan-banner{padding:14px 18px;border-radius:var(--radius-lg);font-size:14px}.scan-validation-warnings{background:#fff7ed;border:1px solid #fed7aa;border-left:4px solid var(--color-warning);border-radius:var(--radius-lg);padding:14px 18px}.scan-validation-warnings__title{font-size:14px;font-weight:700;color:#92400e;margin:0 0 8px}.scan-validation-warnings__item{font-size:13px;color:#78350f;margin:4px 0;line-height:1.5}.scan-banner--error{background:var(--color-error-light);border:1px solid var(--color-error-border);color:var(--color-error)}.scan-upload-card{background:var(--color-bg-primary);border:2px dashed #cbd5e1;border-radius:var(--radius-xl);padding:48px 24px;text-align:center;box-shadow:var(--shadow-sm);color:var(--color-text-secondary);transition:border-color .18s ease,background .18s ease}.scan-upload-card--drag{border-color:var(--color-primary);background:var(--color-primary-50)}.scan-upload-card__title{font-size:20px;font-weight:600;color:var(--color-text-primary);margin:12px 0 6px}.scan-upload-card__hint{margin:0 0 24px;font-size:14px;color:var(--color-text-secondary)}.scan-upload-card__actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:16px}.scan-upload-card__limits{font-size:12px;color:var(--color-text-muted);margin:0}.scan-cta{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius-lg);border:1px solid transparent;font-size:14px;font-weight:600;cursor:pointer;text-decoration:none;transition:background .15s ease,transform .05s ease}.scan-cta:disabled{opacity:.55;cursor:not-allowed}.scan-cta--primary{background:var(--color-primary);color:#fff}.scan-cta--primary:hover:not(:disabled){background:var(--color-primary-hover)}.scan-cta--primary:active:not(:disabled){transform:translateY(1px)}.scan-cta--secondary{background:var(--color-bg-primary);color:var(--color-text-primary);border-color:#e2e8f0}.scan-cta--secondary:hover:not(:disabled){background:var(--color-bg-tertiary)}.scan-cta--text{background:transparent;color:var(--color-text-secondary);padding:8px 12px}.scan-cta--text:hover:not(:disabled){color:var(--color-text-primary)}.scan-confirm-card{background:var(--color-bg-primary);border:1px solid #e2e8f0;border-radius:var(--radius-xl);padding:24px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:16px}.scan-confirm-card__file{display:flex;align-items:center;gap:12px;padding-bottom:16px;border-bottom:1px solid #f1f5f9}.scan-confirm-card__filename{font-size:15px;font-weight:600;color:var(--color-text-primary);word-break:break-all}.scan-confirm-card__filesize{font-size:12px;color:var(--color-text-muted);margin-top:2px}.scan-cost-row{display:flex;justify-content:space-between;align-items:center;font-size:14px}.scan-cost-row__label{color:var(--color-text-secondary)}.scan-cost-row__value{font-weight:600;color:var(--color-text-primary)}.scan-cost-row__value--low{color:var(--color-error)}.scan-confirm-card__dup{background:var(--color-primary-50);color:var(--color-primary-700);border-radius:var(--radius-md);padding:10px 14px;margin:0;font-size:13px}.scan-confirm-card__actions{display:flex;gap:12px;justify-content:flex-end;flex-wrap:wrap}.scan-analyzing-card{background:var(--color-bg-primary);border:1px solid #e2e8f0;border-radius:var(--radius-xl);padding:40px 24px;text-align:center;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;align-items:center;gap:12px}.scan-progress-bar{width:100%;height:6px;background:var(--color-bg-tertiary);border-radius:999px;overflow:hidden;margin-bottom:16px}.scan-progress-bar__fill{height:100%;background:var(--color-primary);border-radius:999px;transition:width 1s ease}.scan-analyzing-card__eta{margin:4px 0 0;font-size:12px;color:var(--color-text-muted)}.scan-spinner{width:36px;height:36px;border:3px solid var(--color-primary-100);border-top-color:var(--color-primary);border-radius:50%;animation:scanSpin .9s linear infinite}@keyframes scanSpin{to{transform:rotate(1turn)}}.scan-analyzing-card__title{margin:0;font-size:18px;font-weight:600;color:var(--color-text-primary)}.scan-analyzing-card__progress{margin:0;color:var(--color-text-secondary);font-size:14px}.scan-error-card{background:var(--color-error-light);border:1px solid var(--color-error-border);border-radius:var(--radius-xl);padding:24px;color:var(--color-error);display:flex;flex-direction:column;gap:8px;align-items:flex-start}.scan-error-card h2{margin:0;font-size:18px}.scan-error-card__refunded{background:rgba(255,255,255,.6);padding:8px 12px;border-radius:var(--radius-md);color:var(--color-text-primary);font-size:13px;margin:4px 0}.scan-regrade-card{background:#eff6ff;border:1px solid #bfdbfe;border-left:4px solid var(--color-primary);border-radius:var(--radius-xl);padding:24px;color:var(--color-primary-700);display:flex;flex-direction:column;gap:10px;align-items:flex-start}.scan-regrade-card h2{margin:0;font-size:18px;color:var(--color-text-primary)}.scan-regrade-card p{margin:0;color:var(--color-text-secondary);line-height:1.55}.scan-regrade-card__actions{display:flex;align-items:center;gap:12px;margin-top:4px}.scan-paywall{background:var(--color-bg-primary);border-radius:var(--radius-xl);padding:56px 32px;text-align:center;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;align-items:center;gap:16px;color:var(--color-text-secondary)}.scan-paywall h1{font-size:24px;color:var(--color-text-primary);margin:0}.scan-paywall p{margin:0;max-width:480px;line-height:1.6}.scan-question-list{display:flex;flex-direction:column;gap:14px}.scan-question-list__heading{font-size:16px;font-weight:600;color:var(--color-text-primary);margin:8px 0 0}.scan-question{background:var(--color-bg-primary);border:1px solid #e2e8f0;border-left:4px solid #cbd5e1;border-radius:var(--radius-lg);padding:16px 18px;box-shadow:var(--shadow-xs);animation:scanFadeIn .2s ease}.scan-question--preview{border-left-color:var(--color-primary-100);opacity:.85}.scan-question__badge--pending{background:var(--color-primary-50);color:var(--color-primary)}.scan-preview-skeleton{height:40px;border-radius:var(--radius-md);background:linear-gradient(90deg,var(--color-bg-tertiary) 25%,var(--color-bg-secondary) 50%,var(--color-bg-tertiary) 75%);background-size:200% 100%;animation:scanShimmer 1.5s ease-in-out infinite;margin-top:10px}@keyframes scanShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.scan-question--missing{border-left-color:var(--color-warning);opacity:.7}.scan-question__badge--missing{background:#fef3c7;color:#92400e}.scan-question--correct{border-left-color:#22c55e}.scan-question--incorrect{border-left-color:var(--color-error)}.scan-question--ungraded{border-left-color:var(--color-warning)}@keyframes scanFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.scan-question__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.scan-question__num{font-weight:700;color:var(--color-text-primary);font-size:14px}.scan-question__head-badges{display:inline-flex;align-items:center;gap:8px}.scan-difficulty{font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px;white-space:nowrap}.scan-difficulty--high{background:var(--color-error-light);color:var(--color-error)}.scan-difficulty--mid{background:#fef3c7;color:#92400e}.scan-difficulty--low{background:var(--color-success-light);color:var(--color-success-text)}.scan-question__badge{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:3px 10px;border-radius:999px}.scan-question__badge--correct{background:var(--color-success-light);color:var(--color-success-text)}.scan-question__badge--incorrect{background:var(--color-error-light);color:var(--color-error)}.scan-question__badge--ungraded{background:#fef3c7;color:#92400e}.scan-question__text{margin:0 0 4px;color:var(--color-text-primary);font-size:14px;line-height:1.6}.scan-question__translation{margin:0 0 10px;color:var(--color-text-secondary);font-size:13px;line-height:1.55;padding-left:12px;border-left:2px solid var(--color-primary-100)}.scan-question__options{list-style:none;padding:0;margin:0 0 8px;display:flex;flex-direction:column;gap:6px}.scan-question__option{display:flex;gap:8px;padding:8px 12px;background:var(--color-bg-secondary);border-radius:var(--radius-md);font-size:13px;color:var(--color-text-secondary)}.scan-question__option-label{font-weight:700;color:var(--color-text-primary);width:18px}.scan-question__option--correct{background:var(--color-success-light);color:var(--color-success-text)}.scan-question__option--user-wrong{background:var(--color-error-light);color:var(--color-error);text-decoration:line-through}.scan-question__cloze{display:flex;flex-direction:column;gap:6px;padding:10px 12px;background:var(--color-bg-secondary);border-radius:var(--radius-md);font-size:13px}.scan-question__cloze-label{font-weight:600;color:var(--color-text-muted);margin-right:8px}.scan-question__cloze-user--wrong{color:var(--color-error);text-decoration:line-through}.scan-question__explanation{margin:10px 0 0;font-size:13px;color:var(--color-text-secondary);background:#fff7ed;border-left:3px solid var(--color-warning);padding:8px 12px;border-radius:var(--radius-sm);line-height:1.55}.scan-question__explanations{margin-top:10px;display:flex;flex-direction:column;gap:6px}.scan-question__explanation-item{display:flex;gap:8px;padding:8px 12px;background:var(--color-bg-secondary);border-radius:var(--radius-md);font-size:13px;line-height:1.55;color:var(--color-text-secondary)}.scan-question__explanation-label{font-weight:700;color:var(--color-error);min-width:18px;flex-shrink:0}.scan-question__kp{margin-top:12px;display:flex;flex-wrap:wrap;gap:6px}.scan-question__kp-chip{background:var(--color-primary-50);color:var(--color-primary-700);font-size:11px;padding:3px 8px;border-radius:999px;font-weight:500}.scan-question__section{padding:14px 0;border-top:1px dashed #e2e8f0}.scan-question__section:first-of-type{border-top:none;padding-top:4px}.scan-question__section-title{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);margin:0 0 8px}.scan-question__options--neutral .scan-question__option{background:var(--color-bg-secondary);color:var(--color-text-secondary)}.scan-question__user-answer{display:inline-flex;align-items:center;padding:8px 14px;border-radius:var(--radius-md);font-weight:600;font-size:15px;background:var(--color-bg-tertiary);color:var(--color-text-primary)}.scan-question__user-answer--correct{background:var(--color-success-light);color:var(--color-success-text)}.scan-question__user-answer--incorrect{background:var(--color-error-light);color:var(--color-error)}.scan-question__user-answer--ungraded{background:#fef3c7;color:#92400e}.scan-question__user-answer--blank{font-style:italic;color:var(--color-text-muted)}.scan-verdict{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:999px;font-weight:700;font-size:14px;margin-bottom:10px}.scan-verdict--correct{background:var(--color-success-light);color:var(--color-success-text)}.scan-verdict--incorrect{background:var(--color-error-light);color:var(--color-error)}.scan-verdict--ungraded{background:#fef3c7;color:#92400e}.scan-question__correct-row{display:flex;align-items:baseline;gap:10px;font-size:14px;color:var(--color-text-primary);margin-bottom:6px}.scan-question__correct-label{color:var(--color-text-muted);font-weight:500}.scan-question__correct-value{font-weight:700;color:var(--color-success-text)}.scan-question__correct-explanation{margin:6px 0 10px;font-size:13px;line-height:1.55;color:var(--color-success-text);background:var(--color-success-light);padding:8px 12px;border-left:3px solid #22c55e;border-radius:var(--radius-sm)}.scan-question__correct-explanation--pending{display:flex;align-items:center;gap:8px;color:var(--color-text-secondary);background:var(--color-surface-muted,#f3f4f6);border-left-color:var(--color-border,#d1d5db);font-style:italic}.scan-question__enrich-spinner{flex:0 0 auto;width:12px;height:12px;border:2px solid var(--color-border,#d1d5db);border-top-color:var(--color-primary,#667eea);border-radius:50%;animation:scan-enrich-spin .7s linear infinite}@keyframes scan-enrich-spin{to{transform:rotate(1turn)}}@media (prefers-reduced-motion:reduce){.scan-question__enrich-spinner{animation:none}}.scan-question__hint{margin:6px 0 0;font-size:13px;color:var(--color-text-muted)}.scan-question__image-block{display:flex;flex-direction:column;gap:10px;margin-top:10px}.scan-question__override{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.scan-question__override-label{font-size:12px;font-weight:600;color:var(--color-text-secondary)}.scan-question__override-buttons{display:flex;gap:6px}.scan-question__override-btn{width:32px;height:32px;border-radius:var(--radius-md);border:1.5px solid #cbd5e1;background:var(--color-bg-primary);color:var(--color-text-primary);font-weight:700;font-size:13px;cursor:pointer;transition:all .12s ease}.scan-question__override-btn:hover{border-color:var(--color-primary);background:var(--color-primary-50)}.scan-question__override-btn--active{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.scan-question__override-note{font-size:11px;color:var(--color-success-text);font-weight:600}.scan-question__hint--image{background:#eff6ff;border-left:3px solid var(--color-primary);padding:8px 12px;border-radius:var(--radius-sm);color:var(--color-primary-700)}.scan-question__reasoning{margin:10px 0 0;font-size:13px;color:var(--color-text-secondary);background:var(--color-bg-secondary);border-radius:var(--radius-md);padding:0}.scan-question__reasoning summary{padding:10px 14px;cursor:pointer;font-weight:600;color:var(--color-primary-700);list-style:none}.scan-question__reasoning summary:before{content:"▶ ";font-size:10px}.scan-question__reasoning[open] summary:before{content:"▼ "}.scan-question__reasoning p{padding:0 14px 12px;margin:0;line-height:1.65;white-space:pre-wrap}.scan-question__kp-list{display:flex;flex-wrap:wrap;gap:8px}.scan-kp-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;font-size:12px;background:var(--color-primary-50);color:var(--color-primary-700);border:1px solid transparent}.scan-kp-chip,.scan-kp-chip__label{font-weight:600}.scan-kp-chip__meta{font-weight:500;color:inherit;opacity:.75}.scan-kp-chip__gap{background:rgba(255,255,255,.7);color:#92400e;font-size:10px;padding:1px 6px;border-radius:999px;font-weight:700}.scan-kp-chip--strong{background:var(--color-success-light);color:var(--color-success-text)}.scan-kp-chip--ok{background:var(--color-primary-50);color:var(--color-primary-700)}.scan-kp-chip--weak{background:#fef3c7;color:#92400e}.scan-kp-chip--gap{background:var(--color-error-light);color:var(--color-error);border-color:var(--color-error-border)}.scan-kp-chip--unresolved{background:var(--color-bg-tertiary);color:var(--color-text-muted)}.scan-kp-chip--pending{background:var(--color-bg-tertiary);color:var(--color-text-secondary);opacity:.75}.scan-result__reattempt{margin-top:14px;display:inline-flex}.scan-question--practice{border-left-color:var(--color-primary-100)}.scan-practice__options{display:flex;flex-direction:column;gap:8px;margin-top:10px}.scan-practice__option{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:12px 14px;border:1.5px solid var(--color-border,#e2e8f0);border-radius:var(--radius-md);background:var(--color-bg-primary,#fff);cursor:pointer;font-size:14px;color:var(--color-text-primary);transition:border-color .12s ease,background .12s ease}.scan-practice__option--selected,.scan-practice__option:hover{border-color:var(--color-primary)}.scan-practice__option--selected{background:var(--color-primary-50)}.scan-practice__option-label{font-weight:700;min-width:20px;color:var(--color-primary-700)}.scan-practice__input{width:100%;margin-top:10px;padding:12px 14px;border:1.5px solid var(--color-border,#e2e8f0);border-radius:var(--radius-md);font-size:14px}.scan-practice__input:focus{outline:none;border-color:var(--color-primary)}.scan-practice__submit-bar{position:sticky;bottom:0;display:flex;justify-content:center;padding:16px 0;background:linear-gradient(to top,var(--color-bg-secondary,#f8fafc) 60%,transparent)}.scan-practice__submit-bar .scan-cta{min-width:200px;justify-content:center}.scan-title__edit{margin-left:10px;font-size:12px;font-weight:600;color:var(--color-primary);background:none;border:none;cursor:pointer;vertical-align:middle}.scan-title-edit{display:flex;gap:8px;align-items:center;justify-content:center;flex-wrap:wrap}.scan-title-edit__input{font-size:20px;font-weight:700;padding:6px 12px;border:1.5px solid var(--color-primary);border-radius:var(--radius-md);text-align:center;min-width:260px}.scan-question__edit-btn{font-size:12px;font-weight:600;color:var(--color-primary);background:var(--color-primary-50);border:none;border-radius:999px;padding:3px 10px;cursor:pointer}.scan-edit-form{display:flex;flex-direction:column;gap:12px;margin:10px 0 4px;padding:16px;background:var(--color-bg-secondary);border:1px solid var(--color-border,#e2e8f0);border-radius:var(--radius-lg)}.scan-edit-form__field{display:flex;flex-direction:column;gap:4px;font-size:12px;font-weight:600;color:var(--color-text-secondary)}.scan-edit-form__field input,.scan-edit-form__field textarea{font-size:14px;font-weight:400;color:var(--color-text-primary);padding:8px 12px;border:1.5px solid var(--color-border,#e2e8f0);border-radius:var(--radius-md);resize:vertical}.scan-edit-form__field input:focus,.scan-edit-form__field textarea:focus{outline:none;border-color:var(--color-primary)}.scan-edit-form__actions{display:flex;gap:10px;align-items:center}.scan-banner--success{background:var(--color-success-light);border:1px solid #bbf7d0;border-radius:var(--radius-lg);padding:12px 16px;color:var(--color-success-text);font-size:14px}.scan-result__actions{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap;justify-content:center}.scan-assign{background:var(--color-bg-primary,#fff);border:1px solid var(--color-border,#e2e8f0);border-radius:var(--radius-xl);padding:20px 22px;display:flex;flex-direction:column;gap:12px}.scan-assign__heading{font-size:15px;font-weight:700;color:var(--color-text-primary);margin:0}.scan-assign__link-row,.scan-assign__row{display:flex;gap:8px;align-items:center}.scan-assign__email{flex:1 1;min-width:0;padding:10px 14px;border:1.5px solid var(--color-border,#e2e8f0);border-radius:var(--radius-md);font-size:14px}.scan-assign__email:focus{outline:none;border-color:var(--color-primary)}.scan-assign__divider{text-align:center;font-size:12px;color:var(--color-text-muted);position:relative}.scan-assign__ok{margin:0;font-size:13px;color:var(--color-success-text);font-weight:600}.scan-inbox__heading{font-size:16px;font-weight:700;color:var(--color-text-primary);margin:0 0 14px}.scan-inbox__status{font-size:12px;font-weight:600;padding:4px 10px;border-radius:999px;white-space:nowrap}.scan-inbox__status--todo{background:var(--color-primary-50);color:var(--color-primary-700)}.scan-inbox__status--done{background:var(--color-success-light);color:var(--color-success-text)}.scan-review-entry__heading{font-size:16px;font-weight:700;color:var(--color-text-primary);margin:0 0 14px}.scan-review-entry__cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.scan-review-entry__card{display:flex;flex-direction:column;gap:4px;padding:16px 18px;border:1px solid var(--color-border,#e2e8f0);border-radius:var(--radius-lg);background:var(--color-bg-primary,#fff);text-decoration:none;transition:border-color .12s ease,box-shadow .12s ease}.scan-review-entry__card:hover{border-color:var(--color-primary);box-shadow:0 2px 8px rgba(102,126,234,.12)}.scan-review-entry__card-title{font-size:15px;font-weight:700;color:var(--color-text-primary)}.scan-review-entry__card-desc{font-size:12px;color:var(--color-text-muted);line-height:1.5}.scan-review-setup{display:flex;flex-direction:column;gap:22px;background:var(--color-bg-primary,#fff);border:1px solid var(--color-border,#e2e8f0);border-radius:var(--radius-xl);padding:24px}.scan-review-setup__group{display:flex;flex-direction:column;gap:10px}.scan-review-setup__label{font-size:13px;font-weight:600;color:var(--color-text-secondary)}.scan-review-setup__options{display:flex;gap:8px;flex-wrap:wrap}.scan-review-setup__chip{padding:8px 18px;border:1.5px solid var(--color-border,#e2e8f0);border-radius:999px;background:var(--color-bg-primary,#fff);font-size:14px;font-weight:600;color:var(--color-text-primary);cursor:pointer;transition:all .12s ease}.scan-review-setup__chip--active,.scan-review-setup__chip:hover{border-color:var(--color-primary)}.scan-review-setup__chip--active{background:var(--color-primary);color:#fff}.scan-review-setup .scan-cta{align-self:flex-start;min-width:200px;justify-content:center}.scan-review-setup__empty{font-size:13px;color:var(--color-text-muted);margin:0}@media (max-width:640px){.scan-review-entry__cards{grid-template-columns:1fr}}.scan-history{border-top:1px solid var(--color-border,#e2e8f0);padding-top:24px}.scan-history__heading{font-size:16px;font-weight:700;color:var(--color-text-primary);margin:0 0 14px}.scan-history__list{display:flex;flex-direction:column;gap:8px}.scan-history__row{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;padding:14px 16px;background:var(--color-bg-primary,#fff);border:1px solid var(--color-border,#e2e8f0);border-radius:var(--radius-lg);cursor:pointer;text-align:left;transition:border-color .12s ease,box-shadow .12s ease,transform .12s ease}.scan-history__row:hover:not(:disabled){border-color:var(--color-primary);box-shadow:0 2px 8px rgba(102,126,234,.12)}.scan-history__row:disabled{opacity:.6;cursor:default}.scan-history__row-main{display:flex;flex-direction:column;gap:2px}.scan-history__date{font-size:14px;font-weight:600;color:var(--color-text-primary)}.scan-history__meta{font-size:12px;color:var(--color-text-muted)}.scan-history__row-right{display:flex;align-items:center;gap:10px}.scan-history__score{font-size:14px;font-weight:700;padding:4px 10px;border-radius:999px}.scan-history__score--high{background:var(--color-success-light);color:var(--color-success-text)}.scan-history__score--mid{background:var(--color-primary-50);color:var(--color-primary-700)}.scan-history__score--low{background:#fef3c7;color:#92400e}.scan-history__badge--refunded{font-size:12px;font-weight:600;padding:4px 10px;border-radius:999px;background:var(--color-bg-tertiary);color:var(--color-text-muted)}.scan-history__chevron{color:var(--color-text-muted);flex-shrink:0}.scan-detail-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px}.scan-detail-date{font-size:13px;font-weight:500;color:var(--color-text-muted);white-space:nowrap}.scan-detail-action,.scan-history__back{background:none;border:none;color:var(--color-primary);font-size:14px;font-weight:600;cursor:pointer;padding:4px 0}.scan-history__back:before{content:"← "}.scan-history__skeleton{height:120px;border-radius:var(--radius-lg);background:linear-gradient(90deg,var(--color-bg-tertiary) 25%,var(--color-bg-secondary) 50%,var(--color-bg-tertiary) 75%);background-size:200% 100%;animation:scanShimmer 1.5s ease-in-out infinite}.scan-history__loading-bar{height:3px;border-radius:999px;margin-bottom:12px;background:linear-gradient(90deg,var(--color-primary-100) 25%,var(--color-primary) 50%,var(--color-primary-100) 75%);background-size:200% 100%;animation:scanShimmer 1s ease-in-out infinite}@media (max-width:640px){.scan-page{padding:16px 12px 60px}.scan-upload-card{padding:32px 16px}.scan-confirm-card__actions{flex-direction:column-reverse}.scan-confirm-card__actions .scan-cta{width:100%;justify-content:center}}@media (prefers-reduced-motion:reduce){.scan-question{animation:none}.scan-spinner{animation-duration:2s}}.exam-listening__badge{display:inline-block;align-self:center;padding:4px 12px;border-radius:999px;background:var(--color-primary-100,#eef0fe);color:var(--color-primary,#667eea);font-size:13px;font-weight:600;margin-bottom:10px}.exam-listening__toolbar{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap;margin-top:14px}.exam-listening__progress{font-size:14px;color:var(--color-text-secondary,#6b7280);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.exam-listening__now-playing{font-size:12px;font-weight:600;color:var(--color-primary,#667eea)}.scan-question.exam-listening__q--playing{box-shadow:0 0 0 2px var(--color-primary,#667eea)}.scan-question__audio{width:100%;height:40px;margin:4px 0 12px}.scan-question__audio-btn{display:inline-flex;align-items:center;gap:6px;height:40px;margin:4px 0 12px;padding:0 16px;border:1px solid var(--color-border,#e5e7eb);border-radius:8px;background:var(--color-surface,#fff);color:var(--color-primary,#667eea);font-size:14px;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s}.scan-question__audio-btn:hover{background:var(--color-primary-light,#eef0fd);border-color:var(--color-primary,#667eea)}.scan-question__audio-btn svg{width:16px;height:16px}.scan-question__audio-btn--active{border-color:var(--color-primary,#667eea);color:#fff}.scan-question__audio-btn--active,.scan-question__audio-btn--active:hover{background:var(--color-primary,#667eea)}.exam-listening-index{padding-bottom:100px}.exam-player{position:fixed;left:0;right:0;bottom:0;z-index:50;background:var(--color-surface,#fff);border-top:1px solid var(--color-border,#e5e7eb);box-shadow:0 -4px 16px rgba(17,24,39,.08);padding:10px 16px calc(10px + env(safe-area-inset-bottom, 0px))}.exam-player__inner{max-width:880px;margin:0 auto;display:flex;align-items:center;gap:16px}.exam-player__transport{display:flex;align-items:center;gap:4px;flex-shrink:0}.exam-player__btn{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border:none;border-radius:50%;background:transparent;color:var(--color-text,#1f2937);cursor:pointer;transition:background .15s,color .15s}.exam-player__btn:hover:not(:disabled){background:var(--color-primary-light,#eef0fd);color:var(--color-primary,#667eea)}.exam-player__btn:disabled{opacity:.35;cursor:default}.exam-player__btn--repeat{position:relative}.exam-player__btn--repeat-on{color:var(--color-primary,#667eea)}.exam-player__btn--repeat-on,.exam-player__btn--repeat-on:hover:not(:disabled){background:var(--color-primary-light,#eef0fd)}.exam-player__repeat-one{position:absolute;right:3px;bottom:3px;min-width:13px;height:13px;padding:0 2px;border-radius:7px;font-size:9px;font-weight:700;line-height:13px;text-align:center}.exam-player__btn--play,.exam-player__repeat-one{background:var(--color-primary,#667eea);color:#fff}.exam-player__btn--play{width:46px;height:46px}.exam-player__btn--play:hover:not(:disabled){background:var(--color-primary,#667eea);filter:brightness(1.05);color:#fff}.exam-player__btn--play svg{width:20px;height:20px}.exam-player__main{flex:1 1;min-width:0;display:flex;flex-direction:column;gap:4px}.exam-player__label{font-size:13px;font-weight:600;color:var(--color-primary,#667eea)}.exam-player__progress{display:flex;align-items:center;gap:8px}.exam-player__time{font-size:12px;color:var(--color-text-secondary,#6b7280);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;flex-shrink:0}.exam-player__seek{flex:1 1;min-width:60px}.exam-player__volume{display:flex;align-items:center;gap:6px;flex-shrink:0}.exam-player__vol-slider{width:80px}.exam-player__seek,.exam-player__vol-slider{appearance:none;height:4px;border-radius:2px;background:var(--color-border,#e5e7eb);cursor:pointer}.exam-player__seek::-webkit-slider-thumb,.exam-player__vol-slider::-webkit-slider-thumb{appearance:none;width:14px;height:14px;border-radius:50%;background:var(--color-primary,#667eea);cursor:pointer}.exam-player__seek::-moz-range-thumb,.exam-player__vol-slider::-moz-range-thumb{width:14px;height:14px;border:none;border-radius:50%;background:var(--color-primary,#667eea);cursor:pointer}@media (max-width:640px){.exam-player__inner{gap:8px}.exam-player__vol-slider{display:none}}.scan-question__text--listen{color:var(--color-text-secondary,#6b7280);font-style:italic}.scan-section-divider{margin:24px 0 4px;padding-bottom:6px;border-bottom:2px solid var(--color-primary-100,#eef0fe);font-size:16px;font-weight:700;color:var(--color-text,#1f2937)}.scan-practice__options--images{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.scan-practice__option--image{flex-direction:column;align-items:stretch;gap:8px;padding:8px;height:auto}.exam-listening__option-img{width:100%;aspect-ratio:1/1;object-fit:contain;border-radius:8px;background:#fff}.exam-listening__full-audio{margin:14px auto 0;max-width:540px;padding:14px 16px;border-radius:12px;background:var(--color-primary-100,#eef0fe);border:1px solid var(--color-primary-200,#dfe3fb);text-align:left}.exam-listening__full-audio-head{display:flex;align-items:center;gap:8px;color:var(--color-primary,#667eea);font-weight:600;font-size:14px;margin-bottom:8px}.exam-listening__full-audio-head svg{width:18px;height:18px}.exam-listening__full-audio-player{width:100%;height:40px}.exam-listening__full-audio-hint{margin:8px 0 0;font-size:12.5px;line-height:1.5;color:var(--color-text-secondary,#6b7280)}.exam-listening__prompt-img{display:block;width:100%;max-width:440px;margin:4px auto 12px;border-radius:10px;border:1px solid var(--color-border,#e5e7eb);background:#fff}.exam-listening__multi-hint{margin:6px 0 10px;font-size:13px;font-weight:600;color:var(--color-primary,#667eea)}.scan-practice__options--chips{flex-direction:row;flex-wrap:wrap;gap:10px}.scan-practice__option--multi{width:auto;min-width:56px;justify-content:center;padding:12px 18px}.scan-practice__option--multi .scan-practice__option-label{min-width:0}.scan-question__options--images{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.scan-question__options--images .scan-question__option{flex-direction:column;align-items:stretch}.scan-question__option-img{width:100%;aspect-ratio:1/1;object-fit:contain;border-radius:8px;background:#fff;margin-top:6px}.scan-question__transcript{margin-top:12px;padding:12px 14px;border-radius:10px;background:var(--color-surface-subtle,#f7f8fb);border:1px solid var(--color-border,#e5e7eb)}.scan-question__transcript>summary{cursor:pointer;font-weight:600;color:var(--color-primary,#667eea);list-style:none}.scan-question__transcript>summary::-webkit-details-marker{display:none}.scan-question__transcript-en{margin:10px 0 0;white-space:pre-line;line-height:1.6;color:var(--color-text,#1f2937)}.scan-question__transcript-zh{margin:8px 0 0;white-space:pre-line;line-height:1.7;color:var(--color-text-secondary,#6b7280)}@media (max-width:640px){.scan-practice__options--images,.scan-question__options--images{grid-template-columns:1fr}}.exam-listening-index__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(158px,1fr));gap:14px;margin-top:8px}.exam-listening-card{position:relative;display:flex;flex-direction:column;gap:6px;padding:16px 16px 16px 20px;border-radius:var(--radius-xl,14px);background:var(--color-surface,#fff);border:1px solid var(--color-border,#e5e7eb);text-decoration:none;color:inherit;cursor:pointer;overflow:hidden;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.exam-listening-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--color-primary,#667eea);opacity:.4;transition:opacity .15s ease}.exam-listening-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md,0 8px 22px rgba(102,126,234,.15));border-color:var(--color-primary,#667eea)}.exam-listening-card:hover:before{opacity:1}.exam-listening-card__top{display:flex;align-items:center;justify-content:space-between;gap:8px}.exam-listening-card__year{font-size:22px;font-weight:800;line-height:1.1;color:var(--color-text,#1f2937);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;letter-spacing:.01em}.exam-listening-card--titled{min-height:92px}.exam-listening-card__title{font-size:15px;font-weight:700;line-height:1.35;color:var(--color-text,#1f2937)}.exam-listening-card__arrow{flex-shrink:0;color:var(--color-primary,#667eea);opacity:0;transform:translateX(-4px);transition:opacity .15s ease,transform .15s ease}.exam-listening-card:hover .exam-listening-card__arrow{opacity:1;transform:translateX(0)}.exam-listening-card__meta{font-size:13px;color:var(--color-text-secondary,#6b7280);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}@media (max-width:480px){.exam-listening-index__grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}.exam-listening-levels{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;margin-top:8px}.exam-listening-level{display:flex;flex-direction:column;gap:8px;padding:20px;border-radius:14px;background:var(--color-surface,#fff);border:1px solid var(--color-border,#e5e7eb);text-decoration:none;color:inherit;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.exam-listening-level:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(102,126,234,.15);border-color:var(--color-primary,#667eea)}.exam-listening-level--soon{opacity:.72}.exam-listening-level--soon:hover{transform:none;box-shadow:none;border-color:var(--color-border,#e5e7eb)}.exam-listening-level__head{display:flex;align-items:center;justify-content:space-between;gap:8px}.exam-listening-level__name{font-size:18px;font-weight:700;color:var(--color-text,#1f2937)}.exam-listening-level__count{font-weight:600;color:var(--color-primary,#667eea);background:var(--color-primary-100,#eef0fe)}.exam-listening-level__count,.exam-listening-level__soon{font-size:12px;padding:2px 10px;border-radius:999px;white-space:nowrap}.exam-listening-level__soon{color:var(--color-text-secondary,#6b7280);background:var(--color-surface-subtle,#f3f4f6)}.exam-listening-level__desc{font-size:13px;color:var(--color-text-secondary,#6b7280);line-height:1.5}.exam-listening-soon{display:flex;flex-direction:column;align-items:center;gap:8px;padding:56px 20px;text-align:center;color:var(--color-text-secondary,#6b7280)}.exam-listening-soon svg{color:var(--color-primary,#667eea);opacity:.7}.exam-listening-soon__title{margin:6px 0 0;font-size:18px;font-weight:700;color:var(--color-text,#1f2937)}.exam-listening-soon__desc{margin:0;font-size:14px}.exam-listening-cats{display:flex;flex-direction:column;gap:28px;margin-top:8px}.exam-listening-cat__head{margin-bottom:12px}.exam-listening-cat__name{margin:0;font-size:18px;font-weight:700;color:var(--color-text,#1f2937)}.exam-listening-cat__desc{margin:2px 0 0;font-size:13px;color:var(--color-text-secondary,#6b7280)}.exam-listening-sublevels{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:12px}.exam-listening-sublevels--page{margin-top:8px}.exam-listening-sublevel{display:flex;flex-direction:column;gap:10px;padding:14px 16px;border-radius:12px;background:var(--color-surface,#fff);border:1px solid var(--color-border,#e5e7eb);text-decoration:none;color:inherit;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.exam-listening-sublevel:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(102,126,234,.14);border-color:var(--color-primary,#667eea)}.exam-listening-sublevel--live{border-color:var(--color-primary-200,#c7d2fe)}.exam-listening-sublevel--soon{opacity:.72}.exam-listening-sublevel--soon:hover{transform:none;box-shadow:none;border-color:var(--color-border,#e5e7eb)}.exam-listening-sublevel__name{font-size:17px;font-weight:700;line-height:1.2;color:var(--color-text,#1f2937);white-space:nowrap;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.exam-listening-sublevel__meta{display:flex;align-items:center;justify-content:space-between;gap:6px}.exam-listening-sublevel__go{display:inline-flex;color:var(--color-primary,#667eea);transition:transform .15s ease}.exam-listening-sublevel:hover .exam-listening-sublevel__go{transform:translateX(2px)}.exam-listening-sublevel__soon{font-size:11px;color:var(--color-text-secondary,#9ca3af);background:var(--color-surface-subtle,#f3f4f6);padding:2px 8px;border-radius:999px;white-space:nowrap}.exam-listening__history{margin:0 0 24px;padding:16px;background:var(--color-surface-subtle,#f3f4f6);border-radius:12px}.exam-listening__history-title{margin:0 0 12px;font-size:14px;font-weight:700;color:var(--color-text-secondary,#6b7280)}.exam-listening__history-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.exam-listening__history-link{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;background:var(--color-surface,#ffffff);border:1px solid var(--color-border,#e5e7eb);border-radius:10px;text-decoration:none;transition:border-color .2s,background-color .2s}.exam-listening__history-link:hover{border-color:var(--color-primary,#667eea);background:var(--color-primary-light,#eef2ff)}.exam-listening__history-date{font-size:13px;color:var(--color-text-secondary,#6b7280)}.exam-listening__history-score{font-size:13px;font-weight:700;color:var(--color-success-text,#15803d);white-space:nowrap}.exam-listening__tf{display:flex;gap:12px;margin-top:12px}.exam-listening__tf-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;font-size:16px;font-weight:700;border:2px solid var(--color-border,#e5e7eb);border-radius:12px;background:var(--color-surface,#fff);color:var(--color-text-secondary,#6b7280);cursor:pointer;transition:all .15s}.exam-listening__tf-btn--selected.exam-listening__tf-btn--yes{border-color:var(--color-success-text,#15803d);background:var(--color-success-light,#dcfce7);color:var(--color-success-text,#15803d)}.exam-listening__tf-btn--selected.exam-listening__tf-btn--no{border-color:var(--color-error,#dc2626);background:var(--color-error-light,#fee2e2);color:var(--color-error,#dc2626)}.exam-listening__match-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;margin:0 0 20px;padding:16px;background:var(--color-surface-subtle,#f3f4f6);border-radius:12px}.exam-listening__match-cell{margin:0;text-align:center}.exam-listening__match-cell img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:8px;border:1px solid var(--color-border,#e5e7eb);background:#fff}.exam-listening__match-cell figcaption{margin-top:4px;font-size:15px;font-weight:700;color:var(--color-primary,#667eea)}.exam-listening__match-pick{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.exam-listening__match-letter{width:44px;height:44px;font-size:16px;font-weight:700;border:2px solid var(--color-border,#e5e7eb);border-radius:10px;background:var(--color-surface,#fff);color:var(--color-text-secondary,#6b7280);cursor:pointer;transition:all .15s}.exam-listening__match-letter--selected{border-color:var(--color-primary,#667eea);background:var(--color-primary-light,#eef2ff);color:var(--color-primary,#667eea)}.speaking-strategy-section{margin-top:20px;padding-top:20px;border-top:1px solid #e8e8e8}.speaking-strategy-title{font-size:14px;font-weight:700;color:#64748b;letter-spacing:.5px;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid #e2e8f0}.annotated-chunks{margin-top:4px;position:relative}.ac-tone-label{display:inline-block;font-size:.7rem;font-weight:500;color:var(--color-text-muted,#64748b);font-style:italic;margin-bottom:2px}.ac-sentence{font-size:1.1rem;line-height:3;padding:10px 0 8px;letter-spacing:.01em;color:var(--color-text-primary,#1e293b)}.ac-chunk-inline{white-space:normal}.ac-chunks-list{display:flex;flex-direction:column;gap:2px;margin-top:4px;padding-top:8px;border-top:1px solid var(--color-border,#e2e8f0)}.ac-chunk-item{display:flex;align-items:baseline;gap:8px;padding:3px 10px;border-radius:4px}.ac-chunk-item:hover{background:var(--color-bg-secondary,#f8fafc)}.ac-chunk-text{font-weight:600;font-size:.88rem;color:var(--color-text-primary,#1e293b);flex-shrink:0}.ac-chunk-meaning{font-size:.8rem;color:var(--color-text-muted,#64748b);line-height:1.4}.ac-stress{font-weight:700;border-bottom:2.5px solid var(--color-primary,#667eea);padding-bottom:1px;cursor:help}.ac-link{text-decoration:underline;text-decoration-style:wavy;text-decoration-color:var(--color-primary,#667eea);text-underline-offset:3px;text-decoration-thickness:1.5px;cursor:help}.ac-pause{font-weight:500}.ac-pause-mark{display:inline-block;color:var(--color-error,#dc2626);font-size:.7em;font-weight:700;margin:0 2px 0 3px;vertical-align:middle;opacity:.6;cursor:help}.ac-annotated-word{position:relative;display:inline;cursor:help}.ac-hint{position:absolute;left:0;font-size:.62rem;font-weight:600;line-height:1.2;white-space:nowrap;letter-spacing:.3px;pointer-events:none;max-width:160px;overflow:hidden;text-overflow:ellipsis}.ac-hint--below{top:calc(100% + 1px)}.ac-hint--above{bottom:calc(100% + 1px)}.ac-hint--syllables{color:var(--color-primary,#667eea)}.ac-hint--reduction{color:#d97706;font-style:italic}.ac-hint--ipa{color:#7c3aed;font-style:italic}.ac-hint-stress{font-weight:800}.ac-syllables{font-weight:600;border-bottom:2px dashed var(--color-text-muted,#64748b);cursor:help}.ac-reduction{border-bottom:2px dotted #f59e0b}.ac-ipa,.ac-reduction{font-weight:500;cursor:help}.ac-ipa{border-bottom:2px solid #8b5cf6}.ac-intonation{display:inline-block;font-size:1.1em;font-weight:700;margin-left:2px;vertical-align:middle;cursor:help}.ac-intonation.rising{color:var(--color-primary,#667eea)}.ac-intonation.falling{color:var(--color-text-muted,#64748b)}.ac-speaking-tip{margin-top:8px;font-size:.82rem;color:var(--color-text-secondary,#475569);line-height:1.5}.ac-legend-help-wrap{position:absolute;top:0;right:0}.ac-legend-help-btn{width:22px;height:22px;border-radius:50%;border:1.5px solid var(--color-border,#cbd5e1);background:var(--color-surface,#fff);color:var(--color-text-muted,#94a3b8);font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .15s,color .15s}.ac-legend-help-btn:hover{border-color:var(--color-primary,#667eea);color:var(--color-primary,#667eea)}.ac-legend-popover{position:absolute;top:28px;right:0;z-index:100;background:var(--color-surface,#fff);border:1px solid var(--color-border,#e2e8f0);border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.1);padding:12px 14px;min-width:200px;animation:acPopIn .15s ease}@keyframes acPopIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.ac-legend-modal-overlay{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.4);display:flex;align-items:flex-end;justify-content:center;animation:acFadeIn .15s ease}@keyframes acFadeIn{0%{opacity:0}to{opacity:1}}.ac-legend-modal{background:var(--color-surface,#fff);border-radius:16px 16px 0 0;width:100%;max-width:480px;padding:20px;animation:acSlideUp .2s ease}@keyframes acSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.ac-legend-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;font-size:16px;font-weight:600;color:var(--color-text-primary,#1e293b)}.ac-legend-modal-close{background:none;border:none;font-size:20px;color:var(--color-text-muted,#94a3b8);cursor:pointer;padding:4px}.ac-legend-content{display:flex;flex-wrap:wrap;gap:10px}.ac-legend-item{font-size:.72rem;color:var(--color-text-muted,#64748b);display:flex;align-items:center;gap:3px}.ac-legend-item .ac-stress{font-size:.72rem;border-bottom-width:1.5px;cursor:default}.ac-link-demo{font-size:.72rem;-webkit-text-decoration:underline wavy var(--color-primary,#667eea);text-decoration:underline wavy var(--color-primary,#667eea);text-underline-offset:2px}.ac-syllables-demo{font-size:.72rem;border-bottom:1.5px dashed var(--color-text-muted,#64748b)}.ac-reduction-demo{font-size:.72rem;border-bottom:1.5px dotted #f59e0b}.ac-ipa-demo{font-size:.72rem;border-bottom:1.5px solid #8b5cf6}.ac-legend-modal .ac-legend-content{flex-direction:column;gap:14px}.ac-legend-modal .ac-legend-item{font-size:.95rem;gap:8px}.ac-legend-modal .ac-ipa-demo,.ac-legend-modal .ac-legend-item .ac-stress,.ac-legend-modal .ac-link-demo,.ac-legend-modal .ac-reduction-demo,.ac-legend-modal .ac-syllables-demo{font-size:.95rem}