/* ============================================================
   RustKid Academy — kid-friendly theme 🦀
   ============================================================ */
:root {
  --orange: #ff7a45;
  --orange-dark: #e05a2b;
  --ink: #2b2742;
  --ink-soft: #5a5470;
  --paper: #fff9f3;
  --card: #ffffff;
  --sky: #eaf6ff;
  --mint: #e8fbf2;
  --lemon: #fff7d6;
  --grape: #f3ecff;
  --rose: #ffe9f1;
  --line: #ece3d8;
  --good: #2bb673;
  --bad: #ff5a5f;
  --shadow: 0 8px 24px rgba(120, 80, 40, 0.12);
  --shadow-lg: 0 14px 40px rgba(120, 80, 40, 0.18);
  --radius: 18px;
  --font-head: "Fredoka", system-ui, sans-serif;
  --font-body: "Nunito", system-ui, sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, Menlo, Consolas, monospace;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--paper);
  background-image:
    radial-gradient(circle at 12% 8%, #fff2e6 0, transparent 38%),
    radial-gradient(circle at 88% 4%, #eaf6ff 0, transparent 34%);
  line-height: 1.65;
  font-size: 18px;
}

h1, h2, h3, h4 { font-family: var(--font-head); line-height: 1.2; color: var(--ink); }

a { color: var(--orange-dark); }

.skip-link {
  position: absolute; left: -999px; top: 0; background: var(--ink); color: #fff;
  padding: 10px 16px; border-radius: 0 0 10px 0; z-index: 100;
}
.skip-link:focus { left: 0; }

/* ---------- Header ---------- */
.site-header {
  position: sticky; top: 0; z-index: 40;
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; flex-wrap: wrap;
  padding: 12px clamp(16px, 4vw, 40px);
  background: rgba(255, 249, 243, 0.92);
  backdrop-filter: blur(8px);
  border-bottom: 3px solid var(--line);
}
.brand {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--font-head); font-weight: 700; font-size: 1.35rem;
  text-decoration: none; color: var(--ink);
}
.brand-crab { font-size: 1.6rem; animation: wiggle 4s ease-in-out infinite; }
.brand-text em { color: var(--orange-dark); font-style: normal; }
.site-nav { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.site-nav a {
  text-decoration: none; color: var(--ink-soft); font-weight: 700;
  padding: 8px 12px; border-radius: 12px;
}
.site-nav a:hover { background: #fff; box-shadow: var(--shadow); color: var(--ink); }
.xp-chip {
  display: inline-flex; align-items: center; gap: 6px;
  background: linear-gradient(135deg, #ffd86b, #ff924c);
  color: #5b3a00; font-weight: 800; font-family: var(--font-head);
  padding: 8px 14px; border-radius: 999px; box-shadow: var(--shadow);
}
.xp-sep { opacity: .5; }
.xp-star { filter: drop-shadow(0 1px 0 #fff7); }

/* ---------- Buttons ---------- */
.big-btn, .ghost-btn, .complete-btn, .link-btn {
  font-family: var(--font-head); cursor: pointer; border: none;
}
.big-btn {
  display: inline-block; text-decoration: none;
  background: linear-gradient(135deg, #ff924c, var(--orange-dark));
  color: #fff; font-size: 1.25rem; font-weight: 700;
  padding: 14px 28px; border-radius: 999px; box-shadow: var(--shadow-lg);
  transition: transform .12s ease, box-shadow .12s ease;
}
.big-btn:hover { transform: translateY(-3px) scale(1.02); }
.big-btn:active { transform: translateY(0) scale(.99); }
.ghost-btn {
  display: inline-block; text-decoration: none; margin-left: 10px;
  background: #fff; color: var(--orange-dark); font-weight: 700;
  padding: 13px 22px; border-radius: 999px; border: 2px solid var(--orange);
}
.link-btn {
  background: none; color: var(--ink-soft); text-decoration: underline;
  font-family: var(--font-body); font-weight: 700; padding: 0 4px;
}

/* ---------- Hero ---------- */
.hero {
  display: grid; grid-template-columns: 280px 1fr; gap: 28px; align-items: center;
  max-width: 1100px; margin: 24px auto 8px; padding: 24px clamp(16px, 4vw, 32px);
}
.hero-art { display: flex; justify-content: center; }
.ferris { width: 100%; max-width: 260px; animation: bob 3.5s ease-in-out infinite; }
.hero h1 { font-size: clamp(2rem, 5vw, 3.1rem); margin: 0 0 10px; }
.rust-word {
  background: linear-gradient(135deg, var(--orange), var(--orange-dark));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.hero-sub { font-size: 1.15rem; color: var(--ink-soft); max-width: 52ch; }

/* ---------- Progress panel ---------- */
.progress-panel {
  display: grid; grid-template-columns: repeat(3, auto) 1fr; gap: 16px;
  align-items: center; max-width: 1100px; margin: 8px auto 28px;
  padding: 18px clamp(16px, 4vw, 28px);
  background: var(--card); border: 3px solid var(--line);
  border-radius: var(--radius); box-shadow: var(--shadow);
}
.stat { text-align: center; }
.stat-num { font-family: var(--font-head); font-weight: 700; font-size: 1.8rem; color: var(--orange-dark); }
.stat-label { font-size: .85rem; color: var(--ink-soft); font-weight: 700; }
.stat-wide { text-align: left; }
.progress-bar { height: 16px; background: #f0e6da; border-radius: 999px; overflow: hidden; }
.progress-fill {
  height: 100%; width: 0%;
  background: linear-gradient(90deg, #8ac926, #2bb673);
  border-radius: 999px; transition: width .6s cubic-bezier(.2,.8,.2,1);
}
.badges-row { display: inline-flex; flex-wrap: wrap; gap: 6px; margin-top: 6px; }
.badge-pill {
  background: var(--lemon); border: 2px solid #f0d97a; border-radius: 999px;
  padding: 2px 10px; font-weight: 800; font-size: .82rem;
}

/* ---------- World map ---------- */
.worlds { max-width: 1100px; margin: 0 auto 60px; padding: 0 clamp(16px, 4vw, 32px); }
.section-title { font-size: clamp(1.6rem, 4vw, 2.2rem); margin: 8px 0 4px; }
.section-sub { color: var(--ink-soft); margin-top: 0; }
.world-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 20px;
}
.world-card {
  background: var(--card); border-radius: var(--radius);
  border: 3px solid var(--line); box-shadow: var(--shadow);
  padding: 18px; position: relative; overflow: hidden;
  transition: transform .12s ease, box-shadow .12s ease;
  border-top: 8px solid var(--world-color, var(--orange));
}
.world-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.world-head { display: flex; align-items: center; gap: 12px; }
.world-emoji {
  font-size: 1.9rem; background: color-mix(in srgb, var(--world-color) 18%, white);
  border-radius: 14px; width: 52px; height: 52px; display: grid; place-items: center;
  flex: none;
}
.world-num { font-size: .78rem; font-weight: 800; color: var(--ink-soft); text-transform: uppercase; letter-spacing: .04em; }
.world-title { margin: 0; font-size: 1.25rem; }
.world-progress {
  margin-left: auto; align-self: flex-start; font-family: var(--font-head); font-weight: 700;
  font-size: .85rem; background: var(--mint); color: #1c7a4f;
  padding: 3px 10px; border-radius: 999px; border: 2px solid #bfead4;
}
.world-progress.complete { background: #d8f5e3; }
.world-blurb { color: var(--ink-soft); font-size: .98rem; margin: 10px 0 12px; }
.lesson-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 6px; }
.lesson-link {
  display: flex; align-items: center; gap: 8px; text-decoration: none;
  color: var(--ink); padding: 7px 10px; border-radius: 12px; background: var(--paper);
  border: 2px solid transparent; font-weight: 600;
}
.lesson-link:hover { border-color: var(--world-color, var(--orange)); background: #fff; }
.lesson-check { font-weight: 800; color: #cbbfae; }
.lesson-link.done { background: var(--mint); }
.lesson-link.done .lesson-check { color: var(--good); }
.lesson-emoji { flex: none; }
.lesson-name { font-size: .95rem; }

/* ---------- Lesson layout ---------- */
.lesson-shell {
  display: grid; grid-template-columns: 290px minmax(0, 1fr);
  gap: 0; max-width: 1180px; margin: 0 auto; align-items: start;
}
.sidebar {
  position: sticky; top: 70px; align-self: start;
  max-height: calc(100vh - 80px); overflow-y: auto;
  padding: 18px 10px 40px 16px; border-right: 3px solid var(--line);
}
.sidebar-home {
  display: block; font-family: var(--font-head); font-weight: 700; text-decoration: none;
  color: var(--ink); background: #fff; border: 2px solid var(--line);
  padding: 10px 12px; border-radius: 12px; margin-bottom: 12px;
}
.side-world { margin-bottom: 4px; }
.side-world > summary {
  cursor: pointer; list-style: none; font-family: var(--font-head); font-weight: 600;
  padding: 8px 10px; border-radius: 10px; color: var(--ink);
}
.side-world > summary::-webkit-details-marker { display: none; }
.side-world > summary:hover { background: #fff; }
.side-emoji { margin-right: 4px; }
.side-world ul { list-style: none; margin: 2px 0 8px; padding: 0 0 0 6px; display: grid; gap: 2px; }
.side-lesson {
  display: flex; align-items: center; gap: 6px; text-decoration: none;
  color: var(--ink-soft); font-size: .92rem; padding: 6px 10px; border-radius: 10px;
  font-weight: 600;
}
.side-lesson:hover { background: #fff; color: var(--ink); }
.side-lesson.is-current { background: var(--orange); color: #fff; }
.side-lesson.is-current .side-check { color: #fff; }
.side-check { color: #cbbfae; font-weight: 800; }
.side-lesson.done .side-check { color: var(--good); }
.side-lesson.is-current.done .side-check { color: #fff; }

.sidebar-toggle {
  display: none; position: sticky; top: 66px; z-index: 30;
  margin: 8px 16px; padding: 10px 16px; border: none; cursor: pointer;
  background: var(--ink); color: #fff; font-family: var(--font-head);
  font-weight: 700; border-radius: 12px; box-shadow: var(--shadow);
}

/* ---------- Lesson content ---------- */
.lesson { padding: 18px clamp(16px, 4vw, 48px) 80px; min-width: 0; }
.crumbs { font-size: .85rem; color: var(--ink-soft); display: flex; gap: 8px; flex-wrap: wrap; }
.crumbs a { color: var(--ink-soft); text-decoration: none; font-weight: 700; }
.lesson-head {
  display: flex; align-items: center; gap: 16px; margin: 12px 0 8px;
  padding-bottom: 16px; border-bottom: 3px dashed var(--line);
}
.lesson-emoji-big {
  font-size: 2.4rem; flex: none; width: 70px; height: 70px; display: grid; place-items: center;
  background: color-mix(in srgb, var(--world-color, var(--orange)) 16%, white);
  border-radius: 18px;
}
.lesson-kicker { font-size: .8rem; font-weight: 800; color: var(--ink-soft); text-transform: uppercase; letter-spacing: .04em; }
.lesson-head h1 { margin: 2px 0 0; font-size: clamp(1.7rem, 4vw, 2.4rem); }

.lesson-body { font-size: 1.08rem; }
.lesson-body p { margin: 0 0 1em; }
.lesson-body h2 { font-size: 1.6rem; margin: 1.6em 0 .4em; }
.lesson-body h3 { font-size: 1.25rem; margin: 1.3em 0 .3em; }
.lesson-body ul, .lesson-body ol { padding-left: 1.4em; }
.lesson-body li { margin: .3em 0; }
.lesson-body img { max-width: 100%; border-radius: 12px; }
.lesson-body a { font-weight: 700; }
.lesson-body strong { color: var(--ink); }

/* inline + block code (non-interactive prose code) */
.lesson-body :not(pre) > code {
  font-family: var(--font-mono); font-size: .9em;
  background: var(--grape); color: #5a2ca0; padding: 2px 7px; border-radius: 7px;
  font-weight: 600;
}
.lesson-body pre {
  background: #2b2742; color: #f3eefe; padding: 16px 18px; border-radius: 14px;
  overflow-x: auto; font-family: var(--font-mono); font-size: .92rem; line-height: 1.5;
  box-shadow: var(--shadow);
}
.lesson-body pre code { background: none; color: inherit; padding: 0; font-weight: 400; }

.lesson-body blockquote {
  margin: 1em 0; padding: 10px 18px; border-left: 6px solid var(--orange);
  background: #fff; border-radius: 0 12px 12px 0; color: var(--ink-soft);
}

/* ---------- Callout boxes ---------- */
.ferris-says, .try-this, .watch-out, .big-idea, .analogy, .vocab {
  margin: 1.3em 0; padding: 16px 18px 16px 56px; border-radius: 16px;
  position: relative; border: 2px solid; font-size: 1.02rem;
}
.ferris-says::before, .try-this::before, .watch-out::before,
.big-idea::before, .analogy::before, .vocab::before {
  position: absolute; left: 16px; top: 14px; font-size: 1.5rem;
}
.ferris-says { background: var(--sky); border-color: #b8e2ff; }
.ferris-says::before { content: "🦀"; }
.analogy { background: var(--grape); border-color: #d9c8ff; }
.analogy::before { content: "💡"; }
.big-idea { background: var(--lemon); border-color: #f0d97a; }
.big-idea::before { content: "⭐"; }
.try-this { background: var(--mint); border-color: #bfead4; }
.try-this::before { content: "🎯"; }
.watch-out { background: var(--rose); border-color: #ffc2d4; }
.watch-out::before { content: "⚠️"; }
.vocab { background: #eef4ff; border-color: #c9d8ff; }
.vocab::before { content: "📖"; }
.ferris-says strong, .analogy strong, .big-idea strong,
.try-this strong, .watch-out strong, .vocab strong { color: var(--ink); }
.callout-title { display: block; font-family: var(--font-head); font-weight: 700; margin-bottom: 2px; }

/* ---------- Code playground ---------- */
.rust-play {
  margin: 1.4em 0; border-radius: 16px; overflow: hidden;
  border: 3px solid #2b2742; box-shadow: var(--shadow); background: #2b2742;
}
.rust-play.is-raw { display: none; } /* before JS upgrade, hide raw textareas */
.rp-bar {
  display: flex; align-items: center; gap: 8px; padding: 8px 12px;
  background: #3a3556; color: #d9d2f0; font-family: var(--font-head); font-weight: 600; font-size: .85rem;
}
.rp-dots { display: flex; gap: 5px; margin-right: 4px; }
.rp-dot { width: 11px; height: 11px; border-radius: 50%; }
.rp-dot.r { background: #ff5f57; } .rp-dot.y { background: #febc2e; } .rp-dot.g { background: #28c840; }
.rp-title { opacity: .8; }
.rp-actions { margin-left: auto; display: flex; gap: 8px; }
.rp-btn {
  font-family: var(--font-head); font-weight: 700; cursor: pointer; border: none;
  border-radius: 10px; padding: 6px 14px; font-size: .85rem;
}
.rp-run { background: #28c840; color: #06310f; }
.rp-run:hover { filter: brightness(1.08); }
.rp-reset { background: #57516f; color: #ece8fa; }
.rp-code {
  width: 100%; border: none; outline: none; resize: vertical;
  background: #2b2742; color: #f3eefe; font-family: var(--font-mono);
  font-size: .92rem; line-height: 1.55; padding: 14px 16px; display: block;
  tab-size: 4; min-height: 60px;
}
.rp-output {
  border-top: 2px dashed #4a4566; background: #1f1b30; color: #c8f7d4;
  font-family: var(--font-mono); font-size: .9rem; padding: 0 16px;
  max-height: 0; overflow: hidden; transition: max-height .35s ease, padding .35s ease;
}
.rp-output.show { max-height: 420px; overflow: auto; padding: 12px 16px; }
.rp-output .out-label { color: #8fb7ff; font-family: var(--font-head); display: block; margin-bottom: 4px; font-size: .82rem; }
.rp-output pre { margin: 0; white-space: pre-wrap; word-break: break-word; background: none; box-shadow: none; padding: 0; color: inherit; }
.rp-note { color: #ffd479; margin-top: 8px; font-family: var(--font-body); font-size: .85rem; }
.rp-compiling { color: #ffd479; }

/* ---------- Quiz ---------- */
.kid-quiz {
  margin: 1.4em 0; padding: 18px; border-radius: 16px;
  background: #fff; border: 3px solid var(--line); box-shadow: var(--shadow);
}
.kid-quiz .q { font-family: var(--font-head); font-weight: 600; font-size: 1.15rem; margin: 0 0 12px; }
.kid-quiz .q::before { content: "❓ "; }
.quiz-options { display: grid; gap: 10px; }
.kid-quiz button.opt {
  text-align: left; font-family: var(--font-body); font-weight: 700; font-size: 1rem;
  cursor: pointer; background: var(--paper); border: 2px solid var(--line);
  border-radius: 12px; padding: 12px 16px; color: var(--ink); transition: transform .08s ease;
}
.kid-quiz button.opt:hover { border-color: var(--orange); transform: translateX(3px); }
.kid-quiz button.opt:disabled { cursor: default; opacity: 1; }
.kid-quiz button.opt.correct { background: var(--mint); border-color: var(--good); }
.kid-quiz button.opt.correct::after { content: " ✅"; }
.kid-quiz button.opt.wrong { background: var(--rose); border-color: var(--bad); animation: shake .35s; }
.kid-quiz button.opt.wrong::after { content: " ❌"; }
.kid-quiz .explain {
  margin: 12px 0 0; padding: 12px 16px; border-radius: 12px;
  background: var(--lemon); border: 2px solid #f0d97a; display: none;
}
.kid-quiz .explain.show { display: block; }
.kid-quiz .explain::before { content: "🎉 "; }

/* ---------- Lesson footer ---------- */
.lesson-done { text-align: center; margin: 40px 0 10px; }
.complete-btn {
  background: linear-gradient(135deg, #8ac926, #2bb673); color: #053019;
  font-size: 1.15rem; font-weight: 700; padding: 14px 26px; border-radius: 999px;
  box-shadow: var(--shadow-lg); transition: transform .12s ease;
}
.complete-btn:hover { transform: translateY(-2px) scale(1.02); }
.complete-btn.done { background: #d8f5e3; color: #1c7a4f; cursor: default; transform: none; box-shadow: var(--shadow); }

.prev-next { display: flex; gap: 14px; justify-content: space-between; margin-top: 28px; flex-wrap: wrap; }
.pn-btn {
  display: flex; flex-direction: column; gap: 2px; text-decoration: none;
  background: #fff; border: 3px solid var(--line); border-radius: 16px;
  padding: 12px 18px; min-width: 200px; flex: 1; box-shadow: var(--shadow); color: var(--ink);
  transition: transform .12s ease, border-color .12s ease;
}
.pn-btn:hover { transform: translateY(-2px); border-color: var(--orange); }
.pn-next { text-align: right; }
.pn-dir { font-size: .8rem; font-weight: 800; color: var(--ink-soft); }
.pn-title { font-family: var(--font-head); font-weight: 600; }
.pn-finish { background: linear-gradient(135deg, #ffd86b, #ff924c); }

/* ---------- Misc pages ---------- */
.page-narrow { max-width: 760px; margin: 0 auto; padding: 30px clamp(16px,4vw,24px) 80px; }
.page-narrow h1 { font-size: 2.2rem; }
.page-narrow a { font-weight: 700; }
.notfound { text-align: center; max-width: 600px; margin: 40px auto; padding: 20px; }
.notfound .ferris { max-width: 200px; }

/* ---------- Footer ---------- */
.site-footer {
  margin-top: 40px; padding: 28px clamp(16px,4vw,40px);
  background: #fff; border-top: 3px solid var(--line); color: var(--ink-soft);
  text-align: center; font-weight: 600;
}
.footer-small { font-size: .85rem; margin-top: 6px; }

/* ---------- Confetti ---------- */
#confetti-canvas { position: fixed; inset: 0; pointer-events: none; z-index: 9999; }

/* ---------- Animations ---------- */
@keyframes bob { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }
@keyframes wiggle { 0%,92%,100% { transform: rotate(0); } 94% { transform: rotate(-14deg); } 96% { transform: rotate(14deg); } 98% { transform: rotate(-8deg); } }
@keyframes shake { 0%,100%{transform:translateX(0)} 25%{transform:translateX(-6px)} 75%{transform:translateX(6px)} }
@keyframes pop { 0%{transform:scale(.6);opacity:0} 60%{transform:scale(1.15)} 100%{transform:scale(1);opacity:1} }
.pop { animation: pop .35s ease; }

@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; scroll-behavior: auto !important; transition: none !important; }
}

/* ---------- Responsive ---------- */
@media (max-width: 860px) {
  body { font-size: 17px; }
  .hero { grid-template-columns: 1fr; text-align: center; }
  .hero-art { order: -1; }
  .ferris { max-width: 180px; }
  .hero-sub { margin-left: auto; margin-right: auto; }
  .progress-panel { grid-template-columns: repeat(3, 1fr); }
  .stat-wide { grid-column: 1 / -1; }
  .lesson-shell { grid-template-columns: 1fr; }
  .sidebar {
    position: fixed; top: 0; left: 0; bottom: 0; width: 86%; max-width: 340px;
    background: var(--paper); z-index: 50; transform: translateX(-105%);
    transition: transform .25s ease; border-right: 3px solid var(--line);
    max-height: 100vh; box-shadow: var(--shadow-lg);
  }
  .sidebar.open { transform: translateX(0); }
  .sidebar-toggle { display: inline-block; }
}
@media (max-width: 480px) {
  .progress-panel { grid-template-columns: repeat(3, 1fr); gap: 8px; }
  .ghost-btn { margin-left: 0; margin-top: 10px; }
  .pn-btn { min-width: 100%; }
}
