/* ================================================================
   THE SPIRIT COMPASS — Complete Design System v3.0
   Standalone WordPress Theme | No Parent Dependency
   Responsive: 320px → 2560px (4K TV)
   SEO/AEO/GEO Optimized
   ================================================================ */

/* ── CSS VARIABLES ────────────────────────────────────────────── */
:root {
  --bg:          #06000f;
  --bg2:         #0d0025;
  --bg3:         #120035;
  --card:        rgba(255,255,255,0.04);
  --card-h:      rgba(255,255,255,0.08);
  --purple:      #7c3aed;
  --purple-l:    #a855f7;
  --gold:        #e8b84b;
  --gold-l:      #fcd34d;
  --gold-dim:    rgba(232,184,75,0.15);
  --teal:        #2dd4bf;
  --teal-dim:    rgba(45,212,191,0.12);
  --rose:        #f43f5e;
  --text:        #faf5ff;
  --text-m:      #c4b5fd;
  --text-d:      rgba(250,245,255,0.45);
  --border:      rgba(232,184,75,0.18);
  --border-h:    rgba(232,184,75,0.45);
  --glow-g:      0 0 40px rgba(232,184,75,0.25);
  --glow-p:      0 0 60px rgba(124,58,237,0.35);
  --r:           14px;
  --r-lg:        22px;
  --font-d:      'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --font-b:      'DM Sans', system-ui, -apple-system, sans-serif;
  --ease:        all 0.32s cubic-bezier(0.4,0,0.2,1);
}

/* ── RESET & BASE ─────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; -webkit-text-size-adjust: 100%; }

body, body.sc-body {
  font-family: var(--font-b);
  background: var(--bg);
  color: var(--text);
  line-height: 1.7;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body::before {
  content: '';
  position: fixed; inset: 0;
  background:
    radial-gradient(ellipse 85% 60% at 15% 8%,  rgba(124,58,237,.18) 0%, transparent 60%),
    radial-gradient(ellipse 65% 55% at 85% 88%,  rgba(45,212,191,.10) 0%, transparent 60%),
    radial-gradient(ellipse 50% 45% at 50% 50%,  rgba(232,184,75,.05) 0%, transparent 70%);
  pointer-events: none; z-index: 0;
}

a { color: inherit; text-decoration: none; transition: var(--ease); }
a:hover { color: var(--gold); }
img { max-width: 100%; height: auto; display: block; }
ul { list-style: none; }
button { cursor: pointer; font-family: var(--font-b); }
input, textarea, select { font-family: var(--font-b); }

/* ── STARS CANVAS ─────────────────────────────────────────────── */
#sc-stars-canvas {
  position: fixed; inset: 0; pointer-events: none; z-index: 0; opacity: .45;
}

/* ── LOADER ───────────────────────────────────────────────────── */
.sc-loader {
  position: fixed; inset: 0; background: var(--bg); z-index: 99999;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 18px; transition: opacity .6s ease, visibility .6s ease;
}
.sc-loader.hidden { opacity: 0; visibility: hidden; }
.sc-loader-logo { font-size: 52px; animation: scFloat 2s ease-in-out infinite; }
.sc-loader-ring {
  width: 48px; height: 48px; border-radius: 50%;
  border: 2px solid rgba(232,184,75,.18);
  border-top-color: var(--gold);
  animation: scSpin 1s linear infinite;
}
.sc-loader-text {
  font-size: 11px; letter-spacing: 4px; color: var(--text-d);
  font-family: var(--font-b); font-weight: 500;
}

/* ── LAYOUT ───────────────────────────────────────────────────── */
.sc-wrap {
  width: 100%; max-width: 1280px;
  margin: 0 auto; padding: 0 24px;
}
.sc-section  { position: relative; padding: 100px 0; z-index: 1; }
.sc-section-sm { padding: 60px 0; z-index: 1; position: relative; }

/* ── TYPOGRAPHY ───────────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-d); font-weight: 400;
  line-height: 1.2; color: var(--text);
}
.sc-eyebrow {
  font-family: var(--font-b); font-size: 11px; font-weight: 600;
  letter-spacing: 3.5px; text-transform: uppercase;
  color: var(--gold); display: block; margin-bottom: 10px;
}
.sc-title {
  font-family: var(--font-d); font-weight: 400;
  font-size: clamp(1.9rem, 4vw, 3.2rem); line-height: 1.15;
}
.sc-title em { color: var(--gold); font-style: italic; }
.sc-divider {
  width: 48px; height: 2px;
  background: linear-gradient(90deg, var(--gold), transparent);
  margin: 16px 0 24px; border-radius: 2px;
}
.sc-section-header { text-align: center; max-width: 680px; margin: 0 auto 56px; }
.sc-section-header .sc-title { font-size: clamp(2rem, 4.5vw, 3.5rem); }

/* ── NAVIGATION ───────────────────────────────────────────────── */
.sc-nav {
  position: sticky; top: 0; z-index: 9000;
  background: rgba(6,0,15,.95); backdrop-filter: blur(24px) saturate(180%);
  -webkit-backdrop-filter: blur(24px) saturate(180%);
  border-bottom: 1px solid var(--border);
}
.sc-nav.scrolled { box-shadow: 0 4px 40px rgba(0,0,0,.6); }
.sc-nav-inner {
  display: flex; align-items: center; height: 64px; gap: 6px;
}
.sc-brand {
  display: flex; align-items: center; gap: 9px;
  margin-right: 12px; flex-shrink: 0;
}
.sc-brand-logo { width: 38px; height: 38px; object-fit: contain; border-radius: 6px; }
.sc-brand-name {
  font-family: var(--font-d); font-size: 1.3rem; font-weight: 400;
  color: var(--text); white-space: nowrap;
}
.sc-nav-links { display: flex; align-items: center; gap: 0; flex: 1; }
.sc-nl {
  padding: 7px 11px; font-size: 13.5px; color: var(--text-m);
  border-radius: 8px; transition: var(--ease); white-space: nowrap;
  border: none; background: none; font-family: var(--font-b);
}
.sc-nl:hover, .sc-nl.active { color: var(--gold); background: var(--gold-dim); }
.sc-cta-btn {
  margin-left: auto; padding: 9px 22px; flex-shrink: 0;
  background: linear-gradient(135deg, #b8620a, var(--gold));
  color: #06000f; border: none; border-radius: 100px;
  font-size: 13px; font-weight: 600; transition: var(--ease);
  font-family: var(--font-b); white-space: nowrap;
}
.sc-cta-btn:hover { transform: translateY(-1px); box-shadow: var(--glow-g); color: #06000f; }
.sc-mob-btn {
  display: none; flex-direction: column; gap: 5px;
  background: none; border: 1px solid var(--border);
  border-radius: 8px; padding: 8px 10px; margin-left: 8px;
}
.sc-mob-btn span { display: block; width: 22px; height: 2px; background: var(--text); border-radius: 2px; }
.sc-mob-menu {
  display: none; position: fixed; inset: 0;
  background: rgba(6,0,15,.98); z-index: 9999;
  flex-direction: column; align-items: center; justify-content: center; gap: 22px;
}
.sc-mob-menu.open { display: flex; }
.sc-mob-menu .sc-nl { font-family: var(--font-d); font-size: 1.9rem; font-weight: 300; padding: 8px 20px; }
.sc-mob-close {
  position: absolute; top: 20px; right: 20px;
  background: none; border: none; color: var(--text-m); font-size: 26px;
}

/* ── HERO ─────────────────────────────────────────────────────── */
.sc-hero {
  min-height: 100vh; display: flex; align-items: center;
  position: relative; z-index: 1; overflow: hidden;
}
.sc-hero-inner {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 60px; align-items: center; padding: 80px 0;
}
.sc-hero-badge {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 7px 16px; border: 1px solid var(--border);
  border-radius: 100px; font-size: 12px; color: var(--gold);
  background: var(--gold-dim); font-family: var(--font-b);
  margin-bottom: 20px; font-weight: 500; letter-spacing: 1px;
}
.sc-hero-badge::before { content: '✦'; }
.sc-hero-h1 {
  font-family: var(--font-d); font-weight: 300;
  font-size: clamp(2.8rem, 6vw, 5.2rem);
  line-height: 1.08; margin-bottom: 20px;
}
.sc-hero-h1 .gold { color: var(--gold); }
.sc-hero-h1 .teal { color: var(--teal); }
.sc-hero-desc {
  font-size: clamp(1rem, 1.6vw, 1.15rem); color: var(--text-m);
  max-width: 480px; margin-bottom: 32px; line-height: 1.75;
}
.sc-hero-btns { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 44px; }
.sc-hero-stats { display: flex; gap: 32px; }
.sc-hero-stat .num {
  display: block; font-family: var(--font-d);
  font-size: clamp(1.8rem, 3.5vw, 2.6rem); color: var(--gold);
}
.sc-hero-stat .lbl { font-size: 12px; color: var(--text-d); font-weight: 500; letter-spacing: .5px; }

/* Hero Visual */
.sc-hero-visual { display: flex; flex-direction: column; align-items: center; gap: 28px; }
.sc-hero-orb {
  width: clamp(200px,28vw,340px); height: clamp(200px,28vw,340px);
  border-radius: 50%; background: radial-gradient(circle, rgba(124,58,237,.35), rgba(6,0,15,.8));
  border: 1px solid var(--border); display: flex; align-items: center; justify-content: center;
  animation: scFloat 5s ease-in-out infinite;
  box-shadow: var(--glow-p), inset 0 0 60px rgba(124,58,237,.2);
  position: relative; overflow: hidden;
}
.sc-hero-orb::before {
  content: ''; position: absolute; inset: -2px;
  border-radius: 50%; background: conic-gradient(var(--gold) 0deg, transparent 120deg, var(--teal) 240deg, transparent 360deg);
  animation: scSpin 8s linear infinite; opacity: .3; z-index: -1;
}
.sc-hero-logo-img { width: 65%; height: 65%; object-fit: contain; filter: drop-shadow(0 0 30px rgba(232,184,75,.4)); }
.sc-float-tags { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; max-width: 340px; }
.sc-float-tag {
  display: flex; align-items: center; gap: 7px; padding: 7px 14px;
  border: 1px solid var(--border); border-radius: 100px;
  font-size: 12px; font-weight: 500; color: var(--text-m);
  background: var(--card); backdrop-filter: blur(10px);
}
.sc-float-tag .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--gold); animation: scPulse 2s ease-in-out infinite;
}

/* Trust Bar */
.sc-trust-bar { background: var(--bg2); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 14px 0; z-index: 1; position: relative; }
.sc-trust-inner { display: flex; flex-wrap: wrap; gap: 12px 28px; justify-content: center; align-items: center; }
.sc-trust-item { font-size: 13px; color: var(--text-d); display: flex; align-items: center; gap: 7px; font-weight: 500; }
.sc-trust-item .icon { font-size: 15px; }

/* ── BUTTONS ──────────────────────────────────────────────────── */
.sc-btn {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 12px 26px; border-radius: 100px; font-size: 14px;
  font-weight: 600; font-family: var(--font-b); transition: var(--ease);
  border: none; white-space: nowrap; cursor: pointer; text-decoration: none;
}
.sc-btn-primary {
  background: linear-gradient(135deg, var(--purple), var(--purple-l));
  color: #fff; box-shadow: 0 4px 20px rgba(124,58,237,.35);
}
.sc-btn-primary:hover { transform: translateY(-2px); box-shadow: var(--glow-p); color: #fff; }
.sc-btn-gold {
  background: linear-gradient(135deg, #b8620a, var(--gold));
  color: #06000f; box-shadow: 0 4px 20px rgba(232,184,75,.3);
}
.sc-btn-gold:hover { transform: translateY(-2px); box-shadow: var(--glow-g); color: #06000f; }
.sc-btn-outline {
  background: transparent; color: var(--text-m);
  border: 1px solid var(--border);
}
.sc-btn-outline:hover { border-color: var(--gold); color: var(--gold); background: var(--gold-dim); }
.sc-btn-teal {
  background: var(--teal); color: #06000f;
}
.sc-btn-teal:hover { transform: translateY(-2px); opacity: .9; color: #06000f; }
.sc-btn-sm { padding: 8px 18px; font-size: 13px; }

/* ── CARDS ────────────────────────────────────────────────────── */
.sc-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: 28px; transition: var(--ease);
}
.sc-card:hover { background: var(--card-h); border-color: var(--border-h); transform: translateY(-3px); box-shadow: var(--glow-p); }

/* ── PATH CARDS (How it Works) ───────────────────────────────── */
.sc-paths-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.sc-path-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: 36px 28px; text-align: center;
  transition: var(--ease); position: relative; overflow: hidden;
}
.sc-path-card:hover { background: var(--card-h); border-color: var(--border-h); transform: translateY(-4px); }
.sc-path-icon { font-size: 44px; margin-bottom: 16px; display: block; }
.sc-path-card h3 { font-family: var(--font-d); font-size: 1.5rem; margin-bottom: 10px; }
.sc-path-card p { font-size: 14px; color: var(--text-d); line-height: 1.7; margin-bottom: 18px; }
.sc-path-link { font-size: 13px; color: var(--gold); font-weight: 600; }

/* ── COURSE CARDS ─────────────────────────────────────────────── */
.sc-courses-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.sc-course-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: 28px; transition: var(--ease); position: relative;
}
.sc-course-card:hover { background: var(--card-h); border-color: var(--border-h); transform: translateY(-3px); box-shadow: var(--glow-p); }
.sc-course-icon { font-size: 40px; margin-bottom: 14px; display: block; }
.sc-badge {
  display: inline-block; padding: 3px 11px; border-radius: 100px;
  font-size: 11px; font-weight: 600; letter-spacing: .5px;
  font-family: var(--font-b); margin-bottom: 12px;
}
.sc-badge-gold   { background: var(--gold-dim);  color: var(--gold); }
.sc-badge-teal   { background: var(--teal-dim);  color: var(--teal); }
.sc-badge-purple { background: rgba(124,58,237,.18); color: var(--purple-l); }
.sc-badge-rose   { background: rgba(244,63,94,.15);  color: var(--rose); }
.sc-course-card h3 { font-family: var(--font-d); font-size: 1.35rem; margin-bottom: 8px; }
.sc-course-card p  { font-size: 13.5px; color: var(--text-d); line-height: 1.65; margin-bottom: 16px; }
.sc-course-meta { display: flex; align-items: center; justify-content: space-between; margin-top: auto; flex-wrap: wrap; gap: 8px; }
.sc-course-meta .time { font-size: 12px; color: var(--text-d); }
.sc-course-meta .price { font-family: var(--font-d); font-size: 1.6rem; color: var(--gold); }
.sc-filter-row { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 36px; }
.sc-filter-btn {
  padding: 8px 18px; border: 1px solid var(--border); background: transparent;
  color: var(--text-m); border-radius: 100px; font-size: 13px; font-weight: 500;
  cursor: pointer; transition: var(--ease); font-family: var(--font-b);
}
.sc-filter-btn:hover, .sc-filter-btn.active { border-color: var(--gold); color: var(--gold); background: var(--gold-dim); }

/* ── FREE TOOLS ───────────────────────────────────────────────── */
.sc-tools-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 18px; }
.sc-tool-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--r); padding: 24px 20px; text-align: center;
  transition: var(--ease); cursor: pointer;
}
.sc-tool-card:hover { background: var(--card-h); border-color: var(--border-h); transform: translateY(-3px); }
.sc-tool-icon { font-size: 36px; margin-bottom: 12px; display: block; }
.sc-tool-card h4 { font-family: var(--font-d); font-size: 1.15rem; margin-bottom: 6px; }
.sc-tool-card p  { font-size: 12.5px; color: var(--text-d); margin-bottom: 12px; }
.sc-tool-free { font-size: 11px; font-weight: 700; color: var(--teal); letter-spacing: 1.5px; }

/* ── CHALLENGES ───────────────────────────────────────────────── */
.sc-challenges-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.sc-challenge-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: 28px; transition: var(--ease);
}
.sc-challenge-card:hover { background: var(--card-h); border-color: var(--border-h); transform: translateY(-3px); }
.sc-challenge-day {
  display: inline-flex; align-items: center; padding: 5px 13px;
  background: var(--gold-dim); border: 1px solid var(--border);
  border-radius: 100px; font-size: 11px; font-weight: 700;
  color: var(--gold); margin-bottom: 14px; letter-spacing: 1px;
}
.sc-challenge-card h3 { font-family: var(--font-d); font-size: 1.3rem; margin-bottom: 8px; }
.sc-challenge-card p  { font-size: 13.5px; color: var(--text-d); margin-bottom: 16px; line-height: 1.65; }
.sc-challenge-meta { font-size: 12.5px; color: var(--text-m); margin-bottom: 16px; }
.sc-challenge-progress { height: 4px; background: rgba(255,255,255,.1); border-radius: 2px; margin-bottom: 16px; overflow: hidden; }
.sc-challenge-progress-fill { height: 100%; background: linear-gradient(90deg, var(--purple), var(--teal)); border-radius: 2px; width: 0; transition: width 1.2s cubic-bezier(.4,0,.2,1); }

/* ── LEADERBOARD ──────────────────────────────────────────────── */
.sc-lb-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--r-lg); overflow: hidden; max-width: 600px; margin: 0 auto;
}
.sc-lb-tabs { display: flex; border-bottom: 1px solid var(--border); }
.sc-lb-tab {
  flex: 1; padding: 14px; text-align: center; font-size: 13px;
  font-weight: 600; color: var(--text-d); border: none; background: none;
  cursor: pointer; transition: var(--ease); font-family: var(--font-b);
}
.sc-lb-tab.active { color: var(--gold); background: var(--gold-dim); }
.sc-lb-row {
  display: flex; align-items: center; gap: 16px; padding: 14px 20px;
  border-bottom: 1px solid rgba(255,255,255,.04); transition: var(--ease);
}
.sc-lb-row:hover { background: rgba(255,255,255,.04); }
.sc-lb-rank { width: 28px; font-size: 18px; font-family: var(--font-d); text-align: center; }
.sc-lb-flag { font-size: 20px; }
.sc-lb-info { flex: 1; }
.sc-lb-name { font-size: 14px; font-weight: 500; }
.sc-lb-loc  { font-size: 12px; color: var(--text-d); }
.sc-lb-pts  { font-family: var(--font-d); font-size: 1.25rem; color: var(--gold); }
.sc-lb-badge-icon { font-size: 14px; }

/* ── TESTIMONIALS ─────────────────────────────────────────────── */
.sc-testimonials-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.sc-testimonial-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: 28px; transition: var(--ease);
}
.sc-testimonial-card:hover { transform: translateY(-3px); background: var(--card-h); }
.sc-stars { color: var(--gold); font-size: 14px; margin-bottom: 14px; }
.sc-testimonial-card p { font-family: var(--font-d); font-style: italic; font-size: 1.05rem; line-height: 1.65; color: var(--text-m); margin-bottom: 16px; }
.sc-testimonial-author { display: flex; align-items: center; gap: 10px; }
.sc-testimonial-author .flag { font-size: 18px; }
.sc-testimonial-author .name { font-size: 13px; font-weight: 600; color: var(--text); }
.sc-testimonial-author .loc  { font-size: 12px; color: var(--text-d); }

/* ── MEET JENNIFER (Homepage) ─────────────────────────────────── */
.sc-meet-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 60px; align-items: center; }
.sc-jennifer-portrait {
  border-radius: var(--r-lg); overflow: hidden; position: relative;
  border: 1px solid var(--border); box-shadow: var(--glow-p);
}
.sc-jennifer-portrait img { width: 100%; aspect-ratio: 3/4; object-fit: cover; object-position: center top; display: block; }
.sc-portrait-badge {
  position: absolute; bottom: 20px; left: 20px;
  background: rgba(6,0,15,.85); backdrop-filter: blur(12px);
  border: 1px solid var(--border); border-radius: 10px;
  padding: 10px 16px; font-size: 12px; font-weight: 600; color: var(--gold);
}
.sc-jennifer-creds { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; }
.sc-jennifer-creds .tag {
  padding: 6px 14px; background: var(--card); border: 1px solid var(--border);
  border-radius: 100px; font-size: 12px; color: var(--text-m);
}

/* ── PRICING ──────────────────────────────────────────────────── */
.sc-pricing-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; align-items: start; }
.sc-pricing-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: 36px 28px; transition: var(--ease);
}
.sc-pricing-card.featured {
  border-color: var(--gold); background: linear-gradient(135deg, rgba(232,184,75,.08), rgba(124,58,237,.08));
  box-shadow: var(--glow-g); transform: scale(1.04);
}
.sc-pricing-card:hover:not(.featured) { background: var(--card-h); border-color: var(--border-h); }
.sc-pricing-popular {
  display: inline-block; padding: 4px 12px; border-radius: 100px;
  background: var(--gold); color: #06000f; font-size: 11px; font-weight: 700;
  margin-bottom: 14px; letter-spacing: 1px;
}
.sc-pricing-name  { font-family: var(--font-d); font-size: 1.5rem; margin-bottom: 8px; }
.sc-pricing-price { font-family: var(--font-d); font-size: clamp(2.5rem,5vw,3.8rem); color: var(--gold); line-height: 1; }
.sc-pricing-per   { font-size: 13px; color: var(--text-d); margin-bottom: 6px; }
.sc-pricing-inr   { font-size: 13px; color: var(--text-d); margin-bottom: 24px; }
.sc-pricing-divider { height: 1px; background: var(--border); margin-bottom: 20px; }
.sc-pricing-features { margin-bottom: 28px; }
.sc-pricing-features li {
  padding: 7px 0; font-size: 13.5px; color: var(--text-m);
  border-bottom: 1px solid rgba(255,255,255,.04);
  display: flex; align-items: center; gap: 8px;
}
.sc-pricing-features li.has { color: var(--text); }
.sc-pricing-features li.no  { color: var(--text-d); }
.sc-pricing-features li::before { font-size: 13px; flex-shrink: 0; }
.sc-pricing-features li.has::before { content: '✓'; color: var(--teal); }
.sc-pricing-features li.no::before  { content: '✗'; color: rgba(255,255,255,.25); }

/* ── CTA BAND ─────────────────────────────────────────────────── */
.sc-cta-band {
  text-align: center; background: linear-gradient(135deg, rgba(124,58,237,.15), rgba(45,212,191,.08));
  border: 1px solid var(--border); border-radius: var(--r-lg); padding: 64px 40px;
  position: relative; overflow: hidden;
}
.sc-cta-band::before { content: '✦'; position: absolute; top: 20px; left: 50%; transform: translateX(-50%); color: var(--gold); font-size: 18px; opacity: .4; }
.sc-cta-band h2 { font-family: var(--font-d); font-size: clamp(1.8rem,4vw,3rem); margin-bottom: 14px; }
.sc-cta-band h2 em { color: var(--gold); font-style: italic; }
.sc-cta-band p { font-size: 15px; color: var(--text-m); max-width: 520px; margin: 0 auto 28px; }
.sc-cta-btns { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* ── NEWSLETTER ───────────────────────────────────────────────── */
.sc-newsletter-form { display: flex; gap: 10px; flex-wrap: wrap; }
.sc-newsletter-form input[type="email"] {
  flex: 1; min-width: 220px; padding: 12px 18px;
  background: rgba(255,255,255,.06); border: 1px solid var(--border);
  border-radius: 100px; color: var(--text); font-size: 14px; outline: none;
  transition: var(--ease); font-family: var(--font-b);
}
.sc-newsletter-form input[type="email"]::placeholder { color: var(--text-d); }
.sc-newsletter-form input[type="email"]:focus { border-color: var(--gold); background: rgba(232,184,75,.08); }

/* ── FOOTER ───────────────────────────────────────────────────── */
.sc-footer {
  background: var(--bg2); border-top: 1px solid var(--border);
  padding: 60px 0 28px; position: relative; z-index: 1;
}
.sc-footer-grid {
  display: grid; grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 40px; margin-bottom: 44px;
}
.sc-footer-brand { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.sc-footer-logo  { width: 36px; height: 36px; object-fit: contain; border-radius: 5px; }
.sc-footer-brand-name { font-family: var(--font-d); font-size: 1.3rem; color: var(--text); }
.sc-footer-desc  { font-size: 13px; color: var(--text-d); line-height: 1.7; margin-bottom: 16px; max-width: 280px; }
.sc-socials { display: flex; gap: 8px; }
.sc-soc {
  width: 34px; height: 34px; border-radius: 50%;
  border: 1px solid var(--border); background: transparent;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; transition: var(--ease); color: var(--text-d);
}
.sc-soc:hover { border-color: var(--gold); color: var(--gold); }
.sc-fc h4 {
  font-size: 10.5px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 2px; color: var(--gold); margin-bottom: 16px; font-family: var(--font-b);
}
.sc-fc ul li { margin-bottom: 9px; }
.sc-fc ul li a { font-size: 13.5px; color: var(--text-d); transition: var(--ease); }
.sc-fc ul li a:hover { color: var(--gold); padding-left: 4px; }
.sc-footer-nl {
  padding: 32px; background: var(--card); border: 1px solid var(--border);
  border-radius: var(--r-lg); margin-bottom: 32px;
}
.sc-footer-nl-inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.sc-footer-nl-title { font-family: var(--font-d); font-size: 1.35rem; margin-bottom: 4px; }
.sc-footer-nl-sub   { font-size: 13px; color: var(--text-d); }
.sc-footer-nl-form  { min-width: 340px; }
.sc-footer-bottom {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 22px; border-top: 1px solid var(--border);
  font-size: 12px; color: var(--text-d); flex-wrap: wrap; gap: 8px;
}

/* ── PAGE HERO ────────────────────────────────────────────────── */
.sc-page-hero {
  background: linear-gradient(135deg, rgba(124,58,237,.12), rgba(45,212,191,.06));
  border-bottom: 1px solid var(--border); padding: 72px 0 52px;
  text-align: center; position: relative; z-index: 1;
}
.sc-breadcrumb { font-size: 12.5px; color: var(--text-d); margin-bottom: 12px; }
.sc-breadcrumb a { color: var(--text-d); }
.sc-breadcrumb a:hover { color: var(--gold); }

/* ── SESSIONS PAGE ────────────────────────────────────────────── */
.sc-sessions-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 24px; }
.sc-session-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: 28px; transition: var(--ease);
}
.sc-session-card:hover { background: var(--card-h); border-color: var(--border-h); transform: translateY(-3px); }
.sc-session-card h3 { font-family: var(--font-d); font-size: 1.35rem; margin-bottom: 8px; }
.sc-session-card p  { font-size: 13.5px; color: var(--text-d); line-height: 1.65; margin-bottom: 16px; }
.sc-session-meta { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 20px; }
.sc-session-prices { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 20px; }
.sc-price-pill {
  display: flex; flex-direction: column; padding: 10px 18px;
  background: var(--bg2); border: 1px solid var(--border); border-radius: var(--r);
  min-width: 110px; transition: var(--ease);
}
.sc-price-pill:hover { border-color: var(--gold); }
.sc-price-pill .dur { font-size: 11px; color: var(--text-d); margin-bottom: 3px; }
.sc-price-pill .usd { font-family: var(--font-d); font-size: 1.5rem; color: var(--gold); }
.sc-price-pill .inr { font-size: 11px; color: var(--text-d); }

/* Jennifer Sidebar on Sessions */
.sc-jennifer-sidebar {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: 28px; text-align: center; position: sticky; top: 84px;
}
.sc-jen-img {
  width: 120px; height: 120px; border-radius: 50%; object-fit: cover; object-position: center top;
  margin: 0 auto 14px; border: 3px solid var(--gold);
  box-shadow: 0 0 30px rgba(232,184,75,.3);
}
.sc-sessions-layout { display: grid; grid-template-columns: 1fr 280px; gap: 40px; align-items: start; }

/* ── ABOUT PAGE ───────────────────────────────────────────────── */
.sc-about-team { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; }
.sc-team-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--r-lg); overflow: hidden; transition: var(--ease);
}
.sc-team-card:hover { border-color: var(--border-h); box-shadow: var(--glow-p); }
.sc-team-photo { width: 100%; aspect-ratio: 1/1.1; object-fit: cover; object-position: center top; display: block; }
.sc-team-info { padding: 28px; }
.sc-team-info h3 { font-family: var(--font-d); font-size: 1.7rem; margin-bottom: 4px; }
.sc-team-info .role { font-size: 13px; color: var(--gold); font-weight: 600; margin-bottom: 12px; }
.sc-team-info p { font-size: 13.5px; color: var(--text-d); line-height: 1.75; margin-bottom: 14px; }
.sc-team-creds { display: flex; flex-wrap: wrap; gap: 7px; }
.sc-team-creds .cred {
  padding: 5px 13px; font-size: 12px;
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: 100px; color: var(--text-m);
}

/* ── CONTACT PAGE ─────────────────────────────────────────────── */
.sc-contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; }
.sc-contact-form {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: 36px;
}
.sc-contact-form h3 { font-family: var(--font-d); font-size: 1.6rem; margin-bottom: 6px; }
.sc-contact-form p  { font-size: 13.5px; color: var(--text-d); margin-bottom: 24px; }
.sc-form-group { margin-bottom: 18px; }
.sc-form-group label { display: block; font-size: 12px; font-weight: 600; color: var(--text-m); margin-bottom: 6px; letter-spacing: .5px; text-transform: uppercase; }
.sc-form-group input, .sc-form-group textarea, .sc-form-group select {
  width: 100%; padding: 12px 16px;
  background: rgba(255,255,255,.05); border: 1px solid var(--border);
  border-radius: var(--r); color: var(--text); font-size: 14px; outline: none;
  transition: var(--ease); resize: vertical; font-family: var(--font-b);
}
.sc-form-group input:focus, .sc-form-group textarea:focus { border-color: var(--gold); background: rgba(232,184,75,.05); }
.sc-form-group input::placeholder, .sc-form-group textarea::placeholder { color: var(--text-d); }
.sc-contact-info h3 { font-family: var(--font-d); font-size: 1.6rem; margin-bottom: 20px; }
.sc-contact-item { display: flex; gap: 14px; margin-bottom: 18px; align-items: flex-start; }
.sc-contact-item .ic { font-size: 22px; flex-shrink: 0; margin-top: 2px; }
.sc-contact-item .lbl { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1.5px; color: var(--gold); margin-bottom: 3px; }
.sc-contact-item .val { font-size: 14px; color: var(--text-m); }

/* ── GAMES PAGE ───────────────────────────────────────────────── */
.sc-games-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.sc-game-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--r-lg); overflow: hidden; transition: var(--ease);
}
.sc-game-card:hover { border-color: var(--border-h); transform: translateY(-3px); }
.sc-game-header { padding: 24px; text-align: center; }
.sc-game-icon { font-size: 48px; margin-bottom: 12px; display: block; }
.sc-game-card h3 { font-family: var(--font-d); font-size: 1.3rem; margin-bottom: 8px; }
.sc-game-card p  { font-size: 13px; color: var(--text-d); line-height: 1.65; }
.sc-game-area { padding: 0 20px 20px; }

/* ── SCROLL REVEAL ────────────────────────────────────────────── */
.sc-reveal { opacity: 0; transform: translateY(28px); transition: opacity .65s ease, transform .65s ease; }
.sc-reveal.visible { opacity: 1; transform: translateY(0); }
.sc-reveal-d1 { transition-delay: .1s; }
.sc-reveal-d2 { transition-delay: .2s; }
.sc-reveal-d3 { transition-delay: .3s; }
.sc-reveal-d4 { transition-delay: .4s; }

/* ── ANIMATIONS ───────────────────────────────────────────────── */
@keyframes scFloat  { 0%,100%{transform:translateY(0)}  50%{transform:translateY(-14px)} }
@keyframes scSpin   { to{transform:rotate(360deg)} }
@keyframes scPulse  { 0%,100%{opacity:.4;transform:scale(1)} 50%{opacity:1;transform:scale(1.3)} }
@keyframes scFadeIn { from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:translateY(0)} }

/* ── STEP NUMBERS (How It Works) ─────────────────────────────── */
.sc-steps-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; }
.sc-step {
  text-align: center; padding: 32px 20px; background: var(--card);
  border: 1px solid var(--border); border-radius: var(--r-lg); transition: var(--ease);
}
.sc-step:hover { background: var(--card-h); border-color: var(--border-h); }
.sc-step-num {
  width: 48px; height: 48px; border-radius: 50%;
  background: linear-gradient(135deg, var(--purple), var(--purple-l));
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-d); font-size: 1.4rem; margin: 0 auto 16px;
  box-shadow: 0 0 20px rgba(124,58,237,.4);
}
.sc-step h4 { font-family: var(--font-d); font-size: 1.15rem; margin-bottom: 8px; }
.sc-step p  { font-size: 13px; color: var(--text-d); line-height: 1.65; }

/* ── FAQ ACCORDION ────────────────────────────────────────────── */
.sc-faq { max-width: 760px; margin: 0 auto; }
.sc-faq-item { border-bottom: 1px solid var(--border); }
.sc-faq-q {
  width: 100%; text-align: left; padding: 18px 0;
  background: none; border: none; color: var(--text);
  font-size: 15px; font-weight: 500; cursor: pointer;
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--font-b); gap: 16px;
}
.sc-faq-q:hover { color: var(--gold); }
.sc-faq-q::after { content: '+'; font-size: 20px; color: var(--gold); flex-shrink: 0; transition: transform .3s; }
.sc-faq-item.open .sc-faq-q::after { transform: rotate(45deg); }
.sc-faq-a { max-height: 0; overflow: hidden; transition: max-height .35s ease, padding .3s ease; }
.sc-faq-item.open .sc-faq-a { max-height: 400px; padding-bottom: 16px; }
.sc-faq-a p { font-size: 14px; color: var(--text-d); line-height: 1.75; }

/* ── RESPONSIVE — TABLET 768–1024px ─────────────────────────── */
@media (max-width: 1100px) {
  .sc-hero-inner     { grid-template-columns: 1fr; gap: 40px; text-align: center; }
  .sc-hero-desc      { max-width: 100%; margin-left: auto; margin-right: auto; }
  .sc-hero-btns      { justify-content: center; }
  .sc-hero-stats     { justify-content: center; }
  .sc-hero-visual    { display: none; }
  .sc-courses-grid   { grid-template-columns: repeat(2,1fr); }
  .sc-tools-grid     { grid-template-columns: repeat(3,1fr); }
  .sc-steps-grid     { grid-template-columns: repeat(2,1fr); }
  .sc-footer-grid    { grid-template-columns: 1fr 1fr; gap: 28px; }
  .sc-footer-nl-form { min-width: 100%; }
  .sc-sessions-layout{ grid-template-columns: 1fr; }
  .sc-jennifer-sidebar{ position: static; }
}

@media (max-width: 900px) {
  .sc-pricing-grid   { grid-template-columns: 1fr; max-width: 440px; margin: 0 auto; }
  .sc-pricing-card.featured { transform: none; }
  .sc-challenges-grid{ grid-template-columns: repeat(2,1fr); }
  .sc-meet-grid      { grid-template-columns: 1fr; }
  .sc-about-team     { grid-template-columns: 1fr; }
  .sc-contact-grid   { grid-template-columns: 1fr; }
  .sc-testimonials-grid { grid-template-columns: repeat(2,1fr); }
  .sc-paths-grid     { grid-template-columns: 1fr 1fr; }
  .sc-games-grid     { grid-template-columns: 1fr 1fr; }
}

/* ── RESPONSIVE — MOBILE ≤ 767px ────────────────────────────── */
@media (max-width: 767px) {
  .sc-nav-links, .sc-cta-btn { display: none; }
  .sc-mob-btn { display: flex; }
  .sc-wrap    { padding: 0 16px; }
  .sc-section    { padding: 64px 0; }
  .sc-section-sm { padding: 40px 0; }
  .sc-hero-h1    { font-size: clamp(2.2rem, 8vw, 3rem); }
  .sc-hero-stats { gap: 20px; }
  .sc-courses-grid  { grid-template-columns: 1fr; }
  .sc-tools-grid    { grid-template-columns: repeat(2,1fr); }
  .sc-challenges-grid{ grid-template-columns: 1fr; }
  .sc-testimonials-grid { grid-template-columns: 1fr; }
  .sc-paths-grid    { grid-template-columns: 1fr; }
  .sc-steps-grid    { grid-template-columns: repeat(2,1fr); }
  .sc-games-grid    { grid-template-columns: 1fr; }
  .sc-sessions-grid { grid-template-columns: 1fr; }
  .sc-footer-grid   { grid-template-columns: 1fr; }
  .sc-footer-bottom { flex-direction: column; text-align: center; gap: 6px; }
  .sc-footer-nl-inner{ flex-direction: column; }
  .sc-footer-nl-form { min-width: 100%; width: 100%; }
  .sc-newsletter-form{ flex-direction: column; }
  .sc-newsletter-form input { min-width: 100%; }
  .sc-cta-btns { flex-direction: column; align-items: center; }
  .sc-hero-btns { flex-direction: column; align-items: center; }
}

/* ── RESPONSIVE — SMALL MOBILE ≤ 400px ──────────────────────── */
@media (max-width: 400px) {
  .sc-tools-grid { grid-template-columns: 1fr; }
  .sc-steps-grid { grid-template-columns: 1fr; }
  .sc-hero-h1    { font-size: 2rem; }
}

/* ── TV / 4K SCREENS ≥ 1920px ───────────────────────────────── */
@media (min-width: 1920px) {
  .sc-wrap { max-width: 1560px; }
  .sc-section { padding: 130px 0; }
  .sc-hero-h1 { font-size: 6rem; }
  .sc-courses-grid { grid-template-columns: repeat(4,1fr); }
  .sc-tools-grid   { grid-template-columns: repeat(5,1fr); }
}

@media (min-width: 2560px) {
  .sc-wrap { max-width: 1920px; }
  .sc-hero-h1 { font-size: 7.5rem; }
  body { font-size: 18px; }
}

/* ── ACCESSIBILITY ────────────────────────────────────────────── */
:focus-visible { outline: 2px solid var(--gold); outline-offset: 3px; }
.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}

/* ── WORDPRESS ADMIN BAR ─────────────────────────────────────── */
@media screen and (min-width: 783px) { body.admin-bar .sc-nav { top: 32px; } }
@media screen and (max-width: 782px) { body.admin-bar .sc-nav { top: 46px; } }

