/* ══════════════════════════════════════════════════
   MASTERIA v3 — Light Theme · Premium Education
   ══════════════════════════════════════════════════ */

:root {
  --bg: #fafbfd;
  --bg-alt: #f0f2f8;
  --bg-card: #ffffff;
  --bg-glass: rgba(255,255,255,0.7);
  --bg-dark: #0c1222;

  --gold: #b8952a;
  --gold-light: #d4af37;
  --gold-bright: #e8c84a;
  --blue: #2563eb;
  --blue-light: #3b82f6;
  --purple: #7c3aed;
  --green: #16a34a;
  --red: #dc2626;

  --text-primary: #0c1222;
  --text-secondary: #4b5068;
  --text-muted: #868ca3;

  --border: rgba(0,0,0,0.07);
  --border-hover: rgba(0,0,0,0.13);
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.04), 0 1px 2px rgba(0,0,0,0.03);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.06), 0 1px 3px rgba(0,0,0,0.04);
  --shadow-lg: 0 12px 40px rgba(0,0,0,0.08), 0 4px 12px rgba(0,0,0,0.04);
  --shadow-glow-gold: 0 8px 32px rgba(184,149,42,0.18);

  --font-display: 'Outfit', sans-serif;
  --font-body: 'Plus Jakarta Sans', sans-serif;
  --max-w: 1200px;
  --section-py: clamp(80px, 12vw, 160px);
  --section-px: clamp(20px, 5vw, 80px);
  --radius: 20px;
  --radius-sm: 12px;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }
body {
  font-family: var(--font-body); background: var(--bg);
  color: var(--text-primary); line-height: 1.6; overflow-x: hidden;
}
img, svg { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
ul { list-style:none; }

.container { max-width: var(--max-w); margin: 0 auto; padding: 0 var(--section-px); }
.gold-text {
  background: linear-gradient(135deg, var(--gold), var(--gold-bright), var(--gold-light));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.gradient-text {
  background: linear-gradient(135deg, #2563eb, #7c3aed, #db2777);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.gradient-blue {
  background: linear-gradient(135deg, #2563eb, #06b6d4, #3b82f6);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.gradient-warm {
  background: linear-gradient(135deg, #2563eb, #7c3aed, #f97316);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.gradient-royal {
  background: linear-gradient(135deg, #3b82f6, #8b5cf6, #ec4899, #f97316);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}

/* ── Particles ── */
#particles-canvas { position: fixed; inset: 0; z-index: 0; pointer-events: none; }

/* ── Scroll reveal ── */
.reveal {
  opacity: 0; transform: translateY(32px);
  transition: opacity .8s cubic-bezier(.16,1,.3,1), transform .8s cubic-bezier(.16,1,.3,1);
}
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-d1 { transition-delay:.08s } .reveal-d2 { transition-delay:.16s }
.reveal-d3 { transition-delay:.24s } .reveal-d4 { transition-delay:.32s }
.reveal-d5 { transition-delay:.40s } .reveal-d6 { transition-delay:.48s }

/* ═══════ NAV ═══════ */
.nav {
  position: fixed; top:0; left:0; right:0; z-index:100;
  padding: 0 var(--section-px); height: 72px;
  display: flex; align-items: center;
  background: rgba(250,251,253,0.6);
  backdrop-filter: blur(32px) saturate(1.5);
  -webkit-backdrop-filter: blur(32px) saturate(1.5);
  border-bottom: 1px solid transparent;
  transition: background .4s, border-color .4s, box-shadow .4s;
}
.nav.scrolled {
  background: rgba(250,251,253,0.92);
  border-bottom-color: var(--border);
  box-shadow: 0 1px 8px rgba(0,0,0,0.04);
}
.nav-inner {
  max-width: var(--max-w); margin: 0 auto; width: 100%;
  display: flex; align-items: center; justify-content: space-between;
}
.nav-logo {
  font-family: var(--font-display); font-weight: 800;
  font-size: 22px; letter-spacing: 2px; text-transform: uppercase;
}
.nav-logo span { color: var(--gold); }
.nav-links { display: flex; align-items: center; gap: 32px; }
.nav-links a {
  font-size: 14px; font-weight: 500; color: var(--text-secondary);
  transition: color .25s;
}
.nav-links a:hover { color: var(--text-primary); }
.nav-cta {
  font-size: 14px !important; font-weight: 600 !important;
  color: #fff !important;
  background: linear-gradient(135deg, #2563eb, #3b82f6);
  padding: 10px 24px; border-radius: 100px;
  transition: transform .25s, box-shadow .25s;
}
.nav-cta:hover { transform: translateY(-1px); box-shadow: 0 4px 24px rgba(37,99,235,0.25); }
.nav-menu-btn {
  display:none; background:none; border:none; cursor:pointer;
  width:32px; height:32px;
  flex-direction:column; justify-content:center; align-items:center; gap:6px;
}
.nav-menu-btn span {
  display:block; width:22px; height:2px; background:var(--text-primary);
  border-radius:2px; transition:transform .3s, opacity .3s;
}

/* ═══════ BUTTONS ═══════ */
.btn-glow {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-body); font-size: 16px; font-weight: 600;
  padding: 16px 36px; border-radius: 100px; border: none; cursor: pointer;
  transition: transform .3s, box-shadow .3s;
}
.btn-glow.primary {
  color: #fff;
  background: linear-gradient(135deg, var(--gold), var(--gold-bright));
  box-shadow: var(--shadow-md);
}
.btn-glow.primary:hover { transform: translateY(-2px); box-shadow: var(--shadow-glow-gold); }
.btn-glow.secondary {
  color: var(--text-primary); background: var(--bg-card);
  border: 1px solid var(--border); box-shadow: var(--shadow-sm);
}
.btn-glow.secondary:hover { transform:translateY(-2px); box-shadow:var(--shadow-md); border-color:var(--border-hover); }

/* ═══════ HERO ═══════ */
.hero {
  position: relative; min-height: 100vh;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 120px var(--section-px) 60px;
  overflow: hidden; text-align: center;
}
.hero-glow {
  position: absolute; top: -15%; left: 50%; transform: translateX(-50%);
  width: 900px; height: 600px; border-radius: 50%;
  background: radial-gradient(ellipse, rgba(37,99,235,0.06) 0%, rgba(124,58,237,0.04) 40%, transparent 70%);
  filter: blur(50px); animation: heroFloat 12s ease-in-out infinite; pointer-events: none;
}
.hero-glow-gold {
  position: absolute; bottom: 10%; right: 20%;
  width: 500px; height: 400px; border-radius: 50%;
  background: radial-gradient(ellipse, rgba(184,149,42,0.06) 0%, transparent 70%);
  filter: blur(50px); animation: heroFloat 10s ease-in-out infinite reverse; pointer-events: none;
}
@keyframes heroFloat {
  0%,100% { transform: translateX(-50%) scale(1) translateY(0); }
  50% { transform: translateX(-50%) scale(1.08) translateY(-15px); }
}
.hero-content { position: relative; z-index: 2; max-width: 860px; }
.hero-badge {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 13px; font-weight: 600; color: var(--blue);
  letter-spacing: .1em; text-transform: uppercase;
  margin-bottom: 28px; padding: 10px 22px;
  border: 1px solid rgba(37,99,235,0.18);
  border-radius: 100px; background: rgba(37,99,235,0.05);
}
.hero-badge-dot {
  width: 7px; height: 7px; background: var(--blue);
  border-radius: 50%; animation: pulse 2s ease-in-out infinite;
}
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.35} }
.hero h1 {
  font-family: var(--font-display);
  font-size: clamp(40px, 6vw, 76px); font-weight: 800;
  line-height: 1.08; letter-spacing: -.035em; margin-bottom: 24px;
}
.hero-sub {
  font-size: clamp(16px, 2vw, 19px); color: var(--text-secondary);
  max-width: 620px; margin: 0 auto 44px; line-height: 1.75;
}
.hero-btns { display:flex; align-items:center; justify-content:center; gap:16px; flex-wrap:wrap; }

/* Hero mockup */
.hero-mockup { margin-top: 72px; perspective: 1200px; position: relative; z-index: 2; }
.hero-mockup-inner {
  transform: rotateX(6deg);
  transition: transform .6s cubic-bezier(.16,1,.3,1);
  border-radius: 20px; overflow: hidden;
  border: 1px solid var(--border);
  background: var(--bg-card);
  box-shadow: var(--shadow-lg);
  padding: 28px;
}
.hero-mockup:hover .hero-mockup-inner { transform: rotateX(2deg); }
.mockup-topbar {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:20px; padding-bottom:14px; border-bottom:1px solid var(--border);
}
.mockup-dots { display:flex; gap:7px; }
.mockup-dot { width:10px; height:10px; border-radius:50%; }
.mockup-dot.r { background:#ef4444; } .mockup-dot.y { background:#eab308; } .mockup-dot.g { background:#22c55e; }
.mockup-tabs { display:flex; gap:4px; }
.mockup-tab {
  padding:6px 14px; border-radius:8px;
  font-size:12px; font-weight:500; color:var(--text-muted);
}
.mockup-tab.active { background:var(--bg-alt); color:var(--text-primary); }
.mockup-body { display:grid; grid-template-columns:1fr 1.6fr .8fr; gap:14px; }
.mockup-panel {
  border-radius:14px; padding:18px;
  background:var(--bg-alt); border:1px solid var(--border);
}
.mockup-panel-title {
  font-size:11px; font-weight:600; color:var(--text-muted);
  text-transform:uppercase; letter-spacing:.08em; margin-bottom:12px;
}
.mockup-stat-row { display:flex; align-items:baseline; gap:8px; margin-bottom:10px; }
.mockup-stat-big { font-family:var(--font-display); font-size:26px; font-weight:700; }
.mockup-stat-badge {
  font-size:11px; font-weight:600; padding:3px 8px;
  border-radius:6px; background:rgba(22,163,74,0.1); color:var(--green);
}
.mockup-mini-card {
  padding:12px; border-radius:10px; margin-bottom:8px;
  background:var(--bg-card); border:1px solid var(--border);
}
.mockup-mini-label { font-size:11px; color:var(--text-muted); margin-bottom:3px; }
.mockup-mini-val { font-family:var(--font-display); font-size:17px; font-weight:600; }
.mockup-chart-line { width:100%; height:80px; }

/* Hero stats */
.hero-stats {
  margin-top:44px; display:flex; justify-content:center; gap:48px;
  flex-wrap:wrap; position:relative; z-index:2;
}
.hero-stat { text-align:center; }
.hero-stat-val { font-family:var(--font-display); font-size:38px; font-weight:700; }
.hero-stat-label {
  font-size:12px; color:var(--text-muted); margin-top:4px;
  text-transform:uppercase; letter-spacing:.08em;
}

/* ═══════ SECTION SHARED ═══════ */
.section { padding: var(--section-py) 0; position: relative; z-index: 1; }
.section.alt { background: var(--bg-alt); }
.section-label {
  font-size:12px; font-weight:700; text-transform:uppercase;
  letter-spacing:.15em; color:var(--blue); margin-bottom:14px;
}
.section-label.gold { color:var(--gold); }
.section-title {
  font-family:var(--font-display);
  font-size:clamp(32px,4.5vw,52px); font-weight:700;
  line-height:1.14; letter-spacing:-.025em; margin-bottom:18px;
}
.section-desc {
  font-size:clamp(16px,1.6vw,18px); color:var(--text-secondary);
  max-width:560px; line-height:1.75;
}
.section-sep {
  width:100%; height:1px; position:relative; z-index:1;
  background: linear-gradient(90deg, transparent, var(--border), transparent);
}

/* ═══════ WHY INVEST ═══════ */
.why-grid {
  margin-top:56px; display:grid;
  grid-template-columns:1fr 1fr; gap:24px;
}
.why-card {
  border-radius:var(--radius); padding:40px 36px;
  background:var(--bg-card); border:1px solid var(--border);
  box-shadow:var(--shadow-sm);
  transition:transform .3s, box-shadow .3s;
}
.why-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); }
.why-card.wide { grid-column: span 2; }
.why-card h3 {
  font-family:var(--font-display); font-size:22px; font-weight:600;
  margin-bottom:12px; line-height:1.35;
}
.why-card p { font-size:15px; color:var(--text-secondary); line-height:1.7; }
.why-stat-row {
  display:flex; gap:40px; margin-top:20px; flex-wrap:wrap;
}
.why-stat-item { text-align:center; }
.why-stat-big {
  font-family:var(--font-display); font-size:36px; font-weight:800;
  line-height:1;
}
.why-stat-big.red { color:var(--red); }
.why-stat-big.gold { color:var(--gold); }
.why-stat-sub { font-size:13px; color:var(--text-muted); margin-top:4px; }

/* ═══════ PROBLEM — Bento ═══════ */
.problem-bento {
  margin-top:56px; display:grid;
  grid-template-columns:1fr 1fr 1fr; grid-template-rows:auto auto; gap:20px;
}
.bento-card {
  border-radius:var(--radius); padding:36px 32px;
  border:1px solid var(--border); background:var(--bg-card);
  box-shadow:var(--shadow-md); position:relative; overflow:hidden;
  transition:transform .35s, box-shadow .35s;
}
.bento-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-lg); }
.bento-card.card-accent {
  grid-column:span 2;
  background:linear-gradient(135deg, rgba(37,99,235,0.07), rgba(124,58,237,0.05));
  border-color:rgba(37,99,235,0.15);
}
.bento-card.card-gold {
  background:linear-gradient(135deg, rgba(184,149,42,0.08), rgba(184,149,42,0.03));
  border-color:rgba(184,149,42,0.15);
}
.bento-num {
  font-family:var(--font-display); font-size:52px; font-weight:800;
  line-height:1; margin-bottom:16px;
}
.bento-card.card-accent .bento-num {
  background:linear-gradient(135deg, #2563eb, #7c3aed);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  opacity:0.6;
}
.bento-card .bento-num {
  background:linear-gradient(135deg, #2563eb, #3b82f6);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  opacity:0.5;
}
.bento-card.card-gold .bento-num {
  background:linear-gradient(135deg, #b8952a, #d4af37);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  opacity:0.6;
}
.bento-card h3 {
  font-family:var(--font-display); font-size:20px; font-weight:700;
  margin-bottom:12px; line-height:1.35;
}
.bento-card p { font-size:15px; color:var(--text-secondary); line-height:1.7; }

.problem-insight {
  margin-top:36px; padding:28px 36px; border-radius:var(--radius);
  background:var(--bg-card); border:1px solid rgba(184,149,42,0.12);
  box-shadow:var(--shadow-sm); position:relative; overflow:hidden;
}
.problem-insight::before {
  content:''; position:absolute; left:0; top:0; bottom:0;
  width:3px; background:linear-gradient(180deg, #2563eb, #7c3aed, #ec4899);
}
.problem-insight p { font-size:17px; font-weight:500; line-height:1.7; }

/* ═══════ PROGRAMME ═══════ */
.programme-header { text-align:center; margin-bottom:56px; }
.programme-header .section-desc { margin:0 auto; }
.modules-grid {
  display:grid; grid-template-columns:repeat(auto-fill, minmax(340px, 1fr)); gap:14px;
}
.module-card {
  position:relative; padding:26px 22px;
  border-radius:var(--radius-sm); background:var(--bg-card);
  border:1px solid var(--border); box-shadow:var(--shadow-sm);
  display:flex; gap:16px; overflow:hidden;
  transition:transform .3s, box-shadow .3s;
}
.module-card:hover { transform:translateY(-2px); box-shadow:var(--shadow-md); }
.module-num {
  flex-shrink:0; width:42px; height:42px; border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-size:15px; font-weight:700;
  background:rgba(37,99,235,0.06); color:var(--blue);
  border:1px solid rgba(37,99,235,0.1);
}
.module-body h3 {
  font-family:var(--font-display); font-size:15px; font-weight:600; line-height:1.45;
}
.module-card.bonus {
  grid-column:1/-1;
  border-color:rgba(37,99,235,0.12);
  background:linear-gradient(135deg, rgba(37,99,235,0.04), rgba(124,58,237,0.02));
}
.module-card.bonus .module-num {
  background:linear-gradient(135deg, #2563eb, #7c3aed);
  color:#fff; border:none;
}

/* ═══════ INCLUDES ═══════ */
.includes-grid {
  margin-top:56px; display:grid;
  grid-template-columns:repeat(2, 1fr); gap:20px;
}
.include-card {
  border-radius:var(--radius); padding:36px 32px;
  background:var(--bg-card); border:1px solid var(--border);
  box-shadow:var(--shadow-sm); transition:transform .3s, box-shadow .3s;
}
.include-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); }
.include-icon {
  width:48px; height:48px; border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  margin-bottom:18px; font-size:22px;
}
.include-icon.gold { background:rgba(184,149,42,0.08); }
.include-icon.blue { background:rgba(37,99,235,0.06); }
.include-icon.purple { background:rgba(124,58,237,0.06); }
.include-icon.green { background:rgba(22,163,74,0.06); }
.include-card h3 {
  font-family:var(--font-display); font-size:20px; font-weight:600; margin-bottom:10px;
}
.include-card p { font-size:15px; color:var(--text-secondary); line-height:1.7; }

/* ═══════ MASTERY — Bento ═══════ */
.mastery-bento {
  margin-top:56px; display:grid;
  grid-template-columns:1fr 1fr; grid-template-rows:auto auto; gap:20px;
}
.mastery-card {
  border-radius:var(--radius); padding:40px 36px;
  border:1px solid var(--border); background:var(--bg-card);
  box-shadow:var(--shadow-sm); transition:transform .35s, box-shadow .35s;
}
.mastery-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); }
.mastery-card.featured {
  grid-row:span 2;
  background:linear-gradient(160deg, rgba(37,99,235,0.06), rgba(124,58,237,0.04) 60%, rgba(184,149,42,0.03));
  border-color:rgba(37,99,235,0.1);
  display:flex; flex-direction:column; justify-content:flex-end;
}
.mastery-icon {
  width:48px; height:48px; border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  margin-bottom:18px; background:rgba(184,149,42,0.06);
  border:1px solid rgba(184,149,42,0.1);
}
.mastery-icon svg {
  width:22px; height:22px; stroke:var(--gold);
  fill:none; stroke-width:1.5; stroke-linecap:round; stroke-linejoin:round;
}
.mastery-icon i { color:var(--gold); }
.mastery-icon.blue { background:rgba(37,99,235,0.06); border-color:rgba(37,99,235,0.1); }
.mastery-icon.blue svg { stroke:var(--blue); }
.mastery-icon.blue i { color:var(--blue); }
.mastery-card h3 { font-family:var(--font-display); font-size:20px; font-weight:600; margin-bottom:10px; line-height:1.3; }
.mastery-card.featured h3 { font-size:26px; }
.mastery-card p { font-size:15px; color:var(--text-secondary); line-height:1.7; }

/* ═══════ JOURNEY ═══════ */
.journey-header { text-align:center; margin-bottom:64px; }
.journey-header .section-desc { margin:0 auto; }
.journey-grid {
  display:grid; grid-template-columns:repeat(4, 1fr); gap:20px;
  max-width:1100px; margin:0 auto;
}
.journey-card {
  border-radius:var(--radius); padding:36px 28px;
  background:var(--bg-card); border:1px solid var(--border);
  box-shadow:var(--shadow-sm); position:relative; overflow:hidden;
  transition:transform .35s, box-shadow .35s;
}
.journey-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); }
.journey-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg, #2563eb, #7c3aed, #ec4899);
  opacity:0; transition:opacity .3s;
}
.journey-card:hover::before { opacity:1; }
.journey-num {
  font-family:var(--font-display); font-size:40px; font-weight:800;
  line-height:1; margin-bottom:18px;
  background:linear-gradient(135deg, rgba(37,99,235,0.2), rgba(124,58,237,0.15));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.journey-card h3 { font-family:var(--font-display); font-size:17px; font-weight:600; margin-bottom:10px; }
.journey-card p { font-size:14px; color:var(--text-secondary); line-height:1.7; }

/* ═══════ FOR WHO ═══════ */
.for-who-grid { margin-top:56px; display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.for-who-card {
  border-radius:var(--radius); padding:40px 36px;
  background:var(--bg-card); border:1px solid var(--border);
  box-shadow:var(--shadow-sm);
}
.for-who-card h3 {
  font-family:var(--font-display); font-size:20px; font-weight:600; margin-bottom:20px;
  display:flex; align-items:center; gap:10px;
}
.for-who-card ul { display:flex; flex-direction:column; gap:12px; }
.for-who-card li {
  font-size:15px; color:var(--text-secondary); line-height:1.6;
  padding-left:24px; position:relative;
}
.for-who-card li::before {
  content:''; position:absolute; left:0; top:8px;
  width:8px; height:8px; border-radius:50%;
}
.for-who-card.yes li::before { background:var(--green); }
.for-who-card.no li::before { background:var(--red); opacity:.6; }

/* ═══════ PRICING ═══════ */
.pricing-card {
  max-width:560px; margin:56px auto 0;
  border-radius:var(--radius); padding:48px 44px;
  background:var(--bg-card); border:2px solid rgba(184,149,42,0.2);
  box-shadow:var(--shadow-lg); text-align:center;
  position:relative; overflow:hidden;
}
.pricing-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg, #2563eb, #7c3aed, #ec4899, #f97316);
}
.pricing-label {
  font-size:13px; font-weight:700; text-transform:uppercase;
  letter-spacing:.1em; color:var(--blue); margin-bottom:8px;
}
.pricing-title {
  font-family:var(--font-display); font-size:24px; font-weight:700; margin-bottom:4px;
}
.pricing-sub { font-size:14px; color:var(--text-muted); margin-bottom:28px; }
.pricing-amount {
  display:flex; align-items:baseline; justify-content:center; gap:12px;
  margin-bottom:8px;
}
.pricing-old {
  font-family:var(--font-display); font-size:24px; font-weight:500;
  text-decoration:line-through; color:var(--text-muted);
}
.pricing-current {
  font-family:var(--font-display); font-size:56px; font-weight:800;
}
.pricing-period { font-size:14px; color:var(--text-muted); margin-bottom:32px; }
.pricing-features { text-align:left; margin-bottom:32px; display:flex; flex-direction:column; gap:12px; }
.pricing-features li {
  font-size:15px; color:var(--text-secondary); line-height:1.5;
  padding-left:28px; position:relative;
}
.pricing-features li::before {
  content:'✓'; position:absolute; left:0; top:0;
  color:var(--green); font-weight:700;
}
.pricing-guarantee {
  margin-top:24px; padding:16px 20px; border-radius:var(--radius-sm);
  background:var(--bg-alt); font-size:14px; color:var(--text-secondary);
}

/* ═══════ FOUNDER ═══════ */
.founder-grid { margin-top:56px; display:grid; grid-template-columns:1fr 1.5fr; gap:40px; align-items:start; }
.founder-photo {
  border-radius:var(--radius); aspect-ratio:4/5;
  background:var(--bg-alt); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  font-size:14px; color:var(--text-muted); font-style:italic;
}
.founder-bio h3 { font-family:var(--font-display); font-size:28px; font-weight:700; margin-bottom:6px; }
.founder-role { font-size:15px; color:var(--blue); font-weight:600; margin-bottom:20px; }
.founder-bio p { font-size:15px; color:var(--text-secondary); line-height:1.75; margin-bottom:16px; }
.founder-stats { display:flex; gap:32px; margin-top:24px; flex-wrap:wrap; }
.founder-stat-val { font-family:var(--font-display); font-size:28px; font-weight:700; color:var(--blue); }
.founder-stat-label { font-size:12px; color:var(--text-muted); text-transform:uppercase; letter-spacing:.06em; }

/* ═══════ TESTIMONIALS ═══════ */
.testimonials-grid { margin-top:56px; display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.testimonial-card {
  border-radius:var(--radius); padding:32px 28px;
  background:var(--bg-card); border:1px solid var(--border);
  box-shadow:var(--shadow-sm);
}
.testimonial-stars { color:var(--gold-bright); font-size:16px; letter-spacing:2px; margin-bottom:14px; }
.testimonial-avatar {
  width:40px; height:40px; border-radius:50%;
  background:linear-gradient(135deg, #2563eb, #7c3aed);
  display:flex; align-items:center; justify-content:center;
  font-size:15px; font-weight:700; color:#fff;
}
.testimonial-text { font-size:15px; color:var(--text-secondary); line-height:1.7; margin-bottom:20px; font-style:italic; }
.testimonial-author { display:flex; align-items:center; gap:12px; }
.testimonial-avatar {
  width:40px; height:40px; border-radius:50%;
  background:linear-gradient(135deg, var(--gold), var(--blue));
  display:flex; align-items:center; justify-content:center;
  font-size:15px; font-weight:700; color:#fff;
}
.testimonial-name { font-size:14px; font-weight:600; }
.testimonial-role { font-size:12px; color:var(--text-muted); }

/* ═══════ FAQ ═══════ */
.faq-list { max-width:760px; margin:56px auto 0; display:flex; flex-direction:column; gap:12px; }
.faq-item {
  border-radius:var(--radius-sm); background:var(--bg-card);
  border:1px solid var(--border); box-shadow:var(--shadow-sm);
  overflow:hidden;
}
.faq-q {
  width:100%; padding:20px 24px;
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  font-family:var(--font-display); font-size:16px; font-weight:600;
  background:none; border:none; cursor:pointer; text-align:left;
  color:var(--text-primary); transition:color .2s;
}
.faq-q:hover { color:var(--gold); }
.faq-chevron {
  flex-shrink:0; width:20px; height:20px;
  transition:transform .3s;
}
.faq-item.open .faq-chevron { transform:rotate(180deg); }
.faq-a {
  max-height:0; overflow:hidden;
  transition:max-height .4s cubic-bezier(.16,1,.3,1), padding .3s;
  padding:0 24px;
}
.faq-item.open .faq-a { max-height:400px; padding:0 24px 20px; }
.faq-a p { font-size:15px; color:var(--text-secondary); line-height:1.7; }

/* ═══════ FINAL CTA ═══════ */
.final-cta { text-align:center; position:relative; overflow:hidden; }
.final-cta-bg {
  position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(ellipse 50% 80% at 50% 100%, rgba(184,149,42,0.05), transparent),
    radial-gradient(ellipse 40% 60% at 50% 0%, rgba(37,99,235,0.04), transparent);
}
.final-cta .container { position:relative; z-index:1; }
.final-cta .section-title { max-width:640px; margin:0 auto 18px; }
.final-cta .section-desc { max-width:500px; margin:0 auto 40px; }

/* ═══════ FOOTER ═══════ */
.footer {
  padding:60px 0 40px; border-top:1px solid var(--border);
  position:relative; z-index:1;
  background:var(--bg-alt);
}
.footer-inner {
  display:flex; align-items:center; justify-content:space-between;
  flex-wrap:wrap; gap:20px;
}
.footer-logo {
  font-family:var(--font-display); font-weight:800;
  font-size:18px; letter-spacing:2px; text-transform:uppercase;
}
.footer-logo span { color:var(--gold); }
.footer-links { display:flex; gap:24px; }
.footer-links a { font-size:14px; color:var(--text-muted); transition:color .25s; }
.footer-links a:hover { color:var(--text-secondary); }
.footer-copy { width:100%; text-align:center; margin-top:28px; font-size:13px; color:var(--text-muted); }
.footer-disclaimer {
  width:100%; text-align:center; margin-top:12px;
  font-size:11px; color:var(--text-muted); max-width:600px; margin-left:auto; margin-right:auto; line-height:1.6;
}

/* ═══════ GOLD-INCLUSIVE GRADIENTS ═══════ */
.gradient-gold-blue {
  background: linear-gradient(135deg, #d4af37, #e8c84a, #3b82f6);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.gradient-blue-gold {
  background: linear-gradient(135deg, #2563eb, #8b5cf6, #d4af37);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.gradient-gold-royal {
  background: linear-gradient(135deg, #d4af37, #e8c84a, #ec4899, #7c3aed, #2563eb);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}

/* ═══════ BEAMS BACKGROUND ═══════ */
.beams-bg {
  position:fixed; inset:0; z-index:0; pointer-events:none;
  overflow:hidden; background:var(--bg);
}
.beam {
  position:absolute;
  top:-20%;
  width:1px;
  height:140%;
  background:linear-gradient(180deg, transparent 0%, var(--beam-color) 30%, var(--beam-color) 70%, transparent 100%);
  opacity:var(--beam-opacity);
  transform-origin:top center;
  animation:beamSway var(--beam-duration) ease-in-out infinite alternate;
  filter:blur(var(--beam-blur));
}
@keyframes beamSway {
  0% { transform:rotate(var(--beam-from)) translateX(var(--beam-drift-from)); }
  100% { transform:rotate(var(--beam-to)) translateX(var(--beam-drift-to)); }
}
.beam.b1 {
  left:10%;
  --beam-color:rgba(59,130,246,0.08);
  --beam-opacity:1;
  --beam-blur:40px;
  --beam-from:-8deg; --beam-to:4deg;
  --beam-drift-from:0px; --beam-drift-to:60px;
  --beam-duration:20s;
  width:120px;
}
.beam.b2 {
  left:30%;
  --beam-color:rgba(212,175,55,0.06);
  --beam-opacity:1;
  --beam-blur:50px;
  --beam-from:3deg; --beam-to:-5deg;
  --beam-drift-from:20px; --beam-drift-to:-40px;
  --beam-duration:25s;
  width:100px;
}
.beam.b3 {
  left:55%;
  --beam-color:rgba(139,92,246,0.06);
  --beam-opacity:1;
  --beam-blur:45px;
  --beam-from:-4deg; --beam-to:6deg;
  --beam-drift-from:-30px; --beam-drift-to:30px;
  --beam-duration:18s;
  width:140px;
}
.beam.b4 {
  left:75%;
  --beam-color:rgba(59,130,246,0.07);
  --beam-opacity:1;
  --beam-blur:35px;
  --beam-from:5deg; --beam-to:-3deg;
  --beam-drift-from:10px; --beam-drift-to:-50px;
  --beam-duration:22s;
  width:90px;
}
.beam.b5 {
  left:90%;
  --beam-color:rgba(212,175,55,0.05);
  --beam-opacity:1;
  --beam-blur:55px;
  --beam-from:-6deg; --beam-to:2deg;
  --beam-drift-from:-20px; --beam-drift-to:40px;
  --beam-duration:28s;
  width:110px;
}
.beam.b6 {
  left:20%;
  --beam-color:rgba(6,182,212,0.04);
  --beam-opacity:1;
  --beam-blur:60px;
  --beam-from:2deg; --beam-to:-4deg;
  --beam-drift-from:40px; --beam-drift-to:-20px;
  --beam-duration:32s;
  width:160px;
}
.beam.b7 {
  left:45%;
  --beam-color:rgba(59,130,246,0.05);
  --beam-opacity:1;
  --beam-blur:50px;
  --beam-from:-3deg; --beam-to:5deg;
  --beam-drift-from:-10px; --beam-drift-to:50px;
  --beam-duration:26s;
  width:80px;
}
.beam.b8 {
  left:65%;
  --beam-color:rgba(184,149,42,0.05);
  --beam-opacity:1;
  --beam-blur:42px;
  --beam-from:4deg; --beam-to:-6deg;
  --beam-drift-from:30px; --beam-drift-to:-30px;
  --beam-duration:30s;
  width:130px;
}

/* ═══════ SHAPE LANDING ANIMATION ═══════ */
.shapes-container {
  position:absolute; inset:0; overflow:hidden;
  pointer-events:none; z-index:0;
}
.shape {
  position:absolute;
  opacity:0.12;
  will-change:transform;
}
.shape.circle {
  border-radius:50%;
  border:2px solid;
}
.shape.square {
  border-radius:16px;
  border:2px solid;
}
.shape.diamond {
  border-radius:8px;
  border:2px solid;
  transform:rotate(45deg);
}
.shape.filled {
  border:none;
  opacity:0.06;
}
/* Shape instances */
.shape.sh1 {
  width:80px; height:80px; top:8%; left:8%;
  border-color:rgba(59,130,246,0.6);
  animation:shapeFloat1 28s ease-in-out infinite;
}
.shape.sh2 {
  width:120px; height:120px; top:20%; right:12%;
  border-color:rgba(212,175,55,0.5);
  animation:shapeFloat2 36s ease-in-out infinite;
}
.shape.sh3 {
  width:60px; height:60px; bottom:25%; left:15%;
  border-color:rgba(139,92,246,0.5);
  animation:shapeFloat3 24s ease-in-out infinite;
}
.shape.sh4 {
  width:100px; height:100px; bottom:15%; right:20%;
  background:rgba(59,130,246,0.08);
  animation:shapeFloat4 40s ease-in-out infinite;
}
.shape.sh5 {
  width:50px; height:50px; top:55%; left:5%;
  border-color:rgba(6,182,212,0.5);
  animation:shapeFloat1 32s ease-in-out infinite reverse;
}
.shape.sh6 {
  width:90px; height:90px; top:10%; left:55%;
  background:rgba(212,175,55,0.06);
  animation:shapeFloat2 44s ease-in-out infinite reverse;
}
.shape.sh7 {
  width:70px; height:70px; bottom:30%; right:8%;
  border-color:rgba(124,58,237,0.4);
  animation:shapeFloat3 30s ease-in-out infinite reverse;
}
.shape.sh8 {
  width:40px; height:40px; top:40%; right:35%;
  border-color:rgba(59,130,246,0.4);
  animation:shapeFloat4 22s ease-in-out infinite;
}
@keyframes shapeFloat1 {
  0%,100% { transform:translate(0,0) rotate(0deg) scale(1); }
  25% { transform:translate(20px,-30px) rotate(45deg) scale(1.1); }
  50% { transform:translate(-15px,-50px) rotate(90deg) scale(0.95); }
  75% { transform:translate(30px,-20px) rotate(135deg) scale(1.05); }
}
@keyframes shapeFloat2 {
  0%,100% { transform:translate(0,0) rotate(0deg); }
  33% { transform:translate(-40px,30px) rotate(-30deg); }
  66% { transform:translate(20px,-40px) rotate(20deg); }
}
@keyframes shapeFloat3 {
  0%,100% { transform:translate(0,0) scale(1) rotate(0deg); }
  50% { transform:translate(30px,40px) scale(1.15) rotate(60deg); }
}
@keyframes shapeFloat4 {
  0%,100% { transform:translate(0,0) rotate(0deg) scale(1); }
  25% { transform:translate(-20px,-25px) rotate(15deg) scale(1.08); }
  75% { transform:translate(25px,15px) rotate(-15deg) scale(0.92); }
}
@keyframes floatA {
  0%,100% { transform:translate(0,0) scale(1); }
  33% { transform:translate(40px,-30px) scale(1.1); }
  66% { transform:translate(-20px,40px) scale(0.95); }
}
@keyframes floatB {
  0%,100% { transform:translate(0,0) scale(1); }
  50% { transform:translate(-50px,30px) scale(1.15); }
}
@keyframes floatC {
  0%,100% { transform:translate(0,0) rotate(0deg); }
  50% { transform:translate(30px,-40px) rotate(10deg); }
}

/* ═══════ LIQUID GLASS BUTTON ═══════ */
.btn-liquid {
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-body); font-size:17px; font-weight:600;
  padding:18px 40px; border-radius:100px; border:none; cursor:pointer;
  color:var(--text-primary);
  background:rgba(255,255,255,0.45);
  backdrop-filter:blur(20px) saturate(1.6);
  -webkit-backdrop-filter:blur(20px) saturate(1.6);
  border:1px solid rgba(255,255,255,0.5);
  box-shadow:
    0 4px 24px rgba(0,0,0,0.06),
    inset 0 1px 0 rgba(255,255,255,0.7),
    inset 0 -1px 0 rgba(0,0,0,0.04);
  position:relative; overflow:hidden;
  transition:transform .3s, box-shadow .3s, background .3s;
}
.btn-liquid::before {
  content:''; position:absolute;
  top:-50%; left:-50%; width:200%; height:200%;
  background:linear-gradient(
    105deg,
    transparent 40%,
    rgba(255,255,255,0.5) 45%,
    rgba(255,255,255,0.7) 50%,
    rgba(255,255,255,0.5) 55%,
    transparent 60%
  );
  animation:liquidShine 4s ease-in-out infinite;
  pointer-events:none;
}
@keyframes liquidShine {
  0% { transform:translateX(-80%) rotate(25deg); }
  100% { transform:translateX(80%) rotate(25deg); }
}
.btn-liquid:hover {
  transform:translateY(-2px);
  background:rgba(255,255,255,0.6);
  box-shadow:
    0 8px 32px rgba(0,0,0,0.08),
    inset 0 1px 0 rgba(255,255,255,0.8),
    inset 0 -1px 0 rgba(0,0,0,0.04);
}

/* ═══════ NEON BUTTON ═══════ */
.btn-neon {
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-body); font-size:17px; font-weight:700;
  padding:18px 40px; border-radius:100px; cursor:pointer;
  color:#fff; background:transparent;
  border:2px solid var(--blue);
  position:relative; overflow:hidden;
  text-shadow:0 0 8px rgba(37,99,235,0.4);
  box-shadow:
    0 0 12px rgba(37,99,235,0.2),
    inset 0 0 12px rgba(37,99,235,0.08);
  transition:transform .3s, box-shadow .3s, background .3s, color .3s;
}
.btn-neon::before {
  content:''; position:absolute; inset:-2px;
  border-radius:inherit;
  background:linear-gradient(135deg, #2563eb, #7c3aed, #ec4899, #2563eb);
  background-size:300% 300%;
  animation:neonBorder 3s ease infinite;
  z-index:-1; opacity:0;
  transition:opacity .3s;
}
.btn-neon::after {
  content:''; position:absolute; inset:0;
  border-radius:inherit;
  background:var(--bg-dark);
  z-index:-1;
}
@keyframes neonBorder {
  0%{background-position:0% 50%} 50%{background-position:100% 50%} 100%{background-position:0% 50%}
}
.btn-neon:hover {
  transform:translateY(-2px);
  color:#fff;
  text-shadow:0 0 16px rgba(37,99,235,0.6);
  box-shadow:
    0 0 24px rgba(37,99,235,0.35),
    0 0 48px rgba(124,58,237,0.15),
    inset 0 0 16px rgba(37,99,235,0.12);
}
.btn-neon:hover::before { opacity:1; }

/* Light-bg neon variant */
.btn-neon.light {
  color:var(--blue); background:transparent;
  border-color:var(--blue);
  text-shadow:none;
}
.btn-neon.light::after { background:var(--bg); }
.btn-neon.light:hover {
  color:#fff; background:transparent;
  text-shadow:0 0 12px rgba(37,99,235,0.5);
}
.btn-neon.light:hover::after {
  background:linear-gradient(135deg, rgba(37,99,235,0.9), rgba(124,58,237,0.85));
}

/* ═══════ VARIED ENTRY ANIMATIONS ═══════ */
.reveal-left {
  opacity:0; transform:translateX(-50px);
  transition:opacity .8s cubic-bezier(.16,1,.3,1), transform .8s cubic-bezier(.16,1,.3,1);
}
.reveal-left.visible { opacity:1; transform:translateX(0); }
.reveal-right {
  opacity:0; transform:translateX(50px);
  transition:opacity .8s cubic-bezier(.16,1,.3,1), transform .8s cubic-bezier(.16,1,.3,1);
}
.reveal-right.visible { opacity:1; transform:translateX(0); }
.reveal-scale {
  opacity:0; transform:scale(0.88);
  transition:opacity .8s cubic-bezier(.16,1,.3,1), transform .8s cubic-bezier(.16,1,.3,1);
}
.reveal-scale.visible { opacity:1; transform:scale(1); }
.reveal-flip {
  opacity:0; transform:perspective(800px) rotateY(12deg) translateX(20px);
  transition:opacity .9s cubic-bezier(.16,1,.3,1), transform .9s cubic-bezier(.16,1,.3,1);
}
.reveal-flip.visible { opacity:1; transform:perspective(800px) rotateY(0) translateX(0); }
.reveal-up-big {
  opacity:0; transform:translateY(60px);
  transition:opacity .9s cubic-bezier(.16,1,.3,1), transform .9s cubic-bezier(.16,1,.3,1);
}
.reveal-up-big.visible { opacity:1; transform:translateY(0); }

/* ═══════ TESTIMONIALS MARQUEE ═══════ */
.testimonials-marquee {
  overflow:hidden; position:relative;
  mask-image:linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
  -webkit-mask-image:linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
}
.marquee-track {
  display:flex; gap:20px; width:max-content;
  animation:marqueeScroll 35s linear infinite;
}
.marquee-track:hover { animation-play-state:paused; }
@keyframes marqueeScroll {
  0% { transform:translateX(0); }
  100% { transform:translateX(-50%); }
}
.testimonial-card {
  flex-shrink:0; width:380px;
  border-radius:var(--radius); padding:32px 28px;
  background:var(--bg-card); border:1px solid var(--border);
  box-shadow:var(--shadow-sm);
}

/* ═══════ RESPONSIVE ═══════ */
@media(max-width:1024px){
  .journey-grid{grid-template-columns:repeat(2,1fr)}
  .mockup-body{grid-template-columns:1fr 1fr}
  .mockup-body>:last-child{display:none}
}
@media(max-width:900px){
  .nav-links{display:none}
  .nav-menu-btn{display:flex}
  .nav-links.open{
    display:flex;flex-direction:column;
    position:fixed;inset:0;
    background:rgba(250,251,253,0.97);backdrop-filter:blur(24px);
    justify-content:center;align-items:center;
    gap:28px;z-index:200;
  }
  .nav-links.open a{font-size:20px}
  .problem-bento{grid-template-columns:1fr}
  .bento-card.card-accent{grid-column:span 1}
  .mastery-bento{grid-template-columns:1fr}
  .mastery-card.featured{grid-row:span 1}
  .modules-grid{grid-template-columns:1fr}
  .includes-grid{grid-template-columns:1fr}
  .for-who-grid{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr}
  .why-card.wide{grid-column:span 1}
  .founder-grid{grid-template-columns:1fr}
  .testimonials-grid{grid-template-columns:1fr}
  .hero-mockup-inner{padding:20px;transform:rotateX(3deg)}
  .mockup-body{grid-template-columns:1fr}
  .mockup-body>:nth-child(n+2){display:none}
}
@media(max-width:600px){
  .journey-grid{grid-template-columns:1fr}
  .hero h1{font-size:34px}
  .hero-btns{flex-direction:column}
  .btn-glow{width:100%;justify-content:center}
  .hero-stats{gap:24px}
  .hero-stat-val{font-size:30px}
  .pricing-card{padding:32px 24px}
  .pricing-current{font-size:44px}
  .timeline-grid{grid-template-columns:1fr}
  .timeline-grid::before{display:none}
  .perf-grid{grid-template-columns:1fr}
  .brique-grid{grid-template-columns:1fr !important}
}

/* ══════════════════════════════════════════════════
   FUSION — Module7 Presentation Elements (Light)
   ══════════════════════════════════════════════════ */

/* Extended palette */
:root {
  --emerald: #10b981;
  --violet: #8b5cf6;
  --fuchsia: #d946ef;
  --amber: #f59e0b;
  --rose: #f43f5e;
}

/* ── Hero badge pill (from Module7) ── */
.hero-badge-pill {
  display:inline-flex; align-items:center; gap:10px;
  font-size:13px; font-weight:700; letter-spacing:.12em;
  text-transform:uppercase; padding:10px 24px;
  border-radius:100px; margin-bottom:32px;
  background:linear-gradient(135deg, rgba(184,149,42,0.08), rgba(37,99,235,0.06), rgba(139,92,246,0.05));
  border:1px solid rgba(184,149,42,0.18);
  color:var(--gold);
}
.hero-badge-pill i { font-size:14px; }

/* ── Brique-style colored module cards ── */
.brique-grid {
  display:grid; grid-template-columns:repeat(2, 1fr); gap:16px;
  margin-top:48px;
}
.brique-card {
  border-radius:var(--radius); padding:28px 26px;
  background:var(--bg-card); border:1px solid var(--border);
  box-shadow:var(--shadow-sm);
  display:flex; gap:18px; align-items:flex-start;
  transition:transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s, border-color .35s;
  position:relative; overflow:hidden;
}
.brique-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); }
.brique-icon {
  width:48px; height:48px; border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  font-size:20px; flex-shrink:0;
}
.brique-card h3 {
  font-family:var(--font-display); font-size:15px; font-weight:600; line-height:1.45;
}
.brique-card .brique-tag {
  font-size:10px; font-weight:700; text-transform:uppercase;
  letter-spacing:.1em; margin-bottom:6px; display:block;
}

/* Color variants */
.brique-card.c-emerald { border-color:rgba(16,185,129,0.15); background:linear-gradient(135deg, rgba(16,185,129,0.03), var(--bg-card)); }
.brique-card.c-emerald .brique-icon { background:rgba(16,185,129,0.08); color:#10b981; }
.brique-card.c-emerald:hover { border-color:rgba(16,185,129,0.3); }
.brique-card.c-emerald .brique-tag { color:#10b981; }

.brique-card.c-blue { border-color:rgba(37,99,235,0.15); background:linear-gradient(135deg, rgba(37,99,235,0.03), var(--bg-card)); }
.brique-card.c-blue .brique-icon { background:rgba(37,99,235,0.08); color:#2563eb; }
.brique-card.c-blue:hover { border-color:rgba(37,99,235,0.3); }
.brique-card.c-blue .brique-tag { color:#2563eb; }

.brique-card.c-violet { border-color:rgba(139,92,246,0.15); background:linear-gradient(135deg, rgba(139,92,246,0.03), var(--bg-card)); }
.brique-card.c-violet .brique-icon { background:rgba(139,92,246,0.08); color:#8b5cf6; }
.brique-card.c-violet:hover { border-color:rgba(139,92,246,0.3); }
.brique-card.c-violet .brique-tag { color:#8b5cf6; }

.brique-card.c-fuchsia { border-color:rgba(217,70,239,0.15); background:linear-gradient(135deg, rgba(217,70,239,0.03), var(--bg-card)); }
.brique-card.c-fuchsia .brique-icon { background:rgba(217,70,239,0.08); color:#d946ef; }
.brique-card.c-fuchsia:hover { border-color:rgba(217,70,239,0.3); }
.brique-card.c-fuchsia .brique-tag { color:#d946ef; }

.brique-card.c-amber { border-color:rgba(245,158,11,0.15); background:linear-gradient(135deg, rgba(245,158,11,0.03), var(--bg-card)); }
.brique-card.c-amber .brique-icon { background:rgba(245,158,11,0.08); color:#f59e0b; }
.brique-card.c-amber:hover { border-color:rgba(245,158,11,0.3); }
.brique-card.c-amber .brique-tag { color:#f59e0b; }

.brique-card.c-gold { border-color:rgba(184,149,42,0.15); background:linear-gradient(135deg, rgba(184,149,42,0.04), var(--bg-card)); }
.brique-card.c-gold .brique-icon { background:rgba(184,149,42,0.08); color:#b8952a; }
.brique-card.c-gold:hover { border-color:rgba(184,149,42,0.3); }
.brique-card.c-gold .brique-tag { color:#b8952a; }

.brique-card.c-rose { border-color:rgba(244,63,94,0.15); background:linear-gradient(135deg, rgba(244,63,94,0.03), var(--bg-card)); }
.brique-card.c-rose .brique-icon { background:rgba(244,63,94,0.08); color:#f43f5e; }
.brique-card.c-rose:hover { border-color:rgba(244,63,94,0.3); }
.brique-card.c-rose .brique-tag { color:#f43f5e; }

/* Bonus card spanning full width */
.brique-card.bonus-wide {
  grid-column:1/-1;
  background:linear-gradient(135deg, rgba(37,99,235,0.04), rgba(139,92,246,0.03), rgba(184,149,42,0.03));
  border-color:rgba(37,99,235,0.12);
}
.brique-card.bonus-wide .brique-icon {
  background:linear-gradient(135deg, #2563eb, #7c3aed);
  color:#fff;
}

/* ── Timeline (from Module7 ritual) ── */
.timeline-grid {
  display:grid; grid-template-columns:repeat(4, 1fr);
  gap:0; max-width:1100px; margin:0 auto;
  position:relative;
}
.timeline-grid::before {
  content:''; position:absolute;
  top:30px; left:10%; right:10%;
  height:3px; border-radius:4px;
  background:linear-gradient(90deg, var(--gold), var(--gold-bright), var(--blue), var(--purple));
  z-index:0; opacity:.5;
}
.timeline-step {
  position:relative; z-index:1; padding:0 14px; text-align:center;
}
.timeline-num {
  width:60px; height:60px; border-radius:18px;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-size:22px; font-weight:800;
  margin:0 auto 22px;
  background:linear-gradient(135deg, #b8952a, #d4af37, #e8c84a);
  color:#fff;
  box-shadow:0 4px 20px rgba(184,149,42,0.25);
  transition:transform .3s, box-shadow .3s;
}
.timeline-step:hover .timeline-num {
  transform:scale(1.08);
  box-shadow:0 6px 28px rgba(184,149,42,0.35);
}
.timeline-step h3 {
  font-family:var(--font-display); font-size:17px;
  font-weight:600; margin-bottom:10px;
}
.timeline-step p {
  font-size:14px; color:var(--text-secondary); line-height:1.7;
}
.timeline-content {
  padding:24px 20px; border-radius:var(--radius);
  background:var(--bg-card); border:1px solid var(--border);
  box-shadow:var(--shadow-sm); margin-top:0;
  transition:transform .3s, box-shadow .3s;
}
.timeline-step:hover .timeline-content {
  transform:translateY(-3px);
  box-shadow:var(--shadow-md);
}

/* ── Colored info boxes (from Module7 warnings/tips) ── */
.info-box {
  padding:22px 26px; border-radius:var(--radius-sm);
  display:flex; gap:16px; align-items:flex-start;
  margin-top:12px;
}
.info-box i { margin-top:3px; font-size:18px; flex-shrink:0; }
.info-box h4 { font-family:var(--font-display); font-size:15px; font-weight:700; margin-bottom:6px; }
.info-box p { font-size:14px; line-height:1.65; color:var(--text-secondary); }

.info-box.rose { background:rgba(244,63,94,0.04); border:1px solid rgba(244,63,94,0.12); }
.info-box.rose i, .info-box.rose h4 { color:#f43f5e; }

.info-box.emerald { background:rgba(16,185,129,0.04); border:1px solid rgba(16,185,129,0.12); }
.info-box.emerald i, .info-box.emerald h4 { color:#10b981; }

.info-box.amber-box { background:rgba(245,158,11,0.04); border:1px solid rgba(245,158,11,0.12); }
.info-box.amber-box i, .info-box.amber-box h4 { color:#f59e0b; }

.info-box.blue-box { background:rgba(37,99,235,0.04); border:1px solid rgba(37,99,235,0.12); }
.info-box.blue-box i, .info-box.blue-box h4 { color:#2563eb; }

/* ── Performance stat grid (from Module7 backtest) ── */
.perf-grid {
  display:grid; grid-template-columns:repeat(3, 1fr);
  gap:20px; margin-top:48px;
}
.perf-stat {
  padding:36px 28px; border-radius:var(--radius);
  background:var(--bg-card); border:1px solid var(--border);
  box-shadow:var(--shadow-sm); text-align:center;
  transition:transform .35s, box-shadow .35s;
  position:relative; overflow:hidden;
}
.perf-stat:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); }
.perf-stat::before {
  content:''; position:absolute; top:0; left:0; right:0;
  height:3px; opacity:0; transition:opacity .3s;
}
.perf-stat:hover::before { opacity:1; }
.perf-stat.c-gold::before { background:linear-gradient(90deg, #b8952a, #d4af37); }
.perf-stat.c-blue::before { background:linear-gradient(90deg, #2563eb, #3b82f6); }
.perf-stat.c-emerald::before { background:linear-gradient(90deg, #10b981, #34d399); }
.perf-stat.c-violet::before { background:linear-gradient(90deg, #8b5cf6, #a78bfa); }
.perf-stat.c-fuchsia::before { background:linear-gradient(90deg, #d946ef, #e879f9); }
.perf-stat.c-amber::before { background:linear-gradient(90deg, #f59e0b, #fbbf24); }

.perf-val {
  font-family:var(--font-display); font-size:44px;
  font-weight:800; line-height:1; margin-bottom:10px;
}
.perf-label {
  font-size:13px; color:var(--text-muted);
  text-transform:uppercase; letter-spacing:.06em;
}
.perf-sub {
  font-size:12px; color:var(--text-muted); margin-top:8px;
  font-style:italic;
}

/* ── Enhanced includes (FA icons in gradient circles) ── */
.include-icon-fa {
  width:52px; height:52px; border-radius:16px;
  display:flex; align-items:center; justify-content:center;
  margin-bottom:20px; font-size:22px;
}
.include-icon-fa.gold-grad {
  background:linear-gradient(135deg, rgba(184,149,42,0.12), rgba(212,175,55,0.06));
  color:var(--gold); border:1px solid rgba(184,149,42,0.15);
}
.include-icon-fa.blue-grad {
  background:linear-gradient(135deg, rgba(37,99,235,0.1), rgba(59,130,246,0.05));
  color:var(--blue); border:1px solid rgba(37,99,235,0.12);
}
.include-icon-fa.violet-grad {
  background:linear-gradient(135deg, rgba(139,92,246,0.1), rgba(167,139,250,0.05));
  color:var(--violet); border:1px solid rgba(139,92,246,0.12);
}
.include-icon-fa.emerald-grad {
  background:linear-gradient(135deg, rgba(16,185,129,0.1), rgba(52,211,153,0.05));
  color:var(--emerald); border:1px solid rgba(16,185,129,0.12);
}

/* ── Section glow backgrounds (light theme adaptation) ── */
.section-glow-gold { position:relative; }
.section-glow-gold::after {
  content:''; position:absolute;
  top:10%; right:-5%; width:400px; height:400px;
  border-radius:50%; pointer-events:none; z-index:0;
  background:radial-gradient(ellipse, rgba(184,149,42,0.05) 0%, transparent 70%);
  filter:blur(60px);
}
.section-glow-blue { position:relative; }
.section-glow-blue::after {
  content:''; position:absolute;
  bottom:5%; left:-5%; width:400px; height:400px;
  border-radius:50%; pointer-events:none; z-index:0;
  background:radial-gradient(ellipse, rgba(37,99,235,0.04) 0%, transparent 70%);
  filter:blur(60px);
}

/* ── Comparison table (from Module7 perf table) ── */
.compare-table {
  width:100%; border-collapse:separate;
  border-spacing:0; border-radius:var(--radius);
  overflow:hidden; border:1px solid var(--border);
  background:var(--bg-card); box-shadow:var(--shadow-sm);
  margin-top:36px;
}
.compare-table th {
  padding:16px 20px; text-align:left;
  font-size:11px; font-weight:700;
  text-transform:uppercase; letter-spacing:.1em;
  color:var(--gold); background:rgba(184,149,42,0.04);
  border-bottom:1px solid var(--border);
}
.compare-table th:not(:first-child) { text-align:center; }
.compare-table td {
  padding:16px 20px; font-size:14px;
  border-bottom:1px solid var(--border);
}
.compare-table td:not(:first-child) { text-align:center; }
.compare-table tr:last-child td { border-bottom:none; }
.compare-table tr:hover td { background:rgba(37,99,235,0.02); }
.compare-table .highlight-row td {
  background:rgba(184,149,42,0.03);
  font-weight:600;
}
.compare-badge {
  display:inline-block; padding:3px 10px;
  border-radius:8px; font-size:12px; font-weight:700;
}

@media(max-width:1024px){
  .timeline-grid{grid-template-columns:repeat(2,1fr)}
  .brique-grid{grid-template-columns:1fr}
  .perf-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:900px){
  .compare-table { font-size:13px; }
  .compare-table th, .compare-table td { padding:12px 14px; }
}
