*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f8f7f2;--surface:#fff;--surface2:#f2f0e8;--border:#ddd9cc;--text:#1a1a2e;--text-muted:#6b6b7a;--accent:#1a3a6b;--accent-light:#e8eef8;--green:#2d7d46;--green-light:#e8f5ec;--red:#c0392b;--red-light:#fdf0ee;--gold:#b8860b;--gold-light:#fdf8e8;--shadow:0 2px 8px rgba(26,26,46,.08);--shadow-lg:0 8px 32px rgba(26,26,46,.12);--radius:12px;--font-display:"Playfair Display",Georgia,serif;--font-body:"Source Serif 4",Georgia,serif}html{font-size:16px;scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:1rem;line-height:1.7;min-height:100vh}h1,h2,h3{font-family:var(--font-display);line-height:1.2}a{color:var(--accent);text-decoration:none}button{cursor:pointer;border:none;font-family:var(--font-body)}.container{max-width:900px;margin:0 auto;padding:0 1.5rem}.passage-block{background:var(--surface2);font-size:.9rem;line-height:1.8;white-space:pre-wrap;max-height:400px;overflow-y:auto;color:var(--text)}.passage-block,.q-card{border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem}.q-card{background:var(--surface);margin-bottom:1rem;box-shadow:var(--shadow);transition:border-color .2s}.q-card:hover{border-color:var(--accent)}.q-label{font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:.5rem}.q-text{font-size:1rem;font-weight:600;margin-bottom:1rem;color:var(--text);line-height:1.5}.option-list{display:flex;flex-direction:column;gap:.5rem}.option-btn{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 1rem;background:var(--bg);border:2px solid var(--border);border-radius:8px;font-family:var(--font-body);font-size:.95rem;text-align:left;color:var(--text);transition:all .15s;cursor:pointer;width:100%}.option-btn.selected,.option-btn:hover{background:var(--accent-light);border-color:var(--accent)}.option-btn.selected{font-weight:600}.option-btn.correct{background:var(--green-light);border-color:var(--green);color:var(--green)}.option-btn.incorrect{background:var(--red-light);border-color:var(--red);color:var(--red)}.option-circle{width:22px;height:22px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.7rem;font-weight:700;margin-top:1px;transition:all .15s}.option-btn.correct .option-circle,.option-btn.selected .option-circle{background:var(--accent);border-color:var(--accent);color:#fff}.option-btn.correct .option-circle{background:var(--green);border-color:var(--green)}.option-btn.incorrect .option-circle{background:var(--red);border-color:var(--red);color:#fff}.tf-group{display:flex;gap:.5rem;flex-wrap:wrap}.tf-btn{padding:.5rem 1.25rem;border:2px solid var(--border);border-radius:20px;background:var(--bg);font-family:var(--font-body);font-weight:600;font-size:.875rem;color:var(--text-muted);cursor:pointer;transition:all .15s}.tf-btn:hover{border-color:var(--accent);color:var(--accent)}.tf-btn.selected{background:var(--accent);border-color:var(--accent);color:#fff}.tf-btn.correct{background:var(--green);border-color:var(--green);color:#fff}.tf-btn.incorrect{background:var(--red);border-color:var(--red);color:#fff}.fill-input{width:100%;max-width:400px;padding:.6rem 1rem;border:2px solid var(--border);border-radius:8px;font-family:var(--font-body);font-size:.95rem;background:var(--bg);color:var(--text);transition:border-color .15s;outline:none}.fill-input:focus{border-color:var(--accent);background:#fff}.fill-input.correct{border-color:var(--green);background:var(--green-light)}.fill-input.incorrect{border-color:var(--red);background:var(--red-light)}.essay-textarea{width:100%;min-height:280px;padding:1rem;border:2px solid var(--border);border-radius:8px;font-family:var(--font-body);font-size:.95rem;background:var(--bg);color:var(--text);resize:vertical;transition:border-color .15s;outline:none;line-height:1.7}.essay-textarea:focus{border-color:var(--accent);background:#fff}.word-count{font-size:.8rem;color:var(--text-muted);margin-top:.4rem;text-align:right}.feedback{margin-top:.75rem;padding:.75rem 1rem;border-radius:8px;font-size:.875rem;line-height:1.5}.feedback.correct{background:var(--green-light);color:var(--green);border-left:3px solid var(--green)}.feedback.incorrect{background:var(--red-light);color:var(--red);border-left:3px solid var(--red)}.feedback.info{background:var(--gold-light);color:var(--gold);border-left:3px solid var(--gold)}.top-bar{background:var(--accent);color:#fff;padding:.875rem 1.5rem;display:flex;align-items:center;justify-content:space-between;position:-webkit-sticky;position:sticky;top:0;z-index:100;box-shadow:0 2px 12px rgba(26,58,107,.3)}.top-bar-title{font-family:var(--font-display);font-size:1.1rem;letter-spacing:.02em}.section-tabs{display:flex;gap:.4rem;overflow-x:auto;padding-bottom:.25rem;scrollbar-width:none}.section-tabs::-webkit-scrollbar{display:none}.tab-btn{padding:.5rem 1rem;border:2px solid var(--border);border-radius:20px;background:#fff;font-family:var(--font-body);font-size:.8rem;font-weight:600;color:var(--text-muted);cursor:pointer;white-space:nowrap;transition:all .15s}.tab-btn:hover{border-color:var(--accent);color:var(--accent)}.tab-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.progress-bar{height:3px;background:var(--border);border-radius:2px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--accent);transition:width .5s ease}.btn-primary{padding:.75rem 2rem;background:var(--accent);color:#fff;border:none;border-radius:8px;font-family:var(--font-display);font-size:1rem;font-weight:600;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:.5rem}.btn-primary:hover{background:#14306a;transform:translateY(-1px);box-shadow:var(--shadow-lg)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-secondary{padding:.65rem 1.5rem;background:transparent;color:var(--accent);border:2px solid var(--accent);border-radius:8px;font-family:var(--font-body);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .15s}.btn-secondary:hover{background:var(--accent-light)}.score-ring-container{position:relative;display:inline-block}.score-ring-text{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.badge{display:inline-block;padding:.25rem .6rem;border-radius:12px;font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.badge-listening{background:#e8eef8;color:#1a3a6b}.badge-reading{background:#e8f5ec;color:#2d7d46}.badge-writing1{background:#fdf8e8;color:#b8860b}.badge-writing2{background:#fdf0ee;color:#c0392b}.badge-grammar{background:#f3e8ff;color:#6b21a8}@keyframes spin{to{transform:rotate(1turn)}}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin:2rem auto}@media (max-width:640px){.q-card{padding:1.1rem}.passage-block{font-size:.82rem;max-height:300px}}