/* ============================================================
   QUEEN MAKEUP ACADEMY — v3 (Cinzel · Montserrat · Poppins)
   Dynamic, elegant, fully mobile-responsive
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;500;600;700;800&family=Montserrat:wght@400;500;600;700&family=Poppins:wght@300;400;500;600&family=Great+Vibes&display=swap');

/* ── Variables ── */
:root {
  --primary:    #7B1C33;
  --secondary:  #F5ECD7;
  --accent:     #5A0E22;
  --light:      #FAF6F1;
  --gold:       #C9A84C;
  --gold2:      #a8883a;
  --text:       #2C2C2C;
  --muted:      #777;
  --border:     rgba(123,28,51,.15);
  --shadow:     rgba(90,14,34,.18);
  --nav-h:      76px;
  --tr:         0.35s cubic-bezier(.4,0,.2,1);
  --radius:     14px;
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;overflow-x:hidden}
body{font-family:'Poppins',sans-serif;color:var(--text);background:#fff;overflow-x:hidden;line-height:1.7;width:100%}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit;transition:var(--tr)}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,select,textarea{font-family:'Poppins',sans-serif}

/* ── Layout ── */
.container{max-width:1180px;margin:0 auto;padding:0 28px}
.section-pad{padding:96px 0}
.text-center{text-align:center}

/* ── Typography ── */
h1,h2,h3,.heading-xl,.heading-lg,.heading-md{font-family:'Cinzel',serif}
.subheading{font-family:'Montserrat',sans-serif;font-weight:600}
.tag{display:inline-flex;align-items:center;gap:8px;font-family:'Montserrat',sans-serif;font-size:0.72rem;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--primary);margin-bottom:16px}
.tag::before{content:'';display:inline-block;width:32px;height:1.5px;background:var(--gold)}
.heading-xl{font-size:clamp(1.8rem,4vw,3.2rem);font-weight:700;line-height:1.1;color:var(--accent)}
.heading-lg{font-size:clamp(1.45rem,3vw,2.3rem);font-weight:600;line-height:1.2;color:var(--accent)}
.heading-md{font-size:clamp(1.1rem,2.2vw,1.6rem);font-weight:600;color:var(--accent)}
.body-text{font-family:'Poppins',sans-serif;font-size:0.95rem;color:var(--muted);line-height:1.9}
.divider{width:56px;height:2px;background:linear-gradient(90deg,var(--primary),var(--gold));margin:16px 0;border-radius:2px}
.divider-center{margin:16px auto}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:9px;padding:13px 32px;border-radius:50px;font-family:'Montserrat',sans-serif;font-weight:600;font-size:0.88rem;letter-spacing:0.6px;transition:var(--tr);cursor:pointer;white-space:nowrap}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;box-shadow:0 6px 22px rgba(123,28,51,.35)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(123,28,51,.45);color:#fff}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#fff;box-shadow:0 6px 22px rgba(201,168,76,.4)}
.btn-gold:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(201,168,76,.5);color:#fff}
.btn-outline{border:2px solid var(--primary);color:var(--primary)}
.btn-outline:hover{background:var(--primary);color:#fff;transform:translateY(-3px)}
.btn-white{background:#fff;color:var(--accent);box-shadow:0 6px 22px rgba(0,0,0,.15)}
.btn-white:hover{background:var(--secondary);transform:translateY(-3px)}
.btn-sm{padding:9px 22px;font-size:0.82rem}

/* ============================================================
   NAVBAR
   ============================================================ */
#navbar{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-h);transition:var(--tr)}
#navbar.scrolled{background:rgba(255,255,255,.97);backdrop-filter:blur(16px);box-shadow:0 2px 24px rgba(90,14,34,.1)}
#navbar:not(.scrolled){background:rgba(255,255,255,.97);backdrop-filter:blur(16px);box-shadow:0 2px 24px rgba(90,14,34,.08)}
#navbar .container{display:flex;align-items:center;justify-content:space-between;height:100%}

/* Logo */
.nav-logo{display:flex;align-items:center;gap:12px;z-index:1001;flex-shrink:0}
.logo-icon{width:46px;height:46px;background:linear-gradient(135deg,var(--accent),var(--primary));border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 14px rgba(90,14,34,.4)}
.logo-icon svg{width:24px;height:24px}
.logo-text{display:flex;flex-direction:column;line-height:1.1}
.logo-name{font-family:'Cinzel',serif;font-size:1.05rem;font-weight:700;transition:var(--tr)}
.nav-logo-img{height:56px;width:auto;object-fit:contain;display:block;}
.logo-sub{font-family:'Montserrat',sans-serif;font-size:0.58rem;font-weight:600;letter-spacing:3px;text-transform:uppercase;transition:var(--tr)}
#navbar:not(.scrolled) .logo-name{color:var(--accent)}
#navbar:not(.scrolled) .logo-sub{color:var(--gold)}
#navbar.scrolled .logo-name{color:var(--accent)}
#navbar.scrolled .logo-sub{color:var(--gold)}

/* Links */
.nav-links{display:flex;align-items:center;gap:4px}
.nav-links a{font-family:'Montserrat',sans-serif;font-size:0.82rem;font-weight:600;letter-spacing:0.5px;padding:8px 14px;border-radius:50px;transition:var(--tr)}
#navbar:not(.scrolled) .nav-links a{color:var(--text)}
#navbar:not(.scrolled) .nav-links a:hover,#navbar:not(.scrolled) .nav-links a.active{color:var(--primary);background:rgba(123,28,51,.08)}
#navbar.scrolled .nav-links a{color:var(--text)}
#navbar.scrolled .nav-links a:hover,#navbar.scrolled .nav-links a.active{color:var(--primary);background:rgba(123,28,51,.08)}
.nav-links .btn-nav{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff!important;padding:10px 24px;border-radius:50px;box-shadow:0 4px 14px rgba(90,14,34,.35)}
.nav-links .btn-nav:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(90,14,34,.45)!important;background:linear-gradient(135deg,var(--accent),var(--primary))!important}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;padding:8px;border-radius:8px;z-index:1001;cursor:pointer}
.hamburger span{display:block;width:24px;height:2px;border-radius:2px;transition:var(--tr)}
#navbar:not(.scrolled) .hamburger span{background:var(--accent)}
#navbar.scrolled .hamburger span{background:var(--accent)}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile Drawer */
.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:1999;opacity:0;pointer-events:none;transition:opacity .35s}
.drawer-overlay.open{opacity:1;pointer-events:all}
.mobile-drawer{position:fixed;top:0;right:-100%;width:min(310px,86vw);height:100vh;background:#fff;z-index:2000;transition:right .38s cubic-bezier(.4,0,.2,1);box-shadow:-6px 0 40px rgba(90,14,34,.18);display:flex;flex-direction:column;overflow-y:auto}
.mobile-drawer.open{right:0}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;background:linear-gradient(135deg,var(--accent),var(--primary))}
.drawer-brand{font-family:'Cinzel',serif;font-size:1.3rem;color:#fff;font-weight:700}
.drawer-close{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.1rem;cursor:pointer;border:none;transition:var(--tr);flex-shrink:0}
.drawer-close:hover{background:rgba(255,255,255,.35)}
.drawer-nav{padding:12px 0;flex:1}
.drawer-nav a{display:flex;align-items:center;gap:12px;padding:13px 24px;font-family:'Montserrat',sans-serif;font-size:0.9rem;font-weight:600;color:var(--text);border-bottom:1px solid rgba(123,28,51,.07);transition:var(--tr)}
.drawer-nav a:hover,.drawer-nav a.active{color:var(--primary);background:rgba(123,28,51,.05);padding-left:30px}
.drawer-nav a .di{width:28px;height:28px;background:rgba(123,28,51,.08);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:0.88rem;flex-shrink:0}
.drawer-foot{padding:20px 24px;background:var(--light);border-top:1px solid rgba(123,28,51,.1)}
.drawer-foot a{display:flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;padding:13px;border-radius:50px;font-family:'Montserrat',sans-serif;font-weight:700;font-size:0.88rem;box-shadow:0 4px 16px rgba(90,14,34,.3)}

/* ============================================================
   HERO — v10 Ghost Image · Deep Maroon Gold Theme
   ============================================================ */

/* ── Shell ── */
#hero{
  position:relative;
  min-height:100svh;
  display:flex;
  align-items:center;
  overflow:hidden;
  background:#fff;
  isolation:isolate;
  max-width:100vw;
}

/* ── Premium Elegant Hero Background ── */
.hero-bg-layer{
  position:absolute;
  inset:0;
  z-index:0;
  /* Warm ivory base — cream, never dark */
  background: linear-gradient(160deg,
    #FFF8F0 0%,
    #FDF3E8 25%,
    #FAF0E0 55%,
    #F5E8D4 80%,
    #F0E0CA 100%
  );
}

/* ── Arched top border — maroon with gold dot pattern ── */
.hero-bg-layer::before{
  content:'';
  position:absolute;
  top:0; left:0; right:0;
  height:6px;
  background: repeating-linear-gradient(
    90deg,
    var(--primary) 0px, var(--primary) 18px,
    var(--gold) 18px, var(--gold) 22px,
    var(--primary) 22px, var(--primary) 40px,
    transparent 40px, transparent 48px
  );
  z-index:2;
}

/* ── Large paisley/mandala glow — left background ── */
.hero-bg-layer::after{
  content:'';
  position:absolute;
  left:-200px; top:50%;
  transform:translateY(-50%);
  width:700px; height:700px;
  border-radius:50%;
  background: radial-gradient(ellipse at center,
    rgba(123,28,51,.06) 0%,
    rgba(201,168,76,.04) 40%,
    transparent 70%
  );
  z-index:0;
}

/* ── Repeating Indian floral tile pattern ── */
.hero-pattern{
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'%3E%3Cg fill='none'%3E%3Cellipse cx='40' cy='14' rx='5' ry='9' fill='%237B1C33' fill-opacity='0.045'/%3E%3Cellipse cx='40' cy='66' rx='5' ry='9' fill='%237B1C33' fill-opacity='0.045'/%3E%3Cellipse cx='14' cy='40' rx='9' ry='5' fill='%237B1C33' fill-opacity='0.045'/%3E%3Cellipse cx='66' cy='40' rx='9' ry='5' fill='%237B1C33' fill-opacity='0.045'/%3E%3Ccircle cx='40' cy='40' r='8' stroke='%23C9A84C' stroke-width='0.6' fill='none' stroke-opacity='0.12'/%3E%3Ccircle cx='40' cy='40' r='4' fill='%23C9A84C' fill-opacity='0.07'/%3E%3Ccircle cx='40' cy='40' r='14' stroke='%237B1C33' stroke-width='0.5' fill='none' stroke-opacity='0.06'/%3E%3Ccircle cx='40' cy='40' r='22' stroke='%23C9A84C' stroke-width='0.4' fill='none' stroke-opacity='0.05'/%3E%3Cpath d='M40 6 Q44 14 40 22 Q36 14 40 6Z' fill='%23C9A84C' fill-opacity='0.06'/%3E%3Cpath d='M40 58 Q44 66 40 74 Q36 66 40 58Z' fill='%23C9A84C' fill-opacity='0.06'/%3E%3Cpath d='M6 40 Q14 44 22 40 Q14 36 6 40Z' fill='%23C9A84C' fill-opacity='0.06'/%3E%3Cpath d='M58 40 Q66 44 74 40 Q66 36 58 40Z' fill='%23C9A84C' fill-opacity='0.06'/%3E%3C/g%3E%3C/svg%3E");
  background-size:80px 80px;
}

/* ── Right-side large floral medallion ── */
.hero-medallion{
  position:absolute;
  right:-80px;
  top:50%;
  transform:translateY(-50%);
  width:680px;
  height:680px;
  z-index:1;
  pointer-events:none;
  animation:medallionSpin 60s linear infinite;
  opacity:.18;
  filter:drop-shadow(0 0 60px rgba(201,168,76,.08));
}
@keyframes medallionSpin{from{transform:translateY(-50%) rotate(0deg)}to{transform:translateY(-50%) rotate(360deg)}}

/* ── Extra corner paisley decorations ── */
#hero::before{
  content:'';
  position:absolute;
  bottom:-40px; left:-40px;
  width:280px; height:280px;
  border-radius:0 60% 0 0;
  border-top:2px solid rgba(201,168,76,.12);
  border-right:2px solid rgba(201,168,76,.08);
  z-index:1;
  pointer-events:none;
}
#hero::after{
  content:'';
  position:absolute;
  top:60px; right:0;
  width:200px; height:200px;
  background: radial-gradient(ellipse,rgba(201,168,76,.07) 0%,transparent 70%);
  z-index:1;
  pointer-events:none;
}

/* ── Floating accent petals ── */
.hero-petal{
  position:absolute;
  border-radius:50% 0 50% 0;
  animation:petalFloat ease-in-out infinite;
  pointer-events:none;
  z-index:1;
}
@keyframes petalFloat{
  0%,100%{transform:translateY(0) rotate(0deg);opacity:.7}
  50%{transform:translateY(-18px) rotate(8deg);opacity:1}
}

/* ── Gold shimmer line top ── */
.hero-shimmer-line{
  position:absolute;
  top:0;left:0;right:0;
  height:3px;
  background:linear-gradient(90deg, transparent, var(--gold), rgba(201,168,76,.6), var(--gold), transparent);
  background-size:400% 100%;
  animation:shimmerMove 3.5s ease infinite;
  z-index:4;
}
@keyframes shimmerMove{0%,100%{background-position:0%}50%{background-position:100%}}

/* ── Two-column hero layout ── */
.hero-inner{
  position:relative;
  z-index:3;
  display:grid;
  grid-template-columns:1fr 420px;
  align-items:center;
  gap:60px;
  width:100%;
  padding-top:calc(var(--nav-h) + 28px);
  padding-bottom:60px;
}

/* ── Left: Text content ── */
.hero-content{max-width:640px}

/* ── Full-width centered text layout ── */
.hero-text-center{
  position:relative;z-index:5;
  display:flex;flex-direction:column;align-items:center;
  text-align:center;
  padding-top:calc(var(--nav-h) + 60px);
  padding-bottom:80px;
  width:100%;max-width:780px;margin:0 auto;
}
.hero-actions--center{justify-content:center}
.hero-br-desk{display:inline}
@media(max-width:600px){
  .hero-text-center{padding-top:calc(var(--nav-h) + 28px);padding-bottom:60px}
  .hero-actions--center{flex-direction:column;align-items:center}
  .hero-actions--center .btn{width:100%;max-width:320px;justify-content:center;padding:14px 24px;font-size:0.95rem}
  .hero-br-desk{display:none}
}

.hero-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:rgba(123,28,51,.07);
  border:1px solid rgba(123,28,51,.16);
  color:var(--primary);
  font-family:'Montserrat',sans-serif;
  font-size:0.68rem;
  font-weight:700;
  letter-spacing:2.5px;
  text-transform:uppercase;
  padding:8px 20px;
  border-radius:50px;
  margin-bottom:22px;
  animation:fadeSlideUp .9s ease both;
  max-width:fit-content;
  white-space:nowrap;
}
.hero-badge::before{content:'✦';color:var(--gold)}

.hero-h1{
  font-family:'Cinzel',serif;
  font-size:clamp(2rem,4.5vw,3.8rem);
  font-weight:800;
  color:var(--accent);
  line-height:1.08;
  margin-bottom:14px;
  animation:fadeSlideUp .9s .12s ease both;
}
.hero-h1 em{
  color:var(--primary);
  font-style:italic;
  background:linear-gradient(135deg,var(--primary),var(--gold));
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

.hero-sub{
  font-family:'Montserrat',sans-serif;
  font-size:clamp(.95rem,1.8vw,1.2rem);
  font-weight:600;
  color:var(--primary);
  font-style:italic;
  margin-bottom:16px;
  animation:fadeSlideUp .9s .22s ease both;
  opacity:.85;
}

.hero-p{
  font-family:'Poppins',sans-serif;
  font-size:0.94rem;
  color:#6B5B4E;
  max-width:500px;
  margin-bottom:36px;
  line-height:1.9;
  animation:fadeSlideUp .9s .32s ease both;
}
.hero-p strong{color:var(--primary);font-weight:600}

.hero-actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  animation:fadeSlideUp .9s .42s ease both;
}

/* Stats strip inside hero */
.hero-stats-row{
  display:flex;
  gap:0;
  margin-top:52px;
  animation:fadeSlideUp .9s .52s ease both;
  border:1px solid rgba(123,28,51,.12);
  border-radius:16px;
  overflow:hidden;
  background:#fff;
  box-shadow:0 4px 24px rgba(123,28,51,.08);
  width:fit-content;
}
.hero-stat-item{
  padding:18px 28px;
  border-right:1px solid rgba(123,28,51,.1);
  text-align:center;
}
.hero-stat-item:last-child{border-right:none}
.hero-stat-num{
  font-family:'Cinzel',serif;
  font-size:1.8rem;
  font-weight:700;
  color:var(--primary);
  line-height:1;
}
.hero-stat-lbl{
  font-family:'Poppins',sans-serif;
  font-size:0.68rem;
  color:var(--muted);
  margin-top:4px;
  text-transform:uppercase;
  letter-spacing:1px;
}

/* ── Right: Decorative card panel ── */
.hero-visual{
  position:relative;
  display:flex;
  flex-direction:column;
  gap:16px;
  animation:fadeSlideUp .9s .2s ease both;
}

/* ── Specialisation card (right column) ── */
.hero-visual-main{
  background:#fff;
  border-radius:22px;
  padding:28px 24px 22px;
  box-shadow:0 16px 52px rgba(123,28,51,.11), 0 3px 12px rgba(123,28,51,.05);
  border:1px solid rgba(123,28,51,.1);
  text-align:center;
  position:relative;
  overflow:hidden;
}
.hero-visual-main::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--primary),var(--gold),var(--primary));
  background-size:200% 100%;
  animation:shimmerMove 2.5s ease infinite;
}

/* intro line */
.hero-card-intro{
  font-family:'Poppins',sans-serif;font-size:0.72rem;font-weight:600;
  letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);
  margin-bottom:10px;
}

/* Slideshow wrapper */
.hero-spec-slider{
  position:relative;
  min-height:148px;
  margin-bottom:16px;
}
.hero-spec-slide{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:8px;
  opacity:0;
  transform:translateY(14px);
  transition:opacity .55s ease, transform .55s ease;
  pointer-events:none;
}
.hero-spec-slide.active{
  opacity:1;transform:translateY(0);pointer-events:auto;
}
.hero-spec-icon{
  font-size:2rem;
  width:64px;height:64px;
  background:linear-gradient(135deg,rgba(123,28,51,.07),rgba(201,168,76,.1));
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  border:1.5px solid rgba(123,28,51,.12);
  flex-shrink:0;
}
.hero-spec-name{
  font-family:'Cinzel',serif;font-size:1rem;font-weight:700;color:var(--accent);
}
.hero-spec-desc{
  font-family:'Poppins',sans-serif;font-size:0.76rem;color:var(--muted);
  line-height:1.65;max-width:240px;margin:0 auto;
}

/* Slider dots */
.hero-spec-dots{
  display:flex;gap:6px;justify-content:center;margin-bottom:16px;
}
.hero-spec-dot{
  width:6px;height:6px;border-radius:50%;
  background:rgba(123,28,51,.18);border:none;cursor:pointer;padding:0;
  transition:.3s;
}
.hero-spec-dot.active{
  background:var(--primary);width:20px;border-radius:3px;
}

/* Progress bar */
.hero-spec-progress{
  height:2px;background:rgba(123,28,51,.08);border-radius:2px;
  margin-bottom:16px;overflow:hidden;
}
.hero-spec-bar{
  height:100%;background:linear-gradient(90deg,var(--primary),var(--gold));
  border-radius:2px;width:0%;
  transition:width .1s linear;
}

/* Rating row */
.hero-rating{
  display:flex;align-items:center;justify-content:center;gap:8px;
  background:linear-gradient(135deg,rgba(201,168,76,.07),rgba(123,28,51,.04));
  border:1px solid rgba(201,168,76,.22);
  border-radius:10px;padding:10px 14px;
}
.hero-stars{color:var(--gold);font-size:0.9rem;letter-spacing:2px}
.hero-rating-text{font-family:'Poppins',sans-serif;font-size:0.75rem;color:var(--accent);font-weight:600}

/* Two stat cards below */
.hero-visual-cards{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.hero-mini-card{
  background:#fff;border-radius:14px;padding:14px 12px;
  box-shadow:0 6px 20px rgba(123,28,51,.07);
  border:1px solid rgba(123,28,51,.08);
  text-align:center;transition:.3s;
}
.hero-mini-card:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(123,28,51,.12)}
.hero-mini-icon{font-size:1.3rem;margin-bottom:5px}
.hero-mini-label{font-family:'Cinzel',serif;font-size:0.72rem;font-weight:700;color:var(--accent);margin-bottom:2px}
.hero-mini-val{font-family:'Poppins',sans-serif;font-size:0.66rem;color:var(--muted)}

/* Floating dots */
.hero-dot-accent{
  position:absolute;
  border-radius:50%;
  background:linear-gradient(135deg,var(--primary),var(--gold));
  animation:dotPulse 3s ease-in-out infinite;
}
@keyframes dotPulse{0%,100%{transform:scale(1);opacity:.6}50%{transform:scale(1.2);opacity:.9}}

@keyframes fadeSlideUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}

/* ── Slide dots (repurposed as section indicators) ── */
.hero-dots{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:5}
.hero-dot-ind{width:6px;height:6px;border-radius:50%;background:rgba(123,28,51,.2);cursor:default}
.hero-dot-ind.active{background:var(--primary);width:22px;border-radius:3px}

/* Mobile hero */
@media(max-width:960px){
  .hero-inner{grid-template-columns:1fr;gap:24px;padding-bottom:36px}
  .hero-visual{max-width:400px;margin:0 auto;width:100%}
  .hero-h1{font-size:clamp(2rem,5.5vw,3rem)}
  .hero-stats-row{width:100%}
}
@media(max-width:600px){
  #hero{min-height:100svh;padding:0;background:transparent}
  .hero-inner{
    gap:18px;
    padding-top:calc(var(--nav-h) + 16px);
    padding-bottom:28px;
  }
  .hero-badge{
    font-size:0.68rem;
    padding:8px 18px;
    margin-bottom:18px;
    max-width:calc(100vw - 40px);
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    display:inline-flex;
  }
  .hero-h1{font-size:2.1rem !important;line-height:1.1;margin-bottom:12px}
  .hero-sub{font-size:1.1rem;margin-bottom:12px}
  .hero-p{font-size:0.97rem;margin-bottom:24px;line-height:1.85}
  .hero-stat-item{padding:10px 12px}
  .hero-stat-num{font-size:1.15rem}
  .hero-stat-lbl{font-size:0.58rem}
  .hero-stats-row{width:100%;margin-top:18px}
  .hero-visual-main{padding:18px 14px}
  .hero-spec-slider{min-height:120px}
  .hero-spec-icon{width:52px;height:52px;font-size:1.6rem}
  .hero-spec-name{font-size:0.88rem}
  .hero-spec-desc{font-size:0.7rem}
  .hero-visual-cards{grid-template-columns:1fr 1fr;gap:8px}
  .hero-mini-card{padding:10px 7px}
  .hero-mini-icon{font-size:1.1rem}
  .hero-mini-label{font-size:0.65rem}
  .hero-mini-val{font-size:0.6rem}
  .hero-actions{gap:10px}
  .hero-actions .btn{font-size:0.8rem;padding:10px 18px}
  .hero-card-intro{font-size:0.62rem}
  .hero-rating{padding:8px 10px}
  .hero-stars{font-size:0.8rem}
  .hero-rating-text{font-size:0.68rem}
}

/* Scroll indicator hidden */
.hero-scroll{display:none}

/* ============================================================
   ANNOUNCEMENT BAR (dynamic scroll ticker)
   ============================================================ */
.announcement-bar{background:linear-gradient(90deg,var(--accent),var(--primary),var(--gold),var(--primary),var(--accent));background-size:400% 100%;animation:gradientShift 6s ease infinite;overflow:hidden;white-space:nowrap;padding:0}
@keyframes gradientShift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.ticker-wrap{display:flex;overflow:hidden;padding:10px 0}
.ticker{display:flex;gap:0;animation:ticker-scroll 28s linear infinite}
.ticker-item{font-family:'Montserrat',sans-serif;font-size:0.75rem;font-weight:600;color:#fff;letter-spacing:1.5px;text-transform:uppercase;padding:0 40px;display:flex;align-items:center;gap:12px;flex-shrink:0}
.ticker-item::after{content:'✦';color:rgba(255,255,255,.5)}
@keyframes ticker-scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ============================================================
   STATS BAR
   ============================================================ */
.stats-bar{background:linear-gradient(135deg,var(--accent),var(--primary));padding:40px 0;position:relative;overflow:hidden}
@media(max-width:600px){.stats-bar{padding:22px 0}}
.stats-bar::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Ccircle cx='40' cy='40' r='30'/%3E%3C/g%3E%3C/svg%3E")}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative;z-index:1}
.stat-item{text-align:center;padding:20px 16px;border-right:1px solid rgba(255,255,255,.12)}
.stat-item:last-child{border-right:none}
.stat-num{font-family:'Cinzel',serif;font-size:2.6rem;font-weight:700;color:#fff;line-height:1;text-shadow:0 2px 12px rgba(0,0,0,.2)}
.stat-lbl{font-family:'Montserrat',sans-serif;font-size:0.72rem;font-weight:600;color:rgba(255,255,255,.65);letter-spacing:2px;text-transform:uppercase;margin-top:7px}

/* ============================================================
   PAGE HERO (inner pages) — with animated gradient
   ============================================================ */
.page-hero{padding:calc(var(--nav-h) + 60px) 0 60px;position:relative;overflow:hidden;text-align:center}
.page-hero-bg{position:absolute;inset:0;background:linear-gradient(135deg,var(--accent) 0%,var(--primary) 50%,#a0354a 100%);background-size:300% 300%;animation:gradientShift 8s ease infinite}
.page-hero-overlay{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='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4z'/%3E%3C/g%3E%3C/svg%3E")}
.page-hero-content{position:relative;z-index:1}
.page-hero h1{font-family:'Cinzel',serif;font-size:clamp(1.5rem,4vw,2.4rem);font-weight:700;color:#fff;margin-bottom:14px;text-shadow:0 2px 16px rgba(0,0,0,.3)}
.page-hero p{font-family:'Poppins',sans-serif;color:rgba(255,255,255,.8);font-size:1rem;max-width:560px;margin:0 auto}
.breadcrumb{display:flex;align-items:center;gap:8px;justify-content:center;margin-bottom:18px;font-family:'Montserrat',sans-serif;font-size:0.78rem;font-weight:500;color:rgba(255,255,255,.6)}
.breadcrumb a{color:rgba(255,255,255,.8)}
.breadcrumb a:hover{color:var(--gold)}
.breadcrumb span{color:rgba(255,255,255,.35)}

/* ============================================================
   ABOUT SECTION
   ============================================================ */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.about-visual{position:relative}
.about-img-main{width:100%;height:500px;object-fit:cover;object-position:top center;border-radius:var(--radius);box-shadow:0 20px 56px var(--shadow)}
.about-badge-fl{position:absolute;bottom:-28px;right:-28px;background:#fff;border-radius:var(--radius);padding:22px 26px;box-shadow:0 10px 36px var(--shadow);display:flex;flex-direction:column;align-items:center;gap:4px;min-width:130px}
.about-badge-fl .num{font-family:'Cinzel',serif;font-size:2.6rem;font-weight:700;color:var(--primary);line-height:1}
.about-badge-fl .lbl{font-family:'Montserrat',sans-serif;font-size:0.7rem;font-weight:600;color:#888;text-align:center;line-height:1.4;letter-spacing:1px;text-transform:uppercase}
.about-feats{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:26px 0}
.af-item{display:flex;align-items:flex-start;gap:12px;padding:14px;background:var(--light);border-radius:10px;border:1px solid rgba(123,28,51,.08);transition:var(--tr)}
.af-item:hover{border-color:rgba(123,28,51,.2);box-shadow:0 4px 16px rgba(90,14,34,.08);transform:translateY(-2px)}
.af-icon{font-size:1.35rem;flex-shrink:0;margin-top:2px}
.af-title{font-family:'Montserrat',sans-serif;font-size:0.82rem;font-weight:700;color:var(--accent);margin-bottom:2px}
.af-desc{font-family:'Poppins',sans-serif;font-size:0.76rem;color:var(--muted)}

/* ============================================================
   SERVICES
   ============================================================ */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.svc-card{background:#fff;border:1px solid rgba(123,28,51,.12);border-radius:var(--radius);overflow:hidden;transition:var(--tr);display:flex;flex-direction:column}
.svc-card:hover{transform:translateY(-8px);box-shadow:0 16px 48px var(--shadow);border-color:rgba(123,28,51,.25)}
.svc-img{height:220px;overflow:hidden;position:relative;background:var(--light)}
.svc-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.svc-card:hover .svc-img img{transform:scale(1.07)}
.svc-img-overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(90,14,34,.55) 0%,transparent 60%);opacity:0;transition:var(--tr)}
.svc-card:hover .svc-img-overlay{opacity:1}
.svc-body{padding:26px 22px;flex:1;display:flex;flex-direction:column;gap:10px}
.svc-body .btn{margin-top:auto;align-self:flex-start;width:100%;justify-content:center}
.svc-name{font-family:'Cinzel',serif;font-size:1.15rem;font-weight:600;color:var(--accent);margin-bottom:10px}
.svc-desc{font-family:'Poppins',sans-serif;font-size:0.85rem;color:var(--muted);line-height:1.8;flex:1;margin-bottom:18px}
.svc-includes{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.svc-includes li{display:flex;align-items:center;gap:7px;font-family:'Poppins',sans-serif;font-size:0.8rem;color:#666}
.svc-includes li::before{content:'✓';color:var(--gold);font-weight:700;flex-shrink:0}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery-filter{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:36px 0 32px}
.filter-btn{padding:10px 26px;border-radius:50px;border:2px solid rgba(123,28,51,.2);color:var(--muted);font-family:'Montserrat',sans-serif;font-size:0.82rem;font-weight:600;transition:var(--tr);background:#fff;cursor:pointer}
.filter-btn.active,.filter-btn:hover{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border-color:transparent;box-shadow:0 6px 20px rgba(90,14,34,.3)}

.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gallery-item{position:relative;border-radius:var(--radius);overflow:hidden;cursor:pointer;background:var(--light);aspect-ratio:3/4}
.gallery-item.wide{aspect-ratio:4/3}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .55s ease}
.gallery-item:hover img{transform:scale(1.07)}
.g-overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(90,14,34,.78) 0%,transparent 55%);opacity:0;transition:var(--tr);display:flex;align-items:flex-end;padding:18px}
.g-overlay span{font-family:'Montserrat',sans-serif;font-size:0.82rem;font-weight:600;color:#fff;letter-spacing:.5px}
.gallery-item:hover .g-overlay{opacity:1}

/* Lightbox */
#lightbox{position:fixed;inset:0;background:rgba(0,0,0,.96);z-index:9999;display:none;align-items:center;justify-content:center;padding:20px}
#lightbox.open{display:flex}
#lb-img{max-width:88vw;max-height:86vh;object-fit:contain;border-radius:10px;animation:lbIn .35s ease}
@keyframes lbIn{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}
.lb-close{position:absolute;top:20px;right:24px;color:#fff;font-size:2.8rem;cursor:pointer;opacity:.75;transition:var(--tr);line-height:1}
.lb-close:hover{opacity:1;transform:scale(1.15)}
.lb-prev,.lb-next{position:absolute;top:50%;transform:translateY(-50%);color:#fff;font-size:3.5rem;cursor:pointer;opacity:.6;transition:var(--tr);padding:0 20px;user-select:none;line-height:1}
.lb-prev{left:0}.lb-next{right:0}
.lb-prev:hover,.lb-next:hover{opacity:1}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testi-section{background:linear-gradient(135deg,var(--accent) 0%,#8B2535 100%);position:relative;overflow:hidden}
.testi-section::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='50' cy='50' r='40' fill='none' stroke='%23ffffff' stroke-opacity='0.03' stroke-width='1'/%3E%3C/svg%3E") repeat}
.testi-slider{position:relative;overflow:hidden;z-index:1}
.testi-track{display:flex;transition:transform .6s cubic-bezier(.4,0,.2,1)}
.testi-card{flex:0 0 calc(33.333% - 16px);margin-right:24px;background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.14);border-radius:16px;padding:34px 28px;backdrop-filter:blur(10px);transition:var(--tr)}
.testi-card:hover{background:rgba(255,255,255,.15);transform:translateY(-4px)}
.stars{color:var(--gold);font-size:1.1rem;letter-spacing:3px;margin-bottom:16px}
.testi-text{font-family:'Poppins',sans-serif;color:rgba(255,255,255,.85);font-size:0.9rem;line-height:1.88;font-style:italic;margin-bottom:22px}
.testi-author{display:flex;align-items:center;gap:14px}
.t-avatar{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--primary));display:flex;align-items:center;justify-content:center;font-family:'Cinzel',serif;font-weight:700;color:#fff;font-size:1.1rem;flex-shrink:0}
.t-name{font-family:'Montserrat',sans-serif;font-weight:700;color:#fff;font-size:0.9rem}
.t-loc{font-family:'Poppins',sans-serif;font-size:0.76rem;color:rgba(255,255,255,.5);margin-top:2px}
.testi-controls{display:flex;align-items:center;gap:14px;justify-content:center;margin-top:32px;z-index:1;position:relative}
.t-prev,.t-next{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--tr);font-size:1.2rem}
.t-prev:hover,.t-next:hover{background:var(--gold);border-color:var(--gold)}
.t-dots{display:flex;gap:8px}
.t-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.3);cursor:pointer;transition:var(--tr);border:none}
.t-dot.active{background:var(--gold);width:24px;border-radius:4px}

/* ============================================================
   ACADEMY / COURSES
   ============================================================ */
.courses-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.course-card{background:#fff;border:1px solid rgba(123,28,51,.12);border-radius:16px;padding:32px 28px;transition:var(--tr);position:relative;overflow:hidden}
.course-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary),var(--gold));transform:scaleX(0);transform-origin:left;transition:transform .4s ease}
.course-card:hover{transform:translateY(-7px);box-shadow:0 18px 52px var(--shadow)}
.course-card:hover::before{transform:scaleX(1)}
.c-badge{display:inline-block;background:linear-gradient(135deg,var(--accent),var(--primary));color:#fff;font-family:'Montserrat',sans-serif;font-size:0.68rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:5px 14px;border-radius:50px;margin-bottom:16px}
.c-name{font-family:'Cinzel',serif;font-size:1.25rem;font-weight:600;color:var(--accent);margin-bottom:12px}
.c-desc{font-family:'Poppins',sans-serif;font-size:0.86rem;color:var(--muted);line-height:1.85;margin-bottom:18px}
.c-meta{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:16px}
.c-meta span{display:flex;align-items:center;gap:6px;font-family:'Poppins',sans-serif;font-size:0.76rem;color:var(--muted);background:var(--light);padding:5px 12px;border-radius:50px}
.c-list{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.c-list li{display:flex;align-items:center;gap:8px;font-family:'Poppins',sans-serif;font-size:0.8rem;color:#666}
.c-list li::before{content:'✓';color:var(--gold);font-weight:700;flex-shrink:0}
.cert-badge{display:inline-flex;align-items:center;gap:7px;background:rgba(201,168,76,.1);color:var(--gold2);font-family:'Montserrat',sans-serif;font-size:0.76rem;font-weight:700;padding:6px 14px;border-radius:50px;border:1px solid rgba(201,168,76,.3)}

/* ============================================================
   CONTACT FORM
   ============================================================ */
.contact-info-card{background:linear-gradient(135deg,var(--accent),var(--primary));border-radius:16px;padding:40px 32px;color:#fff}
.ci-title{font-family:'Cinzel',serif;font-size:1.5rem;font-weight:600;color:#fff;margin-bottom:6px}
.ci-sub{font-family:'Poppins',sans-serif;color:rgba(255,255,255,.72);font-size:0.88rem;margin-bottom:30px}
.c-item{display:flex;align-items:flex-start;gap:14px;margin-bottom:20px}
.c-icon{width:40px;height:40px;background:rgba(255,255,255,.15);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.c-label{font-family:'Montserrat',sans-serif;font-size:0.68rem;font-weight:600;color:rgba(255,255,255,.55);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:3px}
.c-val{font-family:'Poppins',sans-serif;color:#fff;font-size:0.9rem}
.c-val a{color:#fff}.c-val a:hover{color:var(--gold)}
.social-row{display:flex;gap:10px;margin-top:26px}
.s-btn{width:40px;height:40px;background:rgba(255,255,255,.14);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;transition:var(--tr)}
.s-btn:hover{background:var(--gold)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}
.form-group label{font-family:'Montserrat',sans-serif;font-size:0.78rem;font-weight:700;color:var(--accent);letter-spacing:.4px}
.form-group input,.form-group select,.form-group textarea{padding:12px 16px;border:1.5px solid rgba(123,28,51,.2);border-radius:10px;font-family:'Poppins',sans-serif;font-size:0.88rem;color:var(--text);background:#fff;transition:var(--tr);outline:none;width:100%}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(123,28,51,.1)}
.form-group textarea{resize:vertical;min-height:120px}
.form-success{display:none;align-items:center;gap:10px;background:rgba(46,125,50,.08);border:1px solid rgba(46,125,50,.3);color:#2e7d32;padding:14px 18px;border-radius:10px;margin-top:14px;font-family:'Poppins',sans-serif;font-size:0.88rem}

/* ============================================================
   PRICING
   ============================================================ */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.p-card{background:#fff;border:2px solid rgba(123,28,51,.14);border-radius:20px;padding:38px 28px;text-align:center;transition:var(--tr);position:relative;overflow:hidden}
.p-card.featured{border-color:var(--gold);box-shadow:0 18px 52px rgba(201,168,76,.2)}
.p-card.featured::after{content:'Most Popular';position:absolute;top:20px;right:-24px;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#fff;font-family:'Montserrat',sans-serif;font-size:0.65rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:5px 40px;transform:rotate(45deg);transform-origin:top right}
.p-card:hover{transform:translateY(-8px);box-shadow:0 18px 52px var(--shadow)}
.p-icon{font-size:2.6rem;margin-bottom:16px}
.p-name{font-family:'Cinzel',serif;font-size:1.25rem;color:var(--accent);margin-bottom:10px}
.p-price{font-family:'Cinzel',serif;font-size:2.5rem;font-weight:700;color:var(--gold);line-height:1;margin-bottom:8px}
.p-price small{font-family:'Poppins',sans-serif;font-size:0.85rem;color:var(--muted);font-weight:400}
.p-desc{font-family:'Poppins',sans-serif;font-size:0.84rem;color:var(--muted);margin-bottom:20px;line-height:1.65}
.p-features{display:flex;flex-direction:column;gap:9px;margin-bottom:26px;text-align:left}
.p-features li{display:flex;align-items:center;gap:8px;font-family:'Poppins',sans-serif;font-size:0.82rem;color:#666}
.p-features li::before{content:'✓';color:var(--gold);font-weight:700;flex-shrink:0}

/* ============================================================
   BLOG
   ============================================================ */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.blog-card{background:#fff;border-radius:var(--radius);border:1px solid rgba(123,28,51,.1);overflow:hidden;transition:var(--tr)}
.blog-card:hover{transform:translateY(-6px);box-shadow:0 14px 42px var(--shadow)}
.blog-thumb{height:210px;display:flex;align-items:center;justify-content:center;font-size:3.5rem;position:relative;overflow:hidden}
.blog-body{padding:24px}
.b-cat{display:inline-block;font-family:'Montserrat',sans-serif;font-size:0.68rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--primary);background:rgba(123,28,51,.08);padding:4px 12px;border-radius:50px;margin-bottom:10px}
.b-title{font-family:'Cinzel',serif;font-size:1.05rem;font-weight:600;color:var(--accent);margin-bottom:10px;line-height:1.4}
.b-excerpt{font-family:'Poppins',sans-serif;font-size:0.83rem;color:var(--muted);line-height:1.75;margin-bottom:16px}
.b-meta{display:flex;align-items:center;justify-content:space-between;font-family:'Poppins',sans-serif;font-size:0.76rem;color:#aaa}
.b-more{color:var(--primary);font-family:'Montserrat',sans-serif;font-weight:700;font-size:0.8rem;display:inline-flex;align-items:center;gap:4px;transition:var(--tr)}
.b-more:hover{gap:8px}

/* ============================================================
   FAQ
   ============================================================ */
.faq-wrap{max-width:760px;margin:0 auto}
.faq-item{background:#fff;border:1.5px solid rgba(123,28,51,.12);border-radius:12px;margin-bottom:12px;overflow:hidden;transition:var(--tr)}
.faq-item.open{border-color:rgba(123,28,51,.35);box-shadow:0 6px 24px var(--shadow)}
.faq-q{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;cursor:pointer;gap:12px}
.faq-q-text{font-family:'Montserrat',sans-serif;font-weight:600;font-size:0.92rem;color:var(--text)}
.faq-icon{width:30px;height:30px;background:rgba(123,28,51,.1);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--primary);font-size:1.15rem;transition:var(--tr);flex-shrink:0}
.faq-item.open .faq-icon{transform:rotate(45deg);background:var(--primary);color:#fff}
.faq-ans{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-item.open .faq-ans{max-height:300px}
.faq-ans-inner{padding:0 22px 20px;font-family:'Poppins',sans-serif;font-size:0.88rem;color:var(--muted);line-height:1.85}

/* ============================================================
   VALUES / ABOUT PAGE
   ============================================================ */
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.v-card{padding:32px 24px;border-radius:var(--radius);border:1px solid rgba(123,28,51,.13);background:#fff;text-align:center;transition:var(--tr)}
.v-card:hover{transform:translateY(-6px);box-shadow:0 14px 42px var(--shadow);border-color:rgba(123,28,51,.25)}
.v-icon{font-size:2.2rem;margin-bottom:14px}
.v-title{font-family:'Cinzel',serif;font-size:1.1rem;color:var(--accent);margin-bottom:8px}
.v-desc{font-family:'Poppins',sans-serif;font-size:0.84rem;color:var(--muted);line-height:1.78}

/* Founder block */
.founder-block{display:grid;grid-template-columns:1fr 1.2fr;gap:64px;align-items:center}
.founder-img-wrap{position:relative}
.founder-img{width:100%;height:540px;object-fit:cover;object-position:top;border-radius:16px;box-shadow:0 20px 60px var(--shadow)}
.founder-quote{position:absolute;bottom:-20px;left:-20px;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#fff;padding:18px 22px;border-radius:12px;font-family:'Great Vibes',cursive;font-size:1.3rem;max-width:240px;line-height:1.4;box-shadow:0 8px 28px rgba(201,168,76,.45)}

/* Why-academy block */
.why-academy{background:linear-gradient(135deg,var(--accent),var(--primary));border-radius:20px;padding:56px 48px}
.why-list{display:flex;flex-direction:column;gap:14px;margin-top:24px}
.why-item{display:flex;align-items:flex-start;gap:14px;padding:14px;background:rgba(255,255,255,.1);border-radius:10px}
.wi-icon{font-size:1.3rem;flex-shrink:0;margin-top:2px}
.wi-text strong{display:block;font-family:'Montserrat',sans-serif;color:#fff;font-size:0.88rem;margin-bottom:3px}
.wi-text span{font-family:'Poppins',sans-serif;color:rgba(255,255,255,.68);font-size:0.8rem}

/* ============================================================
   FOOTER
   ============================================================ */
footer{background:#120710}
.footer-top{padding:80px 0 52px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:52px}
.f-brand-name{font-family:'Cinzel',serif;font-size:1.6rem;font-weight:700;color:#fff}
.f-brand-sub{font-family:'Montserrat',sans-serif;font-size:0.58rem;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.3);margin:3px 0 14px}
.f-brand p{font-family:'Poppins',sans-serif;color:rgba(255,255,255,.45);font-size:0.84rem;line-height:1.85}
.f-social{display:flex;gap:9px;margin-top:20px}
.f-social a{width:36px;height:36px;background:rgba(255,255,255,.07);border-radius:8px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.55);font-size:0.88rem;transition:var(--tr)}
.f-social a:hover{background:var(--primary);color:#fff}
.f-col h4{font-family:'Cinzel',serif;font-size:1rem;font-weight:600;color:rgba(255,255,255,.88);margin-bottom:18px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.07)}
.f-col ul li{margin-bottom:10px}
.f-col ul li a{font-family:'Poppins',sans-serif;font-size:0.83rem;color:rgba(255,255,255,.45);transition:var(--tr);display:flex;align-items:center;gap:6px}
.f-col ul li a:hover{color:var(--primary);padding-left:4px}
.f-ci{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px;font-family:'Poppins',sans-serif;font-size:0.83rem;color:rgba(255,255,255,.3)}
.f-ci span{color:rgba(255,255,255,.3);flex-shrink:0;margin-top:2px}
.f-ci i{color:rgba(255,255,255,.3)}
.f-ci a{color:rgba(255,255,255,.3);transition:var(--tr)}.f-ci a:hover{color:var(--gold)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding:22px 0}
.fb-inner{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;font-family:'Poppins',sans-serif;font-size:0.78rem;color:rgba(255,255,255,.28)}
.fb-inner a{color:rgba(255,255,255,.38);transition:var(--tr)}.fb-inner a:hover{color:var(--primary)}

/* ============================================================
   SCROLL TOP
   ============================================================ */
#scrollTop{position:fixed;bottom:26px;right:26px;width:46px;height:46px;background:linear-gradient(135deg,var(--accent),var(--primary));color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;box-shadow:0 6px 22px var(--shadow);opacity:0;transform:translateY(20px);pointer-events:none;transition:var(--tr);z-index:900;border:none;cursor:pointer}
#scrollTop.show{opacity:1;transform:translateY(0);pointer-events:all}
#scrollTop:hover{transform:translateY(-4px);box-shadow:0 12px 32px var(--shadow)}

/* ============================================================
   ANIMATIONS
   ============================================================ */
.fade-up{opacity:0;transform:translateY(32px);transition:opacity .7s ease,transform .7s ease}
.fade-left{opacity:0;transform:translateX(-32px);transition:opacity .7s ease,transform .7s ease}
.fade-right{opacity:0;transform:translateX(32px);transition:opacity .7s ease,transform .7s ease}
.fade-up.vis,.fade-left.vis,.fade-right.vis{opacity:1;transform:none}

/* ============================================================
   RESPONSIVE — TABLET ≤960px
   ============================================================ */
@media(max-width:960px){
  :root{--nav-h:68px}
  .nav-links{display:none}
  .hamburger{display:flex}
  .about-grid,.founder-block{grid-template-columns:1fr;gap:40px}
  .about-visual,.founder-img-wrap{max-width:480px;margin:0 auto}
  .about-img-main,.founder-img{height:360px}
  .about-badge-fl{right:0;bottom:0}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .testi-card{flex:0 0 calc(50% - 12px)}
  .courses-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat-item:nth-child(2){border-right:none}
  .stat-item:nth-child(3){border-right:1px solid rgba(255,255,255,.12)}
  .values-grid{grid-template-columns:repeat(2,1fr)}
  .pricing-grid,.blog-grid{grid-template-columns:repeat(2,1fr)}
  .about-feats{grid-template-columns:1fr 1fr}
  .contact-page-grid,.contact-grid{grid-template-columns:1fr!important;gap:32px}
  .why-academy{padding:36px 28px}
}

/* ============================================================
   RESPONSIVE — MOBILE ≤600px
   ============================================================ */
@media(max-width:600px){
  :root{--nav-h:62px}
  .container{padding:0 16px}
  .section-pad{padding:60px 0}

  /* Hero — sizes handled in hero-specific block above */
  .hero-actions{flex-direction:column;align-items:stretch}
  .hero-actions .btn{width:100%;justify-content:center}

  /* Stats */
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat-item{border-right:1px solid rgba(255,255,255,.1)!important;border-bottom:1px solid rgba(255,255,255,.1);padding:10px 6px}
  .stat-item:nth-child(even){border-right:none!important}
  .stat-item:nth-child(3),.stat-item:nth-child(4){border-bottom:none}
  .stat-num{font-size:1.1rem;line-height:1}
  .stat-lbl{font-size:0.58rem;letter-spacing:1px;margin-top:4px}

  /* About */
  .about-visual,.founder-img-wrap{max-width:100%}
  .about-img-main,.founder-img{height:270px}
  .about-badge-fl{position:static;margin-top:16px;display:inline-flex;flex-direction:row;gap:12px;align-items:center;padding:14px 18px}
  .about-badge-fl .num{font-size:2rem}
  .about-feats{grid-template-columns:1fr}
  .founder-quote{position:static;display:inline-block;margin-top:16px;font-size:1.05rem}

  /* Services */
  .services-grid{grid-template-columns:1fr}
  .svc-img{height:200px}

  /* Gallery */
  .gallery-grid{grid-template-columns:1fr 1fr;gap:10px}
  .gallery-filter{gap:6px}
  .filter-btn{padding:8px 16px;font-size:0.78rem}

  /* Testimonials */
  .testi-card{flex:0 0 calc(100%)}

  /* Courses */
  .courses-grid{grid-template-columns:1fr}
  .course-card{padding:24px 18px}

  /* Blog/Pricing */
  .blog-grid,.pricing-grid{grid-template-columns:1fr}
  .p-card.featured::after{display:none}

  /* Values */
  .values-grid{grid-template-columns:1fr}

  /* Footer */
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .footer-top{padding:52px 0 36px}
  .fb-inner{flex-direction:column;text-align:center}

  /* Page hero */
  .page-hero{padding:calc(var(--nav-h) + 36px) 0 40px}
  .page-hero h1{font-size:1.75rem}

  /* Why academy */
  .why-academy{padding:32px 20px}

  /* Form */
  .form-row{grid-template-columns:1fr}

  /* Headings */
  .heading-xl{font-size:1.85rem}
  .heading-lg{font-size:1.6rem}
  .heading-md{font-size:1.25rem}

  /* Scroll/float */
  #scrollTop{bottom:18px;right:18px;width:42px;height:42px;font-size:0.9rem}
}

@media(max-width:380px){
  .hero-h1{font-size:1.8rem !important}
  .gallery-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
}

/* ── MOBILE CRITICAL FIXES ── */
/* Hide logo subtitle everywhere - cleaner look */
.logo-sub{display:none!important}
/* Hide announcement bar completely */
.announcement-bar{display:none!important}

@media(max-width:600px){
  /* Navbar */
  #navbar{height:60px}
  #navbar .container{padding:0 14px;gap:0;overflow:visible}
  .nav-logo{gap:9px;flex-shrink:1;min-width:0;max-width:calc(100vw - 60px)}
  .logo-icon{width:38px;height:38px;flex-shrink:0}
  .logo-name{font-family:'Cinzel',serif;font-size:0.78rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px;line-height:1.2}
  .hamburger{flex-shrink:0;margin-left:auto}
  /* Page hero title font size on small screens */
  .page-hero h1{font-size:1.55rem;word-break:break-word;hyphens:auto}
  /* Hero — sizes handled in hero-specific block above */
  /* Drawer full width on small screens */
  .mobile-drawer{width:100vw}
}
@media(max-width:400px){
  .logo-name{font-size:0.72rem;max-width:160px}
  .page-hero h1{font-size:1.35rem}
}


/* ══ MOBILE CRITICAL FIXES v2 ══ */
@media(max-width:600px){
  /* Contact page grid */
  .contact-wrap{display:flex!important;flex-direction:column!important;gap:22px!important}
  .contact-info-card{padding:24px 18px!important}
  .contact-form-card{padding:22px 16px!important}
  .form-row{grid-template-columns:1fr!important}
  .form-group input,.form-group select,.form-group textarea{font-size:16px!important} /* prevent iOS zoom */

  /* Home page sections mobile */
  #why-grid,#course-preview-grid,#process-grid,#expertise-grid,#loc-grid{
    grid-template-columns:1fr!important;gap:16px!important
  }
  /* Why cards mobile padding */
  #why-grid > div, #course-preview-grid > div{padding:22px 18px!important}

  /* Process steps on mobile */
  #process-grid > div{padding:20px 16px!important}
  #process-grid > div > div:first-child{width:52px!important;height:52px!important;font-size:1.3rem!important}

  /* Section headers */
  .tag{font-size:0.65rem!important;letter-spacing:1.5px!important}

  /* About expertise cards */
  #expertise-grid > div > div:last-child{padding:22px 18px!important}

  /* Location cards */
  #loc-grid > div{padding:26px 22px!important}

  /* Footer */
  .footer-grid{grid-template-columns:1fr!important;gap:24px!important}
  .f-brand-name{font-size:1.3rem!important}
  .fb-inner{flex-direction:column!important;text-align:center!important;gap:8px!important}

  /* Drawer full width */
  .mobile-drawer{width:100vw!important;right:-100vw!important}
  .mobile-drawer.open{right:0!important}

  /* General overflow fix */
  body,html{overflow-x:hidden!important;max-width:100vw!important}
  .container{padding:0 16px!important}
  section,.section-pad{overflow:hidden!important}
}

@media(max-width:400px){
  #why-grid > div, #course-preview-grid > div, #loc-grid > div{padding:18px 14px!important}
  .heading-lg{font-size:1.5rem!important}
  .page-hero h1{font-size:1.4rem!important}
}

/* ── Extra mobile polish (v7 updates) ── */
@media(max-width:480px){
  /* hero-h1 size handled by hero-specific block */
  .hero-actions{flex-direction:column;align-items:flex-start}
  .hero-actions .btn{width:100%;justify-content:center}
  .btn{padding:12px 24px}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat-item{border-right:none;border-bottom:1px solid rgba(255,255,255,.12)}
  .stat-item:nth-child(odd){border-right:1px solid rgba(255,255,255,.12)}
  .stat-num{font-size:1rem}
  .stat-lbl{font-size:0.55rem;letter-spacing:1px}
  .about-feats{grid-template-columns:1fr}
  .section-pad{padding:64px 0}
  .container{padding:0 18px}
  .page-hero h1{font-size:1.8rem}
  .f-ci{font-size:0.8rem}
}

/* ── Hero Bridal Image Card (right column) ── */
.hero-img-card{display:flex;flex-direction:column;gap:12px;animation:fadeSlideUp .9s .2s ease both}
.hero-img-wrap{
  position:relative;border-radius:24px;overflow:hidden;
  box-shadow:0 24px 64px rgba(123,28,51,.18), 0 4px 16px rgba(123,28,51,.08);
  border:3px solid rgba(255,255,255,.9);
  aspect-ratio:4/5;
  background:#f5e8d4;
}
.hero-bridal-img{
  width:100%;height:100%;object-fit:cover;object-position:center top;
  display:block;transition:.4s;
}
.hero-img-wrap:hover .hero-bridal-img{transform:scale(1.03)}
.hero-img-overlay-grad{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(90,14,34,.45) 0%,transparent 55%);
  pointer-events:none;
}
/* Floating badge top-left */
.hero-img-badge{
  position:absolute;
  display:flex;align-items:center;gap:7px;
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(10px);
  border-radius:50px;
  padding:7px 14px;
  box-shadow:0 4px 18px rgba(0,0,0,.12);
  font-family:'Poppins',sans-serif;
}
.hero-img-badge--tl{top:14px;left:14px}
.hero-img-badge--br{bottom:16px;right:14px;flex-direction:column;align-items:center;background:rgba(123,28,51,.92);border-radius:16px;padding:10px 18px}
.hib-icon{color:var(--gold);font-size:0.75rem}
.hib-text{color:var(--primary);font-size:0.72rem;font-weight:600;letter-spacing:0.5px}
.hib-num{font-family:'Cinzel',serif;font-size:1.5rem;font-weight:800;color:#fff;line-height:1}
.hib-lbl{font-family:'Poppins',sans-serif;font-size:0.65rem;color:rgba(255,255,255,.8)}
/* Service strip below image */
.hero-spec-strip{
  display:flex;align-items:center;justify-content:center;
  background:#fff;border-radius:16px;padding:14px 16px;
  box-shadow:0 6px 22px rgba(123,28,51,.08);
  border:1px solid rgba(123,28,51,.09);gap:0;
}
.hss-item{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1}
.hss-icon{font-size:1.2rem}
.hss-label{font-family:'Poppins',sans-serif;font-size:0.65rem;font-weight:600;color:var(--accent)}
.hss-divider{width:1px;height:36px;background:rgba(123,28,51,.1);flex-shrink:0}

/* ── About spec card ── */
.about-spec-card{
  background:#fff;border-radius:24px;padding:32px 28px;
  box-shadow:0 16px 52px rgba(123,28,51,.1), 0 3px 12px rgba(123,28,51,.05);
  border:1px solid rgba(123,28,51,.1);
  text-align:center;position:relative;overflow:hidden;
  height:100%;
}
.about-spec-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--primary),var(--gold),var(--primary));
  background-size:200% 100%;animation:shimmerMove 2.5s ease infinite;
}

@media(max-width:960px){
  .hero-img-wrap{aspect-ratio:3/4}
  .hero-img-card{max-width:380px;margin:0 auto;width:100%}
}
@media(max-width:600px){
  .hero-img-wrap{aspect-ratio:4/5;border-radius:18px}
  .hss-label{font-size:0.58rem}
  .hss-icon{font-size:1rem}
  .hero-img-badge--tl{top:10px;left:10px;padding:5px 10px}
  .hib-text{font-size:0.64rem}
  .hero-img-badge--br{bottom:12px;right:10px;padding:7px 12px}
  .hib-num{font-size:1.2rem}
}

/* ══════════════════════════════════════════════════════
   HERO DECORATIVE PANEL — Indian Arch + Mandala
   ══════════════════════════════════════════════════════ */
.hero-deco-panel{
  position:relative;
  width:100%;
  max-width:380px;
  margin:0 auto;
  height:480px;
  animation:fadeSlideUp .9s .2s ease both;
}

/* Arch SVG — full panel background */
.hdp-arch{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  filter:drop-shadow(0 20px 48px rgba(123,28,51,.12));
}

/* Rotating mandala — centered in arch */
.hdp-mandala-wrap{
  position:absolute;
  top:50%; left:50%;
  transform:translate(-50%,-54%);
  width:280px; height:280px;
  cursor:pointer;
  transition:transform .4s ease;
}
.hdp-mandala-wrap:hover{
  transform:translate(-50%,-54%) scale(1.04);
}
.hdp-mandala{
  width:100%; height:100%;
  animation:mandalaSlowSpin 18s linear infinite;
}
@keyframes mandalaSlowSpin{
  from{transform:rotate(0deg)}
  to{transform:rotate(360deg)}
}
/* Pause on hover */
.hdp-mandala-wrap:hover .hdp-mandala{
  animation-play-state:paused;
}

/* Floating service pills — orbiting around mandala */
.hdp-pills{
  position:absolute;
  inset:0;
  pointer-events:none;
}
.hdp-pill{
  position:absolute;
  display:flex;
  align-items:center;
  gap:6px;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(8px);
  border:1px solid rgba(123,28,51,.14);
  border-radius:50px;
  padding:6px 14px 6px 8px;
  box-shadow:0 4px 16px rgba(123,28,51,.1);
  cursor:pointer;
  pointer-events:all;
  transition:all .3s cubic-bezier(.4,0,.2,1);
  animation:pillFloat ease-in-out infinite;
}
.hdp-pill:hover{
  background:#fff;
  border-color:var(--primary);
  box-shadow:0 8px 28px rgba(123,28,51,.2);
  transform:scale(1.1) translateY(-3px) !important;
  z-index:10;
}
.hdp-pill-icon{font-size:1rem;line-height:1}
.hdp-pill-txt{
  font-family:'Poppins',sans-serif;
  font-size:0.68rem;
  font-weight:600;
  color:var(--primary);
  white-space:nowrap;
}
@keyframes pillFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-6px)}
}

/* Individual pill positions (orbiting the mandala) */
.hdp-pill--1{top:60px;  left:10px;  animation-duration:3.8s; animation-delay:0s}
.hdp-pill--2{top:30px;  right:24px; animation-duration:4.4s; animation-delay:.6s}
.hdp-pill--3{top:48%;  left:0px;   animation-duration:3.6s; animation-delay:.3s}
.hdp-pill--4{top:48%;  right:-4px; animation-duration:4.8s; animation-delay:.9s}
.hdp-pill--5{bottom:115px; left:14px;  animation-duration:4.2s; animation-delay:.2s}
.hdp-pill--6{bottom:115px; right:12px; animation-duration:3.9s; animation-delay:.7s}

/* Bottom tagline in arch */
.hdp-tagline{
  position:absolute;
  bottom:28px; left:50%;
  transform:translateX(-50%);
  text-align:center;
  white-space:nowrap;
}
.hdp-tagline-stars{
  color:var(--gold);
  font-size:0.85rem;
  letter-spacing:4px;
  margin-bottom:4px;
}
.hdp-tagline-text{
  font-family:'Cinzel',serif;
  font-size:0.85rem;
  font-weight:700;
  color:var(--primary);
  letter-spacing:1px;
}

/* ── Responsive ── */
@media(max-width:960px){
  .hero-deco-panel{max-width:340px;height:420px}
  .hdp-mandala-wrap{width:240px;height:240px}
  .hero-visual{width:100%;display:flex;justify-content:center}
}
@media(max-width:600px){
  .hero-deco-panel{height:360px;max-width:300px}
  .hdp-mandala-wrap{width:200px;height:200px}
  .hdp-pill{padding:5px 10px 5px 7px}
  .hdp-pill-txt{font-size:0.6rem}
  .hdp-pill-icon{font-size:0.85rem}
  .hdp-pill--1{top:52px;left:4px}
  .hdp-pill--2{top:26px;right:16px}
  .hdp-pill--3{top:46%;left:-4px}
  .hdp-pill--4{top:46%;right:-8px}
  .hdp-pill--5{bottom:90px;left:4px}
  .hdp-pill--6{bottom:90px;right:4px}
}
