/* ========================================================
   Git & GitHub for Absolute Beginners — jamesgurtner.com edition
   Editorial Dusk theme: warm near-black, Tennessee gold accent,
   Playfair Display headlines, Plus Jakarta Sans body, JetBrains Mono.
   Dark is the default (matches the site); html.light flips to the
   light palette. course.js syncs with the site's next-themes choice.
   ======================================================== */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400..900;1,400..900&family=Plus+Jakarta+Sans:ital,wght@0,300..800;1,300..800&family=JetBrains+Mono:wght@400..700&display=swap');

:root {
  /* layout + ink — Editorial Dusk dark */
  --gt-bg: #0B0E14;
  --gt-card: #11151D;
  --gt-inset: #0E1219;
  --gt-elevated: #1a1f29;
  --gt-ink: #F4F1EC;
  --gt-ink-2nd: #C8C4BD;
  --gt-muted: #8E8B85;
  --gt-border: rgba(244, 241, 236, 0.16);
  --gt-border-subtle: rgba(244, 241, 236, 0.08);

  /* Tennessee gold accent */
  --gt-accent: #E0B25E;
  --gt-accent-hover: #EAC379;
  --gt-accent-deep: #B58A2E;
  --gt-accent-text: #0B0E14;
  --gt-accent-soft: rgba(224, 178, 94, 0.12);
  --gt-gradient-accent: linear-gradient(180deg, #E0B25E 0%, #B58A2E 100%);
  --gt-gradient-accent-hover: linear-gradient(180deg, #EAC379 0%, #E0B25E 100%);

  /* diagram semantics (teaching colors, dusk-tuned) */
  --gt-main: #4ade80;          /* main branch tag */
  --gt-head: #fbbf24;          /* HEAD tag */
  --gt-origin: #a78bfa;        /* origin/* tags */
  --gt-feature: #38bdf8;       /* other branches / feature accents */
  --gt-merge: #f472b6;         /* new/merge beads */
  --gt-merge-stroke: #db2777;
  --gt-alt: #155e75;           /* the "other person's" commit line */
  --gt-alt-stroke: #0e7490;
  --gt-dim: #8E8B85;           /* arrows + dim diagram text */
  --gt-danger: #f87171;
  --gt-success: #4ade80;
  --gt-warning: #fbbf24;
  --gt-tag-text: #0B0E14;      /* dark text on saturated tags, both modes */
  --gt-bead-label: #0B0E14;    /* label text on gold beads */
  --gt-alt-label: #F4F1EC;     /* label text on dark-teal alt beads */
  --gt-code: #EAC379;          /* inline code + command color */
  --gt-success-bg: rgba(74, 222, 128, 0.10);
  --gt-success-border: rgba(74, 222, 128, 0.45);
  --gt-danger-bg: rgba(248, 113, 113, 0.10);
  --gt-feature-bg: rgba(56, 189, 248, 0.08);

  --gt-shadow-md: 0 4px 12px rgba(0, 0, 0, 0.5), 0 2px 4px rgba(0, 0, 0, 0.4);

  --gt-font-display: 'Playfair Display', 'Times New Roman', serif;
  --gt-font-body: 'Plus Jakarta Sans', system-ui, sans-serif;
  --gt-font-mono: 'JetBrains Mono', ui-monospace, Menlo, monospace;
}

html.light {
  --gt-bg: #ffffff;
  --gt-card: #f9fafb;
  --gt-inset: #f3f4f6;
  --gt-elevated: #ffffff;
  --gt-ink: #0B0E14;
  --gt-ink-2nd: #3A3833;
  --gt-muted: #6B6760;
  --gt-border: rgba(11, 14, 20, 0.12);
  --gt-border-subtle: rgba(11, 14, 20, 0.06);

  --gt-accent: #B58A2E;
  --gt-accent-hover: #8F6E20;
  --gt-accent-deep: #8F6E20;
  --gt-accent-text: #ffffff;
  --gt-accent-soft: rgba(181, 138, 46, 0.12);
  --gt-gradient-accent: linear-gradient(180deg, #B58A2E 0%, #8F6E20 100%);
  --gt-gradient-accent-hover: linear-gradient(180deg, #C9A04A 0%, #B58A2E 100%);

  --gt-main: #16a34a;
  --gt-head: #d97706;
  --gt-origin: #8B5CF6;
  --gt-feature: #3B82F6;
  --gt-merge: #db2777;
  --gt-merge-stroke: #9d174d;
  --gt-alt: #0e7490;
  --gt-alt-stroke: #155e75;
  --gt-dim: #6B6760;
  --gt-danger: #dc2626;
  --gt-success: #16a34a;
  --gt-warning: #d97706;
  --gt-tag-text: #ffffff;
  --gt-bead-label: #ffffff;
  --gt-alt-label: #ffffff;
  --gt-code: #8F6E20;
  --gt-success-bg: rgba(22, 163, 74, 0.08);
  --gt-success-border: rgba(22, 163, 74, 0.4);
  --gt-danger-bg: rgba(220, 38, 38, 0.07);
  --gt-feature-bg: rgba(59, 130, 246, 0.07);

  --gt-shadow-md: 0 4px 12px rgba(17, 24, 39, 0.06), 0 2px 4px rgba(17, 24, 39, 0.04);
}

* { box-sizing: border-box; }
body {
  margin: 0;
  background: var(--gt-bg);
  color: var(--gt-ink);
  font-family: var(--gt-font-body);
  line-height: 1.7;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
}
.wrap { max-width: 880px; margin: 0 auto; padding: 24px 20px 96px; }
h1 {
  font-family: var(--gt-font-display);
  font-size: 2.3rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.15;
  margin: 18px 0 4px;
}
h2, h3 { font-family: var(--gt-font-display); letter-spacing: -0.01em; }
.subtitle { color: var(--gt-muted); margin-bottom: 36px; font-size: 1.05rem; }
section {
  background: var(--gt-card);
  border-radius: 12px;
  padding: 28px;
  margin-bottom: 32px;
  border: 1px solid var(--gt-border-subtle);
  box-shadow: var(--gt-shadow-md);
}
section h2 { margin-top: 0; font-size: 1.45rem; font-weight: 600; }
section h2 .num {
  display: inline-block; width: 32px; height: 32px; line-height: 32px;
  text-align: center; border-radius: 50%;
  background: var(--gt-gradient-accent);
  color: var(--gt-accent-text); font-size: 1rem; margin-right: 10px;
  font-family: var(--gt-font-mono); font-weight: 700;
}
section h3 { font-size: 1.08rem; }
p { color: var(--gt-ink); }
.note { color: var(--gt-muted); font-size: .92rem; }
a { color: var(--gt-accent); }

/* ---------- callout boxes ---------- */
.analogy {
  background: var(--gt-feature-bg);
  border-left: 3px solid var(--gt-feature);
  border-radius: 0 8px 8px 0;
  padding: 14px 18px;
  margin: 18px 0;
  font-size: 1rem;
}
.analogy b { color: var(--gt-feature); }
.gitword {
  background: var(--gt-accent-soft);
  border-left: 3px solid var(--gt-accent);
  border-radius: 0 8px 8px 0;
  padding: 12px 18px;
  margin: 18px 0;
  font-size: .98rem;
}
.gitword b { color: var(--gt-accent); }
.warn {
  background: var(--gt-danger-bg);
  border-left: 3px solid var(--gt-danger);
  border-radius: 0 8px 8px 0;
  padding: 12px 18px;
  margin: 18px 0;
  font-size: .98rem;
}
.warn b { color: var(--gt-danger); }
.tryit {
  background: var(--gt-success-bg);
  border: 1px solid var(--gt-success-border);
  border-radius: 8px;
  padding: 16px 20px;
  margin: 18px 0;
}
.tryit h3 { margin: 0 0 8px; color: var(--gt-success); font-size: 1rem; font-family: var(--gt-font-body); font-weight: 700; }
.tryit pre { margin: 8px 0 0; }

/* ---------- code ---------- */
code, pre { font-family: var(--gt-font-mono); font-size: .85em; }
code { background: var(--gt-inset); padding: 2px 7px; border-radius: 4px; color: var(--gt-code); border: 1px solid var(--gt-border-subtle); }
pre {
  background: var(--gt-inset); padding: 14px 18px; border-radius: 8px;
  overflow-x: auto; color: var(--gt-ink-2nd); border: 1px solid var(--gt-border-subtle);
  line-height: 1.55;
}
pre .c { color: var(--gt-muted); }
pre .g { color: var(--gt-success); }
pre .y { color: var(--gt-warning); }
pre .r { color: var(--gt-danger); }
pre .b { color: var(--gt-code); }

/* ---------- SVG diagram language ---------- */
svg { display: block; margin: 18px auto; max-width: 100%; height: auto; }
.bead { fill: var(--gt-accent); stroke: var(--gt-accent-deep); stroke-width: 2; }
.bead-alt { fill: var(--gt-alt); stroke: var(--gt-alt-stroke); stroke-width: 2; }
.bead-new { fill: var(--gt-merge); stroke: var(--gt-merge-stroke); stroke-width: 2; }
.bead-label { fill: var(--gt-bead-label); font-family: var(--gt-font-mono); font-size: 11px; text-anchor: middle; }
/* labels on dark-teal alt beads need light text (the label <text> always
   directly follows its bead <circle> in the course's markup pattern) */
svg .bead-alt + .bead-label { fill: var(--gt-alt-label); }
.bead-msg { fill: var(--gt-muted); font-size: 11px; text-anchor: middle; font-family: var(--gt-font-body); }
.parent-arrow { stroke: var(--gt-dim); stroke-width: 2; fill: none; marker-end: url(#arrGray); }
.tag { rx: 5; }
.tag-text { fill: var(--gt-tag-text); font-size: 11.5px; font-weight: 700; text-anchor: middle; font-family: var(--gt-font-mono); }
.tag-line { stroke-width: 1.6; stroke-dasharray: 3 3; fill: none; }
.svg-box { fill: var(--gt-inset); stroke: var(--gt-border); stroke-width: 2; }
.svg-title { fill: var(--gt-ink); font-size: 14px; font-weight: bold; text-anchor: middle; font-family: var(--gt-font-body); }
.svg-text { fill: var(--gt-muted); font-size: 12px; text-anchor: middle; font-family: var(--gt-font-body); }
.anim { transition: transform 1.2s cubic-bezier(.4,0,.2,1), opacity 1s ease; }
.ghost { opacity: 0; }
.faded { opacity: .25; transition: opacity 1s ease; }

/* --- hex bridge: retheme hard-coded SVG attribute colors. -------------
   CSS attribute selectors override SVG presentation attributes, so the
   original diagrams pick up the theme without touching the markup. */
svg [fill="#22c55e"] { fill: var(--gt-main); }
svg [stroke="#22c55e"] { stroke: var(--gt-main); }
svg [fill="#f59e0b"] { fill: var(--gt-head); }
svg [stroke="#f59e0b"] { stroke: var(--gt-head); }
svg [fill="#a78bfa"] { fill: var(--gt-origin); }
svg [stroke="#a78bfa"] { stroke: var(--gt-origin); }
svg [fill="#38bdf8"] { fill: var(--gt-feature); }
svg [stroke="#38bdf8"] { stroke: var(--gt-feature); }
svg [fill="#64748b"] { fill: var(--gt-dim); }
svg [stroke="#64748b"] { stroke: var(--gt-dim); }
svg [fill="#94a3b8"] { fill: var(--gt-muted); }
svg [stroke="#94a3b8"] { stroke: var(--gt-muted); }
svg [fill="#7dd3fc"] { fill: var(--gt-code); }
svg [fill="#cbd5e1"] { fill: var(--gt-ink-2nd); }
svg [fill="#e2e8f0"] { fill: var(--gt-ink); }
svg [fill="#f87171"] { fill: var(--gt-danger); }
svg [stroke="#f87171"] { stroke: var(--gt-danger); }
svg [fill="#ef4444"] { fill: var(--gt-danger); }
svg [stroke="#ef4444"] { stroke: var(--gt-danger); }
svg [fill="#34d399"] { fill: var(--gt-success); }
svg [stroke="#34d399"] { stroke: var(--gt-success); }
svg [fill="#fbbf24"] { fill: var(--gt-head); }
svg [stroke="#fbbf24"] { stroke: var(--gt-head); }
svg [fill="#0f172a"] { fill: var(--gt-tag-text); }
svg [fill="#0b1120"] { fill: var(--gt-inset); }
svg [stroke="#0b1120"] { stroke: var(--gt-border); }
svg [stroke="#334155"] { stroke: var(--gt-border); }
svg [fill="#0e7490"] { fill: var(--gt-alt); }
svg [stroke="#0891b2"] { stroke: var(--gt-alt-stroke); }
svg [fill="#f472b6"] { fill: var(--gt-merge); }
svg [stroke="#db2777"] { stroke: var(--gt-merge-stroke); }
svg [fill="#4f7cff"] { fill: var(--gt-accent); }
svg [stroke="#2d4fd6"] { stroke: var(--gt-accent-deep); }
svg [fill="#475569"] { fill: var(--gt-muted); }
svg [fill="#fff"], svg [fill="#ffffff"] { fill: var(--gt-bead-label); }
/* polaroid + sticky-note illustration colors stay constant (real-world
   objects read fine on both backgrounds): #f1f5f9 #fde68a #854d0e #713f12 #b45309 */

/* ---------- buttons ---------- */
button {
  background: var(--gt-gradient-accent); color: var(--gt-accent-text);
  border: none; padding: 11px 20px;
  border-radius: 8px; font-size: .98rem; font-weight: 700; cursor: pointer;
  margin: 6px 8px 6px 0;
  font-family: var(--gt-font-body);
}
button:hover { background: var(--gt-gradient-accent-hover); }
button.secondary { background: var(--gt-elevated); color: var(--gt-ink-2nd); border: 1px solid var(--gt-border); }
button.secondary:hover { border-color: var(--gt-accent); color: var(--gt-ink); }
button:disabled { cursor: default; opacity: .85; }

/* ---------- quiz: reveal ---------- */
.answer { display: none; background: var(--gt-success-bg); border: 1px solid var(--gt-success-border); border-radius: 8px; padding: 16px 20px; margin-top: 14px; }
.answer.show { display: block; }

/* ---------- quiz: multiple choice ---------- */
.mc { margin: 22px 0; }
.mc button {
  display: block; width: 100%; text-align: left;
  background: var(--gt-elevated); color: var(--gt-ink);
  margin: 8px 0; padding: 12px 16px;
  border: 1px solid var(--gt-border); border-radius: 8px; font-weight: 500;
}
.mc button:hover:not(:disabled) { border-color: var(--gt-accent); }
.mc button.correct { border: 2px solid var(--gt-success); background: var(--gt-success-bg); }
.mc button.wrong { border: 2px solid var(--gt-danger); background: var(--gt-danger-bg); }
.mc-explain { display: none; background: var(--gt-success-bg); border: 1px solid var(--gt-success-border); border-radius: 8px; padding: 14px 18px; margin-top: 10px; font-size: .95rem; }
.mc-explain.show { display: block; }

/* ---------- tables ---------- */
table { border-collapse: collapse; width: 100%; font-size: .95rem; }
th, td { text-align: left; padding: 9px 12px; border-bottom: 1px solid var(--gt-border-subtle); }
th { color: var(--gt-muted); font-weight: 600; }

/* ---------- big takeaway ---------- */
.takeaway {
  background: var(--gt-accent-soft);
  border: 1px solid var(--gt-accent);
  border-radius: 12px; padding: 24px 28px; font-size: 1.05rem;
  margin-bottom: 32px;
}

/* ---------- navigation ---------- */
.topnav {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 0; border-bottom: 1px solid var(--gt-border-subtle); margin-bottom: 8px;
  font-size: .95rem; gap: 12px;
}
.topnav a { color: var(--gt-accent); text-decoration: none; font-weight: 600; }
.topnav a:hover { text-decoration: underline; }
.topnav .pos { color: var(--gt-muted); font-size: .85rem; font-family: var(--gt-font-mono); }
.bottomnav {
  display: flex; justify-content: space-between; align-items: center;
  gap: 12px; margin-top: 40px; flex-wrap: wrap;
}
.navbtn {
  display: inline-block; background: var(--gt-elevated); color: var(--gt-ink);
  padding: 12px 18px; border-radius: 8px; text-decoration: none;
  font-weight: 600; font-size: .95rem; border: 1px solid var(--gt-border);
}
.navbtn:hover { border-color: var(--gt-accent); }
.complete-btn { background: var(--gt-gradient-accent); }
.complete-btn.done { background: var(--gt-success-bg); color: var(--gt-success); border: 1px solid var(--gt-success-border); }

/* ---------- course home (index) ---------- */
.module-card {
  background: var(--gt-card); border: 1px solid var(--gt-border-subtle); border-radius: 12px;
  padding: 22px 26px; margin-bottom: 22px;
  box-shadow: var(--gt-shadow-md);
}
.module-card h2 { margin: 0 0 4px; font-size: 1.3rem; }
.module-card .mod-desc { color: var(--gt-muted); font-size: .95rem; margin: 0 0 14px; }
.lesson-list { list-style: none; margin: 0; padding: 0; }
.lesson-list li { margin: 0; }
.lesson-list a {
  display: flex; align-items: center; gap: 10px;
  color: var(--gt-ink); text-decoration: none; padding: 9px 12px;
  border-radius: 8px; font-size: 1rem;
}
.lesson-list a:hover { background: var(--gt-accent-soft); }
.lesson-list a::before { content: "○"; color: var(--gt-muted); font-size: .9rem; }
.lesson-list a.done::before { content: "✓"; color: var(--gt-success); font-weight: bold; }
.lesson-list .lnum { color: var(--gt-accent); font-family: var(--gt-font-mono); font-size: .85rem; min-width: 26px; }
.hero {
  background: var(--gt-card);
  border-radius: 12px; padding: 36px 32px; margin-bottom: 32px;
  border: 1px solid var(--gt-border-subtle);
  border-top: 3px solid var(--gt-accent);
  box-shadow: var(--gt-shadow-md);
}
.hero h1 { margin-top: 0; }
.hero p { font-size: 1.05rem; color: var(--gt-ink-2nd); }
.progress-summary { color: var(--gt-muted); font-size: .95rem; margin-bottom: 24px; font-family: var(--gt-font-mono); }
