/* ============================================================
   MONTESSORI'S JAGATHI INTERNATIONAL SCHOOL — STYLESHEET
   ============================================================ */

/* ── Variables ── */
:root {
  --orange:       #F97316;
  --orange-dark:  #EA580C;
  --orange-grad:  linear-gradient(135deg, #F97316 0%, #EF4444 100%);
  --orange-light: #FFF7ED;
  --navy:         #0F172A;
  --navy-2:       #1E293B;
  --gold:         #F59E0B;
  --green:        #10B981;
  --white:        #FFFFFF;
  --off-white:    #FFFBF7;
  --gray-50:      #F8FAFC;
  --gray-100:     #F1F5F9;
  --gray-200:     #E2E8F0;
  --gray-400:     #94A3B8;
  --gray-500:     #64748B;
  --gray-700:     #334155;
  --serif:        'Playfair Display', Georgia, serif;
  --sans:         'Poppins', system-ui, sans-serif;
  --sh-sm:  0 1px 4px rgba(0,0,0,.07), 0 1px 2px rgba(0,0,0,.05);
  --sh-md:  0 4px 20px rgba(0,0,0,.10), 0 2px 6px rgba(0,0,0,.06);
  --sh-lg:  0 16px 50px rgba(0,0,0,.15), 0 6px 12px rgba(0,0,0,.07);
  --sh-xl:  0 30px 80px rgba(0,0,0,.22);
  --ease:   cubic-bezier(.4,0,.2,1);
  --r-sm:   8px;
  --r-md:   16px;
  --r-lg:   24px;
  --nav-h:  76px;
}

/* ── Reset ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px;overflow-x:hidden}
body{font-family:var(--sans);color:var(--gray-700);background:var(--white);line-height:1.7;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:all .3s var(--ease)}
ul{list-style:none}
button{cursor:pointer;border:none;background:none}

/* ── Utilities ── */
.container{max-width:1200px;margin:0 auto;padding:0 24px}
section{padding:100px 0}

h1,h2,h3,h4{font-family:var(--serif);line-height:1.2;color:var(--navy)}
h2 span{color:var(--orange)}

.section-tag{
  display:inline-block;
  background:var(--orange-light);
  color:var(--orange-dark);
  font-size:.72rem;font-weight:600;
  letter-spacing:2px;text-transform:uppercase;
  padding:6px 18px;border-radius:100px;
  margin-bottom:14px;
}
.section-tag.light{background:rgba(255,255,255,.18);color:#fff}

.section-header{text-align:center;max-width:680px;margin:0 auto 64px}
.section-header h2{font-size:clamp(1.9rem,4vw,2.7rem);margin-bottom:14px}
.section-header p{color:var(--gray-500);font-size:1.05rem}

/* ── Buttons ── */
.btn-primary{
  display:inline-flex;align-items:center;gap:9px;
  background:var(--orange-grad);color:#fff;
  padding:14px 34px;border-radius:100px;
  font-weight:600;font-size:.95rem;
  box-shadow:0 4px 22px rgba(249,115,22,.4);
  transition:all .3s var(--ease);
}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 8px 32px rgba(249,115,22,.5);color:#fff}

.btn-ghost{
  display:inline-flex;align-items:center;gap:9px;
  background:rgba(255,255,255,.14);
  backdrop-filter:blur(10px);
  color:#fff;padding:14px 34px;border-radius:100px;
  font-weight:600;font-size:.95rem;
  border:2px solid rgba(255,255,255,.35);
  transition:all .3s var(--ease);
}
.btn-ghost:hover{background:rgba(255,255,255,.25);transform:translateY(-3px);color:#fff}

.btn-white{
  display:inline-flex;align-items:center;gap:9px;
  background:#fff;color:var(--orange);
  padding:16px 42px;border-radius:100px;
  font-weight:700;font-size:1rem;
  box-shadow:0 4px 20px rgba(0,0,0,.15);
  transition:all .3s var(--ease);
}
.btn-white:hover{transform:translateY(-3px);box-shadow:0 8px 30px rgba(0,0,0,.22);color:var(--orange)}

.full-width{width:100%;justify-content:center}

/* ── Preloader ── */
#preloader{
  position:fixed;inset:0;
  background:radial-gradient(ellipse at center, #1a2a4a 0%, #0F172A 70%);
  display:flex;align-items:center;justify-content:center;
  z-index:9999;
  transition:opacity .8s ease, visibility .8s ease;
}
#preloader.hidden{opacity:0;visibility:hidden;pointer-events:none}

.loader{
  display:flex;flex-direction:column;align-items:center;gap:20px;
}

/* Logo wrapper with glow + shine */
.loader-logo-wrap{
  position:relative;
  width:130px;height:130px;
  display:flex;align-items:center;justify-content:center;
}

/* Outer glow ring */
.loader-logo-wrap::before{
  content:'';
  position:absolute;inset:-12px;
  border-radius:50%;
  background:conic-gradient(
    from 0deg,
    transparent 0%,
    rgba(249,115,22,.6) 25%,
    rgba(245,158,11,.8) 50%,
    rgba(249,115,22,.6) 75%,
    transparent 100%
  );
  animation:spinGlow 2.5s linear infinite;
}

/* Inner background circle */
.loader-logo-wrap::after{
  content:'';
  position:absolute;inset:-4px;
  border-radius:50%;
  background:#0F172A;
}

.loader-logo{
  position:relative;z-index:2;
  width:120px;height:120px;
  object-fit:contain;
  border-radius:50%;
  animation:logoPulse 2s ease-in-out infinite;
  filter:drop-shadow(0 0 20px rgba(249,115,22,.5));
}

.loader-logo-fallback{
  position:relative;z-index:2;
  width:120px;height:120px;border-radius:50%;
  background:var(--orange-grad);
  display:none;align-items:center;justify-content:center;
  font-size:3rem;color:#fff;
  animation:logoPulse 2s ease-in-out infinite;
  box-shadow:0 0 30px rgba(249,115,22,.5);
}

/* Shine sweep over logo */
.loader-shine{
  position:absolute;inset:0;z-index:3;
  border-radius:50%;overflow:hidden;
  pointer-events:none;
}
.loader-shine::after{
  content:'';
  position:absolute;top:0;left:-100%;
  width:60%;height:100%;
  background:linear-gradient(
    105deg,
    transparent 20%,
    rgba(255,255,255,.35) 50%,
    transparent 80%
  );
  animation:shineSwipe 2.5s ease-in-out infinite;
  border-radius:50%;
}

/* Text below logo */
.loader-name{
  display:flex;flex-direction:column;align-items:center;gap:2px;
  animation:fadeSlideUp .8s ease forwards;
  animation-delay:.3s;
  opacity:0;
}
.loader-montessori{
  font-family:'Cinzel',serif;
  font-size:.72rem;font-weight:400;
  color:rgba(255,255,255,.5);
  letter-spacing:4px;text-transform:uppercase;
}
.loader-jagathi{
  font-family:'Cinzel Decorative',serif;
  font-size:2rem;font-weight:700;
  color:#fff;letter-spacing:2px;
  background:linear-gradient(135deg,#fff 30%,#F59E0B 70%,#fff 100%);
  background-size:200% auto;
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  animation:textShimmer 2.5s linear infinite;
}
.loader-school{
  font-family:'Cinzel',serif;
  font-size:.65rem;font-weight:400;
  color:var(--orange);
  letter-spacing:3px;text-transform:uppercase;
}

/* Animated dots */
.loader-dots{display:flex;gap:8px;margin-top:4px}
.loader-dots span{
  width:6px;height:6px;border-radius:50%;
  background:var(--orange);opacity:.3;
  animation:dotPulse 1.2s ease-in-out infinite;
}
.loader-dots span:nth-child(2){animation-delay:.2s}
.loader-dots span:nth-child(3){animation-delay:.4s}

/* Keyframes */
@keyframes spinGlow{
  from{transform:rotate(0deg)}
  to{transform:rotate(360deg)}
}
@keyframes logoPulse{
  0%,100%{transform:scale(1);filter:drop-shadow(0 0 16px rgba(249,115,22,.4))}
  50%{transform:scale(1.06);filter:drop-shadow(0 0 32px rgba(249,115,22,.8))}
}
@keyframes shineSwipe{
  0%{left:-100%}
  50%,100%{left:140%}
}
@keyframes textShimmer{
  0%{background-position:200% center}
  100%{background-position:-200% center}
}
@keyframes fadeSlideUp{
  from{opacity:0;transform:translateY(12px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes dotPulse{
  0%,100%{opacity:.3;transform:scale(1)}
  50%{opacity:1;transform:scale(1.4)}
}

/* ── Navbar ── */
#navbar{
  position:fixed;top:0;left:0;right:0;
  z-index:1000;height:var(--nav-h);
  padding:0 24px;
  transition:all .35s var(--ease);
}
#navbar.scrolled{
  background:rgba(15,23,42,.97);
  backdrop-filter:blur(20px);
  box-shadow:0 4px 30px rgba(0,0,0,.3);
}
.nav-container{
  max-width:1200px;margin:0 auto;height:100%;
  display:flex;align-items:center;justify-content:space-between;
}
.nav-logo{display:flex;align-items:center;gap:10px}
.nav-logo-img{
  width:52px;height:52px;
  object-fit:contain;border-radius:50%;
  filter:drop-shadow(0 2px 8px rgba(0,0,0,.4));
}
.logo-icon-fallback{
  width:46px;height:46px;
  background:var(--orange-grad);border-radius:50%;
  align-items:center;justify-content:center;
  color:#fff;font-size:1.2rem;
  box-shadow:0 4px 14px rgba(249,115,22,.4);
}
.logo-text{display:flex;flex-direction:column;gap:1px}
.logo-montessori{
  font-family:'Cinzel',serif;
  font-size:.62rem;font-weight:400;
  color:rgba(255,255,255,.65);
  letter-spacing:2.5px;text-transform:uppercase;
  line-height:1;
}
.logo-main{
  font-family:'Cinzel Decorative','Cinzel',serif;
  font-size:1.2rem;font-weight:700;
  color:#fff;line-height:1.1;letter-spacing:1px;
}
.logo-sub{
  font-family:'Cinzel',serif;
  font-size:.58rem;color:var(--orange);
  letter-spacing:2px;text-transform:uppercase;
  line-height:1;
}
.nav-menu{display:flex;align-items:center;gap:28px}
.nav-list{display:flex;align-items:center;gap:4px}
.nav-list li a{
  color:rgba(255,255,255,.8);font-size:.88rem;font-weight:500;
  padding:8px 13px;border-radius:var(--r-sm);
  transition:all .25s var(--ease);
}
.nav-list li a:hover,.nav-list li a.active{color:#fff;background:rgba(255,255,255,.1)}
.nav-cta{
  background:var(--orange-grad);color:#fff !important;
  padding:10px 24px;border-radius:100px;
  font-weight:600;font-size:.88rem;
  box-shadow:0 4px 16px rgba(249,115,22,.4);
}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 6px 22px rgba(249,115,22,.5)}
.hamburger{display:none;flex-direction:column;gap:5px;padding:8px}
.hamburger span{display:block;width:24px;height:2px;background:#fff;border-radius:2px;transition:all .3s var(--ease)}

/* ── Hero ── */
.hero{
  position:relative;min-height:100vh;
  display:flex;align-items:center;
  background:linear-gradient(135deg,var(--navy) 0%,#1E3A5F 100%);
  overflow:hidden;
}
.hero-bg{position:absolute;inset:0}
.hero-bg img{
  width:100%;height:100%;object-fit:cover;
  object-position:22% center;
  animation:heroZoom 24s ease-in-out infinite alternate;
  transform-origin:22% center;
}
@keyframes heroZoom{from{transform:scale(1.02)}to{transform:scale(1.12)}}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(15,23,42,.88) 0%,rgba(15,23,42,.6) 50%,rgba(249,115,22,.15) 100%);
}
.hero-content{
  position:relative;z-index:10;
  padding-top:calc(var(--nav-h) + 60px);
  padding-bottom:80px;
  max-width:820px;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(249,115,22,.2);
  border:1px solid rgba(249,115,22,.4);
  color:var(--orange);
  padding:8px 20px;border-radius:100px;
  font-size:.82rem;font-weight:600;
  margin-bottom:24px;backdrop-filter:blur(10px);
}
.hero-title{
  font-size:clamp(2.4rem,6vw,4.6rem);
  color:#fff;line-height:1.08;margin-bottom:22px;
}
.hero-pre{
  display:block;font-size:.42em;
  font-weight:400;font-style:italic;
  color:var(--orange);letter-spacing:3px;margin-bottom:4px;
}
.hero-title strong{display:block;font-weight:800}
.hero-title em{
  display:block;font-style:italic;
  color:rgba(255,255,255,.75);
  font-size:.55em;font-weight:400;
}
.hero-subtitle{
  font-size:clamp(.95rem,2vw,1.18rem);
  color:rgba(255,255,255,.8);
  max-width:620px;margin-bottom:40px;line-height:1.85;
}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap}
.hero-scroll{
  position:absolute;bottom:36px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;
  color:rgba(255,255,255,.45);font-size:.7rem;letter-spacing:2px;text-transform:uppercase;
  z-index:10;
}
.scroll-line{
  width:1px;height:56px;
  background:linear-gradient(to bottom,rgba(255,255,255,.5),transparent);
  animation:scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse{0%,100%{opacity:.5;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.1)}}

/* ── Stats Strip ── */
.stats-strip{padding:0;background:var(--navy);border-top:4px solid var(--orange)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat-item{
  padding:40px 24px;text-align:center;
  border-right:1px solid rgba(255,255,255,.07);
  transition:all .3s var(--ease);
}
.stat-item:last-child{border-right:none}
.stat-item:hover{background:rgba(255,255,255,.04)}
.stat-icon{font-size:1.5rem;color:var(--orange);margin-bottom:10px}
.stat-number{
  font-family:var(--serif);font-size:2.6rem;font-weight:800;
  color:#fff;line-height:1;margin-bottom:6px;
}
.stat-number::after{content:'+';font-size:1.4rem;color:var(--orange)}
.stat-label{color:var(--gray-400);font-size:.82rem;font-weight:500;letter-spacing:.5px}

/* ── Montessori ── */
.montessori-section{background:var(--off-white)}
.montessori-intro{
  max-width:820px;margin:0 auto 60px;
  text-align:center;font-size:1.08rem;line-height:1.95;color:var(--gray-700);
}
.principles-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.principle-card{
  background:#fff;border-radius:var(--r-lg);padding:36px 26px;
  text-align:center;box-shadow:var(--sh-md);
  border:1px solid var(--gray-200);
  transition:all .35s var(--ease);
}
.principle-card:hover{transform:translateY(-8px);box-shadow:var(--sh-lg)}
.principle-icon{
  width:72px;height:72px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;margin:0 auto 22px;
}
.principle-icon.orange{background:var(--orange-light);color:var(--orange)}
.principle-icon.blue{background:#EFF6FF;color:#3B82F6}
.principle-icon.green{background:#ECFDF5;color:var(--green)}
.principle-icon.gold{background:#FEF3C7;color:var(--gold)}
.principle-card h3{font-size:1.1rem;margin-bottom:10px}
.principle-card p{color:var(--gray-500);font-size:.875rem;line-height:1.8}

/* ── About ── */
.about-section{background:#fff}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-content .section-tag{margin-top:0}
.about-content h2{font-size:clamp(1.8rem,3.5vw,2.6rem);margin:14px 0 18px}
.about-lead{font-size:1.15rem;color:var(--navy);font-weight:500;margin-bottom:16px}
.about-content p{color:var(--gray-500);line-height:1.9;margin-bottom:14px}
.about-features{margin-top:28px;display:flex;flex-direction:column;gap:12px}
.feature-item{
  display:flex;align-items:flex-start;gap:12px;
  padding:14px 18px;background:var(--gray-50);
  border-radius:var(--r-sm);border-left:3px solid var(--orange);
}
.feature-item i{color:var(--green);font-size:1rem;margin-top:3px;flex-shrink:0}
.feature-item span{font-size:.92rem;color:var(--gray-700);font-weight:500}

/* Image stack */
.img-stack{position:relative;padding:20px 20px 60px 0}
.img-main{
  width:100%;height:480px;object-fit:cover;
  border-radius:var(--r-lg);box-shadow:var(--sh-xl);
}
.img-accent{
  position:absolute;bottom:-30px;left:-32px;
  width:190px;height:190px;object-fit:cover;
  border-radius:var(--r-md);
  box-shadow:var(--sh-lg);border:4px solid #fff;
}
.img-badge{
  position:absolute;top:44px;right:-24px;
  background:var(--orange-grad);color:#fff;
  padding:20px 22px;border-radius:var(--r-md);
  text-align:center;box-shadow:var(--sh-lg);
}
.badge-num{font-family:var(--serif);font-size:2rem;font-weight:800;line-height:1}
.badge-txt{font-size:.7rem;font-weight:500;opacity:.9;margin-top:4px;line-height:1.4}

/* ── Paradise ── */
.paradise-section{position:relative;padding:120px 0;overflow:hidden}
.paradise-bg{
  position:absolute;inset:0;
  background:linear-gradient(135deg,#0F172A 0%,#1a2f50 50%,#0F172A 100%);
}
.paradise-bg::after{
  content:'';position:absolute;inset:0;
  background:url('../images/hero-school.jpg') center/cover no-repeat;
  opacity:.08;
}
.paradise-content{position:relative;z-index:10;color:#fff}
.paradise-content h2{color:#fff;font-size:clamp(1.9rem,4vw,3rem);margin:14px 0 20px;max-width:680px}
.paradise-content h2 span{color:var(--orange)}
.paradise-content>p{color:rgba(255,255,255,.75);max-width:720px;font-size:1.05rem;line-height:1.9;margin-bottom:14px}
.paradise-features{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:56px}
.paradise-feature{
  background:rgba(255,255,255,.07);
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r-lg);padding:30px 22px;
  transition:all .3s var(--ease);
}
.paradise-feature:hover{background:rgba(255,255,255,.12);transform:translateY(-5px)}
.paradise-feature>i{font-size:2rem;color:var(--orange);display:block;margin-bottom:14px}
.paradise-feature h4{color:#fff;font-family:var(--sans);font-size:.95rem;font-weight:600;margin-bottom:10px}
.paradise-feature p{color:rgba(255,255,255,.6);font-size:.85rem;line-height:1.7}

/* ── Activities ── */
.activities-section{background:var(--gray-50)}
.activities-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.activity-card{
  background:#fff;border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--sh-sm);border:1px solid var(--gray-200);
  transition:all .35s var(--ease);
}
.activity-card:hover{transform:translateY(-8px);box-shadow:var(--sh-lg)}
.activity-img{position:relative;height:200px;overflow:hidden}
.activity-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.activity-card:hover .activity-img img{transform:scale(1.1)}
.activity-img.placeholder{display:flex;align-items:center;justify-content:center}
.activity-img.camping{background:linear-gradient(135deg,#065F46,#10B981)}
.activity-img.karate{background:linear-gradient(135deg,#1E3A5F,#3B82F6)}
.activity-img.dance{background:linear-gradient(135deg,#6D28D9,#EC4899)}
.activity-img.horse{background:linear-gradient(135deg,#92400E,#D97706)}
.activity-img.social{background:linear-gradient(135deg,#1E293B,#475569)}
.activity-img.arts{background:linear-gradient(135deg,#9D174D,#F43F5E)}
.activity-overlay{
  position:absolute;inset:0;
  background:rgba(0,0,0,.28);
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:all .3s var(--ease);
}
.activity-overlay.show{opacity:1;background:transparent}
.activity-card:hover .activity-overlay{opacity:1}
.activity-overlay i{font-size:2.4rem;color:#fff;filter:drop-shadow(0 3px 8px rgba(0,0,0,.3))}
.activity-body{padding:22px 20px}
.activity-body h3{font-size:1.05rem;margin-bottom:8px}
.activity-body p{color:var(--gray-500);font-size:.85rem;line-height:1.75}

/* ── Gallery ── */
.gallery-section{background:#fff}
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:auto auto;
  gap:14px;
}
.gallery-item{
  position:relative;border-radius:var(--r-md);
  overflow:hidden;cursor:pointer;aspect-ratio:4/3;
}
.gallery-item.wide{grid-column:1/3;aspect-ratio:16/9}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .55s ease}
.gallery-item:hover img{transform:scale(1.07)}
.gallery-overlay{
  position:absolute;inset:0;
  background:rgba(15,23,42,.5);
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:10px;
  color:#fff;opacity:0;transition:all .3s var(--ease);
}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-overlay i{font-size:1.4rem}
.gallery-overlay span{font-weight:600;font-size:.85rem;letter-spacing:1px}
.gallery-more{text-align:center;margin-top:28px;color:var(--gray-400);font-size:.9rem}

/* ── Lightbox ── */
.lightbox{display:none;position:fixed;inset:0;z-index:9000}
.lightbox.active{display:flex;align-items:center;justify-content:center}
.lightbox-overlay{position:absolute;inset:0;background:rgba(0,0,0,.93)}
.lightbox-inner{
  position:relative;z-index:1;
  display:flex;align-items:center;gap:14px;
  max-width:92vw;max-height:92vh;
}
#lbImg{
  max-width:80vw;max-height:82vh;
  object-fit:contain;border-radius:var(--r-md);
  box-shadow:0 20px 60px rgba(0,0,0,.5);
}
.lb-caption{
  position:absolute;bottom:-36px;left:50%;transform:translateX(-50%);
  color:rgba(255,255,255,.7);font-size:.85rem;white-space:nowrap;
}
.lb-close,.lb-prev,.lb-next{
  width:48px;height:48px;border-radius:50%;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  color:#fff;font-size:1rem;
  display:flex;align-items:center;justify-content:center;
  transition:all .25s var(--ease);flex-shrink:0;
}
.lb-close{position:absolute;top:-60px;right:0}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{background:var(--orange);border-color:var(--orange)}

/* ── Video Section ── */
.video-section{background:var(--gray-50)}
.video-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.video-placeholder{
  background:var(--navy);border-radius:var(--r-lg);
  height:300px;display:flex;align-items:center;justify-content:center;
  border:2px dashed rgba(255,255,255,.1);
  transition:all .3s var(--ease);
}
.video-placeholder:hover{border-color:var(--orange);background:var(--navy-2)}
.vp-inner{text-align:center;color:#fff}
.vp-inner i{font-size:3.2rem;color:var(--orange);display:block;margin-bottom:14px}
.vp-inner p{font-size:1.05rem;font-weight:600;margin-bottom:8px}
.vp-inner span{font-size:.75rem;color:var(--gray-400);letter-spacing:1.5px;text-transform:uppercase}
.video-embed{border-radius:var(--r-lg);overflow:hidden}
.video-embed iframe{display:block;width:100%;height:360px}

/* ── Admissions ── */
.admissions-section{position:relative;padding:120px 0;text-align:center;overflow:hidden}
.admissions-bg{position:absolute;inset:0;background:var(--orange-grad)}
.admissions-bg::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 20% 50%,rgba(255,255,255,.08) 0%,transparent 60%);
}
.admissions-content{position:relative;z-index:10;color:#fff}
.admissions-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.2);padding:8px 22px;
  border-radius:100px;font-size:.8rem;font-weight:600;
  letter-spacing:1.5px;text-transform:uppercase;margin-bottom:22px;
}
.admissions-content h2{color:#fff;font-size:clamp(1.9rem,4vw,3.1rem);margin-bottom:16px}
.admissions-content h2 span{color:rgba(255,255,255,.85);text-decoration:underline;text-underline-offset:6px}
.admissions-content>p{color:rgba(255,255,255,.85);font-size:1.05rem;max-width:580px;margin:0 auto 56px;line-height:1.85}
.steps-row{
  display:flex;align-items:center;justify-content:center;
  flex-wrap:wrap;gap:8px;margin-bottom:48px;
}
.step{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  padding:22px 20px;min-width:140px;
  background:rgba(255,255,255,.15);
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.2);
  border-radius:var(--r-md);
}
.step-num{
  width:48px;height:48px;background:#fff;color:var(--orange);
  font-family:var(--serif);font-size:1.3rem;font-weight:800;
  border-radius:50%;display:flex;align-items:center;justify-content:center;
}
.step h4{color:#fff;font-family:var(--sans);font-size:.9rem;font-weight:600}
.step p{color:rgba(255,255,255,.7);font-size:.75rem;text-align:center}
.step-arrow{color:rgba(255,255,255,.45);font-size:1.2rem;padding:0 2px}

/* ── Contact ── */
.contact-section{background:var(--gray-50)}
.contact-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:36px;margin-bottom:44px}
.contact-info-card{
  background:var(--navy);border-radius:var(--r-lg);padding:40px 36px;
}
.ci-item{display:flex;gap:18px;align-items:flex-start;margin-bottom:30px}
.ci-icon{
  width:46px;height:46px;border-radius:50%;flex-shrink:0;
  background:rgba(249,115,22,.18);
  display:flex;align-items:center;justify-content:center;
  color:var(--orange);font-size:1rem;
}
.ci-item h4{
  color:rgba(255,255,255,.5);font-family:var(--sans);
  font-size:.7rem;font-weight:500;letter-spacing:2px;
  text-transform:uppercase;margin-bottom:5px;
}
.ci-item p,.ci-item a{color:rgba(255,255,255,.82);font-size:.93rem;line-height:1.7}
.ci-item a:hover{color:var(--orange)}
.ci-social{display:flex;gap:10px;margin-top:8px}
.sb{
  width:42px;height:42px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.95rem;color:#fff;transition:all .3s var(--ease);
}
.sb.facebook{background:#1877F2}.sb.instagram{background:linear-gradient(135deg,#833AB4,#FD1D1D,#F77737)}
.sb.youtube{background:#FF0000}.sb.whatsapp{background:#25D366}
.sb:hover{transform:translateY(-4px);box-shadow:0 8px 20px rgba(0,0,0,.3)}

.contact-form{background:#fff;border-radius:var(--r-lg);padding:40px;box-shadow:var(--sh-md)}
.contact-form h3{font-size:1.5rem;margin-bottom:26px;color:var(--navy)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.fg{margin-bottom:16px}
.fg input,.fg select,.fg textarea{
  width:100%;padding:13px 17px;
  border:2px solid var(--gray-200);border-radius:var(--r-sm);
  font-family:var(--sans);font-size:.93rem;color:var(--gray-700);
  background:var(--gray-50);outline:none;
  transition:all .25s var(--ease);
}
.fg input:focus,.fg select:focus,.fg textarea:focus{
  border-color:var(--orange);background:#fff;
  box-shadow:0 0 0 4px rgba(249,115,22,.08);
}
.fg textarea{resize:vertical;min-height:100px}
.form-msg{margin-top:14px;padding:12px 16px;border-radius:var(--r-sm);font-size:.9rem;font-weight:500;text-align:center}
.form-msg.success{background:#ECFDF5;color:#065F46}
.form-msg.error{background:#FEF2F2;color:#991B1B}

.map-wrap{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-md)}

/* ── Footer ── */
.footer{background:var(--navy);color:rgba(255,255,255,.65)}
.footer-top{padding:80px 0 56px;border-bottom:1px solid rgba(255,255,255,.07)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:44px}
.footer-logo-wrap{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.footer-logo-img{
  width:56px;height:56px;object-fit:contain;border-radius:50%;
  filter:drop-shadow(0 2px 8px rgba(0,0,0,.5));flex-shrink:0;
}
.footer-logo-icon{
  width:44px;height:44px;background:var(--orange-grad);border-radius:50%;
  align-items:center;justify-content:center;color:#fff;font-size:1.1rem;flex-shrink:0;
}
.footer-logo-text{
  font-family:'Cinzel Decorative','Cinzel',serif;
  font-size:.95rem;font-weight:700;color:#fff;line-height:1.5;
  letter-spacing:.5px;
}
.footer-brand p{font-size:.85rem;line-height:1.85;margin-bottom:22px}
.footer-social{display:flex;gap:10px}
.footer-social a{
  width:38px;height:38px;background:rgba(255,255,255,.07);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.65);font-size:.88rem;transition:all .3s var(--ease);
}
.footer-social a:hover{background:var(--orange);color:#fff;transform:translateY(-2px)}
.footer-links h4,.footer-acts h4,.footer-contact h4{
  color:#fff;font-family:var(--sans);font-size:.8rem;font-weight:600;
  letter-spacing:2px;text-transform:uppercase;margin-bottom:22px;
}
.footer-links ul li,.footer-acts ul li{margin-bottom:11px;font-size:.85rem}
.footer-links ul li a{color:rgba(255,255,255,.55);transition:all .25s var(--ease)}
.footer-links ul li a:hover{color:var(--orange);padding-left:6px}
.footer-acts ul li{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.55)}
.footer-acts ul li i{color:var(--orange);font-size:.72rem}
.fc-item{display:flex;align-items:flex-start;gap:12px;margin-bottom:18px;font-size:.85rem}
.fc-item i{color:var(--orange);margin-top:3px;flex-shrink:0}
.fc-item p{color:rgba(255,255,255,.6);line-height:1.7}
.fc-item a{color:rgba(255,255,255,.6)}.fc-item a:hover{color:var(--orange)}
.footer-bottom{padding:22px 0}
.footer-bottom .container{display:flex;align-items:center;justify-content:space-between;font-size:.78rem}
.footer-bottom i{color:#EF4444}

/* ── WhatsApp Float ── */
.wa-float{
  position:fixed;bottom:30px;right:30px;
  width:60px;height:60px;background:#25D366;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1.8rem;color:#fff;z-index:900;
  box-shadow:0 6px 28px rgba(37,211,102,.5);
  transition:all .3s var(--ease);
  animation:waPulse 3s ease-in-out infinite;
}
.wa-float:hover{transform:scale(1.12);box-shadow:0 10px 36px rgba(37,211,102,.65);color:#fff}
.wa-tooltip{
  position:absolute;right:68px;
  background:var(--navy);color:#fff;
  padding:7px 14px;border-radius:var(--r-sm);
  font-size:.78rem;font-weight:500;white-space:nowrap;
  opacity:0;pointer-events:none;transition:all .25s var(--ease);
}
.wa-tooltip::after{
  content:'';position:absolute;right:-6px;top:50%;transform:translateY(-50%);
  width:0;height:0;
  border-top:6px solid transparent;border-bottom:6px solid transparent;
  border-left:6px solid var(--navy);
}
.wa-float:hover .wa-tooltip{opacity:1}
@keyframes waPulse{
  0%,100%{box-shadow:0 6px 28px rgba(37,211,102,.5)}
  50%{box-shadow:0 6px 48px rgba(37,211,102,.8),0 0 0 14px rgba(37,211,102,.08)}
}

/* ── Back to Top ── */
.back-top{
  position:fixed;bottom:104px;right:30px;
  width:46px;height:46px;border-radius:50%;
  background:var(--navy-2);color:#fff;font-size:.95rem;
  box-shadow:var(--sh-md);z-index:900;
  opacity:0;visibility:hidden;transition:all .35s var(--ease);
}
.back-top.visible{opacity:1;visibility:visible}
.back-top:hover{background:var(--orange);transform:translateY(-3px)}

/* ── Hero Tagline ── */
.hero-tagline{
  display:flex;flex-wrap:wrap;gap:6px 28px;
  margin-bottom:18px;
}
.hero-tagline span{
  font-family:'Cinzel',serif;
  font-size:clamp(1rem,2.5vw,1.4rem);
  color:#fff;font-weight:600;letter-spacing:1px;
}
.hero-tagline span em{
  color:var(--orange);font-style:normal;
}

/* ── About Badges ── */
.about-badges{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px}
.about-badge{
  display:inline-flex;align-items:center;gap:7px;
  background:var(--orange-light);color:var(--orange-dark);
  padding:7px 16px;border-radius:100px;
  font-size:.78rem;font-weight:600;letter-spacing:.5px;
  border:1px solid rgba(249,115,22,.25);
}
.about-badge.gold{background:#FEF3C7;color:#92400E;border-color:rgba(245,158,11,.3)}
.about-badge i{font-size:.85rem}

/* ── Smart Learning Section ── */
.smart-section{background:var(--off-white)}
.smart-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.smart-content h2{font-size:clamp(1.8rem,3vw,2.5rem);margin:14px 0 16px}
.smart-content>p{color:var(--gray-500);line-height:1.85;margin-bottom:32px}
.smart-steps{display:flex;flex-direction:column;gap:0}
.smart-step{
  display:flex;align-items:flex-start;gap:20px;
  padding:18px 0;
  border-bottom:1px solid var(--gray-200);
}
.smart-step:last-child{border-bottom:none}
.smart-min{
  min-width:64px;
  background:var(--orange-grad);color:#fff;
  padding:8px 10px;border-radius:var(--r-sm);
  font-family:'Cinzel',serif;font-size:.8rem;font-weight:700;
  text-align:center;line-height:1.3;flex-shrink:0;
  box-shadow:0 4px 12px rgba(249,115,22,.3);
}
.smart-desc h4{font-family:var(--sans);font-size:.95rem;font-weight:600;color:var(--navy);margin-bottom:4px}
.smart-desc p{font-size:.85rem;color:var(--gray-500);line-height:1.7}

.smart-outcomes h3{font-size:1.4rem;margin-bottom:24px;color:var(--navy)}
.outcome-card{
  display:flex;align-items:flex-start;gap:16px;
  background:#fff;border-radius:var(--r-md);
  padding:20px;margin-bottom:14px;
  box-shadow:var(--sh-sm);border:1px solid var(--gray-200);
  transition:all .3s var(--ease);
}
.outcome-card:hover{box-shadow:var(--sh-md);transform:translateX(4px)}
.outcome-card>i{
  font-size:1.3rem;color:var(--orange);
  width:40px;height:40px;border-radius:50%;
  background:var(--orange-light);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.outcome-card h4{font-family:var(--sans);font-size:.92rem;font-weight:600;color:var(--navy);margin-bottom:4px}
.outcome-card p{font-size:.82rem;color:var(--gray-500);line-height:1.65}

/* ── Hostel Section ── */
.hostel-section{position:relative;padding:100px 0;overflow:hidden}
.hostel-bg{
  position:absolute;inset:0;
  background:linear-gradient(135deg,#1a0533 0%,#2d1354 50%,#1a0533 100%);
}
.hostel-bg::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 80% 50%,rgba(249,115,22,.12) 0%,transparent 60%);
}
.hostel-grid{position:relative;z-index:10;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.hostel-content h2{color:#fff;font-size:clamp(1.8rem,3vw,2.5rem);margin:14px 0 16px}
.hostel-content h2 span{color:var(--orange)}
.hostel-lead{font-size:1.1rem;color:rgba(255,255,255,.9);font-weight:500;margin-bottom:14px}
.hostel-content>p{color:rgba(255,255,255,.7);line-height:1.85;margin-bottom:28px}
.hostel-features{display:flex;flex-direction:column;gap:12px;margin-bottom:32px}
.hostel-feat{
  display:flex;align-items:center;gap:14px;
  padding:12px 18px;
  background:rgba(255,255,255,.08);
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--r-sm);
  color:rgba(255,255,255,.88);font-size:.9rem;
}
.hostel-feat i{color:var(--orange);font-size:1rem;flex-shrink:0;width:20px;text-align:center}
.hostel-cta{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.hostel-seats{
  color:rgba(255,255,255,.7);font-size:.85rem;
  display:flex;align-items:center;gap:6px;
}
.hostel-seats i{color:var(--orange)}

.hostel-image{position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:400px}
.hostel-image img{width:100%;height:100%;object-fit:cover;border-radius:var(--r-lg);box-shadow:var(--sh-xl)}
.hostel-img-fallback{
  background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.04));
  border:2px dashed rgba(255,255,255,.15);
  display:flex;align-items:center;justify-content:center;
}
.hostel-img-fallback::after{
  content:'Hostel Photo\A Coming Soon';
  white-space:pre;text-align:center;
  color:rgba(255,255,255,.3);font-size:.9rem;
}
.hostel-badge{
  position:absolute;top:24px;right:24px;
  background:var(--orange-grad);color:#fff;
  padding:16px 20px;border-radius:var(--r-md);
  text-align:center;font-weight:700;
  box-shadow:var(--sh-lg);
}
.hostel-badge i{font-size:1.5rem;display:block;margin-bottom:6px}
.hostel-badge span{font-size:.85rem;line-height:1.3}

/* ── Responsive: new sections ── */
@media(max-width:900px){
  .smart-grid{grid-template-columns:1fr;gap:40px}
  .hostel-grid{grid-template-columns:1fr;gap:40px}
  .hostel-image{min-height:280px}
}
@media(max-width:600px){
  .hero-tagline{flex-direction:column;gap:4px}
  .smart-grid{gap:32px}
  .hostel-cta{flex-direction:column;align-items:flex-start}
}

/* ── Custom scrollbar ── */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--gray-100)}
::-webkit-scrollbar-thumb{background:var(--orange);border-radius:3px}

/* ═══════════════════════════════
   RESPONSIVE
═══════════════════════════════ */
@media(max-width:1100px){
  .principles-grid{grid-template-columns:repeat(2,1fr)}
  .activities-grid{grid-template-columns:repeat(2,1fr)}
  .paradise-features{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat-item:nth-child(2){border-right:none}
  .stat-item:nth-child(3){border-top:1px solid rgba(255,255,255,.07)}
  .about-grid{gap:44px}
}

@media(max-width:900px){
  /* Always show dark navbar on mobile — hamburger must be visible on page load */
  #navbar{background:rgba(15,23,42,.94);backdrop-filter:blur(20px)}

  section{padding:72px 0}
  .about-grid{grid-template-columns:1fr}
  .about-images{display:none}
  .contact-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .gallery-item.wide{grid-column:1/-1}
  .nav-menu{
    position:fixed;top:var(--nav-h);left:0;right:0;
    background:rgba(15,23,42,.98);backdrop-filter:blur(20px);
    flex-direction:column;padding:20px 24px;
    gap:12px;border-top:1px solid rgba(255,255,255,.07);
    transform:translateY(-110%);opacity:0;pointer-events:none;
    transition:all .35s var(--ease);
  }
  .nav-menu.open{transform:translateY(0);opacity:1;pointer-events:all}
  .nav-list{flex-direction:column;gap:2px;width:100%}
  .nav-list li a{display:block;padding:11px 16px}
  .nav-cta{width:100%;text-align:center;padding:13px}
  .hamburger{display:flex}
  .steps-row{flex-direction:column;align-items:center}
  .step-arrow{transform:rotate(90deg)}
  .form-row{grid-template-columns:1fr}
}

@media(max-width:600px){
  section{padding:56px 0}
  .principles-grid{grid-template-columns:1fr}
  .activities-grid{grid-template-columns:1fr}
  .paradise-features{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr}
  .gallery-item.wide{grid-column:1;aspect-ratio:4/3}
  .video-grid{grid-template-columns:1fr}
  .hero-actions{flex-direction:column;align-items:flex-start}
  .stats-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom .container{flex-direction:column;gap:6px;text-align:center}
  .hero-title{font-size:clamp(2rem,9vw,3rem)}
  .img-accent{display:none}

  /* Fix WhatsApp button causing horizontal overflow on mobile */
  .wa-float{right:14px;bottom:16px;width:50px;height:50px;font-size:1.5rem}
  .wa-tooltip{display:none}
  .back-top{right:14px;bottom:78px;width:40px;height:40px;font-size:.85rem}
}
