/* ============================================================================
   The PTE Master — shared stylesheet (landing tokens reused across all app pages)
   ========================================================================== */
:root{
  --ink:#15171f; --ink-soft:#3f4554; --mut:#5a616d;
  --paper:#f6f3ec; --paper-2:#efeae0; --card:#fffdf9; --line:#e7e1d5;
  --accent:#2f6df6; --accent-deep:#1b4ed8; --gold:#dd8a1c; --star:#e8a317;
  --good:#1f9d57; --warn:#dd8a1c; --bad:#d4493e;
  --ring:rgba(47,109,246,.16);
  --radius:18px; --radius-sm:11px;
  --shadow:0 1px 0 rgba(0,0,0,.02), 0 22px 48px -30px rgba(20,30,60,.30);
  --display:"Fraunces",Georgia,serif; --body:"Plus Jakarta Sans",system-ui,sans-serif;
  --maxw:1120px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--body);color:var(--ink);background:var(--paper);line-height:1.6}
h1,h2,h3,h4{font-family:var(--display);font-weight:600;letter-spacing:-.015em;margin:0;color:var(--ink)}
p{margin:0}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.muted{color:var(--mut)} .soft{color:var(--ink-soft)} .small{font-size:14px}
.center{text-align:center}
svg.ico{width:100%;height:100%;display:block;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
svg.ico.fill{fill:currentColor;stroke:none}
a:focus-visible,button:focus-visible,select:focus-visible,textarea:focus-visible,summary:focus-visible,[tabindex]:focus-visible{outline:3px solid var(--accent);outline-offset:2px;border-radius:8px}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--body);font-weight:600;font-size:15px;
  border:none;border-radius:12px;padding:13px 22px;cursor:pointer;background:var(--accent);color:#fff;transition:background .15s,transform .15s,box-shadow .15s;text-align:center}
.btn:hover{background:var(--accent-deep);transform:translateY(-1px)}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.btn .ico{width:17px;height:17px}
.btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn.ghost:hover{background:#efeae0;transform:none}
.btn.lg{padding:15px 26px;font-size:16px}
.btn.sm{padding:9px 15px;font-size:14px;border-radius:10px}
.pill{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;padding:5px 12px;border-radius:999px;background:#eef2ff;color:var(--accent-deep)}
.pill.gold{background:#fdf2dd;color:#6d4a0a}
.pill.good{background:#eefaf2;color:#136b3c}
.pill.bad{background:#fdeeec;color:#a3362d}
.dot{width:11px;height:11px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px var(--ring)}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--display);font-weight:700;font-size:21px;color:var(--ink)}

/* simple app header (non-landing pages) */
.appbar{position:sticky;top:0;z-index:40;background:rgba(246,243,236,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.appbar .row{display:flex;align-items:center;justify-content:space-between;height:64px}
.appbar a.back{display:inline-flex;align-items:center;gap:7px;font-weight:600;color:var(--ink-soft);font-size:14.5px}
.appbar a.back .ico{width:16px;height:16px}

.section-head{max-width:var(--maxw);margin:0 auto;padding:40px 22px 6px}
.eyebrow{font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--accent-deep)}
.h2{font-size:clamp(26px,3.2vw,38px);line-height:1.12;margin:10px 0 10px}
.lead{font-size:17px;color:var(--ink-soft);max-width:42em}

/* ---------- TEST SELECTION (tests.html) ---------- */
.toggle-pills{display:inline-flex;gap:4px;background:var(--paper-2);border:1px solid var(--line);border-radius:999px;padding:5px}
.toggle-pills button{border:none;background:transparent;font-family:var(--body);font-weight:600;font-size:14.5px;padding:10px 22px;border-radius:999px;cursor:pointer;color:var(--ink-soft)}
.toggle-pills button.on{background:var(--card);color:var(--ink);box-shadow:0 1px 2px rgba(0,0,0,.07)}
.testinfo{max-width:var(--maxw);margin:22px auto 0;padding:0 22px}
.testinfo .inner{display:flex;align-items:center;gap:10px;background:var(--paper-2);border:1px solid var(--line);border-radius:12px;padding:12px 16px;font-size:13.5px;color:var(--ink-soft)}
.testinfo .inner .ico{width:17px;height:17px;color:var(--accent-deep);flex:none}
.testgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;max-width:var(--maxw);margin:18px auto 30px;padding:0 22px}
.testcard{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:20px;display:flex;flex-direction:column;box-shadow:0 14px 34px -30px rgba(20,30,60,.4);transition:transform .15s,box-shadow .15s,border-color .15s;cursor:pointer}
.testcard:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:0 18px 40px -26px rgba(20,30,60,.55)}
.testcard .tc-top{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.testcard .tc-num{width:46px;height:46px;border-radius:12px;background:#eef2ff;color:var(--accent-deep);font-family:var(--display);font-weight:700;font-size:18px;display:grid;place-items:center;flex:none;font-variant-numeric:tabular-nums}
.testcard .tc-tag{margin-left:auto;font-size:10.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--mut);background:var(--paper-2);border:1px solid var(--line);padding:4px 9px;border-radius:999px}
.testcard h3{font-size:19px;margin-bottom:3px}
.testcard .tc-meta{font-size:13px;color:var(--mut);font-weight:500;margin-bottom:16px}
.testcard .tc-start{margin-top:auto}
.testcard .tc-start .btn{width:100%}

/* ---------- EXAM PLAYER (test.html) ---------- */
body.player{background:#eceae3}
.exam-top{position:sticky;top:0;z-index:30;background:var(--card);border-bottom:1px solid var(--line);box-shadow:0 1px 0 rgba(0,0,0,.03)}
.exam-top .row{display:flex;align-items:center;justify-content:space-between;gap:16px;height:58px;max-width:1000px;margin:0 auto;padding:0 20px}
.exam-top .brand{font-size:17px}
.exam-top .mid{display:flex;align-items:center;gap:14px;font-size:13.5px;color:var(--ink-soft);font-weight:600}
.exam-top .timer{display:inline-flex;align-items:center;gap:7px;background:var(--paper-2);border:1px solid var(--line);border-radius:999px;padding:6px 13px;font-variant-numeric:tabular-nums}
.exam-top .timer .ico{width:15px;height:15px;color:var(--accent-deep)}
.exam-top .qcount{font-variant-numeric:tabular-nums}
.exam-top .exit{font-size:13.5px;font-weight:600;color:var(--mut);cursor:pointer;background:none;border:none}
.exam-top .exit:hover{color:var(--bad)}
.progress{height:4px;background:var(--paper-2)}
.progress .bar{height:100%;background:linear-gradient(90deg,var(--accent),#6f9bff);width:0;transition:width .3s}

.exam-wrap{max-width:1000px;margin:0 auto;padding:24px 20px 130px}
.task-banner{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.task-banner .ic{width:40px;height:40px;border-radius:11px;background:#eef2ff;color:var(--accent-deep);display:grid;place-items:center;flex:none}
.task-banner .ic .ico{width:21px;height:21px}
.task-banner .tt{font-family:var(--display);font-weight:600;font-size:20px}
.task-banner .sec{font-size:12.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--mut)}
.instruction{background:#f4f7ff;border:1px solid #d8e2fb;border-left:3px solid var(--accent);border-radius:0 12px 12px 0;padding:12px 16px;font-size:14.5px;color:var(--ink-soft);margin-bottom:20px}

.qcard{background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:26px}
.passage{font-size:16.5px;line-height:1.85;color:var(--ink);white-space:pre-wrap}
.qtext{font-size:16px;font-weight:600;margin:18px 0 6px}

/* options (radio / checkbox) */
.opts{display:flex;flex-direction:column;gap:11px;margin-top:14px}
.opt{display:flex;gap:12px;align-items:flex-start;border:1px solid var(--line);background:#fff;border-radius:12px;padding:14px 16px;cursor:pointer;transition:border-color .15s,background .15s}
.opt:hover{border-color:var(--accent);background:#f7f9ff}
.opt.sel{border-color:var(--accent);background:#eef3ff;box-shadow:0 0 0 2px var(--ring)}
.opt input{margin-top:3px;width:18px;height:18px;accent-color:var(--accent);flex:none}
.opt .ol{font-weight:700;color:var(--accent-deep);flex:none}
.opt .otext{font-size:15.5px;line-height:1.55}

/* cloze blanks */
.cloze{font-size:16.5px;line-height:2.1;color:var(--ink)}
.cloze select,.cloze input.blank{font-family:var(--body);font-size:15px;border:1.5px solid var(--accent);border-radius:8px;padding:4px 8px;background:#fff;color:var(--accent-deep);font-weight:600;margin:0 2px;min-width:90px}
.cloze input.blank{min-width:110px;color:var(--ink)}
.cloze .drop{display:inline-block;min-width:118px;border-bottom:2px dashed var(--accent);text-align:center;padding:2px 8px;margin:0 3px;color:var(--accent-deep);font-weight:600;background:#f4f7ff;border-radius:6px 6px 0 0;min-height:30px;vertical-align:middle;cursor:pointer}
.cloze .drop.filled{background:#eef3ff;border-bottom-style:solid}
.cloze .drop.over{background:#dde8ff}
.wordbank{display:flex;flex-wrap:wrap;gap:9px;margin-top:22px;padding-top:18px;border-top:1px dashed var(--line)}
.wordbank .chip{font-size:14.5px;font-weight:600;border:1px solid var(--line);background:#fff;border-radius:10px;padding:9px 14px;cursor:grab;user-select:none;transition:border-color .15s,background .15s}
.wordbank .chip:hover{border-color:var(--accent);background:#f7f9ff}
.wordbank .chip.used{opacity:.35;cursor:default;pointer-events:none}
.wordbank .chip.sel{border-color:var(--accent);background:#eef3ff;box-shadow:0 0 0 2px var(--ring)}

/* reorder */
.reorder{display:flex;flex-direction:column;gap:10px;margin-top:6px}
.reorder .ri{display:flex;align-items:center;gap:12px;border:1px solid var(--line);background:#fff;border-radius:12px;padding:12px 14px}
.reorder .ri .grip{font-weight:700;color:var(--mut);font-variant-numeric:tabular-nums;flex:none;width:22px}
.reorder .ri .body{font-size:15px;line-height:1.55;flex:1}
.reorder .ri .arrows{display:flex;flex-direction:column;gap:3px;flex:none}
.reorder .ri .arrows button{border:1px solid var(--line);background:var(--paper-2);border-radius:7px;width:30px;height:24px;cursor:pointer;display:grid;place-items:center;color:var(--ink-soft)}
.reorder .ri .arrows button:hover{border-color:var(--accent);color:var(--accent-deep)}
.reorder .ri .arrows button .ico{width:14px;height:14px}

/* highlight incorrect words */
.hiw-text{font-size:17px;line-height:2.1}
.hiw-text .w{cursor:pointer;border-radius:5px;padding:1px 2px}
.hiw-text .w:hover{background:#fdeeec}
.hiw-text .w.sel{background:var(--bad);color:#fff;font-weight:600}

/* audio + recorder */
.audiobox{display:flex;align-items:center;gap:14px;background:#f0f4ff;border:1px solid #d8e2fb;border-radius:14px;padding:14px 16px;margin-bottom:18px}
.audiobox .ic{width:40px;height:40px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;flex:none}
.audiobox .ic .ico{width:20px;height:20px}
.audiobox .meta b{font-size:14.5px;display:block}
.audiobox .meta span{font-size:13px;color:var(--mut)}
.audiobox button.play{margin-left:auto;border:1px solid var(--line);background:#fff;border-radius:10px;padding:9px 15px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:7px;font-size:14px}
.audiobox button.play .ico{width:15px;height:15px;color:var(--accent-deep)}
.wave{display:flex;align-items:center;gap:3px;height:22px}
.wave i{width:3px;background:var(--accent);border-radius:2px;height:30%;animation:wv 1s ease-in-out infinite}
.wave i:nth-child(2){animation-delay:.1s}.wave i:nth-child(3){animation-delay:.2s}.wave i:nth-child(4){animation-delay:.3s}.wave i:nth-child(5){animation-delay:.4s}
@keyframes wv{0%,100%{height:25%}50%{height:95%}}

.recorder{display:flex;flex-direction:column;align-items:center;gap:14px;border:1px dashed var(--line);border-radius:14px;padding:24px;margin-top:20px;background:#fbfaf6}
.recorder .rbtn{width:74px;height:74px;border-radius:50%;border:none;background:var(--accent);color:#fff;cursor:pointer;display:grid;place-items:center;box-shadow:0 10px 24px -10px rgba(47,109,246,.6);transition:transform .15s,background .15s}
.recorder .rbtn:hover{transform:translateY(-2px)}
.recorder .rbtn.rec{background:var(--bad);animation:pulse 1.4s infinite}
.recorder .rbtn .ico{width:30px;height:30px}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(212,73,62,.5)}70%{box-shadow:0 0 0 16px rgba(212,73,62,0)}100%{box-shadow:0 0 0 0 rgba(212,73,62,0)}}
.recorder .rstate{font-size:14px;color:var(--ink-soft);font-weight:600}
.recorder audio{margin-top:4px;width:100%;max-width:360px}
.recorder .rbtn{cursor:default}
.recorder .rbtn.idle{background:var(--paper-2);color:var(--accent-deep);box-shadow:none}
.recorder .rbtn.done{background:var(--good);box-shadow:0 10px 24px -12px rgba(31,157,87,.6)}
.recorder .rbtn:hover{transform:none}
.rec-timer{font-family:var(--display);font-size:22px;font-weight:600;color:var(--ink)}
.rec-bar{width:100%;max-width:320px;height:8px;background:#ece6db;border-radius:99px;overflow:hidden}
.rec-bar i{display:block;height:100%;width:0;background:var(--accent);border-radius:99px;transition:width .9s linear}
.rec-bar.live i{background:var(--bad)}
.rec-skip{border:1px solid var(--line);background:#fff;border-radius:10px;padding:8px 15px;font-weight:600;cursor:pointer;font-size:13.5px;color:var(--ink-soft)}
.rec-skip:hover{border-color:var(--accent);color:var(--accent-deep)}
.pending-note{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:700;color:var(--accent-deep);background:#eef2ff;padding:5px 11px;border-radius:999px}
.pending-note .ico{width:13px;height:13px}

/* writing */
.writebox textarea{width:100%;min-height:200px;border:1px solid var(--line);border-radius:12px;padding:14px 16px;font-family:var(--body);font-size:15.5px;line-height:1.7;color:var(--ink);resize:vertical;background:#fff}
.writebox textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--ring)}
.wc{display:flex;justify-content:space-between;align-items:center;margin-top:10px;font-size:13.5px;color:var(--mut)}
.wc b{color:var(--ink)} .wc .inrange{color:var(--good);font-weight:700}.wc .outrange{color:var(--warn);font-weight:700}

.describe-img{background:#fbf9f3;border:1px solid var(--line);border-radius:12px;padding:20px;font-size:15.5px;line-height:1.7;color:var(--ink-soft);position:relative}
.describe-img .tag{position:absolute;top:10px;right:12px;font-size:11px;font-weight:700;color:var(--mut)}

/* bottom bar */
.exam-bottom{position:fixed;bottom:0;left:0;right:0;background:var(--card);border-top:1px solid var(--line);box-shadow:0 -2px 18px -12px rgba(0,0,0,.3);z-index:30}
.exam-bottom .row{max-width:1000px;margin:0 auto;padding:14px 20px;display:flex;align-items:center;justify-content:space-between;gap:14px}
.exam-bottom .status{font-size:13.5px;color:var(--mut);font-weight:600}

/* ---------- RESULTS (results.html) ---------- */
.score-hero{background:var(--card);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);padding:32px;display:grid;grid-template-columns:auto 1fr;gap:32px;align-items:center;margin:28px auto;max-width:var(--maxw)}
.ring{--p:0;width:148px;height:148px;border-radius:50%;display:grid;place-items:center;flex:none;
  background:conic-gradient(var(--accent) calc(var(--p)*1%), var(--paper-2) 0);}
.ring .inner{width:118px;height:118px;border-radius:50%;background:var(--card);display:grid;place-items:center;text-align:center}
.ring .inner b{font-family:var(--display);font-size:34px;line-height:1}
.ring .inner span{font-size:12px;color:var(--mut);font-weight:600}
.score-hero h1{font-size:28px;margin-bottom:6px}
.secbreak{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin-top:16px}
.secbox{border:1px solid var(--line);background:#fff;border-radius:12px;padding:14px 16px}
.secbox .nm{font-size:12.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--mut)}
.secbox .v{font-family:var(--display);font-size:22px;margin-top:3px}
.secbox .sub{font-size:12.5px;color:var(--mut)}
.reviewlist{max-width:var(--maxw);margin:10px auto 70px;padding:0 22px;display:flex;flex-direction:column;gap:10px}
.rev{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 16px}
.rev summary{cursor:pointer;list-style:none;display:flex;align-items:center;gap:12px;font-weight:600;font-size:14.5px}
.rev summary::-webkit-details-marker{display:none}
.rev .badge{flex:none;width:24px;height:24px;border-radius:50%;display:grid;place-items:center}
.rev .badge.ok{background:#eefaf2;color:var(--good)} .rev .badge.part{background:#fdf2dd;color:#9a610c} .rev .badge.no{background:#fdeeec;color:var(--bad)} .rev .badge.pend{background:#eef2ff;color:var(--accent-deep)}
.rev .badge .ico{width:14px;height:14px}
.rev .qn{flex:none;color:var(--mut);font-variant-numeric:tabular-nums;font-size:13px}
.rev .tt{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rev .pts{flex:none;font-size:13px;font-weight:700;color:var(--ink-soft)}
.rev .detail{margin-top:12px;font-size:14px;color:var(--ink-soft);line-height:1.6;border-top:1px solid var(--line);padding-top:12px}
.rev .detail .k{font-weight:700;color:var(--ink)}
.rev .detail .yours{color:var(--bad)} .rev .detail .right{color:var(--good)}

/* ---------- EXAM FLOW: mode chooser, part/task screens, timers, pause (examflow.js + test.html) ---------- */

/* Mode chooser on tests.html */
.modechoice{display:grid;grid-template-columns:1fr 1fr;gap:14px;max-width:var(--maxw);margin:18px auto 0;padding:0 22px}
.modecard{position:relative;text-align:left;background:var(--card);border:1.5px solid var(--line);border-radius:16px;padding:20px;cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .15s;font-family:var(--body)}
.modecard:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 16px 36px -28px rgba(20,30,60,.5)}
.modecard.on{border-color:var(--accent);box-shadow:0 0 0 3px var(--ring)}
.modecard .mc-top{display:flex;align-items:center;gap:11px;margin-bottom:8px}
.modecard .mc-ic{width:40px;height:40px;border-radius:11px;background:#eef2ff;color:var(--accent-deep);display:grid;place-items:center;flex:none}
.modecard .mc-ic .ico{width:21px;height:21px}
.modecard h3{font-size:18px;margin:0}
.modecard .mc-tag{margin-left:auto;font-size:10.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--mut);background:var(--paper-2);border:1px solid var(--line);padding:4px 9px;border-radius:999px}
.modecard p{font-size:13.5px;color:var(--ink-soft);margin:0 0 10px;line-height:1.55}
.modecard ul{margin:0;padding:0 0 0 2px;list-style:none;display:flex;flex-direction:column;gap:5px}
.modecard li{display:flex;gap:8px;align-items:flex-start;font-size:13px;color:var(--mut)}
.modecard li .ico{width:14px;height:14px;color:var(--good);flex:none;margin-top:3px}
.modecard li.no .ico{color:var(--mut)}
.modecard .mc-check{position:absolute;top:16px;right:16px;width:22px;height:22px;border-radius:50%;border:2px solid var(--line);display:grid;place-items:center;color:#fff}
.modecard.on .mc-check{background:var(--accent);border-color:var(--accent)}
.modecard.on .mc-check .ico{width:13px;height:13px}
.modecard:not(.on) .mc-check .ico{display:none}

/* Resume banner */
.resume-banner{max-width:var(--maxw);margin:18px auto 0;padding:0 22px}
.resume-banner .inner{display:flex;align-items:center;gap:14px;flex-wrap:wrap;background:#fff8ec;border:1px solid #f0dcb5;border-left:3px solid var(--gold);border-radius:0 12px 12px 0;padding:14px 18px}
.resume-banner .rb-txt{flex:1;min-width:200px;font-size:14px;color:var(--ink-soft)}
.resume-banner .rb-txt b{color:var(--ink)}
.resume-banner .rb-actions{display:flex;gap:8px;flex-wrap:wrap}

/* Full-screen flow overlays (warm-up / part intro / task intro / time-up) — reuse the .intro look */
.mmflow-screen{position:fixed;inset:0;background:rgba(20,23,31,.6);backdrop-filter:blur(5px);display:grid;place-items:center;z-index:70;padding:20px;overflow:auto}
.mmflow-screen .box{background:var(--card);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);max-width:560px;width:100%;padding:34px;text-align:center;animation:mmflow-in .25s ease}
@keyframes mmflow-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.mmflow-screen h1{font-size:27px;margin-bottom:10px}
.mmflow-screen p{color:var(--ink-soft);font-size:15.5px;margin-bottom:8px;line-height:1.6}
.mmflow-eyebrow{font-size:12.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-deep);margin-bottom:6px}
.mmflow-screen .facts{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin:18px 0 6px}
.mmflow-screen .facts .chiplet{font-size:13px;font-weight:600;color:var(--ink-soft);background:var(--paper-2);border:1px solid var(--line);border-radius:999px;padding:7px 13px}
.mmflow-screen .facts .chiplet b{color:var(--ink)}
.mmflow-skip{display:block;margin:12px auto 0;background:none;border:none;color:var(--mut);font-family:var(--body);font-weight:600;font-size:13.5px;cursor:pointer;text-decoration:underline}
.mmflow-skip:hover{color:var(--accent-deep)}
.icon-task{color:var(--accent-deep)}

/* Part timer in the top chrome (counts DOWN). Warns under 2 min, critical under 30s. */
.exam-top .timer.down.warn{background:#fdf2dd;border-color:#f0dcb5;color:#8a5a08}
.exam-top .timer.down.warn .ico{color:#b8770f}
.exam-top .timer.down.crit{background:#fdeeec;border-color:#f0c8c2;color:#a3362d;animation:tpulse 1s infinite}
.exam-top .timer.down.crit .ico{color:#a3362d}
@keyframes tpulse{0%,100%{opacity:1}50%{opacity:.55}}
.exam-top .partlabel{font-weight:700;color:var(--ink)}

/* Speaking recording-status banner (sits above render.js's recorder) */
.rec-status{display:flex;align-items:center;gap:12px;background:#fbf6ec;border:1px solid #f0dcb5;border-radius:14px;padding:13px 16px;margin-top:6px}
.rec-status .rs-ic{width:38px;height:38px;border-radius:50%;background:var(--gold);color:#fff;display:grid;place-items:center;flex:none}
.rec-status .rs-ic .ico{width:19px;height:19px}
.rec-status.live .rs-ic{background:var(--bad);animation:pulse 1.4s infinite}
.rec-status.done .rs-ic{background:var(--good)}
.rec-status .rs-meta b{font-size:14.5px;display:block;color:var(--ink)}
.rec-status .rs-meta span{font-size:13px;color:var(--mut)}
.rec-status .rs-count{margin-left:auto;font-family:var(--display);font-weight:600;font-size:20px;color:var(--ink);font-variant-numeric:tabular-nums}

/* Pause button + paused overlay (Practice mode) */
.exam-top .pausebtn{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--ink-soft);background:var(--paper-2);border:1px solid var(--line);border-radius:999px;padding:6px 13px;cursor:pointer}
.exam-top .pausebtn:hover{border-color:var(--accent);color:var(--accent-deep)}
.exam-top .pausebtn .ico{width:14px;height:14px}
.paused-overlay{position:fixed;inset:0;background:rgba(20,23,31,.78);backdrop-filter:blur(7px);display:grid;place-items:center;z-index:80;padding:20px}
.paused-overlay .box{background:var(--card);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);max-width:420px;width:100%;padding:36px;text-align:center}
.paused-overlay h2{font-size:26px;margin-bottom:8px}
.paused-overlay p{color:var(--ink-soft);font-size:15px;margin-bottom:20px}

/* Listening "Playing…" inline status reuses .audiobox; nothing extra needed. */

@media(max-width:640px){
  .score-hero{grid-template-columns:1fr;text-align:center;justify-items:center}
  .exam-wrap{padding:18px 16px 130px}
  .qcard{padding:18px}
  .modechoice{grid-template-columns:1fr}
  .exam-top .row{flex-wrap:wrap;height:auto;padding:9px 14px;gap:8px}
  .exam-top .mid{order:3;width:100%;justify-content:flex-start;flex-wrap:wrap;gap:8px}
  .mmflow-screen .box{padding:26px 22px}
  .mmflow-screen h1{font-size:23px}
}

/* ============================================================================
   ███  REAL-EXAM RESKIN  ███
   Clinical "Pearson Scored Test"-style look for the in-exam player. Scoped under
   body.player so the marketing pages keep the warm Fraunces theme untouched.
   Palette: white #fff bg · dark-gray #333 text · light #ccc/#ddd borders ·
   teal top bar #2b8caa · navy strip #16205a · blue buttons/progress #2d6c9e ·
   pale-yellow selection #fff8cc · red recorder status #c0392b. Plain Arial.
   ========================================================================== */
:root{
  --pte-teal:#2b8caa; --pte-teal-dark:#1f6e87; --pte-navy:#16205a;
  --pte-blue:#2d6c9e; --pte-blue-dark:#255b85; --pte-ink:#333; --pte-soft:#555;
  --pte-line:#ccc; --pte-line-2:#ddd; --pte-grayhdr:#6f6f6f; --pte-ctrl:#e9e9e9;
  --pte-red:#c0392b; --pte-yellow:#fff8cc; --pte-sans:Arial,Helvetica,"Segoe UI",system-ui,sans-serif;
}
body.player{background:#fff;color:var(--pte-ink);font-family:var(--pte-sans);line-height:1.55}
body.player h1,body.player h2,body.player h3,body.player h4{font-family:var(--pte-sans);font-weight:600;letter-spacing:0;color:var(--pte-ink)}

/* ---- Teal top bar (full width) with dark square home cell + right links ---- */
body.player .exam-top{position:sticky;top:0;z-index:30;background:transparent;border:0;box-shadow:none}
body.player .exam-top .ptebar{display:flex;align-items:stretch;height:48px;
  background:linear-gradient(180deg,#3094b1,#2b8caa);color:#fff}
body.player .exam-top .ptebar .home{width:54px;flex:none;display:grid;place-items:center;
  background:var(--pte-teal-dark);border-right:1px solid rgba(255,255,255,.18)}
body.player .exam-top .ptebar .home .ico{width:20px;height:20px;color:#fff;stroke-width:2}
body.player .exam-top .ptebar .spacer{flex:1}
body.player .exam-top .ptebar .tlink{display:inline-flex;align-items:center;font-size:13.5px;color:#fff;
  opacity:.95;padding:0 16px;background:none;border:0;cursor:pointer;font-family:var(--pte-sans);text-decoration:none}
body.player .exam-top .ptebar .tlink:hover{opacity:1;text-decoration:underline}
body.player .exam-top .ptebar .exit{display:inline-flex;align-items:center;align-self:center;margin-right:14px;
  font-size:12px;letter-spacing:.04em;color:#fff;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.65);border-radius:3px;padding:8px 12px;cursor:pointer;
  font-family:var(--pte-sans);font-weight:400}
body.player .exam-top .ptebar .exit:hover{background:rgba(255,255,255,.16);color:#fff}

/* navy strip above the teal bar — only on section/part-intro screens (body gets .intro-mode) */
body.player .exam-top .ptenavy{display:none;align-items:center;height:38px;background:var(--pte-navy);color:#fff;
  font-weight:700;font-size:18px;letter-spacing:.04em;padding:0 22px}
body.player.intro-mode .exam-top .ptenavy{display:flex}

/* ---- White sub-header: title left · counter · clock · navigator · progress ---- */
body.player .exam-sub{background:#fff;padding:18px 26px 0}
body.player .exam-sub .row2{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;
  max-width:none;margin:0;padding:0}
body.player .exam-sub .ttl{font-size:25px;font-weight:400;color:var(--pte-ink);line-height:1.1;font-family:var(--pte-sans)}
body.player .exam-sub .meta{display:flex;align-items:center;gap:18px;color:var(--pte-ink);font-size:13.5px;
  font-weight:400;padding-bottom:3px}
body.player .exam-sub .meta .qcount{font-variant-numeric:tabular-nums}
body.player .exam-sub .meta .qcount b{font-weight:700}
body.player .exam-sub .meta .timer{display:inline-flex;align-items:center;gap:7px;background:none;border:0;
  border-radius:0;padding:0;color:var(--pte-ink);font-variant-numeric:tabular-nums;font-weight:400}
body.player .exam-sub .meta .timer .ico{width:15px;height:15px;color:var(--pte-ink);stroke-width:2}
body.player .exam-sub .meta .timer.down.warn{background:none;border:0;color:#9a6a00}
body.player .exam-sub .meta .timer.down.warn .ico{color:#9a6a00}
body.player .exam-sub .meta .timer.down.crit{background:none;border:0;color:var(--pte-red);animation:tpulse 1s infinite}
body.player .exam-sub .meta .timer.down.crit .ico{color:var(--pte-red)}
body.player .exam-sub .meta .navbtn{display:inline-grid;place-items:center;width:34px;height:30px;
  border:1px solid var(--pte-line);background:#f4f4f4;border-radius:3px;color:#555;cursor:default}
body.player .exam-sub .meta .navbtn .ico{width:18px;height:18px;stroke-width:2}
body.player .exam-sub .pausebtn{display:none}

/* thin progress bar directly under the sub-header */
body.player .exam-top .progress{height:3px;background:#e3e3e3;margin:12px 26px 0;border-radius:0;overflow:hidden}
body.player .exam-top .progress .bar{height:100%;background:var(--pte-blue);transition:width .3s}

/* ---- Stage / instruction line ---- */
body.player .exam-wrap{max-width:none;margin:0;padding:18px 26px 110px}
body.player .task-banner{display:none}            /* the icon+title banner is not part of the real look */
body.player .instruction{background:none;border:0;border-radius:0;padding:0;margin:6px 0 24px;
  font-size:14px;font-style:italic;font-weight:700;color:var(--pte-ink);line-height:1.5}
body.player .qcard{background:none;border:0;border-radius:0;box-shadow:none;padding:0}
body.player .passage{font-size:14.5px;line-height:1.6;color:var(--pte-ink)}
body.player .qtext{font-size:14.5px;line-height:1.6;color:var(--pte-ink);margin:14px 0 4px;font-weight:400}

/* ---- The signature Audio box (recorder + player) ---- */
body.player .audiobox,body.player .recorder{display:block;max-width:480px;margin:26px auto 0;
  background:#fff;border:1px solid var(--pte-line);border-radius:2px;padding:0;text-align:center}
body.player .audiobox{margin-top:26px}
body.player .ab-head{padding:26px 16px 4px;min-height:96px;position:relative}
body.player .ab-head .ablabel{font-size:13.5px;font-weight:700;color:var(--pte-ink);letter-spacing:.01em}
body.player .ab-head .abstate{display:block;margin-top:18px;font-size:13px;color:var(--pte-red);min-height:16px}
/* right gutter line that the real boxes show (the thin vertical divider near the right edge) */
body.player .ab-head::after{content:"";position:absolute;top:0;right:46px;bottom:0;width:1px;background:#e2e2e2}
/* VU meter (recorder, while live) lives in that right gutter */
body.player .ab-vu{position:absolute;right:8px;bottom:14px;top:14px;width:30px;display:none;
  flex-direction:column-reverse;gap:2px;overflow:hidden}
body.player .recorder.live .ab-vu{display:flex}
body.player .ab-vu i{display:block;height:5px;background:#39b54a;opacity:.25;border-radius:1px}
body.player .ab-vu i.on{opacity:1}
/* control row */
body.player .ab-ctrl{display:flex;align-items:center;gap:10px;background:var(--pte-ctrl);
  border-top:1px solid var(--pte-line);padding:8px 12px}
body.player .ab-ctrl .cbtn{width:22px;height:22px;flex:none;display:grid;place-items:center;border:0;background:none;
  cursor:pointer;color:#555;padding:0}
body.player .ab-ctrl .cbtn .ico{width:15px;height:15px;stroke-width:2}
body.player .ab-ctrl .cbtn.dot{color:#e25b62}
body.player .ab-ctrl .cbtn.dot .ico{fill:currentColor;stroke:none}
body.player .ab-ctrl .ctime{font-size:12px;color:#444;font-variant-numeric:tabular-nums;white-space:nowrap}
body.player .ab-ctrl .cslider{flex:1;height:4px;background:#bdbdbd;border-radius:2px;position:relative}
body.player .ab-ctrl .cslider i{position:absolute;left:0;top:0;bottom:0;background:#8a8a8a;border-radius:2px;width:0}
body.player .ab-ctrl .cvol{width:18px;height:18px;flex:none;color:#555}
body.player .ab-ctrl .cvol .ico{width:18px;height:18px;stroke-width:2}
/* legacy bits no longer used by the box (kept hidden); old big mic button / bars / lines */
body.player .recorder .rbtn,body.player .recorder .rec-bar,body.player .recorder .rec-timer,
body.player .recorder .rstate{display:none!important}
/* manual "Start recording" button — shown only for warm-up / drill (auto exam mode hides it via JS) */
body.player .recorder .rec-skip{display:inline-block;margin:14px auto 0;font-family:var(--pte-sans);font-size:13px;
  font-weight:400;color:var(--pte-ink);background:#f1f1f1;border:1px solid var(--pte-line);border-radius:3px;
  padding:8px 16px;cursor:pointer}
body.player .recorder .rec-skip:hover{background:#e8e8e8}
body.player .recorder audio{display:block;margin:10px auto 12px;width:90%;max-width:430px}
body.player .recorder .transcript{font-size:12.5px;color:#777;font-style:italic;padding:0 16px 10px;text-align:center}
body.player .recorder .pending-note{display:none}
body.player .recorder .fluency{margin:0 auto 14px!important;max-width:430px!important}

/* ---- MCQ: plain radio rows; selected row pale yellow ---- */
body.player .opts{display:block;margin-top:6px}
body.player .opt{display:flex;gap:10px;align-items:flex-start;border:0;background:none;border-radius:0;
  padding:6px 8px;cursor:pointer;transition:background .1s}
body.player .opt:hover{border:0;background:#f4f4f4}
body.player .opt.sel{border:0;background:var(--pte-yellow);box-shadow:none}
body.player .opt input{margin-top:2px;width:14px;height:14px;accent-color:var(--pte-blue);flex:none}
body.player .opt .ol{display:none}
body.player .opt .otext{font-size:14px;line-height:1.5;color:var(--pte-ink)}
/* two-column reading MCQ: passage left, question+options right */
body.player .mcq-split{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:start}
body.player .mcq-split .mcq-passage{font-size:14px;line-height:1.65;color:var(--pte-ink)}
body.player .mcq-split .mcq-q .qtext{margin-top:0}

/* ---- Fill in the Blanks ---- */
body.player .cloze{font-size:14.5px;line-height:2.3;color:var(--pte-ink)}
body.player .cloze select{font-family:var(--pte-sans);font-size:13.5px;border:1px solid #9a9a9a;border-radius:0;
  padding:2px 4px;background:#f0f0f0;color:var(--pte-ink);font-weight:400;margin:0 3px;min-width:120px;vertical-align:middle}
body.player .cloze input.blank{font-family:var(--pte-sans);font-size:13.5px;border:1px solid #9a9a9a;border-radius:0;
  padding:3px 6px;background:#fff;color:var(--pte-ink);font-weight:400;margin:0 3px;min-width:120px;vertical-align:middle;box-shadow:inset 0 1px 2px rgba(0,0,0,.08)}
body.player .cloze .drop{display:inline-block;min-width:120px;border:1px dashed #8a8a8a;border-radius:0;
  text-align:center;padding:2px 8px;margin:0 3px;color:var(--pte-ink);font-weight:400;background:#fff;
  min-height:24px;vertical-align:middle;cursor:pointer}
body.player .cloze .drop.filled{background:#eef3ff;border-style:solid;border-color:#9a9a9a}
body.player .cloze .drop.over{background:#e3edff;border-color:var(--pte-blue)}
body.player .wordbank{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:26px;padding-top:0;
  border:0}
body.player .wordbank .chip{font-size:13.5px;font-weight:400;border:1px solid var(--pte-line);background:#f4f4f4;
  border-radius:2px;padding:7px 14px;cursor:grab;user-select:none}
body.player .wordbank .chip:hover{border-color:#9a9a9a;background:#ececec}
body.player .wordbank .chip.used{opacity:.3;pointer-events:none}
body.player .wordbank .chip.sel{border-color:var(--pte-blue);background:#e3edff;box-shadow:0 0 0 2px rgba(45,108,158,.2)}

/* ---- Re-order: Source | Target panels with gray headers + arrow controls ---- */
body.player .reorder{display:grid;grid-template-columns:1fr 44px 1fr 28px;gap:0 14px;align-items:start;margin-top:6px}
body.player .reorder .ro-col{border:1px solid var(--pte-line);background:#fff}
body.player .reorder .ro-hd{background:var(--pte-grayhdr);color:#fff;text-align:center;font-size:13px;font-weight:700;
  padding:8px 6px;letter-spacing:.02em}
body.player .reorder .ro-body{padding:0}
body.player .reorder .ri{display:flex;align-items:flex-start;gap:9px;border:0;border-bottom:1px solid var(--pte-line);
  background:#fff;border-radius:0;padding:10px 12px;cursor:grab}
body.player .reorder .ro-body .ri:last-child{border-bottom:0}
body.player .reorder .ri.sel{outline:2px solid var(--pte-blue);outline-offset:-2px}
body.player .reorder .ri.dragging{opacity:.45}
body.player .reorder .ri.dragover{background:#eef3ff}
body.player .reorder .ri .grip{flex:none;width:14px;color:#8a8a8a;font-weight:400;font-size:13px;line-height:1.5;cursor:grab}
body.player .reorder .ri .grip::before{content:"\2261"}        /* ≡ */
body.player .reorder .ri .grip span{display:none}              /* hide the numeric index */
body.player .reorder .ri .body{font-size:13px;line-height:1.5;flex:1;color:var(--pte-ink)}
body.player .reorder .ri .arrows{display:none}                 /* per-row up/down replaced by the column controls */
/* between-column ◄ ► (mid) and far-right ▲ ▼ */
body.player .reorder .ro-mid{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding-top:60px}
body.player .reorder .ro-side{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding-top:60px}
body.player .reorder .ro-arrow{width:26px;height:26px;display:grid;place-items:center;border:1px solid var(--pte-line);
  background:#f4f4f4;border-radius:3px;color:#555;cursor:pointer;font-size:12px;line-height:1;font-family:var(--pte-sans);padding:0}
body.player .reorder .ro-arrow:hover{background:#ececec;border-color:#9a9a9a}
body.player .reorder .ro-arrow:disabled{opacity:.4;cursor:default}
body.player .reorder .ro-empty{padding:16px;color:#aaa;font-size:12.5px;text-align:center}

/* ---- Highlight-incorrect-words ---- */
body.player .hiw-text{font-size:14.5px;line-height:2}
body.player .hiw-text .w{cursor:pointer;border-radius:0;padding:0 1px}
body.player .hiw-text .w:hover{background:#eee}
body.player .hiw-text .w.sel{background:var(--pte-yellow);color:var(--pte-ink);font-weight:400}

/* ---- Writing: Copy/Cut/Paste toolbar + word counter top-right ---- */
body.player .writebox{border:1px solid var(--pte-line);border-radius:2px;background:#fff;margin-top:18px}
body.player .writebox .wtoolbar{display:flex;align-items:center;gap:22px;border-bottom:1px solid var(--pte-line);
  padding:7px 12px;background:#fff}
body.player .writebox .wtoolbar button{background:none;border:0;font-family:var(--pte-sans);font-size:13px;
  color:var(--pte-ink);cursor:pointer;padding:0}
body.player .writebox .wtoolbar button:hover{text-decoration:underline}
body.player .writebox .wtoolbar .wc-top{margin-left:auto;font-size:13px;color:var(--pte-ink)}
body.player .writebox .wtoolbar .wc-top b{font-weight:700}
body.player .writebox textarea{width:100%;min-height:150px;border:0;border-radius:0;padding:12px 14px;
  font-family:var(--pte-sans);font-size:14px;line-height:1.6;color:var(--pte-ink);resize:vertical;background:#fff}
body.player .writebox textarea:focus{outline:none;box-shadow:none}
body.player .writebox.focus{outline:2px solid #9fc4e0;outline-offset:-1px}
body.player .writebox .wc{display:none}     /* old bottom counter hidden; counter now lives in the toolbar */
body.player .writebox + .pending-note,body.player .write-wrap .pending-note{display:none}

/* dictation single-line input ("Type here…") */
body.player .dict-input{width:100%;max-width:none;border:1px solid var(--pte-line);border-radius:2px;
  padding:9px 12px;font-family:var(--pte-sans);font-size:14px;color:var(--pte-ink);margin-top:18px;background:#fff}
body.player .dict-input:focus{outline:none;border-color:#9fc4e0;box-shadow:0 0 0 2px rgba(45,108,158,.15)}

/* ---- Describe Image / Re-tell Lecture: visual LEFT, recorder RIGHT ---- */
body.player .speak-split{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:34px;align-items:start;margin-top:4px}
body.player .speak-split .audiobox,body.player .speak-split .recorder{margin-top:14px}
body.player .describe-img{background:none;border:0;border-radius:0;padding:0;color:var(--pte-ink)}
body.player .describe-img .tag{display:none}

/* ---- Footer bar: Save and Exit (left) · Next / Finish (right) ---- */
body.player .exam-bottom{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--pte-line-2);
  box-shadow:none;z-index:30}
body.player .exam-bottom .row{max-width:none;margin:0;padding:14px 26px;display:flex;align-items:center;
  justify-content:space-between;gap:14px}
body.player .exam-bottom .status{display:none}
body.player .exam-bottom .savexit{display:inline-flex;align-items:center;gap:8px;font-family:var(--pte-sans);
  font-size:14px;font-weight:400;color:var(--pte-ink);background:#f1f1f1;border:1px solid var(--pte-line);
  border-radius:3px;padding:9px 16px;cursor:pointer}
body.player .exam-bottom .savexit:hover{background:#e8e8e8}
body.player .exam-bottom .savexit .ico{width:16px;height:16px;color:#555;stroke-width:2}
body.player #nextBtn{font-family:var(--pte-sans);font-size:14px;font-weight:400;color:#fff;
  background:var(--pte-blue);border:1px solid var(--pte-blue-dark);border-radius:3px;padding:9px 22px;cursor:pointer}
body.player #nextBtn:hover{background:var(--pte-blue-dark);transform:none}
body.player #nextBtn:disabled{opacity:.55;cursor:default}

/* ---- Section / part intro & flow overlays → full white "Continue" screen ---- */
body.player .mmflow-screen{position:fixed;inset:0;background:#fff;backdrop-filter:none;display:block;
  z-index:70;padding:0;overflow:auto}
body.player .mmflow-screen .box{background:#fff;border:0;border-radius:0;box-shadow:none;max-width:none;width:100%;
  padding:0;text-align:left;animation:none;min-height:100vh;position:relative;display:block}
body.player .mmflow-screen .pte-introbar .ptenavy{display:flex;align-items:center;height:38px;background:var(--pte-navy);
  color:#fff;font-weight:700;font-size:18px;letter-spacing:.04em;padding:0 22px}
body.player .mmflow-screen .pte-introbar .ptebar{display:flex;align-items:stretch;height:48px;
  background:linear-gradient(180deg,#3094b1,#2b8caa);color:#fff}
body.player .mmflow-screen .pte-introbar .ptebar .home{width:54px;flex:none;display:grid;place-items:center;
  background:var(--pte-teal-dark);border-right:1px solid rgba(255,255,255,.18)}
body.player .mmflow-screen .pte-introbar .ptebar .home .ico{width:20px;height:20px;color:#fff}
body.player .mmflow-screen .pte-introbar .ptebar .spacer{flex:1}
body.player .mmflow-screen .pte-introbar .ptebar .tlink{display:inline-flex;align-items:center;font-size:13.5px;
  color:#fff;opacity:.95;padding:0 16px;text-decoration:none}
body.player .mmflow-screen .pte-introbar .ptebar .exit{align-self:center;margin-right:14px;font-size:12px;color:#fff;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.65);border-radius:3px;padding:8px 12px}
body.player .mmflow-screen .pte-introbody{padding:30px 40px 120px}
body.player .mmflow-screen .pte-introbody h1{font-size:30px;font-weight:400;text-transform:uppercase;
  letter-spacing:.01em;color:var(--pte-ink);margin:6px 0 18px}
body.player .mmflow-screen .pte-introbody hr{border:0;border-top:1px solid var(--pte-line);margin:0 0 24px}
body.player .mmflow-screen .pte-introbody p{color:var(--pte-ink);font-size:14.5px;margin-bottom:10px;line-height:1.6}
body.player .mmflow-screen .pte-introbody p.pte-section{font-weight:700;font-size:16px;margin-bottom:14px}
body.player .mmflow-screen .mmflow-eyebrow{display:none}
body.player .mmflow-screen .task-banner{display:none}
body.player .mmflow-screen .facts{display:none}
body.player .mmflow-screen .small.muted{color:var(--pte-soft);font-size:13px}
/* centered Continue button just above the footer line */
body.player .mmflow-screen .box > .btn,body.player .mmflow-screen .pte-introfoot .btn{display:block;margin:30px auto 0;
  width:auto;min-width:200px;font-family:var(--pte-sans);font-size:15px;font-weight:400;color:#fff;
  background:var(--pte-blue);border:1px solid var(--pte-blue-dark);border-radius:3px;padding:11px 30px;text-align:center}
body.player .mmflow-screen .box > .btn:hover,body.player .mmflow-screen .pte-introfoot .btn:hover{background:var(--pte-blue-dark);transform:none}
body.player .mmflow-screen .pte-introfoot{position:absolute;left:0;right:0;bottom:0;border-top:1px solid var(--pte-line);
  padding:18px 0;background:#fff;text-align:center}
body.player .mmflow-screen .mmflow-skip{color:var(--pte-soft);font-family:var(--pte-sans)}
body.player .mmflow-screen .mmflow-skip:hover{color:var(--pte-blue)}

/* paused overlay keeps a clean white card */
body.player .paused-overlay{background:rgba(40,40,40,.5);backdrop-filter:none}
body.player .paused-overlay .box{background:#fff;border:1px solid var(--pte-line);border-radius:4px;box-shadow:0 10px 40px rgba(0,0,0,.25)}
body.player .paused-overlay h2{font-family:var(--pte-sans);font-weight:600}
body.player .paused-overlay .btn{background:var(--pte-blue);border:1px solid var(--pte-blue-dark);border-radius:3px;font-family:var(--pte-sans);font-weight:400}
body.player .paused-overlay .btn:hover{background:var(--pte-blue-dark)}

/* intro modal (the very first "Begin exam" gate in test.html) — keep simple/white */
body.player #intro{background:#fff}
body.player #intro .box{background:#fff;border:1px solid var(--pte-line);border-radius:4px;box-shadow:0 10px 40px rgba(0,0,0,.18);text-align:center}
body.player #intro h1{font-family:var(--pte-sans);font-weight:600}
body.player #intro .modebadge.exam{background:#eaf4f8;color:var(--pte-teal-dark)}
body.player #intro .modebadge.practice{background:#eef7f0;color:#1f6e87}
body.player #intro .btn{background:var(--pte-blue);border:1px solid var(--pte-blue-dark);border-radius:3px;font-family:var(--pte-sans);font-weight:400}
body.player #intro .btn:hover{background:var(--pte-blue-dark)}

@media(max-width:820px){
  body.player .mcq-split,body.player .speak-split{grid-template-columns:1fr;gap:20px}
  body.player .reorder{grid-template-columns:1fr 1fr;gap:0 8px}
  body.player .reorder .ro-mid,body.player .reorder .ro-side{display:none}
  body.player .exam-sub{padding:14px 16px 0}
  body.player .exam-sub .ttl{font-size:21px}
  body.player .exam-wrap{padding:16px 16px 110px}
  body.player .exam-top .progress{margin:12px 16px 0}
  body.player .exam-bottom .row{padding:12px 16px}
  body.player .mmflow-screen .pte-introbody{padding:24px 18px 110px}
}
