/* ── MCQ QUIZ ──────────────────────────────────────────────── */
.mcq-wrap {
  display:flex; flex-direction:column; gap:14px;
  padding:28px 36px; max-width:820px; margin:0 auto; width:100%;
  animation:mcq-fadein .35s cubic-bezier(.22,.68,0,1.1) both;
}

.mcq-progress-row { display:flex; align-items:center; gap:14px; margin-bottom:4px; }
.mcq-progress-label { font-size:11.5px; font-weight:700; color:var(--t3); white-space:nowrap; letter-spacing:.02em; }
.mcq-bar-track { flex:1; height:4px; background:var(--border); border-radius:4px; overflow:hidden; }
.mcq-bar-fill { height:100%; background:linear-gradient(90deg,var(--blue),#4DB8E8); border-radius:4px; transition:width .45s cubic-bezier(.4,0,.2,1); }
.mcq-score-chip { font-size:11px; font-weight:700; color:var(--blue); background:var(--blue-10); padding:3px 11px; border-radius:20px; white-space:nowrap; border:1px solid var(--blue-20); }
.mcq-timer-chip { font-size:11.5px; font-weight:700; color:var(--t2); background:var(--card); padding:3px 11px; border-radius:20px; white-space:nowrap; border:1.5px solid var(--border); font-variant-numeric:tabular-nums; transition:color .3s,background .3s,border-color .3s; letter-spacing:.04em; }
.mcq-timer-chip.warn   { color:#E07B20; background:#FDF0E3; border-color:#E07B20; }
.mcq-timer-chip.danger { color:#CC3A3A; background:#FBE8E8; border-color:#CC3A3A; animation:pulse-timer .6s ease-in-out infinite; }

/* Premium quiz loading screen */
.ql-wrap {
  display:flex;align-items:center;justify-content:center;
  min-height:420px;padding:48px 28px;
  animation:ql-fadein .65s cubic-bezier(.22,.68,0,1.2) both;
}
.ql-card {
  background:#fff;border-radius:24px;
  box-shadow:var(--sh-card);
  border:1px solid var(--border-s);
  padding:52px 56px;max-width:520px;width:100%;text-align:center;
}
.ql-badge {
  display:inline-flex;align-items:center;gap:7px;
  background:var(--blue-10);color:var(--blue);
  font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  padding:6px 14px;border-radius:20px;margin-bottom:28px;
}
.ql-badge-dot {
  width:7px;height:7px;border-radius:50%;background:var(--blue);
  animation:ql-pulse 1.8s ease-in-out infinite;
}
.ql-title {
  font-size:38px;font-weight:800;color:var(--t1);
  letter-spacing:-.8px;line-height:1.05;margin-bottom:12px;
}
.ql-sub {
  font-size:14.5px;color:var(--t3);line-height:1.65;margin-bottom:38px;font-weight:400;
}
.ql-steps {
  text-align:left;display:flex;flex-direction:column;gap:14px;margin-bottom:34px;
}
.ql-step {
  display:flex;align-items:center;gap:13px;
  font-size:13.5px;color:var(--t1);font-weight:500;line-height:1.4;
  opacity:0;animation:ql-step .55s cubic-bezier(.22,.68,0,1.1) both;
}
.ql-step-icon {
  width:26px;height:26px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:12px;
  transition:all .3s ease;
}
.ql-step-icon.done  { background:#E8F7EF;color:#1D9B5E;font-size:13px; }
.ql-step-icon.spin  { background:var(--blue-10);animation:ql-glow 2s ease-in-out infinite; }
.ql-step-icon.spin .ql-mini-spin {
  width:13px;height:13px;border-radius:50%;
  border:2px solid var(--blue-20);border-top-color:var(--blue);
  animation:spin .9s cubic-bezier(.4,0,.2,1) infinite;
}
.ql-divider {
  height:1px;background:rgba(11,29,51,.06);margin:0 0 28px;
}
.ql-bar-track {
  height:4px;border-radius:4px;background:rgba(11,29,51,.06);overflow:hidden;margin-bottom:28px;
}
.ql-bar-fill {
  height:100%;border-radius:4px;
  background:linear-gradient(90deg,var(--blue) 0%,#5BA4EF 60%,#82C0FF 100%);
  animation:ql-bar 5.5s cubic-bezier(.4,0,.15,1) both;
}
.ql-trust {
  font-size:11.5px;color:var(--t3);letter-spacing:.03em;font-style:italic;opacity:.8;
}

/* ── Question card ── */
.mcq-q-card {
  background:var(--card);
  border:1px solid rgba(11,29,51,.09);
  border-radius:20px;
  padding:28px 28px 24px;
  box-shadow:0 1px 3px rgba(11,29,51,.04),0 6px 20px rgba(11,29,51,.07);
}
.mcq-q-num {
  display:flex; align-items:center; gap:8px; margin-bottom:18px; flex-wrap:wrap;
}
.mcq-q-num-badge {
  font-size:9.5px; font-weight:700; letter-spacing:1.2px; text-transform:uppercase;
  color:var(--blue); background:var(--blue-10); border:1px solid var(--blue-20);
  padding:3px 11px; border-radius:20px;
}
.mcq-q-field-badge {
  font-size:9.5px; font-weight:600; color:var(--t3); letter-spacing:.3px;
  padding:3px 10px; border-radius:20px; background:var(--bg); border:1px solid var(--border);
}
.mcq-q-stem { font-size:14.5px; color:var(--t1); line-height:1.82; font-weight:500; letter-spacing:-.1px; }

/* ── Answer options ── */
.mcq-options { display:flex; flex-direction:column; gap:10px; }
.mcq-opt {
  display:flex; align-items:flex-start; gap:14px;
  padding:15px 18px; border-radius:14px;
  border:1.5px solid var(--border); background:var(--card);
  cursor:pointer; transition:all .2s cubic-bezier(.4,0,.2,1);
  font-size:13px; color:var(--t1); line-height:1.65;
  text-align:left; font-family:'Poppins',sans-serif; width:100%;
  animation:opt-in .28s cubic-bezier(.22,.68,0,1.1) both;
}
.mcq-opt:nth-child(1){animation-delay:.04s}
.mcq-opt:nth-child(2){animation-delay:.08s}
.mcq-opt:nth-child(3){animation-delay:.12s}
.mcq-opt:nth-child(4){animation-delay:.16s}
.mcq-opt:nth-child(5){animation-delay:.20s}
.mcq-opt:hover:not(:disabled) {
  border-color:var(--blue); background:var(--blue-10);
  transform:translateX(2px);
}
.mcq-opt:hover:not(:disabled) .mcq-opt-letter {
  background:var(--blue); border-color:var(--blue); color:#fff;
}
.mcq-opt:disabled { cursor:default; }
.mcq-opt.correct { border-color:#0FAD6F; background:#EBF9F3; color:#0A7A50; transform:none; box-shadow:0 2px 10px rgba(15,173,111,.15); }
.mcq-opt.wrong   { border-color:#CC3A3A; background:#FBE8E8; color:#9A2020; transform:none; }
.mcq-opt.neutral { border-color:var(--border-s); opacity:.4; transform:none; }
.mcq-opt.exam-answered { border-color:var(--blue-20); background:var(--blue-10); opacity:.85; cursor:default; transform:none; }
.mcq-opt-letter {
  width:30px; height:30px; border-radius:9px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  font-size:11px; font-weight:700;
  background:var(--bg); border:1.5px solid var(--border); color:var(--t3);
  transition:all .2s; margin-top:1px;
}
.mcq-opt.correct .mcq-opt-letter { background:#0FAD6F; border-color:#0FAD6F; color:#fff; }
.mcq-opt.wrong   .mcq-opt-letter { background:#CC3A3A; border-color:#CC3A3A; color:#fff; }
.mcq-opt-body { display:flex; flex-direction:column; gap:3px; flex:1; }
.mcq-opt-text { font-weight:500; }
.mcq-expl { font-size:11.5px; line-height:1.6; display:none; margin-top:4px; }
.mcq-opt.correct .mcq-expl { display:block; color:#0A7A50; }
.mcq-opt.wrong   .mcq-expl { display:block; color:#9A2020; }
.mcq-opt.neutral .mcq-expl { display:block; color:var(--t3); }

/* ── Pearl card ── */
.mcq-pearl {
  background:linear-gradient(135deg,#EEF6FF,var(--blue-10));
  border:1.5px solid var(--blue-20); border-radius:16px;
  padding:16px 20px; font-size:13px; color:var(--t2);
  display:none; line-height:1.72;
  box-shadow:0 2px 10px rgba(23,105,200,.09);
}
.mcq-pearl strong { color:var(--blue); }

/* ── Explanation panel (on-demand) ── */
.mcq-expl-panel {
  border-radius:18px; padding:22px 24px;
  display:flex; flex-direction:column; gap:14px;
  border:1.5px solid; animation:expl-in .3s cubic-bezier(.22,.68,0,1.1) both;
}
.mcq-expl-panel.is-correct {
  background:linear-gradient(160deg,#F0FBF6 0%,#E8FBF2 100%);
  border-color:rgba(15,173,111,.3);
}
.mcq-expl-panel.is-wrong {
  background:linear-gradient(160deg,#FEF3F3 0%,#FBE8E8 100%);
  border-color:rgba(204,58,58,.28);
}
.mcq-expl-verdict { font-size:15px; font-weight:700; display:flex; align-items:center; gap:8px; }
.mcq-expl-panel.is-correct .mcq-expl-verdict { color:#0A7A50; }
.mcq-expl-panel.is-wrong   .mcq-expl-verdict { color:#9A2020; }
.mcq-expl-block {
  background:rgba(255,255,255,.65); backdrop-filter:blur(2px);
  border-radius:11px; padding:13px 15px;
  border:1px solid rgba(0,0,0,.05);
}
.mcq-expl-block-lbl { font-size:9px; font-weight:700; letter-spacing:1px; text-transform:uppercase; margin-bottom:5px; }
.mcq-expl-panel.is-correct .mcq-expl-block-lbl { color:#0A7A50; }
.mcq-expl-panel.is-wrong   .mcq-expl-block-lbl { color:#9A2020; }
.mcq-expl-pearl-lbl { color:var(--blue) !important; }
.mcq-expl-block-txt { font-size:12.5px; color:var(--t2); line-height:1.75; }

.mcq-ref { font-size:10.5px; color:var(--t4); display:none; margin-top:-6px; }
.mcq-pearl.on, .mcq-ref.on { display:block; }

.mcq-insight {
  display:none; flex-direction:column; gap:10px;
  background:var(--card); border:1.5px solid var(--border);
  border-radius:16px; padding:16px 18px;
  box-shadow:0 1px 6px rgba(11,29,51,.04);
}
.mcq-insight.on { display:flex; }
.mcq-insight-row { display:flex; flex-direction:column; gap:3px; }
.mcq-insight-lbl { font-size:9px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--blue); }
.mcq-insight-val { font-size:12.5px; color:var(--t2); line-height:1.65; }

.btn-fix {
  display:flex; align-items:center; gap:8px; align-self:stretch; justify-content:center;
  background:linear-gradient(135deg,#0FAD6F,#0A8A58);
  border:none; border-radius:var(--r);
  padding:11px 20px;
  font-family:'Poppins',sans-serif; font-size:13px; font-weight:600; color:#fff;
  cursor:pointer; transition:all .2s;
  box-shadow:0 2px 12px rgba(15,173,111,.3);
}
.btn-fix:hover { transform:translateY(-1px); box-shadow:0 5px 18px rgba(15,173,111,.4); }

.mcq-fix-section { background:var(--card); border:1.5px solid var(--border); border-left:4px solid #0FAD6F; border-radius:var(--r-lg); padding:18px 20px; }
.mcq-fix-ttl { font-size:10.5px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:#0FAD6F; margin-bottom:12px; }
.mcq-fix-body { font-size:12.5px; line-height:1.75; color:var(--t2); }
.mcq-fix-body h3 { font-size:13px; font-weight:700; color:var(--t1); margin:14px 0 5px; }
.mcq-fix-body h3:first-child { margin-top:0; }
.mcq-fix-body h2 { font-size:12px; font-weight:700; color:#0FAD6F; background:#E8FBF2; border-left:3px solid #0FAD6F; padding:6px 10px; border-radius:0 6px 6px 0; margin:16px 0 8px; text-transform:none; letter-spacing:0; }
.mcq-fix-body strong { font-weight:700; color:var(--t1); }
.mcq-fix-body p { margin-bottom:8px; }
.mcq-fix-body ul, .mcq-fix-body ol { padding-left:16px; margin-bottom:10px; }
.mcq-fix-body li { margin-bottom:5px; line-height:1.65; }

.btn-mcq-next { display:none; align-self:center; min-width:200px; justify-content:center; }
.btn-mcq-next.on { display:flex; }

/* Section title */
.mcq-section-ttl { font-size:10.5px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--t3); margin-bottom:10px; }

/* Field chart */
.mcq-field-chart { display:flex; flex-direction:column; gap:13px; }
.mcq-field-row { display:flex; flex-direction:column; gap:6px; }
.mcq-field-header { display:flex; align-items:center; justify-content:space-between; gap:8px; }
.mcq-field-name { font-size:12.5px; font-weight:600; color:var(--t1); }
.mcq-field-right { display:flex; align-items:center; gap:8px; }
.mcq-field-score { font-size:11px; color:var(--t3); font-weight:500; }
.mcq-field-tag { font-size:9.5px; font-weight:700; letter-spacing:.3px; padding:2px 7px; border-radius:8px; }
.mcq-field-tag.strong { color:#0FAD6F; background:#E8FBF2; }
.mcq-field-tag.review { color:#E07B20; background:#FDF0E3; }
.mcq-field-tag.improve { color:#CC3A3A; background:#FBE8E8; }
.mcq-field-bar-track { height:8px; background:var(--border); border-radius:4px; overflow:hidden; }
.mcq-field-bar-fill { height:100%; border-radius:4px; width:0%; transition:width .7s cubic-bezier(.4,0,.2,1); }

/* Feedback card */
.mcq-feedback-card { background:var(--card); border:1.5px solid var(--border); border-radius:var(--r-lg); padding:18px 20px; }
.mcq-feedback-loading { display:flex; align-items:center; gap:8px; color:var(--t3); font-size:12px; }
.mcq-feedback-body { font-size:12.5px; line-height:1.75; color:var(--t2); }
.mcq-feedback-body h3 { font-size:13px; font-weight:700; color:var(--t1); margin:14px 0 5px; }
.mcq-feedback-body h3:first-child { margin-top:0; }
.mcq-feedback-body strong { font-weight:700; color:var(--t1); }
.mcq-feedback-body p { margin-bottom:8px; }
.mcq-feedback-body ul { padding-left:16px; margin-bottom:10px; }
.mcq-feedback-body li { margin-bottom:5px; line-height:1.65; }

/* Stats */
.mcq-stats-hero { text-align:center; padding:20px 0 4px; }
.mcq-stats-score { font-size:52px; font-weight:700; color:var(--blue); letter-spacing:-2px; line-height:1; }
.mcq-stats-pct { font-size:16px; font-weight:600; color:var(--t2); margin-top:6px; }
.mcq-stats-topic { font-size:11.5px; color:var(--t3); margin-top:4px; }
.mcq-stat-row { display:flex; gap:10px; }
.mcq-stat-box { flex:1; background:var(--card); border:1.5px solid var(--border); border-radius:var(--r-lg); padding:14px; text-align:center; }
.mcq-stat-box .s-val { font-size:26px; font-weight:700; color:var(--t1); }
.mcq-stat-box .s-lbl { font-size:9.5px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--t3); margin-top:3px; }
.mcq-stat-box.s-green .s-val { color:#0FAD6F; }
.mcq-stat-box.s-red   .s-val { color:#CC3A3A; }
.mcq-breakdown-ttl { font-size:10.5px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--t3); }
.mcq-br-row { display:flex; align-items:flex-start; gap:10px; padding:9px 13px; background:var(--card); border:1.5px solid var(--border-s); border-radius:var(--r); font-size:12px; }

/* Exam post-review */
.exam-review-wrap { display:flex; flex-direction:column; gap:12px; margin-top:10px; }
.exam-review-card { border-radius:14px; border:1.5px solid var(--border-s); background:#fff; overflow:hidden; }
.exam-review-header { display:flex; align-items:center; gap:12px; padding:14px 16px; cursor:pointer; user-select:none; }
.exam-review-header:hover { background:var(--blue-10); }
.exam-review-qnum { font-size:10.5px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--t3); flex-shrink:0; }
.exam-review-verdict { width:22px; height:22px; border-radius:50%; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:700; }
.exam-review-verdict.v-correct { background:#E8FBF2; color:#0A7A50; }
.exam-review-verdict.v-wrong   { background:#FBE8E8; color:#CC3A3A; }
.exam-review-stem { font-size:12.5px; color:var(--t1); line-height:1.5; flex:1; font-weight:500; }
.exam-review-chevron { color:var(--t3); font-size:11px; flex-shrink:0; transition:transform .2s; }
.exam-review-card.open .exam-review-chevron { transform:rotate(180deg); }
.exam-review-body { display:none; padding:0 16px 16px; border-top:1.5px solid var(--border-s); }
.exam-review-card.open .exam-review-body { display:block; }
.exam-review-opts { display:flex; flex-direction:column; gap:6px; margin:12px 0; }
.exam-review-opt { display:flex; align-items:flex-start; gap:9px; padding:8px 11px; border-radius:9px; font-size:12.5px; border:1.5px solid transparent; }
.exam-review-opt.opt-correct { background:#E8FBF2; border-color:#0FAD6F; color:#0A7A50; font-weight:600; }
.exam-review-opt.opt-chosen  { background:#FBE8E8; border-color:#CC3A3A; color:#9A2020; }
.exam-review-opt.opt-neutral { background:var(--bg); color:var(--t3); }
.exam-review-opt-letter { font-weight:700; flex-shrink:0; width:16px; }
.exam-review-expl-block { background:var(--bg); border-radius:9px; padding:11px 13px; margin-top:8px; }
.exam-review-expl-lbl { font-size:10px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--t3); margin-bottom:5px; }
.exam-review-expl-txt { font-size:12px; color:var(--t2); line-height:1.65; }
.exam-review-meta { display:flex; flex-direction:column; gap:6px; margin-top:10px; padding-top:10px; border-top:1px solid var(--border-s); }
.exam-review-meta-row { display:flex; gap:8px; font-size:11.5px; }
.exam-review-meta-lbl { font-weight:700; color:var(--t3); flex-shrink:0; }
.exam-review-meta-val { color:var(--t2); line-height:1.5; }
.mcq-br-ico { font-size:14px; flex-shrink:0; margin-top:1px; }
.mcq-br-info { color:var(--t2); line-height:1.5; }
.mcq-br-qnum { font-size:10px; font-weight:700; letter-spacing:.5px; text-transform:uppercase; color:var(--t3); display:block; margin-bottom:2px; }
.mcq-br-answer { color:var(--t1); font-weight:600; }
.mcq-br-stem { color:var(--t3); font-size:11.5px; }
.btn-mcq-retry { align-self:center; }

/* Difficulty badge */
.mcq-diff-badge { display:inline-flex; align-items:center; font-size:9px; font-weight:700; letter-spacing:.5px; text-transform:uppercase; padding:3px 10px; border-radius:20px; }
.mcq-diff-badge.diff-easy   { color:#0A7A50; background:#E8FBF2; }
.mcq-diff-badge.diff-medium { color:#9A5010; background:#FDF0E3; }
.mcq-diff-badge.diff-hard   { color:#9A2020; background:#FBE8E8; }

/* Extended learner insight rows */
.mcq-expl-extended { display:flex; flex-direction:column; gap:7px; margin-top:4px; padding-top:10px; border-top:1px solid rgba(0,0,0,.07); }
.mcq-expl-ext-row { display:flex; flex-direction:column; gap:2px; }
.mcq-expl-ext-lbl { font-size:9px; font-weight:700; letter-spacing:.8px; text-transform:uppercase; color:var(--blue); }
.mcq-expl-ext-val { font-size:12px; color:var(--t2); line-height:1.65; }

/* Weighted score row in stats */
.mcq-weighted-row { display:flex; align-items:center; justify-content:space-between; background:var(--blue-10); border:1.5px solid var(--blue-20); border-radius:var(--r); padding:10px 16px; }
.mcq-weighted-lbl { font-size:11px; font-weight:600; color:var(--blue); }
.mcq-weighted-val { font-size:18px; font-weight:700; color:var(--blue); }

/* ── MEDICA SCORE CARD ──────────────────────────────────────── */
.medica-score-card { background:var(--card); border:1.5px solid var(--border); border-radius:var(--r-xl); padding:28px 24px; text-align:center; }
.medica-score-card.score-strong { background:linear-gradient(180deg,rgba(15,173,111,.07) 0%,var(--card) 52%); }
.medica-score-card.score-mid    { background:linear-gradient(180deg,rgba(224,123,32,.07)  0%,var(--card) 52%); }
.medica-score-card.score-weak   { background:linear-gradient(180deg,rgba(204,58,58,.07)   0%,var(--card) 52%); }
.medica-score-num { font-size:76px; font-weight:700; line-height:1; letter-spacing:-3px; }
.medica-score-range { font-size:11px; color:var(--t4); font-weight:500; margin-top:3px; }
.medica-readiness-chip { display:inline-flex; align-items:center; gap:6px; padding:5px 18px; border-radius:20px; font-size:12px; font-weight:700; margin-top:12px; letter-spacing:.02em; }

/* Score gauge bar */
.medica-bar-wrap { margin:18px 0 8px; }
.medica-bar-track { height:10px; background:linear-gradient(90deg,#CC3A3A 0%,#CC3A3A 25%,#E07B20 25%,#E07B20 45%,#D4A020 45%,#D4A020 60%,#0FAD6F 60%,#0FAD6F 73%,#1769C8 73%,#1769C8 90%,#6B3FBD 90%,#6B3FBD 100%); border-radius:5px; position:relative; }
.medica-bar-marker { position:absolute; top:50%; transform:translate(-50%,-50%); width:16px; height:16px; background:white; border:2.5px solid #0B1D33; border-radius:50%; box-shadow:0 0 0 3px rgba(255,255,255,.6),0 2px 8px rgba(0,0,0,.3); }
.medica-bar-labels { display:flex; justify-content:space-between; font-size:8.5px; color:var(--t4); font-weight:600; margin-top:6px; letter-spacing:.02em; }

/* Stat pills under score */
.medica-pills-row { display:flex; gap:8px; justify-content:center; margin-top:14px; flex-wrap:wrap; }
.medica-pill { flex:1; min-width:70px; max-width:100px; display:flex; flex-direction:column; align-items:center; gap:3px; background:var(--bg); border:1px solid var(--border); border-radius:var(--r); padding:8px 10px; }
.medica-pill-val { font-size:17px; font-weight:700; color:var(--t1); }
.medica-pill-lbl { font-size:8.5px; font-weight:700; letter-spacing:.7px; text-transform:uppercase; color:var(--t3); }

/* ── WEAKNESS DETECTOR ────────────────────────────────────────── */
.weakness-detector { display:flex; flex-direction:column; gap:8px; }
.weakness-group { border-radius:var(--r); overflow:hidden; border:1.5px solid transparent; }
.weakness-group.critical { border-color:rgba(204,58,58,.2); }
.weakness-group.moderate { border-color:rgba(224,123,32,.2); }
.weakness-group-hdr { display:flex; align-items:center; gap:8px; padding:8px 14px; font-size:10px; font-weight:700; letter-spacing:.7px; text-transform:uppercase; }
.weakness-group.critical .weakness-group-hdr { background:#FBE8E8; color:#9A2020; }
.weakness-group.moderate .weakness-group-hdr { background:#FDF0E3; color:#9A5010; }
.weakness-item { display:flex; align-items:center; justify-content:space-between; padding:9px 14px; font-size:12.5px; color:var(--t2); border-top:1px solid rgba(0,0,0,.05); background:var(--card); }
.weakness-pct-crit { font-size:11px; font-weight:700; color:#CC3A3A; }
.weakness-pct-mod  { font-size:11px; font-weight:700; color:#E07B20; }

/* ── SUBJECT CARD ─────────────────────────────────────────────── */
.subject-card-grid { display:flex; flex-direction:column; gap:9px; }
.subject-card { background:var(--card); border:1.5px solid var(--border); border-radius:var(--r-lg); padding:14px 16px; border-left-width:3px; }
.subject-card.perf-strong { border-left-color:#1769C8; }
.subject-card.perf-pass   { border-left-color:#0FAD6F; }
.subject-card.perf-border { border-left-color:#E07B20; }
.subject-card.perf-below  { border-left-color:#CC3A3A; }
.subject-card-top { display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.subject-card-name { font-size:13px; font-weight:700; color:var(--t1); }
.subject-level-chip { font-size:9.5px; font-weight:700; padding:3px 9px; border-radius:8px; }
.subject-level-chip.below  { color:#9A2020; background:#FBE8E8; }
.subject-level-chip.border { color:#9A5010; background:#FDF0E3; }
.subject-level-chip.pass   { color:#0A7A50; background:#E8FBF2; }
.subject-level-chip.strong { color:#1359AA; background:var(--blue-10); }
.subject-bar-row { display:flex; align-items:center; gap:10px; }
.subject-bar-track { flex:1; height:9px; background:var(--border); border-radius:4px; overflow:hidden; }
.subject-bar-fill { height:100%; border-radius:4px; transition:width .7s cubic-bezier(.4,0,.2,1); }
.subject-pct { font-size:12px; font-weight:700; width:36px; text-align:right; flex-shrink:0; }

/* ── PREDICTION CARD ──────────────────────────────────────────── */
.prediction-card { background:linear-gradient(135deg,#0B1D33 0%,#142034 60%,#1769C8 100%); border-radius:var(--r-xl); padding:22px 20px; color:white; }
.prediction-eyebrow { font-size:9px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:rgba(255,255,255,.4); margin-bottom:8px; }
.prediction-prob-row { display:flex; align-items:flex-end; gap:12px; }
.prediction-prob-num { font-size:56px; font-weight:700; line-height:1; letter-spacing:-2px; color:white; }
.prediction-prob-sub { font-size:12px; color:rgba(255,255,255,.55); margin-bottom:10px; }
.prediction-divider { width:1px; background:rgba(255,255,255,.15); align-self:stretch; }
.prediction-improved { display:flex; flex-direction:column; gap:4px; }
.prediction-improved-val { font-size:28px; font-weight:700; color:#3FE8A0; }
.prediction-improved-lbl { font-size:10px; color:rgba(255,255,255,.45); font-weight:600; }

/* ── STUDY PRESCRIPTION ───────────────────────────────────────── */
.study-rx { background:var(--card); border:1.5px solid var(--border); border-radius:var(--r-xl); overflow:hidden; }
.study-rx-hdr { padding:14px 18px 12px; background:linear-gradient(90deg,#0B1D33,#142034); }
.study-rx-eyebrow { font-size:9px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:rgba(255,255,255,.4); }
.study-rx-title { font-size:15px; font-weight:700; color:white; margin-top:3px; }
.study-rx-body { padding:16px 18px; display:flex; flex-direction:column; gap:12px; }
.study-rx-block { display:flex; flex-direction:column; gap:6px; }
.study-rx-p-lbl { font-size:9px; font-weight:700; letter-spacing:.8px; text-transform:uppercase; display:flex; align-items:center; gap:6px; margin-bottom:4px; }
.study-rx-p-lbl::before { content:''; display:inline-block; width:7px; height:7px; border-radius:2px; flex-shrink:0; }
.study-rx-p1-lbl { color:#CC3A3A; }
.study-rx-p1-lbl::before { background:#CC3A3A; }
.study-rx-p2-lbl { color:#E07B20; }
.study-rx-p2-lbl::before { background:#E07B20; }
.study-rx-p3-lbl { color:#0FAD6F; }
.study-rx-p3-lbl::before { background:#0FAD6F; }
.study-rx-item { display:flex; align-items:flex-start; gap:12px; padding:10px 13px; border-radius:9px; font-size:12.5px; color:var(--t2); line-height:1.5; }
.study-rx-p1 .study-rx-item { background:#FBE8E8; border-left:3px solid #CC3A3A; }
.study-rx-p2 .study-rx-item { background:#FDF0E3; border-left:3px solid #E07B20; }
.study-rx-p3 .study-rx-item { background:#E8FBF2; border-left:3px solid #0FAD6F; }
.study-rx-pct-badge { font-size:13px; font-weight:700; flex-shrink:0; min-width:36px; text-align:center; padding-top:1px; }
.study-rx-p1 .study-rx-pct-badge { color:#CC3A3A; }
.study-rx-p2 .study-rx-pct-badge { color:#E07B20; }
.study-rx-p3 .study-rx-pct-badge { color:#0FAD6F; }
.study-rx-advice { font-size:11px; color:var(--t3); margin-top:3px; line-height:1.5; }

/* Score interpretation line */
.medica-score-interp { font-size:12.5px; color:var(--t2); line-height:1.7; margin-top:12px; max-width:360px; margin-left:auto; margin-right:auto; }

/* Mistake diagnosis */
.mistake-card { background:var(--card); border:1.5px solid var(--border); border-radius:var(--r-lg); overflow:hidden; }
.mistake-hdr  { padding:10px 16px; background:var(--bg); border-bottom:1px solid var(--border); font-size:10px; font-weight:700; letter-spacing:.8px; text-transform:uppercase; color:var(--t3); }
.mistake-item { display:flex; align-items:flex-start; gap:12px; padding:12px 16px; border-top:1px solid var(--border-s); }
.mistake-item:first-of-type { border-top:none; }
.mistake-dot  { width:8px; height:8px; border-radius:50%; flex-shrink:0; margin-top:5px; }
.mistake-meta { flex:1; }
.mistake-type-name { font-size:11px; font-weight:700; color:var(--t1); margin-bottom:3px; }
.mistake-type-desc { font-size:12px; color:var(--t2); line-height:1.65; }

/* Strength zones */
.strength-list { display:flex; flex-direction:column; gap:7px; }
.strength-zone { display:flex; align-items:center; justify-content:space-between; padding:11px 15px; background:var(--card); border:1.5px solid rgba(15,173,111,.22); border-radius:var(--r); }
.strength-zone-name { font-size:13px; font-weight:600; color:var(--t1); }
.strength-zone-right { display:flex; align-items:center; gap:10px; }
.strength-zone-pct  { font-size:13px; font-weight:700; color:#0FAD6F; }
.strength-zone-bar  { width:56px; height:5px; background:var(--border); border-radius:3px; overflow:hidden; }
.strength-zone-fill { height:100%; background:linear-gradient(90deg,#0FAD6F,#3FE8A0); border-radius:3px; }

/* Improvement forecast */
.forecast-card { background:linear-gradient(135deg,#F0FBF6,#EBF7F1); border:1.5px solid rgba(15,173,111,.25); border-radius:var(--r-xl); padding:18px 20px; display:flex; gap:18px; align-items:flex-start; }
.forecast-left { text-align:center; flex-shrink:0; }
.forecast-gain { font-size:32px; font-weight:700; color:#0A7A50; line-height:1; letter-spacing:-1px; }
.forecast-gain-lbl { font-size:9px; font-weight:700; letter-spacing:.8px; text-transform:uppercase; color:#0A7A50; margin-top:3px; }
.forecast-right { flex:1; }
.forecast-note { font-size:12.5px; color:var(--t2); line-height:1.7; }
.forecast-week { font-size:11px; font-weight:700; color:#0A7A50; margin-top:7px; }

/* Premium CTA grid */
.cta-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.btn-rescue { grid-column:1/-1; display:flex; align-items:center; justify-content:center; gap:10px; padding:14px 20px; border-radius:var(--r); font-size:13.5px; font-weight:700; cursor:pointer; border:none; background:linear-gradient(135deg,#0B1D33 0%,#1769C8 100%); color:white; width:100%; box-shadow:0 4px 18px rgba(23,105,200,.35); transition:transform .15s,box-shadow .15s; font-family:'Poppins',sans-serif; }
.btn-rescue:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(23,105,200,.45); }
.btn-cta-sec { display:flex; align-items:center; justify-content:center; gap:8px; padding:10px 14px; border-radius:var(--r); font-size:12px; font-weight:700; cursor:pointer; background:var(--card); border:1.5px solid var(--border); color:var(--t2); transition:all .15s; font-family:'Poppins',sans-serif; }
.btn-cta-sec:hover { border-color:var(--blue); color:var(--blue); background:var(--blue-10); }
.btn-cta-sec.purple:hover { border-color:var(--purple); color:var(--purple); background:#F0EAFB; }

/* 7-day plan output */
.rescue-plan-card { background:var(--card); border:1.5px solid var(--border); border-left:4px solid var(--blue); border-radius:var(--r-lg); padding:18px 20px; }
.rescue-plan-ttl  { font-size:10.5px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--blue); margin-bottom:12px; }
.rescue-plan-body { font-size:12.5px; line-height:1.8; color:var(--t2); }
.rescue-plan-body strong { font-weight:700; color:var(--t1); }
.rescue-plan-body h3 { font-size:13px; font-weight:700; color:var(--blue); margin:14px 0 5px; }
.rescue-plan-body h3:first-child { margin-top:0; }
.rescue-plan-body p { margin-bottom:7px; }

/* ── AI PERFORMANCE COACH ────────────────────────────────── */
.ai-coach-card {
  background: var(--card); border: 1.5px solid var(--border);
  border-radius: var(--r-xl); overflow: hidden; box-shadow: var(--sh-card);
}
.ai-coach-hdr {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px; border-bottom: 1px solid var(--border-s);
  background: linear-gradient(to right, #FAFCFF, #F5F9FF);
}
.ai-coach-hdr-l { display: flex; align-items: center; gap: 11px; }
.ai-coach-icon {
  width: 34px; height: 34px; border-radius: 9px;
  background: var(--blue-10); border: 1px solid var(--blue-20);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.ai-coach-title { font-size: 13.5px; font-weight: 700; color: var(--t1); letter-spacing: -.1px; }
.ai-coach-sub { font-size: 10px; color: var(--t3); margin-top: 2px; }
.ai-coach-mode-pill {
  font-size: 9px; font-weight: 700; letter-spacing: .07em; text-transform: uppercase;
  padding: 3px 10px; border-radius: 20px;
  background: var(--blue-10); color: var(--blue); border: 1px solid var(--blue-20);
}
.ai-coach-body { padding: 20px 20px 16px; }
.ai-coach-loading { display:flex; align-items:center; gap:10px; color:var(--t3); font-size:13px; padding:4px 0; }
.ai-coach-body h2 {
  font-size: 11px; font-weight: 700; letter-spacing: .8px; text-transform: uppercase;
  color: var(--blue); background: var(--blue-10);
  border-left: 3px solid var(--blue); padding: 6px 10px;
  border-radius: 0 6px 6px 0; margin: 18px 0 9px;
}
.ai-coach-body h2:first-child { margin-top: 0; }
.ai-coach-body h3 { font-size: 13px; font-weight: 700; color: var(--t1); margin: 14px 0 6px; }
.ai-coach-body h3:first-child { margin-top: 0; }
.ai-coach-body p { font-size: 12.5px; color: var(--t2); line-height: 1.75; margin-bottom: 8px; }
.ai-coach-body ul, .ai-coach-body ol { padding-left: 18px; margin-bottom: 10px; }
.ai-coach-body li { font-size: 12.5px; color: var(--t2); margin-bottom: 5px; line-height: 1.65; }
.ai-coach-body strong { font-weight: 600; color: var(--t1); }
.ai-coach-body hr { border: none; border-top: 1px solid var(--border-s); margin: 14px 0; }
.ai-coach-actions {
  padding: 14px 20px 16px; border-top: 1px solid var(--border-s);
  background: var(--bg); display: flex; flex-direction: column; gap: 8px;
}
.ai-coach-btn-primary {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  width: 100%; padding: 11px 20px;
  background: linear-gradient(135deg, var(--blue), var(--blue-h));
  border: none; border-radius: var(--r);
  font-family: 'Poppins', sans-serif; font-size: 13px; font-weight: 600; color: #fff;
  cursor: pointer; transition: all .18s; box-shadow: var(--sh-btn);
}
.ai-coach-btn-primary:hover:not(:disabled) { transform: translateY(-1px); box-shadow: 0 5px 18px var(--blue-glow); }
.ai-coach-btn-primary:disabled { background: var(--t4); box-shadow: none; cursor: not-allowed; }
.ai-coach-btn-row { display: flex; gap: 8px; }
.ai-coach-btn-sec {
  flex: 1; display: flex; align-items: center; justify-content: center; gap: 6px;
  padding: 9px 14px; background: var(--card); border: 1.5px solid var(--border);
  border-radius: var(--r);
  font-family: 'Poppins', sans-serif; font-size: 12px; font-weight: 600; color: var(--t2);
  cursor: pointer; transition: all .15s;
}
.ai-coach-btn-sec:hover { border-color: var(--blue); color: var(--blue); background: var(--blue-10); }
.ai-coach-retry-btn { align-self: flex-end; flex: unset; }
.ai-coach-perfect {
  display: flex; align-items: flex-start; gap: 10px;
  background: #E8FBF2; border: 1px solid rgba(15,173,111,.22);
  border-radius: var(--r); padding: 12px 16px;
  font-size: 12.5px; color: var(--t2); line-height: 1.55;
}
.ai-coach-perfect-ico { color: #0FAD6F; flex-shrink: 0; font-size: 14px; }
.ai-coach-recovery-slot { padding: 18px 20px; border-top: 1px solid var(--border-s); }
.ai-coach-recovery-hdr {
  font-size: 10px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  color: var(--blue); margin-bottom: 14px;
  display: flex; align-items: center; gap: 7px;
}
.ai-coach-recovery-body { font-size: 12.5px; line-height: 1.75; color: var(--t2); }
.ai-coach-recovery-body h3 { font-size: 13px; font-weight: 700; color: var(--t1); margin: 14px 0 5px; }
.ai-coach-recovery-body h3:first-child { margin-top: 0; }
.ai-coach-recovery-body h2 {
  font-size: 11.5px; font-weight: 700; color: var(--blue);
  background: var(--blue-10); border-left: 3px solid var(--blue);
  padding: 6px 10px; border-radius: 0 6px 6px 0;
  margin: 16px 0 8px; text-transform: none; letter-spacing: 0;
}
.ai-coach-recovery-body strong { font-weight: 700; color: var(--t1); }
.ai-coach-recovery-body p { margin-bottom: 8px; }
.ai-coach-recovery-body ul, .ai-coach-recovery-body ol { padding-left: 16px; margin-bottom: 10px; }
.ai-coach-recovery-body li { margin-bottom: 5px; line-height: 1.65; }

/* ── FLASHCARDS ──────────────────────────────────────────── */
.fc-section { display:flex; flex-direction:column; gap:14px; }
.fc-loading { display:flex; align-items:center; gap:9px; color:var(--t3); font-size:12.5px; padding:12px 0; }
.fc-card {
  background:var(--card); border:1.5px solid var(--border);
  border-radius:var(--r-lg); overflow:hidden; cursor:pointer;
  transition:box-shadow .15s, border-color .15s;
}
.fc-card:hover { box-shadow:var(--sh-hover); border-color:rgba(23,105,200,.28); }
.fc-card-front { padding:15px 17px; }
.fc-card-meta { display:flex; align-items:center; gap:7px; margin-bottom:8px; }
.fc-type-badge { font-size:9px; font-weight:700; letter-spacing:.5px; text-transform:uppercase; padding:2px 8px; border-radius:8px; }
.fc-type-recall     { color:var(--blue);    background:var(--blue-10); }
.fc-type-vignette   { color:var(--purple);  background:#F0EAFB; }
.fc-type-compare    { color:#E07B20;         background:#FDF0E3; }
.fc-type-high_yield { color:#0FAD6F;         background:#E8FBF2; }
.fc-type-trap       { color:#CC3A3A;         background:#FBE8E8; }
.fc-subject { font-size:10px; font-weight:600; color:var(--t3); }
.fc-q { font-size:13px; font-weight:600; color:var(--t1); line-height:1.6; }
.fc-flip-hint { font-size:10px; color:var(--t4); margin-top:7px; }
.fc-card-back { display:none; padding:13px 17px; background:var(--bg); border-top:1.5px solid var(--border-s); }
.fc-card.open .fc-card-back { display:block; }
.fc-a { font-size:12.5px; color:var(--t2); line-height:1.75; }
.btn-fc {
  display:flex; align-items:center; justify-content:center; gap:8px;
  width:100%; padding:12px 20px;
  background:linear-gradient(135deg,#0B1D33 0%,#1769C8 100%);
  border:none; border-radius:var(--r);
  font-family:'Poppins',sans-serif; font-size:13px; font-weight:600; color:#fff;
  cursor:pointer; transition:all .18s;
  box-shadow:0 4px 16px rgba(23,105,200,.3);
}
.btn-fc:hover:not(:disabled) { transform:translateY(-1px); box-shadow:0 6px 20px rgba(23,105,200,.42); }
.btn-fc:disabled { background:var(--t3); box-shadow:none; cursor:not-allowed; }
