/* Curso Blender — estilo editorial común */

:root {
  --bg: #f7f3eb;
  --bg-soft: #fbf8f1;
  --text: #2a2622;
  --muted: #6f6a62;
  --accent: #c8580d;
  --accent-soft: #fde9d3;
  --accent-faint: rgba(200, 88, 13, 0.06);
  --rule: #d8d2c2;
  --rule-soft: #e8e2d2;
  --serif: 'Iowan Old Style', 'Charter', 'Georgia', 'Cambria', serif;
  --sans: 'Inter', -apple-system, 'Helvetica Neue', 'Arial', sans-serif;
  --mono: 'Menlo', 'Consolas', monospace;
}

* { box-sizing: border-box; }

html, body { margin: 0; padding: 0; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--serif);
  font-size: 18px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* Progress bar */
.progress {
  position: fixed;
  top: 0; left: 0;
  height: 3px;
  background: var(--accent);
  width: 0%;
  z-index: 100;
  transition: width 0.08s linear;
}

/* Top crumb */
.topbar {
  font-family: var(--sans);
  font-size: 0.8rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  padding: 28px 40px 0 40px;
  max-width: 1180px;
  margin: 0 auto;
}
.topbar a { color: var(--accent); text-decoration: none; }
.topbar a:hover { text-decoration: underline; }

/* Layout: main column + margin notes */
.container {
  max-width: 1180px;
  margin: 0 auto;
  padding: 24px 40px 80px 40px;
  display: grid;
  grid-template-columns: minmax(0, 640px) 280px;
  gap: 60px;
}
@media (max-width: 920px) {
  .container { grid-template-columns: 1fr; gap: 0; padding: 24px 24px 60px 24px; }
}

/* Header */
header.title { grid-column: 1 / -1; margin-bottom: 24px; }
.title h1 {
  font-family: var(--sans);
  font-weight: 700;
  font-size: 2.3rem;
  line-height: 1.2;
  margin: 8px 0 12px 0;
  letter-spacing: -0.01em;
}
.title .meta {
  font-family: var(--sans);
  font-size: 0.95rem;
  color: var(--muted);
}
.title .meta .clock { color: var(--accent); font-weight: 600; }
.title .objetivo {
  font-family: var(--serif);
  font-style: italic;
  font-size: 1.1rem;
  color: var(--text);
  margin: 20px 0 0 0;
  padding-left: 16px;
  border-left: 3px solid var(--accent);
}

/* Main column */
main.col-main { grid-column: 1; }
main.col-main h2 {
  font-family: var(--sans);
  font-weight: 600;
  font-size: 1.35rem;
  margin: 56px 0 16px 0;
  padding-top: 28px;
  border-top: 1px solid var(--rule-soft);
  letter-spacing: -0.005em;
}
main.col-main h2:first-child { border-top: none; padding-top: 0; margin-top: 0; }
main.col-main h3 {
  font-family: var(--sans);
  font-weight: 600;
  font-size: 1.05rem;
  margin: 28px 0 8px 0;
}
main.col-main p { margin: 0 0 14px 0; }
main.col-main p strong { color: var(--text); font-weight: 600; }
main.col-main p em { color: var(--accent); font-style: italic; font-weight: 500; }
main.col-main code {
  background: var(--accent-faint);
  color: var(--accent);
  padding: 1px 6px;
  border-radius: 3px;
  font-family: var(--mono);
  font-size: 0.88em;
}
main.col-main ul, main.col-main ol { margin: 8px 0 18px 0; padding-left: 24px; }
main.col-main li { margin-bottom: 6px; }
main.col-main a { color: var(--accent); text-decoration: none; border-bottom: 1px solid var(--accent-soft); }
main.col-main a:hover { border-bottom-color: var(--accent); }

/* Margin notes (aside) */
aside.col-aside { grid-column: 2; padding-top: 4px; }
@media (max-width: 920px) { aside.col-aside { display: none; } }

.note {
  font-family: var(--sans);
  font-size: 0.82rem;
  line-height: 1.55;
  color: var(--muted);
  padding: 0 0 0 14px;
  border-left: 2px solid var(--rule);
  margin-bottom: 32px;
}
.note strong { color: var(--text); font-weight: 600; }
.note code {
  font-family: var(--mono);
  font-size: 0.85em;
  background: var(--accent-faint);
  color: var(--accent);
  padding: 0 4px;
  border-radius: 3px;
}

/* Inline-on-mobile margin notes (shown when aside hidden) */
.note-inline {
  display: none;
}
@media (max-width: 920px) {
  .note-inline {
    display: block;
    background: var(--bg-soft);
    border: 1px solid var(--rule-soft);
    border-radius: 4px;
    padding: 12px 16px;
    margin: 18px 0;
    font-family: var(--sans);
    font-size: 0.85rem;
    color: var(--muted);
    line-height: 1.55;
  }
  .note-inline strong { color: var(--text); }
  aside.col-aside { display: none; }
}

/* Callout */
.callout {
  background: var(--accent-soft);
  border-left: 3px solid var(--accent);
  padding: 16px 20px;
  margin: 28px 0;
  font-size: 0.97em;
  border-radius: 0 4px 4px 0;
}
.callout strong { color: var(--accent); }

/* Diagram figure */
figure {
  margin: 36px 0;
  padding: 24px 16px 12px 16px;
  background: var(--bg-soft);
  border: 1px solid var(--rule-soft);
  border-radius: 6px;
}
figure svg { display: block; max-width: 100%; height: auto; margin: 0 auto; }
figcaption {
  font-family: var(--sans);
  font-size: 0.82rem;
  color: var(--muted);
  margin-top: 16px;
  text-align: center;
  font-style: italic;
}

/* Recap */
.recap {
  background: var(--accent-faint);
  border-radius: 6px;
  padding: 20px 24px;
  margin: 36px 0;
}
.recap h3 {
  margin-top: 0;
  font-family: var(--sans);
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--accent);
}
.recap ul { margin: 0; padding-left: 22px; }
.recap li { margin-bottom: 6px; }

/* Practice block */
.practice {
  background: white;
  border: 1px solid var(--rule);
  border-radius: 6px;
  padding: 24px 28px;
  margin: 48px 0 32px 0;
  box-shadow: 0 1px 3px rgba(0,0,0,0.03);
}
.practice .label {
  font-family: var(--sans);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--accent);
  font-weight: 700;
}
.practice h3 {
  font-family: var(--sans);
  margin: 6px 0 12px 0;
  font-size: 1.15rem;
}
.practice ol { padding-left: 22px; }
.practice li { margin-bottom: 10px; }
.practice li code { background: var(--accent-faint); color: var(--accent); padding: 1px 6px; border-radius: 3px; font-family: var(--mono); font-size: 0.85em; }
.practice .check {
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px dashed var(--rule);
  font-family: var(--sans);
  font-size: 0.88rem;
  color: var(--muted);
}
.practice .check strong { color: var(--text); }

/* Bottom navigation */
.foot-nav {
  grid-column: 1 / -1;
  display: flex;
  justify-content: space-between;
  margin-top: 64px;
  padding-top: 28px;
  border-top: 1px solid var(--rule);
  font-family: var(--sans);
  font-size: 0.95rem;
}
.foot-nav a {
  color: var(--accent);
  text-decoration: none;
  display: inline-block;
  padding: 6px 0;
}
.foot-nav a:hover { text-decoration: underline; }
.foot-nav .prev::before { content: "← "; }
.foot-nav .next::after { content: " →"; }
.foot-nav .home { color: var(--muted); }

/* Quiz (evaluación) */
.quiz-q {
  background: white;
  border: 1px solid var(--rule);
  border-radius: 6px;
  padding: 22px 26px;
  margin: 24px 0;
}
.quiz-q .qnum {
  font-family: var(--sans);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--accent);
  font-weight: 700;
}
.quiz-q .qtext {
  font-family: var(--serif);
  font-size: 1.05rem;
  margin: 6px 0 14px 0;
  font-weight: 500;
}
.quiz-q ul.options { list-style: none; padding: 0; margin: 0 0 14px 0; }
.quiz-q ul.options li {
  font-family: var(--sans);
  font-size: 0.95rem;
  padding: 6px 0;
  color: var(--text);
}
.quiz-q ul.options li::before { content: "○ "; color: var(--muted); }
.quiz-q details {
  margin-top: 10px;
  padding: 10px 14px;
  background: var(--bg-soft);
  border-radius: 4px;
  font-family: var(--sans);
  font-size: 0.92rem;
}
.quiz-q details summary {
  cursor: pointer;
  font-weight: 600;
  color: var(--accent);
}
.quiz-q details[open] summary { margin-bottom: 8px; }
.quiz-q details .answer { color: var(--text); line-height: 1.6; }
.quiz-q details .answer strong { color: var(--accent); }

/* Index page (portada del curso) */
.cover {
  max-width: 880px;
  margin: 0 auto;
  padding: 60px 40px 80px 40px;
}
.cover h1 {
  font-family: var(--sans);
  font-size: 2.6rem;
  font-weight: 700;
  margin: 0 0 8px 0;
  letter-spacing: -0.015em;
}
.cover .sub {
  font-family: var(--serif);
  font-style: italic;
  font-size: 1.2rem;
  color: var(--muted);
  margin-bottom: 36px;
}
.cover .lead {
  font-size: 1.1rem;
  margin-bottom: 40px;
}
.cover h2 {
  font-family: var(--sans);
  font-size: 1.1rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--accent);
  margin: 48px 0 16px 0;
}
.toc { list-style: none; padding: 0; margin: 0; }
.toc li {
  display: grid;
  grid-template-columns: 36px 1fr auto;
  gap: 16px;
  align-items: baseline;
  padding: 14px 0;
  border-top: 1px solid var(--rule-soft);
}
.toc li:last-child { border-bottom: 1px solid var(--rule-soft); }
.toc .num {
  font-family: var(--sans);
  font-size: 0.85rem;
  color: var(--accent);
  font-weight: 700;
}
.toc .title-row a {
  font-family: var(--sans);
  font-size: 1.05rem;
  color: var(--text);
  text-decoration: none;
  font-weight: 600;
  display: block;
}
.toc .title-row a:hover { color: var(--accent); }
.toc .title-row .desc {
  font-family: var(--serif);
  font-size: 0.95rem;
  color: var(--muted);
  font-style: italic;
  margin-top: 2px;
  display: block;
}
.toc .clock {
  font-family: var(--sans);
  font-size: 0.82rem;
  color: var(--muted);
}
.cover .eval-link {
  display: block;
  margin-top: 32px;
  padding: 18px 22px;
  background: var(--accent-soft);
  border-radius: 6px;
  font-family: var(--sans);
  text-decoration: none;
  color: var(--text);
}
.cover .eval-link strong { color: var(--accent); }
