:root{
  --slate-50:#f8fafc;
  --slate-100:#f1f5f9;
  --slate-200:#e2e8f0;
  --slate-400:#94a3b8;
  --slate-500:#64748b;
  --slate-600:#475569;
  --slate-800:#1e293b;
  --slate-900:#0f172a;
  --green-50:#f0fdf4;
  --green-100:#dcfce7;
  --green-500:#22c55e;
  --green-600:#16a34a;
  --green-700:#15803d;
  --yellow-400:#facc15;
  --blue-500:#3b82f6;
  --orange-500:#f97316;
  --red-600:#dc2626;

  /* Hero tuning knobs */
  --hero-img-max-w:560px;
  --hero-img-max-h:76vh;
  --hero-img-shift-x:26px;
}

*{box-sizing:border-box;}
body{font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;scroll-behavior:smooth;background:var(--slate-50);color:var(--slate-900);}

/* Performance: skip rendering offscreen sections until needed */
.cv-auto{content-visibility:auto;contain-intrinsic-size:900px 1200px;}

/* Try to keep the hero fully visible at 100% zoom */
.hero-section{
  min-height:calc(100vh - 76px);
  padding-top:1.5rem;
  padding-bottom:2rem;
}
.hero-row{padding-top:.5rem;}
.hero-image-wrap{max-width:var(--hero-img-max-w);width:100%;}
.hero-image-wrap img{max-height:var(--hero-img-max-h);position:relative;z-index:3;transform:translateX(var(--hero-img-shift-x, 0px));}

@media (max-height: 820px){
  .hero-section{padding-top:1rem;padding-bottom:1rem;}
  .hero-image-wrap img{max-height:66vh;}
}

.bg-slate-50{background:var(--slate-50);}
.text-slate-900{color:var(--slate-900);}
.text-green{color:var(--green-600);}
.text-green-700{color:var(--green-700) !important;}
.text-red{color:var(--red-600) !important;}

/* Navbar branding */
.brand-icon{display:inline-flex;align-items:center;justify-content:center;background:var(--green-600);color:#fff;border-radius:.7rem;padding:.35rem .45rem;font-size:1.1rem;}
.brand-logo{width:34px;height:34px;border-radius:.6rem;object-fit:cover;display:block;}
.brand-text{font-weight:900;letter-spacing:-.02em;color:var(--slate-900);}
.navlink{font-weight:600;font-size:.9rem;color:var(--slate-600) !important;}
.navlink:hover{color:var(--green-600) !important;}
.navlink.active{color:var(--green-600) !important;}
.btn-join{background:var(--green-600);color:#fff !important;font-weight:800;border-radius:999px;padding:.55rem 1.1rem;border:0;}
.btn-join:hover{background:var(--green-700);}

/* Hero + special effects (ported from index.html) */
.mesh-bg{
  background-color:var(--slate-50);
  background-image:
    radial-gradient(at 0% 0%, hsla(142, 70%, 90%, 1) 0, transparent 50%),
    radial-gradient(at 50% 0%, hsla(142, 60%, 85%, 1) 0, transparent 50%),
    radial-gradient(at 100% 0%, hsla(160, 60%, 90%, 1) 0, transparent 50%);
  animation:none;
}
@keyframes meshMove{0%{background-position:0% 0%;}100%{background-position:100% 100%;}}

.glass{
  background:rgba(255,255,255,.7);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.3);
}
.glass-dark{
  background:rgba(15,23,42,.8);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.1);
}

.text-gradient{
  background:linear-gradient(to right,#10b981,#059669);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
}

.blob{
  position:absolute;
  width:400px;height:400px;
  background:linear-gradient(180deg, rgba(16,185,129,.2) 0%, rgba(5,150,105,.1) 100%);
  filter:blur(80px);
  border-radius:50%;
  z-index:0;
  pointer-events:none;
  will-change:transform;
  contain:layout paint;
  animation:none;
}
@keyframes blobFloat{0%{transform:translate(0,0) scale(1);}100%{transform:translate(100px,50px) scale(1.2);}}

/* Utility-ish helpers to match the current design */
.rounded-2xl{border-radius:1rem;}
.rounded-3xl{border-radius:1.5rem;}
.rounded-4xl{border-radius:2rem;}
.rounded-5xl{border-radius:2.5rem;}
.rounded-6xl{border-radius:3rem;}
.rounded-7xl{border-radius:4rem;}

.shadow-green{box-shadow:0 25px 50px -12px rgba(34,197,94,.25);} 
.shadow-soft{box-shadow:0 25px 50px -12px rgba(15,23,42,.12);} 

.badge-hero{display:inline-block;padding:.45rem 1rem;background:var(--green-600);color:#fff;font-size:.72rem;font-weight:900;text-transform:uppercase;letter-spacing:.14em;border-radius:999px;box-shadow:0 20px 30px rgba(34,197,94,.25);} 

.hero-h1{font-weight:900;letter-spacing:-.03em;line-height:1.05;}
.hero-p{font-weight:600;color:var(--slate-600);line-height:1.6;}

.btn-cta{display:inline-flex;align-items:center;justify-content:center;gap:.75rem;padding:1.15rem 2.5rem;border-radius:1.25rem;background:var(--green-600);color:#fff;font-weight:900;font-size:1.25rem;border:0;transition:transform .2s ease, background .2s ease;box-shadow:0 30px 60px rgba(34,197,94,.25);} 
.btn-cta:hover{background:var(--green-700);transform:scale(1.03);} 

/* Extra attention CTA (used in Worth it section) */
.btn-attn{position:relative;animation:attnBreathe 2.9s ease-in-out infinite;transform-origin:center;}
.btn-attn::after{content:'';position:absolute;inset:-12px;border-radius:1.55rem;border:2px solid rgba(34,197,94,.22);opacity:0;animation:attnRipple 2.9s ease-out infinite;pointer-events:none;}

@keyframes attnBreathe{0%,100%{transform:translate3d(0,0,0) scale(1);}50%{transform:translate3d(0,-2px,0) scale(1.03);}}
@keyframes attnRipple{0%{transform:scale(.86);opacity:0;}25%{opacity:1;}100%{transform:scale(1.12);opacity:0;}}

/* Subtle attention wiggle for primary CTA */
.btn-cta-wiggle{
  animation:none;
  transform-origin:center;
}

@keyframes ctaWiggle{
  0%, 78%, 100%{transform:translate3d(0,0,0) scale(1);} 
  82%{transform:translate3d(0,-2px,0) scale(1.01);} 
  86%{transform:translate3d(0,0,0) rotate(-1deg) scale(1.01);} 
  90%{transform:translate3d(0,0,0) rotate(1deg) scale(1.01);} 
  94%{transform:translate3d(0,0,0) rotate(0deg) scale(1.01);} 
}

.value-chip{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;border-radius:1.25rem;}

.student-avatars img{width:48px;height:48px;border-radius:999px;border:4px solid #fff;box-shadow:0 10px 20px rgba(15,23,42,.08);object-fit:cover;}
.student-avatars .count{width:48px;height:48px;border-radius:999px;background:var(--slate-900);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:900;border:4px solid #fff;}

.section-dark{background:var(--slate-900);color:#fff;position:relative;overflow:hidden;}

/* Value section (after hero) */
.value-bullet{width:28px;height:28px;border-radius:999px;display:flex;align-items:center;justify-content:center;background:rgba(34,197,94,.14);color:var(--green-500);flex:0 0 auto;margin-top:2px;}
.value-card{padding:1.75rem;border-radius:2.25rem;transition:transform .2s ease, border-color .2s ease;}
.value-card:hover{transform:translateY(-3px);border-color:rgba(34,197,94,.28);}
.value-card-icon{width:56px;height:56px;border-radius:1.25rem;display:flex;align-items:center;justify-content:center;background:rgba(34,197,94,.12);color:var(--green-500);font-size:1.35rem;margin-bottom:1.15rem;}
.value-card-title{font-weight:900;font-size:1.25rem;letter-spacing:-.01em;margin-bottom:.35rem;}
.value-card-desc{color:rgba(148,163,184,1);font-weight:650;line-height:1.7;}

/* Roadmap strip (learn plan) */
.roadmap-strip{position:relative;border-radius:2.5rem;border:1px solid rgba(255,255,255,.10);padding:2rem;overflow:hidden;height:100%;display:flex;flex-direction:column;}
.roadmap-strip::before{content:'';position:absolute;inset:0;background:radial-gradient(700px 240px at 25% 15%, rgba(34,197,94,.10), transparent 60%),radial-gradient(600px 220px at 80% 80%, rgba(255,255,255,.06), transparent 60%);opacity:.85;pointer-events:none;}
.roadmap-strip-head{position:relative;z-index:1;margin-bottom:1rem;}
.roadmap-strip-title{font-weight:900;color:#fff;letter-spacing:-.01em;font-size:1.25rem;}

.roadmap-learn{position:relative;z-index:1;display:grid;grid-template-columns:repeat(2, minmax(0, 1fr));gap:1rem;}
.wk-card{border-radius:1.75rem;border:1px solid rgba(255,255,255,.12);background:rgba(15,23,42,.58);padding:1.25rem;box-shadow:0 22px 55px rgba(0,0,0,.18);}
.wk-head{display:flex;align-items:center;gap:.85rem;margin-bottom:.85rem;}
.wk-ic{width:56px;height:56px;border-radius:1.25rem;display:flex;align-items:center;justify-content:center;background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.22);color:var(--green-500);font-size:1.6rem;flex:0 0 auto;}
.wk-tt{font-weight:900;color:#fff;letter-spacing:-.01em;line-height:1.15;font-size:1.05rem;}
.wk-sub{color:rgba(148,163,184,1);font-weight:750;font-size:.88rem;line-height:1.2;margin-top:.15rem;}
.wk-list{margin:0;padding-left:0;list-style:none;display:grid;gap:.45rem;}
.wk-list li{color:rgba(226,232,240,1);font-weight:650;font-size:.92rem;line-height:1.35;display:flex;gap:.55rem;}
.wk-list li::before{content:'✓';width:22px;height:22px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:rgba(34,197,94,.16);color:var(--green-500);font-weight:900;flex:0 0 auto;transform:translateY(1px);}

.roadmap-strip-foot{position:relative;z-index:1;margin-top:1rem;color:rgba(148,163,184,1);font-weight:650;}

@media (max-width: 991.98px){
  .roadmap-strip{padding:1.5rem;}
  .roadmap-learn{grid-template-columns:1fr;}
  .wk-card{padding:1.15rem;}
}

/* Curriculum watermarks */
.curriculum-wrap{position:relative;overflow:visible;}
.curr-watermarks{position:absolute;inset:0;pointer-events:none;z-index:4;}
.curr-watermarks .wm{position:absolute;opacity:.10;filter:blur(.0px);color:var(--slate-900);}
.curr-watermarks .wm-c,.curr-watermarks .wm-d{opacity:.14;}
.curr-watermarks .wm-a{left:-10px;top:40px;font-size:220px;animation:wmFloatA 9s ease-in-out infinite;}
.curr-watermarks .wm-b{right:-20px;top:120px;font-size:200px;animation:wmFloatB 10.5s ease-in-out infinite;}
.curr-watermarks .wm-c{left:6%;bottom:18px;transform:none;display:flex;gap:.75rem;align-items:center;font-size:82px;animation:wmFloatBottomL 10.5s ease-in-out infinite;}
.curr-watermarks .wm-c span{font-size:28px;font-weight:900;letter-spacing:.22em;text-transform:uppercase;opacity:.78;}
.curr-watermarks .wm-d{display:none;}
.curr-watermarks .wm-d::after{content:"Meta";}
.curr-watermarks-edge{position:absolute;left:0;right:0;bottom:0;pointer-events:none;z-index:8;}
.curr-watermarks-edge .wm-d{position:absolute;right:4%;bottom:-34px;font-size:132px;opacity:.18;color:var(--slate-900);animation:wmFloatBottomR 11.2s ease-in-out infinite;}
.curr-watermarks-edge .wm-d::after{content:"Meta";display:block;margin-top:.25rem;font-size:16px;font-weight:900;letter-spacing:.18em;text-transform:uppercase;opacity:.70;text-align:center;}
.curriculum-wrap .container-xl{position:relative;z-index:1;}

/* Keep text/content above watermarks, but allow watermarks above card backgrounds */
.curriculum-wrap .container-xl > :not(.curr-watermarks){position:relative;z-index:3;}

/* Make the watermarks visible and crisp */
.curriculum-wrap .glass{backdrop-filter:none;-webkit-backdrop-filter:none;}
.curriculum-wrap .curr-card{background:rgba(255,255,255,.40);}

@media (max-width: 991.98px){
  .curr-watermarks .wm-a{font-size:170px;left:-30px;top:10px;}
  .curr-watermarks .wm-b{font-size:150px;right:-30px;top:80px;}
  .curr-watermarks .wm-c{left:4%;bottom:10px;font-size:64px;}
  .curr-watermarks-edge .wm-d{right:4%;bottom:-26px;font-size:110px;}
  .curr-watermarks-edge .wm-d::after{font-size:14px;}
}

@keyframes wmFloatBottomL{0%,100%{transform:translate3d(0,0,0) rotate(-4deg);}50%{transform:translate3d(0,-10px,0) rotate(-1deg);}}
@keyframes wmFloatBottomR{0%,100%{transform:translate3d(0,0,0) rotate(5deg);}50%{transform:translate3d(0,-12px,0) rotate(2deg);}}

@keyframes wmFloatA{0%,100%{transform:translate3d(0,0,0) rotate(-6deg);}50%{transform:translate3d(0,10px,0) rotate(-2deg);}}
@keyframes wmFloatB{0%,100%{transform:translate3d(0,0,0) rotate(8deg);}50%{transform:translate3d(0,-12px,0) rotate(4deg);}}
@keyframes wmFloatC{0%,100%{transform:translate3d(-50%,0,0) rotate(-2deg);}50%{transform:translate3d(-50%,-10px,0) rotate(2deg);}}

.reason-icon{width:56px;height:56px;border-radius:1rem;display:flex;align-items:center;justify-content:center;background:rgba(34,197,94,.10);color:var(--green-500);font-size:1.35rem;flex:0 0 auto;}

.curr-card{padding:2.5rem;border-radius:2.5rem;border:1px solid var(--slate-100);transition:border-color .2s ease, transform .2s ease, background .2s ease;}
.curr-card:hover{border-color:rgba(34,197,94,.9);transform:translateY(-2px);} 

.module-num{width:56px;height:56px;border-radius:1rem;background:var(--slate-900);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1.25rem;margin-bottom:2rem;transition:background .2s ease;} 
.curr-card:hover .module-num{background:var(--green-600);} 

.bonus-card{border-radius:2.5rem;color:#fff;background:linear-gradient(135deg,#16a34a,#166534);padding:2.5rem;}

/* Enroll (index) helpers */
.enroll-stat{padding:1.75rem;border-radius:2.25rem;border:1px solid var(--slate-100);}
.enroll-stat-ic{width:56px;height:56px;border-radius:1.25rem;display:flex;align-items:center;justify-content:center;background:rgba(34,197,94,.12);color:var(--green-600);font-size:1.35rem;margin-bottom:1rem;}
.enroll-stat-tt{font-weight:900;font-size:1.15rem;letter-spacing:-.01em;margin-bottom:.35rem;color:var(--slate-900);}
.enroll-stat-ds{color:var(--slate-600);font-weight:650;line-height:1.7;}

/* Reviews */
.review-img{width:100%;height:240px;object-fit:cover;display:block;}
@media (max-width: 575.98px){
  .review-img{height:220px;}
}

.guarantee-wrap{background:#ecfdf5;border-top:1px solid #d1fae5;border-bottom:1px solid #d1fae5;}

/* Always-on attention wiggle (guarantee) */
.guarantee-wiggle{animation:softWiggle 4.8s ease-in-out infinite;transform-origin:center;}
@keyframes softWiggle{
  0%, 76%, 100%{transform:translate3d(0,0,0) rotate(0deg) scale(1);} 
  82%{transform:translate3d(0,-2px,0) rotate(-2deg) scale(1.02);} 
  88%{transform:translate3d(0,0,0) rotate(2deg) scale(1.02);} 
  94%{transform:translate3d(0,0,0) rotate(0deg) scale(1.01);} 
}

.guarantee-badge i{transform-origin:50% 50%;}
.guarantee-wrap.is-in .guarantee-badge i{animation:guaranteePop .85s cubic-bezier(.2,.9,.2,1) both;}

@keyframes guaranteePop{
  0%{transform:scale(.6) rotate(-10deg);opacity:.2;filter:drop-shadow(0 0 0 rgba(34,197,94,0));}
  55%{transform:scale(1.15) rotate(6deg);opacity:1;filter:drop-shadow(0 18px 36px rgba(34,197,94,.22));}
  100%{transform:scale(1) rotate(0deg);opacity:1;filter:drop-shadow(0 10px 22px rgba(15,23,42,.12));}
}

/* Simple, always-working guarantee seal (replaces external image) */
.guarantee-seal{
  width:96px;
  height:96px;
  border-radius:999px;
  position:relative;
  display:grid;
  place-items:center;
}

.guarantee-seal .ring{
  width:96px;
  height:96px;
  border-radius:999px;
  background:#fff;
  border:4px solid var(--green-500);
  box-shadow:0 25px 50px rgba(15,23,42,.12);
  display:grid;
  place-items:center;
}

.guarantee-seal .ring i{
  font-size:2rem;
  color:var(--green-600);
}

.guarantee-seal .txt{
  position:absolute;
  bottom:-10px;
  left:50%;
  transform:translateX(-50%);
  background:var(--slate-900);
  color:#fff;
  font-weight:900;
  font-size:.62rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  padding:.35rem .55rem;
  border-radius:999px;
  border:3px solid #fff;
}

.cta-box{background:var(--slate-900);color:#fff;border-radius:4rem;padding:4rem;position:relative;overflow:hidden;}

/* WhatsApp ask row wrap fix */
.ask-row{flex-wrap:wrap;}
.ask-row .input-ask{min-width:180px;}
@media (max-width: 575.98px){
  .ask-row .btn-ask{width:100%;}
}

.input-ask{background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.20);color:#fff;border-radius:1.25rem;padding:1rem 1.25rem;outline:0;}
.input-ask::placeholder{color:rgba(255,255,255,.35);} 
.input-ask:focus{box-shadow:0 0 0 .35rem rgba(34,197,94,.35);}

.btn-ask{background:var(--green-600);border:0;color:#fff;border-radius:1.25rem;font-weight:900;padding:1rem 1.6rem;box-shadow:0 20px 40px rgba(34,197,94,.25);} 
.btn-ask:hover{background:var(--green-700);} 
.btn-ask:disabled{opacity:.5;} 

.btn-final{width:100%;padding:1.35rem 1.5rem;background:#fff;color:var(--slate-900);font-weight:900;font-size:1.6rem;border-radius:1.75rem;border:0;box-shadow:0 30px 60px rgba(15,23,42,.15);} 
.btn-final:hover{background:var(--slate-100);} 

/* Copy button (payment cards) */
.copy-btn{width:40px;height:40px;border-radius:999px;border:1px solid var(--slate-200);background:#fff;color:var(--slate-600);display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;box-shadow:0 10px 24px rgba(15,23,42,.06);}
.copy-btn:hover{color:var(--green-700);border-color:rgba(34,197,94,.35);}
.copy-btn.is-copied{background:var(--green-50);border-color:#bbf7d0;color:var(--green-700);}

/* Payment submit overlay (animation with tick) */
.submit-overlay{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:rgba(15,23,42,.55);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);}
.submit-overlay .box{width:min(520px, 92vw);border-radius:2.25rem;border:1px solid rgba(255,255,255,.18);background:rgba(15,23,42,.85);color:#fff;padding:2rem;text-align:center;box-shadow:0 35px 80px rgba(0,0,0,.35);}
.submit-overlay .ring{width:86px;height:86px;border-radius:999px;margin:0 auto 1rem;display:grid;place-items:center;border:2px solid rgba(255,255,255,.18);position:relative;}
.submit-overlay .spinner{width:48px;height:48px;border-radius:999px;border:4px solid rgba(255,255,255,.18);border-top-color:var(--green-500);animation:spin 1s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.submit-overlay .tick{display:none;font-size:2.4rem;color:var(--green-500);animation:tickPop .55s cubic-bezier(.2,.9,.2,1) both;}
@keyframes tickPop{0%{transform:scale(.5);opacity:0;}70%{transform:scale(1.12);opacity:1;}100%{transform:scale(1);opacity:1;}}
.submit-overlay.is-done .spinner{display:none;}
.submit-overlay.is-done .tick{display:inline-block;}
.submit-overlay .tt{font-weight:900;font-size:1.3rem;letter-spacing:-.02em;margin-bottom:.35rem;}
.submit-overlay .ds{color:rgba(148,163,184,1);font-weight:700;}

/* Success screen check */
.success-check{font-size:4.25rem;color:var(--green-600);margin-bottom:1.25rem;animation:tickPop .55s cubic-bezier(.2,.9,.2,1) both;filter:drop-shadow(0 18px 36px rgba(34,197,94,.18));}

.whatsapp-fab{position:fixed;right:2.5rem;bottom:2.5rem;width:80px;height:80px;border-radius:999px;background:var(--green-500);color:#fff;display:flex;align-items:center;justify-content:center;font-size:2.2rem;box-shadow:0 30px 60px rgba(15,23,42,.25);z-index:999;transition:transform .2s ease, box-shadow .2s ease;outline:0;text-decoration:none !important;border-bottom:0 !important;line-height:1;-webkit-tap-highlight-color:transparent;}
.whatsapp-fab:hover{transform:scale(1.07);} 

.whatsapp-fab-anim{animation:none;}
.whatsapp-fab-anim::before{display:none;}
.whatsapp-fab-anim:hover{box-shadow:0 35px 70px rgba(15,23,42,.30);} 

@keyframes waFloat{0%,100%{transform:translateY(0);}50%{transform:translateY(-6px);}}
@keyframes waRipple{0%{transform:scale(.85);opacity:.0;}25%{opacity:1;}100%{transform:scale(1.2);opacity:0;}}

/* Simple animations to mimic Tailwind animate-* */
.fade-in{animation:fadeIn .35s ease both;}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}

.pulse{animation:pulse 1.6s ease-in-out infinite;}
@keyframes pulse{0%,100%{transform:scale(1);}50%{transform:scale(1.03);}}

.bounce-slow{animation:bounce 4s infinite;}
@keyframes bounce{0%,100%{transform:translateY(0);}50%{transform:translateY(-8px);}}

/* Footer */
.footer-dark{background:#111827;color:#fff;padding:3.25rem 0;}
.footer-title{font-weight:800;margin-bottom:1rem;}
.footer-subtitle{color:var(--green-500);font-weight:700;margin-bottom:1rem;}
.footer-text{color:#9ca3af;font-size:.9rem;line-height:1.6;}
.footer-links a{color:#9ca3af;text-decoration:none;font-size:.9rem;display:inline-block;padding:.25rem 0;}
.footer-links a:hover{color:#fff;}
.footer-icon{font-size:1.25rem;color:#fff;cursor:pointer;}
.footer-icon:hover{color:var(--green-500);}

.text-xs{font-size:.75rem;}
.text-gray-500{color:#6b7280 !important;}
.border-gray-800{border-color:#1f2937 !important;}

/* Enrollment / Admin / LMS helpers */
.panel{border-radius:3rem;overflow:hidden;}
.panel-head{background:var(--slate-900);color:#fff;text-align:center;padding:4rem 2.5rem;}
.panel-body{padding:2.5rem;}
@media (min-width:992px){.panel-body{padding:4rem;}}

.stepper{position:relative;display:flex;justify-content:space-between;margin-bottom:4rem;}
.stepper::before{content:'';position:absolute;left:0;right:0;top:26px;height:4px;border-radius:999px;background:rgba(255,255,255,.55);}
.stepper .bar{position:absolute;left:0;top:26px;height:4px;border-radius:999px;background:var(--green-600);width:0;transition:width .7s ease;}
.stepper .step{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:.75rem;}
.stepper .dot{width:56px;height:56px;border-radius:1rem;display:flex;align-items:center;justify-content:center;font-weight:900;box-shadow:0 20px 40px rgba(15,23,42,.12);transition:transform .5s ease, background .5s ease, color .5s ease;}
.stepper .dot.active{background:var(--green-600);color:#fff;transform:scale(1.08);} 
.stepper .dot.inactive{background:#fff;color:#cbd5e1;} 
.stepper .label{font-size:.62rem;font-weight:900;color:var(--slate-500);text-transform:uppercase;letter-spacing:.14em;}

.form-label-sm{font-size:.72rem;font-weight:900;color:var(--slate-500);text-transform:uppercase;letter-spacing:.10em;margin-bottom:.35rem;}
.input-xl{padding:1rem 1.25rem;border-radius:1rem;border:1px solid var(--slate-200);font-weight:600;}
.input-xl:focus{border-color:#86efac;box-shadow:0 0 0 .35rem rgba(34,197,94,.12);}

.btn-dark-xl{width:100%;padding:1.25rem 1.5rem;border-radius:2rem;background:var(--slate-900);color:#fff;font-weight:900;font-size:1.15rem;border:0;box-shadow:0 30px 60px rgba(15,23,42,.12);} 
.btn-dark-xl:disabled{opacity:.5;} 

.btn-green-xl{background:var(--green-600);color:#fff;border:0;border-radius:2rem;padding:1.25rem 1.5rem;font-weight:900;box-shadow:0 30px 60px rgba(34,197,94,.25);} 
.btn-green-xl:disabled{opacity:.5;} 

.receipt-drop{width:100%;aspect-ratio:1/1;border-radius:3rem;border:4px dashed var(--slate-200);display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden;transition:border-color .2s ease, background .2s ease;}
.receipt-drop:hover{border-color:rgba(34,197,94,.9);} 
.receipt-drop.filled{border-color:rgba(34,197,94,.9);background:var(--green-50);} 
.receipt-drop input{position:absolute;inset:0;opacity:0;cursor:pointer;}

.table-card{border-radius:2.5rem;overflow:hidden;border:1px solid var(--slate-200);} 
.table thead{background:var(--slate-900);color:#fff;} 

/* Admin layout (responsive sidebar) */
.admin-shell{min-height:100vh;display:flex;gap:1rem;padding:1.25rem 1rem;font-size:14px;line-height:1.45;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;}
.admin-side{width:280px;flex:0 0 auto;background:#fff;border:1px solid var(--slate-100);border-radius:1.75rem;padding:1rem;position:sticky;top:1.25rem;align-self:flex-start;overflow:visible;max-height:none;}
.admin-main{flex:1 1 auto;min-width:0;}
.admin-top{background:#fff;border:1px solid var(--slate-100);border-radius:1.75rem;padding:1.25rem 1.25rem;margin-bottom:1rem;}
.admin-top-title{font-size:1.15rem;font-weight:900;letter-spacing:-.015em;color:var(--slate-900);}

/* Avoid backdrop-filter blur in admin (can make text look soft on Windows) */
.admin-shell .glass{background:#fff;backdrop-filter:none;-webkit-backdrop-filter:none;border:1px solid var(--slate-200);} 

.admin-shell .table-card{border-radius:1.75rem;}
.admin-shell .table thead{background:var(--slate-900);color:#fff;}
.admin-shell .table th{font-size:.62rem;font-weight:900;text-transform:uppercase;letter-spacing:.14em;white-space:nowrap;}
.admin-shell .table th,.admin-shell .table td{padding:1.05rem 1.1rem;}

.admin-brand{display:flex;align-items:center;gap:.85rem;margin-bottom:1rem;padding:.25rem .25rem .75rem;}
.admin-badge{width:44px;height:44px;border-radius:1rem;background:rgba(34,197,94,.12);color:var(--green-600);display:flex;align-items:center;justify-content:center;font-size:1.1rem;}
.admin-brand-title{font-weight:900;letter-spacing:-.01em;line-height:1;}
.admin-brand-sub{font-size:.72rem;font-weight:900;letter-spacing:.14em;text-transform:uppercase;color:var(--slate-400);margin-top:.15rem;}

.admin-nav-link{display:flex;align-items:center;gap:.75rem;padding:.8rem .85rem;border-radius:1.1rem;text-decoration:none;color:var(--slate-700);font-weight:850;}
.admin-nav-link .ic{width:36px;height:36px;border-radius:1rem;background:var(--slate-100);display:flex;align-items:center;justify-content:center;color:var(--slate-700);flex:0 0 auto;}
.admin-nav-link:hover{background:var(--slate-50);color:var(--slate-900);}
.admin-nav-link.active{background:rgba(34,197,94,.12);color:var(--green-700);}
.admin-nav-link.active .ic{background:rgba(34,197,94,.14);color:var(--green-700);}
.admin-nav-link.danger{color:var(--red-600);}
.admin-nav-link.danger .ic{background:#fef2f2;color:var(--red-600);}

.admin-side-divider{height:1px;background:var(--slate-100);margin:1rem 0;}

/* Admin-only dark theme (toggle adds .admin-dark on body) */
body.admin-page.admin-dark{background:var(--slate-900);color:var(--slate-50);}
body.admin-page.admin-dark .admin-shell{color:var(--slate-50);}
body.admin-page.admin-dark .admin-side,
body.admin-page.admin-dark .admin-top,
body.admin-page.admin-dark .glass,
body.admin-page.admin-dark .table-card{background:var(--slate-800) !important;border-color:rgba(226,232,240,.14) !important;}
body.admin-page.admin-dark .admin-brand-sub{color:rgba(226,232,240,.6);}
body.admin-page.admin-dark .admin-top-title{color:var(--slate-50);}

body.admin-page.admin-dark .admin-nav-link{color:rgba(241,245,249,.86);}
body.admin-page.admin-dark .admin-nav-link:hover{background:rgba(241,245,249,.06);color:var(--slate-50);}
body.admin-page.admin-dark .admin-nav-link .ic{background:rgba(241,245,249,.08);color:rgba(241,245,249,.86);}

body.admin-page.admin-dark .admin-side-divider{background:rgba(226,232,240,.14);}

body.admin-page.admin-dark .admin-nav-link.active{background:rgba(34,197,94,.14);color:var(--green-100);}
body.admin-page.admin-dark .admin-nav-link.active .ic{background:rgba(34,197,94,.16);color:var(--green-100);}

body.admin-page.admin-dark .admin-nav-link.danger{color:rgba(252,165,165,.95);}
body.admin-page.admin-dark .admin-nav-link.danger .ic{background:rgba(220,38,38,.18);color:rgba(252,165,165,.95);}


/* Stat boxes */
body.admin-page.admin-dark .statbox{background:var(--slate-800) !important;border-color:rgba(226,232,240,.14) !important;}
body.admin-page.admin-dark .statbox .lab{color:rgba(226,232,240,.58) !important;}
body.admin-page.admin-dark .statbox .ic{background:rgba(241,245,249,.08) !important;color:rgba(241,245,249,.86) !important;}

/* Tables (remove white blocks + ensure readability) */
body.admin-page.admin-dark .bg-white{background-color:transparent !important;}
body.admin-page.admin-dark .table{color:rgba(241,245,249,.86);--bs-table-color:rgba(241,245,249,.86);--bs-table-bg:transparent;--bs-table-border-color:rgba(226,232,240,.12);}
body.admin-page.admin-dark .table>:not(caption)>*>*{background-color:transparent !important;color:rgba(241,245,249,.86) !important;}
body.admin-page.admin-dark .table td,
body.admin-page.admin-dark .table th{border-color:rgba(226,232,240,.12) !important;}
body.admin-page.admin-dark .table tbody{background-color:transparent !important;}
body.admin-page.admin-dark .table tbody tr{background-color:transparent !important;}

/* Buttons used in admin headers */
body.admin-page.admin-dark .btn[style*="background:var(--slate-100)"]{background:rgba(241,245,249,.08) !important;color:rgba(241,245,249,.90) !important;}
body.admin-page.admin-dark .btn[style*="color:var(--slate-700)"]{color:rgba(241,245,249,.90) !important;}
body.admin-page.admin-dark .btn[style*="color:var(--slate-800)"]{color:rgba(241,245,249,.90) !important;}

/* Inputs */
body.admin-page.admin-dark .form-control,
body.admin-page.admin-dark .form-select{background:rgba(241,245,249,.06) !important;color:var(--slate-50) !important;border-color:rgba(226,232,240,.14) !important;}
body.admin-page.admin-dark .form-control::placeholder{color:rgba(226,232,240,.45) !important;}
body.admin-page.admin-dark .form-label-sm{color:rgba(226,232,240,.66) !important;}

/* Fix inline text colors used throughout admin pages */
body.admin-page.admin-dark [style*="color:var(--slate-900)"]{color:var(--slate-50) !important;}
body.admin-page.admin-dark [style*="color:var(--slate-800)"]{color:rgba(241,245,249,.92) !important;}
body.admin-page.admin-dark [style*="color:var(--slate-700)"]{color:rgba(241,245,249,.86) !important;}
body.admin-page.admin-dark [style*="color:var(--slate-600)"]{color:rgba(226,232,240,.76) !important;}
body.admin-page.admin-dark [style*="color:var(--slate-500)"]{color:rgba(226,232,240,.62) !important;}
body.admin-page.admin-dark [style*="color:var(--slate-400)"]{color:rgba(226,232,240,.52) !important;}

/* Delete buttons (existing inline bg is light on dark mode) */
body.admin-page.admin-dark button[style*="background:#fef2f2"],
body.admin-page.admin-dark a[style*="background:#fef2f2"]{
  background:rgba(220,38,38,.16) !important;
  color:rgba(252,165,165,.95) !important;
}

@media (max-width: 991.98px){
  .admin-shell{flex-direction:column;}
  .admin-side{width:100%;position:relative;top:auto;max-height:none;}
}

/* Admin stats */
.admin-shell .statbox{background:#fff;border:1px solid var(--slate-200);border-radius:1.25rem;padding:1rem 1.1rem;min-width:160px;display:flex;align-items:center;justify-content:space-between;gap:1rem;} 
.admin-shell .statbox .val{font-size:1.6rem;font-weight:900;line-height:1;} 
.admin-shell .statbox .lab{font-size:.62rem;font-weight:900;text-transform:uppercase;letter-spacing:.14em;color:var(--slate-400);margin-top:.35rem;} 
.admin-shell .statbox .ic{width:44px;height:44px;border-radius:1rem;background:var(--slate-100);display:flex;align-items:center;justify-content:center;color:var(--slate-700);flex:0 0 auto;font-size:1.05rem;}

.lms-card{background:#fff;border:1px solid #e5e7eb;border-radius:1.5rem;box-shadow:0 10px 30px rgba(15,23,42,.06);} 

/* Enrollment success screen */
.success-card{position:relative;overflow:hidden;}
.success-card::before{content:'';position:absolute;inset:-120px;left:-140px;background:radial-gradient(circle at 30% 30%, rgba(34,197,94,.22), transparent 55%);filter:blur(10px);pointer-events:none;}
.success-check{position:relative;z-index:1;width:96px;height:96px;margin:0 auto 1.25rem;border-radius:999px;background:#fff;border:4px solid var(--green-500);box-shadow:0 25px 50px rgba(15,23,42,.12);display:flex;align-items:center;justify-content:center;animation:successPop .85s cubic-bezier(.2,.9,.2,1) both;}
.success-check i{font-size:2.4rem;color:var(--green-600);}

/* LMS (Udemy-style) */
.lms-shell{min-height:100vh;background:var(--slate-50);display:grid;grid-template-columns:1fr 360px;}
.lms-header{grid-column:1 / -1;background:#fff;border-bottom:1px solid var(--slate-100);padding:.75rem 1.1rem;}
.lms-header{position:sticky;top:0;z-index:50;}
.lms-brand{display:flex;align-items:center;gap:.75rem;min-width:0;}
.lms-brand .logo{width:44px;height:44px;border-radius:1.1rem;background:var(--slate-900);color:#fff;display:flex;align-items:center;justify-content:center;flex:0 0 auto;box-shadow:0 18px 40px rgba(15,23,42,.10);}
.lms-brand .name{font-weight:950;letter-spacing:-.02em;color:var(--slate-900);font-size:1.05rem;line-height:1.05;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.lms-brand .sub{color:var(--slate-500);font-weight:750;font-size:.82rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.lms-header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;}
.lms-header-actions{display:flex;align-items:center;gap:.5rem;flex:0 0 auto;}
.lms-main{padding:1.1rem;}
.lms-main-inner{max-width:980px;}
.lms-player{max-width:860px;}
.lms-side{background:#fff;border-left:1px solid var(--slate-100);padding:1rem;position:sticky;top:0;height:100vh;overflow:auto;}
.lms-side{top:1rem;max-height:calc(100vh - 2rem);height:auto;}
.lms-kicker{font-size:.62rem;font-weight:900;text-transform:uppercase;letter-spacing:.14em;color:var(--slate-400);}
.lms-title{font-weight:900;letter-spacing:-.02em;color:var(--slate-900);}
.lms-meta{color:var(--slate-500);font-weight:700;font-size:.85rem;}
.lms-lesson-link{display:flex;gap:.65rem;align-items:center;padding:.7rem .8rem;border-radius:1.1rem;color:var(--slate-700);text-decoration:none;border:1px solid transparent;}
.lms-lesson-link:hover{background:var(--slate-50);border-color:var(--slate-100);}
.lms-lesson-link.active{background:var(--slate-900);color:#fff;border-color:var(--slate-900);box-shadow:0 20px 40px rgba(15,23,42,.12);}
.lms-lesson-link .ic{width:32px;height:32px;border-radius:999px;background:var(--slate-100);display:flex;align-items:center;justify-content:center;color:var(--slate-600);flex:0 0 auto;}
.lms-lesson-link.active .ic{background:rgba(241,245,249,.10);color:#fff;}
.lms-video{aspect-ratio:16/9;background:#000;border-radius:1.25rem;overflow:hidden;border:1px solid var(--slate-100);}

/* LMS Notification popup */
.lms-modal-backdrop{position:fixed;inset:0;display:none;align-items:center;justify-content:center;padding:1.25rem;background:rgba(15,23,42,.45);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:9999;}
.lms-modal-backdrop.show{display:flex;animation:lmsFadeIn .2s ease-out both;}
.lms-modal{width:min(680px, 100%);background:#fff;border:1px solid var(--slate-100);border-radius:1.6rem;box-shadow:0 40px 90px rgba(15,23,42,.22);overflow:hidden;transform:translateY(10px) scale(.98);opacity:0;}
.lms-modal-backdrop.show .lms-modal{animation:lmsPop .28s cubic-bezier(.2,.9,.2,1) both;}
.lms-modal-head{padding:1.1rem 1.25rem;border-bottom:1px solid var(--slate-100);display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;}
.lms-modal-title{font-weight:950;letter-spacing:-.02em;color:var(--slate-900);font-size:1.1rem;line-height:1.2;}
.lms-modal-body{padding:1.1rem 1.25rem;color:var(--slate-700);font-weight:650;line-height:1.65;}
.lms-modal-meta{padding:0 1.25rem 1.1rem;color:var(--slate-400);font-weight:800;font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;}

@keyframes lmsFadeIn{from{opacity:0}to{opacity:1}}
@keyframes lmsPop{from{transform:translateY(14px) scale(.97);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}

@media (prefers-reduced-motion: reduce){
  .lms-modal-backdrop.show{animation:none;}
  .lms-modal-backdrop.show .lms-modal{animation:none;transform:none;opacity:1;}
}

@media (max-width: 991.98px){
  .lms-shell{grid-template-columns:1fr;}
  .lms-side{position:relative;height:auto;border-left:0;border-top:1px solid var(--slate-100);}
  .lms-main-inner{max-width:none;}
}

@keyframes successPop{
  0%{transform:scale(.6) rotate(-12deg);opacity:.2;}
  55%{transform:scale(1.12) rotate(6deg);opacity:1;}
  100%{transform:scale(1) rotate(0deg);opacity:1;}
}

/* Hero floating skill cards */
/* Atom-like orbiting cards */
.hero-image-wrap{position:relative;}

/* Hero topics panel (replaces orbit/floating cards) */
.hero-topics{
  border:1px solid rgba(255,255,255,.45);
  padding:1.15rem;
}

/* Static shadow behind hero portrait (cheap paint) */
.hero-image-wrap::after{content:'';position:absolute;inset:auto 12% 10% 12%;height:64%;border-radius:2.5rem;background:radial-gradient(closest-side, rgba(15,23,42,.10), transparent 70%);filter:blur(8px);z-index:1;pointer-events:none;}

.hero-portrait{mask-image:linear-gradient(to bottom, black 80%, transparent 100%);}

.hero-topics-kicker{
  font-size:.7rem;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--slate-500);
  margin-bottom:.75rem;
}

.hero-topics-list{
  position:relative;
  --topic-h:68px;
  --topic-gap:10px;
  display:grid;
  gap:var(--topic-gap);
}

.hero-topic{
  position:relative;
  z-index:2;
  display:flex;
  align-items:center;
  gap:.85rem;
  padding:.75rem .85rem;
  border-radius:1.35rem;
  height:var(--topic-h);
  opacity:.55;
  transform:translate3d(0,0,0) scale(.98);
  animation:topicPulse 8s linear infinite;
  animation-delay:calc(var(--i, 0) * 2s);
}

.hero-topic-icon{
  width:44px;height:44px;
  border-radius:1rem;
  display:flex;align-items:center;justify-content:center;
  background:rgba(34,197,94,.12);
  color:var(--green-600);
  flex:0 0 auto;
  font-size:1.1rem;
}

.hero-topic-title{font-weight:900;color:var(--slate-900);line-height:1.05;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.hero-topic-sub{font-size:.72rem;font-weight:800;color:var(--slate-500);margin-top:.1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

.hero-topic-highlight{
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:var(--topic-h);
  border-radius:1.35rem;
  background:rgba(34,197,94,.10);
  border:1px solid rgba(34,197,94,.25);
  z-index:1;
  animation:topicHighlight 8s linear infinite;
}

@keyframes topicHighlight{
  0%,24.999%{transform:translateY(0);} 
  25%,49.999%{transform:translateY(calc((var(--topic-h) + var(--topic-gap)) * 1));}
  50%,74.999%{transform:translateY(calc((var(--topic-h) + var(--topic-gap)) * 2));}
  75%,99.999%{transform:translateY(calc((var(--topic-h) + var(--topic-gap)) * 3));}
  100%{transform:translateY(0);} 
}

@keyframes topicPulse{
  0%, 24.999%{opacity:1;transform:scale(1.02);filter:drop-shadow(0 18px 36px rgba(15,23,42,.10));}
  25%, 100%{opacity:.55;transform:scale(.98);filter:none;}
}

@media (min-width:992px){
  .hero-topics{
    position:absolute;
    left:-10%;
    bottom:8%;
    width:min(340px, 70%);
    z-index:2;
    box-shadow:0 35px 70px rgba(15,23,42,.12);
  }
}

@media (max-width:991.98px){
  .hero-topics{margin-top:1rem;}
}

.hero-float-card{
  position:absolute;
  width:260px;
  max-width:62vw;
  opacity:.18;
  transform:scale(.90);
  filter:drop-shadow(0 15px 30px rgba(15,23,42,.08));
  animation:heroCardFocus 16s ease-in-out infinite;
  animation-delay:var(--delay);
}

.hero-float-card-inner{
  display:flex;
  align-items:center;
  gap:.85rem;
  padding:1rem 1.1rem;
  border-radius:1.75rem;
  border:none;
  box-shadow:0 25px 50px -12px rgba(15,23,42,.10);
  transform:translate3d(0,0,0);
  animation:heroCardDrift 4.25s ease-in-out infinite alternate;
}

.hero-float-icon{
  width:44px;height:44px;
  border-radius:1rem;
  display:flex;align-items:center;justify-content:center;
  background:rgba(34,197,94,.12);
  color:var(--green-600);
  flex:0 0 auto;
  font-size:1.1rem;
}

.hero-float-title{font-weight:900;color:var(--slate-900);line-height:1.05;}
.hero-float-sub{font-size:.62rem;font-weight:900;text-transform:uppercase;letter-spacing:.14em;color:var(--slate-500);margin-top:.15rem;}

@keyframes heroCardFocus{
  0%, 65%, 100%{
    opacity:.18;
    transform:scale(.90);
    filter:drop-shadow(0 15px 30px rgba(15,23,42,.06));
  }
  10%, 26%{
    opacity:1;
    transform:scale(1.05);
    filter:drop-shadow(0 30px 60px rgba(15,23,42,.18));
  }
}

@keyframes heroCardDrift{
  from{transform:translate3d(-10px, 10px, 0);}
  to{transform:translate3d(10px, -10px, 0);}
}

@media (prefers-reduced-motion: reduce){
  .hero-topic,
  .hero-topic-highlight{
    animation:none !important;
  }

  .btn-cta-wiggle{
    animation:none !important;
  }

  .guarantee-wrap.is-in .guarantee-badge i{
    animation:none !important;
  }
}
