/* ==========================================================================
   PlayGuitar v3 — Inside-the-course member surface
   Ported from design/od-learndash/screens/{lesson,overview,quiz}-desktop.html
   (all approved/locked 2026-05-29). Covers single-sfwd-courses (overview),
   single-sfwd-lessons (lesson keystone), single-sfwd-topic (= lesson + one
   breadcrumb level) and single-sfwd-quiz (LearnDash quiz UI brand override).

   Scoped under body.pg-learndash so it beats legacy main.css and wins
   equal-specificity ties over the shared chrome (it is enqueued last, after
   marketing.css + member.css). Tokens-only — no :root, no hardcoded brand hex.
   The member header (.member-header) comes from member.css (.pg-member); the
   dark footer + base reset come from marketing.css (.pg-market). LD pages
   carry .pg-market + .pg-member + .pg-learndash. noindex via enqueue.php.

   Colour roles flip on member pages: GREEN (--accent) is the primary
   expression (progress, completion, mark-done, quiz pass/start). ORANGE
   (--brand) appears in exactly ONE place per page: the current-module dot in
   the outline (lesson + overview) and the locked/no-access "See the course."
   CTA. The quiz uses no orange at all; its "not quite" state is calm amber,
   never alarm red — the three amber values live as scoped local tokens below
   (the one sanctioned off-palette accent, per the approved quiz render).
   ========================================================================== */

.pg-learndash {
  --amber-wash: #FBF4E6;
  --amber-edge: #E8DAB8;
  --amber-ink:  #8A6A1F;
}

/* ---- shared base for the LD body content ---------------------------------- */
.pg-learndash .visually-hidden {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* Page wrappers (sit inside the theme's <main class="site-main">, which
   marketing.css zeroes out). .container gives max-width + padding. */
.pg-learndash .lesson-page,
.pg-learndash .course-page,
.pg-learndash .quiz-page {
  padding-top: 32px;
  padding-bottom: 96px;
}

/* ---- Breadcrumb ----------------------------------------------------------- */
.pg-learndash .breadcrumb {
  font-size: var(--text-sm);
  color: var(--ink-muted);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  margin: 0 0 12px 0;
}
.pg-learndash .breadcrumb a { color: var(--ink-muted); transition: color var(--transition-fast); }
.pg-learndash .breadcrumb a:hover { color: var(--ink-heading); }
.pg-learndash .breadcrumb .crumb-sep { color: var(--ink-light); }
.pg-learndash .breadcrumb .crumb-current { color: var(--ink-body); }
.pg-learndash .course-page .breadcrumb { margin-bottom: 20px; }

/* ==========================================================================
   LESSON (keystone) + TOPIC
   ========================================================================== */
.pg-learndash .lesson-title {
  font-size: var(--h1);
  margin: 0 0 28px 0;
}

/* Video — full container width, click-to-load facade -> real embed */
.pg-learndash .video-frame {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: var(--dark);
  background-image: radial-gradient(ellipse at 50% 35%, var(--dark-elev) 0%, var(--dark) 70%);
  border-radius: var(--radius-lg);
  overflow: hidden;
  cursor: pointer;
  margin: 0 0 12px 0;
  box-shadow: var(--shadow-md);
}
.pg-learndash .video-frame iframe,
.pg-learndash .video-frame embed,
.pg-learndash .video-frame object,
.pg-learndash .video-frame video {
  position: absolute; inset: 0; width: 100%; height: 100%; border: 0; display: block;
}
.pg-learndash .video-play {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 84px; height: 84px;
  border-radius: 50%;
  background: rgba(253,252,250,0.96);
  border: none;
  display: flex; align-items: center; justify-content: center;
  transition: transform var(--transition-fast), background var(--transition-fast);
  box-shadow: 0 8px 28px rgba(0,0,0,0.32);
}
.pg-learndash .video-frame:hover .video-play { transform: translate(-50%, -50%) scale(1.04); }
.pg-learndash .video-play svg { width: 30px; height: 30px; fill: var(--ink-heading); margin-left: 4px; }
.pg-learndash .video-caption {
  position: absolute; left: 22px; bottom: 18px;
  color: var(--on-dark-muted);
  font-size: var(--text-sm);
  letter-spacing: 0.01em;
}
.pg-learndash .video-frame.loading .video-play { opacity: 0.4; transform: translate(-50%, -50%) scale(0.92); }

/* Two-column layout: post content + sticky course-nav sidebar */
.pg-learndash .layout-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 64px;
  align-items: start;
}
.pg-learndash .lesson-page .layout-grid { margin-top: 48px; }

.pg-learndash .lesson-main,
.pg-learndash .course-main { min-width: 0; }

.pg-learndash .lesson-prose {
  font-size: 18px;
  line-height: 1.78;
  color: var(--ink-body);
  max-width: 680px;
}
.pg-learndash .lesson-prose > *:first-child { margin-top: 0; }
.pg-learndash .lesson-prose p { margin: 0 0 1.25em 0; }
.pg-learndash .lesson-prose p:last-child { margin-bottom: 0; }
.pg-learndash .lesson-prose h2 { font-size: var(--h2); margin: 1.6em 0 0.5em; }
.pg-learndash .lesson-prose h3 { font-size: var(--text-xl); margin: 1.4em 0 0.4em; }
.pg-learndash .lesson-prose img { border-radius: var(--radius-md); margin: 1.5em 0; max-width: 100%; height: auto; }
.pg-learndash .lesson-prose ul,
.pg-learndash .lesson-prose ol { margin: 0 0 1.25em 0; padding-left: 1.4em; }
.pg-learndash .lesson-prose li { margin: 0 0 0.5em 0; }
.pg-learndash .lesson-prose a { color: var(--accent); text-decoration: underline; text-underline-offset: 2px; }
.pg-learndash .lesson-prose a:hover { color: var(--accent-hover); }
.pg-learndash .lesson-prose svg { vertical-align: middle; }

/* Audio examples (jam tracks, riff/tempo demos) — were Thrive .tcb-audio, now native.
   Tight vertical rhythm: the bpm/label line hugs its player; modest gap between examples. */
.pg-learndash .lesson-prose audio { width: 100%; max-width: 480px; margin: 0.2em 0 1em; }
.pg-learndash .lesson-prose p:has(+ audio) { margin-bottom: 0.3em; }

/* Play-along examples — 2-column card of labeled players (the v2 card, rebuilt) */
.pg-learndash .lesson-prose .audio-examples {
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4) var(--space-6);
  background: var(--paper-tint); border: 1px solid var(--hairline);
  border-radius: var(--radius-lg); padding: var(--space-5) var(--space-6); margin: 1.5em 0;
}
.pg-learndash .lesson-prose .audio-example { display: flex; flex-direction: column; gap: 6px; }
.pg-learndash .lesson-prose .audio-example .ae-label { font-size: var(--text-sm); font-weight: 600; color: var(--ink-heading); }
.pg-learndash .lesson-prose .audio-example audio { width: 100%; max-width: none; margin: 0; }
@media (max-width: 640px) { .pg-learndash .lesson-prose .audio-examples { grid-template-columns: 1fr; } }

/* Tables (chord/key worksheets) — were Thrive .thrv_table, now native */
.pg-learndash .lesson-prose table {
  width: 100%; border-collapse: collapse; margin: 1.5em 0;
  font-size: var(--text-base);
}
.pg-learndash .lesson-prose th,
.pg-learndash .lesson-prose td {
  border: 1px solid var(--hairline); padding: 10px 14px;
  text-align: left; vertical-align: top;
}
.pg-learndash .lesson-prose th {
  background: var(--paper-tint); font-weight: var(--weight-semibold);
  color: var(--ink-heading);
}

/* Topics-in-this-lesson list (body) */
.pg-learndash .topics-section { margin-top: 56px; }
.pg-learndash .topics-section > h2 { font-size: var(--h2); margin-bottom: 16px; }
.pg-learndash .topic-list {
  list-style: none; margin: 0; padding: 0;
  border-top: 1px solid var(--hairline);
  max-width: 680px;
}
.pg-learndash .topic-list li {
  display: flex; align-items: center; gap: 16px;
  padding: 14px 0; min-height: 44px;
  border-bottom: 1px solid var(--hairline);
  font-size: 17px; color: var(--ink-body);
}
.pg-learndash .topic-list a.topic-title { color: inherit; }
.pg-learndash .topic-list a.topic-title:hover { color: var(--ink-heading); }
.pg-learndash .topic-list li.complete .status-icon { background: var(--accent-soft); border-color: transparent; }
.pg-learndash .topic-list li.complete .topic-title { color: var(--ink-muted); }
.pg-learndash .topic-list li.current { color: var(--ink-heading); font-weight: var(--weight-medium); }
.pg-learndash .topic-list li.not-started .topic-title { color: var(--ink-muted); }

/* Status icons (complete green check / current green dot / not-started outline) */
.pg-learndash .status-icon {
  flex: 0 0 22px; width: 22px; height: 22px;
  border-radius: 50%;
  border: 1.5px solid var(--hairline);
  display: inline-flex; align-items: center; justify-content: center;
  background: transparent;
}
.pg-learndash .status-icon.complete { background: var(--accent-soft); border-color: transparent; }
.pg-learndash .status-icon.complete svg { width: 12px; height: 12px; fill: none; stroke: var(--accent); stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round; }
.pg-learndash .status-icon.current { border-color: var(--accent); background: transparent; position: relative; }
.pg-learndash .status-icon.current::after { content: ""; width: 10px; height: 10px; background: var(--accent); border-radius: 50%; }
.pg-learndash .status-icon.not-started { background: transparent; }

/* Lesson actions: green mark-done (left) + outline prev/next (right) */
.pg-learndash .lesson-actions {
  display: flex; flex-wrap: wrap;
  align-items: center; justify-content: space-between;
  gap: 20px;
  margin-top: 48px; padding-top: 32px;
  border-top: 1px solid var(--hairline);
}
.pg-learndash .lesson-actions__complete { display: inline-flex; }
/* Style LearnDash's native mark-complete control (form/input/button) green */
.pg-learndash .lesson-actions__complete form { margin: 0; }
.pg-learndash .btn-done,
.pg-learndash .lesson-actions__complete input[type="submit"],
.pg-learndash .lesson-actions__complete input[type="button"],
.pg-learndash .lesson-actions__complete button,
.pg-learndash .lesson-actions__complete .ld-button {
  background: var(--accent);
  color: var(--on-dark);
  border: none;
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: var(--weight-semibold);
  padding: 14px 24px;
  border-radius: var(--radius-md);
  transition: background var(--transition-fast);
  display: inline-flex; align-items: center; gap: 10px;
  cursor: pointer;
  line-height: 1.2;
  text-decoration: none;
}
.pg-learndash .btn-done:hover,
.pg-learndash .lesson-actions__complete input[type="submit"]:hover,
.pg-learndash .lesson-actions__complete input[type="button"]:hover,
.pg-learndash .lesson-actions__complete button:hover,
.pg-learndash .lesson-actions__complete .ld-button:hover { background: var(--accent-hover); color: var(--on-dark); }
.pg-learndash .btn-done svg { width: 16px; height: 16px; stroke: var(--on-dark); fill: none; stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round; }
.pg-learndash .lesson-actions__complete .learndash_complete_prog { margin: 0; }

.pg-learndash .nav-buttons { display: flex; gap: 12px; flex-wrap: wrap; }
.pg-learndash .nav-buttons .btn-outline {
  display: inline-flex; align-items: center;
  padding: 13px 18px;
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--ink-heading);
  background: transparent;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-md);
  transition: border-color var(--transition-fast), background var(--transition-fast);
  line-height: 1.2;
  text-decoration: none;
}
.pg-learndash .nav-buttons .btn-outline:hover { border-color: var(--ink-muted); background: var(--paper-tint); color: var(--ink-heading); }

/* Comments — styled in marketing.css under .comments-section (shared with free-sample) */
.pg-learndash .comments-section { margin-top: 72px; max-width: 680px; }

/* ---- Sidebar (course nav) ------------------------------------------------- */
.pg-learndash .lesson-sidebar,
.pg-learndash .course-sidebar {
  position: sticky;
  top: 24px;
  font-size: var(--text-sm);
}

.pg-learndash .progress-card {
  background: var(--paper);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-lg);
  padding: 18px 18px 20px;
  margin-bottom: 20px;
}
.pg-learndash .course-title-link {
  font-family: var(--font-heading);
  font-size: 17px;
  font-weight: var(--weight-semibold);
  color: var(--ink-heading);
  display: block;
  margin-bottom: 8px;
  letter-spacing: -0.01em;
  transition: color var(--transition-fast);
}
.pg-learndash a.course-title-link:hover { color: var(--accent-hover); }
.pg-learndash .progress-label {
  font-size: var(--text-xs);
  color: var(--ink-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: var(--weight-medium);
  margin-bottom: 10px;
}
.pg-learndash .progress-card .progress-bar {
  position: relative;
  height: 6px;
  background: var(--paper-deep);
  border-radius: var(--radius-pill);
  overflow: hidden;
  margin: 0;
}
.pg-learndash .progress-card .progress-fill {
  position: absolute; top: 0; left: 0;
  height: 100%; width: 0;
  background: var(--accent);
  border-radius: var(--radius-pill);
  transition: width 400ms ease;
}

.pg-learndash .course-outline {
  background: var(--paper);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.pg-learndash .module-row {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 14px 16px; min-height: 56px;
  border-bottom: 1px solid var(--hairline);
  color: var(--ink-body);
  transition: background var(--transition-fast);
  cursor: pointer;
  text-decoration: none;
}
.pg-learndash .module-row:last-child { border-bottom: none; }
.pg-learndash .module-row:hover { background: var(--paper-tint); color: var(--ink-heading); }
.pg-learndash .module-row .row-icon { flex: 0 0 22px; margin-top: 2px; }
.pg-learndash .module-row .row-body { flex: 1; min-width: 0; }
.pg-learndash .module-row .row-title {
  font-family: var(--font-body);
  font-size: 14.5px;
  font-weight: var(--weight-medium);
  color: var(--ink-heading);
  line-height: 1.4;
  margin-bottom: 3px;
}
.pg-learndash .module-row .row-meta { font-size: var(--text-xs); color: var(--ink-muted); }
.pg-learndash .module-row .row-chevron { flex: 0 0 14px; margin-top: 5px; color: var(--ink-light); }
.pg-learndash .module-row .row-chevron svg { width: 12px; height: 12px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; display: block; }
.pg-learndash .module-row.complete .row-title { color: var(--ink-muted); }
.pg-learndash .module-row.not-started .row-title { color: var(--ink-body); }
.pg-learndash .module-row.current {
  background: var(--paper-tint);
  flex-wrap: wrap;
  cursor: default;
}
.pg-learndash .module-row.current:hover { background: var(--paper-tint); }
.pg-learndash .module-row.current .row-title { color: var(--ink-heading); font-weight: var(--weight-semibold); }

/* The single sanctioned orange: the current-module dot */
.pg-learndash .row-icon.orange-dot {
  width: 22px; height: 22px;
  display: inline-flex; align-items: center; justify-content: center;
  margin-top: 2px;
}
.pg-learndash .row-icon.orange-dot::after {
  content: ""; width: 11px; height: 11px;
  background: var(--brand); border-radius: 50%;
  box-shadow: 0 0 0 4px rgba(236,124,42,0.14);
}

/* Current-module expanded topic sublist (inline, in the sidebar) */
.pg-learndash .topic-sublist {
  list-style: none; margin: 10px 0 4px 0; padding: 0;
  width: 100%; border-top: 1px solid var(--hairline);
}
.pg-learndash .topic-sublist li {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 0 10px 34px; min-height: 36px;
  font-size: 13.5px; line-height: 1.4;
}
.pg-learndash .topic-sublist li + li { border-top: 1px dashed var(--hairline); }
.pg-learndash .topic-sublist .status-icon { flex: 0 0 16px; width: 16px; height: 16px; border-width: 1.5px; }
.pg-learndash .topic-sublist .status-icon.complete svg { width: 9px; height: 9px; stroke-width: 2.5; }
.pg-learndash .topic-sublist .status-icon.current::after { width: 7px; height: 7px; }
.pg-learndash .topic-sublist .sub-title { color: var(--ink-body); }
.pg-learndash .topic-sublist li.complete .sub-title { color: var(--ink-muted); }
.pg-learndash .topic-sublist li.current .sub-title { color: var(--ink-heading); font-weight: var(--weight-medium); }
.pg-learndash .topic-sublist li.not-started .sub-title { color: var(--ink-body); }

/* ---- No-access / locked state (alt) --------------------------------------- */
.pg-learndash .alt-state-block {
  max-width: 620px;
  margin: 48px auto 0 auto;
  background: var(--paper-tint);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-lg);
  padding: 40px 44px;
  text-align: left;
}
.pg-learndash .alt-state-block h2 { font-size: clamp(1.5rem, 2.4vw, 1.875rem); margin-bottom: 14px; line-height: var(--leading-tight); }
.pg-learndash .alt-state-block p { font-size: 17px; line-height: 1.7; color: var(--ink-body); margin: 0 0 24px 0; }
.pg-learndash .alt-state-block .btn-orange {
  display: inline-block;
  background: var(--brand);
  color: var(--on-dark);
  font-weight: var(--weight-semibold);
  padding: 13px 26px;
  border-radius: var(--radius-md);
  font-size: var(--text-base);
  transition: background var(--transition-fast);
  text-decoration: none;
}
.pg-learndash .alt-state-block .btn-orange:hover { background: var(--brand-hover); color: var(--on-dark); }

/* ==========================================================================
   COURSE OVERVIEW (single-sfwd-courses)
   ========================================================================== */
.pg-learndash .course-banner {
  padding: 12px 0 40px 0;
  border-bottom: 1px solid var(--hairline);
  margin-bottom: 48px;
}
.pg-learndash .course-kicker {
  display: inline-block;
  font-size: var(--text-xs);
  color: var(--ink-muted);
  font-weight: var(--weight-medium);
  letter-spacing: var(--track-eyebrow);
  text-transform: uppercase;
  margin: 0 0 14px 0;
}
.pg-learndash .course-title {
  font-size: var(--h1);
  margin: 0 0 12px 0;
  max-width: 820px;
}
.pg-learndash .course-meta {
  font-size: 17px;
  color: var(--ink-muted);
  margin: 0 0 28px 0;
  line-height: 1.5;
}
.pg-learndash .btn-continue {
  display: inline-flex; align-items: center; gap: 12px;
  background: var(--accent);
  color: var(--on-dark);
  font-family: var(--font-body);
  font-size: 17px;
  font-weight: var(--weight-semibold);
  padding: 16px 26px;
  border-radius: var(--radius-md);
  border: none;
  transition: background var(--transition-fast);
  line-height: 1.3;
  letter-spacing: -0.005em;
  text-decoration: none;
}
.pg-learndash .btn-continue:hover { background: var(--accent-hover); color: var(--on-dark); }
.pg-learndash .btn-continue svg { width: 16px; height: 16px; fill: none; stroke: currentColor; stroke-width: 2.4; stroke-linecap: round; stroke-linejoin: round; flex-shrink: 0; }

/* Conditional welcome / intro video (full container width) */
.pg-learndash .welcome-video { margin: 0 0 var(--space-12) 0; }
.pg-learndash .welcome-video-label {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-muted);
  margin: 0 0 var(--space-3) 0;
}

.pg-learndash .course-description {
  font-size: 18px;
  line-height: 1.78;
  color: var(--ink-body);
  max-width: 680px;
}
.pg-learndash .course-description > *:first-child { margin-top: 0; }
.pg-learndash .course-description p { margin: 0 0 1.25em 0; }
.pg-learndash .course-description p:last-child { margin-bottom: 0; }
.pg-learndash .course-description h2 { font-size: var(--h2); margin: 1.6em 0 0.5em; }
.pg-learndash .course-description h3 { font-size: var(--text-xl); margin: 1.4em 0 0.4em; }
.pg-learndash .course-description ul,
.pg-learndash .course-description ol { margin: 0 0 1.25em 0; padding-left: 1.4em; }
.pg-learndash .course-description a { color: var(--accent); text-decoration: underline; text-underline-offset: 2px; }

/* Auto-collapsed downloads/resources expander (legacy <details> from content) */
.pg-learndash .course-resources { max-width: 680px; margin-top: 32px; border: 1px solid var(--hairline); border-radius: var(--radius-md); overflow: hidden; }
.pg-learndash .course-resources__toggle { display: flex; align-items: center; gap: 10px; padding: 16px 18px; cursor: pointer; font-weight: var(--weight-semibold); color: var(--ink-heading); list-style: none; }
.pg-learndash .course-resources__toggle::-webkit-details-marker { display: none; }
.pg-learndash .course-resources__icon { color: var(--accent); }
.pg-learndash .course-resources__chevron { margin-left: auto; transition: transform var(--transition-fast); }
.pg-learndash details[open] .course-resources__chevron { transform: rotate(180deg); }
.pg-learndash .course-resources__body { padding: 0 18px 18px; }

.pg-learndash .downloads-section { margin-top: 64px; max-width: 680px; }
.pg-learndash .downloads-section > h2 { font-size: var(--h2); margin-bottom: 18px; }
.pg-learndash .download-list { list-style: none; margin: 0; padding: 0; border-top: 1px solid var(--hairline); }
.pg-learndash .download-list li { border-bottom: 1px solid var(--hairline); }
.pg-learndash .download-list a {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 16px 4px; min-height: 56px;
  color: var(--ink-body); font-size: 17px; line-height: 1.5;
  transition: background var(--transition-fast), color var(--transition-fast);
  text-decoration: none;
}
.pg-learndash .download-list a:hover { color: var(--ink-heading); background: var(--paper-tint); }
.pg-learndash .download-list .dl-tag {
  flex-shrink: 0;
  font-size: var(--text-xs);
  color: var(--ink-muted);
  font-weight: var(--weight-medium);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 4px 9px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-sm);
  background: var(--paper);
}

/* ==========================================================================
   QUIZ (single-sfwd-quiz) — v3 intro voice + LearnDash WpProQuiz brand override
   GREEN is the only action colour here; "not quite" is calm amber, never red.
   ========================================================================== */
.pg-learndash .quiz-column { max-width: var(--width-content); margin: 0 auto; }
.pg-learndash .quiz-page .breadcrumb { max-width: var(--width-content); margin: 0 auto 40px auto; }

.pg-learndash .quiz-eyebrow {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: var(--track-eyebrow);
  color: var(--ink-muted);
  font-weight: var(--weight-medium);
  margin: 0 0 14px 0;
  display: inline-flex; align-items: center; gap: 8px;
}
.pg-learndash .quiz-eyebrow::before { content: ""; width: 7px; height: 7px; background: var(--accent); border-radius: 50%; }

.pg-learndash .quiz-intro { padding: 8px 0; }
.pg-learndash .quiz-intro h1 { font-size: var(--h1); margin: 0 0 18px 0; }
.pg-learndash .quiz-intro .lede { font-size: 19px; line-height: 1.7; color: var(--ink-body); margin: 0 0 30px 0; max-width: 620px; }
.pg-learndash .quiz-meta { display: flex; flex-wrap: wrap; gap: 18px 28px; font-size: var(--text-sm); color: var(--ink-muted); margin: 0 0 32px 0; }
.pg-learndash .quiz-meta .item { display: inline-flex; align-items: center; gap: 8px; }
.pg-learndash .quiz-meta .dot { width: 4px; height: 4px; border-radius: 50%; background: var(--ink-light); }

.pg-learndash .btn-primary {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  background: var(--accent);
  color: var(--on-dark);
  border: none;
  font-size: var(--text-base);
  font-weight: var(--weight-semibold);
  padding: 15px 28px; min-height: 48px;
  border-radius: var(--radius-md);
  transition: background var(--transition-fast);
  text-decoration: none; line-height: 1.2; cursor: pointer;
}
.pg-learndash .btn-primary:hover { background: var(--accent-hover); color: var(--on-dark); }
.pg-learndash .btn-primary svg { width: 16px; height: 16px; fill: none; stroke: currentColor; stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round; }

.pg-learndash .result-actions .btn-outline {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 14px 22px; min-height: 48px;
  font-size: var(--text-base); font-weight: var(--weight-medium);
  color: var(--ink-heading); background: transparent;
  border: 1px solid var(--hairline); border-radius: var(--radius-md);
  transition: border-color var(--transition-fast), background var(--transition-fast);
  line-height: 1.2; text-decoration: none;
}
.pg-learndash .result-actions .btn-outline:hover { border-color: var(--ink-muted); background: var(--paper-tint); color: var(--ink-heading); }

.pg-learndash .live-sep { margin: 48px auto 8px auto; max-width: var(--width-content); border: 0; border-top: 1px solid var(--hairline); }

/* ---- WpProQuiz brand override (LearnDash renders the real quiz DOM) ---- */
/* Hide ld30's own breadcrumb — our member breadcrumb already carries it. */
.pg-learndash .quiz-ld .ld-breadcrumbs { display: none; }
.pg-learndash .wpProQuiz_content { max-width: var(--width-content); margin: 0 auto; }
.pg-learndash .wpProQuiz_content h2,
.pg-learndash .wpProQuiz_header { font-family: var(--font-heading); color: var(--ink-heading); }
.pg-learndash .wpProQuiz_quiz ol,
.pg-learndash .wpProQuiz_quiz ul { list-style: none; margin: 0; padding: 0; }
.pg-learndash .wpProQuiz_listItem { margin: 0 0 28px 0; }
.pg-learndash .wpProQuiz_question_text { font-family: var(--font-heading); font-size: clamp(1.25rem, 2.4vw, 1.5rem); color: var(--ink-heading); line-height: 1.35; margin: 0 0 20px 0; }
.pg-learndash .wpProQuiz_questionList { display: flex; flex-direction: column; gap: 12px; margin: 0; }
.pg-learndash .wpProQuiz_questionListItem {
  display: flex; align-items: center; gap: 14px;
  padding: 16px 20px; min-height: 60px;
  background: var(--paper);
  border: 1.5px solid var(--hairline);
  border-radius: var(--radius-md);
  font-size: 17px; color: var(--ink-body);
  cursor: pointer;
  transition: border-color var(--transition-fast), background var(--transition-fast);
}
.pg-learndash .wpProQuiz_questionListItem:hover { border-color: var(--ink-muted); background: var(--paper-tint); }
.pg-learndash .wpProQuiz_questionListItem label { cursor: pointer; display: flex; align-items: center; gap: 14px; width: 100%; margin: 0; }
.pg-learndash .wpProQuiz_questionListItem.wpProQuiz_answerCorrect { border-color: var(--accent); background: var(--accent-soft); box-shadow: 0 0 0 1px var(--accent); color: var(--ink-heading); }
.pg-learndash .wpProQuiz_questionListItem.wpProQuiz_answerIncorrect { border-color: var(--amber-edge); background: var(--amber-wash); }
/* Primary quiz buttons (Start, Next, Check, Finish) + the lesson mark-complete
   button. ld30 colours these with an INLINE color-scheme rule at ~5-class
   specificity + !important (configured blue), so we mirror that specificity,
   prefixed with .pg-learndash, and load last — the brand green then wins. The
   excluded :not() classes (reShow/restart, reverse/transparent) keep ld30's own
   secondary/quiet treatment so re-take and back stay visually subordinate. */
.pg-learndash .wpProQuiz_content .wpProQuiz_button:not(.wpProQuiz_button_reShowQuestion):not(.wpProQuiz_button_restartQuiz),
.pg-learndash .ld-button:not(.ld-button-reverse):not(.learndash-link-previous-incomplete):not(.ld-button-transparent) {
  background-color: var(--accent) !important;
  background-image: none !important;
  color: var(--on-dark) !important;
  border: 0 !important;
  border-radius: var(--radius-md) !important;
  font-family: var(--font-body);
  font-weight: var(--weight-semibold);
  text-shadow: none !important;
  box-shadow: none !important;
  opacity: 1;
  transition: background-color var(--transition-fast);
}
.pg-learndash .wpProQuiz_content .wpProQuiz_button:not(.wpProQuiz_button_reShowQuestion):not(.wpProQuiz_button_restartQuiz):hover,
.pg-learndash .ld-button:not(.ld-button-reverse):not(.learndash-link-previous-incomplete):not(.ld-button-transparent):hover {
  background-color: var(--accent-hover) !important;
  opacity: 1 !important;
}
.pg-learndash .wpProQuiz_progress { background: var(--paper-deep); border-radius: var(--radius-pill); height: 4px; overflow: hidden; }
.pg-learndash .wpProQuiz_progress_points { background: var(--accent); height: 100%; }
.pg-learndash .wpProQuiz_results { background: var(--accent-soft); border: 1px solid rgba(31,122,71,0.18); border-radius: var(--radius-lg); padding: 32px 36px; }

/* Active-question + result demo blocks (matching the render's documented states) */
.pg-learndash .quiz-active { padding: 8px 0; }
.pg-learndash .progress-line { display: flex; align-items: center; gap: 14px; margin: 0 0 18px 0; }
.pg-learndash .progress-line .label { font-size: var(--text-sm); color: var(--ink-muted); font-weight: var(--weight-medium); white-space: nowrap; }
.pg-learndash .progress-line .track { flex: 1; height: 4px; background: var(--paper-deep); border-radius: var(--radius-pill); overflow: hidden; }
.pg-learndash .progress-line .fill { height: 100%; background: var(--accent); border-radius: var(--radius-pill); }
.pg-learndash .result { border-radius: var(--radius-lg); padding: 40px 44px; border: 1px solid transparent; }
.pg-learndash .result .state-tag { font-size: var(--text-xs); text-transform: uppercase; letter-spacing: var(--track-eyebrow); font-weight: var(--weight-medium); margin: 0 0 14px 0; display: inline-flex; align-items: center; gap: 8px; }
.pg-learndash .result h2 { font-size: clamp(1.5rem, 2.4vw, 1.875rem); margin: 0 0 14px 0; line-height: var(--leading-tight); }
.pg-learndash .result p { font-size: 17px; line-height: 1.7; color: var(--ink-body); margin: 0 0 24px 0; max-width: 540px; }
.pg-learndash .result-actions { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.pg-learndash .result.pass { background: var(--accent-soft); border-color: rgba(31,122,71,0.18); }
.pg-learndash .result.pass .state-tag { color: var(--accent-hover); }
.pg-learndash .result.retry { background: var(--amber-wash); border-color: var(--amber-edge); }
.pg-learndash .result.retry .state-tag { color: var(--amber-ink); }

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width: 960px) {
  .pg-learndash .layout-grid { grid-template-columns: 1fr; gap: 56px; }
  .pg-learndash .lesson-page .layout-grid { margin-top: 36px; }
  .pg-learndash .lesson-sidebar,
  .pg-learndash .course-sidebar { position: static; }
  .pg-learndash .course-banner { margin-bottom: 36px; padding-bottom: 32px; }
}
@media (max-width: 640px) {
  .pg-learndash .lesson-page,
  .pg-learndash .course-page,
  .pg-learndash .quiz-page { padding-top: 24px; padding-bottom: 64px; }
  .pg-learndash .lesson-title { margin-bottom: 20px; }
  .pg-learndash .video-play { width: 64px; height: 64px; }
  .pg-learndash .video-play svg { width: 22px; height: 22px; }
  .pg-learndash .video-caption { left: 14px; bottom: 12px; font-size: 13px; }
  .pg-learndash .lesson-prose,
  .pg-learndash .course-description { font-size: 17px; line-height: 1.72; }
  .pg-learndash .topics-section { margin-top: 40px; }
  .pg-learndash .topic-list li { font-size: 16px; gap: 12px; }
  .pg-learndash .lesson-actions { padding-top: 24px; margin-top: 36px; gap: 14px; flex-direction: column; align-items: stretch; }
  .pg-learndash .nav-buttons { width: 100%; flex-direction: column; }
  .pg-learndash .nav-buttons .btn-outline { width: 100%; justify-content: center; text-align: center; white-space: normal; overflow-wrap: anywhere; }
  .pg-learndash .btn-done,
  .pg-learndash .lesson-actions__complete,
  .pg-learndash .lesson-actions__complete input,
  .pg-learndash .lesson-actions__complete button { width: 100%; justify-content: center; }
  .pg-learndash .course-banner { padding: 8px 0 28px 0; margin-bottom: 28px; }
  .pg-learndash .course-title { margin-bottom: 10px; }
  .pg-learndash .course-meta { font-size: 16px; margin-bottom: 22px; }
  .pg-learndash .btn-continue { width: 100%; justify-content: space-between; padding: 16px 22px; font-size: 16px; }
  .pg-learndash .downloads-section { margin-top: 44px; }
  .pg-learndash .download-list a { font-size: 16px; padding: 14px 4px; }
  .pg-learndash .alt-state-block { padding: 28px 22px; }
  .pg-learndash .quiz-intro .lede { font-size: 18px; }
  .pg-learndash .result { padding: 28px 22px; }
  .pg-learndash .result-actions { width: 100%; }
  .pg-learndash .result-actions .btn-primary,
  .pg-learndash .result-actions .btn-outline { width: 100%; }
}
