/* ============================================
   NITZEX VISUAL. Shared design system.
   Single source of truth across every page.
   ============================================ */

:root{
  --accent:#76f70c;
  --accent-dark:#5bc909;
  --accent-deep:#3a7a00;
  --accent-faint:#f0ffe0;
  --accent-glow:rgba(118,247,12,0.35);

  --black:#0a0a0a;
  --gray-950:#0d0d0d;
  --gray-900:#111111;
  --gray-800:#1a1a1a;
  --gray-700:#262626;
  --gray-600:#525252;
  --gray-500:#737373;
  --gray-400:#a3a3a3;
  --gray-300:#d4d4d4;
  --gray-200:#e5e5e5;
  --gray-100:#f5f5f5;
  --gray-50:#fafafa;
  --paper:#fafaf7;
  --white:#ffffff;

  --text:#0a0a0a;
  --text-2:#525252;
  --text-3:#737373;
  --text-4:#a3a3a3;
  --border:#e8e8e5;
  --border-soft:#f0f0ec;

  --r-sm:8px;
  --r:14px;
  --r-md:18px;
  --r-lg:24px;
  --r-xl:32px;

  --shadow-sm:0 1px 2px rgba(0,0,0,0.04),0 1px 3px rgba(0,0,0,0.06);
  --shadow:0 4px 24px rgba(0,0,0,0.06),0 2px 8px rgba(0,0,0,0.04);
  --shadow-lg:0 24px 64px rgba(0,0,0,0.08),0 8px 24px rgba(0,0,0,0.05);
  --shadow-xl:0 40px 80px rgba(0,0,0,0.10);

  --ease:cubic-bezier(0.4,0,0.2,1);
  --ease-out:cubic-bezier(0.22,1,0.36,1);
  --ease-spring:cubic-bezier(0.34,1.56,0.64,1);

  --nav-h:64px;
  --bar-h:42px;
  --mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

html{
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
  font-size:16px;
}

body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  background:var(--paper);
  color:var(--text);
  line-height:1.55;
  font-feature-settings:'cv11','ss01','ss03';
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  text-rendering:optimizeLegibility;
}

img,svg,video{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer}
a{color:inherit;text-decoration:none}
input,select,textarea{font-family:inherit;font-size:inherit}

::selection{background:var(--accent);color:var(--black)}

/* ===== TYPOGRAPHY ===== */
.t-eyebrow{font-size:.7rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-deep)}
.t-display-1{font-size:clamp(2.6rem,7.5vw,6.5rem);font-weight:800;line-height:1.05;letter-spacing:-.045em}
.t-display-2{font-size:clamp(2rem,5vw,4rem);font-weight:800;line-height:1.08;letter-spacing:-.035em}
.t-h1{font-size:clamp(1.6rem,3vw,2.4rem);font-weight:700;line-height:1.15;letter-spacing:-.025em}
.t-h2{font-size:clamp(1.15rem,2vw,1.5rem);font-weight:700;line-height:1.3;letter-spacing:-.018em}
.t-body-lg{font-size:clamp(1rem,1.4vw,1.18rem);line-height:1.6;color:var(--text-2)}
.t-body{font-size:1rem;line-height:1.6;color:var(--text-2)}
.t-small{font-size:.85rem;line-height:1.55;color:var(--text-2)}
.accent{color:var(--accent-deep)}
.mono{font-family:var(--mono);font-feature-settings:'tnum'}

/* ===== CONTAINERS ===== */
.wrap{max-width:1200px;margin:0 auto;padding:0 clamp(1.25rem,4vw,2.5rem)}
.wrap-narrow{max-width:760px;margin:0 auto;padding:0 clamp(1.25rem,4vw,2.5rem)}
.wrap-wide{max-width:1480px;margin:0 auto;padding:0 clamp(1.25rem,4vw,3rem)}
@media(min-width:1920px){.wrap{max-width:1320px}.wrap-narrow{max-width:820px}.wrap-wide{max-width:1640px}}

section{padding:clamp(4rem,8vw,7rem) 0}

/* ===== UTILITY BANNER ===== */
.banner{
  position:relative;z-index:101;
  background:var(--black);color:var(--white);
  padding:.75rem clamp(1rem,4vw,2rem);
  text-align:center;font-size:.82rem;font-weight:500;
  display:flex;align-items:center;justify-content:center;
  gap:.65rem;flex-wrap:wrap;min-height:var(--bar-h);
}
.banner strong{color:var(--accent);font-weight:700}
.banner a{color:var(--accent);font-weight:600;text-decoration:underline;text-underline-offset:3px}
.banner-dot{
  width:7px;height:7px;background:var(--accent);border-radius:50%;
  flex-shrink:0;animation:pulseDot 2s infinite;
}
@keyframes pulseDot{
  0%,100%{box-shadow:0 0 0 0 rgba(118,247,12,.5);transform:scale(1)}
  50%{box-shadow:0 0 0 6px rgba(118,247,12,0);transform:scale(.9)}
}

/* ===== NAV ===== */
nav.nav{
  position:sticky;top:0;z-index:100;
  height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 clamp(1.25rem,4vw,2.5rem);
  background:rgba(250,250,247,0.78);
  backdrop-filter:saturate(1.8) blur(20px);
  -webkit-backdrop-filter:saturate(1.8) blur(20px);
  border-bottom:1px solid transparent;
  transition:border-color .25s var(--ease),background .25s var(--ease);
}
nav.nav.scrolled{border-bottom-color:rgba(0,0,0,.06);background:rgba(250,250,247,0.93)}
.logo{
  display:inline-flex;align-items:center;gap:.55rem;
  font-size:1.02rem;font-weight:800;letter-spacing:-.025em;color:var(--text);
}
.logo-mark{
  width:24px;height:24px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;color:var(--text);
  transition:transform .35s var(--ease-spring),color .25s var(--ease);
}
.logo-mark svg{width:100%;height:100%}
.logo:hover .logo-mark{transform:rotate(-8deg) scale(1.05);color:var(--accent-deep)}
.nav-links{display:none;align-items:center;gap:1.6rem}
.nav-links a{
  position:relative;
  font-size:.86rem;font-weight:500;color:var(--text-2);
  transition:color .2s var(--ease);
  padding:.25rem 0;
}
.nav-links a:hover{color:var(--text)}
.nav-links a.is-current{color:var(--text);font-weight:600}
.nav-links a.is-current::after{
  content:'';position:absolute;left:0;right:0;bottom:-2px;
  height:2px;background:var(--accent);border-radius:2px;
}
@media(min-width:900px){.nav-links{display:flex}}
.nav-right{display:flex;align-items:center;gap:.5rem}

/* Mobile menu */
.menu-btn{
  display:flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:10px;
  border:1px solid var(--border);background:var(--white);
  cursor:pointer;
}
.menu-btn:hover{background:var(--gray-50)}
.menu-btn svg{width:18px;height:18px}
@media(min-width:900px){.menu-btn{display:none}}

.mobile-menu{
  position:fixed;inset:var(--nav-h) 0 0 0;z-index:99;
  background:var(--paper);
  padding:1.5rem clamp(1.25rem,4vw,2.5rem);
  transform:translateY(-110%);opacity:0;pointer-events:none;
  transition:transform .35s var(--ease),opacity .25s var(--ease);
  display:flex;flex-direction:column;gap:.25rem;
  overflow-y:auto;
}
.mobile-menu.open{transform:translateY(0);opacity:1;pointer-events:auto}
.mobile-menu a{
  padding:1rem 0;font-size:1.05rem;font-weight:600;color:var(--text);
  border-bottom:1px solid var(--border-soft);
}
.mobile-menu a:last-of-type{border-bottom:none}
.mobile-menu .btn{margin-top:1rem;justify-content:center}
@media(min-width:900px){.mobile-menu{display:none !important}}

/* Progress bar inside nav */
.progress{position:absolute;left:0;right:0;bottom:-2px;height:2px;z-index:1;pointer-events:none;overflow:hidden}
.progress-fill{height:100%;width:0%;background:linear-gradient(90deg,var(--accent-dark),var(--accent),var(--accent-dark));box-shadow:0 0 8px rgba(118,247,12,.5);transition:width .12s linear;will-change:width}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:.5rem;padding:.7rem 1.4rem;
  font-size:.88rem;font-weight:600;letter-spacing:-.005em;
  border:none;border-radius:999px;cursor:pointer;
  transition:transform .18s var(--ease),box-shadow .25s var(--ease),background .2s var(--ease),color .2s var(--ease);
  white-space:nowrap;position:relative;isolation:isolate;text-decoration:none;
}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--accent);color:var(--black);box-shadow:0 6px 18px -4px var(--accent-glow)}
.btn-primary::before{
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(135deg,#9eff44 0%,#76f70c 100%);
  opacity:0;transition:opacity .25s var(--ease);z-index:-1;
}
.btn-primary:hover{transform:translateY(-1.5px);box-shadow:0 12px 32px -4px var(--accent-glow),0 0 0 6px rgba(118,247,12,.08)}
.btn-primary:hover::before{opacity:1}
.btn-lg{padding:1rem 2rem;font-size:1rem;font-weight:700}
.btn-xl{padding:1.1rem 2.4rem;font-size:1.05rem;font-weight:700;letter-spacing:-.01em}
.btn-ghost{background:transparent;color:var(--text);border:1.5px solid var(--border)}
.btn-ghost:hover{background:var(--gray-50);border-color:#d4d4d4;transform:translateY(-1px)}
.btn-dark{background:var(--black);color:var(--white)}
.btn-dark:hover{background:#1c1c1c;transform:translateY(-1px);box-shadow:0 12px 28px rgba(0,0,0,.18)}
.btn .arrow{width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;transition:transform .25s var(--ease)}
.btn:hover .arrow{transform:translateX(3px)}
.btn:focus-visible{outline:none;box-shadow:0 0 0 3px var(--paper),0 0 0 5px var(--text)}
.btn-primary:focus-visible{box-shadow:0 0 0 3px var(--paper),0 0 0 5px var(--accent-dark)}

/* ===== SHARED HERO ===== */
.hero{
  position:relative;
  min-height:calc(100dvh - var(--nav-h) - var(--bar-h));
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:clamp(3rem,7vw,5.5rem) clamp(1.25rem,4vw,2.5rem) clamp(3rem,6vw,5rem);
  text-align:center;overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 70% 55% at 50% -10%,rgba(118,247,12,.14) 0%,transparent 60%),
    radial-gradient(ellipse 35% 35% at 85% 55%,rgba(118,247,12,.07) 0%,transparent 60%),
    radial-gradient(ellipse 30% 30% at 15% 75%,rgba(118,247,12,.05) 0%,transparent 60%);
}
.hero-grid{
  position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(0,0,0,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(0,0,0,.025) 1px,transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 50%,black 0%,transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 50%,black 0%,transparent 75%);
}
.hero-content{position:relative;z-index:2;max-width:920px;width:100%}
.eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.4rem 1rem;
  background:var(--accent-faint);
  border:1px solid rgba(118,247,12,.32);
  border-radius:999px;
  font-size:.74rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--accent-deep);margin-bottom:1.75rem;
}
.eyebrow-dot{width:6px;height:6px;background:var(--accent);border-radius:50%;animation:pulseDot 2s infinite}
.hero h1{margin:0 auto;max-width:16ch}
.hero h1 .accent-line{
  display:inline-block;
  background:linear-gradient(135deg,#5bc909 0%,#3a7a00 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  padding-bottom:.12em;
  margin-bottom:-.08em;
  line-height:1.05;
}
.hero-sub{margin:1.5rem auto 0;max-width:600px}
.hero-cta{margin-top:2.25rem;display:flex;flex-direction:column;align-items:center;gap:.75rem}
@media(min-width:520px){.hero-cta{flex-direction:row;justify-content:center}}

/* ===== SECTION HEADERS ===== */
.sec-head{text-align:center;margin-bottom:clamp(2.5rem,4vw,3.5rem);max-width:680px;margin-left:auto;margin-right:auto}
.sec-head.left{text-align:left;margin-left:0;margin-right:0}
.sec-eyebrow{
  display:inline-block;font-size:.72rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;color:var(--accent-deep);
  margin-bottom:1rem;
}
.sec-head h2{margin-bottom:.85rem}

/* ===== REVEAL ANIMATION ===== */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-stagger > *{opacity:0;transform:translateY(18px);transition:opacity .6s var(--ease-out),transform .6s var(--ease-out)}
.reveal-stagger.in > *{opacity:1;transform:translateY(0)}
.reveal-stagger.in > *:nth-child(1){transition-delay:0ms}
.reveal-stagger.in > *:nth-child(2){transition-delay:60ms}
.reveal-stagger.in > *:nth-child(3){transition-delay:120ms}
.reveal-stagger.in > *:nth-child(4){transition-delay:180ms}
.reveal-stagger.in > *:nth-child(5){transition-delay:240ms}
.reveal-stagger.in > *:nth-child(6){transition-delay:300ms}
.reveal-stagger.in > *:nth-child(7){transition-delay:360ms}
.reveal-stagger.in > *:nth-child(8){transition-delay:420ms}
.reveal-stagger.in > *:nth-child(9){transition-delay:480ms}

/* ===== HERO ENTRANCE ===== */
.hero-content > *{opacity:0;transform:translateY(18px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
.hero-content.in > *:nth-child(1){opacity:1;transform:translateY(0);transition-delay:80ms}
.hero-content.in > *:nth-child(2){opacity:1;transform:translateY(0);transition-delay:160ms}
.hero-content.in > *:nth-child(3){opacity:1;transform:translateY(0);transition-delay:280ms}
.hero-content.in > *:nth-child(4){opacity:1;transform:translateY(0);transition-delay:400ms}
.hero-content.in > *:nth-child(5){opacity:1;transform:translateY(0);transition-delay:520ms}
.hero-canvas{opacity:0;transform:translateY(36px) scale(.97);transition:opacity .9s var(--ease-out) .65s,transform .9s var(--ease-out) .65s}
.hero-canvas.in{opacity:1;transform:translateY(0) scale(1)}

/* ===== HOMEPAGE BRAND CANVAS ===== */
.brand-canvas{
  margin:clamp(2.75rem,6vw,4.5rem) auto 0;
  max-width:1080px;width:100%;
  position:relative;
}
.brand-canvas::before{
  content:'';position:absolute;
  inset:-30px -30px 30px -30px;
  background:radial-gradient(ellipse 60% 40% at 50% 50%,rgba(118,247,12,.18) 0%,transparent 65%);
  filter:blur(40px);z-index:-1;opacity:.7;pointer-events:none;
}
.canvas-frame{
  background:linear-gradient(165deg,#0d0d0d 0%,#1a1a1a 100%);
  border-radius:clamp(14px,1.8vw,22px);
  overflow:hidden;
  box-shadow:
    0 60px 120px -20px rgba(0,0,0,.32),
    0 0 0 1px rgba(255,255,255,.05),
    inset 0 1px 0 rgba(255,255,255,.06);
  aspect-ratio:16/9;
  position:relative;
  display:flex;align-items:center;justify-content:center;
}
.canvas-frame::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:24px 24px;
  pointer-events:none;
  mask-image:radial-gradient(ellipse 90% 80% at 50% 50%,black 0%,transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 90% 80% at 50% 50%,black 0%,transparent 80%);
}
.canvas-frame::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 50% at 50% 70%,rgba(118,247,12,.08) 0%,transparent 70%);
  pointer-events:none;
}
.brand-mark{
  position:relative;z-index:1;
  width:24%;height:auto;
  color:var(--accent);
  filter:drop-shadow(0 8px 32px rgba(118,247,12,.5));
  animation:markBreathe 3.5s var(--ease-out) infinite alternate;
}
@keyframes markBreathe{
  0%{transform:translateY(0) scale(1);filter:drop-shadow(0 8px 32px rgba(118,247,12,.45))}
  100%{transform:translateY(-4px) scale(1.04);filter:drop-shadow(0 14px 48px rgba(118,247,12,.65))}
}
.canvas-tag{
  position:absolute;
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.4rem .8rem;
  background:rgba(20,20,20,.85);
  border:1px solid rgba(255,255,255,.08);
  backdrop-filter:blur(10px);
  border-radius:8px;
  font-family:var(--mono);
  font-size:clamp(.62rem,1vw,.72rem);
  color:rgba(255,255,255,.7);font-weight:500;letter-spacing:.02em;
  z-index:3;
}
.canvas-tag .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px rgba(118,247,12,.7);animation:pulseDot 2s infinite}
.canvas-tag.tl{top:clamp(20px,3vw,38px);left:clamp(20px,3vw,38px);animation:floatTL 6s var(--ease) infinite}
.canvas-tag.tr{top:clamp(20px,3vw,38px);right:clamp(20px,3vw,38px);animation:floatTR 7s var(--ease) infinite}
.canvas-tag.bl{bottom:clamp(20px,3vw,38px);left:clamp(20px,3vw,38px);animation:floatBL 7.5s var(--ease) infinite}
.canvas-tag.br{bottom:clamp(20px,3vw,38px);right:clamp(20px,3vw,38px);animation:floatBR 6.5s var(--ease) infinite}
.canvas-tag strong{color:var(--accent);font-weight:700}
@keyframes floatTL{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
@keyframes floatTR{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
@keyframes floatBL{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}
@keyframes floatBR{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@media(max-width:640px){
  .canvas-tag.tr,.canvas-tag.bl{display:none}
}

/* ===== HOMEPAGE: PILLARS (CREATIVITY x TECH x BUSINESS x AI) ===== */
.pillars{background:var(--white)}
.pillars-grid{
  display:grid;grid-template-columns:1fr;gap:1px;
  background:rgba(0,0,0,.06);
  border:1px solid rgba(0,0,0,.06);
  border-radius:var(--r-lg);overflow:hidden;
}
@media(min-width:640px){.pillars-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.pillars-grid{grid-template-columns:repeat(4,1fr)}}
.pillar{
  background:var(--white);
  padding:1.85rem 1.65rem;
  position:relative;overflow:hidden;
  transition:background .25s var(--ease);
}
.pillar:hover{background:#fafff0}
.pillar-num{
  position:absolute;top:1rem;right:1.25rem;
  font-family:var(--mono);
  font-size:2.5rem;font-weight:800;
  letter-spacing:-.05em;line-height:1;
  color:var(--accent);opacity:.18;pointer-events:none;
}
.pillar-icon{
  width:40px;height:40px;
  background:var(--accent-faint);
  border:1px solid rgba(118,247,12,.22);
  border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:1.1rem;position:relative;z-index:1;
  transition:transform .3s var(--ease-spring),background .25s var(--ease);
}
.pillar:hover .pillar-icon{transform:scale(1.08) rotate(-3deg);background:var(--accent)}
.pillar-icon svg{width:18px;height:18px;color:var(--accent-deep);transition:color .25s var(--ease)}
.pillar:hover .pillar-icon svg{color:var(--black)}
.pillar h3{font-size:.98rem;font-weight:700;letter-spacing:-.012em;margin-bottom:.45rem;position:relative;z-index:1}
.pillar p{font-size:.84rem;color:var(--text-2);line-height:1.6;position:relative;z-index:1}

/* ===== TWIN CTA: SHOP & MENTORSHIP ===== */
.twin{background:var(--paper)}
.twin-grid{
  display:grid;grid-template-columns:1fr;gap:1.5rem;
}
@media(min-width:768px){.twin-grid{grid-template-columns:1fr 1fr}}
.twin-card{
  position:relative;overflow:hidden;
  border-radius:var(--r-xl);
  padding:clamp(2rem,4vw,3rem);
  min-height:clamp(360px,40vw,460px);
  display:flex;flex-direction:column;justify-content:space-between;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);
  cursor:pointer;
  isolation:isolate;
}
.twin-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.twin-card.shop{
  background:linear-gradient(160deg,#0a0a0a 0%,#1a1a1a 100%);
  color:var(--white);
}
.twin-card.shop::before{
  content:'';position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(ellipse 60% 50% at 80% 0%,rgba(118,247,12,.18) 0%,transparent 60%),
    radial-gradient(ellipse 50% 40% at 20% 100%,rgba(118,247,12,.10) 0%,transparent 60%);
}
.twin-card.shop::after{
  content:'';position:absolute;inset:0;z-index:-1;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:32px 32px;
  mask-image:radial-gradient(ellipse 80% 70% at 50% 50%,black 0%,transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 50%,black 0%,transparent 80%);
}
.twin-card.mentor{
  background:linear-gradient(160deg,var(--accent-faint) 0%,#e6ffba 100%);
  color:var(--text);
  border:1px solid rgba(118,247,12,.25);
}
.twin-eyebrow{
  display:inline-flex;align-items:center;gap:.45rem;
  font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  margin-bottom:1.4rem;
}
.twin-card.shop .twin-eyebrow{color:var(--accent)}
.twin-card.mentor .twin-eyebrow{color:var(--accent-deep)}
.twin-eyebrow .dot{width:6px;height:6px;border-radius:50%;background:currentColor}
.twin-card h3{
  font-size:clamp(1.8rem,3.5vw,2.6rem);
  font-weight:800;line-height:1.05;letter-spacing:-.03em;
  margin-bottom:.85rem;
  max-width:14ch;
}
.twin-card.shop h3 .ac{
  background:linear-gradient(135deg,#9eff44 0%,#76f70c 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}
.twin-card.mentor h3 .ac{color:var(--accent-deep)}
.twin-card p{
  font-size:.95rem;line-height:1.6;
  max-width:32ch;
  margin-bottom:1.75rem;
}
.twin-card.shop p{color:rgba(255,255,255,.65)}
.twin-card.mentor p{color:var(--text-2)}
.twin-meta{
  display:flex;flex-wrap:wrap;gap:.5rem;
  margin-bottom:1.5rem;
}
.twin-pill{
  font-family:var(--mono);
  font-size:.7rem;font-weight:600;
  padding:.32rem .65rem;
  border-radius:6px;
  letter-spacing:.02em;
}
.twin-card.shop .twin-pill{background:rgba(255,255,255,.08);color:rgba(255,255,255,.75);border:1px solid rgba(255,255,255,.1)}
.twin-card.mentor .twin-pill{background:rgba(255,255,255,.65);color:var(--accent-deep);border:1px solid rgba(118,247,12,.25)}
.twin-foot{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:1.5rem;
  border-top:1px solid;
}
.twin-card.shop .twin-foot{border-color:rgba(255,255,255,.08)}
.twin-card.mentor .twin-foot{border-color:rgba(118,247,12,.2)}
.twin-cta{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.95rem;font-weight:700;
  transition:gap .25s var(--ease);
}
.twin-card.shop .twin-cta{color:var(--accent)}
.twin-card.mentor .twin-cta{color:var(--accent-deep)}
.twin-card:hover .twin-cta{gap:.85rem}
.twin-cta svg{width:14px;height:14px}
.twin-count{
  font-family:var(--mono);font-size:.78rem;
}
.twin-card.shop .twin-count{color:rgba(255,255,255,.5)}
.twin-card.mentor .twin-count{color:var(--text-3)}
.twin-count strong{color:inherit;font-weight:700}
.twin-card.shop .twin-count strong{color:var(--accent)}
.twin-card.mentor .twin-count strong{color:var(--accent-deep)}

/* ===== FEATURED PRODUCTS GRID ===== */
.products{background:var(--white)}
.products-grid{
  display:grid;grid-template-columns:1fr;gap:1.25rem;
}
@media(min-width:600px){.products-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.products-grid{grid-template-columns:repeat(3,1fr)}}

.product-card{
  background:var(--white);
  border:1px solid var(--border-soft);
  border-radius:var(--r-lg);
  overflow:hidden;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease);
  display:flex;flex-direction:column;
  cursor:pointer;
  text-decoration:none;color:inherit;
}
.product-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:rgba(118,247,12,.3)}
.product-thumb{
  position:relative;
  aspect-ratio:16/9;
  background:linear-gradient(135deg,var(--gray-100),var(--gray-50));
  overflow:hidden;
}
.product-thumb img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s var(--ease);
}
.product-card:hover .product-thumb img{transform:scale(1.05)}
.product-thumb-fallback{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  color:var(--accent);
  background:linear-gradient(135deg,#0d0d0d 0%,#1a1a1a 100%);
}
.product-thumb-fallback svg{width:24%;height:auto;opacity:.85;animation:markBreathe 3s var(--ease-out) infinite alternate}
.product-badge{
  position:absolute;top:12px;left:12px;
  display:inline-flex;align-items:center;gap:.35rem;
  padding:.32rem .65rem;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(8px);
  border-radius:999px;
  font-size:.66rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
  color:var(--accent-deep);
  box-shadow:0 2px 8px rgba(0,0,0,.08);
}
.product-badge.new{color:var(--accent-deep)}
.product-badge.bestseller{color:#854d0e;background:#fef9c3}
.product-badge.free{color:#1e40af;background:#dbeafe}
.product-info{
  padding:1.25rem 1.4rem 1.4rem;
  display:flex;flex-direction:column;gap:.5rem;flex:1;
}
.product-cat{
  font-size:.7rem;font-weight:600;
  color:var(--text-3);letter-spacing:.06em;text-transform:uppercase;
}
.product-name{font-size:1rem;font-weight:700;letter-spacing:-.012em;color:var(--text);line-height:1.3}
.product-desc{font-size:.83rem;color:var(--text-2);line-height:1.5;flex:1}
.product-foot{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:.85rem;
  margin-top:.4rem;
  border-top:1px solid var(--border-soft);
}
.product-price{
  display:flex;align-items:baseline;gap:.4rem;
}
.product-price-now{font-size:1rem;font-weight:800;color:var(--text);letter-spacing:-.018em;font-family:var(--mono)}
.product-price-old{font-size:.78rem;color:var(--text-3);text-decoration:line-through;font-family:var(--mono)}
.product-price.free .product-price-now{color:var(--accent-deep)}
.product-cta{
  display:inline-flex;align-items:center;gap:.4rem;
  font-size:.78rem;font-weight:700;color:var(--accent-deep);
  transition:gap .25s var(--ease);
}
.product-card:hover .product-cta{gap:.7rem}
.product-cta svg{width:12px;height:12px}

.products-foot{
  text-align:center;margin-top:2.5rem;
}

/* ===== FILTER BAR (shop page) ===== */
.shop-filters{
  display:flex;flex-wrap:wrap;gap:.5rem;
  margin-bottom:2rem;
  justify-content:center;
}
.shop-filter{
  padding:.55rem 1.15rem;
  font-size:.83rem;font-weight:600;
  background:var(--white);
  border:1px solid var(--border);
  color:var(--text-2);
  border-radius:999px;
  letter-spacing:-.005em;
  transition:all .2s var(--ease);
}
.shop-filter:hover{border-color:#d4d4d4;color:var(--text)}
.shop-filter.active{
  background:var(--black);color:var(--white);border-color:var(--black);
  box-shadow:0 4px 12px rgba(0,0,0,.18);
}
.shop-search{
  position:relative;
  max-width:500px;margin:0 auto 2rem;
}
.shop-search input{
  width:100%;
  padding:.85rem 1.15rem .85rem 2.85rem;
  font-size:.95rem;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:999px;
  outline:none;
  transition:border-color .2s var(--ease),box-shadow .2s var(--ease);
}
.shop-search input:focus{border-color:var(--accent-dark);box-shadow:0 0 0 3px rgba(118,247,12,.15)}
.shop-search svg{
  position:absolute;left:1.05rem;top:50%;transform:translateY(-50%);
  width:18px;height:18px;color:var(--text-3);pointer-events:none;
}
.shop-empty{
  text-align:center;padding:4rem 1.5rem;color:var(--text-3);
  font-size:.95rem;
}

/* ===== ABOUT / FOUNDER STRIP ===== */
.about{background:var(--paper)}
.about-grid{
  display:grid;grid-template-columns:1fr;gap:2rem;
  max-width:1080px;margin:0 auto;align-items:center;
}
@media(min-width:900px){.about-grid{grid-template-columns:1.1fr 1fr;gap:3.5rem}}
.about-mark{
  position:relative;
  border-radius:var(--r-xl);
  overflow:hidden;
  background:linear-gradient(160deg,#0a0a0a 0%,#1a1a1a 100%);
  aspect-ratio:1/1.05;
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-lg);
  isolation:isolate;
}
.about-mark::before{
  content:'';position:absolute;inset:0;z-index:-1;
  background:radial-gradient(ellipse 60% 50% at 50% 50%,rgba(118,247,12,.18) 0%,transparent 60%);
}
.about-mark::after{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:24px 24px;
  pointer-events:none;
}
.about-mark svg{
  width:48%;height:auto;
  color:var(--accent);
  filter:drop-shadow(0 8px 32px rgba(118,247,12,.45));
  animation:markBreathe 3.5s var(--ease-out) infinite alternate;
  position:relative;z-index:1;
}
.about-quote{
  position:absolute;
  bottom:1.5rem;left:1.5rem;right:1.5rem;
  z-index:2;
  font-family:var(--mono);
  font-size:.72rem;
  color:rgba(255,255,255,.55);
  letter-spacing:.04em;
}
.about-quote strong{color:var(--accent);font-weight:700;display:block;margin-bottom:.15rem;font-family:'Inter',sans-serif;letter-spacing:-.01em;font-size:.88rem}
.about-text h2{margin-bottom:1.2rem}
.about-text p{font-size:1rem;line-height:1.7;color:var(--text-2);margin-bottom:1rem;max-width:48ch}
.about-text p strong{color:var(--text);font-weight:600}
.about-mission{
  margin-top:1.75rem;
  padding:1.25rem 1.4rem;
  background:var(--white);
  border:1px solid var(--accent-faint);
  border-left:3px solid var(--accent);
  border-radius:var(--r);
}
.about-mission .lbl{
  font-size:.7rem;font-weight:700;color:var(--accent-deep);
  letter-spacing:.12em;text-transform:uppercase;
  margin-bottom:.55rem;
}
.about-mission p{font-size:.92rem;color:var(--text);font-weight:500;margin:0}
.about-mission p span{color:var(--accent-deep);font-weight:700}

/* ===== STATS STRIP ===== */
.stats{
  background:var(--white);
  border-top:1px solid var(--border-soft);
  border-bottom:1px solid var(--border-soft);
  padding:clamp(2.5rem,5vw,3.75rem) 0;
}
.stats-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:2rem clamp(1.25rem,3vw,3rem);
  text-align:center;
}
@media(min-width:640px){.stats-grid{grid-template-columns:repeat(4,1fr)}}
.stat-num{font-size:clamp(1.9rem,3.5vw,2.7rem);font-weight:800;letter-spacing:-.04em;line-height:1;color:var(--text)}
.stat-num .suffix{color:var(--accent-deep);font-weight:800}
.stat-label{margin-top:.4rem;font-size:.76rem;font-weight:500;color:var(--text-3);letter-spacing:.01em}

/* ===== MENTORSHIP CARDS ===== */
.mentor-list{background:var(--white)}
.mentor-grid{
  display:grid;grid-template-columns:1fr;gap:1.5rem;
}
@media(min-width:768px){.mentor-grid{grid-template-columns:repeat(3,1fr)}}
.mentor-card{
  position:relative;overflow:hidden;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:1.85rem 1.65rem;
  display:flex;flex-direction:column;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease);
  cursor:pointer;
}
.mentor-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:rgba(118,247,12,.35)}
.mentor-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--accent),var(--accent-dark));
  transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--ease);
}
.mentor-card:hover::before{transform:scaleX(1)}
.mentor-tag{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.3rem .7rem;
  background:var(--accent-faint);
  border:1px solid rgba(118,247,12,.25);
  border-radius:999px;
  font-family:var(--mono);
  font-size:.68rem;font-weight:600;
  color:var(--accent-deep);
  letter-spacing:.04em;text-transform:uppercase;
  margin-bottom:1.1rem;align-self:flex-start;
}
.mentor-card h3{
  font-size:1.4rem;font-weight:800;letter-spacing:-.025em;
  margin-bottom:.4rem;
}
.mentor-card .tag{
  font-size:.86rem;color:var(--text-3);font-style:italic;
  margin-bottom:1.15rem;
}
.mentor-card p{font-size:.85rem;color:var(--text-2);line-height:1.6;margin-bottom:1.25rem;flex:1}
.mentor-meta{
  display:flex;flex-wrap:wrap;gap:.4rem;
  padding:.85rem 0 1.15rem;
  border-top:1px solid var(--border-soft);
}
.mentor-pill{
  font-family:var(--mono);
  font-size:.7rem;font-weight:600;
  padding:.3rem .55rem;
  background:var(--gray-50);
  border:1px solid var(--border-soft);
  border-radius:6px;
  color:var(--text-2);
  letter-spacing:.02em;
}
.mentor-foot{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:.85rem;
  border-top:1px solid var(--border-soft);
}
.mentor-price{
  font-family:var(--mono);font-size:.95rem;font-weight:800;
  color:var(--text);
}
.mentor-price .old{color:var(--text-3);text-decoration:line-through;font-weight:500;margin-right:.4rem;font-size:.78rem}
.mentor-cta{
  display:inline-flex;align-items:center;gap:.4rem;
  font-size:.82rem;font-weight:700;color:var(--accent-deep);
  transition:gap .25s var(--ease);
}
.mentor-card:hover .mentor-cta{gap:.7rem}
.mentor-cta svg{width:12px;height:12px}

/* ===== TESTIMONIALS ===== */
.testimonials{background:var(--paper)}
.testimonial-grid{
  column-count:1;column-gap:1.25rem;
  max-width:1180px;margin:0 auto;
}
@media(min-width:640px){.testimonial-grid{column-count:2}}
@media(min-width:1024px){.testimonial-grid{column-count:3}}
.testimonial{
  break-inside:avoid;
  background:var(--white);
  border:1px solid var(--border-soft);
  border-radius:var(--r-lg);
  padding:1.5rem 1.5rem 1.4rem;
  margin:0 0 1.25rem 0;
  display:flex;flex-direction:column;gap:1rem;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease);
}
.testimonial:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.testimonial blockquote{
  font-size:.92rem;line-height:1.6;color:var(--text);
  letter-spacing:-.005em;font-weight:500;
}
.testimonial figcaption{
  display:flex;align-items:center;gap:.7rem;
  padding-top:1rem;border-top:1px solid var(--border-soft);
}
.tav{
  width:36px;height:36px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.78rem;font-weight:700;
  flex-shrink:0;
  border:1px solid var(--border-soft);
}
.tav.a{background:linear-gradient(135deg,#fef3c7,#fbbf24);color:#854d0e}
.tav.b{background:linear-gradient(135deg,#dbeafe,#60a5fa);color:#1e40af}
.tav.c{background:linear-gradient(135deg,#fce7f3,#f472b6);color:#9d174d}
.tav.d{background:linear-gradient(135deg,#dcfce7,#76f70c);color:var(--black)}
.tav.e{background:linear-gradient(135deg,#ede9fe,#a78bfa);color:#5b21b6}
.tav.f{background:linear-gradient(135deg,#fee2e2,#f87171);color:#991b1b}
.tav.g{background:linear-gradient(135deg,#cffafe,#22d3ee);color:#155e75}
.tav.h{background:linear-gradient(135deg,#fed7aa,#fb923c);color:#7c2d12}
.tav.i{background:linear-gradient(135deg,#bbf7d0,#22c55e);color:#14532d}
.tav.j{background:linear-gradient(135deg,#e0e7ff,#818cf8);color:#3730a3}
.tinfo .name{font-size:.86rem;font-weight:700;color:var(--text);letter-spacing:-.005em;display:block}
.tinfo .role{font-size:.74rem;color:var(--text-3);margin-top:.1rem;display:block}
.tstars{
  display:inline-flex;gap:1px;color:var(--accent-deep);margin-left:auto;
  font-size:.78rem;
}
.tstars span{color:var(--accent-deep)}
.tstars .dim{color:var(--text-4)}

/* ===== BOOK A CALL ===== */
.book{
  background:linear-gradient(160deg,#0a0a0a 0%,#161616 100%);
  color:var(--white);
  position:relative;overflow:hidden;
}
.book::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 50% at 50% 0%,rgba(118,247,12,.15) 0%,transparent 60%);
  pointer-events:none;
}
.book::after{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 50%,black 0%,transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 50%,black 0%,transparent 75%);
  pointer-events:none;
}
.book-inner{position:relative;z-index:1;max-width:760px;margin:0 auto;text-align:center}
.book .sec-eyebrow{color:var(--accent)}
.book h2{color:var(--white);margin-bottom:1.25rem}
.book h2 .accent-line{
  display:inline-block;
  background:linear-gradient(135deg,#76f70c 0%,#9eff44 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  padding-bottom:.12em;margin-bottom:-.08em;line-height:1.08;
}
.book p{color:rgba(255,255,255,.6);max-width:540px;margin:0 auto 2rem}
.book-perks{
  display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem;
  margin:0 auto 2rem;max-width:560px;
}
.book-perk{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.4rem .85rem;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  border-radius:999px;
  font-size:.78rem;color:rgba(255,255,255,.8);font-weight:500;
}
.book-perk svg{width:14px;height:14px;color:var(--accent)}

/* ===== FAQ ===== */
.faq{background:var(--white)}
.faq-list{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:.6rem}
.faq-item{
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  overflow:hidden;
  transition:border-color .25s var(--ease);
}
.faq-item:hover{border-color:#d4d4d4}
.faq-item.open{border-color:rgba(118,247,12,.4);box-shadow:0 4px 16px rgba(118,247,12,.06)}
.faq-q{
  width:100%;padding:1.1rem 1.4rem;
  background:none;border:none;text-align:left;
  font-size:.92rem;font-weight:600;color:var(--text);
  letter-spacing:-.012em;
  display:flex;align-items:center;justify-content:space-between;
  gap:1rem;
  transition:background .15s var(--ease);
}
.faq-q:hover{background:var(--gray-50)}
.faq-icon{
  flex-shrink:0;width:24px;height:24px;
  background:var(--gray-100);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  position:relative;
  transition:transform .35s var(--ease),background .25s var(--ease);
}
.faq-icon::before,.faq-icon::after{
  content:'';position:absolute;
  background:var(--text-2);border-radius:1px;
  transition:background .2s var(--ease);
}
.faq-icon::before{width:9px;height:1.5px}
.faq-icon::after{width:1.5px;height:9px;transition:transform .35s var(--ease),background .2s var(--ease)}
.faq-item.open .faq-icon{background:var(--accent);transform:rotate(180deg)}
.faq-item.open .faq-icon::before,.faq-item.open .faq-icon::after{background:var(--black)}
.faq-item.open .faq-icon::after{transform:scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
.faq-a-inner{padding:0 1.4rem 1.25rem;font-size:.86rem;color:var(--text-2);line-height:1.65}

/* ===== NEWSLETTER ===== */
.newsletter{background:var(--paper)}
.news-card{
  max-width:760px;margin:0 auto;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--r-xl);
  padding:clamp(2rem,4vw,3rem);
  text-align:center;
  position:relative;overflow:hidden;
}
.news-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--accent-dark),var(--accent),var(--accent-dark));
}
.news-card h2{font-size:clamp(1.5rem,3vw,2.2rem);font-weight:800;letter-spacing:-.025em;margin-bottom:.85rem;line-height:1.15}
.news-card h2 .ac{color:var(--accent-deep)}
.news-card p{font-size:.95rem;color:var(--text-2);line-height:1.6;max-width:480px;margin:0 auto 2rem}
.news-form{
  display:flex;flex-direction:column;gap:.65rem;
  max-width:480px;margin:0 auto;
}
@media(min-width:520px){.news-form{flex-direction:row}}
.news-form input{
  flex:1;
  padding:.85rem 1.15rem;
  font-size:.95rem;
  background:var(--paper);
  border:1px solid var(--border);
  border-radius:999px;
  outline:none;
  transition:border-color .2s var(--ease),box-shadow .2s var(--ease);
}
.news-form input:focus{border-color:var(--accent-dark);box-shadow:0 0 0 3px rgba(118,247,12,.15)}
.news-msg{margin-top:.85rem;font-size:.82rem;color:var(--accent-deep);font-weight:600;min-height:1em}

/* ===== FOOTER ===== */
footer{
  padding:3rem clamp(1.25rem,4vw,2.5rem) 2rem;
  background:var(--paper);
  border-top:1px solid var(--border-soft);
}
.foot-top{
  display:grid;grid-template-columns:1fr;gap:2rem;
  max-width:1200px;margin:0 auto 2rem;
}
@media(min-width:768px){.foot-top{grid-template-columns:1.6fr 1fr 1fr 1fr}}
.foot-brand{display:flex;flex-direction:column;gap:.85rem;max-width:360px}
.foot-brand p{font-size:.85rem;color:var(--text-3);line-height:1.6}
.foot-social{
  display:flex;gap:.5rem;margin-top:.5rem;
}
.foot-social a{
  width:36px;height:36px;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:var(--white);
  border:1px solid var(--border);
  color:var(--text-2);
  transition:transform .25s var(--ease-spring),background .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease);
}
.foot-social a:hover{
  background:var(--text);color:var(--accent);
  border-color:var(--text);transform:translateY(-2px);
}
.foot-social svg{width:16px;height:16px}
.foot-col h5{
  font-size:.72rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--text-3);margin-bottom:.85rem;
}
.foot-col a{
  display:block;
  font-size:.86rem;color:var(--text-2);
  padding:.25rem 0;
  transition:color .2s var(--ease);
}
.foot-col a:hover{color:var(--accent-deep)}
.foot-bottom{
  border-top:1px solid var(--border-soft);
  padding-top:1.5rem;
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  text-align:center;
  max-width:1200px;margin:0 auto;
}
@media(min-width:640px){.foot-bottom{flex-direction:row;justify-content:space-between}}
.foot-copy{font-size:.76rem;color:var(--text-4)}
.foot-quote{font-size:.76rem;color:var(--text-3);font-style:italic}

/* ===== FLOATING BOOK BUTTON (every page) ===== */
.float-book{
  position:fixed;bottom:1.25rem;right:1.25rem;z-index:90;
  display:inline-flex;align-items:center;gap:.55rem;
  padding:.75rem 1.15rem;
  background:rgba(10,10,10,.96);
  color:var(--white);
  backdrop-filter:blur(14px);
  border-radius:999px;
  box-shadow:0 16px 48px rgba(0,0,0,.28),0 0 0 1px rgba(255,255,255,.06);
  font-size:.85rem;font-weight:700;
  text-decoration:none;
  transform:translateY(140%);opacity:0;pointer-events:none;
  transition:transform .45s var(--ease-spring),opacity .3s var(--ease),background .25s var(--ease);
  white-space:nowrap;
}
.float-book.show{transform:translateY(0);opacity:1;pointer-events:auto}
.float-book:hover{background:var(--accent);color:var(--black)}
.float-book .pulse{
  width:8px;height:8px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 0 0 rgba(118,247,12,.6);
  animation:pulseDot 1.6s infinite;
}
.float-book:hover .pulse{background:var(--black);box-shadow:none;animation:none}
@media(max-width:480px){
  .float-book{bottom:1rem;right:1rem;padding:.65rem 1rem;font-size:.8rem}
  .float-book .lbl{display:none}
}

/* ===== PRODUCT DETAIL PAGE ===== */
.product-page{padding:clamp(2rem,5vw,4rem) 0}
.product-back{
  display:inline-flex;align-items:center;gap:.45rem;
  font-size:.85rem;color:var(--text-3);font-weight:600;
  margin-bottom:1.5rem;
  transition:color .2s var(--ease),gap .25s var(--ease);
}
.product-back:hover{color:var(--text);gap:.7rem}
.product-back svg{width:14px;height:14px}
.product-grid{
  display:grid;grid-template-columns:1fr;gap:2.5rem;
}
@media(min-width:900px){.product-grid{grid-template-columns:1.4fr 1fr;gap:3rem}}
.product-cover{
  position:relative;
  border-radius:var(--r-xl);
  overflow:hidden;
  background:linear-gradient(135deg,#0a0a0a 0%,#1a1a1a 100%);
  aspect-ratio:16/9;
  border:1px solid var(--border);
}
.product-cover img{width:100%;height:100%;object-fit:cover}
.product-cover-fallback{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
}
.product-cover-fallback svg{width:18%;height:auto;color:var(--accent);animation:markBreathe 3s var(--ease-out) infinite alternate}
.product-detail-meta{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-deep);margin-bottom:.85rem}
.product-detail h1{
  font-size:clamp(1.6rem,3vw,2.4rem);
  font-weight:800;letter-spacing:-.025em;line-height:1.15;
  margin-bottom:1rem;
}
.product-detail-price{
  display:flex;align-items:baseline;gap:.65rem;
  margin-bottom:1.5rem;
  padding-bottom:1.5rem;border-bottom:1px solid var(--border-soft);
}
.product-detail-price .now{font-family:var(--mono);font-size:1.85rem;font-weight:800;color:var(--text);letter-spacing:-.025em}
.product-detail-price .old{font-family:var(--mono);font-size:1rem;color:var(--text-3);text-decoration:line-through}
.product-detail-price .save{
  padding:.22rem .55rem;
  background:#fef9c3;color:#854d0e;
  border-radius:5px;font-size:.7rem;font-weight:700;letter-spacing:.04em;
}
.product-detail p{font-size:.95rem;color:var(--text-2);line-height:1.7;margin-bottom:1.5rem}
.product-features{
  list-style:none;display:flex;flex-direction:column;gap:.65rem;
  margin-bottom:1.85rem;
}
.product-features li{
  display:flex;align-items:flex-start;gap:.65rem;
  font-size:.88rem;color:var(--text-2);line-height:1.5;
}
.product-features li::before{
  content:'';flex-shrink:0;
  width:18px;height:18px;
  background:var(--accent-faint);border-radius:50%;
  margin-top:1px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' fill='none'%3E%3Cpath d='M2.5 6.5L4.5 8.5L9.5 3.5' stroke='%233a7a00' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-size:11px 11px;background-position:center;background-repeat:no-repeat;
}
.product-buy{display:flex;flex-direction:column;gap:.65rem;margin-bottom:1.5rem}
.product-buy .btn{justify-content:center}
.product-trust{font-size:.78rem;color:var(--text-3);text-align:center}
.product-trust strong{color:var(--text-2);font-weight:600}

/* ===== HIDE EMPTY ===== */
[hidden]{display:none !important}

/* ===== REDUCED MOTION ===== */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
    scroll-behavior:auto !important;
  }
  .reveal,.reveal-stagger > *,.hero-content > *,.hero-canvas{opacity:1 !important;transform:none !important}
}

/* ===== ULTRAWIDE ===== */
@media(min-width:1920px){
  body{font-size:17px}
  .stat-num{font-size:3rem}
}

/* ===== MOBILE ===== */
@media(max-width:480px){
  .banner{font-size:.76rem;padding:.6rem .9rem;line-height:1.45}
  .nav-right .btn-primary{padding:.55rem 1rem;font-size:.8rem}
}


/* ============================================================
   MENTORSHIP TRILOGY. Cinematic showcase section.
   ============================================================ */
.trilogy{
  position:relative;
  background:linear-gradient(180deg,#070707 0%,#0d0d0d 60%,#070707 100%);
  color:var(--white);
  padding:clamp(5rem,10vw,8.5rem) 0 clamp(4rem,8vw,7rem);
  overflow:hidden;
  isolation:isolate;
}
.trilogy-bg{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 70% 45% at 50% 0%, rgba(118,247,12,0.18) 0%, transparent 60%),
    radial-gradient(ellipse 40% 30% at 12% 80%, rgba(118,247,12,0.08) 0%, transparent 60%),
    radial-gradient(ellipse 40% 30% at 88% 60%, rgba(118,247,12,0.06) 0%, transparent 60%);
}
.trilogy::before{
  content:'';position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 50%, black 0%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 50%, black 0%, transparent 80%);
}
.trilogy > .wrap-wide{position:relative;z-index:1}

.trilogy-head{text-align:center;margin-bottom:clamp(2.5rem,5vw,4rem);max-width:880px;margin-left:auto;margin-right:auto}
.trilogy-tag{
  display:inline-flex;align-items:center;gap:.55rem;
  padding:.45rem 1rem;
  background:rgba(118,247,12,.08);
  border:1px solid rgba(118,247,12,.28);
  border-radius:999px;
  font-size:.74rem;font-weight:700;
  color:var(--accent);
  letter-spacing:.14em;text-transform:uppercase;
  margin-bottom:1.85rem;
}
.trilogy-tag-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px rgba(118,247,12,.7);animation:pulseDot 2s infinite}
.trilogy-head h2{color:var(--white);letter-spacing:-.045em;line-height:1.04}
.trilogy-headline-ac{
  display:inline-block;
  background:linear-gradient(135deg,#9eff44 0%,#76f70c 50%,#5bcc00 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  padding-bottom:.12em;margin-bottom:-.08em;line-height:1.05;
}
.trilogy-sub{color:rgba(255,255,255,.55);max-width:620px;margin:1.4rem auto 0}

/* The stack */
.trilogy-stack{
  display:grid;
  grid-template-columns:1fr;
  gap:1.25rem;
  margin-bottom:clamp(3rem,6vw,4.5rem);
}
@media(min-width:768px){.trilogy-stack{grid-template-columns:repeat(3,1fr);gap:1.25rem}}

.program{
  position:relative;
  border-radius:clamp(20px,2.4vw,28px);
  padding:clamp(1.65rem,2.5vw,2.1rem) clamp(1.5rem,2.2vw,1.85rem) clamp(1.5rem,2.2vw,1.85rem);
  background:rgba(15,15,15,0.92);
  border:1px solid rgba(255,255,255,0.08);
  overflow:hidden;
  isolation:isolate;
  display:flex;flex-direction:column;
  cursor:pointer;
  transition:transform .45s var(--ease-out),border-color .35s var(--ease),box-shadow .45s var(--ease);
  min-height:clamp(420px,42vw,520px);
}
.program:hover,.program:focus-visible{
  transform:translateY(-6px);
  border-color:rgba(118,247,12,.35);
  box-shadow:0 24px 60px -12px rgba(118,247,12,.22);
  outline:none;
}
.program-bg{
  position:absolute;inset:0;z-index:-2;pointer-events:none;
  opacity:.85;transition:opacity .35s var(--ease);
}
.program:hover .program-bg{opacity:1}
.program-frameshift .program-bg{
  background:
    radial-gradient(ellipse 80% 60% at 50% 0%, rgba(118,247,12,0.20) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 50% 100%, rgba(118,247,12,0.08) 0%, transparent 60%);
}
.program-dieline .program-bg{
  background:
    radial-gradient(ellipse 80% 60% at 0% 0%, rgba(118,247,12,0.15) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 100% 100%, rgba(255,255,255,0.04) 0%, transparent 60%);
}
.program-aaroh .program-bg{
  background:
    radial-gradient(ellipse 80% 60% at 100% 0%, rgba(118,247,12,0.18) 0%, transparent 60%),
    radial-gradient(ellipse 70% 50% at 50% 100%, rgba(118,247,12,0.10) 0%, transparent 60%);
}
.program-grid{
  position:absolute;inset:0;z-index:-1;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size:24px 24px;
  mask-image:radial-gradient(ellipse 90% 70% at 50% 50%, black 0%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 90% 70% at 50% 50%, black 0%, transparent 80%);
}

.program-meta{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:1.25rem;
  font-family:var(--mono);
  font-size:.72rem;font-weight:600;
  letter-spacing:.06em;
}
.program-num{color:var(--accent);font-weight:800;letter-spacing:-.02em;font-size:.85rem}
.program-cat{color:rgba(255,255,255,.45);text-transform:uppercase}

.program-glyph{
  background:rgba(255,255,255,0.02);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:14px;
  padding:1.15rem;
  margin-bottom:1.4rem;
  position:relative;
  overflow:hidden;
}
.program-glyph svg{width:100%;height:auto;display:block;max-height:120px}
.program-glyph::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 40% at 50% 50%, rgba(118,247,12,.06), transparent 60%);
  pointer-events:none;
}

/* Program-specific signature glyph animations */
.program-frameshift .program-glyph svg line{
  animation:fsScrub 6s var(--ease) infinite;
  transform-origin:center;
}
.program-frameshift .program-glyph svg circle{
  animation:fsScrubDot 6s var(--ease) infinite;
}
@keyframes fsScrub{
  0%,100%{transform:translateX(-30%)}
  50%{transform:translateX(30%)}
}
@keyframes fsScrubDot{
  0%,100%{transform:translateX(-30%)}
  50%{transform:translateX(30%)}
}
.program-dieline .program-glyph svg rect[width="100"]{
  animation:dlPulse 3s var(--ease-out) infinite;
  transform-origin:center;
  transform-box:fill-box;
}
@keyframes dlPulse{
  0%,100%{transform:scale(1);opacity:1}
  50%{transform:scale(1.04);opacity:.85}
}
.program-aaroh .program-glyph svg polygon{
  animation:arRise 3s var(--ease-out) infinite alternate;
  transform-origin:center bottom;
  transform-box:fill-box;
}
@keyframes arRise{
  0%{transform:translateY(0) scale(1)}
  100%{transform:translateY(-2px) scale(1.05)}
}

.program-body{flex:1;display:flex;flex-direction:column}
.program-name{
  font-size:clamp(1.45rem,2.6vw,1.85rem);
  font-weight:900;letter-spacing:-.035em;line-height:1;
  color:var(--white);margin-bottom:.4rem;
}
.program-tag{
  font-size:.86rem;
  color:var(--accent);
  font-style:italic;
  margin-bottom:1.1rem;
  letter-spacing:-.005em;
}
.program-desc{
  font-size:.88rem;
  color:rgba(255,255,255,.6);
  line-height:1.55;
  margin-bottom:1.4rem;
  flex:1;
}

.program-stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:.4rem;
  padding:.85rem 0;
  margin-bottom:1.25rem;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.program-stats > div{
  text-align:center;
  display:flex;flex-direction:column;gap:.18rem;
}
.program-stats strong{
  font-size:.95rem;font-weight:800;color:var(--white);
  letter-spacing:-.018em;font-family:var(--mono);
}
.program-stats span{
  font-size:.62rem;font-weight:500;
  color:rgba(255,255,255,.4);
  text-transform:uppercase;letter-spacing:.06em;
}

.program-foot{display:flex;align-items:center;justify-content:space-between;gap:.85rem}
.program-price{display:flex;align-items:baseline;gap:.45rem;flex-wrap:wrap}
.program-price .now{
  font-family:var(--mono);
  font-size:1.05rem;font-weight:800;
  color:var(--accent);
  letter-spacing:-.018em;
}
.program-price .old{
  font-family:var(--mono);
  font-size:.78rem;
  color:rgba(255,255,255,.35);
  text-decoration:line-through;
}
.program-cta{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.55rem 1.05rem;
  background:rgba(118,247,12,.12);
  border:1px solid rgba(118,247,12,.3);
  border-radius:999px;
  font-size:.78rem;font-weight:700;
  color:var(--accent);
  letter-spacing:-.005em;
  transition:background .25s var(--ease),color .25s var(--ease),gap .25s var(--ease);
}
.program-cta svg{width:12px;height:12px}
.program:hover .program-cta{
  background:var(--accent);color:var(--black);gap:.7rem;
}

/* Path roadmap below the stack */
.trilogy-path{
  position:relative;
  max-width:920px;margin:0 auto clamp(2rem,4vw,3rem);
  padding:1.65rem 1.25rem;
  background:rgba(255,255,255,0.02);
  border:1px solid rgba(255,255,255,0.06);
  border-radius:clamp(16px,2vw,22px);
}
.trilogy-path-rail{
  position:absolute;
  top:50%;left:9%;right:9%;height:1px;
  background:linear-gradient(90deg, transparent 0%, rgba(118,247,12,0.4) 20%, rgba(118,247,12,0.4) 80%, transparent 100%);
  transform:translateY(-50%);
  z-index:0;
  display:none;
}
@media(min-width:768px){
  .trilogy-path-rail{display:block}
}
.trilogy-path-steps{
  list-style:none;
  display:grid;grid-template-columns:1fr;gap:1rem;
  position:relative;z-index:1;
}
@media(min-width:768px){
  .trilogy-path-steps{grid-template-columns:repeat(3,1fr);gap:1.25rem}
}
.trilogy-step{
  display:flex;align-items:center;gap:.85rem;
  padding:.4rem .25rem;
}
@media(min-width:768px){
  .trilogy-step{flex-direction:column;align-items:center;text-align:center;gap:.85rem}
}
.trilogy-step-dot{
  flex-shrink:0;
  width:42px;height:42px;
  border-radius:50%;
  background:var(--black);
  border:1.5px solid rgba(118,247,12,0.35);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);
  font-size:.74rem;font-weight:800;
  color:var(--accent);
  box-shadow:0 0 0 5px rgba(118,247,12,0.06);
}
.trilogy-step-text{display:flex;flex-direction:column;gap:.18rem}
.trilogy-step-text strong{
  font-size:.92rem;font-weight:700;color:var(--white);
  letter-spacing:-.012em;
}
.trilogy-step-text span{
  font-size:.78rem;color:rgba(255,255,255,.5);
  line-height:1.5;
}

.trilogy-cta{
  display:flex;flex-direction:column;align-items:center;gap:.85rem;
  padding-top:.5rem;
}
@media(min-width:520px){.trilogy-cta{flex-direction:row;justify-content:center}}
.trilogy-cta .btn-ghost{
  background:rgba(255,255,255,.05);
  color:var(--white);border-color:rgba(255,255,255,.15);
}
.trilogy-cta .btn-ghost:hover{
  background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.3);
}

/* Mobile reveal stagger inside the trilogy stack */
.trilogy-stack > .program{
  opacity:0;transform:translateY(24px);
  transition:opacity .7s var(--ease-out), transform .7s var(--ease-out), border-color .35s var(--ease), box-shadow .45s var(--ease);
}
.trilogy-stack.in > .program{opacity:1;transform:translateY(0)}
.trilogy-stack.in > .program:nth-child(1){transition-delay:60ms}
.trilogy-stack.in > .program:nth-child(2){transition-delay:160ms}
.trilogy-stack.in > .program:nth-child(3){transition-delay:260ms}

/* Ticker / scrolling brand strip below trilogy */
.trilogy-ticker{
  margin-top:clamp(2rem,4vw,3rem);
  overflow:hidden;
  border-top:1px solid rgba(255,255,255,.05);
  border-bottom:1px solid rgba(255,255,255,.05);
  padding:.85rem 0;
  position:relative;
  z-index:1;
  mask-image:linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
  -webkit-mask-image:linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
}
.trilogy-ticker-track{
  display:flex;gap:0;width:max-content;
  animation:tickerScroll 40s linear infinite;
}
.trilogy-ticker-item{
  display:inline-flex;align-items:center;gap:.65rem;
  padding:0 2.5rem;
  font-family:var(--mono);
  font-size:.78rem;font-weight:600;
  color:rgba(255,255,255,.45);
  letter-spacing:.06em;text-transform:uppercase;
  white-space:nowrap;
}
.trilogy-ticker-item .dot{
  width:5px;height:5px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 6px rgba(118,247,12,.5);
  flex-shrink:0;
}
@keyframes tickerScroll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* Reduced motion guard */
@media (prefers-reduced-motion: reduce) {
  .program-frameshift .program-glyph svg line,
  .program-frameshift .program-glyph svg circle,
  .program-dieline .program-glyph svg rect,
  .program-aaroh .program-glyph svg polygon,
  .trilogy-ticker-track{
    animation: none !important;
  }
}
