/* ===========================================
   AISSE 2026 - Premium Luxury UI
   Colors: White · Sky Blue · Royal Gold
=========================================== */

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&family=Poppins:wght@300;400;500;600;700;800&display=swap');

:root {
  --sky: #38BDF8;
  --sky-dark: #0ea5e9;
  --sky-light: #bae6fd;
  --sky-pale: #f0f9ff;
  --gold: #F5C542;
  --gold-dark: #d4a017;
  --gold-light: #fde68a;
  --white: #ffffff;
  --off-white: #f8fafc;
  --text-dark: #0f172a;
  --text-mid: #334155;
  --text-light: #64748b;
  --shadow: 0 20px 60px rgba(56,189,248,0.12);
  --shadow-gold: 0 0 30px rgba(245,197,66,0.25);
  --shadow-sky: 0 8px 32px rgba(56,189,248,0.2);
  --radius: 16px;
  --radius-lg: 24px;
  --transition: all 0.35s cubic-bezier(0.4,0,0.2,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:'Poppins',sans-serif;
  background:#fff;
  color:var(--text-dark);
  overflow-x:hidden;
  line-height:1.7;
}

/* ---- Loader ---- */
#loader{
  position:fixed;inset:0;
  background:#fff;
  display:flex;align-items:center;justify-content:center;
  z-index:9999;
  transition:opacity 0.6s ease, visibility 0.6s ease;
}
#loader.hidden{opacity:0;visibility:hidden;pointer-events:none;}
.loader-inner{text-align:center;color:var(--text-dark)}
.loader-logo{
  font-family:'Outfit',sans-serif;
  font-size:3rem;font-weight:900;
  background:linear-gradient(135deg,var(--sky),var(--sky-dark));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  letter-spacing:6px;
  margin-bottom:1.5rem;
  animation:pulse 1.5s ease infinite;
}
@keyframes pulse{0%,100%{filter:drop-shadow(0 0 8px rgba(56,189,248,0.4))}50%{filter:drop-shadow(0 0 20px rgba(56,189,248,0.8))}}
.loader-bar{
  width:200px;height:4px;
  background:var(--sky-light);
  border-radius:2px;
  margin:0 auto 1rem;overflow:hidden;
}
.loader-fill{
  height:100%;width:0;
  background:linear-gradient(90deg,var(--sky),var(--gold));
  border-radius:2px;
  animation:loadbar 2s ease forwards;
}
@keyframes loadbar{to{width:100%}}
.loader-inner p{color:var(--text-light);font-size:0.85rem;letter-spacing:2px}

/* ---- Navbar ---- */
#navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:0;
  transition:var(--transition);
}
#navbar.scrolled{
  background:rgba(255,255,255,0.95);
  backdrop-filter:blur(20px);
  box-shadow:0 4px 30px rgba(56,189,248,0.12);
  padding:0;
}
.nav-container{
  max-width:1280px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem 2rem;
}
.nav-logo{
  display:flex;align-items:center;gap:0.75rem;
  text-decoration:none;
}
.logo-icon{
  width:58px;
  height:58px;

  display:flex;
  align-items:center;
  justify-content:center;

  border-radius:10px;

  overflow:hidden;

  background:#fff;

  box-shadow:
  0 8px 25px rgba(0,0,0,0.08);
}

.logo-icon img{
  width:100%;
  height:100%;
  object-fit:contain;
}
.footer-logo img{
  width:42px;
  height:42px;

  border-radius:10px;

  object-fit:contain;

  background:#fff;

  padding:3px;
}
.logo-text{display:flex;flex-direction:column;line-height:1.2}
.logo-main{
  font-family:'Outfit',sans-serif;
  font-size:1.4rem;font-weight:800;
  background:linear-gradient(135deg,var(--sky-dark),var(--sky));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  letter-spacing:2px;
}
.logo-sub{font-size:0.65rem;color:var(--text-light);letter-spacing:1px}
.nav-links{
  display:flex;align-items:center;gap:0.25rem;
  list-style:none;
}
.nav-links a{
  color:var(--text-mid);
  text-decoration:none;
  font-size:0.88rem;font-weight:500;
  padding:0.5rem 0.85rem;
  border-radius:8px;
  transition:var(--transition);
}
.nav-links a:hover{color:var(--sky-dark);background:var(--sky-pale)}
.nav-cta{
  background:linear-gradient(135deg,var(--sky),var(--sky-dark)) !important;
  color:#fff !important;
  font-weight:700 !important;
  border-radius:50px !important;
  padding:0.55rem 1.4rem !important;
  box-shadow:0 4px 15px rgba(56,189,248,0.35);
}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(56,189,248,0.5) !important;background:var(--sky-dark) !important}
.hamburger{
  display:none;flex-direction:column;gap:5px;
  background:none;border:none;cursor:pointer;padding:4px;
}
.hamburger span{
  width:25px;height:2px;
  background:var(--text-dark);border-radius:2px;
  transition:var(--transition);display:block;
}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ---- Gold text ---- */
.gold-text{
  background:linear-gradient(135deg,var(--gold-dark),var(--gold));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

/* ---- Buttons ---- */
/* ===== PREMIUM BUTTONS ===== */

.btn{
  position:relative;
  overflow:hidden;

  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:12px;

  padding:15px 32px;

  border:none;
  outline:none;

  border-radius:60px;

  font-size:0.96rem;
  font-weight:700;
  font-family:'Poppins',sans-serif;

  cursor:pointer;
  text-decoration:none;

  transition:all .35s ease;

  letter-spacing:.3px;

  z-index:1;
}

/* shine effect */

.btn::before{
  content:'';

  position:absolute;
  top:0;
  left:-120%;

  width:100%;
  height:100%;

  background:linear-gradient(
    120deg,
    transparent,
    rgba(255,255,255,0.35),
    transparent
  );

  transition:.7s ease;

  z-index:-1;
}

.btn:hover::before{
  left:120%;
}

/* primary */

.btn-gold{
  background:linear-gradient(
    135deg,
    #0ea5e9,
    #0284c7
  );

  color:#fff;

  box-shadow:
  0 10px 30px rgba(14,165,233,0.28);
}

.btn-gold:hover{
  transform:translateY(-4px) scale(1.02);

  box-shadow:
  0 16px 40px rgba(14,165,233,0.4);
}

/* outline */

.btn-outline{
  background:#fff;

  color:#0284c7;

  border:2px solid rgba(14,165,233,0.25);

  box-shadow:
  0 8px 24px rgba(14,165,233,0.08);
}

.btn-outline:hover{
  background:#f0f9ff;

  border-color:#0ea5e9;

  transform:translateY(-4px);

  box-shadow:
  0 15px 35px rgba(14,165,233,0.18);
}

/* xl */

.btn-xl{
  padding:18px 42px;
  font-size:1.05rem;
}

/* icon */

.btn i{
  transition:.3s ease;
}

.btn:hover i{
  transform:translateX(4px);
}

/* ---- Hero ---- */
.hero{
  min-height:100vh;
  background:linear-gradient(135deg,#ffffff 0%,#f0f9ff 40%,#e0f2fe 70%,#f0f9ff 100%);
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
  padding:120px 2rem 80px;
}
.hero-bg{position:absolute;inset:0;pointer-events:none}
.hero-shape{
  position:absolute;border-radius:50%;
  filter:blur(80px);opacity:0.25;
}
.s1{width:600px;height:600px;background:var(--sky);top:-100px;right:-100px;animation:float 8s ease-in-out infinite}
.s2{width:400px;height:400px;background:var(--gold);bottom:-100px;left:-100px;animation:float 10s ease-in-out infinite reverse;opacity:0.15}
.s3{width:300px;height:300px;background:var(--sky-light);top:50%;left:50%;transform:translate(-50%,-50%);animation:pulse2 6s ease infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-30px)}}
@keyframes pulse2{0%,100%{opacity:0.15}50%{opacity:0.35}}
.hero-particles{position:absolute;inset:0}
.particle{
  position:absolute;width:4px;height:4px;
  background:var(--sky);border-radius:50%;
  opacity:0.5;animation:particleFloat linear infinite;
}
@keyframes particleFloat{
  0%{transform:translateY(100vh) rotate(0deg);opacity:0}
  10%{opacity:0.5}
  90%{opacity:0.2}
  100%{transform:translateY(-100px) rotate(720deg);opacity:0}
}
.hero-content{position:relative;z-index:2;text-align:center;max-width:900px;margin:0 auto}
.hero-badge{
  display:inline-flex;align-items:center;gap:0.5rem;
  background:rgba(56,189,248,0.1);
  border:1px solid rgba(56,189,248,0.3);
  color:var(--sky-dark);
  padding:0.4rem 1.2rem;
  border-radius:50px;
  font-size:0.85rem;font-weight:600;
  letter-spacing:1px;
  margin-bottom:1.5rem;
  animation:fadeInDown 0.8s ease;
}
.hero-title{
  font-family:'Outfit',sans-serif;
  font-size:clamp(2.2rem,5vw,4rem);
  font-weight:900;
  color:var(--text-dark);line-height:1.2;
  margin-bottom:1.2rem;
  animation:fadeInUp 0.9s ease;
}
.hero-subtitle{
  font-size:1.15rem;color:var(--text-mid);
  margin-bottom:1.5rem;
  animation:fadeInUp 1s ease;
}
.hero-highlight{
  display:inline-flex;align-items:center;gap:0.75rem;
  background:rgba(56,189,248,0.08);
  border:1px solid rgba(56,189,248,0.2);
  border-radius:50px;
  padding:0.75rem 1.8rem;
  margin-bottom:2rem;
  font-size:0.95rem;color:var(--text-mid);
  flex-wrap:wrap;justify-content:center;
  animation:fadeInUp 1.1s ease;
}
.hero-highlight strong{color:var(--sky-dark);font-weight:700}
.exam-fee-box{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(245,197,66,0.1);
  border:1px solid rgba(245,197,66,0.35);
  padding:12px 22px;border-radius:50px;
  color:var(--text-dark);
  margin-top:0;margin-bottom:0;
  font-size:1rem;
}
.exam-fee-box strong{color:var(--gold-dark);font-weight:700}
.hero-btns{
  display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;
  margin-bottom:3rem;
  animation:fadeInUp 1.2s ease;
}
.hero-stats{
  display:flex;align-items:center;justify-content:center;gap:2rem;
  flex-wrap:wrap;
  animation:fadeInUp 1.3s ease;
}
.hstat{display:flex;flex-direction:column;text-align:center}
.hstat strong{
  font-size:1.8rem;font-weight:800;
  background:linear-gradient(135deg,var(--sky-dark),var(--sky));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hstat span{font-size:0.8rem;color:var(--text-light)}
.hstat-div{width:1px;height:40px;background:rgba(56,189,248,0.25)}
.hero-scroll-hint{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:0.5rem;
  color:var(--text-light);font-size:0.8rem;
  animation:fadeIn 2s ease;
}
.scroll-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--sky);animation:bounce 1.5s ease infinite;
}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}

/* ---- Sections ---- */
.section{padding:6rem 0}
.section-dark{
  background:linear-gradient(135deg,#0c1a2e,#0f2744,#0c1a2e);
}
.container{max-width:1200px;margin:0 auto;padding:0 2rem}
.section-label{
  font-size:0.8rem;font-weight:700;letter-spacing:3px;
  text-transform:uppercase;color:var(--sky-dark);
  margin-bottom:0.5rem;
}
.section-title{
  font-family:'Outfit',sans-serif;
  font-size:clamp(1.8rem,4vw,2.8rem);
  font-weight:800;color:var(--text-dark);
  margin-bottom:1rem;line-height:1.2;
}
.section-desc{
  font-size:1.05rem;color:var(--text-light);
  max-width:600px;margin-bottom:3rem;
}

/* ---- About Cards ---- */
.about-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:1.5rem;
}
.about-card{
  background:#fff;
  border:1px solid rgba(56,189,248,0.15);
  border-radius:var(--radius);
  padding:2rem;
  box-shadow:var(--shadow);
  transition:var(--transition);
  position:relative;overflow:hidden;
  border-top:3px solid var(--sky);
}
.about-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(56,189,248,0.03),rgba(245,197,66,0.03));
  opacity:0;transition:var(--transition);
}
.about-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-sky);border-top-color:var(--gold)}
.about-card:hover::before{opacity:1}
.about-icon{font-size:2.5rem;margin-bottom:1rem;color:var(--sky)}
.about-card h3{font-size:1.15rem;font-weight:700;color:var(--text-dark);margin-bottom:0.5rem}
.about-card p{color:var(--text-light);font-size:0.93rem}

/* ---- Levels ---- */
.levels-timeline{
  display:flex;align-items:center;gap:2rem;
  justify-content:center;flex-wrap:wrap;
}
.level-card{
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.15);
  border-radius:var(--radius-lg);
  padding:2.5rem;
  backdrop-filter:blur(20px);
  max-width:380px;width:100%;
  transition:var(--transition);
  color:#fff;
  box-shadow:0 20px 50px rgba(0,0,0,0.3);
}
.level-card:hover{transform:translateY(-6px);box-shadow:0 30px 60px rgba(0,0,0,0.4)}
.level-card-gold{
  border-color:rgba(245,197,66,0.4);
  background:linear-gradient(135deg,rgba(245,197,66,0.12),rgba(245,197,66,0.05));
  box-shadow:var(--shadow-gold);
}
.level-badge{
  display:inline-block;
  background:rgba(255,255,255,0.15);
  color:#fff;
  padding:0.3rem 1rem;border-radius:50px;
  font-size:0.8rem;font-weight:700;
  letter-spacing:2px;margin-bottom:1.2rem;
}
.level-badge-gold{background:var(--gold);color:#0f172a}
.level-icon{font-size:3rem;margin-bottom:1rem;color:var(--sky-light)}
.level-card h3{font-size:1.4rem;font-weight:700;margin-bottom:1.5rem;font-family:'Outfit',sans-serif}
.level-details{display:flex;gap:1rem;margin-bottom:1.5rem}
.level-stat{
  flex:1;background:rgba(255,255,255,0.08);
  border-radius:12px;padding:1rem;text-align:center;
}
.ls-val{display:block;font-size:1.4rem;font-weight:800;color:var(--gold)}
.ls-label{font-size:0.75rem;color:rgba(255,255,255,0.6);margin-top:0.2rem}
.qualify-badge{
  background:rgba(255,255,255,0.1);
  border:1px solid rgba(255,255,255,0.2);
  border-radius:8px;padding:0.75rem 1rem;
  font-size:0.85rem;font-weight:600;
  color:rgba(255,255,255,0.9);
  margin-bottom:1.5rem;
}
.qualify-gold{
  background:rgba(245,197,66,0.15);
  border-color:rgba(245,197,66,0.4);
  color:var(--gold-light);
}
.level-points{list-style:none;display:flex;flex-direction:column;gap:0.5rem}
.level-points li{
  padding-left:1.2rem;position:relative;
  font-size:0.9rem;color:rgba(255,255,255,0.75);
}
.level-points li::before{
  content:'•';position:absolute;left:0;color:var(--sky-light);font-weight:bold;
}
.levels-arrow{display:flex;flex-direction:column;align-items:center;gap:0.5rem}
.arrow-line{width:60px;height:2px;background:linear-gradient(90deg,var(--sky),var(--gold))}
.arrow-text{color:var(--gold);font-size:0.85rem;font-weight:600;white-space:nowrap}

/* ---- Scholarship ---- */
.scholarship-hero{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:3rem;align-items:center;
  background:linear-gradient(135deg,var(--sky-pale),#fff);
  border:1px solid rgba(56,189,248,0.2);
  border-radius:var(--radius-lg);
  padding:3rem;
  margin-bottom:3rem;
  box-shadow:var(--shadow);
}
.sch-award{text-align:center;padding:2rem}
.sch-amount{
  font-family:'Outfit',sans-serif;
  font-size:3.5rem;font-weight:900;
  background:linear-gradient(135deg,var(--gold-dark),var(--gold));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.sch-label{color:var(--text-light);font-size:0.85rem;font-weight:600;margin-top:0.5rem;letter-spacing:1px}
.sch-details{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1.5rem;
}
.sch-card{
  background:#fff;border-radius:var(--radius);
  padding:1.5rem;text-align:center;
  box-shadow:var(--shadow);
  border:1px solid rgba(56,189,248,0.12);
  border-top:3px solid var(--sky);
  transition:var(--transition);
}
.sch-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-sky);border-top-color:var(--gold)}
.sch-val{
  font-family:'Outfit',sans-serif;
  font-size:1.8rem;font-weight:900;
  color:var(--sky-dark);
}
.sch-desc{color:var(--text-light);font-size:0.8rem;margin-top:0.25rem}
.sch-cta{text-align:center}
.sch-cta p{color:var(--text-mid);margin-bottom:1.5rem;font-size:1.05rem}
.ci-icon{
  width:48px;height:48px;border-radius:12px;
  background:linear-gradient(135deg,var(--sky-pale),rgba(56,189,248,0.15));
  border:1px solid rgba(56,189,248,0.2);
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;flex-shrink:0;color:var(--sky-dark);
  margin-bottom:0.75rem;
}

/* ---- Eligibility ---- */
.elig-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
  gap:1.5rem;
}
.elig-card{
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(56,189,248,0.25);
  border-radius:var(--radius);
  padding:2rem;
  backdrop-filter:blur(10px);
  transition:var(--transition);
  color:#fff;
}
.elig-card:hover{transform:translateY(-6px);box-shadow:0 20px 50px rgba(56,189,248,0.15)}
.elig-check{font-size:2rem;margin-bottom:1rem;color:var(--gold)}
.elig-card h3{color:#fff;font-size:1.1rem;font-weight:700;margin-bottom:0.5rem}
.elig-card p{color:rgba(255,255,255,0.7);font-size:0.9rem}

/* ---- Why ---- */
.why-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:1.5rem;
}
.why-card{
  background:#fff;
  border:1px solid rgba(56,189,248,0.12);
  border-radius:var(--radius);
  padding:2rem;
  transition:var(--transition);
  box-shadow:0 4px 20px rgba(56,189,248,0.06);
  position:relative;overflow:hidden;
}
.why-card::after{
  content:'';position:absolute;bottom:0;left:0;right:0;
  height:3px;
  background:linear-gradient(90deg,var(--sky),var(--gold));
  transform:scaleX(0);transform-origin:left;
  transition:var(--transition);
}
.why-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-sky)}
.why-card:hover::after{transform:scaleX(1)}
.why-icon,.why-card .ci-icon{font-size:2.5rem;margin-bottom:1rem;color:var(--sky)}
.why-card h4{font-size:1.05rem;font-weight:700;color:var(--text-dark);margin-bottom:0.5rem}
.why-card p{color:var(--text-light);font-size:0.9rem}

/* ---- Testimonials ---- */
.testi-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:1.5rem;
}
.testi-card{
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(56,189,248,0.2);
  border-radius:var(--radius);
  padding:2rem;
  backdrop-filter:blur(10px);
  transition:var(--transition);
  position:relative;
}
.testi-card:hover{transform:translateY(-4px);box-shadow:0 20px 50px rgba(56,189,248,0.15)}
.testi-quote{
  font-family:'Outfit',sans-serif;
  font-size:4rem;line-height:1;
  color:var(--sky);opacity:0.4;
  margin-bottom:-1rem;
}
.testi-card p{color:rgba(255,255,255,0.8);font-size:0.95rem;margin-bottom:1.5rem;font-style:italic}
.testi-author{display:flex;align-items:center;gap:0.75rem}
.testi-avatar{
  width:45px;height:45px;border-radius:50%;
  background:linear-gradient(135deg,var(--sky),var(--sky-dark));
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;font-weight:700;color:#fff;flex-shrink:0;
}
.testi-author strong{display:block;color:#fff;font-size:0.95rem}
.testi-author span{display:block;color:rgba(255,255,255,0.55);font-size:0.8rem}

/* ---- FAQ ---- */
.faq-list{
  max-width:900px;
  margin:auto;
}

#faq .section-title,
#faq .section-desc,
#faq .section-label{
  text-align:center;
  margin-left:auto;
  margin-right:auto;
}

#faq .section-desc{
  max-width:700px;
}
.faq-item{
  background:#fff;

  border-radius:20px;

  border:1px solid rgba(14,165,233,0.12);

  margin-bottom:20px;

  overflow:hidden;

  transition:.35s ease;

  box-shadow:
  0 8px 24px rgba(14,165,233,0.05);
}

.faq-item:hover{
  transform:translateY(-3px);

  box-shadow:
  0 16px 35px rgba(14,165,233,0.12);
}
.faq-q{
  width:100%;text-align:left;
  background:none;border:none;
  padding:1.2rem 1.5rem;
  display:flex;justify-content:space-between;align-items:center;
  font-size:0.97rem;font-weight:600;
  color:var(--text-dark);cursor:pointer;
  font-family:'Poppins',sans-serif;
  transition:var(--transition);
}
.faq-q:hover{background:var(--sky-pale)}
.faq-item.active .faq-q{background:linear-gradient(135deg,rgba(56,189,248,0.05),rgba(245,197,66,0.05))}
.faq-icon{
  font-size:1.3rem;font-weight:300;color:var(--sky);
  transition:var(--transition);flex-shrink:0;
}
.faq-item.active .faq-icon{transform:rotate(45deg);color:var(--gold)}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height 0.35s ease,padding 0.35s ease;
}
.faq-a p{padding:0 1.5rem 1.2rem;color:var(--text-light);font-size:0.92rem}
.faq-item.active .faq-a{max-height:200px}

/* ---- CTA Banner ---- */
.cta-banner{
  background:linear-gradient(135deg,var(--sky-dark) 0%,#0284c7 50%,#0369a1 100%);
  padding:5rem 2rem;text-align:center;
  position:relative;overflow:hidden;
}
.cta-shape{position:absolute;border-radius:50%;filter:blur(60px);opacity:0.3;pointer-events:none}
.cs1{width:400px;height:400px;background:var(--gold);top:-100px;right:-100px}
.cs2{width:300px;height:300px;background:#fff;bottom:-50px;left:-50px;opacity:0.1}
.cta-banner h2{
  font-family:'Outfit',sans-serif;
  font-size:clamp(1.8rem,4vw,2.8rem);
  color:#fff;margin-bottom:1rem;font-weight:800;
}
.cta-banner p{color:rgba(255,255,255,0.85);font-size:1.05rem;margin-bottom:2rem}
.cta-banner .btn-gold{
  background:linear-gradient(135deg,var(--gold),var(--gold-dark)) !important;
  color:#0f172a !important;
  box-shadow:0 4px 20px rgba(245,197,66,0.4) !important;
}
.cta-banner .btn-gold:hover{box-shadow:0 8px 35px rgba(245,197,66,0.6) !important}

/* ---- Contact ---- */
.contact-grid{
  width:100%;

  max-width:1200px;

  margin:0 auto;

  display:flex;

  flex-direction:column;

  justify-content:center;

  align-items:center;

  gap:3rem;
}
#contact .section-label,
#contact .section-title,
#contact .section-desc{
  text-align:center;
  margin-left:auto;
  margin-right:auto;
}

#contact .section-desc{
  max-width:700px;
  margin-bottom:4rem;
}
.contact-info{
  width:100%;

  display:flex;

  flex-direction:row;

  justify-content:center;

  align-items:stretch;

  flex-wrap:wrap;

  gap:2rem;
}
.contact-item{
  width:280px;

  background:#fff;

  border-radius:24px;

  padding:32px 24px;

  display:flex;

  flex-direction:column;

  justify-content:center;

  align-items:center;

  text-align:center;

  gap:14px;

  box-shadow:
  0 12px 35px rgba(14,165,233,0.08);

  border:1px solid rgba(14,165,233,0.08);

  transition:.35s ease;
}

.contact-item:hover{
  transform:translateY(-6px);

  box-shadow:
  0 18px 45px rgba(14,165,233,0.14);
}

.contact-item .ci-icon{
  margin:0 auto;
}
.contact-form{
  width:100%;

  max-width:750px;

  margin:0 auto;

  display:flex;

  flex-direction:column;

  gap:1.2rem;

  background:#fff;

  padding:40px;

  border-radius:30px;

  box-shadow:
  0 20px 60px rgba(14,165,233,0.08);

  border:1px solid rgba(14,165,233,0.08);
}
.contact-item strong{color:var(--text-dark);font-weight:700;display:block;margin-bottom:0.2rem}
.contact-item p{color:var(--text-light);font-size:0.93rem}
.contact-form{
  display:flex;
  flex-direction:column;
  gap:1.2rem;

  background:#fff;

  padding:35px;

  border-radius:28px;

  box-shadow:
  0 20px 60px rgba(14,165,233,0.08);

  border:1px solid rgba(14,165,233,0.08);
}
.cf-group input,
.cf-group textarea{
  width:100%;

  padding:16px 18px;

  border-radius:16px;

  border:1.5px solid rgba(14,165,233,0.15);

  background:#fff;

  font-size:0.95rem;

  transition:.3s ease;

  font-family:'Poppins',sans-serif;
}

.cf-group input:focus,
.cf-group textarea:focus{
  outline:none;

  border-color:#0ea5e9;

  box-shadow:
  0 0 0 5px rgba(14,165,233,0.08);
}

/* ---- Footer ---- */
.footer{background:linear-gradient(135deg,#0c1a2e,#0f2744)}
.footer-top{padding:4rem 0 2rem}
.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1.5fr;
  gap:2rem;
}
.footer-brand{color:rgba(255,255,255,0.7)}
.footer-logo{
  font-family:'Outfit',sans-serif;
  font-size:1.4rem;color:var(--sky-light);
  font-weight:800;margin-bottom:1rem;
  display:flex;align-items:center;gap:0.5rem;
}
.footer-brand p{font-size:0.88rem;line-height:1.7;margin-bottom:1.5rem}
.social-links{display:flex;gap:0.75rem}
.social-links a{
  width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,0.08);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,0.6);
  text-decoration:none;font-size:0.85rem;font-weight:700;
  transition:var(--transition);
}
.social-links a:hover{background:var(--sky);color:#fff;box-shadow:0 4px 15px rgba(56,189,248,0.3)}
.footer-col h4{color:#fff;font-size:0.95rem;font-weight:700;margin-bottom:1rem}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:0.5rem}
.footer-col ul li a{
  color:rgba(255,255,255,0.6);text-decoration:none;
  font-size:0.88rem;transition:var(--transition);
}
.footer-col ul li a:hover{color:var(--sky-light);padding-left:4px}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,0.08);
  margin-top:2rem;
  padding:1.2rem 2rem;
  
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:1rem;

  max-width:1200px;
  margin-left:auto;
  margin-right:auto;

  color:rgba(255,255,255,0.6);
  font-size:0.82rem;
  flex-wrap:wrap;
}
.footer-bottom a {
  color:var(--sky-light);
  text-decoration: none;
  margin: 0 4px;
}
.footer-bottom a:hover {
  text-decoration: underline;
}
.footer-bottom-left{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.footer-bottom-right{
  font-size:0.78rem;
  text-align:right;
  line-height:1.6;
}

/* ---- Back to Top ---- */
.back-top{
  position:fixed;bottom:5rem;right:1.5rem;
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg,var(--sky),var(--sky-dark));
  color:#fff;border:none;
  font-size:1.1rem;font-weight:700;cursor:pointer;
  box-shadow:0 4px 15px rgba(56,189,248,0.4);
  transition:var(--transition);z-index:500;
  opacity:0;pointer-events:none;
}
.back-top.show{opacity:1;pointer-events:auto}
.back-top:hover{transform:translateY(-3px);box-shadow:0 8px 25px rgba(56,189,248,0.6)}

/* ---- WhatsApp Float ---- */
.whatsapp-float{
  position:fixed;bottom:1.5rem;right:1.5rem;
  width:52px;height:52px;border-radius:50%;
  background:#25d366;color:#fff;
  display:flex;align-items:center;justify-content:center;
  text-decoration:none;z-index:500;
  box-shadow:0 4px 20px rgba(37,211,102,0.4);
  transition:var(--transition);
}
.whatsapp-float svg{width:28px;height:28px}
.whatsapp-float:hover{transform:scale(1.1);box-shadow:0 8px 30px rgba(37,211,102,0.6)}

/* ---- Animations ---- */
.fade-in{
  opacity:0;transform:translateY(30px);
  transition:opacity 0.7s ease,transform 0.7s ease;
}
.fade-in.visible{opacity:1;transform:translateY(0)}
@keyframes fadeInDown{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ---- Font Awesome icons ---- */
.logo-icon i,.about-icon i,.level-icon i,.sch-icon i,.why-icon i,.ci-icon i,.footer-logo i{font-size:inherit}
.fa-solid,.fa-brands{transition:0.3s ease}
.btn i{margin-left:8px}
.qualify-badge i,.elig-check i,.form-success i{margin-right:8px}
.footer-bottom .fa-heart{color:var(--sky-light);margin:0 4px}

/* ---- Responsive ---- */
@media(max-width:1024px){
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .scholarship-hero{grid-template-columns:1fr;text-align:center}
  .sch-details{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .nav-links{
    position:fixed;top:0;right:-100%;
    width:80%;max-width:320px;height:100vh;
    background:#fff;
    flex-direction:column;
    padding:6rem 2rem 2rem;
    gap:0.5rem;
    transition:right 0.35s ease;
    box-shadow:-10px 0 40px rgba(56,189,248,0.15);
    z-index:999;
  }
  .nav-links.open{right:0}
  .nav-links a{
    width:100%;padding:0.85rem 1rem;
    border-radius:12px;font-size:1rem;
    color:var(--text-dark);
  }
  .hamburger{display:flex;z-index:1001;position:relative}
  .levels-timeline{flex-direction:column}
  .levels-arrow{transform:rotate(90deg)}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{
  flex-direction:column;
  text-align:center;
  padding:1.5rem 1rem;
}

.footer-bottom-left{
  justify-content:center;
}

.footer-bottom-right{
  text-align:center;
}
  .hero-stats{gap:1.2rem}
  .hstat-div{display:none}
}

.hero-btns{
  width:100%;
}

.hero-btns .btn{
  width:100%;
  max-width:320px;
}
.contact-grid{
  text-align:center;
}

.contact-info{
  align-items:center;
}

.contact-info{
  flex-direction:column;
  align-items:center;
}

.contact-item{
  width:100%;
  max-width:340px;
}

.contact-form{
  padding:28px 20px;
}
@media(max-width:480px){
  .hero-btns{flex-direction:column;align-items:center}
  .sch-details{grid-template-columns:1fr 1fr}
}
.container{
  padding:0 1rem;
}

.hero{
  padding:110px 1rem 70px;
}

.hero-title{
  font-size:2rem;
  line-height:1.3;
}

.hero-subtitle{
  font-size:0.95rem;
}

.hero-highlight{
  border-radius:20px;
  padding:1rem;
}



.level-card,
.about-card,
.why-card,
.testi-card,
.elig-card,
.sch-card{
  padding:1.4rem;
}

.footer{
  overflow:hidden;
}

/* =========================================
   ULTRA PREMIUM FLOAT BUTTON
========================================= */

.premium-float-btn{

  position:fixed;

  left:50%;
  bottom:28px;

  transform:
  translateX(-50%)
  translateY(120px)
  scale(.8);

  opacity:0;
  visibility:hidden;

  display:flex;
  align-items:center;
  justify-content:center;

  min-width:260px;

  padding:17px 30px;

  border-radius:80px;

  text-decoration:none;

  z-index:9999;

  overflow:hidden;

  backdrop-filter:blur(22px);

  background:
  rgba(15,23,42,0.72);

  border:
  1px solid rgba(255,255,255,0.16);

  box-shadow:
  0 15px 45px rgba(0,0,0,0.28);

  transition:
  all .45s cubic-bezier(.22,1,.36,1);
}

/* SHOW */

.premium-float-btn.show-float{

  opacity:1;
  visibility:visible;

  transform:
  translateX(-50%)
  translateY(0)
  scale(1);

  animation:
  floatingBtn 3s ease-in-out infinite;
  pointer-events:auto;
}

/* animated border */

.premium-float-btn::before{

  content:'';

  position:absolute;

  inset:-2px;

  border-radius:80px;

  padding:2px;

  background:
  linear-gradient(
    135deg,
    #38bdf8,
    #ffffff,
    #0ea5e9,
    #7dd3fc
  );

  background-size:300% 300%;

  animation:
  borderMove 5s linear infinite;

  
  -webkit-mask-composite:xor;
          mask-composite:exclude;
}

/* glow */

.btn-glow{

  position:absolute;

  width:180px;
  height:180px;

  background:
  rgba(56,189,248,.25);

  border-radius:50%;

  filter:blur(55px);

  animation:
  pulseGlow 3s ease infinite;
}

/* content */

.btn-content{

  position:relative;

  display:flex;
  align-items:center;
  gap:12px;

  color:#000218bb;

  font-size:1rem;
  font-weight:700;

  letter-spacing:.3px;

  z-index:2;
}

/* icon */

.btn-content i{

  font-size:1rem;

  color:#7dd3fc;
}

/* hover */

.premium-float-btn:hover{

  transform:
  translateX(-50%)
  translateY(-7px)
  scale(1.05);

  box-shadow:
  0 22px 60px rgba(14,165,233,0.32);
}

/* floating */

@keyframes floatingBtn{

  0%{
    transform:
    translateX(-50%)
    translateY(0px)
    scale(1);
  }

  50%{
    transform:
    translateX(-50%)
    translateY(-7px)
    scale(1.02);
  }

  100%{
    transform:
    translateX(-50%)
    translateY(0px)
    scale(1);
  }
}

/* border */

@keyframes borderMove{

  0%{
    background-position:0% 50%;
  }

  100%{
    background-position:300% 50%;
  }
}

/* glow pulse */

@keyframes pulseGlow{

  0%{
    opacity:.35;
    transform:scale(1);
  }

  50%{
    opacity:.7;
    transform:scale(1.18);
  }

  100%{
    opacity:.35;
    transform:scale(1);
  }
}

/* mobile */

@media(max-width:768px){

  .premium-float-btn{

    width:88%;

    min-width:auto;

    bottom:18px;

    padding:15px 20px;
  }

  .btn-content{

    font-size:.92rem;
  }

}