:root{--ielts-red:#e2231a;--ielts-red-dark:#c41a12;--ielts-dark:#1f2430;--ink:#1f2430;--muted:#6b7280;--bar-bg:#f7f8fa;--border:#e6e8ec;--border-strong:#d3d7de;--blue:#2b6cb0;--green:#2f855a;--red:#c53030;--amber:#f0ad4e;--page:#fff;--surface:#fff;--surface-2:#f7f8fa;--radius:14px;--shadow-sm:0 1px 3px rgba(20,24,33,.06),0 1px 2px rgba(20,24,33,.04);--shadow-md:0 8px 24px rgba(20,24,33,.08);--shadow-lg:0 18px 48px rgba(20,24,33,.12);--ring:0 0 0 3px rgba(226,35,26,.18)}*{box-sizing:border-box}body,html{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:var(--ink);background:var(--page);font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}a{color:var(--blue);text-decoration:none;transition:color .12s ease}a:hover{text-decoration:underline}:focus-visible{outline:none;box-shadow:var(--ring);border-radius:6px}h1,h2,h3{letter-spacing:-.01em}.home{max-width:1320px;margin:0 auto;padding:32px 28px 80px}.home h1{font-size:30px;margin-bottom:4px}.home .sub{color:#666;margin-bottom:28px}.notice{background:#fff8e1;border:1px solid #ffe082;border-radius:8px;padding:14px 16px;margin-bottom:28px;font-size:14px;color:#5f4b00}.book-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));grid-gap:14px;gap:14px;margin-bottom:40px}.book-card{border:1px solid var(--border);border-radius:10px;padding:16px;text-align:center;transition:box-shadow .15s,transform .15s}.book-card:hover{box-shadow:0 4px 14px rgba(0,0,0,.09);transform:translateY(-2px)}.book-card .num{font-size:34px;font-weight:700;color:var(--ielts-red)}.book-card .lbl{font-size:13px;color:#555}.book-card.disabled{opacity:.45}.test-list{margin-top:8px}.test-row{justify-content:space-between;border:1px solid var(--border);border-radius:8px;padding:14px 18px;margin-bottom:10px}.test-row,.test-row .meta{display:flex;align-items:center}.test-row .meta{gap:14px}.pill{font-size:11px;text-transform:uppercase;letter-spacing:.04em;padding:3px 9px;border-radius:999px;color:#fff}.pill.listening{background:#6b46c1}.pill.reading{background:#2b6cb0}.btn{display:inline-flex;align-items:center;gap:6px;background:var(--ielts-red);color:#fff;border:none;border-radius:10px;padding:10px 20px;font-size:14px;font-weight:600;cursor:pointer;box-shadow:var(--shadow-sm);transition:background .14s ease,transform .08s ease,box-shadow .14s ease}.btn:hover{background:var(--ielts-red-dark);text-decoration:none;color:#fff;box-shadow:var(--shadow-md)}.btn:active{transform:translateY(1px)}.btn.ghost{background:#fff;color:var(--ink);border:1px solid var(--border-strong);box-shadow:none}.btn.ghost:hover{background:var(--surface-2)}.btn.small{padding:7px 13px;font-size:13px}.player{display:flex;flex-direction:column;height:100vh}.topbar{height:56px;background:var(--bar-bg);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 18px;flex-shrink:0}.topbar .brand{font-weight:700}.topbar .brand .red{color:var(--ielts-red)}.topbar .center{gap:18px}.timer,.topbar .center{display:flex;align-items:center}.timer{gap:8px;font-weight:700;font-size:16px;background:#fff;border:1px solid var(--border);padding:6px 14px;border-radius:6px}.timer.low{color:var(--red);border-color:var(--red)}.audiobar{background:#f4f6f9;border-bottom:1px solid var(--border);padding:8px 26px;gap:18px;flex-shrink:0;min-height:52px}.audiobar,.pa{display:flex;align-items:center}.pa{gap:14px;flex:1 1;max-width:760px}.pa-btn{width:34px;height:34px;border-radius:50%;border:none;cursor:pointer;background:var(--ielts-dark);color:#fff;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.pa-btn:hover{background:#33405e}.pa-time{color:#556;font-size:13px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;min-width:38px;text-align:center}.pa-track{flex:1 1;height:7px;border-radius:4px;cursor:pointer;background:#d9dee7;overflow:hidden}.pa-fill{height:100%;background:var(--ielts-red);border-radius:4px}.pa-vol{display:inline-flex;align-items:center;gap:7px;color:#556}.pa-vol input[type=range]{width:90px;accent-color:var(--ielts-red)}.audiobar .lbl{font-weight:700;font-size:14px;color:var(--ielts-dark);display:inline-flex;align-items:center;gap:8px;white-space:nowrap}.audiobar .audio-missing{color:#778;font-size:13px}.gapfill td p,.instructions td p{margin:2px 0}.gapfill img,.instructions img{display:block;width:auto;max-width:min(100%,640px);max-height:min(48vh,460px);object-fit:contain;margin:10px 0;background:#fff;border:1px solid var(--border);border-radius:8px;padding:6px;cursor:zoom-in}.img-lightbox{position:fixed;inset:0;z-index:200;background:rgba(15,18,28,.82);display:flex;align-items:center;justify-content:center;padding:30px;cursor:zoom-out}.img-lightbox img{max-width:96vw;max-height:94vh;width:auto;height:auto;background:#fff;border-radius:8px;padding:10px}.content{flex:1 1;overflow:auto;padding:22px 26px 40px}.content:not(.reading-content)>.block-body{max-width:880px;margin-left:12px;margin-right:auto}.content:not(.reading-content)>.block-body:has(.match-layout){max-width:1360px}.reading-split{display:grid;grid-template-columns:1fr 1fr;grid-gap:0;gap:0}.reading-split .col{padding:22px 26px 40px}.reading-split .col.left{border-right:2px solid var(--border)}.passage h2{font-size:19px}.passage p{margin:0 0 12px}.passage .para-num{color:var(--ielts-red);font-weight:700;margin-right:6px}.instructions{background:#f7f7f7;border-left:3px solid var(--ielts-red);border-radius:0 6px 6px 0;padding:10px 14px;margin:16px 0 10px;font-size:14px}.instructions p{margin:5px 0}.instructions p:first-child{margin-top:0}.instructions p:last-child{margin-bottom:0}.block-heading,.instructions strong{font-weight:700}.block-heading{font-size:16px;margin:16px 0 8px}.gapfill{line-height:1.9}.gapfill p{margin:7px 0}.gapfill h1,.gapfill h2,.gapfill h3,.gapfill h4{margin:14px 0 6px}.gapfill table{border-collapse:collapse;width:100%;margin:10px 0}.gapfill td,.gapfill th{border:1px solid var(--border);padding:8px 10px;vertical-align:top;text-align:left}.gapfill ul{padding-left:20px;margin:6px 0}.gapfill li{margin:4px 0}.blank{gap:7px;margin:1px 3px;padding:2px 4px 2px 2px;background:#fffbe8;border-radius:6px;vertical-align:middle}.blank,.qnum-badge{display:inline-flex;align-items:center}.qnum-badge{justify-content:center;min-width:24px;height:24px;background:var(--ielts-dark);color:#fff;font-size:12.5px;font-weight:700;border-radius:5px;padding:0 6px;flex-shrink:0}.blank input{width:150px;height:30px;border:1px solid #9aa1ab;border-radius:5px;padding:2px 9px;font-size:14.5px;font-family:inherit;background:#fff}.blank input:focus{outline:2px solid var(--blue);border-color:var(--blue)}.gap-wrap{position:relative;display:inline-flex;align-items:center}.gap-input.over-limit{border-color:var(--ielts-red);background:#fff5f4}.mod-btn.full{border-style:dashed}.mod-btn.full .mb-type{color:var(--ielts-red)}.test-card.complete{border-color:#2f855a}.tc-done{float:right;font-size:11px;font-weight:700;background:#2f855a;color:#fff;border-radius:10px;padding:2px 8px}.mod-btn.done{border-color:#9ecdb4;background:#f4fbf7}.mb-done{color:#2f855a;font-weight:700}.book-card{position:relative}.book-card.complete{border-color:#2f855a;background:#f4fbf7}.bc-done,.bc-partial{position:absolute;top:8px;right:8px;font-size:11px;font-weight:700;border-radius:10px;padding:2px 8px}.bc-done{background:#2f855a;color:#fff}.bc-partial{background:#eef1f6;color:#445}.book-progress{display:flex;flex-direction:column;gap:8px}.bp-row{display:grid;grid-template-columns:220px 1fr 60px;grid-gap:14px;gap:14px;align-items:center;padding:7px 10px;border-radius:8px;color:inherit;text-decoration:none}.bp-row:hover{background:#f6f6f7}.bp-name{font-weight:600;font-size:14px}.bp-name.done{color:#2f855a}.bp-bar{height:9px;background:#eceef2;overflow:hidden}.bp-bar,.bp-fill{border-radius:5px}.bp-fill{display:block;height:100%;background:var(--ielts-red)}.bp-count{font-size:13px;color:#666;text-align:right}.wrong-filter{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14px;cursor:pointer;background:#fff;border:1px solid var(--border);border-radius:8px;padding:8px 14px;margin:4px 0 10px}.transcript mark{background:#ffe9a8;border-radius:3px;padding:0 2px}.limit-warn{position:absolute;top:100%;left:0;margin-top:3px;background:var(--ielts-red);color:#fff;font-size:11px;font-weight:700;padding:2px 7px;border-radius:4px;white-space:nowrap;z-index:5}.match-layout{display:flex;gap:36px;align-items:flex-start;flex-wrap:nowrap;margin:12px 0}.match-figure{flex:0 1 auto;min-width:0;max-width:calc(100% - 330px)}.match-figure img{display:block;width:auto;max-width:100%;max-height:none;zoom:.75;background:#fff;border:1px solid var(--border);border-radius:8px;padding:6px;cursor:zoom-in}.match-side{flex:1 0 300px;min-width:280px}.match-side .q{margin:10px 0}.match-select{padding:6px 10px;border-radius:5px;border:1px solid #9aa1ab;font-size:14px;font-family:inherit;background:#fff;max-width:100%}.match-bank{background:#f7f7f7;border-radius:8px;padding:10px 12px 10px 30px;margin:0 0 16px}.match-bank li{margin:3px 0}.q{margin:16px 0;padding-bottom:4px}.q .qhead{display:flex;gap:10px;align-items:baseline}.q .qtext{font-weight:600}.opt{display:flex;align-items:flex-start;gap:9px;padding:6px 8px;border-radius:6px;cursor:pointer;margin:2px 0}.opt:hover{background:#f2f7fd}.opt input{margin-top:3px}.opt .lab{font-weight:700;margin-right:2px}.select-hint{font-size:12px;color:#888;margin-left:32px}.palette{border-top:1px solid var(--border);background:var(--bar-bg);flex-shrink:0}.part-tabs{display:flex;border-bottom:1px solid var(--border)}.part-tab{padding:8px 18px;cursor:pointer;font-size:13px;font-weight:600;border-right:1px solid var(--border);color:#555}.part-tab.active{background:#fff;color:var(--ielts-dark)}.part-tab .cnt{color:#999;font-weight:400;margin-left:6px}.palette-row{display:flex;align-items:center;gap:8px;padding:10px 18px;flex-wrap:wrap}.dot{width:30px;height:30px;border-radius:6px;font-size:13px}.palette .actions{margin-left:auto;display:flex;gap:10px}.review{max-width:1180px;margin:0 auto;padding:30px 24px 80px}.scorecard{display:flex;gap:20px;flex-wrap:wrap;border:1px solid var(--border);border-radius:12px;padding:22px;margin-bottom:26px}.scorecard .box{text-align:center;flex:1 1;min-width:120px}.scorecard .big{font-size:40px;font-weight:700}.scorecard .big.band{color:var(--ielts-red)}.scorecard .cap{font-size:12px;text-transform:uppercase;color:#888;letter-spacing:.04em}.rev-q{border:1px solid var(--border);border-radius:10px;padding:14px 16px;margin-bottom:12px}.rev-q.correct{border-left:5px solid var(--green)}.rev-q.wrong{border-left:5px solid var(--red)}.rev-q .top{display:flex;align-items:center;gap:10px;margin-bottom:6px}.rev-q .badge{min-width:26px;height:26px;border-radius:6px;color:#fff;font-weight:700;display:inline-flex;align-items:center;justify-content:center;font-size:13px}.rev-q.correct .badge{background:var(--green)}.rev-q.wrong .badge{background:var(--red)}.rev-q .yours{color:var(--red)}.rev-q .ans,.rev-q .yours.ok{color:var(--green)}.rev-q .ans{font-weight:700}.rev-q .exp{background:#f7f9fc;border-radius:8px;padding:10px 12px;margin-top:8px;font-size:14px}.rev-q .exp b{color:#333}.transcript-toggle{margin:26px 0 10px}.transcript{border:1px solid var(--border);border-radius:10px;padding:18px 20px;background:#fafafa;line-height:1.7}.transcript h3{margin-top:0}.transcript mark{background:#fff2a8;padding:1px 2px}.spk{font-weight:700}.tabs-review{display:flex;gap:6px;margin-bottom:18px;flex-wrap:wrap}.tab-btn{border:1px solid var(--border);background:#fff;padding:7px 14px;border-radius:6px;cursor:pointer;font-weight:600}.tab-btn.active{background:var(--ielts-dark);color:#fff;border-color:var(--ielts-dark)}.section-title{font-size:20px;margin:28px 0 12px;border-bottom:2px solid var(--border);padding-bottom:6px}.topbar .candidate{line-height:1.2;display:flex;align-items:center;gap:10px}.cand-name{font-weight:700;font-size:14px}.cand-id{font-size:12px;color:#777}.topbar .center{gap:10px}.timer .tlbl{font-weight:400;font-size:12px;color:#777;margin-left:2px}.timer.warn{color:#b7791f;border-color:#d69e2e}.icon-btn{background:#fff;border:1px solid var(--border);border-radius:6px;padding:7px 12px;font-size:13px;font-weight:600;cursor:pointer;color:#333}.icon-btn:hover{background:#f2f2f2}.settings-wrap{position:relative}.settings-menu{position:absolute;right:0;top:42px;z-index:40;background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:0 10px 30px rgba(0,0,0,.15);padding:12px 14px;width:250px}.s-row{align-items:center;justify-content:space-between;margin:8px 0;font-size:13px}.s-row,.seg{display:flex}.seg{gap:4px}.seg button{min-width:34px;height:30px;border:1px solid var(--border);background:#fff;border-radius:6px;cursor:pointer;font-weight:700}.seg button.on{outline:2px solid var(--blue);border-color:var(--blue)}.toast{position:fixed;top:70px;left:50%;transform:translateX(-50%);background:#1a1a1a;color:#fff;padding:10px 18px;border-radius:8px;font-weight:600;z-index:60;box-shadow:0 6px 20px rgba(0,0,0,.25)}.navbar{border-top:1px solid var(--border);background:var(--bar-bg);display:flex;align-items:stretch;flex-shrink:0;min-height:68px;overflow:visible}.nav-part,.nav-parts{display:flex;flex:1 1;gap:10px;padding:0 12px;min-width:0;align-items:center}.nav-part{height:42px;border:1px solid #9aa1ab;border-radius:6px;background:#fff;cursor:pointer;justify-content:center;overflow:hidden}.nav-part:hover{border-color:var(--ielts-dark)}.nav-part.active{border:2px solid var(--ielts-red);box-shadow:none;flex:0 0 auto}.navbar .dot{width:26px;height:26px}.np-dots{padding:0}.np-title{font-size:14px;font-weight:700;color:#333;white-space:nowrap}.nav-part.active .np-title{color:var(--ielts-dark)}.np-count{font-size:13px;color:#555;font-style:italic;white-space:nowrap}.np-dots{display:flex;gap:4px;flex-wrap:nowrap;overflow-x:auto;padding:2px 0}.dot{width:27px;height:27px;border-radius:5px;border:1px solid #bbb;background:#fff;font-size:12px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;position:relative}.dot:hover{border-color:var(--blue)}.dot.answered{background:var(--ielts-dark);color:#fff;border-color:var(--ielts-dark)}.dot.current{outline:2px solid var(--blue);outline-offset:1px}.dot.flagged:after{content:"";position:absolute;top:-3px;right:-3px;width:9px;height:9px;background:var(--amber);border-radius:50%;border:1px solid #fff}.nav-right{gap:12px;padding:0 16px;border-left:1px solid var(--border);background:#fff}.nav-right,.review-check{display:flex;align-items:center}.review-check{gap:6px;font-size:13px;font-weight:600;cursor:pointer}.nav-progress{font-size:13px;color:#666}.arrow{width:40px;height:40px;border-radius:50%;border:1px solid var(--border);background:#fff;font-size:22px;line-height:1;cursor:pointer;color:#333}.arrow:hover:not(:disabled){background:var(--ielts-dark);color:#fff;border-color:var(--ielts-dark)}.arrow:disabled{opacity:.35;cursor:default}.q-flash,[data-qanchor].q-flash{animation:qflash 1.2s ease}@keyframes qflash{0%{background:#fff6c2}to{background:transparent}}.reading-content{padding:0!important}.reading-split{display:flex;height:100%;position:relative}.reading-split .col{overflow:auto;padding:20px 24px 40px}.reading-split .col.left{border-right:none}.divider{width:6px;background:var(--border);cursor:col-resize;flex-shrink:0}.divider:hover{background:var(--blue)}.passage-tools{font-size:12px;color:#999;margin-bottom:10px}.uhl{background:#ffe98a;cursor:pointer}.uhl.has-note{background:#ffd98a;border-bottom:2px solid #e2231a}.uhl.has-note:after{content:"📝";font-size:.7em;vertical-align:super;margin-left:1px}.hl-toolbar{position:absolute;transform:translate(-50%,-100%);z-index:50;display:flex;gap:2px;background:var(--ielts-dark);border-radius:8px;padding:3px;box-shadow:var(--shadow-md)}.hl-toolbar button{background:transparent;color:#fff;border:none;border-radius:6px;padding:6px 12px;font-size:13px;font-weight:600;cursor:pointer}.hl-toolbar button:hover{background:hsla(0,0%,100%,.15)}.note-pop{position:absolute;transform:translate(-50%,-100%);z-index:55;background:#fff;border:1px solid var(--border-strong);border-radius:10px;box-shadow:var(--shadow-lg);padding:10px;width:240px}.note-pop textarea{width:100%;height:84px;border:1px solid var(--border);border-radius:8px;padding:8px;font-family:inherit;font-size:13px;resize:vertical}.note-pop textarea:focus{outline:none;box-shadow:var(--ring)}.np-actions{display:flex;justify-content:space-between;margin-top:8px}.np-actions button{border:none;border-radius:7px;padding:6px 12px;font-size:13px;font-weight:600;cursor:pointer}.np-del{background:#fdecea;color:var(--red)}.np-done{background:var(--ielts-dark);color:#fff}.notepad{position:fixed;z-index:70;width:320px;background:#fffef7;border:1px solid var(--border-strong);border-radius:12px;box-shadow:var(--shadow-lg);overflow:hidden}.np-bar{display:flex;align-items:center;justify-content:space-between;background:#fff7cc;padding:8px 12px;cursor:move;font-weight:700;font-size:13px;border-bottom:1px solid #f0e6a8}.np-x{background:transparent;border:none;font-size:20px;line-height:1;cursor:pointer;color:#777}.np-x:hover{color:var(--ink)}.notepad textarea{width:100%;height:200px;border:none;padding:12px;font-family:inherit;font-size:14px;resize:vertical;background:transparent;line-height:1.6}.notepad textarea:focus{outline:none}.icon-btn.on{background:#fdecea;border-color:#f6c8c4;color:var(--ielts-red)}.map-figure{margin:12px 0 16px;border:1px solid var(--border);border-radius:10px;padding:10px;background:#fff;text-align:center}.map-figure img{max-width:100%;height:auto;border-radius:6px}.map-missing{color:#999;font-size:13px;padding:30px;border:1px dashed var(--border-strong);border-radius:8px}.map-questions{display:flex;flex-direction:column;gap:8px}.map-q{display:flex;align-items:center;gap:10px;margin:0}.map-q .qtext{flex:1 1}.map-q select{padding:6px 10px;border-radius:6px;border:1px solid #999;font-family:inherit;font-size:14px}.site-footer{margin-top:56px;padding-top:22px;border-top:1px solid var(--border);color:var(--muted)}.foot-top{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:16px}.foot-logo{display:inline-flex}.foot-logo:hover{text-decoration:none}.foot-nav{display:flex;gap:18px;flex-wrap:wrap}.foot-nav a{color:var(--muted);font-weight:600}.foot-nav a:hover{color:var(--ielts-red)}.foot-legal{font-size:12.5px;line-height:1.65;max-width:860px}.foot-legal p{margin:0 0 8px}.foot-legal a{color:var(--muted);text-decoration:underline}.foot-legal a:hover{color:var(--ielts-red)}.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-top:14px;padding-top:12px;border-top:1px solid var(--border);font-size:12.5px}.foot-bottom a{color:var(--muted)}.foot-bottom a:hover{color:var(--ielts-red)}.legal{max-width:760px}.legal h2{font-size:17px;margin:22px 0 6px}.legal p{margin:0 0 10px;color:#333}.legal-note{margin-top:20px;padding:12px 14px;background:#fff8e1;border:1px solid #ffe082;border-radius:8px;font-size:13px;color:#5f4b00}.score-headline{font-size:22px;margin:4px 0 18px;padding:16px 20px;background:linear-gradient(135deg,#fff,#fdf3f2);border:1px solid var(--border);border-radius:12px}.score-headline strong{font-size:26px}.score-headline .sh-eq{color:var(--muted);margin:0 6px}.score-headline .sh-band{color:var(--ielts-red);font-weight:800}.calc{border:1px solid var(--border);border-radius:16px;padding:22px;box-shadow:var(--shadow-sm);margin:18px 0 26px}.calc-label{display:block;font-size:13px;font-weight:700;color:var(--muted);margin:14px 0 8px}.calc-label:first-child{margin-top:0}.calc-seg{display:inline-flex;flex-wrap:wrap;gap:6px}.calc-seg button{border:1px solid var(--border-strong);background:#fff;border-radius:9px;padding:9px 16px;font-weight:600;cursor:pointer;color:#444;min-width:auto;height:auto}.calc-seg button.on{background:var(--ielts-red);color:#fff;border-color:var(--ielts-red)}.calc-input-row{display:flex;align-items:center;gap:16px}.calc-slider{flex:1 1}.calc-number{width:74px;padding:9px;border:1px solid var(--border-strong);border-radius:8px;font-size:16px;font-family:inherit;text-align:center}.calc-result{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:20px;padding:18px 22px;border-radius:12px;background:#fff5f4;border:1px solid #f3c9c5;border-left:5px solid var(--ielts-red);color:var(--ielts-dark)}.cr-raw{font-size:20px;font-weight:700}.cr-arrow{color:#b99}.cr-arrow,.cr-band{font-size:20px}.cr-band strong{font-size:38px;color:var(--ielts-red);font-weight:800}.cr-mod{margin-left:auto;font-size:12px;font-weight:700;background:#fff;border:1px solid #f3c9c5;color:var(--ielts-red);border-radius:20px;padding:4px 12px}.calc-table-wrap{margin-top:18px}.calc-table-wrap summary{cursor:pointer;font-weight:600;color:var(--blue)}.calc-table{border-collapse:collapse;width:100%;max-width:360px;margin-top:12px}.calc-table td,.calc-table th{border:1px solid var(--border);padding:7px 12px;text-align:left;font-size:14px}.calc-table th{background:var(--surface-2)}.calc-table tr.hit td{background:#fdecea;font-weight:700}.calc-note{color:var(--muted);font-size:13px;margin-top:14px}.calc-h2{font-size:21px;margin:34px 0 6px}.overall-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:12px;gap:12px}.ob-field{display:flex;flex-direction:column;gap:6px}.ob-label{font-size:13px;font-weight:700;color:var(--muted)}.ob-field select,.target-helper select{padding:10px;border:1px solid var(--border-strong);border-radius:8px;font-size:16px;font-family:inherit;background:#fff}.target-helper{display:flex;flex-direction:column;gap:10px}.th-line{font-size:17px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.th-line select{font-size:15px;padding:7px 10px}.th-result{font-size:18px}.th-result strong{color:var(--ielts-red);font-size:22px}@media (max-width:640px){.overall-grid{grid-template-columns:repeat(2,1fr)}}.prose{max-width:720px;margin-top:30px}.prose h2{font-size:20px;margin:26px 0 10px}.prose p{color:#333;margin:0 0 12px}.faq-item h3{font-size:16px;margin:18px 0 4px}.faq-item p{color:#444}.guide-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:14px;gap:14px;margin-top:18px}.guide-card{border:1px solid var(--border);border-radius:14px;padding:18px;background:#fff;color:inherit;box-shadow:var(--shadow-sm);transition:box-shadow .16s ease,transform .16s ease}.guide-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);text-decoration:none}.gc-title{font-weight:700;font-size:17px;margin-bottom:6px}.gc-desc{color:var(--muted);font-size:14px;line-height:1.5}.gc-meta{margin-top:10px;font-size:13px;font-weight:600;color:var(--ielts-red)}.guide h1{font-size:30px;margin-bottom:4px}.guide-meta{color:var(--muted);font-size:13px;margin:0 0 16px}.guide-intro{font-size:17px;color:#333}.guide-list{margin:8px 0 12px;padding-left:22px}.guide-list li{margin:6px 0;color:#333}.guide-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:30px;padding-top:20px;border-top:1px solid var(--border)}.font-sm .content{font-size:14px}.font-md .content{font-size:16px}.font-lg .content{font-size:19px}.theme-yellow .content{background:#000;color:#ffd400}.theme-yellow .content .instructions{background:#1a1a1a;color:#ffd400;border-left-color:#ffd400}.theme-yellow .content .blank input,.theme-yellow .content select{background:#000;color:#ffd400;border-color:#ffd400}.theme-yellow .content .qnum-badge{background:#ffd400;color:#000}.theme-yellow .content .gapfill td,.theme-yellow .content .gapfill th{border-color:#555}.theme-yellow .content .opt:hover{background:#222}.theme-yellow .uhl{background:#650;color:#ffd400}.theme-white .content{background:#000;color:#fff}.theme-white .content .instructions{background:#1a1a1a;color:#fff;border-left-color:#fff}.theme-white .content .blank input,.theme-white .content select{background:#000;color:#fff;border-color:#888}.theme-white .content .qnum-badge{background:#fff;color:#000}.theme-white .content .gapfill td,.theme-white .content .gapfill th{border-color:#555}.theme-white .content .opt:hover{background:#222}@media (max-width:820px){.reading-split{flex-direction:column}.reading-split .col{width:100%!important}.divider{display:none}.nav-right{flex-wrap:wrap}}.hero{background:linear-gradient(135deg,#fff,#fdf3f2);border:1px solid var(--border);border-radius:16px;padding:30px 30px 28px;margin-bottom:24px}.hero h1{font-size:38px;margin:0 0 6px}.hero .accent{color:var(--ielts-red)}.tagline{color:#555;font-size:16px;max-width:640px;margin:0}.hero-disclaimer{color:#8a8a8a;font-size:12.5px;margin:10px 0 0}.sec-h{font-size:20px;margin:0 0 12px}.muted{color:#6a6a6a}.back-link{font-size:14px}.resume-strip{margin-bottom:26px}.resume-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));grid-gap:12px;gap:12px}.resume-card{border:1px solid var(--border);border-radius:12px;padding:14px 16px;background:#fff;transition:box-shadow .15s,transform .15s;color:inherit}.resume-card:hover{box-shadow:0 6px 18px rgba(0,0,0,.08);transform:translateY(-2px);text-decoration:none}.rc-title{font-weight:700;margin:8px 0 3px}.rc-sub{font-size:12px;color:#888}.controls{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:8px}.tabs{display:inline-flex;background:#f1f1f1;border-radius:10px;padding:4px}.tab{border:none;background:transparent;padding:8px 18px;border-radius:8px;font-weight:600;cursor:pointer;color:#555}.tab.on{background:#fff;color:var(--ielts-dark);box-shadow:0 1px 4px rgba(0,0,0,.1)}.search{border:1px solid var(--border);border-radius:10px;padding:10px 14px;font-size:14px;min-width:240px;flex:1 1;max-width:320px;font-family:inherit}.book-card .bc-counts{display:flex;gap:10px;justify-content:center;margin-top:8px;font-size:13px;color:#666}.book-card .bc-counts.locked{color:#bbb;font-size:12px}.test-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:14px;gap:14px}.test-card{border:1px solid var(--border);border-radius:14px;padding:16px;background:#fff}.tc-head{font-weight:700;font-size:16px;margin-bottom:12px}.tc-mods{display:flex;flex-direction:column;gap:10px}.mod-btn{display:flex;align-items:center;justify-content:space-between;border:1px solid var(--border);border-radius:10px;padding:12px 14px;color:inherit;transition:background .12s,border-color .12s}.mod-btn:hover{text-decoration:none;border-color:var(--blue);background:#f6faff}.mod-btn.listening:hover{border-color:#6b46c1;background:#f7f4fd}.mod-btn .mb-type{font-weight:700}.mod-btn .mb-meta{font-size:13px;color:#888}.startscreen{min-height:100vh;display:flex;flex-direction:column;align-items:stretch;padding:18px 24px 24px;background:#f6f6f7}.startscreen .site-header-wrap{width:100%;max-width:1080px;margin:0 auto 12px}.startscreen-body{flex:1 1;display:flex;align-items:center;justify-content:center}.start-card{background:#fff;border:1px solid var(--border);border-radius:18px;padding:30px 34px;max-width:620px;width:100%;box-shadow:0 12px 40px rgba(0,0,0,.08)}.start-card h1{font-size:27px;margin:4px 0}.start-card .back-link{display:inline-block;margin-bottom:8px}.mode-choose,.soundcheck{margin-top:22px;padding-top:18px;border-top:1px solid var(--border)}.mode-choose h3,.soundcheck h3{margin:0 0 8px;font-size:16px}.sc-row{gap:16px;flex-wrap:wrap;margin-top:10px}.sc-row,.vol{display:flex;align-items:center}.vol{gap:8px}.vol input[type=range]{width:130px}.ok-tick{color:var(--green);font-weight:600;font-size:13px}.mode-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.mode-card{text-align:left;border:2px solid var(--border);border-radius:12px;padding:14px;background:#fff;cursor:pointer}.mode-card.sel{border-color:var(--ielts-red);background:#fff7f6}.mc-title{font-weight:700;margin-bottom:4px}.mc-desc{font-size:13px;color:#666}.start-actions{display:flex;gap:12px;margin-top:24px}.exam-audio{display:flex;align-items:center;gap:16px;flex:1 1}.ea-status{font-weight:700;font-size:13.5px;color:var(--ielts-dark);min-width:120px}.ea-bar{flex:1 1;max-width:720px;height:8px;background:#d9dee7;border-radius:6px;overflow:hidden}.ea-fill{height:100%;background:#6b46c1;transition:width .25s linear}.autosave{font-size:12px;color:var(--green);font-weight:600}@media (max-width:1024px){.home{padding:22px 18px 70px}.hero h1{font-size:32px}.book-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.topbar{flex-wrap:wrap;height:auto;padding:8px 14px;gap:8px}.cand-name{font-size:13px}.content{padding:18px 18px 36px}.icon-btn,.timer{padding:8px 12px}.dot{width:32px;height:32px}.mod-btn{padding:14px 16px}.tab{padding:10px 20px}}@media (max-width:760px){.hero{padding:22px 20px}.mode-grid{grid-template-columns:1fr}.controls{flex-direction:column;align-items:stretch}.search{max-width:none}.start-actions{flex-direction:column}.start-actions .btn{width:100%;text-align:center}.navbar{flex-direction:column}.nav-right{border-left:none;border-top:1px solid var(--border);justify-content:space-between;padding:8px 14px}.reading-split{grid-template-columns:1fr;height:auto}.reading-split .col.left{border-right:none;border-bottom:2px solid var(--border);max-height:45vh}.audiobar{padding:8px 12px;gap:10px}.pa-vol input[type=range]{width:60px}.pa-time{min-width:32px;font-size:12px}.nav-parts{gap:6px;padding:0 8px}.nav-part{padding:0 8px;min-width:auto}.nav-part.active{flex:1 1 auto;min-width:0;max-width:100%}.navbar .dot{width:24px;height:24px;flex-shrink:0}.np-title{font-size:12px}.np-count{display:none}.match-layout{flex-direction:column}.content:not(.reading-content)>.block-body{max-width:none}.gapfill table{display:block;overflow-x:auto}.blank input{width:120px}.topbar .center{flex-wrap:wrap;gap:6px}.review{padding:20px 14px 60px}.bp-row{grid-template-columns:130px 1fr 50px;gap:8px}}@media (hover:none){.book-card:hover,.resume-card:hover{transform:none}}.logo{display:inline-flex;align-items:center;gap:10px}.logo-word{font-weight:800;font-size:18px;color:var(--ink);letter-spacing:-.02em}.logo-accent{color:var(--ielts-red)}.site-header-wrap{margin-bottom:18px}.site-header{display:flex;align-items:center;justify-content:space-between;padding:6px 0 14px;border-bottom:1px solid var(--border)}.header-logo{display:inline-flex}.header-logo:hover{text-decoration:none}.header-nav{display:flex;gap:6px}.header-nav a{padding:8px 16px;border-radius:9px;color:var(--muted);font-weight:600;transition:background .12s ease,color .12s ease}.header-nav a:hover{background:var(--surface-2);text-decoration:none;color:var(--ink)}.menu-btn{width:42px;height:42px;border-radius:10px;color:var(--ielts-dark);align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.menu-btn,.mobile-nav{display:none;border:1px solid var(--border);background:#fff}.mobile-nav{flex-direction:column;gap:4px;border-radius:12px;padding:8px;margin:8px 0 4px;box-shadow:0 10px 30px rgba(0,0,0,.08)}.mobile-nav a{padding:12px 14px;border-radius:8px;font-weight:600;color:var(--ink)}.mobile-nav a:hover{background:var(--surface-2);text-decoration:none}.header-nav a.on,.mobile-nav a.on{background:#fdecea;color:var(--ielts-red)}.breadcrumbs{font-size:13px;padding-top:12px}.breadcrumbs,.breadcrumbs a{color:var(--muted)}.breadcrumbs a:hover{color:var(--ielts-red)}.crumb-sep{margin:0 8px;color:#c8ccd2}.crumb-cur{color:var(--ink);font-weight:600}.book-card,.panel,.resume-card,.stat-card,.test-card{transition:box-shadow .16s ease,transform .16s ease,border-color .16s ease}.book-card{box-shadow:var(--shadow-sm)}.book-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong)}.hero{box-shadow:var(--shadow-sm)}.stat-cards{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:14px;gap:14px;margin:20px 0 26px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;text-align:center;box-shadow:var(--shadow-sm)}.sc-big{font-size:38px;font-weight:800;line-height:1;letter-spacing:-.02em}.sc-big.accent{color:var(--ielts-red)}.sc-cap{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-top:8px}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px;margin-bottom:18px;box-shadow:var(--shadow-sm)}.trend{width:100%;height:auto}.weak-row{display:flex;align-items:center;gap:14px;margin:9px 0}.wr-label{width:210px;font-size:14px;font-weight:600;flex-shrink:0}.wr-bar{flex:1 1;height:12px;background:#eef0f3;overflow:hidden}.wr-bar,.wr-fill{border-radius:7px}.wr-fill{height:100%;transition:width .5s ease}.wr-pct{width:96px;text-align:right;font-size:13px;font-weight:600;flex-shrink:0}.attempts{margin-top:14px}.attempt-row{display:flex;align-items:center;gap:14px;padding:11px 4px;border-bottom:1px solid var(--border);font-size:14px}.attempt-row:last-child{border-bottom:none}.ar-title{font-weight:600;flex:1 1;min-width:120px}.ar-score{color:var(--muted)}.ar-band{font-weight:700;color:var(--ielts-red)}.ar-date{font-size:13px}.ar-retake{font-weight:600}.empty-state{text-align:center;padding:60px 20px;border:1px dashed var(--border-strong);border-radius:18px;margin-top:20px}.es-emoji{font-size:46px}.empty-state h2{margin:10px 0 6px}.empty-state p{max-width:440px;margin:0 auto 18px}@media (max-width:760px){.stat-cards{grid-template-columns:1fr 1fr}.wr-label{width:120px;font-size:13px}.attempt-row{flex-wrap:wrap;gap:8px}.site-header{flex-wrap:nowrap;gap:10px}.header-logo{flex-shrink:0}.logo-word{white-space:nowrap;font-size:15px}.header-nav{display:none}.menu-btn{display:inline-flex}.mobile-nav{display:flex}.breadcrumbs{flex-wrap:wrap}}