/* ============================================================
   style.css — ยกเครื่องตามหลัก UI UX Pro Max
   โครงสี/ระยะ/เงา ใช้ระบบ token (ตัวแปร CSS) ปรับที่เดียวเปลี่ยนทั้งเว็บ
   ============================================================ */

:root {
  /* ---- สี (พื้นหลังเข้มแบบ developer ช่วยอ่านโค้ดสบายตา) ---- */
  --bg:            #0b1120;   /* พื้นหลังหลัก */
  --surface:       #161f33;   /* การ์ด/กล่อง */
  --surface-2:     #1f2b44;   /* การ์ดตอน hover */
  --code-bg:       #0d1526;   /* กล่องโค้ด */
  --border:        #2a3650;

  --text:          #e7ecf5;   /* ตัวอักษรหลัก */
  --text-muted:    #93a2bd;   /* ตัวอักษรรอง */

  --primary:       #6366f1;   /* ปุ่มหลัก (indigo) */
  --primary-hover: #4f53e3;
  --success:       #22c55e;   /* ถูก/ผ่าน */
  --success-bg:    #0f3322;
  --danger:        #ef4444;   /* ผิด */
  --danger-bg:     #3a1620;
  --accent:        #f59e0b;   /* เฉลย/ไฮไลต์ */

  /* ---- ระยะห่าง / มุมโค้ง / เงา / จังหวะ ---- */
  --radius:   16px;
  --radius-sm: 10px;
  --shadow:   0 10px 30px -12px rgba(0,0,0,.55);
  --ease:     200ms cubic-bezier(.4,0,.2,1);

  /* ---- ฟอนต์ ---- */
  --font-ui:   "IBM Plex Sans Thai", -apple-system, "Segoe UI", sans-serif;
  --font-code: "JetBrains Mono", "SF Mono", Consolas, monospace;
}

* { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: var(--font-ui);
  font-size: 16px;
  line-height: 1.7;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(99,102,241,.10) 0, transparent 60%),
    var(--bg);
  background-color: var(--bg);
  color: var(--text);
}

/* โฟกัสด้วยคีย์บอร์ด (accessibility) */
:focus-visible { outline: 3px solid var(--primary); outline-offset: 2px; border-radius: 6px; }

/* ---------------- แถบหัว ---------------- */
header {
  position: sticky; top: 0; z-index: 10;
  display: flex; align-items: center; gap: 12px;
  background: rgba(11,17,32,.85);
  backdrop-filter: blur(10px);
  padding: 12px 18px;
  border-bottom: 1px solid var(--border);
}
.brand { display: flex; align-items: center; gap: 10px; }
.brand h1 { font-size: 18px; font-weight: 700; margin: 0; letter-spacing: .2px; }
.logo {
  font-family: var(--font-code); font-weight: 700; font-size: 15px;
  color: #fff; background: linear-gradient(135deg, var(--primary), #8b5cf6);
  padding: 5px 9px; border-radius: 9px;
}

/* ---------------- พื้นที่หลัก ---------------- */
main { padding: 20px 18px 60px; max-width: 760px; margin: 0 auto; }

/* ---------------- ปุ่มทั่วไป ---------------- */
button {
  font-family: inherit; font-size: 16px;
  border: none; border-radius: var(--radius-sm);
  padding: 14px 18px; min-height: 48px;   /* แตะถนัดบนจอสัมผัส (>=44px) */
  cursor: pointer; color: var(--text);
  transition: transform var(--ease), background var(--ease), border-color var(--ease);
}
button:active { transform: scale(.985); }

.ghost {
  background: transparent; color: var(--text-muted);
  display: inline-flex; align-items: center; gap: 4px;
  padding: 8px 10px; min-height: 0; font-size: 15px; font-weight: 500;
}
.ghost:hover { color: var(--text); }

.primary {
  background: var(--primary); color: #fff; font-weight: 600;
  width: 100%; margin-top: 18px;
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  box-shadow: 0 8px 20px -8px var(--primary);
}
.primary:hover { background: var(--primary-hover); }

/* ---------------- การ์ดเลือกบทในเมนู ---------------- */
.menu-intro { color: var(--text-muted); font-size: 15px; margin: 4px 0 18px; }

.lesson-card {
  display: flex; align-items: center; gap: 15px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 18px;
  margin-bottom: 13px; width: 100%; text-align: left; color: var(--text);
  box-shadow: var(--shadow);
}
.lesson-card:hover { background: var(--surface-2); transform: translateY(-2px); }
.lesson-card .num {
  flex: 0 0 42px; height: 42px; border-radius: 12px;
  background: linear-gradient(135deg, #334155, #1e293b); color: #cbd5e1;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-code); font-weight: 700; font-size: 18px;
}
.lesson-card.done .num { background: linear-gradient(135deg, var(--success), #15803d); color: #fff; }
.lesson-card .title { flex: 1; font-size: 17px; font-weight: 500; }
.lesson-card .check { color: var(--success); font-size: 22px; font-weight: 700; }

/* ---------------- กล่องเนื้อหาบทเรียน ---------------- */
h2.lesson-title { font-size: 21px; font-weight: 700; margin: 4px 0 16px; }
.content-box {
  background: var(--code-bg); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 18px;
  white-space: pre-wrap;            /* คงรูปแบบโค้ด/การย่อหน้า */
  font-family: var(--font-code); font-size: 14.5px; line-height: 1.75;
  color: #d7e0f0; overflow-x: auto;
}

/* ---------------- โจทย์ ---------------- */
.progress-row { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.progress-text { color: var(--text-muted); font-size: 14px; white-space: nowrap; }
.progress-track { flex: 1; height: 7px; background: var(--border); border-radius: 99px; overflow: hidden; }
.progress-fill  { height: 100%; background: linear-gradient(90deg, var(--primary), #8b5cf6); border-radius: 99px; transition: width var(--ease); }

.question {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 20px;
  white-space: pre-wrap; font-size: 17px; margin-bottom: 18px;
}
/* โค้ดในโจทย์ให้ขึ้นบรรทัดใหม่อ่านง่าย (ส่วน \n ในข้อความ) */
.question { font-family: var(--font-ui); }

.choice {
  display: flex; align-items: center; gap: 12px; width: 100%; text-align: left;
  background: var(--surface); color: var(--text);
  border: 2px solid var(--border); margin-bottom: 12px;
  font-size: 16.5px; line-height: 1.5;
}
.choice .key {
  flex: 0 0 30px; height: 30px; border-radius: 8px;
  background: var(--surface-2); color: var(--text-muted);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-code); font-weight: 700; font-size: 15px;
}
.choice:hover:not(:disabled) { border-color: #4b5b7e; background: var(--surface-2); }
.choice.correct { background: var(--success-bg); border-color: var(--success); }
.choice.correct .key { background: var(--success); color: #fff; }
.choice.wrong   { background: var(--danger-bg); border-color: var(--danger); }
.choice.wrong .key { background: var(--danger); color: #fff; }
.choice:disabled { cursor: default; }

.explain {
  background: var(--surface); border-left: 4px solid var(--accent);
  border-radius: 12px; padding: 16px; margin-top: 8px;
  font-size: 15.5px;
}
.result-emoji { font-size: 17px; font-weight: 700; margin-bottom: 6px; }
.result-emoji.ok  { color: var(--success); }
.result-emoji.no  { color: var(--danger); }

/* ---------------- สรุปผลจบบท ---------------- */
.summary { text-align: center; padding: 40px 16px; }
.summary .big { font-size: 60px; margin-bottom: 12px; line-height: 1; }
.summary .score { font-size: 24px; font-weight: 700; margin-bottom: 8px; }
.summary p { color: var(--text-muted); }

/* ---------------- จอใหญ่ขึ้น (iPad แนวนอน/เดสก์ท็อป) ---------------- */
@media (min-width: 768px) {
  .brand h1 { font-size: 20px; }
  h2.lesson-title { font-size: 24px; }
}

/* ---------------- เนื้อหาบทเรียนแบบบล็อก (ใหม่) ---------------- */
.c-h {
  font-size: 18px; font-weight: 700; color: #fff;
  margin: 26px 0 10px; line-height: 1.45;
}
.c-h:first-child { margin-top: 4px; }
.c-p {
  font-family: var(--font-ui); font-size: 16.5px; line-height: 1.8;
  color: var(--text); margin: 0 0 12px;
}
.c-code {
  background: var(--code-bg); border: 1px solid var(--border);
  border-left: 3px solid var(--primary); border-radius: 10px;
  padding: 14px 16px; margin: 0 0 14px;
  font-family: var(--font-code); font-size: 14.5px; line-height: 1.7;
  color: #e6edfb; white-space: pre-wrap; overflow-x: auto;
}
.c-note {
  background: rgba(245,158,11,.08); border-left: 4px solid var(--accent);
  border-radius: 10px; padding: 13px 15px; margin: 0 0 16px;
  font-family: var(--font-ui); font-size: 15.5px; line-height: 1.7; color: #f3e6c8;
}

/* ---------------- โจทย์พิมพ์โค้ด ---------------- */
.code-label { color: var(--text-muted); font-size: 14px; margin: 0 0 8px; }
.code-input {
  width: 100%; min-height: 150px; resize: vertical;
  background: var(--code-bg); color: #e6edfb;
  border: 1px solid var(--border); border-radius: 12px; padding: 14px;
  font-family: var(--font-code); font-size: 15px; line-height: 1.6;
  tab-size: 4;
}
.code-input:focus { outline: 2px solid var(--primary); outline-offset: 1px; }
.code-hint { color: var(--text-muted); font-size: 13.5px; margin: 12px 0 0; }
.code-hint pre {
  margin: 6px 0 0; padding: 10px 12px;
  background: var(--surface); border: 1px dashed var(--border); border-radius: 8px;
  font-family: var(--font-code); font-size: 14px; color: var(--accent);
  white-space: pre-wrap;
}
.output-box {
  margin-top: 16px; background: #07101f; border: 1px solid var(--border);
  border-radius: 12px; padding: 14px;
}
.output-title { color: var(--text-muted); font-size: 13px; margin-bottom: 6px; }
.output-box pre {
  margin: 0; font-family: var(--font-code); font-size: 14.5px;
  color: #cfe3ff; white-space: pre-wrap; word-break: break-word;
}

/* ---------------- เคารพการตั้งค่าลดการเคลื่อนไหว ---------------- */
@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; animation: none !important; }
  .lesson-card:hover { transform: none; }
}
