:root{
  /* Palette aligned to socialconnectionguidelines.org */
  --orange-50:#FFF7ED;
  --orange-100:#FFEDD5;
  --orange-200:#FED7AA;
  --orange-300:#FDBA74;
  --orange-400:#FB923C;
  --orange-500:#F97316;
  --orange-600:#EA580C;
  --orange-700:#C2410C;
  --orange-800:#9A3412;
  --orange-900:#7C2D12;

  --slate-50:#F8FAFC;  --slate-100:#F1F5F9;  --slate-200:#E2E8F0;
  --slate-300:#CBD5E1; --slate-400:#94A3B8;  --slate-500:#64748B;
  --slate-600:#475569; --slate-700:#334155;  --slate-800:#1E293B; --slate-900:#0F172A;

  --gray-50:#F9FAFB;   --gray-100:#F3F4F6;   --gray-200:#E5E7EB;
  --gray-300:#D1D5DB;  --gray-400:#9CA3AF;   --gray-500:#6B7280;
  --gray-600:#4B5563;  --gray-700:#374151;   --gray-800:#1F2937;  --gray-900:#111827;

  --ink:var(--gray-900);
  --ink-soft:var(--gray-700);
  --ink-mute:var(--slate-500);
  --paper:#FFFFFF;
  --line:var(--gray-200);
  --line-soft:var(--gray-100);

  /* Legacy aliases — keep older rules working */
  --maroon:var(--orange-600);
  --dark-maroon:var(--orange-800);
  --light-maroon:var(--orange-300);
  --very-light-maroon:var(--orange-50);
  --dusty-rose:var(--orange-200);
  --dark:var(--gray-900);
  --text:var(--gray-700);
  --text-light:var(--slate-500);
  --bg:#FFFFFF;
  --white:#fff;
  --amber:var(--orange-500);
  --light-amber:var(--orange-100);
  --green:var(--orange-700);
  --light-green:var(--orange-100);
  --rose:var(--orange-700);
  --light-rose:var(--orange-100);
  --teal:var(--slate-600);
  --light-teal:var(--slate-100);
  --grey:var(--gray-200);

  --radius:8px;
  --radius-sm:6px;
  --radius-lg:12px;
  --shadow:0 1px 3px rgba(15,23,42,.05), 0 1px 2px rgba(15,23,42,.04);
  --shadow-lg:0 10px 30px rgba(15,23,42,.10);
  --shadow-card:0 1px 2px rgba(15,23,42,.04), 0 1px 3px rgba(15,23,42,.06);

  --sidebar-w:300px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Figtree', 'Inter', 'Segoe UI', system-ui, -apple-system, sans-serif;
  color: var(--gray-700);
  line-height: 1.6;
  font-size: 16px;
  background: var(--gray-50);
  -webkit-font-smoothing: antialiased;
}
@media(min-width:640px){
  body{
    background: linear-gradient(180deg, #FFEDD5 0%, #FED7AA 60%, #FDBA74 100%);
    background-attachment: fixed;
    min-height: 100vh;
  }
}
h1,h2,h3,h4 { font-family: 'Domine', Georgia, serif; color: var(--gray-900); letter-spacing: -.015em; font-weight: 700; }
a { color: var(--orange-700); text-decoration: none; }
a:hover { color: var(--orange-800); }
button { font-family: inherit; }

/* ── Sidebar ── */
.sidebar {
  position: fixed; top: 0; left: 0; width: var(--sidebar-w); height: 100vh;
  background: #C2410C;   /* warm burnt-orange / terracotta */
  color: rgba(255,255,255,0.85);
  z-index: 100; display: flex; flex-direction: column;
  transition: transform 0.3s ease; overflow: hidden;
}
.sidebar-header { padding: 24px 22px 18px; border-bottom: 1px solid rgba(255,255,255,0.12); text-align: center; flex-shrink: 0; }
.sidebar-header .sidebar-logo { width: 100%; max-width: 88px; height: auto; display: block; margin: 0 auto 12px; opacity: 0.95; }
.sidebar-header h2 { font-family: 'Domine', serif; font-size: 17px; font-weight: 700; line-height: 1.3; color: #fff; text-align: center; letter-spacing: -.012em; }
.sidebar-header p { font-size: 11px; letter-spacing: .8px; text-transform: uppercase; color: rgba(255,255,255,0.75); font-weight: 600; margin-top: 6px; text-align: center; }
.sidebar-nav { flex: 1; overflow-y: auto; padding: 14px 0 4px; }
.sidebar-nav::-webkit-scrollbar { width: 5px; }
.sidebar-nav::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.2); border-radius: 3px; }
.nav-item {
  display: flex; align-items: center; gap: 11px; padding: 10px 22px;
  cursor: pointer; transition: all .15s; font-size: 13.5px;
  color: rgba(255,255,255,0.78); border-left: 3px solid transparent;
  line-height: 1.35; font-weight: 500;
}
.nav-item:hover { background: rgba(255,255,255,0.08); color: #fff; }
.nav-item.active { background: rgba(255,255,255,0.14); color: #fff; font-weight: 600; border-left-color: var(--orange-300); }
.nav-item .dot {
  width: 22px; height: 22px; border-radius: 50%; border: 1.5px solid rgba(255,255,255,0.35);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; font-size: 11px; font-weight: 700; color: rgba(255,255,255,0.75);
  background: rgba(255,255,255,0.04);
}
.nav-item.active .dot { border-color: var(--orange-300); background: rgba(253,186,116,0.25); color: #fff; }
.nav-item.completed .dot { background: var(--orange-50); border-color: var(--orange-50); color: var(--orange-800); }
.nav-item.completed .dot::after { content: '✓'; }
.sidebar-progress { padding: 14px 22px 8px; border-top: 1px solid rgba(255,255,255,0.12); }
.progress-bar-bg { height: 6px; background: rgba(255,255,255,0.15); border-radius: 3px; overflow: hidden; }
.progress-bar-fill { height: 100%; background: var(--orange-300); border-radius: 3px; transition: width 0.5s ease; width: 0%; }
.progress-text { font-size: 11px; color: rgba(255,255,255,0.75); margin-top: 6px; font-weight: 500; }
.sidebar-footer {
  padding: 14px 22px 18px; border-top: 1px solid rgba(255,255,255,0.12);
  font-size: 10.5px; line-height: 1.55; color: rgba(255,255,255,0.65);
  max-height: 220px; overflow-y: auto;
  background: rgba(0,0,0,0.15);
}
.sidebar-footer p { margin-bottom: 8px; }
.sidebar-footer a { color: var(--orange-200); text-decoration: underline; }
.sidebar-footer a:hover { color: #fff; }

/* ── Main ── */
.main { margin-left: var(--sidebar-w); min-height: 100vh; background: #FFFFFF; }
.module-page { display: none; }
.module-page.active { display: block; animation: fadeIn 0.4s ease; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }

/* Module banner — warm light, no gradient */
.module-banner {
  background: var(--orange-50);
  color: var(--gray-900);
  padding: 26px 36px 22px;
  border-bottom: 1px solid var(--orange-100);
  display: flex; align-items: center; gap: 18px; flex-wrap: wrap;
}
.module-banner .module-tag {
  display: inline-block; background: var(--orange-100); color: var(--orange-800);
  padding: 5px 12px; border-radius: 6px;
  font-size: 11px; font-weight: 700; letter-spacing: 0.6px; text-transform: uppercase;
  font-family: 'Figtree', sans-serif;
}
.module-banner h1 { font-family: 'Domine', serif; font-size: 24px; font-weight: 700; color: var(--gray-900); flex: 1; line-height: 1.22; letter-spacing: -.012em; }
.module-banner .time { font-size: 12.5px; color: var(--slate-500); font-weight: 500; }

/* ═══ Walkthrough Stage (light themed) ═══ */
.av-fullscreen {
  background: var(--gray-50);
  min-height: 580px;
  display: flex; flex-direction: column; position: relative;
  border-bottom: 1px solid var(--gray-200);
}
.av-stage {
  flex: 1; min-height: 540px;
  display: flex; align-items: center; justify-content: center;
  padding: 28px 32px 14px; position: relative;
}
.av-card {
  width: 100%; max-width: 1180px; min-height: 500px;
  background: #fff; color: var(--gray-700);
  border: 1px solid var(--gray-200);
  border-radius: 16px;
  box-shadow: var(--shadow-card);
  overflow: hidden; position: relative;
}
.av-slide {
  position: absolute; inset: 0;
  display: none; flex-direction: column;
  padding: 44px 56px; overflow-y: auto;
}
.av-slide.active { display: flex; animation: avFade 0.4s ease; }
@keyframes avFade { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }

.av-tag {
  display: inline-block; background: var(--orange-100); color: var(--orange-800);
  font-size: 11px; font-weight: 700; letter-spacing: 0.6px; text-transform: uppercase;
  padding: 5px 12px; border-radius: 6px; margin-bottom: 14px; align-self: flex-start;
  font-family: 'Figtree', sans-serif;
}
.av-slide h1 { font-family: 'Domine', serif; font-size: 36px; font-weight: 700; line-height: 1.15; color: var(--gray-900); margin-bottom: 14px; letter-spacing: -.018em; }
.av-slide h2 { font-family: 'Domine', serif; font-size: 26px; font-weight: 700; line-height: 1.2; color: var(--gray-900); margin-bottom: 12px; letter-spacing: -.012em; }
.av-slide h3 { font-family: 'Figtree', sans-serif; font-size: 16px; font-weight: 600; color: var(--orange-800); margin-bottom: 8px; }
.av-slide p { font-size: 15.5px; color: var(--gray-700); margin-bottom: 12px; line-height: 1.55; }
.av-slide p.lede { font-size: 17.5px; color: var(--gray-700); font-weight: 400; line-height: 1.5; }
.av-slide ul { list-style: none; padding: 0; margin: 0; }
.av-slide ul li { position: relative; padding: 7px 0 7px 22px; font-size: 15px; color: var(--gray-700); }
.av-slide ul li::before { content: ''; position: absolute; left: 4px; top: 16px; width: 6px; height: 6px; background: var(--orange-400); border-radius: 50%; }
.av-slide ul li strong { color: var(--gray-900); font-weight: 600; }

.av-slide.divider {
  background: var(--orange-50);
  color: var(--gray-900);
  align-items: flex-start; justify-content: center;
  border-left: 6px solid var(--orange-300);
}
.av-slide.divider h1 { font-family: 'Domine', serif; color: var(--gray-900); font-size: 40px; max-width: 820px; }
.av-slide.divider p { color: var(--gray-600); font-size: 17px; max-width: 700px; }
.av-slide.divider .module-num { font-family: 'Figtree', sans-serif; font-size: 12px; font-weight: 700; letter-spacing: 1.6px; text-transform: uppercase; color: var(--orange-700); margin-bottom: 16px; }
.av-slide.divider .duration { display: inline-block; background: var(--orange-100); color: var(--orange-800); padding: 5px 14px; border-radius: 6px; font-size: 12.5px; font-weight: 600; margin-top: 22px; }

.av-two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.av-three-col { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 14px; }
.av-four-col { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 12px; }
.av-card-tile {
  background: var(--orange-50);
  border: 1px solid var(--orange-100);
  border-radius: 12px;
  padding: 16px 18px;
  border-left: 4px solid var(--orange-400);
}
.av-card-tile h3 { font-family: 'Figtree', sans-serif; font-size: 15px; color: var(--gray-900); font-weight: 600; margin-bottom: 6px; }
.av-card-tile p { font-size: 13.5px; margin: 0; color: var(--gray-700); line-height: 1.5; }
.av-card-tile.rose { background: var(--orange-100); border-left-color: var(--orange-600); border-color: var(--orange-200); }
.av-card-tile.rose h3 { color: var(--orange-800); }
.av-card-tile.amber { background: var(--orange-50); border-left-color: var(--orange-500); border-color: var(--orange-200); }
.av-card-tile.amber h3 { color: var(--orange-800); }
.av-card-tile.green { background: var(--orange-50); border-left-color: var(--orange-300); border-color: var(--orange-100); }
.av-card-tile.green h3 { color: var(--orange-800); }
.av-card-tile.teal { background: var(--slate-50); border-left-color: var(--slate-400); border-color: var(--slate-200); }
.av-card-tile.teal h3 { color: var(--slate-800); }

.av-pill-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-top: 14px; }
.av-pill {
  background: var(--orange-100);
  color: var(--orange-800);
  border: 1px solid var(--orange-200);
  border-radius: 10px; padding: 14px 12px; text-align: center;
  font-family: 'Figtree', sans-serif;
  font-size: 12.5px; font-weight: 600; line-height: 1.3;
  display: flex; align-items: center; justify-content: center; min-height: 64px;
}
.av-quote {
  border-left: 4px solid var(--orange-400); padding: 14px 22px; margin: 14px 0;
  font-size: 17px; font-style: italic; color: var(--gray-700);
  background: var(--orange-50); border-radius: 0 var(--radius) var(--radius) 0;
}
.av-quote .attrib { display: block; margin-top: 8px; font-style: normal; font-size: 12px; color: var(--orange-700); font-weight: 700; letter-spacing: 0.6px; text-transform: uppercase; }

/* Walkthrough nav arrows */
.av-arrow {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 42px; height: 42px; border-radius: 50%;
  background: rgba(255,255,255,0.9); color: var(--gray-900);
  border: 1px solid var(--gray-200);
  font-size: 22px; cursor: pointer; opacity: 0; transition: opacity 0.2s, background 0.2s;
  z-index: 10; font-family: inherit;
  box-shadow: var(--shadow-card);
}
.av-stage:hover .av-arrow { opacity: 0.95; }
.av-arrow:hover { background: var(--orange-100); color: var(--orange-800); opacity: 1 !important; }
.av-arrow:disabled { opacity: 0.2 !important; cursor: not-allowed; }
.av-arrow.prev { left: 48px; }
.av-arrow.next { right: 48px; }

.av-controls {
  background: #FFFFFF;
  border-top: 1px solid var(--gray-200);
  padding: 14px 36px; color: var(--gray-700);
  display: flex; align-items: center; gap: 14px;
}
.av-nav-btn {
  background: var(--gray-100); border: 1px solid var(--gray-200);
  color: var(--slate-700); width: 36px; height: 36px; border-radius: 50%; cursor: pointer;
  font-size: 16px; flex-shrink: 0; font-family: inherit; transition: all 0.15s;
}
.av-nav-btn:hover:not(:disabled) { background: var(--orange-100); color: var(--orange-700); }
.av-nav-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.av-progress-wrap { flex: 1; min-width: 0; }
.av-progress-label { font-size: 12.5px; color: var(--slate-600); font-weight: 500; }
.av-counter { font-size: 12.5px; color: var(--slate-600); min-width: 70px; text-align: right; font-variant-numeric: tabular-nums; font-weight: 500; }
.av-toggle-btn {
  background: #FFFFFF; border: 1px solid var(--gray-300);
  color: var(--slate-700); padding: 7px 14px; border-radius: 8px; font-size: 12px; cursor: pointer;
  font-family: 'Figtree', sans-serif; font-weight: 600; transition: all 0.15s; flex-shrink: 0;
}
.av-toggle-btn:hover { background: var(--orange-50); border-color: var(--orange-300); color: var(--orange-800); }
.av-toggle-btn.active { background: var(--orange-300); border-color: var(--orange-300); color: var(--gray-900); }

.av-transcript {
  background: var(--orange-50); color: var(--gray-700);
  border-top: 1px solid var(--orange-100);
  max-height: 0; overflow: hidden;
  transition: max-height 0.35s ease;
}
.av-transcript.open { max-height: 320px; overflow-y: auto; }
.av-transcript-inner { padding: 22px 36px; font-size: 15px; line-height: 1.7; color: var(--gray-700); }
.av-transcript-inner h4 {
  font-family: 'Figtree', sans-serif;
  font-size: 11px; letter-spacing: 1.2px; text-transform: uppercase;
  color: var(--orange-700); margin-bottom: 10px; font-weight: 700;
  display: flex; justify-content: space-between; align-items: center;
}
.av-transcript-inner button.close {
  background: none; border: none; color: var(--slate-500); cursor: pointer; font-size: 18px;
  padding: 0 4px; font-family: inherit;
}
.av-transcript-inner button.close:hover { color: var(--orange-700); }

/* Dive deeper */
.dive-deeper {
  background: var(--orange-100);
  color: var(--orange-800);
  padding: 18px 32px 22px; text-align: center;
  border-bottom: 1px solid var(--orange-200);
}
.dive-deeper .label {
  font-family: 'Figtree', sans-serif;
  font-size: 12.5px; font-weight: 700; letter-spacing: 1.2px; text-transform: uppercase;
  display: inline-flex; align-items: center; gap: 10px;
}
.dive-deeper .arrow {
  display: inline-block; font-size: 18px;
  animation: diveBounce 1.6s ease-in-out infinite;
}
@keyframes diveBounce { 0%,100% { transform: translateY(0); } 50% { transform: translateY(4px); } }

/* Static section */
.static-section { padding: 48px 48px 80px; max-width: 920px; margin: 0 auto; }
.static-section h2 { font-family: 'Domine', serif; font-size: 22px; color: var(--gray-900); margin: 32px 0 14px; font-weight: 700; letter-spacing: -.012em; }
.static-section h2:first-child { margin-top: 0; }
.static-section h3 { font-family: 'Domine', serif; font-size: 18px; color: var(--gray-900); margin: 22px 0 10px; font-weight: 700; letter-spacing: -.005em; }
.static-section p { font-size: 15.5px; color: var(--gray-700); margin-bottom: 16px; line-height: 1.6; }
.static-section ul { margin: 10px 0 16px 22px; padding-left: 0; }
.static-section ol { margin: 10px 0 16px 22px; padding-left: 12px; }
.static-section li { margin-bottom: 6px; font-size: 15px; color: var(--gray-700); line-height: 1.55; }
.static-section strong { color: var(--gray-900); font-weight: 600; }
.static-section em { color: var(--gray-700); }

.section-intro {
  background: var(--orange-50); border: 1px solid var(--orange-100); border-radius: 12px;
  padding: 20px 26px; margin-bottom: 28px;
  border-left: 4px solid var(--orange-300);
}
.section-intro h2 { margin: 0 0 6px; font-size: 18px; color: var(--gray-900); }
.section-intro p { font-size: 14px; color: var(--gray-600); margin: 0; line-height: 1.55; }

/* Info boxes / reflections (callouts) */
.info-box { border-radius: 0 var(--radius) var(--radius) 0; padding: 20px 24px; margin: 18px 0; border-left: 4px solid; }
.info-box.amber { background: var(--orange-50); border-color: var(--orange-500); }
.info-box.rose { background: var(--orange-100); border-color: var(--orange-600); }
.info-box.green { background: var(--orange-50); border-color: var(--orange-300); }
.info-box.maroon { background: var(--orange-50); border-color: var(--orange-400); }
.info-box.teal { background: var(--slate-50); border-color: var(--slate-400); }
.info-box h4 { font-family: 'Figtree', sans-serif; color: var(--gray-900); font-size: 16px; margin-bottom: 8px; font-weight: 600; }
.info-box.amber h4, .info-box.rose h4, .info-box.green h4, .info-box.maroon h4 { color: var(--orange-800); }
.info-box.teal h4 { color: var(--slate-800); }
.info-box .prompt-text { color: var(--gray-700); font-size: 14.5px; line-height: 1.6; margin: 0 0 12px; }
.info-box p { color: var(--gray-700); font-size: 14.5px; line-height: 1.6; margin-bottom: 10px; }
.info-box p:last-child { margin-bottom: 0; }
.info-box textarea {
  width: 100%; min-height: 90px; padding: 11px 14px; border: 1.5px solid var(--gray-300);
  border-radius: var(--radius-sm); font-family: 'Figtree', sans-serif; font-size: 14.5px; line-height: 1.55;
  resize: vertical; background: #fff; color: var(--gray-900);
  transition: border .15s, box-shadow .15s;
}
.info-box textarea:focus { outline: none; border-color: var(--orange-400); box-shadow: 0 0 0 3px var(--orange-100); }
.info-box textarea:disabled { background: var(--gray-50); color: var(--slate-500); }
.opening-actions { margin-top: 12px; display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }

/* Buttons */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  padding: 11px 20px; border-radius: var(--radius);
  font-weight: 600; font-size: 14.5px; cursor: pointer; border: none;
  transition: all 0.15s; font-family: 'Figtree', sans-serif;
}
.btn-primary { background: var(--orange-300); color: var(--gray-900); }
.btn-primary:hover:not(:disabled) { background: var(--orange-400); }
.btn-primary.not-yet { background: var(--orange-100); color: var(--orange-800); border: 1px solid var(--orange-200); }
.btn-primary.not-yet:hover { background: var(--orange-200); }
.btn-primary.disabled, .btn-primary:disabled { opacity: 0.5; cursor: not-allowed; }
.btn-secondary { background: #FFFFFF; color: var(--slate-700); border: 1.5px solid var(--gray-300); }
.btn-secondary:hover { background: var(--orange-50); border-color: var(--orange-300); color: var(--gray-900); }
.btn-success { background: var(--orange-300); color: var(--gray-900); }
.btn-success:hover:not(:disabled) { background: var(--orange-400); }
.btn-success.disabled, .btn-success:disabled { opacity: 0.5; cursor: not-allowed; }
.opening-status { font-size: 12.5px; color: var(--slate-500); margin: 0; }
.opening-status .pending { color: var(--slate-500); }
.opening-status .submitted, .opening-status .done { color: var(--orange-700); font-weight: 600; }

/* Flip cards */
.flip-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin: 14px 0 20px; }
.flip-card { perspective: 1000px; height: 120px; cursor: pointer; }
.flip-card-inner { position: relative; width: 100%; height: 100%; transition: transform 0.6s; transform-style: preserve-3d; }
.flip-card.flipped .flip-card-inner { transform: rotateY(180deg); }
.flip-card-front, .flip-card-back {
  position: absolute; inset: 0; backface-visibility: hidden;
  border-radius: 12px; padding: 14px; display: flex; align-items: center; justify-content: center;
  text-align: center; font-size: 13.5px; font-weight: 600;
  font-family: 'Figtree', sans-serif;
}
.flip-card-front { background: var(--orange-300); color: var(--gray-900); }
.flip-card-back { background: #FFFFFF; border: 1px solid var(--gray-200); color: var(--gray-700); transform: rotateY(180deg); font-weight: 400; font-size: 12.5px; line-height: 1.5; padding: 14px; }

/* Tabs */
.tabs { margin: 18px 0; }
.tab-buttons { display: flex; gap: 4px; flex-wrap: wrap; margin-bottom: -1px; padding: 0 6px 0; position: relative; z-index: 2; }
.tab-btn {
  padding: 10px 16px; background: var(--gray-100); color: var(--slate-600);
  border: 1px solid var(--gray-200); border-bottom: none;
  border-radius: 10px 10px 0 0; cursor: pointer;
  font-size: 13px; font-family: 'Figtree', sans-serif; font-weight: 600;
  transition: all 0.15s; position: relative;
}
.tab-btn:hover:not(.active) { background: var(--orange-50); color: var(--orange-800); }
.tab-btn.active { background: #fff; border-color: var(--gray-200); border-top: 4px solid var(--orange-400); padding-top: 8px; color: var(--gray-900); z-index: 3; }
.tab-panel { display: none; background: #fff; border: 1px solid var(--gray-200); border-radius: 0 10px 10px 10px; padding: 22px 24px; }
.tab-panel.active { display: block; }
.tab-panel p { font-size: 14.5px; color: var(--gray-700); }
.tab-panel h4 { font-family: 'Figtree', sans-serif; font-size: 15.5px; color: var(--gray-900); margin-bottom: 10px; font-weight: 600; }

/* Accordion */
.accordion-item { border: 1px solid var(--gray-200); border-radius: var(--radius); margin-bottom: 8px; overflow: hidden; background: #FFFFFF; }
.accordion-header { padding: 14px 18px; background: var(--orange-50); cursor: pointer; font-family: 'Figtree', sans-serif; font-weight: 600; color: var(--gray-900); font-size: 14.5px; display: flex; justify-content: space-between; align-items: center; }
.accordion-header:hover { background: var(--orange-100); }
.accordion-body { max-height: 0; overflow: hidden; transition: max-height 0.35s ease; }
.accordion-body-inner { padding: 16px 20px; font-size: 14.5px; color: var(--gray-700); line-height: 1.55; }
.accordion-item.open .arrow { transform: rotate(180deg); }
.accordion .arrow { transition: transform 0.2s; font-size: 11px; color: var(--orange-700); }

/* Pathway diagram */
.pathway-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin: 18px 0 28px; }
.pathway-card { background: #FFFFFF; border: 1px solid var(--gray-200); border-radius: 14px; padding: 18px 20px; border-top: 4px solid var(--orange-400); }
.pathway-card .pnum { font-family: 'Figtree', sans-serif; font-size: 11px; font-weight: 700; color: var(--orange-700); letter-spacing: 1px; text-transform: uppercase; margin-bottom: 6px; }
.pathway-card h4 { font-family: 'Figtree', sans-serif; font-size: 15.5px; color: var(--gray-900); margin-bottom: 8px; font-weight: 600; }
.pathway-card p { font-size: 13.5px; line-height: 1.55; margin-bottom: 0; color: var(--gray-700); }
.pathway-card.signposting { border-top-color: var(--orange-300); }
.pathway-card.direct { border-top-color: var(--slate-400); }
.pathway-card.direct .pnum { color: var(--slate-600); }
.pathway-card.linkworker { border-top-color: var(--orange-500); }

/* Resource link */
.resource-link { background: var(--gray-50); border: 1px solid var(--gray-200); border-radius: 10px; padding: 14px 18px; margin: 10px 0; display: flex; gap: 14px; align-items: flex-start; }
.rl-icon { width: 36px; height: 36px; background: var(--orange-300); color: var(--gray-900); border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 18px; flex-shrink: 0; font-weight: 700; }
.rl-body { flex: 1; }
.rl-hook { font-family: 'Figtree', sans-serif; font-weight: 700; color: var(--gray-900); font-size: 14.5px; margin-bottom: 4px; }
.rl-desc { font-size: 13.5px; color: var(--gray-600); margin: 0; line-height: 1.5; }

/* Takeaways */
.takeaways { background: var(--orange-50); border: 1px solid var(--orange-100); border-radius: 12px; padding: 22px 26px; margin: 28px 0; }
.takeaways h3 { font-family: 'Domine', serif; color: var(--gray-900); margin: 0 0 12px; font-size: 18px; font-weight: 700; }
.takeaways ul { margin: 0 0 0 22px; }
.takeaways li { margin-bottom: 6px; color: var(--gray-700); }

/* Quiz */
.quiz { background: #FFFFFF; border: 1px solid var(--gray-200); border-radius: 14px; margin: 28px 0; overflow: hidden; }
.quiz-header { background: var(--orange-100); color: var(--orange-800); padding: 14px 24px; font-family: 'Figtree', sans-serif; font-weight: 700; font-size: 14.5px; }
.quiz-body { padding: 22px 26px; }
.quiz-question { margin-bottom: 22px; padding-bottom: 22px; border-bottom: 1px solid var(--gray-200); }
.quiz-question:last-of-type { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
.quiz-question p { font-family: 'Figtree', sans-serif; font-weight: 600; color: var(--gray-900); margin-bottom: 12px; font-size: 15px; }
.quiz-option { display: block; padding: 10px 14px; margin-bottom: 8px; cursor: pointer; border: 1.5px solid var(--gray-200); border-radius: var(--radius-sm); font-size: 14px; transition: all 0.15s; background: #fff; color: var(--gray-700); }
.quiz-option:hover { background: var(--orange-50); border-color: var(--orange-300); }
.quiz-option input { margin-right: 10px; }
.quiz-option.correct { background: var(--orange-50); border-color: var(--orange-400); color: var(--orange-800); }
.quiz-option.incorrect { background: var(--orange-100); border-color: var(--orange-600); color: var(--orange-800); }
.quiz-explanation { display: none; margin-top: 10px; padding: 12px 14px; background: var(--orange-50); border: 1px solid var(--orange-100); border-radius: var(--radius-sm); font-size: 13px; color: var(--gray-700); line-height: 1.5; }
.quiz-question.checked .quiz-explanation, .quiz-explanation.show { display: block; }
.quiz-actions { display: flex; gap: 12px; align-items: center; margin-top: 14px; flex-wrap: wrap; }
.quiz-result { margin-top: 14px; padding: 14px 18px; border-radius: var(--radius); font-weight: 600; display: none; font-family: 'Figtree', sans-serif; }
.quiz-result.pass { display: block; background: var(--orange-50); color: var(--orange-800); border: 1px solid var(--orange-200); }
.quiz-result.fail { display: block; background: var(--orange-100); color: var(--orange-800); border: 1px solid var(--orange-200); }
.quiz-retry { display: none; }
.quiz-retry.show { display: inline-block; }

/* Module nav */
.module-nav { margin: 36px 0 0; padding-top: 24px; border-top: 1px solid var(--gray-200); display: flex; justify-content: flex-end; }
.requirement-note { font-size: 12px; color: var(--slate-500); margin: 8px 0 0; text-align: right; }
.req-pending { color: var(--orange-700); }
.req-met, .req-check { color: var(--orange-700); font-weight: 600; }

/* Welcome (light) */
.welcome-hero {
  min-height: 100vh; display: flex; flex-direction: column; align-items: center; justify-content: center;
  background: var(--orange-50);
  color: var(--gray-900); text-align: center; padding: 60px 32px; position: relative;
}
.welcome-hero .brand-line { font-family: 'Figtree', sans-serif; font-size: 12px; letter-spacing: 2.4px; color: var(--orange-700); text-transform: uppercase; margin-bottom: 20px; font-weight: 700; }
.welcome-hero h1 { font-family: 'Domine', serif; font-size: 44px; font-weight: 700; margin-bottom: 14px; line-height: 1.15; max-width: 820px; color: var(--gray-900); letter-spacing: -.018em; }
.welcome-hero .subtitle { font-size: 18px; color: var(--gray-600); margin-bottom: 32px; max-width: 640px; line-height: 1.5; }
.welcome-hero .start-btn {
  background: var(--orange-300); color: var(--gray-900); padding: 14px 32px; border-radius: 30px;
  font-size: 16px; font-weight: 700; border: none; cursor: pointer;
  transition: all 0.2s; font-family: 'Figtree', sans-serif;
  box-shadow: var(--shadow-card);
}
.welcome-hero .start-btn:hover { background: var(--orange-400); transform: translateY(-1px); box-shadow: var(--shadow-lg); }
.welcome-hero .pitch {
  margin-top: 36px; max-width: 700px; background: #FFFFFF;
  border: 1px solid var(--orange-200); border-radius: 14px; padding: 28px 32px;
  text-align: left; font-size: 14.5px; line-height: 1.65; color: var(--gray-700);
  box-shadow: var(--shadow-card);
}
.welcome-hero .pitch h3 { font-family: 'Figtree', sans-serif; font-size: 12px; letter-spacing: 1.4px; color: var(--orange-700); margin-bottom: 14px; text-transform: uppercase; text-align: center; font-weight: 700; }
.welcome-hero .pitch p { margin-bottom: 14px; }
.welcome-hero .pitch p:last-child { margin-bottom: 0; }

/* Outcome cards */
.outcome-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin: 16px 0 24px; }
.outcome-card { padding: 14px 16px; border-radius: 12px; background: #FFFFFF; border: 1px solid var(--gray-200); border-top: 4px solid var(--orange-400); }
.outcome-card h4 { font-family: 'Figtree', sans-serif; font-size: 14px; color: var(--gray-900); margin-bottom: 6px; font-weight: 600; }
.outcome-card p { font-size: 12.5px; line-height: 1.5; margin: 0; color: var(--gray-700); }
.outcome-card.process { border-top-color: var(--orange-400); }
.outcome-card.mental { border-top-color: var(--orange-500); }
.outcome-card.physical { border-top-color: var(--slate-400); }
.outcome-card.social { border-top-color: var(--orange-300); }
.outcome-card.system { border-top-color: var(--orange-600); }
.outcome-card.community { border-top-color: var(--orange-700); }

/* Case study card */
.case-study {
  background: var(--orange-50);
  border: 1px solid var(--orange-200);
  border-left: 6px solid var(--orange-400);
  color: var(--gray-900);
  border-radius: 14px; padding: 26px 30px; margin: 24px 0;
}
.case-study .cs-tag { display: inline-block; background: var(--orange-300); color: var(--gray-900); padding: 4px 12px; border-radius: 6px; font-family: 'Figtree', sans-serif; font-size: 11px; font-weight: 700; letter-spacing: 0.8px; text-transform: uppercase; margin-bottom: 12px; }
.case-study h3 { font-family: 'Domine', serif; color: var(--gray-900); font-size: 22px; margin-bottom: 14px; font-weight: 700; letter-spacing: -.01em; }
.case-study p { color: var(--gray-700); font-size: 14.5px; line-height: 1.6; margin-bottom: 12px; }
.case-study p:last-child { margin-bottom: 0; }

/* Certificate */
.certificate {
  display: none; background: #FFFFFF; border: 3px double var(--orange-400);
  padding: 60px 48px; margin: 28px 0; text-align: center; border-radius: 14px;
  box-shadow: var(--shadow-lg);
}
.certificate h2 { font-family: 'Domine', serif; font-size: 32px; color: var(--gray-900); margin-bottom: 8px; font-weight: 700; }
.certificate .cert-line { width: 80px; height: 2px; background: var(--orange-400); margin: 12px auto; }
.certificate p { font-size: 15px; color: var(--gray-700); margin-bottom: 8px; }
.certificate .cert-name { font-family: 'Domine', serif; font-size: 28px; color: var(--orange-800); font-weight: 700; margin: 18px 0; }
.certificate .cert-brand { font-family: 'Figtree', sans-serif; font-size: 12px; letter-spacing: 2.4px; text-transform: uppercase; color: var(--orange-700); margin-bottom: 18px; font-weight: 700; }

/* Mobile */
.mobile-toggle {
  display: none; position: fixed; top: 12px; left: 12px; z-index: 110;
  background: var(--orange-300); color: var(--gray-900); border: none;
  width: 40px; height: 40px; border-radius: 10px; font-size: 18px; cursor: pointer;
  box-shadow: var(--shadow-card);
}
@media (max-width: 1100px) {
  .av-pill-grid { grid-template-columns: repeat(2, 1fr); }
  .av-three-col, .av-four-col, .pathway-grid, .outcome-grid { grid-template-columns: 1fr 1fr; }
  .av-slide { padding: 32px 32px; }
  .av-slide h1 { font-size: 28px; }
  .av-slide h2 { font-size: 22px; }
  .av-slide.divider h1 { font-size: 30px; }
  .av-slide p, .av-slide ul li { font-size: 15px; }
  .flip-grid { grid-template-columns: repeat(2, 1fr); }
  .av-arrow.prev { left: 16px; } .av-arrow.next { right: 16px; }
  .av-two-col { grid-template-columns: 1fr; }
}
@media (max-width: 900px) {
  .sidebar { transform: translateX(-100%); }
  .sidebar.open { transform: translateX(0); }
  .main { margin-left: 0; }
  .static-section { padding: 32px 20px 60px; }
  .module-banner { padding: 18px 22px; }
  .module-banner h1 { font-size: 19px; }
  .av-controls { padding: 10px 18px; gap: 10px; }
  .mobile-toggle { display: flex; align-items: center; justify-content: center; }
  .av-fullscreen { min-height: 460px; }
  .outcome-grid, .pathway-grid { grid-template-columns: 1fr; }
  .welcome-hero h1 { font-size: 30px; }
}

/* ============================================================
   Course extras — differentiated callout palette
   ============================================================ */
:root{
  --blue-50:#EFF6FF;   --blue-100:#DBEAFE;   --blue-200:#BFDBFE;
  --blue-300:#93C5FD;  --blue-400:#60A5FA;   --blue-500:#3B82F6;
  --blue-600:#2563EB;  --blue-700:#1D4ED8;   --blue-800:#1E40AF; --blue-900:#1E3A8A;

  --purple-50:#FAF5FF; --purple-100:#F3E8FF; --purple-200:#E9D5FF;
  --purple-300:#D8B4FE;--purple-400:#C084FC; --purple-500:#A855F7;
  --purple-600:#9333EA;--purple-700:#7E22CE; --purple-800:#6B21A8;

  --green-50:#F0FDF4;  --green-100:#DCFCE7;  --green-200:#BBF7D0;
  --green-300:#86EFAC; --green-400:#4ADE80;  --green-500:#22C55E;
  --green-600:#16A34A; --green-700:#15803D;  --green-800:#166534;

  --amber-deep-50:#FFFBEB; --amber-deep-100:#FEF3C7; --amber-deep-200:#FDE68A;
  --amber-deep-300:#FCD34D; --amber-deep-400:#FBBF24; --amber-deep-500:#F59E0B;
  --amber-deep-600:#D97706; --amber-deep-700:#B45309; --amber-deep-800:#92400E;
}

.objectives-box {
  background: var(--forest-50);
  border: 1px solid var(--forest-100);
  border-left: 4px solid var(--forest-600);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 22px 26px;
  margin: 18px 0 26px;
}
.objectives-box h4 {
  font-family: 'Figtree', sans-serif;
  font-size: 11.5px; letter-spacing: 1.4px; text-transform: uppercase;
  color: var(--forest-800); margin-bottom: 12px; font-weight: 700;
  display: flex; align-items: center; gap: 8px;
}
.objectives-box h4::before { content: '◎'; color: var(--forest-600); font-size: 14px; }
.objectives-box ul { margin: 0 0 0 22px; }
.objectives-box li { color: var(--gray-800); margin-bottom: 6px; font-size: 14.5px; line-height: 1.55; }
.objectives-box li strong { color: var(--forest-900); }

.guideline-box {
  background: var(--orange-100);
  border: 1px solid var(--orange-200);
  border-left: 6px solid var(--orange-600);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 22px 26px;
  margin: 22px 0;
  color: var(--gray-900);
}
.guideline-box .gl-tag {
  display: inline-block; background: var(--orange-600); color: #fff;
  font-family: 'Figtree', sans-serif;
  font-size: 10.5px; letter-spacing: 1.2px; text-transform: uppercase;
  font-weight: 700; padding: 4px 10px; border-radius: 5px; margin-bottom: 10px;
}
.guideline-box .gl-text {
  font-family: 'Domine', serif; font-size: 18.5px; font-weight: 600;
  color: var(--orange-900); line-height: 1.4; margin: 0 0 10px;
}
.guideline-box .gl-text::before { content: '\201C'; color: var(--orange-500); margin-right: 4px; }
.guideline-box .gl-text::after  { content: '\201D'; color: var(--orange-500); margin-left: 4px; }
.guideline-box .gl-link {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: 'Figtree', sans-serif; font-size: 13px; font-weight: 600;
  color: var(--orange-800); text-decoration: none; margin-top: 4px;
}
.guideline-box .gl-link:hover { color: var(--orange-900); text-decoration: underline; }
.guideline-box .gl-link::after { content: '\2192'; transition: transform 0.15s; }
.guideline-box .gl-link:hover::after { transform: translateX(3px); }

.brief-box {
  background: var(--amber-deep-50);
  border: 1px solid var(--amber-deep-200);
  border-left: 4px solid var(--amber-deep-500);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 18px 22px;
  margin: 18px 0;
}
.brief-box .brief-tag {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: 'Figtree', sans-serif;
  font-size: 10.5px; letter-spacing: 1.4px; text-transform: uppercase;
  color: var(--amber-deep-700); font-weight: 700; margin-bottom: 8px;
}
.brief-box h4 {
  font-family: 'Figtree', sans-serif; font-size: 15.5px; color: var(--gray-900);
  font-weight: 600; margin: 0 0 6px;
}
.brief-box p { font-size: 13.5px; color: var(--gray-700); line-height: 1.55; margin: 0 0 8px; }
.brief-box ul { margin: 4px 0 0 20px; }
.brief-box li { font-size: 13.5px; line-height: 1.55; margin-bottom: 4px; }
.brief-box a {
  color: var(--amber-deep-700); font-weight: 600; text-decoration: none;
  border-bottom: 1px dotted var(--amber-deep-400);
}
.brief-box a:hover { color: var(--amber-deep-800); border-bottom-color: var(--amber-deep-600); }

.evidence-box {
  background: var(--amber-deep-50);
  border: 1px solid var(--amber-deep-200);
  border-left: 4px solid var(--amber-deep-500);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 18px 22px;
  margin: 18px 0;
}
.evidence-box .ev-tag {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: 'Figtree', sans-serif;
  font-size: 10.5px; letter-spacing: 1.4px; text-transform: uppercase;
  color: var(--amber-deep-700); font-weight: 700; margin-bottom: 8px;
}
.evidence-box h4 {
  font-family: 'Figtree', sans-serif; font-size: 15.5px; color: var(--gray-900);
  font-weight: 600; margin: 0 0 8px;
}
.evidence-box p { font-size: 13.5px; color: var(--gray-700); line-height: 1.55; margin: 0 0 6px; }
.evidence-box .ev-cite {
  display: block; margin-top: 8px; font-size: 12.5px;
  color: var(--amber-deep-800); font-weight: 600; font-style: italic;
}
.evidence-box .ev-cite a { color: var(--amber-deep-800); text-decoration: underline dotted; }
.evidence-box .ev-cite a:hover { color: var(--amber-deep-700); }

.cite {
  display: inline; color: var(--orange-700); text-decoration: none;
  border-bottom: 1px dotted var(--orange-400);
  font-size: 0.95em;
}
.cite:hover { color: var(--orange-800); border-bottom-color: var(--orange-700); }

.takeaways-green {
  background: var(--forest-50);
  border: 1px solid var(--forest-200);
  border-left: 6px solid var(--forest-600);
  border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
  padding: 24px 28px;
  margin: 30px 0;
}
.takeaways-green h3 {
  font-family: 'Domine', serif; color: var(--forest-800);
  margin: 0 0 14px; font-size: 19px; font-weight: 700;
  display: flex; align-items: center; gap: 10px;
}
.takeaways-green h3::before { content: '\2713'; color: var(--forest-600); font-size: 22px; }
.takeaways-green ul { margin: 0 0 0 22px; }
.takeaways-green li { margin-bottom: 6px; color: var(--gray-800); }
.takeaways-green li strong { color: var(--forest-800); }

.next-up {
  background: var(--slate-50);
  border: 1px solid var(--slate-200);
  border-left: 4px solid var(--slate-400);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 16px 22px;
  margin: 24px 0;
  font-size: 14.5px; color: var(--slate-700); line-height: 1.55;
}
.next-up strong { color: var(--slate-900); }
.next-up .next-tag {
  font-family: 'Figtree', sans-serif;
  font-size: 10.5px; letter-spacing: 1.4px; text-transform: uppercase;
  color: var(--slate-600); font-weight: 700; display: block; margin-bottom: 4px;
}

.case-study .cs-loc {
  display: inline-block; font-family: 'Figtree', sans-serif;
  font-size: 11.5px; color: var(--orange-700); font-weight: 600;
  margin-bottom: 6px;
}
.case-study .cs-link {
  display: inline-block; margin-top: 10px;
  font-family: 'Figtree', sans-serif; font-size: 13px; font-weight: 600;
  color: var(--orange-700); text-decoration: none;
}
.case-study .cs-link::after { content: ' \2192'; transition: transform 0.15s; display: inline-block; }
.case-study .cs-link:hover { color: var(--orange-900); }
.case-study .cs-link:hover::after { transform: translateX(3px); }

.sidebar-header.wheel .sidebar-logo {
  width: 100px;
  height: 100px;
  max-width: 100px;
  background: #fff;
  border-radius: 50%;
  padding: 16px;
  margin: 0 auto 14px;
  opacity: 1;
  box-shadow: 0 2px 8px rgba(0,0,0,0.12);
  box-sizing: border-box;
  object-fit: contain;
}

.figure {
  margin: 26px 0;
  background: #fff;
  border: 1px solid var(--gray-200);
  border-radius: 14px;
  padding: 22px 24px;
  box-shadow: var(--shadow-card);
}
.figure svg { display: block; width: 100%; height: auto; }
.figure .fig-caption {
  margin-top: 12px; font-size: 13px; color: var(--slate-600);
  font-family: 'Figtree', sans-serif; text-align: center; line-height: 1.5;
}
.figure .fig-caption strong { color: var(--gray-900); }

a.nav-item { text-decoration: none; }
a.nav-item, a.nav-item:visited { color: rgba(255,255,255,0.78); }
a.nav-item.active { color: #fff; }
a.nav-item.completed { color: #fff; }

.av-card-tile.blue { background: var(--blue-50); border-left-color: var(--blue-500); border-color: var(--blue-100); }
.av-card-tile.blue h3 { color: var(--blue-800); }
.av-card-tile.purple { background: var(--forest-50); border-left-color: var(--forest-600); border-color: var(--forest-200); }
.av-card-tile.purple h3 { color: var(--forest-800); }

/* ============================================================
   Course extras — differentiated callout palette
   New accent tokens that complement the existing orange/slate
   scheme and give different learning-architecture elements
   distinct visual identity.
   ============================================================ */
:root{
  --blue-50:#EFF6FF;   --blue-100:#DBEAFE;   --blue-200:#BFDBFE;
  --blue-300:#93C5FD;  --blue-400:#60A5FA;   --blue-500:#3B82F6;
  --blue-600:#2563EB;  --blue-700:#1D4ED8;   --blue-800:#1E40AF; --blue-900:#1E3A8A;

  --purple-50:#FAF5FF; --purple-100:#F3E8FF; --purple-200:#E9D5FF;
  --purple-300:#D8B4FE;--purple-400:#C084FC; --purple-500:#A855F7;
  --purple-600:#9333EA;--purple-700:#7E22CE; --purple-800:#6B21A8;

  --green-50:#F0FDF4;  --green-100:#DCFCE7;  --green-200:#BBF7D0;
  --green-300:#86EFAC; --green-400:#4ADE80;  --green-500:#22C55E;
  --green-600:#16A34A; --green-700:#15803D;  --green-800:#166534;

  --amber-deep-50:#FFFBEB; --amber-deep-100:#FEF3C7; --amber-deep-200:#FDE68A;
  --amber-deep-300:#FCD34D; --amber-deep-400:#FBBF24; --amber-deep-500:#F59E0B;
  --amber-deep-600:#D97706; --amber-deep-700:#B45309; --amber-deep-800:#92400E;
}

/* Learning objectives — cool slate/blue for "what you'll learn" */
.objectives-box {
  background: var(--forest-50);
  border: 1px solid var(--forest-100);
  border-left: 4px solid var(--forest-600);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 22px 26px;
  margin: 18px 0 26px;
}
.objectives-box h4 {
  font-family: 'Figtree', sans-serif;
  font-size: 11.5px; letter-spacing: 1.4px; text-transform: uppercase;
  color: var(--forest-800); margin-bottom: 12px; font-weight: 700;
  display: flex; align-items: center; gap: 8px;
}
.objectives-box h4::before { content: '◎'; color: var(--forest-600); font-size: 14px; }
.objectives-box ul { margin: 0 0 0 22px; }
.objectives-box li { color: var(--gray-800); margin-bottom: 6px; font-size: 14.5px; line-height: 1.55; }
.objectives-box li strong { color: var(--forest-900); }

/* Guideline anchor box — strong orange, for the actual recommendation text */
.guideline-box {
  background: var(--orange-100);
  border: 1px solid var(--orange-200);
  border-left: 6px solid var(--orange-600);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 22px 26px;
  margin: 22px 0;
  color: var(--gray-900);
}
.guideline-box .gl-tag {
  display: inline-block; background: var(--orange-600); color: #fff;
  font-family: 'Figtree', sans-serif;
  font-size: 10.5px; letter-spacing: 1.2px; text-transform: uppercase;
  font-weight: 700; padding: 4px 10px; border-radius: 5px; margin-bottom: 10px;
}
.guideline-box .gl-text {
  font-family: 'Domine', serif; font-size: 18.5px; font-weight: 600;
  color: var(--orange-900); line-height: 1.4; margin: 0 0 10px;
}
.guideline-box .gl-text::before { content: '“'; color: var(--orange-500); margin-right: 4px; }
.guideline-box .gl-text::after  { content: '”'; color: var(--orange-500); margin-left: 4px; }
.guideline-box .gl-link {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: 'Figtree', sans-serif; font-size: 13px; font-weight: 600;
  color: var(--orange-800); text-decoration: none; margin-top: 4px;
}
.guideline-box .gl-link:hover { color: var(--orange-900); text-decoration: underline; }
.guideline-box .gl-link::after { content: '→'; transition: transform 0.15s; }
.guideline-box .gl-link:hover::after { transform: translateX(3px); }

/* Evidence brief callout — purple/violet for "learn more from SHC" */
.brief-box {
  background: var(--amber-deep-50);
  border: 1px solid var(--amber-deep-200);
  border-left: 4px solid var(--amber-deep-500);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 18px 22px;
  margin: 18px 0;
}
.brief-box .brief-tag {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: 'Figtree', sans-serif;
  font-size: 10.5px; letter-spacing: 1.4px; text-transform: uppercase;
  color: var(--amber-deep-700); font-weight: 700; margin-bottom: 8px;
}
.brief-box .brief-tag::before { content: '📑'; }
.brief-box h4 {
  font-family: 'Figtree', sans-serif; font-size: 15.5px; color: var(--gray-900);
  font-weight: 600; margin: 0 0 6px;
}
.brief-box p { font-size: 13.5px; color: var(--gray-700); line-height: 1.55; margin: 0 0 8px; }
.brief-box ul { margin: 4px 0 0 20px; }
.brief-box li { font-size: 13.5px; line-height: 1.55; margin-bottom: 4px; }
.brief-box a {
  color: var(--amber-deep-700); font-weight: 600; text-decoration: none;
  border-bottom: 1px dotted var(--amber-deep-400);
}
.brief-box a:hover { color: var(--amber-deep-800); border-bottom-color: var(--amber-deep-600); }

/* "How we know" research callout — warm amber, for foundational studies */
.evidence-box {
  background: var(--amber-deep-50);
  border: 1px solid var(--amber-deep-200);
  border-left: 4px solid var(--amber-deep-500);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 18px 22px;
  margin: 18px 0;
}
.evidence-box .ev-tag {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: 'Figtree', sans-serif;
  font-size: 10.5px; letter-spacing: 1.4px; text-transform: uppercase;
  color: var(--amber-deep-700); font-weight: 700; margin-bottom: 8px;
}
.evidence-box .ev-tag::before { content: '🔬'; }
.evidence-box h4 {
  font-family: 'Figtree', sans-serif; font-size: 15.5px; color: var(--gray-900);
  font-weight: 600; margin: 0 0 8px;
}
.evidence-box p { font-size: 13.5px; color: var(--gray-700); line-height: 1.55; margin: 0 0 6px; }
.evidence-box .ev-cite {
  display: block; margin-top: 8px; font-size: 12.5px;
  color: var(--amber-deep-800); font-weight: 600;
  font-style: italic;
}
.evidence-box .ev-cite a { color: var(--amber-deep-800); text-decoration: underline dotted; }
.evidence-box .ev-cite a:hover { color: var(--amber-deep-700); }

/* In-text citation links */
.cite {
  display: inline; color: var(--orange-700); text-decoration: none;
  border-bottom: 1px dotted var(--orange-400);
  font-size: 0.95em;
}
.cite:hover { color: var(--orange-800); border-bottom-color: var(--orange-700); }

/* Key takeaways — rich forest green (matches socialconnectionguidelines.org) */
.takeaways-green {
  background: var(--forest-50);
  border: 1px solid var(--forest-200);
  border-left: 6px solid var(--forest-600);
  border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
  padding: 24px 28px;
  margin: 30px 0;
}
.takeaways-green h3 {
  font-family: 'Domine', serif; color: var(--forest-800);
  margin: 0 0 14px; font-size: 19px; font-weight: 700;
  display: flex; align-items: center; gap: 10px;
}
.takeaways-green h3::before { content: '✓'; color: var(--forest-600); font-size: 22px; }
.takeaways-green ul { margin: 0 0 0 22px; }
.takeaways-green li { margin-bottom: 6px; color: var(--gray-800); }
.takeaways-green li strong { color: var(--forest-800); }

/* Section navigation hint / Where this leads */
.next-up {
  background: var(--slate-50);
  border: 1px solid var(--slate-200);
  border-left: 4px solid var(--slate-400);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 16px 22px;
  margin: 24px 0;
  font-size: 14.5px; color: var(--slate-700); line-height: 1.55;
}
.next-up strong { color: var(--slate-900); }
.next-up .next-tag {
  font-family: 'Figtree', sans-serif;
  font-size: 10.5px; letter-spacing: 1.4px; text-transform: uppercase;
  color: var(--slate-600); font-weight: 700; display: block; margin-bottom: 4px;
}

/* Case study — global location pin variant */
.case-study .cs-loc {
  display: inline-block; font-family: 'Figtree', sans-serif;
  font-size: 11.5px; color: var(--orange-700); font-weight: 600;
  margin-bottom: 6px;
}
.case-study .cs-link {
  display: inline-block; margin-top: 10px;
  font-family: 'Figtree', sans-serif; font-size: 13px; font-weight: 600;
  color: var(--orange-700); text-decoration: none;
}
.case-study .cs-link::after { content: ' →'; transition: transform 0.15s; display: inline-block; }
.case-study .cs-link:hover { color: var(--orange-900); }
.case-study .cs-link:hover::after { transform: translateX(3px); }

/* Wheel logo on sidebar — give it a white plate */
.sidebar-header.wheel .sidebar-logo {
  width: 100px;
  height: 100px;
  max-width: 100px;
  background: #fff;
  border-radius: 50%;
  padding: 16px;
  margin: 0 auto 14px;
  opacity: 1;
  box-shadow: 0 2px 8px rgba(0,0,0,0.12);
  box-sizing: border-box;
  object-fit: contain;
}

/* SVG figure container */
.figure {
  margin: 26px 0;
  background: #fff;
  border: 1px solid var(--gray-200);
  border-radius: 14px;
  padding: 22px 24px;
  box-shadow: var(--shadow-card);
}
.figure svg { display: block; width: 100%; height: auto; }
.figure .fig-caption {
  margin-top: 12px; font-size: 13px; color: var(--slate-600);
  font-family: 'Figtree', sans-serif; text-align: center; line-height: 1.5;
}
.figure .fig-caption strong { color: var(--gray-900); }

/* Asset wheel (ABCD figure) supports a focused, clean look */
.figure.no-bg { background: transparent; box-shadow: none; border: none; padding: 8px 0; }

/* Sidebar entry — nav item used as <a> link */
a.nav-item { text-decoration: none; }
a.nav-item, a.nav-item:visited { color: rgba(255,255,255,0.78); }
a.nav-item.active { color: #fff; }
a.nav-item.completed { color: #fff; }

/* Soft accent variations for av-card-tile to differentiate slides */
.av-card-tile.blue { background: var(--blue-50); border-left-color: var(--blue-500); border-color: var(--blue-100); }
.av-card-tile.blue h3 { color: var(--blue-800); }
.av-card-tile.purple { background: var(--forest-50); border-left-color: var(--forest-600); border-color: var(--forest-200); }
.av-card-tile.purple h3 { color: var(--forest-800); }


/* ============================================================
   Course extras — differentiated callout palette
   ============================================================ */
:root{
  --blue-50:#EFF6FF;   --blue-100:#DBEAFE;   --blue-200:#BFDBFE;
  --blue-300:#93C5FD;  --blue-400:#60A5FA;   --blue-500:#3B82F6;
  --blue-600:#2563EB;  --blue-700:#1D4ED8;   --blue-800:#1E40AF; --blue-900:#1E3A8A;

  --purple-50:#FAF5FF; --purple-100:#F3E8FF; --purple-200:#E9D5FF;
  --purple-300:#D8B4FE;--purple-400:#C084FC; --purple-500:#A855F7;
  --purple-600:#9333EA;--purple-700:#7E22CE; --purple-800:#6B21A8;

  --green-50:#F0FDF4;  --green-100:#DCFCE7;  --green-200:#BBF7D0;
  --green-300:#86EFAC; --green-400:#4ADE80;  --green-500:#22C55E;
  --green-600:#16A34A; --green-700:#15803D;  --green-800:#166534;

  --amber-deep-50:#FFFBEB; --amber-deep-100:#FEF3C7; --amber-deep-200:#FDE68A;
  --amber-deep-300:#FCD34D; --amber-deep-400:#FBBF24; --amber-deep-500:#F59E0B;
  --amber-deep-600:#D97706; --amber-deep-700:#B45309; --amber-deep-800:#92400E;

  /* Forest green — matches socialconnectionguidelines.org dark header.
     Used for learning objectives, key takeaways, and guideline tile accents. */
  --forest-50:#ECF4F1;  --forest-100:#D2E5DC; --forest-200:#A8CDBE;
  --forest-300:#73AE9A; --forest-400:#468B78; --forest-500:#29705E;
  --forest-600:#1B5949; --forest-700:#11463A; --forest-800:#0C3530;
  --forest-900:#082724;
}

.objectives-box {
  background: var(--forest-50);
  border: 1px solid var(--forest-100);
  border-left: 4px solid var(--forest-600);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 22px 26px;
  margin: 18px 0 26px;
}
.objectives-box h4 {
  font-family: 'Figtree', sans-serif;
  font-size: 11.5px; letter-spacing: 1.4px; text-transform: uppercase;
  color: var(--forest-800); margin-bottom: 12px; font-weight: 700;
  display: flex; align-items: center; gap: 8px;
}
.objectives-box h4::before { content: '\25CE'; color: var(--forest-600); font-size: 14px; }
.objectives-box ul { margin: 0 0 0 22px; }
.objectives-box li { color: var(--gray-800); margin-bottom: 6px; font-size: 14.5px; line-height: 1.55; }
.objectives-box li strong { color: var(--forest-900); }

.guideline-box {
  background: var(--orange-100);
  border: 1px solid var(--orange-200);
  border-left: 6px solid var(--orange-600);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 22px 26px;
  margin: 22px 0;
  color: var(--gray-900);
}
.guideline-box .gl-tag {
  display: inline-block; background: var(--orange-600); color: #fff;
  font-family: 'Figtree', sans-serif;
  font-size: 10.5px; letter-spacing: 1.2px; text-transform: uppercase;
  font-weight: 700; padding: 4px 10px; border-radius: 5px; margin-bottom: 10px;
}
.guideline-box .gl-text {
  font-family: 'Domine', serif; font-size: 18.5px; font-weight: 600;
  color: var(--orange-900); line-height: 1.4; margin: 0 0 10px;
}
.guideline-box .gl-text::before { content: '\201C'; color: var(--orange-500); margin-right: 4px; }
.guideline-box .gl-text::after  { content: '\201D'; color: var(--orange-500); margin-left: 4px; }
.guideline-box .gl-link {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: 'Figtree', sans-serif; font-size: 13px; font-weight: 600;
  color: var(--orange-800); text-decoration: none; margin-top: 4px;
}
.guideline-box .gl-link:hover { color: var(--orange-900); text-decoration: underline; }
.guideline-box .gl-link::after { content: '\2192'; transition: transform 0.15s; }
.guideline-box .gl-link:hover::after { transform: translateX(3px); }

.brief-box {
  background: var(--amber-deep-50);
  border: 1px solid var(--amber-deep-200);
  border-left: 4px solid var(--amber-deep-500);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 18px 22px;
  margin: 18px 0;
}
.brief-box .brief-tag {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: 'Figtree', sans-serif;
  font-size: 10.5px; letter-spacing: 1.4px; text-transform: uppercase;
  color: var(--amber-deep-700); font-weight: 700; margin-bottom: 8px;
}
.brief-box h4 {
  font-family: 'Figtree', sans-serif; font-size: 15.5px; color: var(--gray-900);
  font-weight: 600; margin: 0 0 6px;
}
.brief-box p { font-size: 13.5px; color: var(--gray-700); line-height: 1.55; margin: 0 0 8px; }
.brief-box ul { margin: 4px 0 0 20px; }
.brief-box li { font-size: 13.5px; line-height: 1.55; margin-bottom: 4px; }
.brief-box a {
  color: var(--amber-deep-700); font-weight: 600; text-decoration: none;
  border-bottom: 1px dotted var(--amber-deep-400);
}
.brief-box a:hover { color: var(--amber-deep-800); border-bottom-color: var(--amber-deep-600); }

.evidence-box {
  background: var(--amber-deep-50);
  border: 1px solid var(--amber-deep-200);
  border-left: 4px solid var(--amber-deep-500);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 18px 22px;
  margin: 18px 0;
}
.evidence-box .ev-tag {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: 'Figtree', sans-serif;
  font-size: 10.5px; letter-spacing: 1.4px; text-transform: uppercase;
  color: var(--amber-deep-700); font-weight: 700; margin-bottom: 8px;
}
.evidence-box h4 {
  font-family: 'Figtree', sans-serif; font-size: 15.5px; color: var(--gray-900);
  font-weight: 600; margin: 0 0 8px;
}
.evidence-box p { font-size: 13.5px; color: var(--gray-700); line-height: 1.55; margin: 0 0 6px; }
.evidence-box .ev-cite {
  display: block; margin-top: 8px; font-size: 12.5px;
  color: var(--amber-deep-800); font-weight: 600; font-style: italic;
}
.evidence-box .ev-cite a { color: var(--amber-deep-800); text-decoration: underline dotted; }
.evidence-box .ev-cite a:hover { color: var(--amber-deep-700); }

.cite {
  display: inline; color: var(--orange-700); text-decoration: none;
  border-bottom: 1px dotted var(--orange-400);
  font-size: 0.95em;
}
.cite:hover { color: var(--orange-800); border-bottom-color: var(--orange-700); }

.takeaways-green {
  background: var(--forest-50);
  border: 1px solid var(--forest-200);
  border-left: 6px solid var(--forest-600);
  border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
  padding: 24px 28px;
  margin: 30px 0;
}
.takeaways-green h3 {
  font-family: 'Domine', serif; color: var(--forest-800);
  margin: 0 0 14px; font-size: 19px; font-weight: 700;
  display: flex; align-items: center; gap: 10px;
}
.takeaways-green h3::before { content: '\2713'; color: var(--forest-600); font-size: 22px; }
.takeaways-green ul { margin: 0 0 0 22px; }
.takeaways-green li { margin-bottom: 6px; color: var(--gray-800); }
.takeaways-green li strong { color: var(--forest-800); }

.next-up {
  background: var(--slate-50);
  border: 1px solid var(--slate-200);
  border-left: 4px solid var(--slate-400);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 16px 22px;
  margin: 24px 0;
  font-size: 14.5px; color: var(--slate-700); line-height: 1.55;
}
.next-up strong { color: var(--slate-900); }
.next-up .next-tag {
  font-family: 'Figtree', sans-serif;
  font-size: 10.5px; letter-spacing: 1.4px; text-transform: uppercase;
  color: var(--slate-600); font-weight: 700; display: block; margin-bottom: 4px;
}

.case-study .cs-loc {
  display: inline-block; font-family: 'Figtree', sans-serif;
  font-size: 11.5px; color: var(--orange-700); font-weight: 600;
  margin-bottom: 6px;
}
.case-study .cs-link {
  display: inline-block; margin-top: 10px;
  font-family: 'Figtree', sans-serif; font-size: 13px; font-weight: 600;
  color: var(--orange-700); text-decoration: none;
}
.case-study .cs-link::after { content: ' \2192'; transition: transform 0.15s; display: inline-block; }
.case-study .cs-link:hover { color: var(--orange-900); }
.case-study .cs-link:hover::after { transform: translateX(3px); }

.sidebar-header.wheel .sidebar-logo {
  width: 100px;
  height: 100px;
  max-width: 100px;
  background: #fff;
  border-radius: 50%;
  padding: 16px;
  margin: 0 auto 14px;
  opacity: 1;
  box-shadow: 0 2px 8px rgba(0,0,0,0.12);
  box-sizing: border-box;
  object-fit: contain;
}

.figure {
  margin: 26px 0;
  background: #fff;
  border: 1px solid var(--gray-200);
  border-radius: 14px;
  padding: 22px 24px;
  box-shadow: var(--shadow-card);
}
.figure svg { display: block; width: 100%; height: auto; }
.figure .fig-caption {
  margin-top: 12px; font-size: 13px; color: var(--slate-600);
  font-family: 'Figtree', sans-serif; text-align: center; line-height: 1.5;
}
.figure .fig-caption strong { color: var(--gray-900); }

a.nav-item { text-decoration: none; }
a.nav-item, a.nav-item:visited { color: rgba(255,255,255,0.78); }
a.nav-item.active { color: #fff; }
a.nav-item.completed { color: #fff; }

.av-card-tile.blue { background: var(--blue-50); border-left-color: var(--blue-500); border-color: var(--blue-100); }
.av-card-tile.blue h3 { color: var(--blue-800); }
.av-card-tile.purple { background: var(--forest-50); border-left-color: var(--forest-600); border-color: var(--forest-200); }
.av-card-tile.purple h3 { color: var(--forest-800); }
