/* 미적분 LMS — 라이트하고 차분한 톤 */
:root {
  --bg: #0E1116;
  --panel: #161B22;
  --panel-2: #1F2530;
  --text: #E6EDF3;
  --muted: #8B98A6;
  --accent: #7FE3FF;
  --accent-strong: #4FB8E0;
  --warn: #FF8A65;
  --ok: #7FD49C;
  --line: #2A2F3A;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Noto Sans KR', sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.55;
}

.topbar {
  display: flex; align-items: center; gap: 1rem;
  padding: 0.6rem 1.2rem;
  background: var(--panel);
  border-bottom: 1px solid var(--line);
  position: sticky; top: 0; z-index: 10;
}
.topbar .brand { font-weight: 600; color: var(--text); text-decoration: none; }
.topbar nav { display: flex; align-items: center; gap: 1rem; margin-left: auto; }
.topbar nav a { color: var(--muted); text-decoration: none; }
.topbar nav a:hover { color: var(--text); }
.topbar nav .who { color: var(--accent); }
.topbar form.inline { display: inline; margin: 0; }
.topbar button.link {
  background: none; border: none; color: var(--muted); cursor: pointer; padding: 0;
}
.topbar button.link:hover { color: var(--text); }

main { max-width: 1200px; margin: 0 auto; padding: 1.4rem 1.2rem 4rem; }

h1 { font-size: 1.6rem; margin: 0.2rem 0 1rem; }
h2 { font-size: 1.2rem; margin-top: 1.5rem; color: var(--text); }
h3.chapter { color: var(--muted); font-size: 0.95rem; margin: 1rem 0 0.5rem; font-weight: 500; }
.muted { color: var(--muted); }
.small { font-size: 0.85rem; }
.error { color: var(--warn); }

/* 인증 */
.auth-card {
  max-width: 360px; margin: 4rem auto;
  background: var(--panel); border: 1px solid var(--line);
  padding: 1.6rem; border-radius: 8px;
}
.auth-card label {
  display: block; margin-bottom: 0.8rem;
  color: var(--muted); font-size: 0.9rem;
}
.auth-card input {
  width: 100%; margin-top: 0.3rem;
  background: var(--panel-2); border: 1px solid var(--line); color: var(--text);
  padding: 0.55rem 0.7rem; border-radius: 4px;
}

button, .btn {
  background: var(--panel-2); border: 1px solid var(--line); color: var(--text);
  padding: 0.5rem 0.95rem; border-radius: 4px; cursor: pointer;
  font-size: 0.9rem;
  text-decoration: none; display: inline-block;
}
button:hover, .btn:hover { border-color: var(--accent); }
button.primary, .btn.primary {
  background: var(--accent-strong); border-color: var(--accent-strong); color: #001722;
  font-weight: 600;
}
button.primary:hover { background: var(--accent); border-color: var(--accent); }
button.ghost, .btn.ghost { background: transparent; }
button.recording { background: #c0392b; border-color: #c0392b; color: white; }
.btn.small { padding: 0.3rem 0.6rem; font-size: 0.85rem; }

/* 강의 카탈로그 */
.level-block { margin-bottom: 2rem; }
.topic-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 0.9rem;
}
.topic-card {
  background: var(--panel); border: 1px solid var(--line); border-radius: 6px;
  padding: 0.9rem 1rem; display: flex; flex-direction: column; gap: 0.6rem;
}
.topic-card.disabled { opacity: 0.55; }
.topic-card .topic-title { font-weight: 500; }
.topic-card .topic-meta { font-size: 0.85rem; color: var(--muted); }
.topic-card .resume { color: var(--accent); margin-left: 0.4rem; }

/* 플레이어 */
.player-layout {
  display: grid; gap: 1rem;
  grid-template-columns: minmax(0, 1fr) 380px;
}
@media (max-width: 980px) {
  .player-layout { grid-template-columns: 1fr; }
}
.player-left video {
  width: 100%; max-height: 60vh; background: black; border-radius: 6px;
}
.chapters { margin-top: 0.8rem; background: var(--panel); border: 1px solid var(--line); padding: 0.6rem 0.9rem; border-radius: 6px; }
.chapters summary { cursor: pointer; }
.chapters ol { margin: 0.5rem 0 0; padding-left: 1.4rem; }
.chapters a.jump { color: var(--text); text-decoration: none; }
.chapters a.jump:hover { color: var(--accent); }

/* Q&A */
.qa-panel {
  background: var(--panel); border: 1px solid var(--line); border-radius: 6px;
  padding: 0.9rem; display: flex; flex-direction: column; gap: 0.7rem;
  height: calc(100vh - 8rem); position: sticky; top: 4.5rem;
}
.qa-panel h2 { margin: 0; font-size: 1rem; }
#qa-history { flex: 1; overflow: auto; display: flex; flex-direction: column; gap: 0.7rem; padding-right: 0.3rem; }
.qa-item { background: var(--panel-2); border: 1px solid var(--line); border-radius: 4px; padding: 0.6rem 0.7rem; }
.qa-q { color: var(--accent); font-size: 0.9rem; margin-bottom: 0.4rem; }
.qa-a b { color: var(--ok); }
.qa-md { white-space: pre-wrap; }
.qa-form textarea {
  width: 100%; resize: vertical;
  background: var(--panel-2); border: 1px solid var(--line); color: var(--text);
  padding: 0.5rem; border-radius: 4px;
}
.qa-actions { display: flex; gap: 0.5rem; align-items: center; flex-wrap: wrap; }
.qa-actions span { margin-left: auto; }

/* 풀이 */
.solve-form { display: flex; flex-direction: column; gap: 0.6rem; max-width: 700px; }
.solve-form .checkbox { color: var(--muted); font-size: 0.9rem; }
.answer-md { background: var(--panel); border: 1px solid var(--line); padding: 1rem; border-radius: 6px; margin-top: 1rem; min-height: 10rem; white-space: pre-wrap; }

/* 관리자 */
.admin-table { width: 100%; border-collapse: collapse; margin-bottom: 1.2rem; }
.admin-table th, .admin-table td {
  padding: 0.4rem 0.6rem; border-bottom: 1px solid var(--line); text-align: left;
}
.admin-table th { color: var(--muted); font-weight: 500; }
.actions { display: flex; gap: 0.3rem; align-items: center; flex-wrap: wrap; }
.job-progress { font-size: 0.85rem; color: var(--accent); margin-left: 0.5rem; }
.badge {
  font-size: 0.75rem; padding: 0.15rem 0.5rem; border-radius: 999px;
  background: var(--panel-2); border: 1px solid var(--line);
}
.badge.published { background: rgba(127, 212, 156, 0.15); border-color: var(--ok); color: var(--ok); }
.badge.draft { color: var(--muted); }
.badge.queued { color: var(--muted); }
.badge.running { color: var(--accent); border-color: var(--accent); }
.badge.done { color: var(--ok); border-color: var(--ok); }
.badge.failed { color: var(--warn); border-color: var(--warn); }
