:root{
  --maroon:#7a1530;
  --maroon-dark:#52101f;
  --maroon-light:#a8324f;
  --gold:#cf9b29;
  --gold-light:#f3d27a;
  --cream:#fdf6e9;
  --cream-dark:#f4e8d2;
  --ink:#3a1c0a;
  --text:#5b4636;
  --text-soft:#8a7866;
  --white:#fffdf8;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Poppins',sans-serif;color:var(--text);background:var(--cream);line-height:1.7;overflow-x:hidden;}
h1,h2,h3,h4,.logo-text,.section-tag{font-family:'Cinzel',serif;}
img{max-width:100%;display:block;}
a{text-decoration:none;color:inherit;}
ul{list-style:none;}
.container{max-width:1200px;margin:0 auto;padding:0 24px;}

/* ===== BACKGROUND PATTERN ===== */
.bg-pattern{
  position:fixed; inset:0; z-index:-1; pointer-events:none;
  background-image:
    radial-gradient(circle at 15% 20%, rgba(207,155,41,0.06) 0%, transparent 35%),
    radial-gradient(circle at 85% 80%, rgba(122,21,48,0.05) 0%, transparent 35%);
}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:15px 34px; border-radius:50px;
  font-weight:600; font-size:14.5px; letter-spacing:.5px;
  border:2px solid transparent; cursor:pointer; transition:all .3s ease;
}
.btn-primary{ background:linear-gradient(135deg, var(--gold) 0%, var(--gold-light) 100%); color:var(--maroon-dark); box-shadow:0 10px 28px rgba(207,155,41,.35); }
.btn-primary:hover{ transform:translateY(-3px); box-shadow:0 16px 36px rgba(207,155,41,.45); }
.btn-outline{ border-color:rgba(255,255,255,.5); color:var(--white); }
.btn-outline:hover{ background:rgba(255,255,255,.12); border-color:#fff; }
.btn-dark{ background:linear-gradient(135deg, var(--maroon) 0%, var(--maroon-light) 100%); color:#fff; box-shadow:0 10px 28px rgba(122,21,48,.3); }
.btn-dark:hover{ transform:translateY(-3px); box-shadow:0 16px 36px rgba(122,21,48,.4); }

/* ===== SECTION HEAD ===== */
.section-tag{
  display:inline-block; font-size:13px; font-weight:700; letter-spacing:3px;
  text-transform:uppercase; color:var(--gold); margin-bottom:14px; position:relative; padding-left:46px;
}
.section-tag::before{ content:''; position:absolute; left:0; top:50%; width:36px; height:2px; background:var(--gold); transform:translateY(-50%); }
.section-tag.light{ color:var(--gold-light); }
.section-head{ margin-bottom:50px; }
.section-head.center{ text-align:center; }
.section-head.center .section-tag{ padding-left:0; }
.section-head.center .section-tag::before{ display:none; }
.section-head h2{ font-size:38px; font-weight:700; color:var(--ink); line-height:1.35; }
.section-head h2 span{ color:var(--maroon); }
.section-head.light h2{ color:#fff; }
.section-head p{ max-width:640px; margin:16px auto 0; color:var(--text-soft); font-size:15px; }
.section-head p.testi-lead{ max-width:100%; color:var(--maroon); font-size:18px; margin-top:8px; font-family:'Cinzel',serif; }
.section-head p.testi-lead + p{ max-width:780px; }

/* ===== NAVBAR ===== */
.navbar{
  position:fixed; top:0; left:0; right:0; z-index:1000;
  background:rgba(253,246,233,0); transition:all .35s ease; padding:18px 0;
}
.navbar.scrolled{ background:rgba(253,246,233,.96); backdrop-filter:blur(10px); box-shadow:0 6px 24px rgba(58,28,10,.08); padding:10px 0; }
.nav-container{ display:flex; align-items:center; justify-content:space-between; max-width:1200px; margin:0 auto; padding:0 24px; }
.logo{ display:flex; align-items:center; gap:12px; }
.logo-om{
  width:48px; height:48px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg, var(--maroon) 0%, var(--maroon-light) 100%); color:var(--gold-light);
  font-size:24px; box-shadow:0 6px 18px rgba(122,21,48,.35); flex-shrink:0;
}
.logo-text{ font-size:18px; font-weight:700; color:var(--maroon-dark); line-height:1.2; }
.logo-text small{ display:block; font-family:'Poppins',sans-serif; font-size:11px; font-weight:500; letter-spacing:2px; color:var(--gold); text-transform:uppercase; }
.nav-links{ display:flex; gap:34px; }
.nav-links a{ font-size:14.5px; font-weight:600; color:var(--ink); position:relative; padding:6px 0; transition:color .2s; }
.nav-links a::after{ content:''; position:absolute; bottom:0; left:0; width:0; height:2px; background:var(--gold); transition:width .25s; }
.nav-links a:hover{ color:var(--maroon); }
.nav-links a:hover::after{ width:100%; }
.navbar:not(.scrolled) .nav-links a{ color:var(--gold-light); }
.navbar:not(.scrolled) .nav-links a:hover,
.navbar:not(.scrolled) .nav-links a.active{ color:var(--gold); }
.navbar:not(.scrolled) .logo-text{ color:var(--gold-light); }
.nav-cta{ background:linear-gradient(135deg, var(--maroon) 0%, var(--maroon-light) 100%); color:#fff; padding:11px 26px; border-radius:50px; font-size:13.5px; font-weight:700; letter-spacing:.5px; box-shadow:0 8px 20px rgba(122,21,48,.3); }
.nav-toggle{ display:none; background:none; border:none; font-size:24px; color:var(--maroon); cursor:pointer; }

/* ===== HERO ===== */
.hero{
  position:relative; min-height:100vh; display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg, var(--maroon-dark) 0%, var(--maroon) 50%, #6b1228 100%);
  overflow:hidden; text-align:center; padding:140px 24px 100px;
}
.hero::before{
  content:''; position:absolute; width:900px; height:900px; border-radius:50%;
  border:1px dashed rgba(243,210,122,.18); top:50%; left:50%; transform:translate(-50%,-50%);
  animation:spin 90s linear infinite;
}
.hero::after{
  content:''; position:absolute; width:680px; height:680px; border-radius:50%;
  border:1px dashed rgba(243,210,122,.12); top:50%; left:50%; transform:translate(-50%,-50%);
  animation:spin 70s linear infinite reverse;
}
@keyframes spin{ from{ transform:translate(-50%,-50%) rotate(0deg); } to{ transform:translate(-50%,-50%) rotate(360deg); } }
.hero-bg-ring{ position:absolute; inset:0; pointer-events:none; }
.zodiac-sym{
  position:absolute; top:50%; left:50%; font-size:26px; color:rgba(243,210,122,.22);
  width:900px; height:900px; margin:-450px 0 0 -450px;
  display:flex; align-items:center; justify-content:center;
  animation:spin 120s linear infinite;
}
.zodiac-sym span{ position:absolute; top:14px; }
.hero-content{ position:relative; z-index:2; max-width:760px; margin:0 auto; }
.hero-om{
  font-size:54px; color:var(--gold-light); margin-bottom:18px;
  text-shadow:0 0 30px rgba(243,210,122,.6); animation:glow 3s ease-in-out infinite;
}
@keyframes glow{ 0%,100%{ opacity:.7; transform:scale(1); } 50%{ opacity:1; transform:scale(1.08); } }
.hero-eyebrow{ font-size:14px; letter-spacing:4px; text-transform:uppercase; color:var(--gold-light); font-weight:600; margin-bottom:18px; }
.hero h1{ font-size:58px; font-weight:900; color:#fff; line-height:1.2; margin-bottom:16px; }
.hero-sub{ font-size:17px; font-weight:600; color:var(--gold-light); letter-spacing:1px; margin-bottom:22px; }
.hero-desc{ font-size:15.5px; color:rgba(255,255,255,.78); max-width:600px; margin:0 auto 36px; }
.hero-buttons{ display:flex; gap:18px; justify-content:center; flex-wrap:wrap; margin-bottom:48px; }
.hero-badges{ display:flex; gap:30px; justify-content:center; flex-wrap:wrap; }
.hero-badges span{ display:flex; align-items:center; gap:10px; font-size:13.5px; font-weight:600; color:#fff; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.18); padding:10px 20px; border-radius:50px; backdrop-filter:blur(4px); }
.hero-badges i{ color:var(--gold-light); }
.scroll-cue{
  position:absolute; bottom:32px; left:50%; transform:translateX(-50%);
  width:40px; height:40px; border:1.5px solid rgba(255,255,255,.35); border-radius:50%;
  display:flex; align-items:center; justify-content:center; color:#fff; font-size:14px;
  animation:bounce 2s infinite; z-index:2;
}
@keyframes bounce{ 0%,100%{ transform:translate(-50%,0); } 50%{ transform:translate(-50%,8px); } }

/* ===== ABOUT ===== */
.about{ padding:110px 0; background:var(--white); }
.about .container{ max-width:1200px; margin:0 auto; padding:0 24px; }
.about-grid{ display:grid; grid-template-columns:1fr 1.25fr; gap:70px; align-items:start; }
.about-visual{ position:relative; display:flex; flex-direction:column; align-items:center; gap:36px; }
.about-visual .section-head{ margin-bottom:0; }
.about-visual .credentials{ margin:14px 0 0; width:100%; max-width:380px; text-align:center; }
.about-visual .credential-tags{ justify-content:center; }
.about-text{ padding-top:6px; }
.about-photo-wrap{ position:relative; width:100%; max-width:380px; }
.about-frame{ position:relative; width:100%; max-width:380px; aspect-ratio:1; }
.about-photo{
  width:100%; height:100%; border-radius:24px;
  background:linear-gradient(135deg, var(--maroon) 0%, var(--maroon-light) 60%, var(--gold) 130%);
  display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.85); font-size:120px;
  box-shadow:0 30px 70px rgba(122,21,48,.28); position:relative; z-index:2; overflow:hidden;
}
.about-photo::before{
  content:'ॐ'; position:absolute; font-size:280px; color:rgba(255,255,255,.06); font-family:'Cinzel',serif;
}
.about-ring{
  position:absolute; inset:-22px; border:2px dashed var(--gold); border-radius:30px; z-index:1; opacity:.5;
}
.about-stat-badge{
  position:absolute; bottom:-26px; right:-10px; background:#fff; border-radius:18px;
  padding:18px 26px; box-shadow:0 16px 40px rgba(58,28,10,.14); text-align:center; z-index:3;
}
.about-stat-badge strong{ display:block; font-family:'Cinzel',serif; font-size:30px; font-weight:900; color:var(--maroon); }
.about-stat-badge span{ font-size:11.5px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--text-soft); }
.about-text p{ margin-bottom:18px; font-size:15px; color:var(--text); }
.about-text p strong{ color:var(--ink); }
.credentials{ margin:28px 0 32px; }
.credentials h4{ font-size:14px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:var(--maroon); margin-bottom:14px; font-family:'Poppins',sans-serif; }
.credential-tags{ display:flex; flex-wrap:wrap; gap:10px; }
.credential-tags span{
  font-size:12.5px; font-weight:700; padding:8px 16px; border-radius:30px;
  background:var(--cream-dark); color:var(--maroon-dark); border:1px solid #ecdcc0;
}

/* ===== SERVICES ===== */
.services{ padding:110px 0; background:var(--cream); position:relative; }
.services-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:32px; }
.service-card{
  background:#fff; border-radius:22px; padding:44px 34px; text-align:center;
  box-shadow:0 14px 40px rgba(58,28,10,.06); border:1px solid #f1e6d2; transition:all .35s ease; position:relative; overflow:hidden;
}
.service-card::before{
  content:''; position:absolute; top:0; left:0; right:0; height:5px;
  background:linear-gradient(90deg, var(--maroon), var(--gold)); transform:scaleX(0); transform-origin:left; transition:transform .35s ease;
}
.service-card:hover{ transform:translateY(-10px); box-shadow:0 26px 60px rgba(58,28,10,.14); }
.service-card:hover::before{ transform:scaleX(1); }
.service-icon{
  width:84px; height:84px; border-radius:50%; margin:0 auto 24px;
  display:flex; align-items:center; justify-content:center; font-size:34px;
  background:linear-gradient(135deg, var(--maroon) 0%, var(--maroon-light) 100%); color:var(--gold-light);
  box-shadow:0 12px 28px rgba(122,21,48,.28);
}
.service-card h3{ font-size:22px; font-weight:700; color:var(--ink); margin-bottom:14px; }
.service-card p{ font-size:14px; color:var(--text-soft); margin-bottom:22px; }
.service-link{ font-size:13px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--maroon); display:inline-flex; align-items:center; gap:8px; }
.service-link i{ transition:transform .25s; }
.service-card:hover .service-link i{ transform:translateX(4px); }

/* ===== WHY US / STATS ===== */
.why-us{
  padding:110px 0; background:linear-gradient(135deg, var(--maroon-dark) 0%, var(--maroon) 100%); color:#fff; position:relative; overflow:hidden;
}
.why-us::before{
  content:'ॐ'; position:absolute; font-family:'Cinzel',serif; font-size:480px; color:rgba(255,255,255,.03);
  right:-100px; top:-140px; pointer-events:none;
}
.why-grid{ display:grid; grid-template-columns:1.1fr 1fr; gap:70px; align-items:center; position:relative; z-index:1; }
.why-text p{ color:rgba(255,255,255,.8); font-size:15px; margin-bottom:24px; }
.why-list{ display:grid; grid-template-columns:1fr 1fr; gap:14px 22px; }
.why-list li{ display:flex; align-items:flex-start; gap:10px; font-size:14px; font-weight:500; color:#fff; }
.why-list i{
  width:24px; height:24px; border-radius:50%; background:var(--gold); color:var(--maroon-dark);
  display:flex; align-items:center; justify-content:center; font-size:11px; flex-shrink:0; margin-top:2px;
}
.stats-grid{ display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.stat-box{
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14); border-radius:20px;
  padding:34px 20px; text-align:center; backdrop-filter:blur(6px);
}
.stat-num{ font-family:'Cinzel',serif; font-size:44px; font-weight:900; color:var(--gold-light); line-height:1; margin-bottom:8px; }
.stat-label{ font-size:12.5px; font-weight:600; letter-spacing:1px; text-transform:uppercase; color:rgba(255,255,255,.75); }

/* ===== ACHIEVEMENTS ===== */
.achievements{ padding:110px 0; background:var(--white); }
.achievements-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:26px; }
.achievement-card{
  background:var(--cream); border-radius:20px; padding:36px 24px; text-align:center;
  border:1px solid #f1e6d2; transition:all .3s ease;
}
.achievement-card:hover{ transform:translateY(-8px); box-shadow:0 20px 48px rgba(58,28,10,.1); background:#fff; }
.achievement-card i{
  width:64px; height:64px; border-radius:50%; margin:0 auto 18px; display:flex; align-items:center; justify-content:center;
  font-size:26px; background:linear-gradient(135deg, var(--gold) 0%, var(--gold-light) 100%); color:var(--maroon-dark);
}
.achievement-card h3{ font-size:16px; font-weight:700; color:var(--ink); margin-bottom:10px; }
.achievement-card p{ font-size:13px; color:var(--text-soft); }

/* ===== TESTIMONIALS ===== */
.testimonials{ padding:110px 0; background:var(--cream-dark); text-align:center; position:relative; }
.testimonial-track{
  display:flex; gap:28px; overflow:hidden; max-width:1000px; margin:0 auto 30px; padding:8px;
}
.testimonial-card{
  flex:0 0 100%; background:#fff; border-radius:22px; padding:44px 50px; box-shadow:0 16px 44px rgba(58,28,10,.08);
  display:flex; flex-direction:column; align-items:center; transition:opacity .4s;
}
.testimonial-card i.fa-quote-left{ font-size:26px; color:var(--gold); margin-bottom:18px; }
.testimonial-card p{ font-size:16px; color:var(--text); max-width:640px; margin-bottom:22px; font-style:italic; }
.testimonial-stars{ color:var(--gold); margin-bottom:14px; font-size:14px; }
.testimonial-name{ font-weight:700; color:var(--ink); font-size:15px; }
.testimonial-role{ font-size:12.5px; color:var(--text-soft); letter-spacing:.5px; text-transform:uppercase; margin-top:2px; }
.testimonial-nav{ display:flex; align-items:center; justify-content:center; gap:20px; }
.testimonial-nav button{
  width:42px; height:42px; border-radius:50%; border:1.5px solid #e3d4ba; background:#fff; color:var(--maroon);
  cursor:pointer; font-size:14px; transition:all .2s;
}
.testimonial-nav button:hover{ background:var(--maroon); color:#fff; border-color:var(--maroon); }
.testimonial-dots{ display:flex; gap:9px; }
.testimonial-dots span{ width:9px; height:9px; border-radius:50%; background:#e3d4ba; cursor:pointer; transition:all .2s; }
.testimonial-dots span.active{ background:var(--maroon); width:24px; border-radius:6px; }

/* ===== CONTACT ===== */
.contact{ padding:110px 0; background:var(--white); }
.contact-grid{ display:grid; grid-template-columns:1fr 1.3fr; gap:60px; margin-bottom:60px; }
.contact-item{ display:flex; gap:18px; margin-bottom:26px; }
.contact-item i{
  width:50px; height:50px; border-radius:14px; flex-shrink:0; display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg, var(--maroon) 0%, var(--maroon-light) 100%); color:var(--gold-light); font-size:18px;
}
.contact-item h4{ font-size:15px; font-weight:700; color:var(--ink); margin-bottom:4px; font-family:'Poppins',sans-serif; }
.contact-item p, .contact-item a{ font-size:13.5px; color:var(--text-soft); display:block; }
.contact-item a:hover{ color:var(--maroon); }
.social-links{ display:flex; gap:12px; margin:28px 0; }
.social-links a{
  width:42px; height:42px; border-radius:50%; border:1.5px solid #e3d4ba; display:flex; align-items:center; justify-content:center;
  color:var(--maroon); transition:all .2s; font-size:15px;
}
.social-links a:hover{ background:var(--maroon); color:#fff; border-color:var(--maroon); }
.payment-box{
  background:var(--cream-dark); border-radius:18px; padding:24px 26px; border:1px solid #ecdcc0;
}
.payment-box h4{ font-size:14px; font-weight:700; color:var(--maroon); text-transform:uppercase; letter-spacing:1px; margin-bottom:12px; font-family:'Poppins',sans-serif; }
.payment-box p{ font-size:13.5px; color:var(--text); margin-bottom:4px; }
.payment-box p strong{ color:var(--ink); }

.contact-form{ background:var(--cream); border-radius:24px; padding:44px; border:1px solid #f1e6d2; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-bottom:18px; }
.contact-form input, .contact-form textarea{
  width:100%; padding:15px 18px; border-radius:12px; border:1.5px solid #e8dcc6; background:#fff;
  font-family:'Poppins',sans-serif; font-size:14px; color:var(--ink); transition:border-color .2s; outline:none;
}
.contact-form input:focus, .contact-form textarea:focus{ border-color:var(--gold); }
.contact-form textarea{ min-height:130px; resize:vertical; margin-bottom:18px; }
.contact-form button{ width:100%; justify-content:center; border:none; }
.form-msg{ margin-top:14px; font-size:13.5px; font-weight:600; color:var(--maroon); text-align:center; min-height:18px; }
.form-group{ display:flex; flex-direction:column; gap:8px; margin-bottom:18px; }
.form-group label{ font-size:13px; font-weight:600; color:var(--ink); font-family:'Poppins',sans-serif; }
.contact-form select{
  width:100%; padding:15px 18px; border-radius:12px; border:1.5px solid #e8dcc6; background:#fff;
  font-family:'Poppins',sans-serif; font-size:14px; color:var(--ink); outline:none; cursor:pointer;
}
.contact-form select:focus{ border-color:var(--gold); }
.form-status{ margin-top:14px; font-size:13.5px; font-weight:600; color:var(--maroon); text-align:center; min-height:18px; opacity:0; transition:opacity .3s; }
.form-status.show{ opacity:1; }
.nav-links a.active{ color:var(--maroon); }
.nav-links a.active::after{ width:100%; }

.map-wrap{ border-radius:24px; overflow:hidden; box-shadow:0 16px 44px rgba(58,28,10,.1); }
.map-wrap iframe{ width:100%; height:380px; border:0; display:block; }

/* ===== FOOTER ===== */
.footer{ background:var(--ink); color:rgba(255,255,255,.7); padding:80px 0 0; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:50px; padding-bottom:50px; border-bottom:1px solid rgba(255,255,255,.08); }
.footer-col h4{ font-family:'Poppins',sans-serif; font-size:14px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:var(--gold-light); margin-bottom:20px; }
.footer-logo{ display:flex; align-items:center; gap:12px; margin-bottom:16px; }
.footer-logo .logo-om{ width:46px; height:46px; font-size:22px; }
.footer-logo span{ font-family:'Cinzel',serif; font-size:17px; font-weight:700; color:#fff; }
.footer-col p{ font-size:13.5px; line-height:1.8; }
.footer-col ul li{ margin-bottom:10px; font-size:13.5px; }
.footer-col ul a:hover{ color:var(--gold-light); }
.footer-col ul i{ width:18px; color:var(--gold); margin-right:8px; }
.footer-bottom{ text-align:center; padding:28px 0; font-size:12.5px; color:rgba(255,255,255,.45); }
.footer-bottom p{ margin-bottom:6px; }

/* ===== BACK TO TOP ===== */
.back-to-top{
  position:fixed; bottom:28px; right:28px; width:50px; height:50px; border-radius:50%; border:none;
  background:linear-gradient(135deg, var(--maroon) 0%, var(--maroon-light) 100%); color:#fff; font-size:17px;
  cursor:pointer; box-shadow:0 12px 30px rgba(122,21,48,.35); z-index:900; opacity:0; pointer-events:none;
  transition:all .3s ease;
}
.back-to-top.show{ opacity:1; pointer-events:auto; }
.back-to-top:hover{ transform:translateY(-4px); }

/* ===== RESPONSIVE ===== */
@media (max-width: 1024px){
  .about-grid, .why-grid, .contact-grid{ grid-template-columns:1fr; gap:50px; }
  .about-visual{ order:-1; }
  .services-grid{ grid-template-columns:repeat(2,1fr); }
  .achievements-grid{ grid-template-columns:repeat(2,1fr); }
  .hero h1{ font-size:46px; }
}
@media (max-width: 768px){
  .nav-links, .nav-cta{ display:none; }
  .nav-toggle{ display:block; }
  .navbar.open .nav-links{
    display:flex; flex-direction:column; gap:0; position:absolute; top:100%; left:0; right:0;
    background:var(--white); box-shadow:0 14px 30px rgba(58,28,10,.1); padding:10px 24px;
  }
  .navbar.open .nav-links li{ width:100%; }
  .navbar.open .nav-links a{ display:block; padding:14px 0; border-bottom:1px solid #f1e6d2; }
  .navbar.open.navbar:not(.scrolled) .nav-links a,
  .navbar.open .nav-links a{ color:var(--ink); }
  .navbar.open .logo-text{ color:var(--maroon-dark); }
  .navbar.open .nav-cta{ display:inline-flex; margin:16px 24px 20px; }
  .hero h1{ font-size:36px; }
  .hero-sub{ font-size:14px; }
  .section-head h2{ font-size:28px; }
  .services-grid{ grid-template-columns:1fr; }
  .achievements-grid{ grid-template-columns:1fr 1fr; }
  .form-row{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:36px; }
  .why-list{ grid-template-columns:1fr; }
}
@media (max-width: 480px){
  .hero-badges{ flex-direction:column; align-items:center; }
  .achievements-grid{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr; }
  .about-stat-badge{ right:50%; transform:translateX(50%); }
}

/* ===== DETAIL PAGE: PAGE HERO ===== */
.page-hero{
  position:relative; padding:170px 0 90px; text-align:center; overflow:hidden;
  background:linear-gradient(135deg, var(--maroon-dark) 0%, var(--maroon) 55%, var(--maroon-light) 100%);
}
.page-hero::before{
  content:'ॐ'; position:absolute; top:-60px; right:-40px; font-size:280px; color:rgba(255,255,255,.05); font-family:'Cinzel',serif;
}
.page-hero .container{ position:relative; z-index:1; }
.page-hero .breadcrumb{ font-size:13.5px; font-weight:600; letter-spacing:1px; color:var(--gold-light); margin-bottom:18px; }
.page-hero .breadcrumb a{ color:rgba(255,255,255,.75); transition:color .2s; }
.page-hero .breadcrumb a:hover{ color:var(--gold-light); }
.page-hero h1{ font-size:46px; font-weight:900; color:#fff; line-height:1.25; margin-bottom:14px; }
.page-hero p{ max-width:680px; margin:0 auto; color:rgba(255,255,255,.8); font-size:15.5px; }
.page-hero .hero-om{ margin:0 auto 18px; }

/* ===== PHOTO GALLERY (achievement pages) ===== */
.photo-gallery{ padding:70px 0 0; background:var(--white); }
.photo-gallery .container{ max-width:1200px; margin:0 auto; padding:0 24px; }
.photo-gallery-head{ text-align:center; margin-bottom:30px; }
.photo-gallery-head h3{ font-family:'Cinzel',serif; font-size:24px; font-weight:700; color:var(--ink); margin-bottom:8px; }
.photo-gallery-head h3 span{ color:var(--maroon); }
.photo-gallery-head p{ font-size:14px; color:var(--text-soft); }
.photo-gallery-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.photo-placeholder{
  position:relative; aspect-ratio:4/3; border-radius:16px; overflow:hidden;
  background:linear-gradient(135deg, var(--cream) 0%, var(--cream-dark) 100%);
  border:1.5px dashed #e3d4ba; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px;
  transition:all .3s ease;
}
.photo-placeholder:hover{ border-color:var(--maroon); transform:translateY(-4px); box-shadow:0 14px 34px rgba(58,28,10,.1); }
.photo-placeholder i{
  width:44px; height:44px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:17px; background:linear-gradient(135deg, var(--maroon) 0%, var(--maroon-light) 100%); color:var(--gold-light);
}
.photo-placeholder span{ font-size:11px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--text-soft); }

/* ===== DETAIL CONTENT ===== */
.detail-section{ padding:90px 0; background:var(--white); }
.detail-grid{ display:grid; grid-template-columns:2.2fr 1fr; gap:60px; align-items:start; }
.detail-content h2{ font-family:'Cinzel',serif; font-size:28px; font-weight:700; color:var(--ink); margin:34px 0 16px; }
.detail-content h2:first-child{ margin-top:0; }
.detail-content h2 span{ color:var(--maroon); }
.detail-content > p{ font-size:15.5px; color:var(--text); margin-bottom:18px; }
.detail-list{ display:grid; gap:12px; margin:8px 0 30px; }
.detail-list li{
  display:flex; align-items:flex-start; gap:12px; font-size:15px; color:var(--text);
  background:var(--cream); border:1px solid #f1e6d2; border-radius:14px; padding:14px 18px;
}
.detail-list li i{ color:var(--gold); margin-top:3px; flex-shrink:0; }

/* ===== DETAIL SIDEBAR ===== */
.detail-sidebar{ position:sticky; top:110px; display:flex; flex-direction:column; gap:24px; }
.sidebar-card{
  background:var(--cream); border:1px solid #f1e6d2; border-radius:20px; padding:30px;
}
.sidebar-card h3{ font-family:'Cinzel',serif; font-size:19px; color:var(--ink); margin-bottom:14px; }
.sidebar-card p{ font-size:14px; color:var(--text-soft); margin-bottom:20px; }
.sidebar-card .btn{ width:100%; justify-content:center; }
.sidebar-nav{ display:flex; flex-direction:column; gap:10px; }
.sidebar-nav a{
  display:flex; align-items:center; justify-content:space-between; gap:10px; font-size:14.5px; font-weight:600;
  color:var(--ink); background:var(--cream); border:1px solid #f1e6d2; border-radius:12px; padding:14px 18px; transition:all .2s;
}
.sidebar-nav a:hover, .sidebar-nav a.active{ background:var(--maroon); color:#fff; border-color:var(--maroon); }
.sidebar-nav a.active i{ color:var(--gold-light); }

/* ===== DETAIL CTA BAND ===== */
.detail-cta{
  background:linear-gradient(135deg, var(--maroon) 0%, var(--maroon-light) 100%);
  border-radius:28px; padding:54px 50px; text-align:center; margin-top:60px;
}
.detail-cta h3{ font-family:'Cinzel',serif; font-size:28px; color:#fff; margin-bottom:12px; }
.detail-cta p{ color:rgba(255,255,255,.82); max-width:600px; margin:0 auto 26px; font-size:15px; }
.detail-cta .btn-primary{ background:#fff; color:var(--maroon); }
.detail-cta .btn-primary:hover{ background:var(--gold-light); }

@media (max-width: 900px){
  .detail-grid{ grid-template-columns:1fr; }
  .detail-sidebar{ position:static; }
  .page-hero h1{ font-size:32px; }
  .photo-gallery-grid{ grid-template-columns:repeat(3,1fr); }
}
@media (max-width: 600px){
  .photo-gallery-grid{ grid-template-columns:repeat(2,1fr); }
}
