/* =========================================================
   WOOSPEAK AI — ASSESSMENT UI PREMIUM V3.1 COMPACT POLISH
   Finition premium compacte, fine et mobile-friendly
   ========================================================= */

#woospeak-ai-app{
  --ws-assess-bg:#f4f7fb;
  --ws-assess-surface:#ffffff;
  --ws-assess-surface-soft:#f8fbff;
  --ws-assess-surface-2:#f1f5fb;
  --ws-assess-border:#dbe4f0;
  --ws-assess-border-strong:#c7d4e4;
  --ws-assess-text:#142033;
  --ws-assess-text-soft:#5e6f86;
  --ws-assess-text-muted:#8191a6;
  --ws-assess-primary:#2563eb;
  --ws-assess-primary-2:#1d4ed8;
  --ws-assess-primary-soft:#e9f1ff;
  --ws-assess-success:#0f9f6e;
  --ws-assess-success-soft:#e8f8f2;
  --ws-assess-danger:#d14343;
  --ws-assess-danger-soft:#fdecec;
  --ws-assess-warning:#b45309;
  --ws-assess-warning-soft:#fff4e5;
  --ws-assess-shadow-xs:0 2px 8px rgba(15,23,42,.035);
  --ws-assess-shadow-sm:0 8px 22px rgba(15,23,42,.055);
  --ws-assess-shadow-md:0 14px 34px rgba(15,23,42,.08);
  --ws-assess-shadow-lg:0 22px 56px rgba(15,23,42,.12);
  --ws-assess-radius-sm:10px;
  --ws-assess-radius-md:16px;
  --ws-assess-radius-lg:22px;
  --ws-assess-radius-xl:28px;
  --ws-assess-primary-rgb:37,99,235;
  --ws-assess-violet:#7c3aed;
  --ws-assess-glow:0 16px 38px rgba(37,99,235,.14);
}

/* =========================================================
   LEVEL PANEL / ASSESSMENT CONTAINER
   ========================================================= */
#woospeak-ai-app #woospeak-ai-level,
#woospeak-ai-app .woospeak-ai-level-inner,
#woospeak-ai-app .ws-assessment-shell{
  background:
    radial-gradient(820px 280px at 0% 0%, rgba(37,99,235,.07), transparent 55%),
    radial-gradient(740px 260px at 100% 0%, rgba(129,140,248,.05), transparent 52%),
    linear-gradient(180deg, #f8fbff 0%, var(--ws-assess-bg) 100%);
  border:1px solid rgba(15,23,42,.055);
  border-radius:var(--ws-assess-radius-xl);
  box-shadow:var(--ws-assess-shadow-sm);
  padding:20px;
  min-height:420px;
  position:relative;
  overflow:hidden;
}

#woospeak-ai-app .ws-assessment-screen,
#woospeak-ai-app .ws-assessment-waiting,
#woospeak-ai-app .ws-assessment-error,
#woospeak-ai-app .ws-assessment-result{
  max-width:900px;
  margin:0 auto;
  animation:wsFadeUp .38s cubic-bezier(.2,.8,.2,1);
}

/* =========================================================
   STEP CARD CORE
   ========================================================= */
#woospeak-ai-app .ws-step{
  position:relative;
  overflow:hidden;
  border-radius:var(--ws-assess-radius-lg);
  border:1px solid var(--ws-assess-border);
  background:
    radial-gradient(520px 180px at 0% 0%, rgba(37,99,235,.045), transparent 55%),
    linear-gradient(180deg, #ffffff 0%, #fcfdff 100%);
  box-shadow:var(--ws-assess-shadow-md);
  backdrop-filter:blur(10px);
}

#woospeak-ai-app .ws-step::before{
  content:"";
  position:absolute;
  inset:0 auto auto 0;
  width:100%;
  height:4px;
  background:linear-gradient(90deg, var(--ws-assess-primary) 0%, #60a5fa 55%, #818cf8 100%);
}

#woospeak-ai-app .ws-step::after{
  content:"";
  position:absolute;
  inset:-30% auto auto -10%;
  width:42%;
  height:170px;
  background:radial-gradient(circle, rgba(255,255,255,.72) 0%, rgba(255,255,255,0) 70%);
  pointer-events:none;
  opacity:.72;
}

#woospeak-ai-app .ws-step-shell{
  display:flex;
  flex-direction:column;
  gap:14px;
  padding:24px 24px 20px;
}

#woospeak-ai-app .ws-step-topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}

#woospeak-ai-app .ws-step-header{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin:0;
  padding:8px 14px;
  border-radius:999px;
  border:1px solid rgba(37,99,235,.12);
  background:linear-gradient(180deg, #f2f7ff 0%, #eaf2ff 100%);
  color:var(--ws-assess-primary);
  font-size:12px;
  line-height:1;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  box-shadow:0 6px 16px rgba(37,99,235,.07);
}

#woospeak-ai-app .ws-step-progress{
  margin:0;
  color:var(--ws-assess-text-muted);
  font-size:12px;
  line-height:1.2;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}

#woospeak-ai-app .ws-step-progressbar,
#woospeak-ai-app .ws-progress-modern{
  margin:0;
  padding:0;
  border:none;
  background:transparent;
  box-shadow:none;
}

#woospeak-ai-app .ws-progress-modern-head{
  display:none;
}

#woospeak-ai-app .ws-progress-modern-rail{
  position:relative;
  height:8px;
  overflow:hidden;
  border-radius:999px;
  background:linear-gradient(180deg, #dfe9f7, #edf3fb);
  box-shadow:inset 0 1px 1px rgba(15,23,42,.03);
}

#woospeak-ai-app .ws-progress-modern-bar{
  position:absolute;
  inset:0 auto 0 0;
  width:0;
  border-radius:999px;
  background:linear-gradient(90deg, var(--ws-assess-primary) 0%, #3b82f6 45%, var(--ws-assess-violet) 100%);
  box-shadow:0 0 0 1px rgba(255,255,255,.12) inset, 0 8px 18px rgba(59,130,246,.18);
  transition:width .5s cubic-bezier(.2,.8,.2,1);
}

#woospeak-ai-app .ws-progress-modern-bar::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(255,255,255,0) 0%, rgba(255,255,255,.28) 45%, rgba(255,255,255,0) 100%);
  animation:wsShimmer 2.6s linear infinite;
}

#woospeak-ai-app .ws-step-body{
  display:flex;
  flex-direction:column;
  gap:14px;
}

#woospeak-ai-app .ws-question-card{
  padding:18px 18px 16px;
  border-radius:18px;
  border:1px solid rgba(148,163,184,.14);
  background:linear-gradient(180deg, rgba(248,251,255,.95), rgba(255,255,255,.98));
  box-shadow:var(--ws-assess-shadow-xs);
}

#woospeak-ai-app .ws-question-eyebrow{
  margin:0 0 8px;
  color:var(--ws-assess-primary);
  font-size:11px;
  line-height:1.2;
  font-weight:900;
  letter-spacing:.16em;
  text-transform:uppercase;
}

#woospeak-ai-app .ws-question{
  margin:0;
}

#woospeak-ai-app .ws-question-en{
  margin:0;
  color:var(--ws-assess-text);
  font-size:19px;
  line-height:1.36;
  font-weight:900;
  letter-spacing:-.025em;
  text-wrap:pretty;
}

#woospeak-ai-app .ws-form-card{
  padding:16px;
  border-radius:18px;
  border:1px solid rgba(148,163,184,.14);
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(250,252,255,.98));
  box-shadow:var(--ws-assess-shadow-xs);
}

#woospeak-ai-app .ws-step-form{
  display:flex;
  flex-direction:column;
  gap:12px;
}

/* =========================================================
   QUESTION BLOCKS / MCQ
   ========================================================= */
#woospeak-ai-app .ws-question-block{
  position:relative;
  overflow:hidden;
  margin:0;
  padding:14px;
  border-radius:16px;
  background:linear-gradient(180deg, rgba(248,251,255,.95), rgba(255,255,255,.98));
  border:1px solid rgba(148,163,184,.14);
  box-shadow:0 1px 8px rgba(15,23,42,.025);
}

#woospeak-ai-app .ws-question-block + .ws-question-block{
  margin-top:12px;
}

#woospeak-ai-app .ws-question-block::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(135deg, rgba(255,255,255,.3), rgba(255,255,255,0) 30%);
}

#woospeak-ai-app .ws-question-block-head{
  display:flex;
  align-items:center;
  gap:10px;
  margin:0 0 10px;
}

#woospeak-ai-app .ws-question-index{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:28px;
  min-height:28px;
  padding:0 8px;
  border-radius:999px;
  background:linear-gradient(180deg, #eef4ff 0%, #e5efff 100%);
  border:1px solid rgba(37,99,235,.12);
  color:var(--ws-assess-primary);
  font-size:12px;
  font-weight:900;
  letter-spacing:.04em;
  box-shadow:0 4px 10px rgba(37,99,235,.06);
}

#woospeak-ai-app .ws-question-subtitle{
  margin:0;
  color:var(--ws-assess-text);
  font-size:15px;
  line-height:1.45;
  font-weight:800;
}

#woospeak-ai-app .ws-question-options{
  display:flex;
  flex-direction:column;
  gap:8px;
}

/* =========================================================
   FORM FIELDS
   ========================================================= */
#woospeak-ai-app .ws-step-form textarea,
#woospeak-ai-app .ws-step-form input[type="text"],
#woospeak-ai-app .ws-step-form select{
  width:100%;
  box-sizing:border-box;
  appearance:none;
  border:1px solid var(--ws-assess-border-strong);
  background:linear-gradient(180deg, #ffffff 0%, #fcfdff 100%);
  color:var(--ws-assess-text);
  border-radius:16px;
  padding:14px 16px;
  font-size:15px;
  line-height:1.55;
  box-shadow:inset 0 1px 2px rgba(15,23,42,.025);
  transition:border-color .18s ease, box-shadow .18s ease, transform .18s ease, background .18s ease;
}

#woospeak-ai-app .ws-step-form textarea{
  min-height:168px;
  resize:vertical;
}

#woospeak-ai-app .ws-open-question-textarea,
#woospeak-ai-app .ws-speaking-transcript{
  min-height:205px !important;
  padding:16px 18px !important;
  font-size:15px !important;
  line-height:1.62;
}

#woospeak-ai-app .ws-step-form textarea::placeholder,
#woospeak-ai-app .ws-step-form input[type="text"]::placeholder{
  color:#97a5b8;
}

#woospeak-ai-app .ws-step-form textarea:hover,
#woospeak-ai-app .ws-step-form input[type="text"]:hover,
#woospeak-ai-app .ws-step-form select:hover{
  border-color:#b9c8da;
}

#woospeak-ai-app .ws-step-form textarea:focus,
#woospeak-ai-app .ws-step-form input[type="text"]:focus,
#woospeak-ai-app .ws-step-form select:focus{
  outline:none;
  border-color:rgba(37,99,235,.55);
  box-shadow:0 0 0 4px rgba(37,99,235,.09), 0 8px 18px rgba(37,99,235,.065);
  background:#fff;
}

#woospeak-ai-app .ws-word-helper{
  margin-top:4px;
  font-size:12px;
  line-height:1.4;
  color:var(--ws-assess-text-soft);
  font-weight:700;
}
#woospeak-ai-app .ws-word-helper.is-valid{ color:var(--ws-assess-success); }
#woospeak-ai-app .ws-word-helper.is-invalid{ color:var(--ws-assess-danger); }

/* =========================================================
   CHOICE OPTIONS
   ========================================================= */
#woospeak-ai-app .ws-choice-option,
#woospeak-ai-app .ws-step-form label{
  display:flex;
  align-items:center;
  gap:12px;
  padding:13px 14px;
  border-radius:15px;
  border:1px solid var(--ws-assess-border);
  background:#fff;
  color:var(--ws-assess-text);
  font-size:15px;
  line-height:1.45;
  cursor:pointer;
  transition:border-color .16s ease, box-shadow .16s ease, background .16s ease, transform .16s ease;
  position:relative;
  overflow:hidden;
}

#woospeak-ai-app .ws-choice-option::before,
#woospeak-ai-app .ws-step-form label::before{
  content:"";
  position:absolute;
  inset:0 auto 0 0;
  width:0;
  border-radius:inherit;
  background:linear-gradient(90deg, rgba(var(--ws-assess-primary-rgb),.09), rgba(var(--ws-assess-primary-rgb),0));
  transition:width .2s ease;
  pointer-events:none;
}

#woospeak-ai-app .ws-choice-option:hover,
#woospeak-ai-app .ws-step-form label:hover{
  border-color:rgba(37,99,235,.26);
  box-shadow:0 8px 18px rgba(37,99,235,.07);
  background:#fcfdff;
  transform:translateY(-1px);
}

#woospeak-ai-app .ws-choice-option:hover::before,
#woospeak-ai-app .ws-step-form label:hover::before,
#woospeak-ai-app .ws-choice-option.is-selected::before,
#woospeak-ai-app .ws-step-form label.is-selected::before,
#woospeak-ai-app .ws-choice-option:has(input[type="radio"]:checked)::before,
#woospeak-ai-app .ws-step-form label:has(input[type="radio"]:checked)::before{
  width:100%;
}

#woospeak-ai-app .ws-step-form input[type="radio"]{
  margin:0;
  transform:scale(1.1);
  accent-color:var(--ws-assess-primary);
  flex:0 0 auto;
  position:relative;
  z-index:1;
}

#woospeak-ai-app .ws-choice-control{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:24px;
  height:24px;
  border-radius:999px;
  border:1.5px solid rgba(37,99,235,.22);
  background:linear-gradient(180deg, #fff, #f7faff);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9);
  flex:0 0 auto;
}

#woospeak-ai-app .ws-choice-text,
#woospeak-ai-app .ws-step-form label span{
  position:relative;
  z-index:1;
}

#woospeak-ai-app .ws-choice-option.is-selected,
#woospeak-ai-app .ws-step-form label.is-selected,
#woospeak-ai-app .ws-choice-option:has(input[type="radio"]:checked),
#woospeak-ai-app .ws-step-form label:has(input[type="radio"]:checked){
  border-color:rgba(37,99,235,.5);
  background:linear-gradient(180deg, #f4f8ff 0%, #edf4ff 100%);
  box-shadow:0 10px 24px rgba(37,99,235,.11);
  transform:translateY(-1px);
}

#woospeak-ai-app .ws-choice-option:has(input[type="radio"]:checked) .ws-choice-control,
#woospeak-ai-app .ws-step-form label:has(input[type="radio"]:checked) .ws-choice-control{
  border-color:rgba(37,99,235,.45);
  background:linear-gradient(180deg, #eff5ff 0%, #e3efff 100%);
  box-shadow:0 4px 10px rgba(37,99,235,.08);
}

#woospeak-ai-app .ws-choice-text{
  font-weight:700;
}

/* =========================================================
   FILL IN THE BLANK
   ========================================================= */
#woospeak-ai-app .ws-fill-inputs{
  display:flex;
  flex-direction:column;
  gap:12px;
}

#woospeak-ai-app .ws-fill-gaps-sentence{
  padding:16px 18px;
  border-radius:16px;
  background:linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
  border:1px solid var(--ws-assess-border);
  color:var(--ws-assess-text);
  font-size:15px;
  line-height:1.85;
  box-shadow:0 8px 22px rgba(15,23,42,.04);
}

#woospeak-ai-app .ws-fill-gaps-sentence input[type="text"]{
  display:inline-block;
  width:138px;
  min-height:auto;
  margin:0 5px;
  padding:9px 11px;
  border-radius:11px;
  vertical-align:middle;
  font-size:14px;
}

#woospeak-ai-app .ws-word-bank{
  margin:2px 0 0;
  color:var(--ws-assess-text-soft);
  font-size:12px;
  font-weight:900;
  letter-spacing:.06em;
  text-transform:uppercase;
}

#woospeak-ai-app .ws-fill-choices{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

#woospeak-ai-app .ws-fill-choice{
  appearance:none;
  border:1px solid var(--ws-assess-border);
  background:linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border-radius:999px;
  padding:8px 13px;
  font-size:13px;
  font-weight:800;
  color:var(--ws-assess-text);
  cursor:pointer;
  transition:all .16s ease, transform .16s ease, box-shadow .16s ease;
}

#woospeak-ai-app .ws-fill-choice:hover{
  border-color:var(--ws-assess-primary);
  background:var(--ws-assess-primary-soft);
  color:var(--ws-assess-primary);
  transform:translateY(-1px);
  box-shadow:var(--ws-assess-shadow-sm);
}

#woospeak-ai-app .ws-fill-choice.is-used{
  background:#eef2f7;
  border-color:var(--ws-assess-border);
  color:var(--ws-assess-text-muted);
  opacity:.6;
  pointer-events:none;
}

/* =========================================================
   LISTENING
   ========================================================= */
#woospeak-ai-app .ws-listening{
  position:relative;
  margin-bottom:14px;
  padding:16px 18px;
  border-radius:16px;
  border:1px solid #d9e8ff;
  background:linear-gradient(180deg, #f8fbff 0%, #f2f7ff 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.58), 0 8px 18px rgba(37,99,235,.05);
}

#woospeak-ai-app .ws-listening-play{
  appearance:none;
  border:none;
  border-radius:999px;
  background:linear-gradient(135deg, var(--ws-assess-primary) 0%, #3b82f6 100%);
  color:#fff;
  font-weight:900;
  font-size:13px;
  line-height:1;
  padding:10px 15px;
  cursor:pointer;
  box-shadow:0 8px 18px rgba(37,99,235,.17), inset 0 1px 0 rgba(255,255,255,.22);
  transition:transform .16s ease, box-shadow .16s ease, background .16s ease;
}

#woospeak-ai-app .ws-listening-play:hover{
  transform:translateY(-1px);
  box-shadow:0 12px 24px rgba(37,99,235,.21);
}

#woospeak-ai-app .ws-listening-play.is-playing{
  background:linear-gradient(135deg, #0f9f6e 0%, #22c55e 100%);
  box-shadow:0 10px 22px rgba(34,197,94,.22);
}

#woospeak-ai-app .ws-listening-help{
  margin:10px 0 0;
  font-size:12px;
  line-height:1.5;
  color:var(--ws-assess-text-soft);
  font-weight:700;
}

/* =========================================================
   SPEAKING
   ========================================================= */
#woospeak-ai-app .ws-speaking-box{
  padding:16px 18px;
  border-radius:16px;
  border:1px solid rgba(37,99,235,.12);
  background:linear-gradient(180deg, #fbfdff 0%, #f7faff 100%);
  box-shadow:0 10px 26px rgba(15,23,42,.045);
}

#woospeak-ai-app .ws-speaking-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:10px;
}

#woospeak-ai-app .ws-speaking-start,
#woospeak-ai-app .ws-speaking-stop{
  appearance:none;
  border:none;
  min-height:40px;
  padding:0 15px;
  border-radius:999px;
  font-size:13px;
  font-weight:900;
  cursor:pointer;
  transition:transform .16s ease, box-shadow .16s ease, opacity .16s ease, background .16s ease;
}

#woospeak-ai-app .ws-speaking-start{
  background:linear-gradient(135deg, var(--ws-assess-primary) 0%, #3b82f6 100%);
  color:#fff;
  box-shadow:0 8px 18px rgba(37,99,235,.18);
}

#woospeak-ai-app .ws-speaking-stop{
  background:#ffffff;
  color:#334155;
  border:1px solid rgba(148,163,184,.28);
  box-shadow:0 4px 12px rgba(15,23,42,.05);
}

#woospeak-ai-app .ws-speaking-start:hover,
#woospeak-ai-app .ws-speaking-stop:hover{
  transform:translateY(-1px);
}

#woospeak-ai-app .ws-speaking-start:disabled,
#woospeak-ai-app .ws-speaking-stop:disabled{
  opacity:.6;
  cursor:not-allowed;
  transform:none;
}

#woospeak-ai-app .ws-speaking-help{
  margin:0 0 10px;
  font-size:12px;
  line-height:1.5;
  color:var(--ws-assess-text-soft);
}

#woospeak-ai-app .ws-speaking-status{
  margin:0 0 10px;
  padding:9px 11px;
  border-radius:12px;
  background:#fff;
  border:1px dashed rgba(37,99,235,.20);
  color:var(--ws-assess-text-soft);
  font-size:12px;
  font-weight:800;
}

#woospeak-ai-app .ws-speaking-box.is-recording{
  border-color:rgba(15,159,110,.28);
  box-shadow:0 14px 28px rgba(15,159,110,.11);
}

#woospeak-ai-app .ws-speaking-box.is-recording .ws-speaking-status{
  background:var(--ws-assess-success-soft);
  border-color:rgba(15,159,110,.22);
  color:var(--ws-assess-success);
}

#woospeak-ai-app .ws-speaking-box.is-recording .ws-speaking-start{
  background:linear-gradient(135deg, #0f9f6e 0%, #22c55e 100%);
  box-shadow:0 12px 24px rgba(34,197,94,.18);
}

/* =========================================================
   ERRORS / INLINE HELPERS
   ========================================================= */
#woospeak-ai-app .ws-form-error{
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(209,67,67,.18);
  background:linear-gradient(180deg, #fff7f7 0%, var(--ws-assess-danger-soft) 100%);
  color:#8a2f2f;
  box-shadow:var(--ws-assess-shadow-xs);
}
#woospeak-ai-app .ws-form-error[hidden]{ display:none !important; }
#woospeak-ai-app .ws-form-error-title{
  display:block;
  margin:0 0 4px;
  font-size:12px;
  font-weight:900;
}
#woospeak-ai-app .ws-form-error-message{
  display:block;
  font-size:12px;
  line-height:1.45;
  font-weight:700;
}

/* =========================================================
   ACTIONS / CTA
   ========================================================= */
#woospeak-ai-app .ws-step-footer,
#woospeak-ai-app .ws-submit-area{
  display:flex;
  justify-content:flex-end;
  margin-top:6px;
}

#woospeak-ai-app .ws-submit-step,
#woospeak-ai-app .ws-restart-assessment{
  appearance:none;
  border:none;
  border-radius:13px;
  background:linear-gradient(135deg, var(--ws-assess-primary) 0%, #3b82f6 100%);
  color:#fff;
  font-size:14px;
  font-weight:900;
  letter-spacing:.01em;
  padding:13px 20px;
  min-width:160px;
  min-height:46px;
  cursor:pointer;
  box-shadow:0 10px 20px rgba(37,99,235,.2), inset 0 1px 0 rgba(255,255,255,.18);
  transition:transform .16s ease, box-shadow .16s ease, background .16s ease, opacity .16s ease;
  position:relative;
  overflow:hidden;
}

#woospeak-ai-app .ws-submit-step::after,
#woospeak-ai-app .ws-restart-assessment::after,
#woospeak-ai-app .woospeak-ai-assessment-trigger::after{
  content:"";
  position:absolute;
  top:0;
  left:-120%;
  width:70%;
  height:100%;
  transform:skewX(-22deg);
  background:linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,.22), rgba(255,255,255,0));
  transition:left .52s ease;
}

#woospeak-ai-app .ws-submit-step:hover,
#woospeak-ai-app .ws-restart-assessment:hover{
  transform:translateY(-1px);
  box-shadow:0 13px 26px rgba(37,99,235,.24), inset 0 1px 0 rgba(255,255,255,.2);
  background:linear-gradient(135deg, var(--ws-assess-primary-2) 0%, var(--ws-assess-primary) 100%);
}
#woospeak-ai-app .ws-submit-step:hover::after,
#woospeak-ai-app .ws-restart-assessment:hover::after,
#woospeak-ai-app .woospeak-ai-assessment-trigger:hover::after{
  left:145%;
}
#woospeak-ai-app .ws-submit-step:disabled,
#woospeak-ai-app .ws-submit-step[aria-busy="true"]{
  opacity:.72;
  cursor:not-allowed;
  transform:none;
  box-shadow:0 8px 18px rgba(15,23,42,.12);
}

/* =========================================================
   WAITING / ERROR / RESULT
   ========================================================= */
#woospeak-ai-app .ws-assessment-waiting,
#woospeak-ai-app .ws-assessment-error,
#woospeak-ai-app .ws-assessment-result{
  position:relative;
  overflow:hidden;
  padding:28px 22px;
  border-radius:var(--ws-assess-radius-lg);
  border:1px solid var(--ws-assess-border);
  background:linear-gradient(180deg, #ffffff 0%, #fcfdff 100%);
  box-shadow:var(--ws-assess-shadow-md);
}

#woospeak-ai-app .ws-assessment-waiting::before,
#woospeak-ai-app .ws-assessment-result::before{
  content:"";
  position:absolute;
  inset:0 auto auto 0;
  width:100%;
  height:4px;
  background:linear-gradient(90deg, var(--ws-assess-primary) 0%, #60a5fa 55%, #818cf8 100%);
}

#woospeak-ai-app .ws-assessment-error{
  border-color:#f0cccc;
  background:linear-gradient(180deg, #ffffff 0%, #fffdfd 100%);
}

#woospeak-ai-app .ws-waiting-enhanced{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:240px;
}

#woospeak-ai-app .ws-waiting-box,
#woospeak-ai-app .ws-error-box{
  max-width:560px;
  margin:0 auto;
  text-align:center;
  position:relative;
}

#woospeak-ai-app .ws-waiting-box::before{
  content:"";
  position:absolute;
  inset:auto 50% -24px auto;
  width:170px;
  height:22px;
  transform:translateX(50%);
  background:radial-gradient(circle, rgba(37,99,235,.14), rgba(37,99,235,0) 72%);
  filter:blur(8px);
}

#woospeak-ai-app .ws-waiting-box h3,
#woospeak-ai-app .ws-error-box h3{
  margin:0 0 10px;
  font-size:24px;
  line-height:1.22;
  font-weight:900;
  letter-spacing:-.02em;
}

#woospeak-ai-app .ws-error-box h3{ color:var(--ws-assess-danger); }

#woospeak-ai-app .ws-waiting-box p,
#woospeak-ai-app .ws-error-box p{
  margin:0;
  font-size:14px;
  line-height:1.6;
  color:var(--ws-assess-text-soft);
}

#woospeak-ai-app .ws-waiting-spinner,
#woospeak-ai-app .ws-spinner{
  width:44px;
  height:44px;
  margin:0 auto 18px;
  border:4px solid #dce7f6;
  border-top-color:var(--ws-assess-primary);
  border-radius:50%;
  animation:wsAssessSpin .9s linear infinite;
  box-shadow:0 4px 14px rgba(37,99,235,.08);
}

@keyframes wsAssessSpin{ to{ transform:rotate(360deg); } }

/* =========================================================
   RESULT PAGE
   ========================================================= */
#woospeak-ai-app .ws-result-box{ display:flex; flex-direction:column; gap:20px; }
#woospeak-ai-app .ws-result-header{ display:flex; flex-direction:column; gap:8px; padding:4px 0 2px; }
#woospeak-ai-app .ws-result-eyebrow{
  margin:0;
  color:var(--ws-assess-primary);
  font-size:12px;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
}
#woospeak-ai-app .ws-result-title{
  margin:0;
  color:var(--ws-assess-text);
  font-size:30px;
  line-height:1.08;
  font-weight:950;
  letter-spacing:-.04em;
}
#woospeak-ai-app .ws-result-subtitle,
#woospeak-ai-app .ws-result-lead,
#woospeak-ai-app .ws-result-section-intro{
  margin:0;
  color:var(--ws-assess-text-soft);
  font-size:14px;
  line-height:1.55;
}

#woospeak-ai-app .ws-result-overview{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:14px;
}

#woospeak-ai-app .ws-result-metric,
#woospeak-ai-app .ws-result-skill-card,
#woospeak-ai-app .ws-result-step-card{
  border:1px solid rgba(148,163,184,.16);
  border-radius:16px;
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.96));
  box-shadow:var(--ws-assess-shadow-xs);
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}

#woospeak-ai-app .ws-result-metric:hover,
#woospeak-ai-app .ws-result-skill-card:hover,
#woospeak-ai-app .ws-result-step-card:hover,
#woospeak-ai-app .ws-result-correction-accordion:hover{
  transform:translateY(-2px);
}

#woospeak-ai-app .ws-result-metric{
  position:relative;
  overflow:hidden;
  padding:15px 16px;
}
#woospeak-ai-app .ws-result-metric::before,
#woospeak-ai-app .ws-result-step-card::before,
#woospeak-ai-app .ws-result-competency-card::before{
  content:"";
  position:absolute;
  inset:0 auto auto 0;
  width:100%;
  height:4px;
  background:linear-gradient(90deg, var(--ws-assess-primary) 0%, #60a5fa 55%, #818cf8 100%);
  opacity:.92;
}
#woospeak-ai-app .ws-result-metric-label{
  margin:0 0 8px;
  color:var(--ws-assess-text-muted);
  font-size:11px;
  font-weight:900;
  letter-spacing:.06em;
  text-transform:uppercase;
}
#woospeak-ai-app .ws-result-metric-value{
  color:var(--ws-assess-text);
  font-size:23px;
  line-height:1.1;
  font-weight:900;
  letter-spacing:-.02em;
}

#woospeak-ai-app .ws-result-section{ display:flex; flex-direction:column; gap:12px; }
#woospeak-ai-app .ws-result-section h3{
  margin:0;
  color:var(--ws-assess-text);
  font-size:21px;
  line-height:1.2;
  font-weight:900;
  letter-spacing:-.02em;
}

#woospeak-ai-app .ws-result-cefr-description{
  padding:16px 18px;
  border-radius:16px;
  background:linear-gradient(180deg, #f8fbff 0%, #f3f7ff 100%);
  border:1px solid #dbe7fb;
  color:#334155;
  line-height:1.6;
  box-shadow:var(--ws-assess-shadow-xs);
}

#woospeak-ai-app .ws-result-skills-grid,
#woospeak-ai-app .ws-result-steps-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:14px;
}

#woospeak-ai-app .ws-result-skill-card,
#woospeak-ai-app .ws-result-step-card{
  padding:16px;
  position:relative;
  overflow:hidden;
}

#woospeak-ai-app .ws-result-skill-header,
#woospeak-ai-app .ws-result-step-header,
#woospeak-ai-app .ws-result-step-header-compact{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:10px;
}

#woospeak-ai-app .ws-result-skill-header{
  align-items:center;
  margin-bottom:2px;
}

#woospeak-ai-app .ws-result-skill-header h4,
#woospeak-ai-app .ws-result-step-title{
  margin:0;
  color:var(--ws-assess-text);
  font-size:17px;
  line-height:1.28;
  font-weight:900;
}

#woospeak-ai-app .ws-result-skill-cefr,
#woospeak-ai-app .ws-result-step-badge,
#woospeak-ai-app .ws-result-step-badge-score{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:30px;
  padding:6px 10px;
  border-radius:999px;
  background:var(--ws-assess-primary-soft);
  border:1px solid rgba(37,99,235,.14);
  color:var(--ws-assess-primary);
  font-size:12px;
  font-weight:900;
  white-space:nowrap;
  box-shadow:0 4px 12px rgba(37,99,235,.08);
}
#woospeak-ai-app .ws-result-step-badge-score{
  background:linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}
#woospeak-ai-app .ws-result-step-meta,
#woospeak-ai-app .ws-result-step-score,
#woospeak-ai-app .ws-result-step-detail,
#woospeak-ai-app .ws-result-step-compact-meta{
  margin:0;
  font-size:13px;
  line-height:1.52;
  color:var(--ws-assess-text-soft);
  font-weight:700;
}
#woospeak-ai-app .ws-result-step-details{
  display:flex;
  flex-direction:column;
  gap:9px;
  margin-top:12px;
}
#woospeak-ai-app .ws-result-list{
  margin:0;
  padding-left:18px;
  color:var(--ws-assess-text-soft);
}
#woospeak-ai-app .ws-result-list li{
  margin:0 0 8px;
  line-height:1.5;
}
#woospeak-ai-app .ws-result-actions{
  display:flex;
  justify-content:flex-end;
  margin-top:4px;
}

/* =========================================================
   RESULT CORRECTIONS
   ========================================================= */
#woospeak-ai-app .ws-result-correction-group,
#woospeak-ai-app .ws-result-correction-accordion-list{
  display:flex;
  flex-direction:column;
  gap:10px;
}

#woospeak-ai-app .ws-result-correction-accordion{
  border:1px solid rgba(148,163,184,.18);
  border-radius:16px;
  overflow:hidden;
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(249,251,255,.98));
  box-shadow:0 8px 20px rgba(15,23,42,.045);
  transition:border-color .16s ease, box-shadow .16s ease, transform .16s ease;
}
#woospeak-ai-app .ws-result-correction-accordion[open]{
  box-shadow:0 14px 28px rgba(15,23,42,.08);
  border-color:rgba(37,99,235,.18);
}
#woospeak-ai-app .ws-result-correction-accordion-correct{
  border-color:rgba(15,159,110,.18);
}
#woospeak-ai-app .ws-result-correction-accordion-incorrect{
  border-color:rgba(209,67,67,.16);
}

#woospeak-ai-app .ws-result-correction-summary{
  list-style:none;
  cursor:pointer;
  display:block;
  position:relative;
  padding:14px 46px 14px 16px;
  transition:background .16s ease, color .16s ease;
}
#woospeak-ai-app .ws-result-correction-summary::-webkit-details-marker{ display:none; }
#woospeak-ai-app .ws-result-correction-summary::after{
  content:"⌄";
  position:absolute;
  top:50%;
  right:16px;
  transform:translateY(-52%);
  font-size:17px;
  font-weight:900;
  color:var(--ws-assess-text-muted);
  transition:transform .16s ease, color .16s ease;
}
#woospeak-ai-app .ws-result-correction-accordion[open] > .ws-result-correction-summary::after{
  transform:translateY(-52%) rotate(180deg);
  color:var(--ws-assess-primary);
}
#woospeak-ai-app .ws-result-correction-accordion-correct > .ws-result-correction-summary{
  background:linear-gradient(180deg, rgba(232,248,242,.96) 0%, rgba(255,255,255,.98) 100%);
}
#woospeak-ai-app .ws-result-correction-accordion-incorrect > .ws-result-correction-summary{
  background:linear-gradient(180deg, rgba(253,236,236,.96) 0%, rgba(255,255,255,.98) 100%);
}

#woospeak-ai-app .ws-result-correction-summary-main{
  display:flex;
  flex-direction:column;
  gap:3px;
  min-width:0;
}
#woospeak-ai-app .ws-result-correction-summary-title{
  display:block;
  color:var(--ws-assess-text);
  font-size:14px;
  line-height:1.38;
  font-weight:900;
}
#woospeak-ai-app .ws-result-correction-accordion-correct .ws-result-correction-summary-title{
  color:#0b7a55;
}
#woospeak-ai-app .ws-result-correction-accordion-incorrect .ws-result-correction-summary-title{
  color:#b03939;
}
#woospeak-ai-app .ws-result-correction-summary-meta{
  display:block;
  color:var(--ws-assess-text-soft);
  font-size:12px;
  line-height:1.42;
  font-weight:700;
}

#woospeak-ai-app .ws-result-correction-panel{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:14px 16px;
  border-top:1px solid rgba(148,163,184,.14);
  background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(248,250,255,.98) 100%);
}

#woospeak-ai-app .ws-result-correction-block{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:12px 13px;
  border-radius:14px;
  border:1px solid rgba(148,163,184,.14);
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,251,255,.96));
  box-shadow:0 2px 8px rgba(15,23,42,.03);
}

#woospeak-ai-app .ws-result-correction-block-label,
#woospeak-ai-app .ws-result-correction-question-label{
  margin:0;
  color:var(--ws-assess-text-muted);
  font-size:11px;
  line-height:1.2;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}

#woospeak-ai-app .ws-result-correction-prompt,
#woospeak-ai-app .ws-result-correction-line,
#woospeak-ai-app .ws-result-correction-template{
  margin:0;
  color:var(--ws-assess-text);
  font-size:14px;
  line-height:1.55;
  font-weight:700;
}
#woospeak-ai-app .ws-result-correction-template{
  color:var(--ws-assess-text-soft);
  font-style:italic;
}

#woospeak-ai-app .ws-result-correction-options{
  display:flex;
  flex-direction:column;
  gap:6px;
  margin:0;
  padding:0;
  list-style:none;
}
#woospeak-ai-app .ws-result-correction-options li{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(148,163,184,.12);
  background:#fff;
  color:var(--ws-assess-text);
  font-size:14px;
  line-height:1.45;
  font-weight:700;
}
#woospeak-ai-app .ws-result-correction-option-text{
  min-width:0;
  font-size:13px;
  font-weight:700;
  line-height:1.48;
}
#woospeak-ai-app .ws-result-correction-option-badge,
#woospeak-ai-app .ws-result-inline-badge{
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:24px;
  min-height:24px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  background:rgba(15,23,42,.04);
  color:var(--ws-assess-text-soft);
}
#woospeak-ai-app .ws-result-correction-options li.is-correct-answer{
  border-color:rgba(15,159,110,.2);
  background:linear-gradient(180deg, #f3fcf7 0%, #ecfbf4 100%);
}
#woospeak-ai-app .ws-result-correction-options li.is-correct-answer .ws-result-correction-option-text{
  color:#0b7a55;
  font-weight:900;
}
#woospeak-ai-app .ws-result-correction-options li.is-correct-answer .ws-result-correction-option-badge{
  background:rgba(15,159,110,.12);
  color:#0b7a55;
}
#woospeak-ai-app .ws-result-correction-options li.is-user-answer{
  border-color:rgba(209,67,67,.2);
  background:linear-gradient(180deg, #fff8f8 0%, #fff1f1 100%);
}
#woospeak-ai-app .ws-result-correction-options li.is-user-answer .ws-result-correction-option-text{
  color:#b03939;
  font-weight:800;
}
#woospeak-ai-app .ws-result-correction-options li.is-user-answer .ws-result-correction-option-badge{
  background:rgba(209,67,67,.1);
  color:#b03939;
}

#woospeak-ai-app .ws-result-answer-inline{
  margin:0;
  color:var(--ws-assess-text);
  font-size:13px;
  line-height:1.5;
}
#woospeak-ai-app .ws-result-answer-inline strong{
  color:var(--ws-assess-text-muted);
  font-weight:800;
}

#woospeak-ai-app .ws-result-skill-card{
  display:flex;
  flex-direction:column;
  gap:10px;
  min-height:100%;
}
#woospeak-ai-app .ws-result-skill-description{
  margin:0;
  color:var(--ws-assess-text);
  font-size:14px;
  line-height:1.56;
  font-weight:700;
}
#woospeak-ai-app .ws-result-skill-guidance{
  margin:0;
  color:var(--ws-assess-text-soft);
  font-size:13px;
  line-height:1.52;
  font-weight:600;
}
#woospeak-ai-app .ws-result-skill-score,
#woospeak-ai-app .ws-result-skill-meta,
#woospeak-ai-app .ws-result-skill-bar,
#woospeak-ai-app .ws-result-skill-bar-fill{
  display:none !important;
}

/* =========================================================
   ASSESSMENT TRIGGER + ACTIONS
   ========================================================= */
#woospeak-ai-app .woospeak-ai-assessment-trigger{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-width:220px;
  min-height:44px;
  padding:11px 16px;
  border-radius:14px;
  border:1px solid transparent;
  background:linear-gradient(135deg, #6366f1 0%, #4f46e5 100%);
  color:#ffffff !important;
  -webkit-text-fill-color:#ffffff !important;
  font-size:14px;
  font-weight:800;
  line-height:1.2;
  cursor:pointer;
  box-shadow:0 12px 26px rgba(79,70,229,.22);
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, opacity .18s ease;
  position:relative;
  overflow:hidden;
}
#woospeak-ai-app .woospeak-ai-assessment-trigger:hover{
  transform:translateY(-1px);
  box-shadow:0 16px 32px rgba(79,70,229,.26);
  background:linear-gradient(135deg, #4f46e5 0%, #4338ca 100%);
}
#woospeak-ai-app .woospeak-ai-assessment-trigger:active{
  transform:translateY(0);
  box-shadow:0 8px 18px rgba(79,70,229,.20);
}
#woospeak-ai-app .woospeak-ai-assessment-trigger:focus{
  outline:none;
  box-shadow:0 0 0 4px rgba(79,70,229,.12), 0 14px 28px rgba(79,70,229,.24);
}

#woospeak-ai-app .woospeak-ai-actions{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  grid-template-areas:
    "chat mic"
    "simulation assessment";
  gap:10px;
  width:100%;
  align-items:start;
}
#woospeak-ai-app #woospeak-ai-send{ grid-area:chat; }
#woospeak-ai-app .woospeak-ai-mic-stack{ grid-area:mic; }
#woospeak-ai-app #woospeak-ai-simulation-trigger{ grid-area:simulation; }
#woospeak-ai-app .woospeak-ai-assessment-trigger{
  grid-area:assessment;
  width:100%;
}

/* =========================================================
   ACCESSIBILITY / RESPONSIVE
   ========================================================= */
#woospeak-ai-app .ws-step,
#woospeak-ai-app .ws-step-form textarea,
#woospeak-ai-app .ws-step-form input[type="text"],
#woospeak-ai-app .ws-step-form select,
#woospeak-ai-app .ws-step-form label,
#woospeak-ai-app .ws-submit-step,
#woospeak-ai-app .ws-assessment-waiting,
#woospeak-ai-app .ws-assessment-error,
#woospeak-ai-app .ws-assessment-result{
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

#woospeak-ai-app .ws-step-form button:focus-visible,
#woospeak-ai-app .ws-step-form textarea:focus-visible,
#woospeak-ai-app .ws-step-form input:focus-visible,
#woospeak-ai-app .ws-step-form select:focus-visible,
#woospeak-ai-app .ws-restart-assessment:focus-visible{
  outline:none;
  box-shadow:0 0 0 4px rgba(37,99,235,.12), 0 14px 28px rgba(37,99,235,.18);
}

@keyframes wsFadeUp{
  from{ opacity:0; transform:translateY(10px); }
  to{ opacity:1; transform:translateY(0); }
}

@keyframes wsShimmer{
  0%{ transform:translateX(-100%); }
  100%{ transform:translateX(180%); }
}

@media (max-width:900px){
  #woospeak-ai-app #woospeak-ai-level,
  #woospeak-ai-app .woospeak-ai-level-inner,
  #woospeak-ai-app .ws-assessment-shell{
    padding:16px;
  }

  #woospeak-ai-app .ws-step-shell{
    padding:20px 18px 18px;
    gap:12px;
  }

  #woospeak-ai-app .ws-question-en{
    font-size:18px;
  }

  #woospeak-ai-app .ws-result-overview,
  #woospeak-ai-app .ws-result-skills-grid,
  #woospeak-ai-app .ws-result-steps-grid{
    grid-template-columns:1fr 1fr;
  }
}

@media (max-width:640px){
  #woospeak-ai-app .woospeak-ai-actions{
    grid-template-columns:1fr;
    grid-template-areas:
      "chat"
      "simulation"
      "assessment"
      "mic";
  }

  #woospeak-ai-app .woospeak-ai-assessment-trigger{
    width:100%;
    min-width:0;
  }

  #woospeak-ai-app .ws-step-shell{
    padding:16px 14px 15px;
    gap:10px;
  }

  #woospeak-ai-app .ws-step-topbar{
    gap:8px;
    align-items:flex-start;
    flex-direction:column;
  }

  #woospeak-ai-app .ws-step-header{
    font-size:11px;
    padding:7px 11px;
  }

  #woospeak-ai-app .ws-step-progress{
    font-size:11px;
  }

  #woospeak-ai-app .ws-progress-modern-rail{
    height:7px;
  }

  #woospeak-ai-app .ws-question-card,
  #woospeak-ai-app .ws-form-card,
  #woospeak-ai-app .ws-question-block{
    padding:12px;
    border-radius:14px;
  }

  #woospeak-ai-app .ws-question-en{
    font-size:17px;
    line-height:1.42;
  }

  #woospeak-ai-app .ws-question-subtitle{
    font-size:14px;
  }

  #woospeak-ai-app .ws-choice-option,
  #woospeak-ai-app .ws-step-form label{
    padding:12px 12px;
    gap:10px;
    border-radius:13px;
    align-items:flex-start;
  }

  #woospeak-ai-app .ws-step-form textarea,
  #woospeak-ai-app .ws-step-form input[type="text"],
  #woospeak-ai-app .ws-step-form select{
    font-size:14px;
    padding:13px 13px;
    border-radius:13px;
  }

  #woospeak-ai-app .ws-open-question-textarea,
  #woospeak-ai-app .ws-speaking-transcript{
    min-height:180px !important;
    padding:14px !important;
    font-size:14px !important;
  }

  #woospeak-ai-app .ws-submit-area,
  #woospeak-ai-app .ws-result-actions{
    justify-content:stretch;
  }

  #woospeak-ai-app .ws-submit-step,
  #woospeak-ai-app .ws-restart-assessment,
  #woospeak-ai-app .ws-listening-play{
    width:100%;
    min-width:0;
  }

  #woospeak-ai-app .ws-fill-choices{
    gap:7px;
  }

  #woospeak-ai-app .ws-fill-choice{
    font-size:12px;
    padding:7px 11px;
  }

  #woospeak-ai-app .ws-speaking-actions{
    flex-direction:column;
  }

  #woospeak-ai-app .ws-result-overview,
  #woospeak-ai-app .ws-result-skills-grid,
  #woospeak-ai-app .ws-result-steps-grid{
    grid-template-columns:1fr;
  }

  #woospeak-ai-app .ws-result-title{
    font-size:25px;
  }

  #woospeak-ai-app .ws-result-section h3{
    font-size:19px;
  }

  #woospeak-ai-app .ws-fill-gaps-sentence input[type="text"]{
    width:100%;
    margin:6px 0;
    display:block;
  }

  #woospeak-ai-app .ws-result-correction-summary{
    padding:13px 40px 13px 13px;
  }

  #woospeak-ai-app .ws-result-correction-summary-title{
    font-size:13px;
  }

  #woospeak-ai-app .ws-result-correction-summary-meta{
    font-size:11px;
  }

  #woospeak-ai-app .ws-result-correction-panel{
    gap:10px;
    padding:12px;
  }

  #woospeak-ai-app .ws-result-correction-block{
    padding:11px;
    border-radius:12px;
  }

  #woospeak-ai-app .ws-result-correction-options li{
    padding:10px 11px;
    align-items:flex-start;
  }

  #woospeak-ai-app .ws-result-correction-option-text{
    font-size:12px;
  }
}
/* =========================================================
   WOOSPEAK AI — ASSESSMENT UI V4
   Compact / Premium / Stronger hierarchy
   À coller tout à la fin du fichier
   ========================================================= */

#woospeak-ai-app{
  --ws-v4-panel:#ffffff;
  --ws-v4-panel-soft:linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(247,250,255,.98) 100%);
  --ws-v4-stroke:rgba(148,163,184,.16);
  --ws-v4-stroke-strong:rgba(37,99,235,.18);
  --ws-v4-shadow-1:0 8px 24px rgba(15,23,42,.05);
  --ws-v4-shadow-2:0 14px 36px rgba(37,99,235,.10);
  --ws-v4-shadow-3:0 20px 46px rgba(15,23,42,.10);
}

/* =========================================================
   GLOBAL STEP COMPACTION + BETTER STRUCTURE
   ========================================================= */
#woospeak-ai-app .ws-step{
  padding:22px 22px 18px;
  border-radius:22px;
  box-shadow:var(--ws-v4-shadow-1);
}

#woospeak-ai-app .ws-step::before{
  height:4px;
}

#woospeak-ai-app .ws-step-shell{
  display:flex;
  flex-direction:column;
  gap:14px;
}

#woospeak-ai-app .ws-step-topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin-bottom:2px;
}

#woospeak-ai-app .ws-step-header{
  margin:0;
  padding:8px 14px;
  font-size:12px;
  letter-spacing:.06em;
  box-shadow:none;
}

#woospeak-ai-app .ws-step-progress{
  margin:0;
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#7b8aa2;
  font-weight:900;
}

#woospeak-ai-app .ws-step-progressbar{
  position:relative;
  height:10px;
  border-radius:999px;
  overflow:hidden;
  background:linear-gradient(180deg, #e7eef8 0%, #eef3fb 100%);
  border:1px solid rgba(148,163,184,.10);
}

#woospeak-ai-app .ws-step-progressbar-fill{
  position:absolute;
  inset:0 auto 0 0;
  width:var(--ws-step-progress, 0%);
  border-radius:999px;
  background:linear-gradient(90deg, #2563eb 0%, #4f7cff 48%, #7c3aed 100%);
  box-shadow:0 8px 20px rgba(37,99,235,.18);
}

#woospeak-ai-app .ws-step-progressbar-fill::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(255,255,255,0) 0%, rgba(255,255,255,.30) 45%, rgba(255,255,255,0) 100%);
  animation:wsV4Shimmer 2.6s linear infinite;
}

#woospeak-ai-app .ws-step-body{
  display:flex;
  flex-direction:column;
  gap:14px;
}

/* =========================================================
   QUESTION CARD
   ========================================================= */
#woospeak-ai-app .ws-question-card{
  position:relative;
  overflow:hidden;
  padding:18px 18px 16px;
  border-radius:20px;
  border:1px solid var(--ws-v4-stroke);
  background:var(--ws-v4-panel-soft);
  box-shadow:0 2px 10px rgba(15,23,42,.03);
}

#woospeak-ai-app .ws-question-card::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(420px 120px at 0% 0%, rgba(37,99,235,.05), transparent 60%),
    linear-gradient(135deg, rgba(255,255,255,.28), rgba(255,255,255,0) 30%);
}

#woospeak-ai-app .ws-question-eyebrow{
  position:relative;
  z-index:1;
  margin:0 0 10px;
  color:#2563eb;
  font-size:11px;
  line-height:1.2;
  font-weight:900;
  letter-spacing:.16em;
  text-transform:uppercase;
}

#woospeak-ai-app .ws-question{
  position:relative;
  z-index:1;
  margin:0;
}

#woospeak-ai-app .ws-question-en{
  margin:0;
  font-size:22px;
  line-height:1.34;
  font-weight:950;
  letter-spacing:-.03em;
  color:#142033;
  text-wrap:pretty;
}

#woospeak-ai-app .ws-question-subtitle{
  margin:0 0 10px;
  font-size:15px;
  line-height:1.45;
  font-weight:850;
  color:#1d2940;
}

/* =========================================================
   FORM CARD
   ========================================================= */
#woospeak-ai-app .ws-form-card{
  padding:16px;
  border-radius:20px;
  border:1px solid rgba(148,163,184,.14);
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(250,252,255,.98));
  box-shadow:0 4px 14px rgba(15,23,42,.04);
}

#woospeak-ai-app .ws-step-form{
  gap:12px;
}

/* =========================================================
   CHOICE BLOCKS — MORE COMPACT / MORE PREMIUM
   ========================================================= */
#woospeak-ai-app .ws-question-block{
  margin:0 0 14px;
  padding:14px;
  border-radius:18px;
  background:linear-gradient(180deg, rgba(248,251,255,.92), rgba(255,255,255,.98));
  border:1px solid rgba(148,163,184,.14);
  box-shadow:none;
}

#woospeak-ai-app .ws-question-block:last-child{
  margin-bottom:0;
}

#woospeak-ai-app .ws-question-chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:6px 12px;
  margin:0 0 10px;
  border-radius:999px;
  border:1px solid rgba(37,99,235,.12);
  background:#f3f7ff;
  color:#4f7cff;
  font-size:11px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
}

#woospeak-ai-app .ws-choice-option,
#woospeak-ai-app .ws-step-form label{
  gap:12px;
  padding:14px 16px;
  border-radius:16px;
  border:1px solid #d9e3f2;
  background:linear-gradient(180deg, #ffffff 0%, #fcfdff 100%);
  font-size:14px;
  line-height:1.42;
  font-weight:700;
  box-shadow:none;
}

#woospeak-ai-app .ws-choice-option + .ws-choice-option,
#woospeak-ai-app .ws-step-form label + label{
  margin-top:8px;
}

#woospeak-ai-app .ws-choice-option:hover,
#woospeak-ai-app .ws-step-form label:hover{
  border-color:rgba(37,99,235,.26);
  background:#fbfdff;
  box-shadow:0 8px 22px rgba(37,99,235,.07);
  transform:translateY(-1px);
}

#woospeak-ai-app .ws-choice-option input[type="radio"],
#woospeak-ai-app .ws-step-form label input[type="radio"]{
  width:20px;
  height:20px;
  margin:1px 0 0;
  accent-color:#2563eb;
  transform:none;
}

#woospeak-ai-app .ws-choice-option:has(input[type="radio"]:checked),
#woospeak-ai-app .ws-step-form label:has(input[type="radio"]:checked),
#woospeak-ai-app .ws-choice-option.is-selected,
#woospeak-ai-app .ws-step-form label.is-selected{
  border-color:rgba(37,99,235,.50);
  background:linear-gradient(180deg, #edf4ff 0%, #f4f8ff 100%);
  box-shadow:0 10px 24px rgba(37,99,235,.10);
}

/* =========================================================
   OPEN ANSWER / WRITING / SPEAKING
   ========================================================= */
#woospeak-ai-app .ws-step-form textarea,
#woospeak-ai-app .ws-step-form input[type="text"],
#woospeak-ai-app .ws-step-form select{
  border-radius:16px;
  padding:14px 16px;
  font-size:14px;
}

#woospeak-ai-app .ws-step-form textarea{
  min-height:150px;
}

#woospeak-ai-app .ws-open-question-textarea,
#woospeak-ai-app .ws-speaking-transcript{
  min-height:190px !important;
  padding:16px 18px !important;
  font-size:15px !important;
  line-height:1.62;
}

#woospeak-ai-app .ws-word-helper{
  margin-top:6px;
  font-size:12px;
}

/* =========================================================
   FILL IN THE BLANK
   ========================================================= */
#woospeak-ai-app .ws-fill-inputs{
  gap:10px;
}

#woospeak-ai-app .ws-fill-gaps-sentence{
  padding:16px 18px;
  border-radius:18px;
  font-size:15px;
  line-height:1.8;
}

#woospeak-ai-app .ws-fill-gaps-sentence input[type="text"]{
  width:136px;
  margin:0 4px;
  padding:9px 11px;
  border-radius:12px;
  font-size:13px;
}

#woospeak-ai-app .ws-word-bank{
  margin-top:2px;
  font-size:12px;
}

#woospeak-ai-app .ws-fill-choices{
  gap:8px;
}

#woospeak-ai-app .ws-fill-choice{
  padding:8px 12px;
  font-size:13px;
  font-weight:800;
  box-shadow:none;
}

/* =========================================================
   LISTENING — PLAYER FEEL
   ========================================================= */
#woospeak-ai-app .ws-listening{
  padding:16px;
  border-radius:18px;
  border:1px solid rgba(37,99,235,.16);
  background:linear-gradient(135deg, #f4f8ff 0%, #ffffff 100%);
  box-shadow:none;
}

#woospeak-ai-app .ws-listening-head{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:10px;
}

#woospeak-ai-app .ws-listening-play{
  min-width:122px;
  min-height:42px;
  padding:10px 16px;
  font-size:14px;
  box-shadow:0 8px 18px rgba(37,99,235,.16);
}

#woospeak-ai-app .ws-listening-meta{
  display:flex;
  flex-direction:column;
  gap:2px;
  min-width:0;
}

#woospeak-ai-app .ws-listening-meta-title{
  color:#142033;
  font-size:13px;
  font-weight:900;
  line-height:1.3;
}

#woospeak-ai-app .ws-listening-help{
  margin:0;
  font-size:12px;
  line-height:1.45;
}

/* =========================================================
   SPEAKING — CLEANER RECORDER
   ========================================================= */
#woospeak-ai-app .ws-speaking-box{
  padding:16px;
  border-radius:18px;
}

#woospeak-ai-app .ws-speaking-actions{
  gap:8px;
  margin-bottom:10px;
}

#woospeak-ai-app .ws-speaking-start,
#woospeak-ai-app .ws-speaking-stop{
  min-height:40px;
  padding:0 14px;
  font-size:13px;
  font-weight:900;
}

#woospeak-ai-app .ws-speaking-help{
  margin:0 0 8px;
  font-size:12px;
}

#woospeak-ai-app .ws-speaking-status{
  margin:0 0 10px;
  padding:9px 11px;
  border-radius:12px;
  font-size:12px;
}

/* =========================================================
   CTA
   ========================================================= */
#woospeak-ai-app .ws-submit-area{
  margin-top:6px;
}

#woospeak-ai-app .ws-submit-step,
#woospeak-ai-app .ws-restart-assessment{
  min-width:152px;
  min-height:44px;
  padding:12px 18px;
  border-radius:14px;
  font-size:14px;
  box-shadow:0 10px 20px rgba(37,99,235,.18);
}

/* =========================================================
   WAITING / ERROR
   ========================================================= */
#woospeak-ai-app .ws-assessment-waiting,
#woospeak-ai-app .ws-assessment-error,
#woospeak-ai-app .ws-assessment-result{
  padding:24px 22px;
  border-radius:22px;
}

#woospeak-ai-app .ws-waiting-box h3,
#woospeak-ai-app .ws-error-box h3{
  font-size:24px;
}

#woospeak-ai-app .ws-waiting-box p,
#woospeak-ai-app .ws-error-box p{
  font-size:14px;
}

/* =========================================================
   RESULTS — STRONGER VISUAL HIERARCHY
   ========================================================= */
#woospeak-ai-app .ws-result-box{
  gap:18px;
}

#woospeak-ai-app .ws-result-header{
  gap:6px;
}

#woospeak-ai-app .ws-result-eyebrow{
  font-size:11px;
  letter-spacing:.18em;
}

#woospeak-ai-app .ws-result-title{
  font-size:28px;
  line-height:1.06;
}

#woospeak-ai-app .ws-result-subtitle,
#woospeak-ai-app .ws-result-lead,
#woospeak-ai-app .ws-result-section-intro{
  font-size:14px;
}

#woospeak-ai-app .ws-result-overview{
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:12px;
}

#woospeak-ai-app .ws-result-metric{
  position:relative;
  overflow:hidden;
  padding:14px 16px;
  border-radius:18px;
  box-shadow:none;
}

#woospeak-ai-app .ws-result-metric::before{
  content:"";
  position:absolute;
  inset:0 auto auto 0;
  width:100%;
  height:4px;
  background:linear-gradient(90deg, #2563eb 0%, #60a5fa 52%, #818cf8 100%);
}

#woospeak-ai-app .ws-result-metric:first-child{
  border-color:rgba(37,99,235,.24);
  background:linear-gradient(135deg, #eef4ff 0%, #ffffff 100%);
  box-shadow:0 14px 30px rgba(37,99,235,.12);
}

#woospeak-ai-app .ws-result-metric-label{
  margin:0 0 8px;
  font-size:11px;
  letter-spacing:.10em;
}

#woospeak-ai-app .ws-result-metric-value{
  font-size:19px;
  font-weight:950;
  letter-spacing:-.03em;
}

#woospeak-ai-app .ws-result-metric:first-child .ws-result-metric-value{
  font-size:30px;
}

#woospeak-ai-app .ws-result-section{
  gap:12px;
}

#woospeak-ai-app .ws-result-section h3{
  font-size:18px;
}

#woospeak-ai-app .ws-result-cefr-description{
  padding:16px 18px;
  border-radius:18px;
  font-size:14px;
}

#woospeak-ai-app .ws-result-skills-grid,
#woospeak-ai-app .ws-result-steps-grid{
  gap:12px;
}

#woospeak-ai-app .ws-result-skill-card,
#woospeak-ai-app .ws-result-step-card{
  padding:14px 16px;
  border-radius:18px;
  box-shadow:none;
}

#woospeak-ai-app .ws-result-skill-header,
#woospeak-ai-app .ws-result-step-header{
  margin-bottom:8px;
}

#woospeak-ai-app .ws-result-skill-header h4,
#woospeak-ai-app .ws-result-step-title{
  font-size:16px;
}

#woospeak-ai-app .ws-result-skill-cefr,
#woospeak-ai-app .ws-result-step-badge{
  min-height:28px;
  padding:5px 10px;
  font-size:11px;
}

#woospeak-ai-app .ws-result-skill-description{
  font-size:14px;
  line-height:1.5;
  font-weight:800;
}

#woospeak-ai-app .ws-result-skill-guidance,
#woospeak-ai-app .ws-result-step-meta,
#woospeak-ai-app .ws-result-step-score,
#woospeak-ai-app .ws-result-step-detail{
  font-size:13px;
  line-height:1.5;
}

#woospeak-ai-app .ws-result-list{
  padding-left:17px;
}

#woospeak-ai-app .ws-result-list li{
  margin:0 0 8px;
  font-size:13px;
  line-height:1.55;
}

#woospeak-ai-app .ws-result-actions{
  margin-top:0;
}

/* =========================================================
   CORRECTIONS — MORE DENSE
   ========================================================= */
#woospeak-ai-app .ws-result-correction-accordion{
  border-radius:16px;
  box-shadow:none;
}

#woospeak-ai-app .ws-result-correction-summary{
  padding:14px 44px 14px 14px;
}

#woospeak-ai-app .ws-result-correction-summary-title{
  font-size:14px;
  line-height:1.35;
}

#woospeak-ai-app .ws-result-correction-summary-meta{
  font-size:12px;
}

#woospeak-ai-app .ws-result-correction-panel{
  gap:10px;
  padding:14px;
}

#woospeak-ai-app .ws-result-correction-block{
  gap:6px;
  padding:12px;
  border-radius:14px;
}

#woospeak-ai-app .ws-result-correction-block-label{
  font-size:10px;
}

#woospeak-ai-app .ws-result-correction-prompt,
#woospeak-ai-app .ws-result-correction-line,
#woospeak-ai-app .ws-result-correction-template{
  font-size:13px;
  line-height:1.5;
}

#woospeak-ai-app .ws-result-correction-options{
  gap:6px;
}

#woospeak-ai-app .ws-result-correction-options li{
  padding:10px 12px;
  border-radius:12px;
}

#woospeak-ai-app .ws-result-correction-option-text{
  font-size:13px;
}

#woospeak-ai-app .ws-result-correction-option-badge{
  min-width:22px;
  min-height:22px;
  font-size:11px;
}

/* =========================================================
   PREMIUM MICRO MOTION
   ========================================================= */
#woospeak-ai-app .ws-step,
#woospeak-ai-app .ws-result-metric,
#woospeak-ai-app .ws-result-skill-card,
#woospeak-ai-app .ws-result-step-card,
#woospeak-ai-app .ws-question-card,
#woospeak-ai-app .ws-form-card{
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}

#woospeak-ai-app .ws-result-metric:hover,
#woospeak-ai-app .ws-result-skill-card:hover,
#woospeak-ai-app .ws-result-step-card:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 28px rgba(15,23,42,.08);
}

#woospeak-ai-app .ws-question-card:hover,
#woospeak-ai-app .ws-form-card:hover{
  border-color:rgba(37,99,235,.16);
}

@keyframes wsV4Shimmer{
  0%{ transform:translateX(-100%); }
  100%{ transform:translateX(180%); }
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:900px){
  #woospeak-ai-app .ws-step{
    padding:18px 18px 16px;
  }

  #woospeak-ai-app .ws-question-en{
    font-size:20px;
  }

  #woospeak-ai-app .ws-result-overview{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  #woospeak-ai-app .ws-result-skills-grid,
  #woospeak-ai-app .ws-result-steps-grid{
    grid-template-columns:1fr 1fr;
  }
}

@media (max-width:640px){
  #woospeak-ai-app .ws-step-topbar{
    flex-direction:column;
    align-items:flex-start;
    gap:10px;
  }

  #woospeak-ai-app .ws-step{
    padding:16px 14px 14px;
    border-radius:18px;
  }

  #woospeak-ai-app .ws-question-card,
  #woospeak-ai-app .ws-form-card{
    padding:14px;
    border-radius:16px;
  }

  #woospeak-ai-app .ws-question-en{
    font-size:18px;
    line-height:1.42;
  }

  #woospeak-ai-app .ws-question-subtitle{
    font-size:14px;
  }

  #woospeak-ai-app .ws-question-block{
    padding:12px;
    border-radius:16px;
  }

  #woospeak-ai-app .ws-choice-option,
  #woospeak-ai-app .ws-step-form label{
    padding:12px 13px;
    gap:10px;
    font-size:13px;
  }

  #woospeak-ai-app .ws-step-form textarea,
  #woospeak-ai-app .ws-step-form input[type="text"],
  #woospeak-ai-app .ws-step-form select{
    padding:13px 14px;
    font-size:13px;
  }

  #woospeak-ai-app .ws-open-question-textarea,
  #woospeak-ai-app .ws-speaking-transcript{
    min-height:170px !important;
    padding:14px 15px !important;
    font-size:14px !important;
  }

  #woospeak-ai-app .ws-fill-gaps-sentence input[type="text"]{
    width:100%;
    display:block;
    margin:6px 0;
  }

  #woospeak-ai-app .ws-listening-head{
    flex-direction:column;
    align-items:flex-start;
  }

  #woospeak-ai-app .ws-listening-play,
  #woospeak-ai-app .ws-submit-step,
  #woospeak-ai-app .ws-restart-assessment{
    width:100%;
    min-width:0;
  }

  #woospeak-ai-app .ws-result-title{
    font-size:24px;
  }

  #woospeak-ai-app .ws-result-overview,
  #woospeak-ai-app .ws-result-skills-grid,
  #woospeak-ai-app .ws-result-steps-grid{
    grid-template-columns:1fr;
  }
}
/* Fix — remove duplicated native radio circle */
#woospeak-ai-app .ws-choice-option input[type="radio"],
#woospeak-ai-app .ws-step-form label input[type="radio"]{
  position:absolute !important;
  opacity:0 !important;
  pointer-events:none !important;
  width:1px !important;
  height:1px !important;
  margin:0 !important;
}

/* Keep custom control aligned */
#woospeak-ai-app .ws-choice-option,
#woospeak-ai-app .ws-step-form label{
  position:relative;
}
/* ===============================
   RADIO CUSTOM — ACTIVE STATE V4
   =============================== */

/* Cercle de base */
#woospeak-ai-app .ws-choice-control{
  width:20px;
  height:20px;
  border-radius:50%;
  border:2px solid #c7d2e5;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:all .18s ease;
}

/* Point intérieur */
#woospeak-ai-app .ws-choice-control::after{
  content:"";
  width:8px;
  height:8px;
  border-radius:50%;
  background:#2563eb;
  transform:scale(0);
  transition:all .18s ease;
}

/* 👉 HOVER */
#woospeak-ai-app .ws-choice-option:hover .ws-choice-control{
  border-color:#4f7cff;
}

/* 👉 SELECTED */
#woospeak-ai-app .ws-choice-option:has(input[type="radio"]:checked) .ws-choice-control,
#woospeak-ai-app .ws-choice-option.is-selected .ws-choice-control{
  border-color:#2563eb;
  background:#eef4ff;
  box-shadow:0 0 0 4px rgba(37,99,235,.12);
}

/* 👉 DOT visible */
#woospeak-ai-app .ws-choice-option:has(input[type="radio"]:checked) .ws-choice-control::after,
#woospeak-ai-app .ws-choice-option.is-selected .ws-choice-control::after{
  transform:scale(1);
}

/* 👉 PETIT EFFET CLICK (micro animation) */
#woospeak-ai-app .ws-choice-option:has(input[type="radio"]:checked) .ws-choice-control{
  animation:wsRadioPop .22s ease;
}

@keyframes wsRadioPop{
  0%{ transform:scale(.85); }
  100%{ transform:scale(1); }
}
/* ===============================
   GAP INPUT — VERSION PREMIUM
   =============================== */
#woospeak-ai-app .ws-gap-input{
  display:inline-block;
  width:110px;
  min-width:110px;
  height:44px;
  margin:0 6px;
  padding:0 12px;

  border-radius:14px;
  border:1.5px solid #d6deed;
  background:#f8fbff;
  color:#142033;

  font-size:15px;
  font-weight:700;
  line-height:44px;
  text-align:center;
  vertical-align:middle;

  transition:
    border-color .18s ease,
    background .18s ease,
    box-shadow .18s ease,
    transform .18s ease;
}

#woospeak-ai-app .ws-gap-input::placeholder{
  color:#9aa8bb;
  font-weight:700;
}

#woospeak-ai-app .ws-gap-input:hover{
  border-color:#4f7cff;
  background:#eef4ff;
}

#woospeak-ai-app .ws-gap-input:focus{
  outline:none;
  border-color:#2563eb;
  background:#ffffff;
  box-shadow:0 0 0 4px rgba(37,99,235,.12);
}

#woospeak-ai-app .ws-gap-input.filled{
  border-color:#2563eb;
  background:#eef4ff;
  box-shadow:0 8px 20px rgba(37,99,235,.10);
}