/* ---------- CSS Variables & Themes ---------- */
:root {
  /* Accent palette choices */
  --accent-violet: #7c5cff;
  --accent-blue: #3b82f6;
  --accent-green: #22c55e;
  --accent-orange: #f59e0b;
  --accent-rose: #f43f5e;

  /* Active accent (overridden by JS) */
  --accent: var(--accent-orange);

  /* Light theme tokens */
  --bg: #ffffff;
  --text: #0f172a;
  --muted: #6b7280;
  --panel: #f8fafc;
  --border: #e5e7eb;
  --contrast: #0b1020;
  --contrast-text: #eef2ff;
}
html[data-theme="dark"] {
  --bg: #0b1020;
  --text: #e5e7eb;
  --muted: #9ca3af;
  --panel: #121733;
  --border: #1f2a44;
  --contrast: #070a17;
  --contrast-text: #e2e8f0;
}

/* ---------- Global ---------- */
html, body { background: var(--bg); color: var(--text); }
a { color: var(--accent); }
a:hover { color: var(--text); }
.text-accent { color: var(--accent)!important; }
.text-muted-light { color: var(--muted); }
html[data-theme="dark"] .text-muted-light { color: color-mix(in oklab, var(--text) 90%, var(--muted)); }
.border-accent-subtle { border: 1px solid color-mix(in oklab, var(--accent) 35%, var(--border)); }
.btn-accent {
  --bs-btn-bg: var(--accent);
  --bs-btn-border-color: var(--accent);
  --bs-btn-hover-bg: color-mix(in oklab, var(--accent), black 12%);
  --bs-btn-hover-border-color: color-mix(in oklab, var(--accent), black 12%);
  --bs-btn-color: #fff;
}
.btn-outline-accent {
  --bs-btn-color: var(--accent);
  --bs-btn-border-color: var(--accent);
  --bs-btn-hover-bg: var(--accent);
  --bs-btn-hover-border-color: var(--accent);
  --bs-btn-hover-color: #fff;
}
.fw-extrabold { font-weight: 800; }
.bg-body { background: var(--bg)!important; }

/* Navbar */
.navbar .nav-link { color: var(--text); }
.navbar .nav-link.active { color: var(--accent); }

/* Theme dots */
.theme-dots { gap: .35rem; }
.theme-dot {
  width: 18px; height: 18px; border-radius: 999px; border: 2px solid var(--border);
  background: var(--accent); padding: 0; outline: none;
}
.theme-dot[data-accent="violet"] { background: var(--accent-violet); }
.theme-dot[data-accent="blue"]   { background: var(--accent-blue); }
.theme-dot[data-accent="green"]  { background: var(--accent-green); }
.theme-dot[data-accent="orange"] { background: var(--accent-orange); }
.theme-dot[data-accent="rose"]   { background: var(--accent-rose); }

/* ---------- Hero ---------- */
.hero { background: radial-gradient(1200px 400px at 50% -10%, color-mix(in oklab, var(--accent) 12%, transparent), transparent 60%); }
html[data-accent="orange"] .hero { background: transparent; }
.hero-title { letter-spacing: -.3px; }
.accent-underline { position: relative; }
.accent-underline::after{
  content:""; position:absolute; left:0; right:0; bottom:-6px; height:8px;
  background: color-mix(in oklab, var(--accent) 35%, transparent);
  border-radius: 8px; z-index:-1;
}
.hero-sub { max-width: 820px; color: var(--muted); }

/* Make the hero accent button text use the site text color for contrast */
.hero .btn-accent { color: var(--text) !important; }

/* Steps rail */
.steps-rail { position: relative; }
.step-item { text-align: center; }
.step-icon {
  width: 56px; height: 56px; display: grid; place-content: center;
  border-radius: 14px; margin: 0 auto .5rem;
  background: var(--panel); border: 1px solid var(--border);
  box-shadow: 0 6px 18px color-mix(in oklab, var(--accent) 10%, transparent);
}
.step-icon i { font-size: 28px; color: var(--accent); }
.step-day { font-weight: 700; }
.step-text { font-size: .9rem; color: var(--muted); margin: .25rem 0 0; }
.steps-line {
  position: absolute; left: 0; right: 0; bottom: -16px; height: 2px; border-radius: 2px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
}

/* ---------- Contrast section ---------- */
.contrast { background: var(--contrast); color: var(--contrast-text); }
.contrast h2 { color: #fff; }
.compare-card {
  background: color-mix(in oklab, var(--bg) 10%, transparent);
  border-radius: 16px; padding: 1.25rem; border: 1px solid var(--border);
}
.compare-card ul { padding-left: 1rem; }
.compare-card li { margin: .35rem 0;

/* ---------- Stats (count-up) ---------- */
.stats-rail {
  margin-top: 2rem;
  margin-bottom: 2rem;
}
.stat-item { text-align: center; }
.stat-icon {
  width: 128px; height: 128px; margin: 0 auto .75rem; display: grid; place-content: center;
  border-radius: 16px; background: var(--panel); border: 1px solid var(--border);
  box-shadow: 0 8px 28px color-mix(in oklab, var(--accent) 12%, transparent);
}
.stat-icon i { font-size: 48px; color: var(--accent); }
.stats-rail .step-icon { width: 192px; height: 192px; border-radius: 18px; }
.stats-rail .step-icon i { font-size: 72px; }
.stat-number {
  font-size: 4.5rem;
  font-weight: 900;
  color: var(--text);
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial;
  line-height: 1;
}
.stat-label { color: var(--muted); font-size: .95rem; }

/* Exams section spacing */
#exams { padding-top: 1.25rem; padding-bottom: 1.25rem; }
@media (min-width: 768px) {
  #exams { padding-top: 2rem; padding-bottom: 2rem; }
}

/* ---------- Video section ---------- */
.section-snow { background: var(--contrast); color: var(--contrast-text); }
.section-snow .video-list { text-align: left; }
.section-snow .video-cta-link { color: var(--text-accent); }

/* Bottom gold accent line for sections */
section { position: relative; }
section::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
  opacity: 0.95;
  pointer-events: none;
  z-index: 2;
}

@media (max-width: 767.98px) {
  .stats-rail .step-icon { width: 120px; height: 120px; }
  .stats-rail .step-icon i { font-size: 40px; }
  .stat-number { font-size: 3rem; }
}
.video-title-gradient { display: inline-block; padding: .5rem 1rem; border-radius: 999px; }
.video-title { font-weight: 800; }
.video-title.display-6 { font-size: 1.5rem; letter-spacing: -0.6px; }
.video-list { padding-left: 1rem; }
.video-cta-link { color: var(--accent); text-decoration: none; }
.video-cta-link:hover { text-decoration: underline; }
