/* ===== mezoxo — light theme, optimized animations ===== */
:root{
  --bg:#f6f9fc;
  --bg-2:#ffffff;
  --surface:#ffffff;
  --surface-2:#f4f6fb;
  --border:#e3e8f0;
  --text:#0a2540;
  --muted:#4a5568;
  /* single brand family (Stripe-style indigo) */
  --brand:#635bff;
  --brand-600:#4f46e5;
  --brand-100:#ecebff;
  /* legacy accent names remapped to the brand family for cohesion */
  --cyan:#635bff;
  --violet:#4f46e5;
  --pink:#7c83ff;
  --accent:#635bff;
  --grad:linear-gradient(135deg,#635bff 0%,#4f46e5 100%);
  --radius:18px;
  --shadow:0 18px 40px rgba(10,37,64,0.10);
  --shadow-sm:0 6px 18px rgba(10,37,64,0.07);
  --maxw:1180px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:'Sora',sans-serif;line-height:1.14;font-weight:700;letter-spacing:-0.02em;color:var(--text)}
a{color:inherit;text-decoration:none}
img{max-width:100%}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ===== Background (lightweight, no per-frame blur) ===== */
.bg-orbs{position:fixed;inset:0;z-index:-2;overflow:hidden;pointer-events:none;
  background:
    radial-gradient(900px 480px at 85% -10%, rgba(99,91,255,0.10), transparent 60%),
    radial-gradient(800px 460px at -5% 10%, rgba(99,91,255,0.07), transparent 60%),
    var(--bg);}
.orb{position:absolute;border-radius:50%;opacity:.35;will-change:transform;
  animation:float 22s ease-in-out infinite}
.orb-1{width:360px;height:360px;background:radial-gradient(circle,#c9c6ff,transparent 70%);top:-90px;left:-70px}
.orb-2{width:320px;height:320px;background:radial-gradient(circle,#d6d4ff,transparent 70%);top:45%;right:-90px;animation-delay:-7s}
.orb-3{width:260px;height:260px;background:radial-gradient(circle,#bcc2ff,transparent 70%);bottom:-70px;left:32%;animation-delay:-14s}
.grid-overlay{position:absolute;inset:0;opacity:.5;
  background-image:linear-gradient(rgba(15,20,36,.035) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(15,20,36,.035) 1px,transparent 1px);
  background-size:52px 52px;
  -webkit-mask-image:radial-gradient(circle at 50% 25%,#000,transparent 78%);
  mask-image:radial-gradient(circle at 50% 25%,#000,transparent 78%)}
@keyframes float{0%,100%{transform:translate3d(0,0,0)}50%{transform:translate3d(24px,-22px,0)}}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;gap:8px;justify-content:center;
  font-weight:600;font-size:.95rem;padding:11px 20px;border-radius:999px;border:1px solid transparent;
  cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease,border-color .2s,color .2s}
.btn:active{transform:translateY(0) scale(.98)}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 8px 22px rgba(99,91,255,.28);font-weight:700}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(99,91,255,.36)}
.btn-outline{border-color:var(--border);background:var(--surface);color:var(--text)}
.btn-outline:hover{border-color:var(--cyan);color:var(--cyan);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--text)}
.btn-ghost:hover{color:var(--violet)}
.btn-soft{background:var(--surface-2);border:1px solid var(--border);color:var(--text)}
.btn-soft:hover{border-color:var(--violet);color:var(--violet);transform:translateY(-2px)}
.btn-help{background:var(--grad);color:#fff;font-weight:700;box-shadow:0 8px 20px rgba(99,91,255,.32)}
.btn-help:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(99,91,255,.45)}
.btn-lg{padding:14px 26px;font-size:1rem}
.btn-block{width:100%}
.btn .arrow{transition:transform .2s}
.btn:hover .arrow{transform:translateX(4px)}

/* ===== Navbar ===== */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;transition:background .25s,box-shadow .25s,border-color .25s;
  border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(255,255,255,.85);box-shadow:var(--shadow-sm);border-bottom-color:var(--border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{display:flex;align-items:center;font-weight:800;font-family:'Sora',sans-serif}
.brand-name{font-size:1.5rem;letter-spacing:-0.04em;color:var(--brand)}
.nav-links{display:flex;gap:22px}
.nav-links a{color:var(--muted);font-weight:500;font-size:.95rem;position:relative;transition:color .2s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--grad);transition:width .25s;border-radius:2px}
.nav-links a:hover,.nav-links a.active{color:var(--text)}
.nav-links a.active::after,.nav-links a:hover::after{width:100%}
.nav-cta{display:flex;gap:10px;align-items:center}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:24px;height:2px;background:var(--text);border-radius:2px;transition:.3s}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{display:none;flex-direction:column;gap:12px;padding:16px 24px 24px;background:#fff;border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm)}
.mobile-menu.open{display:flex}
.mobile-menu a{color:var(--text);font-weight:500}

/* ===== Hero ===== */
.hero{padding:130px 0 56px}
.page-hero{padding:130px 0 40px}
.hero-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.pill{display:inline-flex;align-items:center;gap:8px;font-size:.82rem;color:var(--muted);
  padding:7px 14px;border:1px solid var(--border);border-radius:999px;background:var(--surface)}
.pill .dot{width:8px;height:8px;border-radius:50%;background:#16a34a;box-shadow:0 0 0 4px rgba(22,163,74,.15);animation:pulse 2.2s infinite}
@keyframes pulse{50%{box-shadow:0 0 0 8px rgba(22,163,74,0)}}
.hero-title{font-size:clamp(2.3rem,5.2vw,3.9rem);margin:20px 0 18px;font-weight:800}
.hero-sub{color:var(--muted);font-size:1.1rem;max-width:540px}
.hero-actions{display:flex;gap:14px;margin:30px 0 26px;flex-wrap:wrap}
.hero-trust{display:flex;align-items:center;gap:14px;color:var(--muted);font-size:.92rem}
.hero-trust strong{color:var(--text)}
.avatars{display:flex}
.avatars span{width:34px;height:34px;border-radius:50%;border:2px solid var(--bg);margin-left:-10px;background:var(--grad)}
.avatars span:nth-child(2){background:linear-gradient(120deg,#7c83ff,#4f46e5)}
.avatars span:nth-child(3){background:linear-gradient(120deg,#635bff,#312e81)}
.avatars span:nth-child(4){background:linear-gradient(120deg,#4f46e5,#8b87ff)}

/* Hero visual */
.hero-visual{position:relative;height:440px}
.float-card{position:absolute;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}
.card-main{top:30px;left:10px;right:30px;padding:22px;will-change:transform;animation:bob 8s ease-in-out infinite}
.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.chip{font-size:.8rem;color:var(--muted);background:var(--surface-2);padding:5px 12px;border-radius:999px;border:1px solid var(--border)}
.status-live{display:flex;align-items:center;gap:6px;font-size:.78rem;color:#16a34a}
.status-live span{width:8px;height:8px;border-radius:50%;background:#16a34a;animation:pulse 2.2s infinite}
.card-row{display:flex;gap:14px;margin-bottom:18px}
.mini-stat{flex:1;background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:12px}
.mini-label{font-size:.72rem;color:var(--muted)}
.mini-num{font-family:'Sora';font-size:1.5rem;font-weight:700}
.bar-chart{display:flex;align-items:flex-end;gap:8px;height:90px}
.bar-chart span{flex:1;height:var(--h);background:var(--grad);border-radius:6px 6px 0 0;opacity:.9}
.card-pill{bottom:60px;left:-6px;display:flex;align-items:center;gap:12px;padding:14px 18px;will-change:transform;animation:bob 7s ease-in-out infinite reverse}
.card-pill .ok{display:grid;place-items:center;min-width:28px;height:28px;border-radius:50%;background:rgba(22,163,74,.14);color:#16a34a;font-weight:700}
.fp-title{font-weight:700;font-size:.92rem}
.fp-sub{font-size:.78rem;color:var(--muted)}
.card-course{bottom:0;right:0;width:210px;padding:16px;will-change:transform;animation:bob 9s ease-in-out infinite}
.fc-tag{font-size:.72rem;color:var(--cyan);font-weight:600}
.fc-title{font-family:'Sora';font-weight:700;margin:4px 0 12px}
.progress{height:8px;border-radius:999px;background:var(--surface-2);overflow:hidden}
.progress span{display:block;height:100%;width:var(--p);background:var(--grad);border-radius:999px}
.fc-sub{font-size:.74rem;color:var(--muted);margin-top:8px}
@keyframes bob{0%,100%{transform:translate3d(0,0,0)}50%{transform:translate3d(0,-12px,0)}}

/* ===== Marquee ===== */
.marquee-wrap{padding:22px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg-2)}
.marquee{display:flex;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:flex;gap:28px;align-items:center;white-space:nowrap;will-change:transform;animation:scroll 30s linear infinite;padding-right:28px}
.marquee-track span{font-family:'Sora';font-weight:600;font-size:1.05rem;color:var(--muted)}
.marquee-track span:nth-child(odd){color:var(--text)}
@keyframes scroll{to{transform:translate3d(-100%,0,0)}}

/* ===== Sections ===== */
.section{padding:84px 0}
.section-alt{background:var(--bg-2)}
.section-head{text-align:center;max-width:680px;margin:0 auto 50px}
.eyebrow{display:inline-block;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--violet);font-weight:700;margin-bottom:14px}
.section-head h2{font-size:clamp(1.8rem,3.6vw,2.6rem)}
.section-head p{color:var(--muted);margin-top:14px;font-size:1.05rem}

/* services grid */
.cards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.svc-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;
  transition:transform .2s,border-color .2s,box-shadow .2s;display:flex;flex-direction:column}
.svc-card:hover{transform:translateY(-6px);border-color:#d9c9f7;box-shadow:var(--shadow)}
.svc-icon{width:52px;height:52px;display:grid;place-items:center;font-size:1.5rem;border-radius:14px;background:var(--surface-2);border:1px solid var(--border);margin-bottom:16px}
.svc-card h3{font-size:1.12rem;margin-bottom:8px}
.svc-card p{color:var(--muted);font-size:.92rem;flex:1}
.svc-link{display:inline-flex;align-items:center;gap:6px;margin-top:14px;font-weight:600;font-size:.88rem;color:var(--violet);
  opacity:.55;transform:translateY(2px);transition:opacity .2s,transform .2s,gap .2s}
.svc-card:hover .svc-link{opacity:1;transform:translateY(0)}
.svc-link:hover{gap:10px;text-decoration:underline}

/* ===== Tabs ===== */
.tabs{max-width:980px;margin:0 auto}
.tab-bar{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:30px}
.tab{padding:11px 22px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--muted);
  font-weight:600;cursor:pointer;transition:.2s}
.tab:hover{color:var(--text)}
.tab.is-active{background:var(--grad);color:#fff;border-color:transparent}
.tab-panel{display:none}
.tab-panel.is-active{display:block;animation:fadeUp .4s ease}
.panel-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:center;
  background:var(--surface);border:1px solid var(--border);border-radius:24px;padding:36px;box-shadow:var(--shadow-sm)}
.badge{display:inline-block;font-size:.76rem;font-weight:700;color:var(--brand-600);background:rgba(99,91,255,.10);padding:5px 12px;border-radius:999px;margin-bottom:14px}
.panel-grid h3{font-size:1.5rem;margin-bottom:10px}
.panel-grid>div>p{color:var(--muted);margin-bottom:18px}
.feature-list{list-style:none;display:grid;gap:10px;margin-bottom:22px}
.feature-list li{position:relative;padding-left:28px;color:var(--text);font-size:.95rem}
.feature-list li::before{content:"✓";position:absolute;left:0;top:0;color:var(--cyan);font-weight:700}
.panel-card{background:var(--surface-2);border:1px solid var(--border);border-radius:18px;padding:22px}
.pc-label{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px}
.pc-step{padding:12px 14px;border-radius:12px;background:var(--surface);border:1px solid var(--border);margin-bottom:10px;font-size:.92rem;color:var(--muted)}
.pc-step.done{color:var(--text);border-color:rgba(22,163,74,.4)}
.pc-step.active{color:var(--text);border-color:var(--brand);background:rgba(99,91,255,.07);position:relative}
.pc-step.active::after{content:"";position:absolute;right:14px;top:50%;width:8px;height:8px;margin-top:-4px;border-radius:50%;background:var(--cyan);animation:pulse 1.8s infinite}

/* ===== Stats band ===== */
.stats-band{padding:56px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg-2)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat-num{font-family:'Sora';font-size:clamp(2rem,4vw,3rem);font-weight:800;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat-label{color:var(--muted);font-size:.95rem;margin-top:6px}

/* ===== Courses ===== */
.courses-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.course-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;overflow:hidden;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column}
.course-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.course-top{height:120px;display:flex;align-items:flex-start;justify-content:space-between;padding:16px}
.course-emoji{font-size:2.2rem;filter:drop-shadow(0 4px 8px rgba(0,0,0,.18))}
.ct-tags{display:flex;gap:8px;align-items:flex-start;flex-wrap:wrap}
.course-level{font-size:.74rem;font-weight:700;background:rgba(255,255,255,.85);color:#1a1a1a;padding:5px 11px;border-radius:999px}
.course-free-tag{font-size:.72rem;font-weight:800;font-family:'Sora',sans-serif;letter-spacing:.06em;
  background:#16a34a;color:#fff;padding:5px 11px;border-radius:999px;box-shadow:0 4px 10px rgba(22,163,74,.4);
  animation:freepulse 2s ease-in-out infinite}

/* All-courses-free banner */
.free-banner{position:relative;overflow:hidden;display:flex;align-items:center;gap:22px;flex-wrap:wrap;
  background:var(--grad);color:#fff;border-radius:22px;padding:24px 30px;box-shadow:0 18px 42px rgba(99,91,255,.32)}
.free-banner .fb-badge{flex:none;font-family:'Sora',sans-serif;font-weight:800;font-size:.82rem;letter-spacing:.08em;
  background:#fff;color:var(--brand-600);padding:9px 15px;border-radius:999px;animation:freepulse 2s ease-in-out infinite}
.free-banner .fb-text{flex:1;min-width:240px}
.free-banner .fb-text h3{font-family:'Sora',sans-serif;font-weight:800;font-size:1.25rem;margin:0 0 4px;color:#fff}
.free-banner .fb-text p{margin:0;color:rgba(255,255,255,.9);font-size:.93rem}
.free-banner .btn-light{flex:none;background:#fff;color:var(--brand-600);font-weight:700}
.free-banner .btn-light:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(0,0,0,.2)}
.free-banner::after{content:"";position:absolute;top:0;left:-60%;width:38%;height:100%;pointer-events:none;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.38),transparent);transform:skewX(-20deg);
  animation:shine 3.6s ease-in-out infinite}
@keyframes shine{0%{left:-60%}55%,100%{left:130%}}
@keyframes freepulse{50%{transform:scale(1.07)}}
.grad-a{background:linear-gradient(135deg,#635bff,#4f46e5)}
.grad-b{background:linear-gradient(135deg,#4f46e5,#312e81)}
.grad-c{background:linear-gradient(135deg,#8b87ff,#635bff)}
.grad-d{background:linear-gradient(135deg,#0a2540,#4f46e5)}
.grad-e{background:linear-gradient(135deg,#635bff,#a5a0ff)}
.grad-f{background:linear-gradient(135deg,#312e81,#635bff)}
.course-body{padding:20px;display:flex;flex-direction:column;flex:1}
.course-body h3{font-size:1.12rem;margin-bottom:8px}
.course-body p{color:var(--muted);font-size:.9rem;margin-bottom:14px;flex:1}
.course-meta{display:flex;justify-content:space-between;color:var(--muted);font-size:.82rem;margin-bottom:16px}

/* ===== Steps ===== */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.step{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:26px;transition:transform .2s,border-color .2s,box-shadow .2s}
.step:hover{transform:translateY(-6px);border-color:#bae6fd;box-shadow:var(--shadow-sm)}
.step-num{font-family:'Sora';font-size:2.2rem;font-weight:800;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;display:block;margin-bottom:12px}
.step h3{font-size:1.1rem;margin-bottom:8px}
.step p{color:var(--muted);font-size:.92rem}

/* ===== Global ===== */
.global-inner{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.global-copy h2{font-size:clamp(1.9rem,3.6vw,2.7rem);margin:8px 0 16px}
.global-copy>p{color:var(--muted);font-size:1.05rem;margin-bottom:22px;max-width:480px}
.global-points{display:grid;gap:12px;margin-bottom:26px}
.global-points div{display:flex;align-items:center;gap:10px;color:var(--text)}
.global-visual{display:grid;place-items:center;height:360px}
.globe{position:relative;width:300px;height:300px}
.globe-core{position:absolute;inset:90px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#8b87ff,#4f46e5 70%);box-shadow:0 12px 40px rgba(99,91,255,.3)}
.ring{position:absolute;border:1px solid var(--border);border-radius:50%;will-change:transform;animation:spin 18s linear infinite}
.r1{inset:0}
.r2{inset:36px;border-color:rgba(99,91,255,.35);animation-duration:24s;animation-direction:reverse}
.r3{inset:72px;border-color:rgba(124,131,255,.3);animation-duration:30s}
@keyframes spin{to{transform:rotate(360deg)}}
.ping{position:absolute;width:12px;height:12px;border-radius:50%;background:#16a34a;animation:pingA 2.8s infinite}
.p1{top:20px;left:140px}
.p2{top:150px;left:6px;animation-delay:.7s;background:var(--cyan)}
.p3{bottom:30px;right:60px;animation-delay:1.3s;background:var(--pink)}
.p4{top:90px;right:18px;animation-delay:1.9s}
@keyframes pingA{0%{transform:scale(.8);opacity:1}70%{transform:scale(1.6);opacity:0}100%{transform:scale(.8);opacity:0}}

/* ===== Testimonials ===== */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.testi{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:26px;transition:transform .2s,border-color .2s,box-shadow .2s}
.testi:hover{transform:translateY(-5px);border-color:#d9c9f7;box-shadow:var(--shadow-sm)}
.stars{color:#f59e0b;letter-spacing:2px;margin-bottom:14px}
.testi blockquote{color:var(--text);font-size:1rem;margin-bottom:18px}
.testi figcaption{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:.86rem}
.t-ava{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;font-weight:700;color:#fff;background:var(--grad)}
.testi figcaption strong{color:var(--text)}

/* ===== CTA / contact ===== */
.cta{padding:84px 0}
.cta-inner{max-width:680px;margin:0 auto;text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:28px;padding:48px 36px;box-shadow:var(--shadow)}
.cta-inner h2{font-size:clamp(1.8rem,3.4vw,2.4rem)}
.cta-inner>p{color:var(--muted);margin:14px 0 28px}
.cta-form{display:grid;grid-template-columns:1fr 1fr;gap:14px;text-align:left}
.field{display:flex;flex-direction:column}
.cta-form .btn{grid-column:1/-1}
.cta-form input,.cta-form select,.cta-form textarea{width:100%;padding:13px 16px;border-radius:12px;background:var(--bg);
  border:1px solid var(--border);color:var(--text);font-size:.95rem;font-family:inherit;transition:border-color .2s,box-shadow .2s}
.cta-form input:focus,.cta-form select:focus,.cta-form textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(99,91,255,.18)}

/* ===== Custom dropdown (unique interest selector) ===== */
.field-full{grid-column:1/-1}
.cdrop{position:relative;width:100%}
.cdrop-btn{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:13px 16px;border-radius:12px;background:var(--bg);border:1px solid var(--border);
  color:var(--muted);font-family:inherit;font-size:.95rem;cursor:pointer;text-align:left;
  transition:border-color .2s,box-shadow .2s}
.cdrop-btn:hover{border-color:#c3c7ff}
.cdrop.open .cdrop-btn,.cdrop-btn:focus-visible{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(99,91,255,.18)}
.cdrop-label{flex:1}
.cdrop-label.filled{color:var(--text);font-weight:600}
.cdrop-chev{flex:none;width:18px;height:18px;color:var(--muted);transition:transform .25s,color .2s}
.cdrop.open .cdrop-chev{transform:rotate(180deg);color:var(--brand)}
.cdrop-menu{position:absolute;top:calc(100% + 8px);left:0;right:0;z-index:30;list-style:none;margin:0;
  background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);
  padding:6px;max-height:0;overflow:hidden;opacity:0;transform:translateY(-6px);pointer-events:none;
  transition:opacity .18s ease,transform .18s ease}
.cdrop.open .cdrop-menu{max-height:300px;overflow:auto;opacity:1;transform:none;pointer-events:auto}
.cdrop-opt{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:10px;
  font-size:.92rem;color:var(--text);cursor:pointer;transition:background .15s,color .15s}
.cdrop-opt .o-ic{width:20px;text-align:center}
.cdrop-opt:hover{background:var(--brand-100);color:var(--brand-600)}
.cdrop-opt[aria-selected="true"]{background:var(--brand);color:#fff}
.cta-form textarea{grid-column:1/-1;min-height:110px;resize:vertical}
.form-msg{grid-column:1/-1;display:block;height:auto;min-height:20px;text-align:center;font-size:.92rem;line-height:1.5;margin:2px 0}
.form-msg.ok{color:#16a34a}
.form-msg.err{color:#dc2626}
.form-msg:empty{min-height:0;margin:0}

/* ===== Slide-to-verify (custom human check) ===== */
.hp-field{position:absolute!important;left:-9999px!important;top:-9999px!important;width:1px;height:1px;opacity:0;pointer-events:none}
.slideverify{grid-column:1/-1;user-select:none;-webkit-user-select:none}
.sv-track{position:relative;height:56px;border-radius:14px;background:#f3f4ff;border:1.5px solid var(--brand-100);overflow:hidden;display:flex;align-items:center;box-shadow:inset 0 1px 3px rgba(10,37,64,.06)}
.sv-fill{position:absolute;left:0;top:0;bottom:0;width:0;background:var(--grad);border-radius:14px;transition:width .05s linear}
.sv-text{position:relative;width:100%;text-align:center;font-size:.92rem;font-weight:600;color:var(--brand-600);letter-spacing:.2px;padding-left:30px;z-index:1;pointer-events:none;transition:color .2s ease}
.sv-handle{position:absolute;left:4px;top:4px;width:48px;height:48px;border:none;border-radius:11px;background:#fff;box-shadow:0 4px 12px rgba(79,70,229,.28);display:flex;align-items:center;justify-content:center;color:var(--brand);cursor:grab;touch-action:none;z-index:2;transition:transform .25s cubic-bezier(.2,.8,.3,1.2),background .2s ease,color .2s ease}
.sv-handle:active,.sv-handle.grab{cursor:grabbing}
.sv-handle svg{width:24px;height:24px;stroke:currentColor;stroke-width:2.6;fill:none;stroke-linecap:round;stroke-linejoin:round}
.sv-handle .sv-arrows{animation:svPulse 1.4s ease-in-out infinite}
@keyframes svPulse{0%,100%{opacity:.45;transform:translateX(-2px)}50%{opacity:1;transform:translateX(2px)}}
.slideverify.verified .sv-track{border-color:#16a34a;background:#ecfdf3}
.slideverify.verified .sv-fill{background:linear-gradient(135deg,#22c55e 0%,#16a34a 100%);transition:width .25s ease}
.slideverify.verified .sv-text{color:#fff}
.slideverify.verified .sv-handle{background:#fff;color:#16a34a;cursor:default}
.slideverify.verified .sv-handle .sv-arrows{display:none}
.slideverify.verified .sv-handle .sv-check{display:block}
.sv-handle .sv-check{display:none}

/* ===== Generic page content ===== */
.prose{max-width:760px;margin:0 auto}
.prose p{color:var(--muted);margin-bottom:16px}
.value-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.value-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px;transition:transform .2s,box-shadow .2s}
.value-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-sm)}
.value-card .v-ic{font-size:1.6rem;margin-bottom:10px}
.value-card h3{font-size:1.08rem;margin-bottom:8px}
.value-card p{color:var(--muted);font-size:.92rem}
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:36px;align-items:start}
.contact-info{display:grid;gap:18px}
.contact-info .ci{display:flex;gap:14px;align-items:flex-start;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:18px}
.contact-info .ci .ci-ic{font-size:1.3rem}
.contact-info .ci h4{margin-bottom:2px}
.contact-info .ci p,.contact-info .ci a{color:var(--muted);font-size:.92rem}
.contact-info .ci a:hover{color:var(--violet)}
.contact-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:30px;box-shadow:var(--shadow-sm)}

/* ===== Donation page ===== */
.donate-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.impact-list{display:flex;flex-direction:column;gap:12px}
.impact{display:flex;gap:13px;align-items:flex-start;background:var(--surface);border:1px solid var(--border);
  border-radius:14px;padding:15px 16px}
.impact .im-ic{font-size:1.35rem;flex:none;line-height:1}
.impact h4{font-size:.98rem;margin:0 0 3px;font-family:'Sora',sans-serif;font-weight:700}
.impact p{font-size:.86rem;color:var(--muted);margin:0;line-height:1.45}
.donate-form-title{font-family:'Sora',sans-serif;font-weight:800;font-size:1.25rem;margin-bottom:18px}
.field-label{font-size:.82rem;font-weight:600;color:var(--muted);margin-bottom:8px;display:block}
.cur-seg{display:flex;background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:4px;gap:4px}
.cur-seg button{flex:1;border:0;background:transparent;font-family:inherit;font-weight:700;font-size:.9rem;
  color:var(--muted);padding:11px 14px;border-radius:9px;cursor:pointer;transition:background .2s,color .2s}
.cur-seg button.active{background:var(--brand);color:#fff;box-shadow:0 4px 12px rgba(99,91,255,.3)}
.amount-wrap{position:relative}
.amount-wrap .cur-sym{position:absolute;left:15px;top:50%;transform:translateY(-50%);font-weight:700;color:var(--muted);pointer-events:none}
.cta-form .amount-wrap input{padding-left:32px}
.amount-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.amount-chips button{border:1px solid var(--border);background:var(--bg);border-radius:999px;padding:8px 15px;
  font-family:inherit;font-weight:600;font-size:.85rem;color:var(--text);cursor:pointer;transition:.15s}
.amount-chips button:hover{border-color:var(--brand);color:var(--brand-600)}
.amount-chips button.active{background:var(--brand);color:#fff;border-color:var(--brand)}
.amount-chips button.chip-custom{border-style:dashed}
.amount-chips button.chip-custom.active{border-style:solid}
.donate-note{grid-column:1/-1;font-size:.78rem;color:var(--muted);text-align:center;margin-top:2px}

/* ===== Auth (login / register / reset / dashboard) ===== */
.auth-section{display:flex;align-items:center;justify-content:center;padding:140px 0 70px;min-height:70vh}
.auth-card{max-width:440px;width:100%;margin:0 auto}
.auth-head{text-align:center;margin-bottom:22px}
.auth-head h2{font-size:1.7rem;margin-bottom:6px}
.auth-head p{color:var(--muted);font-size:.95rem}
.auth-alt{grid-column:1/-1;text-align:center;margin-top:4px;font-size:.9rem;color:var(--muted)}
.auth-alt a{color:var(--brand-600);font-weight:600}
.auth-row{grid-column:1/-1;display:flex;justify-content:space-between;align-items:center;font-size:.85rem}
.auth-row a{color:var(--brand-600);font-weight:600}
.input-label{font-size:.82rem;font-weight:600;color:var(--muted);margin-bottom:6px;display:block}
.pw-wrap{position:relative}
.pw-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:0;cursor:pointer;color:var(--muted);font-size:.8rem;font-weight:600;font-family:inherit}
.dash-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:26px}
.dash-card{padding:22px}
.dash-card h4{font-size:.85rem;color:var(--muted);font-weight:600;margin-bottom:8px}
.dash-card .dash-num{font-family:'Sora',sans-serif;font-size:1.7rem;font-weight:700}
.dash-welcome{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px}
.dash-empty{margin-top:26px;text-align:center;padding:46px 20px;border:1.5px dashed var(--border);border-radius:16px;color:var(--muted)}

/* ===== Formation: what-you-get + state fees ===== */
.panel-sub{font-size:1.05rem;margin:30px 0 14px;font-family:'Sora',sans-serif;font-weight:700}
.panel-full{margin-top:26px;border-top:1px solid var(--border);padding-top:24px}
.incl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.incl{display:flex;align-items:flex-start;gap:10px;background:var(--surface-2);border:1px solid var(--border);
  border-radius:12px;padding:13px 14px}
.incl .i-ic{display:grid;place-items:center;min-width:30px;height:30px;border-radius:9px;background:var(--brand-100);
  color:var(--brand-600);font-size:.95rem}
.incl h5{font-size:.92rem;margin:0 0 2px;font-family:'Sora',sans-serif;font-weight:700}
.incl p{font-size:.8rem;color:var(--muted);margin:0;line-height:1.4}

.mini-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.mini-step{background:var(--surface-2);border:1px solid var(--border);border-radius:14px;padding:18px}
.mini-step .ms-num{display:grid;place-items:center;width:30px;height:30px;border-radius:50%;background:var(--brand);
  color:#fff;font-weight:700;font-size:.9rem;font-family:'Sora';margin-bottom:10px}
.mini-step h5{font-size:.95rem;margin:0 0 4px;font-family:'Sora',sans-serif;font-weight:700}
.mini-step p{font-size:.84rem;color:var(--muted);margin:0}

.partners{display:flex;flex-wrap:wrap;gap:10px}
.partner{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);
  border-radius:999px;padding:9px 16px;font-weight:600;font-size:.9rem}
.partner .p-dot{width:9px;height:9px;border-radius:50%;background:var(--brand)}

.fee-explorer{margin-top:26px;border-top:1px solid var(--border);padding-top:24px}
.fee-head{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;flex-wrap:wrap;margin-bottom:16px}
.fee-head h4{font-size:1.05rem;font-family:'Sora',sans-serif;font-weight:700}
.fee-head p{font-size:.85rem;color:var(--muted);margin-top:4px;max-width:560px}
.fee-search{padding:11px 14px;border-radius:10px;border:1px solid var(--border);background:var(--bg);
  font-family:inherit;font-size:.9rem;min-width:200px;color:var(--text);transition:border-color .2s,box-shadow .2s}
.fee-search:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(99,91,255,.18)}
.fee-table{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;max-height:300px;overflow:auto;padding:4px;
  border:1px solid var(--border);border-radius:14px;background:var(--surface-2)}
.fee-row{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--surface);
  border:1px solid var(--border);border-radius:10px;padding:11px 13px;font-size:.9rem}
.fee-row .fr-state{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--text)}
.fee-row .fr-fee{font-weight:700;color:var(--brand-600);font-family:'Sora',sans-serif}
.fee-row .fr-tag{font-size:.64rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
  background:var(--brand-100);color:var(--brand-600);padding:2px 7px;border-radius:999px}
.fee-empty{grid-column:1/-1;text-align:center;color:var(--muted);font-size:.9rem;padding:18px}
.fee-addon{display:flex;align-items:center;gap:14px;margin-top:14px;padding:14px 16px;border-radius:14px;
  background:var(--brand-100);border:1px solid #d6d4ff}
.fee-addon .fa-ic{font-size:1.3rem;flex:none}
.fee-addon .fa-text{flex:1;font-size:.9rem;color:var(--text)}
.fee-addon .fa-price{flex:none;font-family:'Sora',sans-serif;font-weight:800;color:var(--brand-600);font-size:1.05rem}
.fee-note{font-size:.78rem;color:var(--muted);margin-top:12px}

/* ===== Footer ===== */
.footer{border-top:1px solid var(--border);background:var(--bg-2);padding:54px 0 26px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:32px;margin-bottom:34px}
.footer-brand p{color:var(--muted);margin-top:14px;max-width:280px;font-size:.92rem}
.footer-col h4{font-size:.95rem;margin-bottom:14px}
.footer-col a{display:block;color:var(--muted);font-size:.9rem;padding:5px 0;transition:color .2s}
.footer-col a:hover{color:var(--violet)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:22px;border-top:1px solid var(--border);color:var(--muted);font-size:.88rem;flex-wrap:wrap;gap:12px}
.footer-socials{display:flex;gap:18px}
.footer-socials a:hover{color:var(--text)}

/* ===== Reveal animation ===== */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* ===== Responsive ===== */
@media (max-width:980px){
  .cards-grid{grid-template-columns:repeat(2,1fr)}
  .courses-grid,.testi-grid,.value-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .hero-inner,.global-inner,.panel-grid,.contact-grid,.donate-grid{grid-template-columns:1fr}
  .incl-grid,.fee-table{grid-template-columns:repeat(2,1fr)}
  .hero-visual{height:380px;margin-top:10px}
  .global-visual{height:300px}
}
@media (max-width:760px){
  .nav-links{display:none}
  .nav-toggle{display:flex}
  .nav-cta .btn-help{display:none}
  .nav-cta .auth-cta{display:none}
  .dash-grid{grid-template-columns:1fr}
  .hero{padding:110px 0 40px}
  .cards-grid,.courses-grid,.testi-grid,.steps,.stats-grid,.value-grid{grid-template-columns:1fr}
  .incl-grid,.mini-steps,.fee-table{grid-template-columns:1fr}
  .fee-head{align-items:stretch}
  .fee-search{width:100%}
  .cta-form{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}

/* ===== Custom cursor (desktop / fine pointer only) ===== */
.has-custom-cursor,.has-custom-cursor *{cursor:none!important}
.has-custom-cursor input,.has-custom-cursor textarea,.has-custom-cursor [contenteditable]{cursor:text!important}
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;z-index:10000;
  opacity:0;will-change:transform;transform:translate(-50%,-50%)}
.cursor-dot{width:7px;height:7px;background:var(--brand);box-shadow:0 0 12px rgba(99,91,255,.75);
  transition:opacity .25s}
.cursor-ring{width:34px;height:34px;border:2px solid rgba(99,91,255,.5);background:rgba(99,91,255,.04);
  transition:width .22s ease,height .22s ease,border-color .22s ease,background .22s ease,opacity .25s}
.cursor-ring.hover{width:54px;height:54px;border-color:var(--brand);background:rgba(99,91,255,.12)}
.cursor-ring.click{width:24px;height:24px;border-color:var(--brand-600);background:rgba(99,91,255,.2)}
