@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800&display=swap');

#cw-qgen * { box-sizing: border-box; margin: 0; padding: 0; }
#cw-qgen {
  font-family: 'Nunito', 'Segoe UI', sans-serif;
  background: linear-gradient(160deg, #e8f4fd 0%, #fef9f0 55%, #edf7f0 100%);
  border-radius: 20px;
  overflow: hidden;
  max-width: 760px;
  margin: 0 auto;
}
#cw-qgen header {
  background: linear-gradient(135deg, #1a6fa8, #2d9cdb);
  padding: 26px 32px;
  position: relative;
  overflow: hidden;
}
#cw-qgen header::before {
  content: ''; position: absolute; border-radius: 50%;
  background: rgba(255,255,255,.09);
  width: 200px; height: 200px; top: -70px; right: 40px;
}
#cw-qgen .cw-hi { position: relative; z-index: 1; }
#cw-qgen .cw-eye {
  color: rgba(255,255,255,.72); font-size: 11px;
  letter-spacing: 3px; text-transform: uppercase;
  font-weight: 700; margin-bottom: 6px;
}
#cw-qgen h2 {
  color: #fff; font-size: clamp(18px, 3.5vw, 26px);
  font-weight: 800; line-height: 1.2;
}
#cw-qgen .cw-sub { color: rgba(255,255,255,.78); font-size: 13px; margin-top: 5px; }
#cw-qgen .cw-body { padding: 28px 28px 40px; }
#cw-qgen .cw-lbl {
  display: block; font-size: 11px; font-weight: 800;
  letter-spacing: 2.5px; text-transform: uppercase;
  color: #888; margin-bottom: 10px;
}
#cw-qgen .cw-grades { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 24px; }
#cw-qgen .cw-gpill {
  padding: 9px 18px; border-radius: 40px;
  border: 2px solid #ddd; background: #fff;
  font-family: inherit; font-size: 13px; font-weight: 700;
  color: #666; cursor: pointer; transition: all .17s;
}
#cw-qgen .cw-gpill:hover { border-color: #2d9cdb; color: #1a6fa8; }
#cw-qgen .cw-gpill.cw-active {
  border-color: #1a6fa8; background: #1a6fa8;
  color: #fff; box-shadow: 0 3px 14px rgba(26,111,168,.3);
}
#cw-qgen .cw-drop {
  border: 2.5px dashed #b0cfe8; border-radius: 16px;
  background: #fff; padding: 36px 20px; text-align: center;
  cursor: pointer; transition: all .2s; margin-bottom: 18px;
  box-shadow: 0 2px 12px rgba(0,0,0,.04);
}
#cw-qgen .cw-drop:hover,
#cw-qgen .cw-drop.cw-drag { border-color: #2d9cdb; background: rgba(45,156,219,.04); }
#cw-qgen .cw-drop.cw-loaded { border-color: #3aaa6e; background: rgba(58,170,110,.05); }
#cw-qgen .cw-dicon { font-size: 36px; margin-bottom: 8px; }
#cw-qgen .cw-dtitle { font-size: 15px; font-weight: 700; color: #1a6fa8; margin-bottom: 3px; }
#cw-qgen .cw-drop.cw-loaded .cw-dtitle { color: #2d7a47; }
#cw-qgen .cw-dsub { font-size: 12px; color: #aaa; }
#cw-qgen .cw-err {
  background: #fff3f3; border: 1.5px solid #f5c2c2;
  border-radius: 10px; padding: 12px 15px;
  color: #c0392b; font-size: 13px;
  margin-bottom: 15px; display: none; line-height: 1.5;
}

/* ── Main generate button ── */
#cw-qgen .cw-btn {
  width: 100%; padding: 15px; border-radius: 14px; border: none;
  background: linear-gradient(135deg, #1a6fa8, #2d9cdb);
  color: #fff; font-family: inherit; font-size: 16px;
  font-weight: 800; cursor: pointer; transition: all .2s;
  box-shadow: 0 4px 20px rgba(26,111,168,.38);
  display: flex; align-items: center; justify-content: center; gap: 10px;
  margin-bottom: 0;
}
#cw-qgen .cw-btn:disabled { background: #a0c4e0; box-shadow: none; cursor: not-allowed; }
#cw-qgen .cw-btn:not(:disabled):hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 24px rgba(26,111,168,.45);
}

/* ── Skills button ── */
#cw-qgen .cw-btn-skills {
  background: linear-gradient(135deg, #7B5EA7, #9b6dd6);
  box-shadow: 0 4px 20px rgba(123,94,167,.35);
  margin-top: 12px;
}
#cw-qgen .cw-btn-skills:disabled { background: #c5b8d8; box-shadow: none; cursor: not-allowed; }
#cw-qgen .cw-btn-skills:not(:disabled):hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 24px rgba(123,94,167,.45);
}

/* ── Translate button ── */
#cw-qgen #cw-translate-bar { margin-top: 12px; }
#cw-qgen .cw-btn-translate {
  background: linear-gradient(135deg, #1a9a94, #3CBBB1);
  box-shadow: 0 4px 20px rgba(60,187,177,.35);
}
#cw-qgen .cw-btn-translate:disabled { background: #a8d8d6; box-shadow: none; cursor: not-allowed; }
#cw-qgen .cw-btn-translate:not(:disabled):hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 24px rgba(60,187,177,.45);
}

/* ── Spinner ── */
#cw-qgen .cw-spin {
  width: 17px; height: 17px; border-radius: 50%;
  border: 2.5px solid rgba(255,255,255,.35);
  border-top-color: #fff; display: none;
  animation: cw-spin .7s linear infinite; flex-shrink: 0;
}
@keyframes cw-spin { to { transform: rotate(360deg); } }

/* ── Results header ── */
#cw-qgen .cw-rhead {
  display: flex; justify-content: space-between;
  align-items: center; margin-bottom: 16px; margin-top: 32px;
}
#cw-qgen .cw-cbtn {
  padding: 7px 15px; border-radius: 30px;
  border: 1.5px solid #2d9cdb; background: transparent;
  color: #1a6fa8; font-family: inherit;
  font-size: 12px; font-weight: 700; cursor: pointer; transition: all .15s;
}
#cw-qgen .cw-cbtn:hover { background: #1a6fa8; color: #fff; }
#cw-qgen .cw-cbtn-skills { border-color: #7B5EA7; color: #7B5EA7; }
#cw-qgen .cw-cbtn-skills:hover { background: #7B5EA7; color: #fff; }

/* ── Discussion question cards ── */
#cw-qgen .cw-card {
  background: #fff; border-radius: 14px;
  padding: 18px 20px; margin-bottom: 12px;
  box-shadow: 0 2px 14px rgba(0,0,0,.06);
  display: flex; gap: 14px; align-items: flex-start;
  border-left: 4px solid #ddd;
  animation: cw-up .32s ease both;
}
@keyframes cw-up {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}
#cw-qgen .cw-num {
  min-width: 30px; height: 30px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-weight: 800; font-size: 13px;
  flex-shrink: 0; margin-top: 2px;
}
#cw-qgen .cw-qtext {
  font-size: 15px; line-height: 1.65; color: #222;
  margin-bottom: 9px; font-style: italic;
}
#cw-qgen .cw-meta { display: flex; align-items: flex-start; gap: 9px; flex-wrap: wrap; }
#cw-qgen .cw-badge {
  padding: 3px 10px; border-radius: 20px;
  font-size: 11px; font-weight: 800; color: #fff; flex-shrink: 0;
}
#cw-qgen .cw-rat { font-size: 12px; color: #888; line-height: 1.5; }
#cw-qgen .cw-legend {
  margin-top: 22px; padding: 13px 16px;
  background: rgba(26,111,168,.06); border-radius: 12px;
  font-size: 12px; color: #777; text-align: center; line-height: 1.8;
}

/* ── Skills Report sections ── */
#cw-qgen .cw-sr-section { margin-bottom: 16px; }

#cw-qgen .cw-sr-head {
  font-size: 12px; font-weight: 800; letter-spacing: 1.5px;
  text-transform: uppercase; padding: 9px 14px;
  border-radius: 10px 10px 0 0; color: #fff;
}
#cw-qgen .cw-sr-sel   { background: #7B5EA7; }
#cw-qgen .cw-sr-ela   { background: #4A90D9; }
#cw-qgen .cw-sr-char  { background: #F26419; }
#cw-qgen .cw-sr-vocab { background: #3CBBB1; }

#cw-qgen .cw-sr-card {
  background: #fff; border-left: 4px solid #ddd;
  padding: 12px 16px; margin-bottom: 4px;
  border-radius: 0 0 0 0;
  box-shadow: 0 1px 6px rgba(0,0,0,.05);
  display: flex; align-items: flex-start; gap: 10px; flex-wrap: wrap;
  animation: cw-up .3s ease both;
}
#cw-qgen .cw-sr-section .cw-sr-card:last-child {
  border-radius: 0 0 10px 0;
}
#cw-qgen .cw-sr-tag {
  font-size: 11px; font-weight: 800; color: #fff;
  padding: 3px 10px; border-radius: 20px; white-space: nowrap; flex-shrink: 0;
}
#cw-qgen .cw-sr-desc { font-size: 13px; color: #444; line-height: 1.6; flex: 1; min-width: 160px; }

#cw-qgen .cw-sr-traits {
  background: #fff; border-radius: 0 0 10px 0;
  padding: 14px 16px; display: flex; flex-wrap: wrap; gap: 8px;
  box-shadow: 0 1px 6px rgba(0,0,0,.05);
}
#cw-qgen .cw-sr-trait {
  background: #fff3ec; border: 1.5px solid #F26419;
  color: #c04a00; font-size: 12px; font-weight: 800;
  padding: 5px 13px; border-radius: 20px;
}

#cw-qgen .cw-sr-vocab-row {
  background: #fff; display: flex; align-items: baseline;
  gap: 10px; padding: 10px 14px; margin-bottom: 4px;
  border-left: 4px solid #3CBBB1;
  box-shadow: 0 1px 6px rgba(0,0,0,.05);
  animation: cw-up .3s ease both;
}
#cw-qgen .cw-sr-section .cw-sr-vocab-row:last-child {
  border-radius: 0 0 10px 0;
}
#cw-qgen .cw-sr-word { font-size: 14px; font-weight: 800; color: #1a7a74; flex-shrink: 0; }
#cw-qgen .cw-sr-def  { font-size: 13px; color: #555; line-height: 1.5; }

/* ── Print button & action group ── */
#cw-qgen .cw-ractions {
  display: flex; gap: 8px; align-items: center; flex-wrap: wrap;
}
#cw-qgen .cw-cbtn-print {
  border-color: #888; color: #555;
}
#cw-qgen .cw-cbtn-print:hover { background: #555; color: #fff; border-color: #555; }
#cw-qgen .cw-cbtn-skills-print { border-color: #888; color: #555; }
