
/* ══════════════════════════════════════
   RESET & TOKENS
══════════════════════════════════════ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
:root{
  --bg:#060b14;
  --surface:#0d1525;
  --surface2:#111d33;
  --accent:#f0c040;
  --accent2:#3edfb8;
  --accent3:#ff6b6b;
  --text:#e8edf5;
  --muted:#6b7d99;
  --border:rgba(255,255,255,.07);
  --glow-a:rgba(240,192,64,.18);
  --glow-b:rgba(62,223,184,.12);
  --r:20px;
}
body{
  font-family:'Cabinet Grotesk',sans-serif;
  background:var(--bg);
  color:var(--text);
  overflow-x:hidden;
  cursor:none;
}

/* Custom cursor */
#cursor{
  width:14px;height:14px;
  background:var(--accent);
  border-radius:50%;
  position:fixed;z-index:9999;
  pointer-events:none;
  transform:translate(-50%,-50%);
  transition:transform .08s,width .2s,height .2s,background .2s;
  mix-blend-mode:screen;
}
#cursor-ring{
  width:36px;height:36px;
  border:1.5px solid rgba(240,192,64,.5);
  border-radius:50%;
  position:fixed;z-index:9998;
  pointer-events:none;
  transform:translate(-50%,-50%);
  transition:transform .18s ease,width .2s,height .2s;
}
body:hover #cursor{opacity:1}

/* ── Scrollbar ── */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:#0d1525}
::-webkit-scrollbar-thumb{background:var(--accent);border-radius:3px}

/* ══════════════════════════════════════
   NAV
══════════════════════════════════════ */
nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 6%;height:70px;
  background:rgba(6,11,20,.85);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
}
.logo{
  font-family:'Fraunces',serif;
  font-size:1.6rem;font-weight:900;
  background:linear-gradient(90deg,var(--accent),var(--accent2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  letter-spacing:-1px;
}
.nav-links{display:flex;gap:2rem;list-style:none}
.nav-links a{
  text-decoration:none;color:var(--muted);
  font-size:.88rem;font-weight:500;letter-spacing:.5px;
  transition:color .2s;
}
.nav-links a:hover{color:var(--accent)}
.nav-btn{
  background:var(--accent);color:var(--bg);
  padding:9px 24px;border-radius:50px;
  font-family:'Cabinet Grotesk',sans-serif;
  font-weight:700;font-size:.88rem;border:none;cursor:none;
  transition:transform .2s,box-shadow .2s;
  box-shadow:0 0 20px var(--glow-a);
}
.nav-btn:hover{transform:translateY(-2px);box-shadow:0 0 32px rgba(240,192,64,.4)}

/* ══════════════════════════════════════
   HERO
══════════════════════════════════════ */
.hero{
  min-height:100vh;
  padding:120px 6% 80px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:4rem;
  align-items:center;
  position:relative;
  overflow:hidden;
}

/* Animated gradient mesh background */
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(ellipse 60% 50% at 80% 50%, rgba(62,223,184,.07) 0%,transparent 70%),
    radial-gradient(ellipse 50% 60% at 20% 60%, rgba(240,192,64,.06) 0%,transparent 70%),
    radial-gradient(ellipse 40% 40% at 50% 10%, rgba(255,107,107,.05) 0%,transparent 70%),
    var(--bg);
  animation:bgShift 12s ease-in-out infinite alternate;
}
@keyframes bgShift{
  0%{background-position:0% 50%}
  100%{background-position:100% 50%}
}

/* Grid lines */
.hero-grid{
  position:absolute;inset:0;z-index: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:60px 60px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black,transparent);
}

.hero-content{position:relative;z-index:2}
.hero-tag{
  display:inline-flex;align-items:center;gap:.5rem;
  background:rgba(240,192,64,.1);
  border:1px solid rgba(240,192,64,.25);
  color:var(--accent);
  padding:6px 16px;border-radius:50px;
  font-size:.75rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;
  margin-bottom:1.6rem;
  animation:fadeSlide .8s ease both;
}
.hero-tag::before{content:'◉';animation:spin 3s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

h1.hero-title{
  font-family:'Fraunces',serif;
  font-size:clamp(3rem,5.5vw,5rem);
  font-weight:900;line-height:1.05;
  margin-bottom:1.6rem;
  animation:fadeSlide .8s .1s ease both;
}
h1.hero-title em{
  font-style:italic;font-weight:300;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.hero-desc{
  color:var(--muted);font-size:1.08rem;line-height:1.75;
  max-width:480px;margin-bottom:2.5rem;
  animation:fadeSlide .8s .2s ease both;
}
.hero-actions{
  display:flex;gap:1rem;flex-wrap:wrap;
  animation:fadeSlide .8s .3s ease both;
}
.btn-main{
  background:var(--accent);color:var(--bg);
  padding:15px 34px;border-radius:50px;
  font-family:'Cabinet Grotesk',sans-serif;
  font-weight:700;font-size:1rem;border:none;cursor:none;
  transition:transform .2s,box-shadow .2s;
  box-shadow:0 0 28px var(--glow-a);
}
.btn-main:hover{transform:translateY(-3px);box-shadow:0 0 42px rgba(240,192,64,.5)}
.btn-ghost{
  background:transparent;color:var(--text);
  padding:15px 34px;border-radius:50px;
  font-family:'Cabinet Grotesk',sans-serif;
  font-weight:600;font-size:1rem;
  border:1.5px solid var(--border);cursor:none;
  transition:border-color .2s,color .2s;
}
.btn-ghost:hover{border-color:var(--accent2);color:var(--accent2)}

.hero-trust{
  display:flex;align-items:center;gap:1rem;
  margin-top:2rem;
  animation:fadeSlide .8s .4s ease both;
}
.trust-avatars{display:flex}
.trust-avatars img{
  width:34px;height:34px;border-radius:50%;
  border:2px solid var(--bg);
  margin-left:-10px;object-fit:cover;
}
.trust-avatars img:first-child{margin-left:0}
.trust-text{font-size:.82rem;color:var(--muted)}
.trust-text strong{color:var(--accent);font-size:.95rem}

/* ══════════════════════════════════════
   FLOATING IMAGE MOSAIC
══════════════════════════════════════ */
.mosaic{
  position:relative;z-index:2;
  height:560px;
  animation:fadeSlide .9s .15s ease both;
}
.tile{
  position:absolute;
  border-radius:var(--r);
  overflow:hidden;
  box-shadow:0 24px 60px rgba(0,0,0,.5);
  transition:transform .4s ease;
}
.tile img{width:100%;height:100%;object-fit:cover;display:block}
.tile:hover{transform:scale(1.04) !important}

/* Individual tiles with float animations */
.t1{width:240px;height:280px;top:0;right:30px;
    animation:float1 7s ease-in-out infinite}
.t2{width:190px;height:220px;top:40px;right:290px;
    animation:float2 8s ease-in-out infinite}
.t3{width:210px;height:155px;top:300px;right:50px;
    animation:float3 6.5s ease-in-out infinite}
.t4{width:170px;height:200px;top:290px;right:280px;
    animation:float1 9s ease-in-out infinite 1s}
.t5{width:130px;height:130px;top:160px;right:200px;
    border-radius:50%;
    animation:float2 5.5s ease-in-out infinite .5s;
    box-shadow:0 0 40px var(--glow-b)}

/* Glow overlays on tiles */
.tile::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom,transparent 50%,rgba(6,11,20,.5));
  pointer-events:none;
}

/* Label badges on tiles */
.tile-label{
  position:absolute;bottom:12px;left:12px;
  background:rgba(6,11,20,.85);backdrop-filter:blur(8px);
  border:1px solid var(--border);
  color:var(--text);padding:5px 10px;border-radius:8px;
  font-size:.72rem;font-weight:600;letter-spacing:.5px;
  z-index:3;
}

@keyframes float1{
  0%,100%{transform:translateY(0) rotate(0deg)}
  50%{transform:translateY(-20px) rotate(.5deg)}
}
@keyframes float2{
  0%,100%{transform:translateY(0) rotate(0deg)}
  50%{transform:translateY(-15px) rotate(-.4deg)}
}
@keyframes float3{
  0%,100%{transform:translateY(0) rotate(0deg)}
  50%{transform:translateY(-25px) rotate(.3deg)}
}

/* Decorative floating elements */
.deco-ring{
  position:absolute;border-radius:50%;
  border:1px solid rgba(62,223,184,.2);
  animation:pulse 5s ease-in-out infinite;
}
.deco-ring.r1{width:80px;height:80px;top:-10px;right:0}
.deco-ring.r2{width:50px;height:50px;bottom:80px;right:340px;animation-delay:1s}
.deco-ring.r3{width:120px;height:120px;top:200px;right:-20px;animation-delay:2s;border-color:rgba(240,192,64,.15)}
@keyframes pulse{
  0%,100%{transform:scale(1);opacity:.6}
  50%{transform:scale(1.15);opacity:1}
}

.deco-dot{
  position:absolute;border-radius:50%;
  animation:float1 6s ease-in-out infinite;
}
.dd1{width:8px;height:8px;background:var(--accent);top:80px;right:250px;opacity:.7}
.dd2{width:5px;height:5px;background:var(--accent2);top:400px;right:170px;opacity:.6;animation-duration:7s}
.dd3{width:6px;height:6px;background:var(--accent3);top:220px;right:20px;opacity:.5;animation-duration:5s}

/* ══════════════════════════════════════
   MARQUEE STRIP
══════════════════════════════════════ */
.strip{
  background:var(--accent);
  overflow:hidden;padding:13px 0;
  position:relative;
}
.strip-track{
  display:flex;gap:0;
  animation:marquee 20s linear infinite;
  width:max-content;
}
.strip-item{
  display:flex;align-items:center;gap:1.2rem;
  padding:0 2rem;
  font-family:'Cabinet Grotesk',sans-serif;
  font-weight:700;font-size:.88rem;
  color:var(--bg);letter-spacing:.5px;white-space:nowrap;
}
.strip-item span{color:rgba(6,11,20,.4);font-size:1.2rem}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ══════════════════════════════════════
   STATS
══════════════════════════════════════ */
.stats{
  padding:70px 6%;
  display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;
  background:var(--surface);
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
}
.stat{text-align:center;padding:1rem}
.stat-n{
  font-family:'Fraunces',serif;
  font-size:3rem;font-weight:900;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  display:block;margin-bottom:.3rem;
}
.stat-l{font-size:.82rem;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase}

/* ══════════════════════════════════════
   CATEGORIES GRID
══════════════════════════════════════ */
.section{padding:100px 6%}
.s-chip{
  display:inline-flex;align-items:center;gap:.4rem;
  background:rgba(62,223,184,.1);border:1px solid rgba(62,223,184,.2);
  color:var(--accent2);padding:5px 14px;border-radius:50px;
  font-size:.72rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;
  margin-bottom:1rem;
}
.s-title{
  font-family:'Fraunces',serif;
  font-size:clamp(2rem,3.5vw,3rem);font-weight:900;
  line-height:1.15;margin-bottom:1rem;
}
.s-title em{font-style:italic;font-weight:300;color:var(--accent)}
.s-sub{color:var(--muted);font-size:1rem;max-width:500px;line-height:1.7;margin-bottom:3rem}

.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.2rem}
.cat-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r);padding:1.8rem 1.4rem;
  cursor:none;
  transition:transform .3s,border-color .3s,box-shadow .3s;
  position:relative;overflow:hidden;
}
.cat-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,var(--glow-a),transparent);
  opacity:0;transition:opacity .3s;
}
.cat-card:hover{transform:translateY(-6px);border-color:rgba(240,192,64,.35);box-shadow:0 16px 40px rgba(240,192,64,.1)}
.cat-card:hover::before{opacity:1}
.cat-icon{font-size:2rem;margin-bottom:1rem;display:block}
.cat-name{font-weight:700;font-size:1rem;margin-bottom:.4rem}
.cat-count{font-size:.8rem;color:var(--muted)}

/* ══════════════════════════════════════
   FEATURED COURSES — HORIZONTAL SCROLL
══════════════════════════════════════ */
.courses-wrap{overflow:hidden;position:relative}
.courses-scroll{
  display:flex;gap:1.8rem;
  overflow-x:auto;padding:1rem 6% 2rem;
  scrollbar-width:none;
}
.courses-scroll::-webkit-scrollbar{display:none}
.course-card{
  flex:0 0 280px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r);overflow:hidden;
  cursor:none;
  transition:transform .3s,box-shadow .3s;
}
.course-card:hover{transform:translateY(-8px);box-shadow:0 24px 50px rgba(0,0,0,.5)}
.course-thumb{width:100%;height:165px;object-fit:cover;display:block;transition:transform .4s}
.course-card:hover .course-thumb{transform:scale(1.06)}
.course-body{padding:1.3rem}
.course-tag{font-size:.7rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent2);margin-bottom:.5rem}
.course-name{font-family:'Fraunces',serif;font-size:1.1rem;font-weight:700;line-height:1.3;margin-bottom:.8rem}
.course-meta{display:flex;gap:1rem;font-size:.78rem;color:var(--muted);flex-wrap:wrap}
.course-price{font-weight:800;color:var(--accent);font-size:1.1rem;margin-top:.9rem}
.course-badge{
  position:absolute;top:12px;right:12px;
  background:var(--accent3);color:#fff;
  font-size:.65rem;font-weight:800;letter-spacing:1px;text-transform:uppercase;
  padding:3px 9px;border-radius:50px;
}

/* ══════════════════════════════════════
   IMAGE GALLERY — MASONRY-STYLE
══════════════════════════════════════ */
.gallery-section{padding:80px 6%;background:var(--surface)}
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:160px;
  gap:1rem;
  margin-top:3rem;
}
.g-cell{
  border-radius:14px;overflow:hidden;position:relative;cursor:none;
}
.g-cell img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s}
.g-cell:hover img{transform:scale(1.1)}
.g-cell.tall{grid-row:span 2}
.g-cell.wide{grid-column:span 2}
.g-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(6,11,20,.8) 0%,transparent 60%);
  opacity:0;transition:opacity .3s;
  display:flex;align-items:flex-end;padding:1rem;
}
.g-cell:hover .g-overlay{opacity:1}
.g-label{color:#fff;font-size:.82rem;font-weight:600;letter-spacing:.5px}

/* ══════════════════════════════════════
   TESTIMONIALS
══════════════════════════════════════ */
.testi-section{padding:100px 6%}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.testi-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r);padding:2rem;
  position:relative;overflow:hidden;
}
.testi-card::before{
  content:'❝';position:absolute;top:.5rem;right:1rem;
  font-size:4rem;color:rgba(240,192,64,.08);
  font-family:'Fraunces',serif;line-height:1;
}
.stars{color:var(--accent);font-size:.9rem;margin-bottom:1rem;letter-spacing:2px}
.testi-text{color:var(--muted);font-size:.92rem;line-height:1.7;margin-bottom:1.4rem}
.testi-author{display:flex;align-items:center;gap:.8rem}
.testi-author img{width:40px;height:40px;border-radius:50%;object-fit:cover}
.author-name{font-weight:700;font-size:.88rem}
.author-role{font-size:.78rem;color:var(--muted)}

/* ══════════════════════════════════════
   CTA BANNER
══════════════════════════════════════ */
.cta-section{
  margin:0 6% 100px;
  background:linear-gradient(135deg,var(--surface2),rgba(62,223,184,.08));
  border:1px solid rgba(62,223,184,.15);
  border-radius:28px;padding:70px;
  text-align:center;position:relative;overflow:hidden;
}
.cta-section::before{
  content:'';position:absolute;
  top:-40%;left:50%;transform:translateX(-50%);
  width:400px;height:400px;
  background:radial-gradient(circle,rgba(240,192,64,.12),transparent 70%);
  border-radius:50%;
  animation:pulse 6s ease-in-out infinite;
}
.cta-section h2{
  font-family:'Fraunces',serif;
  font-size:clamp(2rem,4vw,3.2rem);font-weight:900;
  margin-bottom:1rem;position:relative;
}
.cta-section p{color:var(--muted);font-size:1.05rem;margin-bottom:2.5rem;position:relative}
.cta-row{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;position:relative}

/* ══════════════════════════════════════
   FOOTER
══════════════════════════════════════ */
footer{
  background:var(--surface);
  border-top:1px solid var(--border);
  padding:3rem 6%;
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1.5rem;
}
.f-logo{
  font-family:'Fraunces',serif;font-size:1.5rem;font-weight:900;
  background:linear-gradient(90deg,var(--accent),var(--accent2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
footer p{color:var(--muted);font-size:.83rem}
.f-links{display:flex;gap:1.5rem}
.f-links a{color:var(--muted);text-decoration:none;font-size:.83rem;transition:color .2s}
.f-links a:hover{color:var(--accent)}

/* ══════════════════════════════════════
   ANIMATIONS
══════════════════════════════════════ */
@keyframes fadeSlide{
  from{opacity:0;transform:translateY(28px)}
  to{opacity:1;transform:translateY(0)}
}
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s,transform .7s}
.reveal.on{opacity:1;transform:none}

/* ══════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════ */
@media(max-width:980px){
  .hero{grid-template-columns:1fr;padding-top:100px}
  .mosaic{display:none}
  .stats{grid-template-columns:repeat(2,1fr)}
  .testi-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .cta-section{padding:40px 30px;margin:0 4% 60px}
}
