/* ===== RESET & BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#fefcf8;
  --bg-alt:#f8f5ef;
  --bg-card:#fff;
  --blue:#2b5876;
  --blue-dark:#1a3a52;
  --blue-light:#e6eef7;
  --gold:#c9a84c;
  --gold-light:#e8d48b;
  --gold-dark:#a8882e;
  --text:#2c3e50;
  --text-light:#6b7a8a;
  --text-muted:#a0adb8;
  --shadow:0 4px 24px rgba(43,88,118,.06);
  --shadow-hover:0 8px 40px rgba(43,88,118,.1);
  --shadow-gold:0 4px 24px rgba(201,168,76,.25);
  --radius:12px;
  --radius-lg:20px;
  --radius-full:50px;
  --transition:.4s cubic-bezier(.25,.46,.45,.94);
  --font-display:'Playfair Display',serif;
  --font-body:'Inter',sans-serif;
  --max-width:1240px;
}
html{scroll-behavior:smooth;scroll-padding-top:80px}
body{
  font-family:var(--font-body);
  color:var(--text);
  background:var(--bg);
  line-height:1.7;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{text-decoration:none;color:inherit}
::selection{background:var(--gold);color:var(--blue-dark)}

/* ===== TYPOGRAPHY ===== */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.15}
.section-label{
  font-family:var(--font-body);
  font-size:.7rem;
  font-weight:600;
  letter-spacing:4px;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:1rem;
  display:inline-block;
  position:relative;
}
.section-label::after{
  content:'';
  display:block;
  width:36px;
  height:2px;
  background:var(--gold);
  margin-top:.5rem;
  border-radius:2px;
}
.section-title{
  font-size:clamp(1.8rem,4.5vw,3rem);
  color:var(--blue-dark);
  margin-bottom:1.2rem;
  line-height:1.2;
}
.section-sub{
  font-size:1.05rem;
  color:var(--text-light);
  max-width:640px;
  line-height:1.8;
}

/* ===== CONTAINER ===== */
.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 24px}

/* ===== NAVIGATION ===== */
nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:1rem 0;
  transition:var(--transition);
}
nav.scrolled{
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  box-shadow:0 1px 32px rgba(43,88,118,.06);
  padding:.6rem 0;
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  max-width:var(--max-width);margin:0 auto;padding:0 24px;
}
.nav-logo{
  font-family:var(--font-display);
  font-size:1.3rem;
  font-weight:700;
  color:#fff;
  transition:var(--transition);
}
.nav-logo span{color:var(--gold)}
nav.scrolled .nav-logo{color:var(--blue-dark)}
nav.scrolled .nav-link{color:var(--text)}
.nav-link{
  font-size:.82rem;font-weight:500;
  color:rgba(255,255,255,.85);
  transition:var(--transition);
  position:relative;
  padding-bottom:2px;
}
.nav-link::after{
  content:'';position:absolute;bottom:0;left:0;
  width:0;height:1.5px;background:var(--gold);
  transition:var(--transition);
}
.nav-link:hover::after{width:100%}
.nav-link:hover{color:var(--gold)}
.nav-links{display:flex;align-items:center;gap:2rem;list-style:none}
.nav-cta{
  background:var(--gold);
  color:var(--blue-dark)!important;
  padding:.5rem 1.5rem;
  border-radius:var(--radius-full);
  font-weight:600;
  font-size:.78rem;
  transition:var(--transition);
}
.nav-cta:hover{background:var(--gold-light);transform:translateY(-1px)}
.nav-cta::after{display:none!important}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:4px;color:#fff;font-size:1.4rem}
nav.scrolled .menu-toggle{color:var(--blue-dark)}

/* ===== HERO ===== */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;align-items:center;
  background:linear-gradient(135deg,var(--blue-dark) 0%,var(--blue) 50%,#3a6b8f 100%);
  overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  opacity:.15;
}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(26,58,82,.88) 0%,rgba(43,88,118,.55) 100%);
}
.hero-pattern{
  position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23c9a84c' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.hero-glow{
  position:absolute;
  top:-30%;right:-20%;
  width:70%;height:140%;
  background:radial-gradient(ellipse at center,rgba(201,168,76,.1) 0%,transparent 70%);
  pointer-events:none;
}
.hero-content{position:relative;z-index:2;max-width:820px;padding:6rem 0 4rem}
.hero-badge{
  display:inline-flex;align-items:center;gap:.5rem;
  background:rgba(201,168,76,.12);
  border:1px solid rgba(201,168,76,.25);
  color:var(--gold-light);
  padding:.4rem 1.2rem;
  border-radius:var(--radius-full);
  font-size:.75rem;font-weight:500;letter-spacing:1px;
  margin-bottom:2rem;
  backdrop-filter:blur(4px);
}
.hero-badge i{font-size:.6rem}
.hero h1{
  font-size:clamp(2.4rem,6.5vw,4.5rem);
  color:#fff;
  margin-bottom:.75rem;
  line-height:1.08;
}
.hero h1 .gold{background:linear-gradient(135deg,var(--gold),var(--gold-light),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero p{
  font-size:clamp(1rem,1.6vw,1.2rem);
  color:rgba(255,255,255,.7);
  max-width:580px;
  line-height:1.8;
  margin-bottom:2.5rem;
  font-weight:300;
}
.hero-actions{display:flex;flex-wrap:wrap;gap:1rem}
.btn{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:.85rem 2rem;
  border-radius:var(--radius-full);
  font-weight:600;
  font-size:.85rem;
  transition:var(--transition);
  cursor:pointer;border:none;
  font-family:var(--font-body);
}
.btn-primary{
  background:linear-gradient(135deg,var(--gold),var(--gold-light));
  color:var(--blue-dark);
  box-shadow:var(--shadow-gold);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(201,168,76,.35)}
.btn-outline{
  background:transparent;
  color:#fff;
  border:1.5px solid rgba(255,255,255,.25);
}
.btn-outline:hover{border-color:var(--gold);color:var(--gold);background:rgba(201,168,76,.08)}
.btn-outline-light{
  background:transparent;
  color:var(--blue-dark);
  border:1.5px solid var(--blue);
}
.btn-outline-light:hover{background:var(--blue);color:#fff}
.hero-scroll{
  position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  color:rgba(255,255,255,.3);
  font-size:.6rem;letter-spacing:2px;text-transform:uppercase;
  animation:bounce-scroll 2s ease-in-out infinite;
}
@keyframes bounce-scroll{
  0%,100%{transform:translateX(-50%) translateY(0)}
  50%{transform:translateX(-50%) translateY(6px)}
}
.hero-scroll i{font-size:.75rem}

/* ===== SECTION BASE ===== */
section{padding:4.5rem 0}
@media(min-width:768px){section{padding:6rem 0}}

/* ===== COUNTER ===== */
.counter-strip{background:var(--bg-alt);padding:2.5rem 0;border-top:1px solid rgba(201,168,76,.12);border-bottom:1px solid rgba(201,168,76,.12)}
.counter-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;text-align:center}
.counter-number{
  font-family:var(--font-display);
  font-size:clamp(2rem,4.5vw,3.2rem);
  font-weight:700;
  background:linear-gradient(135deg,var(--gold),var(--gold-dark));
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  line-height:1;
}
.counter-label{font-size:.82rem;color:var(--text-light);font-weight:500;margin-top:.4rem;letter-spacing:.5px}
.counter-plus{
  font-family:var(--font-display);
  font-size:clamp(1.3rem,2.5vw,1.8rem);
  background:linear-gradient(135deg,var(--gold),var(--gold-dark));
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

/* ===== STORY ===== */
.story{background:var(--bg)}
.story-grid{display:grid;grid-template-columns:1fr;gap:3rem;align-items:center}
@media(min-width:900px){.story-grid{grid-template-columns:1fr 1fr;gap:5rem}}
.story-image{
  position:relative;
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow);
}
.story-image img{
  width:100%;
  height:400px;
  object-fit:cover;
  display:block;
}
.story-image .img-placeholder{
  width:100%;
  height:400px;
  background:linear-gradient(145deg,var(--blue-light),var(--bg-alt));
  display:flex;align-items:center;justify-content:center;
  color:var(--text-muted);
  font-size:.9rem;
}
.story-accent{
  position:absolute;
  top:-.8rem;right:-.8rem;
  width:5rem;height:5rem;
  border:2px solid var(--gold);
  border-radius:50%;
  opacity:.25;
  animation:pulse-ring 3s ease-in-out infinite;
  pointer-events:none;
}
@keyframes pulse-ring{
  0%,100%{transform:scale(1);opacity:.25}
  50%{transform:scale(1.06);opacity:.12}
}

/* ===== GALLERY ===== */
.gallery{background:var(--bg);padding:4.5rem 0}
@media(min-width:768px){.gallery{padding:6rem 0}}
.gallery-header{text-align:center;margin-bottom:3rem}
.gallery-header .section-sub{margin:0 auto}
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:1.2rem;
}
.gallery-item{
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow);
  transition:var(--transition);
  aspect-ratio:4/3;
}
.gallery-item:hover{box-shadow:var(--shadow-hover);transform:translateY(-3px)}
.gallery-item img{
  width:100%;height:100%;
  object-fit:cover;
  transition:var(--transition);
}
.gallery-item:hover img{transform:scale(1.05)}
.lifestyle-gallery{background:var(--bg-alt)}
.lifestyle-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}
.lifestyle-grid .gallery-item:first-child{grid-row:span 2;aspect-ratio:auto}
.lifestyle-grid .gallery-item.tall{min-height:320px}
@media(max-width:600px){
  .lifestyle-grid .gallery-item:first-child{grid-row:auto}
  .lifestyle-grid .gallery-item.tall{min-height:auto;aspect-ratio:4/3}
}

/* ===== HOSTELS ===== */
.hostels{background:var(--bg-alt)}
.hostels-header{text-align:center;margin-bottom:3.5rem}
.hostels-header .section-sub{margin:0 auto}
.hostel-grid{display:grid;grid-template-columns:1fr;gap:2.5rem}
@media(min-width:900px){.hostel-grid{grid-template-columns:1fr 1fr;gap:2rem}}
.hostel-card{
  background:var(--bg-card);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow);
  transition:var(--transition);
}
.hostel-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-3px)}
.hostel-card-img{
  height:220px;
  overflow:hidden;
  position:relative;
}
.hostel-card-img img{
  width:100%;height:100%;
  object-fit:cover;
  transition:var(--transition);
}
.hostel-card:hover .hostel-card-img img{transform:scale(1.04)}
.hostel-card-img .img-fallback{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  font-size:2.5rem;
  opacity:.15;
}
.hostel-card-img .badge{
  position:absolute;
  top:1.2rem;left:1.2rem;
  background:var(--gold);
  color:var(--blue-dark);
  font-size:.65rem;font-weight:700;letter-spacing:1.5px;
  text-transform:uppercase;
  padding:.35rem 1rem;
  border-radius:var(--radius-full);
  z-index:2;
}
.hostel-card-img .card-title-overlay{
  position:absolute;
  bottom:0;left:0;right:0;
  padding:1.5rem;
  background:linear-gradient(transparent,rgba(0,0,0,.5));
  z-index:2;
}
.hostel-card-img .card-title-overlay h3{
  color:#fff;
  font-size:1.3rem;
}
.hostel-card-img .card-title-overlay h3 span{
  display:block;
  font-family:var(--font-body);
  font-size:.7rem;
  font-weight:400;
  color:rgba(255,255,255,.65);
  margin-top:.15rem;
  letter-spacing:1.5px;
  text-transform:uppercase;
}
.hostel-card-body{padding:1.8rem 1.8rem 2.2rem}
.hostel-features{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
.hostel-feature{
  display:flex;align-items:center;gap:.55rem;
  font-size:.85rem;color:var(--text);
  padding:.2rem 0;
}
.hostel-feature i{
  color:var(--gold);
  font-size:.6rem;
  width:18px;height:18px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(201,168,76,.1);
  border-radius:50%;
  flex-shrink:0;
}
.hostel-card .btn{margin-top:1.5rem;width:100%;justify-content:center}

/* ===== AMENITIES SLIDER ===== */
.amenities{background:var(--bg);position:relative;overflow:hidden}
.amenities-header{text-align:center;margin-bottom:3rem}
.amenities-header .section-sub{margin:0 auto}
.amenities-slider-wrap{position:relative;max-width:1100px;margin:0 auto}
.amenities-track{display:flex;transition:transform .5s cubic-bezier(.25,.46,.45,.94);gap:0}
.amenities-slide{
  min-width:100%;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:1.2rem;
  padding:0 .5rem;
}
.amenity-card{
  text-align:center;
  padding:2rem 1.2rem;
  border-radius:var(--radius);
  background:var(--bg-card);
  box-shadow:var(--shadow);
  transition:var(--transition);
  border:1px solid rgba(201,168,76,.08);
}
.amenity-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-3px);border-color:rgba(201,168,76,.2)}
.amenity-icon{
  width:52px;height:52px;
  margin:0 auto 1rem;
  background:var(--blue-light);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;
  color:var(--blue);
  transition:var(--transition);
}
.amenity-card:hover .amenity-icon{background:var(--gold);color:var(--blue-dark)}
.amenity-card h4{
  font-family:var(--font-body);
  font-size:.9rem;
  font-weight:600;
  color:var(--blue-dark);
  margin-bottom:.25rem;
}
.amenity-card p{font-size:.78rem;color:var(--text-light);line-height:1.5}
.amenity-nav{
  display:flex;justify-content:center;align-items:center;gap:1rem;
  margin-top:2rem;
}
.amenity-btn{
  width:40px;height:40px;
  border-radius:50%;
  border:1.5px solid rgba(43,88,118,.15);
  background:var(--bg-card);
  color:var(--blue);
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:var(--transition);
  font-size:.8rem;
}
.amenity-btn:hover{border-color:var(--gold);color:var(--gold);background:rgba(201,168,76,.06)}
.amenity-dots{display:flex;gap:.4rem}
.amenity-dot{
  width:8px;height:8px;
  border-radius:50%;
  background:var(--text-muted);
  cursor:pointer;
  transition:var(--transition);
  border:none;opacity:.4;
}
.amenity-dot.active{background:var(--gold);opacity:1;width:26px;border-radius:4px}

/* ===== TESTIMONIALS ===== */
.testimonials{
  background:var(--bg-alt);
  position:relative;
}
.testimonials-header{text-align:center;margin-bottom:3rem}
.testimonials-header .section-sub{margin:0 auto}
.testimonial-slider{position:relative;max-width:750px;margin:0 auto}
.testimonial-track{display:flex;transition:transform .6s cubic-bezier(.25,.46,.45,.94)}
.testimonial-slide{min-width:100%;padding:0 .5rem}
.testimonial-card{
  text-align:center;
  padding:2.5rem 2rem;
  background:var(--bg-card);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow);
}
.testimonial-stars{color:var(--gold);font-size:.85rem;letter-spacing:3px;margin-bottom:1.2rem}
.testimonial-quote{
  font-family:var(--font-display);
  font-size:clamp(1rem,1.8vw,1.25rem);
  line-height:1.8;
  color:var(--text);
  font-style:italic;
  max-width:600px;
  margin:0 auto 1.8rem;
}
.testimonial-author{display:flex;align-items:center;justify-content:center;gap:.8rem}
.testimonial-avatar{
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),var(--gold-dark));
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:1rem;color:var(--blue-dark);
  flex-shrink:0;
}
.testimonial-name{font-weight:600;font-size:.85rem;text-align:left}
.testimonial-name span{display:block;font-weight:400;font-size:.75rem;color:var(--text-light);margin-top:.1rem}
.testimonial-nav{
  display:flex;justify-content:center;align-items:center;gap:1rem;
  margin-top:1.5rem;
}
.testimonial-btn{
  width:40px;height:40px;
  border-radius:50%;
  border:1.5px solid rgba(43,88,118,.15);
  background:var(--bg-card);
  color:var(--blue);
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:var(--transition);
  font-size:.8rem;
}
.testimonial-btn:hover{border-color:var(--gold);color:var(--gold)}
.testimonial-dots{display:flex;gap:.4rem}
.testimonial-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--text-muted);cursor:pointer;
  transition:var(--transition);border:none;opacity:.4;
}
.testimonial-dot.active{background:var(--gold);opacity:1;width:26px;border-radius:4px}
.quote-mark{font-size:3rem;font-family:var(--font-display);color:rgba(201,168,76,.15);line-height:0;position:relative;top:.8rem}

/* ===== CTA ===== */
.cta{
  background:linear-gradient(135deg,var(--blue-dark) 0%,var(--blue) 100%);
  text-align:center;
  position:relative;
  overflow:hidden;
  padding:4.5rem 0;
}
.cta-pattern{
  position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23c9a84c' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.cta-content{position:relative;z-index:2;max-width:680px;margin:0 auto}
.cta h2{
  font-size:clamp(1.8rem,4vw,2.6rem);
  color:#fff;
  margin-bottom:.8rem;
}
.cta p{
  color:rgba(255,255,255,.55);
  font-size:1rem;
  margin-bottom:2.2rem;
  line-height:1.8;
}
.cta .btn-primary{font-size:.95rem;padding:1rem 2.4rem}
.cta-email{
  display:inline-flex;align-items:center;gap:.5rem;
  margin-top:1.2rem;
  color:rgba(255,255,255,.35);
  font-size:.82rem;
  transition:var(--transition);
}
.cta-email:hover{color:var(--gold)}
.cta-email i{color:var(--gold);font-size:.75rem}
.cta-accent{
  position:absolute;bottom:-2rem;right:-2rem;
  width:10rem;height:10rem;
  border:1px solid rgba(201,168,76,.06);
  border-radius:50%;
  pointer-events:none;
}
.cta-accent-2{
  position:absolute;top:-2.5rem;left:-1rem;
  width:7rem;height:7rem;
  border:1px solid rgba(201,168,76,.04);
  border-radius:50%;
  pointer-events:none;
}

/* ===== WHATSAPP BUTTON ===== */
.whatsapp-btn{
  position:fixed;
  bottom:24px;right:24px;
  z-index:999;
  width:54px;height:54px;
  border-radius:50%;
  background:#25D366;
  color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;
  box-shadow:0 4px 20px rgba(37,211,102,.35);
  transition:var(--transition);
  border:none;cursor:pointer;
}
.whatsapp-btn:hover{transform:scale(1.08);box-shadow:0 6px 28px rgba(37,211,102,.45)}
.whatsapp-tooltip{
  position:absolute;
  right:62px;
  top:50%;transform:translateY(-50%);
  background:var(--bg-card);
  color:var(--text);
  padding:.4rem 1rem;
  border-radius:8px;
  font-size:.75rem;font-weight:500;white-space:nowrap;
  box-shadow:var(--shadow);
  opacity:0;pointer-events:none;
  transition:var(--transition);
}
.whatsapp-btn:hover .whatsapp-tooltip{opacity:1;right:66px}

/* ===== FOOTER ===== */
footer{
  background:var(--blue-dark);
  padding:2rem 0;
  text-align:center;
}
footer .container{display:flex;flex-direction:column;align-items:center;gap:.6rem}
@media(min-width:600px){footer .container{flex-direction:row;justify-content:space-between}}
footer p{color:rgba(255,255,255,.3);font-size:.78rem}
.footer-logo{font-family:var(--font-display);font-size:.95rem;color:rgba(255,255,255,.45)}
.footer-logo span{color:var(--gold)}

/* ===== REVEAL ANIMATIONS ===== */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-30px);transition:opacity .7s ease,transform .7s ease}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(30px);transition:opacity .7s ease,transform .7s ease}
.reveal-right.visible{opacity:1;transform:translateX(0)}
.reveal-scale{opacity:0;transform:scale(.93);transition:opacity .7s ease,transform .7s ease}
.reveal-scale.visible{opacity:1;transform:scale(1)}
.stagger-children>*{opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}
.stagger-children.visible>*{opacity:1;transform:translateY(0)}
.stagger-children.visible>*:nth-child(1){transition-delay:.05s}
.stagger-children.visible>*:nth-child(2){transition-delay:.1s}
.stagger-children.visible>*:nth-child(3){transition-delay:.15s}
.stagger-children.visible>*:nth-child(4){transition-delay:.2s}
.stagger-children.visible>*:nth-child(5){transition-delay:.25s}
.stagger-children.visible>*:nth-child(6){transition-delay:.3s}
.stagger-children.visible>*:nth-child(7){transition-delay:.35s}
.stagger-children.visible>*:nth-child(8){transition-delay:.4s}
.stagger-children.visible>*:nth-child(9){transition-delay:.45s}

/* ===== RESPONSIVE ===== */
@media(max-width:768px){
  .menu-toggle{display:block}
  .nav-links{
    position:fixed;
    top:0;right:-100%;
    width:270px;height:100vh;
    background:var(--bg-card);
    flex-direction:column;
    justify-content:center;
    gap:1.5rem;
    transition:var(--transition);
    box-shadow:-8px 0 32px rgba(0,0,0,.08);
  }
  .nav-links.open{right:0}
  .nav-links .nav-link{color:var(--text);font-size:1rem}
  .hero h1{font-size:clamp(1.8rem,9vw,2.6rem)}
  .hostel-features{grid-template-columns:1fr}
  .section-title{font-size:1.6rem}
  .counter-grid{gap:1.2rem}
  .amenities-slide{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:480px){
  .hero-actions{flex-direction:column}
  .hero-actions .btn{width:100%;justify-content:center}
  .counter-grid{grid-template-columns:1fr;gap:1.5rem}
  .amenities-slide{grid-template-columns:1fr}
}