:root {
  --red: #E31E24;
  --blue: #1E2D7D;
  --yellow: #FFD700;
  --light-blue: #2E4DB3;
  --dark: #111827;
  --gray: #6B7280;
  --light: #F9FAFB;
  --white: #ffffff;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Poppins',sans-serif;color:var(--dark);overflow-x:hidden;}
section[id]{scroll-margin-top:150px;}
#home{scroll-margin-top:0;}

/* ===== TOPBAR ===== */
.topbar{background:var(--blue);color:white;padding:8px 0;font-size:13px;}
.topbar-inner{max-width:1200px;margin:0 auto;padding:0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:6px;}
.topbar a{color:white;text-decoration:none;margin-left:16px;}
.topbar a:hover{color:var(--yellow);}

/* ===== NAVBAR ===== */
.navbar{background:white;box-shadow:0 2px 20px rgba(0,0,0,0.1);position:sticky;top:0;z-index:1000;padding:0;}
.nav-inner{max-width:1200px;margin:0 auto;padding:0;display:flex;justify-content:space-between;align-items:center;}
.logo-wrap{display:flex;align-items:center;gap:12px;padding:10px 0;text-decoration:none;}
.logo-img{height:60px;width:auto;display:block;}
.footer-logo{height:70px;} /* Makes logo white in footer if needed, or just adjust size */
.nav-links{display:flex;list-style:none;gap:4px;align-items:center;}
.nav-links a{text-decoration:none;color:var(--dark);font-weight:500;font-size:14px;padding:8px 12px;border-radius:8px;transition:.2s;position:relative;}
.nav-links a:hover{background:var(--blue);color:white;}
.nav-links a:not(.nav-cta).active{background:var(--blue);color:white;}
.nav-cta{background:var(--red)!important;color:white!important;padding:10px 20px!important;border-radius:25px!important;font-weight:500!important;}
.nav-cta:hover{background:#c0151a!important;transform:scale(1.05);}
.hamburger{display:none;font-size:24px;cursor:pointer;color:var(--blue);}
.mobile-menu{display:none;background:white;padding:16px 20px;box-shadow:0 4px 20px rgba(0,0,0,0.1);}
.mobile-menu a{display:block;padding:10px 0;color:var(--dark);text-decoration:none;font-weight:500;border-bottom:1px solid #f0f0f0;}
.mobile-menu a:not(.nav-cta).active{color:white;background:var(--blue);border-radius:8px;padding:10px 12px;border-bottom-color:transparent;}

/* ===== HERO ===== */
.hero{min-height:80vh;background:linear-gradient(135deg,var(--blue) 0%,#0f1f6b 50%,var(--red) 100%);position:relative;display:flex;align-items:center;overflow:hidden;}
.hero-bg-shapes{position:absolute;inset:0;pointer-events:none;}
.hero-shape{position:absolute;border-radius:50%;opacity:.08;background:white;}
.hero-shape.s1{width:500px;height:500px;top:-150px;right:-100px;}
.hero-shape.s2{width:300px;height:300px;bottom:-80px;left:-80px;}
.hero-shape.s3{width:200px;height:200px;top:50%;left:40%;}
.hero-inner{max-width:1200px;margin:0 auto;padding:40px 0;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;z-index:2;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,215,0,0.2);border:1px solid var(--yellow);color:var(--yellow);padding:8px 18px;border-radius:25px;font-size:13px;font-weight:600;margin-bottom:20px;animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(255,215,0,0.4);}50%{box-shadow:0 0 0 10px rgba(255,215,0,0);}}
.hero h1{font-size:clamp(36px,5vw,60px);font-weight:500;color:white;line-height:1.15;margin-bottom:20px;}
.hero h1 span{color:var(--yellow);}
.hero-sub{font-size:18px;color:rgba(255,255,255,0.85);margin-bottom:30px;line-height:1.7;}
.hero-ctas{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:40px;}
.btn-primary{background:var(--yellow);color:var(--blue);padding:16px 32px;border-radius:50px;font-weight:500;font-size:16px;text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:.3s;border:none;cursor:pointer;}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 15px 40px rgba(255,215,0,0.4);}
.btn-outline{background:transparent;color:white;border:2px solid white;padding:14px 30px;border-radius:50px;font-weight:500;font-size:16px;text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:.3s;}
.btn-outline:hover{background:white;color:var(--blue);}
.hero-stats{display:flex;gap:30px;flex-wrap:wrap;}
.hero-stat{text-align:center;}
.hero-stat .num{font-size:28px;font-weight:500;color:var(--yellow);}
.hero-stat .lbl{font-size:12px;color:rgba(255,255,255,0.7);text-transform:uppercase;letter-spacing:1px;}
.hero-visual{position:relative;}
.hero-img-wrap.slider{width:100%;aspect-ratio:1/1;border-radius:30px;position:relative;box-shadow:0 30px 80px rgba(0,0,0,0.4);display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;scrollbar-width:none;}
.hero-img-wrap.slider::-webkit-scrollbar{display:none;}
.slide{min-width:100%;scroll-snap-align:start;position:relative;background:var(--light);overflow:hidden;}
.slide img{width:100%;height:100%;object-fit:cover;display:block;}
.slider-counter{position:absolute;bottom:20px;right:20px;z-index:10;background:rgba(0,0,0,0.6);color:white;padding:6px 16px;border-radius:30px;font-size:14px;font-weight:400;letter-spacing:1px;backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,0.1);font-family:monospace;}
.hero-img-wrap img,.placeholder-img{width:100%;height:100%;object-fit:cover;}
.placeholder-img{background:linear-gradient(135deg,#e8f4fd,#d1ecf9);display:flex;flex-direction:column;align-items:center;justify-content:center;color:#5a9fc7;font-size:14px;gap:10px;}
.placeholder-img i{font-size:48px;opacity:.5;}
.hero-float-card{position:absolute;background:white;border-radius:16px;padding:10px 14px;box-shadow:0 10px 40px rgba(0,0,0,0.15);display:flex;align-items:center;gap:10px;z-index:11;}
.hero-float-card.card1{bottom:30px;left:-20px;animation:float1 3s ease-in-out infinite;}
.hero-float-card.card2{top:30px;right:-20px;animation:float2 3s ease-in-out infinite;}
@keyframes float1{0%,100%{transform:translateY(0);}50%{transform:translateY(-10px);}}
@keyframes float2{0%,100%{transform:translateY(0);}50%{transform:translateY(10px);}}
.float-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;}
.float-icon.red{background:#fff0f0;color:var(--red);}
.float-icon.blue{background:#f0f4ff;color:var(--blue);}
.float-text .ft{font-size:14px;font-weight:500;color:var(--dark);}
.float-text .fb{font-size:11px;color:var(--gray);}

/* ===== ADMISSION URGENCY MARQUEE ===== */
.urgency-bar.marquee {
  background: var(--red);
  color: white;
  padding: 8px 0;
  position: sticky;
  top: 80px;
  z-index: 998;
  overflow: hidden;
  white-space: nowrap;
  display: flex;
  align-items: center;
}
.marquee-inner {
  display: flex;
  width: max-content;
  animation: marquee-scroll 25s linear infinite;
}
.marquee-item {
  display: flex;
  align-items: center;
  gap: 20px;
  padding-right: 60px;
}
.marquee-item strong {
  font-size: 15px;
}
.marquee-item span {
  font-size: 13px;
  opacity: 0.9;
}
.btn-urgency {
  background: white;
  color: var(--red);
  padding: 5px 15px;
  border-radius: 20px;
  font-weight: 700;
  font-size: 12px;
  text-decoration: none;
  transition: .2s;
  margin-left: 10px;
}
.btn-urgency:hover {
  background: var(--yellow);
  color: var(--blue);
}
@keyframes marquee-scroll {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ===== QUICK STATS ===== */
.stats-band{background:var(--blue);padding:0;}
.stats-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.stat-item{text-align:center;color:white;padding:20px;}
.stat-item .big-num{font-size:48px;font-weight:600;color:var(--yellow);line-height:1;}
.stat-item .stat-label{font-size:14px;opacity:.85;margin-top:6px;}

/* ===== SECTION COMMONS ===== */
section{padding:0;}
.section-inner{max-width:1200px;margin:0 auto;}
.section-tag{display:inline-block;background:#fff0f0;color:var(--red);padding:6px 16px;border-radius:25px;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:1px;margin-bottom:14px;}
.section-tag.blue{background:#f0f4ff;color:var(--blue);}
.section-tag.yellow{background:#fffbea;color:#b8860b;}
h2.section-title{font-size:clamp(28px,4vw,42px);font-weight:500;line-height:1.2;margin-bottom:16px;}
h2.section-title span{color:var(--red);}
h2.section-title span.blue{color:var(--blue);}
.section-desc{font-size:16px;color:var(--gray);line-height:1.8;max-width:680px;text-align:center !important;margin:0 auto !important;}

/* ===== ABOUT ===== */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;margin-top:25px;margin-bottom: 50px;}
.about-img-collage{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.collage-img{border-radius:16px;overflow:hidden;aspect-ratio:1;}
.collage-img img{width:100%;height:100%;object-fit:cover;display:block;}
.about-content .check-list{list-style:none;margin:24px 0;display:flex;flex-direction:column;gap:12px;}
.check-list li{display:flex;align-items:flex-start;gap:12px;font-size:15px;line-height:1.6;}
.check-list li .ci{width:24px;height:24px;min-width:24px;border-radius:50%;background:var(--blue);color:white;display:flex;align-items:center;justify-content:center;font-size:11px;margin-top:2px;}
.about-highlight{background:linear-gradient(135deg,var(--blue),var(--light-blue));color:white;border-radius:24px;padding:24px;margin-top:30px;display:flex;align-items:center;gap:20px;position:relative;overflow:hidden;z-index:1;transition:all 0.4s cubic-bezier(0.4,0,0.2,1);box-shadow:0 10px 30px rgba(15,31,107,0.1);}
.about-highlight::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--red),#f04040);opacity:0;transition:opacity 0.6s ease;z-index:-1;}
.about-highlight:hover::before{opacity:1;}
.about-highlight:hover{transform:translateY(-8px);box-shadow:0 15px 40px rgba(227,30,36,0.25);}
.ah-icon{font-size:36px;transition:transform 0.5s ease;}
.about-highlight:hover .ah-icon{transform:scale(1.2) rotate(10deg);}
.ah-text .t1{font-size:20px;font-weight:500;margin-bottom:4px;}
.ah-text .t2{font-size:14px;opacity:.9;line-height:1.4;}

/* ===== WHY CHOOSE ===== */
.why-section{background:linear-gradient(180deg,#f8faff 0%,white 100%);padding-bottom: 40px;}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:25px;}
.why-card{background:white;border-radius:24px;padding:32px 28px;box-shadow:0 4px 30px rgba(0,0,0,0.06);border:1px solid #f0f0f0;transition:transform .35s ease,box-shadow .35s ease,border-color .35s ease;position:relative;overflow:hidden;}
.why-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--red);transition:height .35s ease,box-shadow .35s ease;}
.why-card::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(30,45,125,.06),rgba(227,30,36,.04));opacity:0;transition:opacity .35s ease;pointer-events:none;}
.why-card.blue-top::before{background:var(--blue);}
.why-card.yellow-top::before{background:var(--yellow);}
.why-card:hover{transform:translateY(-6px);box-shadow:0 18px 50px rgba(15,31,107,0.12);border-color:rgba(30,45,125,.14);}
.why-card:hover::before{height:6px;box-shadow:0 8px 22px rgba(30,45,125,.12);}
.why-card:hover::after{opacity:1;}
.why-icon{width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;padding:14px;transition:transform .35s ease,box-shadow .35s ease;}
.mask-icon{
  width:100%;
  height:100%;
  background-color:currentColor;
  -webkit-mask-size:contain;
  mask-size:contain;
  -webkit-mask-repeat:no-repeat;
  mask-repeat:no-repeat;
  -webkit-mask-position:center;
  mask-position:center;
  display:block;
}
.why-icon.red{background:#fff0f0;color:var(--red);}
.why-icon.blue{background:#f0f4ff;color:var(--blue);}
.why-icon.yellow{background:#fffbea;color:#c8970a;}
.why-icon.green{background:#f0fff4;color:#22c55e;}
.why-card:hover .why-icon{transform:translateY(-3px) scale(1.04);box-shadow:0 10px 22px rgba(0,0,0,.08);}
.why-card h3{font-size:18px;font-weight:500;margin-bottom:10px;color:var(--dark);}
.why-card p{font-size:14px;color:var(--gray);line-height:1.7;}

/* ===== PROGRAMS ===== */
.programs-section{background:var(--blue);padding-bottom: 40px;}
.programs-section .section-title{color:white;}
.programs-section .section-tag{background:rgba(255,215,0,0.2);color:var(--yellow);}
.programs-section .section-desc{color:rgba(255,255,255,.75);}
.programs-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px;margin-top:25px;}
.prog-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:24px;padding:28px 20px;text-align:center;transition:.3s;cursor:pointer;}
.prog-card:hover{background:rgba(255,255,255,.18);transform:translateY(-6px);}
.prog-card .prog-icon{font-size:44px;margin-bottom:16px;display:block;}
.prog-card h3{color:white;font-size:17px;font-weight:500;margin-bottom:8px;}
.prog-card p{color:rgba(255,255,255,.7);font-size:13px;line-height:1.6;}
.prog-card .prog-age{display:inline-block;background:var(--yellow);color:var(--blue);padding:4px 14px;border-radius:25px;font-size:12px;font-weight:500;margin-top:12px;}
.prog-feature{font-size:12px;color:rgba(255,255,255,0.8);margin-top:10px;display:flex;align-items:center;justify-content:center;gap:6px;}
.prog-feature i{color:var(--yellow);font-size:14px;}

/* ===== LIFE SKILLS ===== */
.lifeskills-section{background:white;}
.lifeskills-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;margin-top:25px;margin-bottom: 50px;}
.skill-bubbles{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.skill-bubble{background:linear-gradient(135deg,var(--blue),var(--light-blue));color:white;border-radius:20px;padding:24px 16px;text-align:center;transition:.3s;}
.skill-bubble:hover{transform:scale(1.05);}
.skill-bubble:nth-child(even){background:linear-gradient(135deg,var(--red),#f04040);}
.skill-bubble:nth-child(3n){background:linear-gradient(135deg,#c8970a,#e6b010);}
.skill-bubble i{font-size:32px;margin-bottom:10px;display:block;}
.skill-bubble span{font-size:13px;font-weight:600;}
.lifeskills-content{display:flex;flex-direction:column;gap:28px;margin-top:28px;}
.skill-point{display:flex;gap:16px;align-items:flex-start;}
.skill-point-icon{width:50px;height:50px;min-width:50px;border-radius:14px;background:linear-gradient(135deg,var(--blue),var(--light-blue));color:white;display:flex;align-items:center;justify-content:center;font-size:22px;}
.skill-point-text h4{font-size:16px;font-weight:500;margin-bottom:4px;}
.skill-point-text p{font-size:14px;color:var(--gray);line-height:1.6;}

/* ===== FACILITIES ===== */
.facilities-section{background:#f8faff;padding-bottom: 40px;}
.fac-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:25px;}
.fac-card{background:var(--red);border-radius:24px;padding:16px;transition:.4s cubic-bezier(0.4,0,0.2,1);display:flex;flex-direction:column;gap:12px;box-shadow:0 10px 30px rgba(0,0,0,.15);height:100%;position:relative;overflow:hidden;z-index:1;}
.fac-card::before{content:'';position:absolute;bottom:0;left:0;width:100%;height:0;background:var(--blue);transition:height 0.6s cubic-bezier(0.4,0,0.2,1);z-index:-1;}
.fac-card:hover::before{height:100%;}
.fac-card:hover{transform:translateY(-10px);box-shadow:0 25px 50px rgba(15,31,107,0.3);}
.fac-img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:16px;transition: transform 0.6s ease;position:relative;z-index:1;}
.fac-card:hover .fac-img{transform:scale(1.05);}
.fac-overlay{display:none;}
.fac-label{padding:4px 8px;text-align:left;position:relative;z-index:1;}
.fac-label h3{font-size:22px;font-weight:500;color:var(--white);margin-bottom:4px;}
.fac-label p{font-size:18px;color:rgba(255,255,255,0.8);line-height:1.4;}

/* ===== ADMISSIONS PROCESS ===== */
.admissions-section{background:white;}
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:25px;position:relative;}
.steps-grid::before{content:'';position:absolute;top:80px !important;left:10%;right:10%;height:2px;background:linear-gradient(to right,var(--blue),var(--red));z-index:0;}
.step-card{text-align:center;position:relative;z-index:1;}
.step-num{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--light-blue));color:white;font-size:28px;font-weight:500;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;border:4px solid white;box-shadow:0 0 0 4px var(--blue);position:relative;overflow:hidden;z-index:1;transition:all 0.4s cubic-bezier(0.4,0,0.2,1);cursor:pointer;}
.step-num::before{content:'';position:absolute;top:50%;left:50%;width:0;height:0;background:var(--red);border-radius:50%;transform:translate(-50%,-50%);z-index:-1;transition:width 0.6s cubic-bezier(0.4,0,0.2,1),height 0.6s cubic-bezier(0.4,0,0.2,1);}
.step-num:hover::before{width:200%;height:200%;}
.step-num:hover{box-shadow:0 0 0 4px var(--red);transform:scale(1.1);text-shadow:0 2px 4px rgba(0,0,0,0.2);}
.step-card h3{font-size:16px;font-weight:500;margin-bottom:8px;}
.step-card p{font-size:13px;color:var(--gray);line-height:1.6;text-align:center;}

/* ===== LEAD FORM ===== */
.lead-section{background:linear-gradient(135deg,var(--blue) 0%,#0f1f6b 100%);position:relative;overflow:hidden;padding: 40px;}
.lead-section::before{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;border-radius:50%;background:rgba(255,255,255,.04);}
.lead-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.lead-content h2{font-size:clamp(28px,4vw,40px);font-weight:500;color:white;margin-bottom:16px;}
.lead-content h2 span{color:var(--yellow);}
.lead-content p{color:rgba(255,255,255,.8);font-size:16px;line-height:1.8;margin-bottom:30px;}
.lead-perks{list-style:none;display:flex;flex-direction:column;gap:12px;}
.lead-perks li{display:flex;align-items:center;gap:12px;color:white;font-size:15px;}
.lead-perks li i{color:var(--yellow);font-size:18px;}
.lead-form{background:white;border-radius:28px;padding:40px 36px;box-shadow:0 30px 80px rgba(0,0,0,.3);}
.lead-form h3{font-size:22px;font-weight:500;color:var(--blue);margin-bottom:8px;}
.lead-form .form-sub{font-size:13px;color:var(--gray);margin-bottom:24px;}
.form-group{margin-bottom:18px;}
.form-group label{display:block;font-size:13px;font-weight:600;color:var(--dark);margin-bottom:6px;}
.form-group input,.form-group textarea{width:100%;border:2px solid #e5e7eb;border-radius:14px;padding:12px 16px;font-size:15px;font-family:'Poppins',sans-serif;transition:all 0.3s ease;outline:none;background-color:white;color:var(--dark);}
.form-group input:focus,.form-group textarea:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(15,31,107,0.05);background-color:#fcfdff;}
.form-group input.invalid,.form-group textarea.invalid,.custom-select.invalid .select-trigger{border-color:#ef4444;background:#fff7f7;}
.form-error{display:block;margin-top:6px;color:#dc2626;font-size:12px;font-weight:500;line-height:1.4;}

/* Custom Select (Truly Custom) */
.custom-select{position:relative;width:100%;}
.select-trigger{width:100%;border:2px solid #e5e7eb;border-radius:14px;padding:12px 16px;font-size:15px;background:white;cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:.3s;user-select:none;}
.select-trigger::after{content:'';width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid var(--blue);transition:.3s;}
.custom-select.open .select-trigger{border-color:var(--blue);box-shadow:0 0 0 4px rgba(15,31,107,0.05);}
.custom-select.open .select-trigger::after{transform:rotate(180deg);}
.select-options{position:absolute;top:calc(100% + 8px);left:0;right:0;background:white;border-radius:16px;box-shadow:0 10px 30px rgba(0,0,0,0.1);border:1px solid #f0f0f0;overflow:hidden;opacity:0;visibility:hidden;transform:translateY(10px);transition:.3s;z-index:1000;}
.custom-select.open .select-options{opacity:1;visibility:visible;transform:translateY(0);}
.option{padding:12px 16px;font-size:14px;cursor:pointer;transition:.2s;user-select:none;}
.option:hover{background:#f0f4ff;color:var(--blue);}
.option.selected{background:var(--blue);color:white;}

/* Custom Date Picker (Flatpickr override) */
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.btn-submit{width:100%;background:linear-gradient(135deg,var(--red),#c0151a);color:white;border:none;padding:16px;border-radius:50px;font-size:17px;font-weight:500;cursor:pointer;transition:.3s;display:flex;align-items:center;justify-content:center;gap:10px;}
.btn-submit:hover{transform:translateY(-2px);box-shadow:0 15px 40px rgba(227,30,36,.4);}
.form-note{font-size:12px;color:var(--gray);text-align:center;margin-top:12px;}

/* ===== MOMENTS SECTION ===== */
.moments-section{background:white;padding-bottom: 40px;}
.moments-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:25px;}
.moment-card{position:relative;border-radius:24px;overflow:hidden;aspect-ratio:9/16;cursor:pointer;transition:.4s ease;border:1px solid #f0f0f0;padding:0 !important;}
.moment-card img, .moment-card video{width:100%;height:100%;object-fit:cover;transition:.6s;}
.moment-card:hover{box-shadow:0 20px 50px rgba(0,0,0,0.15);}
.moment-audio{position:absolute;bottom:20px;right:20px;width:44px;height:44px;background:rgba(255,255,255,0.3);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:50%;display:flex;align-items:center;justify-content:center;color:white;border:1px solid rgba(255,255,255,0.4);transition:.3s;z-index:10;}
.moment-audio:hover{background:var(--red);border-color:var(--red);transform:scale(1.1);}
.moment-audio.active{background:var(--red);border-color:var(--red);}

/* ===== TESTIMONIALS ===== */
.testi-section{background:#fafafa;padding-bottom: 40px;}
.testi-carousel-wrapper{position:relative;margin-top:25px;padding:0 20px;}
.testi-track{display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;padding:20px 0 40px;scroll-behavior:smooth;}
.testi-track::-webkit-scrollbar{display:none;}
.testi-card{min-width:calc(33.333% - 16px);background:white;border-radius:24px;padding:32px;box-shadow:0 4px 30px rgba(0,0,0,.06);border:1px solid #f0f0f0;transition:.3s;scroll-snap-align:start;display:flex;flex-direction:column;justify-content:space-between;height:auto;}
.testi-card:hover{transform:translateY(-8px);box-shadow:0 20px 60px rgba(0,0,0,.1);}
.testi-controls{display:flex;justify-content:center;gap:20px;margin-top:10px;}
.testi-ctrl{width:50px;height:50px;border-radius:50%;border:none;background:white;color:var(--blue);box-shadow:0 4px 15px rgba(0,0,0,.1);cursor:pointer;transition:.3s;display:flex;align-items:center;justify-content:center;font-size:18px;}
.testi-ctrl:hover:not(:disabled){background:var(--blue);color:white;transform:scale(1.1);}
.testi-ctrl:disabled{opacity:0.3;cursor:not-allowed;box-shadow:none;}
@media (max-width:1024px){.testi-card{min-width:calc(50% - 12px);}}
@media (max-width:640px){.testi-card{min-width:100%;}}
.stars{color:var(--yellow);font-size:18px;margin-bottom:14px;}
.testi-text{font-size:15px;color:#374151;line-height:1.75;margin-bottom:20px;font-style:italic;}
.testi-author{display:flex;align-items:center;gap:14px;}
.testi-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--light-blue));display:flex;align-items:center;justify-content:center;color:white;font-size:18px;font-weight:500;}
.testi-name{font-weight:500;font-size:15px;}
.testi-role{font-size:12px;color:var(--gray);}

/* ===== CAMPUS VISIT CTA ===== */
.campus-cta{background:linear-gradient(135deg,var(--red),#c0151a);padding:80px 20px;text-align:center;position:relative;overflow:hidden;}
.campus-cta::before{content:'🏫';position:absolute;font-size:200px;opacity:.05;top:-20px;left:-30px;}
.campus-cta::after{content:'⭐';position:absolute;font-size:150px;opacity:.05;bottom:-20px;right:-30px;}
.campus-cta h2{font-size:clamp(28px,4vw,44px);font-weight:500;color:white;margin-bottom:16px;}
.campus-cta p{font-size:18px;color:rgba(255,255,255,.9);margin-bottom:36px;max-width:600px;margin-left:auto;margin-right:auto;}
.campus-cta-btns{display:flex;justify-content:center;gap:20px;flex-wrap:wrap;}
.btn-white{background:white;color:var(--red);padding:16px 36px;border-radius:50px;font-weight:500;font-size:16px;text-decoration:none;display:inline-flex;align-items:center;gap:10px;transition:.3s;}
.btn-white:hover{transform:translateY(-3px);box-shadow:0 15px 40px rgba(0,0,0,.2);}
.btn-whatsapp{background:#25D366;color:white;padding:16px 36px;border-radius:50px;font-weight:500;font-size:16px;text-decoration:none;display:inline-flex;align-items:center;gap:10px;transition:.3s;}
.btn-whatsapp:hover{transform:translateY(-3px);box-shadow:0 15px 40px rgba(37,211,102,.4);}

/* ===== GALLERY ===== */
.gallery-section{background:white;padding-bottom: 40px;}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:220px;gap:16px;margin-top:25px;}
.gallery-item{border:0;border-radius:16px;overflow:hidden;cursor:pointer;transition:transform .35s ease,box-shadow .35s ease;position:relative;background:#eef2ff;padding:0;font:inherit;color:white;}
.gallery-item:hover{transform:translateY(-4px);box-shadow:0 18px 42px rgba(15,31,107,.16);}
.gallery-item.span2{grid-column:span 2;grid-row:span 2;}
.gallery-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease;}
.gallery-item:hover img{transform:scale(1.06);}
.gallery-item::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 45%,rgba(0,0,0,.45));opacity:.75;transition:opacity .35s ease;}
.gallery-item:hover::after{opacity:.95;}
.gallery-caption{position:absolute;left:18px;right:18px;bottom:16px;z-index:1;font-size:14px;font-weight:500;text-align:left;text-shadow:0 2px 14px rgba(0,0,0,.35);}
.gal-plus{position:absolute;inset:0;z-index:2;background:rgba(15,31,107,.68);backdrop-filter:blur(2px);display:flex;flex-direction:column;align-items:center;justify-content:center;color:white;text-align:center;font-size:18px;font-weight:500;gap:6px;transition:background .3s ease;}
.gal-plus strong{font-size:34px;color:var(--yellow);line-height:1;}
.gallery-item:hover .gal-plus{background:rgba(227,30,36,.72);}
.gallery-lightbox{position:fixed;inset:0;background:rgba(7,13,32,.9);backdrop-filter:blur(10px);z-index:10001;display:flex;align-items:center;justify-content:center;padding:30px;opacity:0;visibility:hidden;transition:.3s ease;}
.gallery-lightbox.active{opacity:1;visibility:visible;}
.gallery-lightbox-frame{width:min(100%,980px);max-height:88vh;margin:0;display:flex;flex-direction:column;align-items:center;gap:14px;}
.gallery-lightbox-frame img{max-width:100%;max-height:78vh;object-fit:contain;border-radius:18px;box-shadow:0 25px 90px rgba(0,0,0,.45);}
.gallery-lightbox-frame figcaption{color:white;font-size:14px;opacity:.82;}
.gallery-lightbox-close,.gallery-lightbox-nav{position:absolute;border:0;border-radius:50%;background:white;color:var(--blue);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.25s ease;box-shadow:0 10px 30px rgba(0,0,0,.25);}
.gallery-lightbox-close{top:24px;right:24px;width:44px;height:44px;font-size:18px;}
.gallery-lightbox-nav{top:50%;width:52px;height:52px;font-size:20px;transform:translateY(-50%);}
.gallery-lightbox-nav.prev{left:26px;}
.gallery-lightbox-nav.next{right:26px;}
.gallery-lightbox-close:hover,.gallery-lightbox-nav:hover{background:var(--yellow);transform:scale(1.06);}
.gallery-lightbox-nav:hover{transform:translateY(-50%) scale(1.06);}

/* ===== CONTACT / MAP ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:25px;align-items:stretch;}
.contact-info{display:grid;grid-template-columns:1fr;gap:16px;height:100%;}
.contact-card{background:white;border-radius:24px;padding:20px 24px;display:flex;gap:20px;align-items:center;border:1px solid #edf2f7;transition:.3s;box-shadow:0 4px 15px rgba(0,0,0,.03);}
.contact-card:hover{transform:translateX(8px);border-color:var(--blue);box-shadow:0 12px 30px rgba(0,0,0,.08);}
.contact-card-icon{width:56px;height:56px;min-width:56px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:24px;transition:.3s;}
.contact-card:hover .contact-card-icon{transform:scale(1.1);}
.contact-card-icon.red{background:#fff0f0;color:var(--red);}
.contact-card-icon.blue{background:#f0f4ff;color:var(--blue);}
.contact-card-icon.yellow{background:#fffbea;color:#c8970a;}
.contact-card-icon.green{background:#f0fff4;color:#22c55e;}
.contact-card-text h4{font-size:16px;font-weight:400;margin-bottom:4px;color:var(--blue);}
.contact-card-text p,.contact-card-text a{font-size:14px;color:var(--gray);text-decoration:none;line-height:1.6;}
.contact-card-text a:hover{color:var(--red);text-decoration:underline;}
.map-container{height:100%;display:flex;flex-direction:column;}
.map-wrap{border-radius:28px;overflow:hidden;flex-grow:1;min-height:400px;box-shadow:0 10px 40px rgba(0,0,0,.1);border:1px solid #eee;}
.map-wrap iframe{width:100%;height:100%;border:none;filter:grayscale(0.2) contrast(1.1);}

/* ===== FOOTER ===== */
footer{background:var(--dark);color:white;padding:60px 0 0;}
.footer-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.1);}
.footer-brand .logo-wrap{padding:0;margin-bottom:16px;}
.footer-brand .logo-text .school-name{color:white;}
.footer-brand p{font-size:14px;color:rgba(255,255,255,.6);line-height:1.8;margin-bottom:20px;}
.social-links{display:flex;gap:12px;}
.social-link{width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:white;text-decoration:none;transition:.2s;}
.social-link:hover{background:var(--blue);}
.footer-col h4{font-size:15px;font-weight:500;margin-bottom:20px;color:var(--yellow);}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:10px;}
.footer-links a{color:rgba(255,255,255,.6);text-decoration:none;font-size:14px;transition:.2s;}
.footer-links a:hover{color:white;}
.footer-bottom{max-width:1200px;margin:0 auto;padding:20px 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;}
.footer-bottom p{font-size:13px;color:rgba(255,255,255,.5);}
.footer-bottom a{color:var(--yellow);text-decoration:none;}

/* ===== FLOATING WHATSAPP ===== */
.whatsapp-float{position:fixed;bottom:30px;right:30px;z-index:9999;display:flex;flex-direction:column;align-items:flex-end;gap:10px;}
.wa-btn{width:60px;height:60px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;color:white;font-size:28px;box-shadow:0 6px 30px rgba(37,211,102,.5);text-decoration:none;animation:waPulse 2s infinite;}
@keyframes waPulse{0%,100%{box-shadow:0 6px 30px rgba(37,211,102,.5);}50%{box-shadow:0 6px 50px rgba(37,211,102,.8);}}
.wa-tooltip{background:var(--dark);color:white;padding:8px 16px;border-radius:25px;font-size:13px;font-weight:600;white-space:nowrap;opacity:0;transform:translateY(10px);transition:.3s;pointer-events:none;}
.whatsapp-float:hover .wa-tooltip{opacity:1;transform:translateY(0);}

/* ===== ENQUIRY MODAL ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(15,31,107,0.85);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:10000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all 0.4s ease;padding:20px;}
.modal-overlay.active{opacity:1;visibility:visible;}
.modal-content{background:white;width:100%;max-width:500px;border-radius:24px;position:relative;transform:translateY(40px);transition:all 0.5s cubic-bezier(0.4,0,0.2,1);max-height:90vh;overflow-y:auto;box-shadow:0 30px 100px rgba(0,0,0,0.4);}
.modal-overlay.active .modal-content{transform:translateY(0);}
.modal-close{position:absolute;top:15px;right:15px;width:36px;height:36px;border-radius:50%;border:none;background:#f0f4ff;color:var(--blue);font-size:18px;cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center;transition:.3s;}
.modal-close:hover{background:var(--red);color:white;transform:rotate(90deg);}

/* Custom Date Picker (Flatpickr override) */
.flatpickr-calendar{border-radius:24px !important;box-shadow:0 15px 50px rgba(15,31,107,0.15) !important;border:none !important;padding:12px !important;font-family:'Poppins',sans-serif !important;}
.flatpickr-day.selected,.flatpickr-day.selected:hover{background:var(--red) !important;border-color:var(--red) !important;color:white !important;}
.flatpickr-day:hover{background:#f0f4ff !important;border-color:#f0f4ff !important;}
.flatpickr-months .flatpickr-month{color:var(--blue) !important;fill:var(--blue) !important;}
.flatpickr-current-month .flatpickr-monthDropdown-months{font-weight:500 !important;background:white !important;}
.flatpickr-weekday{color:var(--gray) !important;font-weight:600 !important;}
.flatpickr-calendar.arrowTop:after{border-bottom-color:white !important;}

/* ===== SCROLL TO TOP ===== */
.scroll-top{position:fixed;bottom:30px;left:30px;z-index:9999;width:48px;height:48px;background:var(--blue);color:white;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;cursor:pointer;box-shadow:0 4px 20px rgba(0,0,0,.2);opacity:0;transition:.3s;text-decoration:none;}
.scroll-top.show{opacity:1;}

/* ===== ANIMATIONS ===== */
.fade-up{opacity:0;transform:translateY(30px);transition:.6s ease;padding: 40px;}
.fade-up.visible{opacity:1;transform:translateY(0);}
.mobile-carousel-dots{display:none;}
.mobile-carousel-dot{width:9px;height:9px;border:0;border-radius:999px;background:#d6dbe8;padding:0;cursor:pointer;transition:.25s ease;}
.mobile-carousel-dot.active{width:24px;background:var(--red);}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
.hero-inner{grid-template-columns:1fr;text-align:center;}
.hero-ctas{justify-content:center;}
.hero-stats{justify-content:center;}
.hero-visual{display:none;}
.stats-grid{grid-template-columns:repeat(2,1fr);}
.about-grid{grid-template-columns:1fr;}
.why-grid{grid-template-columns:repeat(2,1fr);}
.programs-grid{grid-template-columns:repeat(2,1fr);}
.lifeskills-grid{grid-template-columns:1fr;}
.fac-grid{grid-template-columns:repeat(2,1fr);}
.fac-card.wide{grid-column:span 2;}
.steps-grid{grid-template-columns:repeat(2,1fr);}
.steps-grid::before{display:none;}
.lead-inner{grid-template-columns:1fr;}
.testi-grid{grid-template-columns:repeat(2,1fr);}
.contact-grid{grid-template-columns:1fr;}
.footer-grid{grid-template-columns:1fr 1fr;}
.gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:190px;}
.gallery-item.span2{grid-column:span 2;}
}

@media(min-width:769px) and (max-width:1180px) and (min-height:769px) and (max-height:1180px){
.topbar-inner,
.nav-inner,
.hero-inner,
.section-inner,
.stats-grid,
.testi-carousel-wrapper,
.footer-grid,
.footer-bottom{
  max-width:100%;
  padding-left:28px;
  padding-right:28px;
}
.topbar{font-size:12px;}
.logo-img{height:54px;}
.nav-links{gap:0;}
.nav-links a{font-size:13px;padding:8px 9px;}
.nav-cta{padding:10px 16px!important;}
.urgency-bar.marquee{top:76px;}
}

@media(min-width:769px) and (max-width:1024px) and (min-height:769px) and (max-height:1180px) and (orientation:portrait){
.nav-links{display:none;}
.hamburger{display:block;}
.nav-inner{min-height:74px;}
.mobile-menu{position:absolute;left:0;right:0;z-index:1001;}
.urgency-bar.marquee{top:74px;}
.hero{min-height:auto;}
.hero-inner{
  padding-top:78px;
  padding-bottom:96px;
}
.hero h1{
  font-size:clamp(38px,6vw,52px);
  max-width:760px;
  margin-left:auto;
  margin-right:auto;
}
.hero-sub{
  max-width:680px;
  margin-left:auto;
  margin-right:auto;
}
.hero-ctas{justify-content:center;}
.hero-stats{justify-content:center;gap:34px;}
}

@media(min-width:1025px) and (max-width:1180px) and (min-height:769px) and (max-height:1180px) and (orientation:landscape){
.hero{min-height:auto;}
.hero-inner{
  grid-template-columns:minmax(0,1fr) minmax(420px,.95fr);
  gap:36px;
  padding-top:46px;
  padding-bottom:46px;
}
.hero h1{font-size:clamp(44px,5vw,56px);}
.hero-sub{font-size:17px;max-width:560px;}
.hero-ctas{margin-bottom:32px;}
.hero-stats{gap:22px;}
.hero-img-wrap.slider{max-width:500px;margin-left:auto;}
.hero-float-card.card1{left:-8px;bottom:22px;}
.hero-float-card.card2{right:-8px;top:24px;}
}

@media(max-width:768px){
.topbar{font-size:11px;padding:6px 0;}
.topbar-inner{flex-direction:column;gap:4px;text-align:center;padding-left:10px !important;padding-right:10px !important;}
.topbar-address{line-height:1.3;}
.topbar-contact{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:center;align-items:center;column-gap:8px;row-gap:2px;}
.topbar-divider{display:inline;opacity:0.5;}
.topbar a{margin-left:0;}
.nav-links{display:none;}
.hamburger{display:block;}
.stats-grid{grid-template-columns:repeat(2,1fr);}
.why-grid{grid-template-columns:1fr;}
.programs-grid{grid-template-columns:1fr 1fr;}
.skill-bubbles{grid-template-columns:repeat(2,1fr);}
.fac-grid{grid-template-columns:1fr;}
.fac-card.wide{grid-column:span 1;}
.steps-grid{grid-template-columns:1fr;}
.testi-grid{grid-template-columns:1fr;}
.campus-cta-btns{flex-direction:column;align-items:center;}
.footer-grid{grid-template-columns:1fr;}
.gallery-grid{grid-template-columns:1fr;grid-auto-rows:220px;}
.gallery-item.span2{grid-column:span 1;grid-row:span 1;}
.gallery-lightbox{padding:18px;}
.gallery-lightbox-nav{width:42px;height:42px;font-size:16px;}
.gallery-lightbox-nav.prev{left:12px;}
.gallery-lightbox-nav.next{right:12px;}
.gallery-lightbox-close{top:14px;right:14px;}
.form-row{grid-template-columns:1fr;}
section{padding:0;}
.section-inner, .nav-inner, .topbar-inner, .hero-inner, .footer-grid, .lead-inner, .testi-carousel-wrapper {
  padding-left: 20px !important;
  padding-right: 20px !important;
}
.lead-section{
  padding-left:0;
  padding-right:0;
}
.lead-section .lead-content.fade-up,
.contact-section .fade-up{
  padding-left:0;
  padding-right:0;
}
.why-grid,
.programs-grid,
.skill-bubbles,
.fac-grid,
.steps-grid,
.moments-grid{
  display:flex;
  grid-template-columns:none;
  gap:18px;
  overflow-x:auto;
  overflow-y:hidden;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  scrollbar-width:none;
  -ms-overflow-style:none;
  -webkit-overflow-scrolling:touch;
}
.why-grid::-webkit-scrollbar,
.programs-grid::-webkit-scrollbar,
.skill-bubbles::-webkit-scrollbar,
.fac-grid::-webkit-scrollbar,
.steps-grid::-webkit-scrollbar,
.moments-grid::-webkit-scrollbar{
  display:none;
}
.why-grid > *,
.programs-grid > *,
.skill-bubbles > *,
.fac-grid > *,
.steps-grid > *,
.moments-grid > *{
  flex:0 0 100%;
  max-width:100%;
  scroll-snap-align:start;
  scroll-snap-stop:always;
}
.skill-bubbles > .skill-bubble{
  aspect-ratio:1/1;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
}
.mobile-carousel-dots{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  margin:14px 0 4px;
}
}

@media(min-width: 1441px) {
  .section-inner, 
  .topbar-inner, 
  .nav-inner, 
  .hero-inner, 
  .urgency-bar-inner, 
  .stats-grid, 
  .footer-grid, 
  .footer-bottom { 
    max-width: 1500px; 
  }
}
