/* ═══════════════════════════════
   TOKENS
═══════════════════════════════ */
:root {
  --bg:      #050505; /* Slightly darker black */
  --bg2:     #0d0d0d;
  --card:    #151515;
  --gold:    #d4af37; /* More classic gold */
  --gold2:   #f1e5ac;
  --rose:    #e8557a;
  --cream:   #fdfaf6;
  --muted:   #8a837e; /* Slightly lighter muted text for better contrast */
  --border:  rgba(212,175,55,.15);
  --wa:      #25D366;
  --r:       4px; /* Sharper edges */
  --trans:   .4s cubic-bezier(0.25, 1, 0.5, 1); /* Smoother easing */
}

/* ═══════════════════════════════
   RESET
═══════════════════════════════ */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; font-weight: 300; }
body { background:var(--bg); color:var(--cream); font-family:'DM Sans',sans-serif; text-rendering: optimizeLegibility; -webkit-font-smoothing: antialiased; overflow-x:hidden; letter-spacing: 0.02em; }
img  { display:block; max-width:100%; height:auto; }
a    { text-decoration:none; color:inherit; }
button { cursor:pointer; font-family:inherit; }

/* ═══════════════════════════════
   ANIMATIONS (CSS only, no libs)
═══════════════════════════════ */
@keyframes fadeUp   { from{opacity:0;transform:translateY(32px)} to{opacity:1;transform:translateY(0)} }
@keyframes shimmer  { 0%,100%{background-position:0% 50%} 50%{background-position:100% 50%} }
@keyframes scrollBar{ 0%{transform:scaleY(0);transform-origin:top} 49%{transform:scaleY(1);transform-origin:top} 50%{transform:scaleY(1);transform-origin:bottom} 100%{transform:scaleY(0);transform-origin:bottom} }
@keyframes spin     { to{transform:rotate(360deg)} }
@keyframes marq     { from{transform:translateX(0)} to{transform:translateX(-50%)} }
@keyframes pulse    { 0%,100%{box-shadow:0 0 0 0 rgba(37,211,102,.45)} 70%{box-shadow:0 0 0 12px rgba(37,211,102,0)} }
@keyframes float    { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }

.reveal { opacity:0; transform:translateY(36px); transition:opacity .8s ease, transform .8s ease; }
.reveal.in { opacity:1; transform:translateY(0); }
.d1{transition-delay:.1s} .d2{transition-delay:.2s} .d3{transition-delay:.3s} .d4{transition-delay:.42s}

/* ═══════════════════════════════
   LAYOUT
═══════════════════════════════ */
.wrap { max-width:1100px; margin:0 auto; padding:0 1.5rem; }

/* ═══════════════════════════════
   FLOATING WHATSAPP
═══════════════════════════════ */
.wa-float {
  position:fixed; bottom:1.5rem; right:1.5rem; z-index:900;
  width:54px; height:54px; border-radius:50%;
  background:var(--wa); display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 18px rgba(37,211,102,.4);
  animation:pulse 2.4s infinite;
  transition:transform var(--trans);
}
.wa-float:hover { transform:scale(1.1); }
.wa-float svg { width:26px; height:26px; fill:#fff; }

/* ═══════════════════════════════
   NAV
═══════════════════════════════ */
nav {
  position:fixed; top:0; left:0; right:0; z-index:800;
  padding:1.2rem 1.5rem;
  display:flex; align-items:center; justify-content:space-between;
  transition:background var(--trans), border-color var(--trans), padding var(--trans);
  border-bottom:1px solid transparent;
}
nav.scrolled {
  background:rgba(10,10,10,.92);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border-bottom-color:var(--border);
  padding:.85rem 1.5rem;
}
.nav-logo {
  font-family:'Playfair Display',serif;
  font-size:1.15rem; font-style:italic;
  background:linear-gradient(120deg, var(--cream), var(--gold2));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.nav-links { display:flex; gap:2rem; list-style:none; }
.nav-links a { font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); transition:color var(--trans); }
.nav-links a:hover { color:var(--gold); }
.nav-wa {
  display:flex; align-items:center; gap:.5rem;
  background:var(--wa); color:#fff;
  font-size:.7rem; letter-spacing:.15em; text-transform:uppercase; font-weight:500;
  padding:.6rem 1.3rem; border-radius:var(--r);
  transition:background var(--trans), transform var(--trans);
}
.nav-wa:hover { background:#1fba59; transform:translateY(-1px); }
.nav-wa svg { width:14px; height:14px; fill:#fff; }
.ham { display:none; background:none; border:none; color:var(--cream); padding:4px; flex-direction:column; gap:5px; }
.ham span { display:block; width:22px; height:1.5px; background:var(--cream); transition:all .25s; }
.ham.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.ham.open span:nth-child(2){opacity:0}
.ham.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* Mobile nav */
.mob-nav {
  display:none; position:fixed; inset:0; z-index:790;
  background:rgba(10,10,10,.97);
  flex-direction:column; align-items:center; justify-content:center; gap:2rem;
}
.mob-nav.open { display:flex; }
.mob-nav a { font-family:'Playfair Display',serif; font-size:2.2rem; font-style:italic; color:var(--cream); transition:color var(--trans); }
.mob-nav a:hover { color:var(--gold); }

/* ═══════════════════════════════
   HERO
═══════════════════════════════ */
#hero {
  min-height:100svh;
  display:grid; grid-template-columns: 0.85fr 1.15fr;
  gap:0; overflow:hidden; position:relative;
}
.hero-img-col {
  position:relative; overflow:hidden;
  min-height:100svh;
}
.hero-img-col img {
  width:100%; height:100%; object-fit:cover; object-position:center top;
  transition:transform 8s ease-out; /* Slower, more elegant zoom */
}
.hero-img-col:hover img { transform:scale(1.08); }
.hero-img-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to right, rgba(5,5,5,.7) 0%, transparent 100%);
}
.hero-content-col {
  display:flex; flex-direction:column; justify-content:center;
  padding:7rem 3.5rem 4rem 5rem; /* More breathing room */
  background:linear-gradient(135deg, var(--bg) 0%, #0a0505 100%);
  position:relative; overflow:hidden;
}
.hero-content-col::before {
  content:'';
  position:absolute; width:600px; height:600px; border-radius:50%; /* Larger glow */
  background:radial-gradient(circle, rgba(212,175,55,.05) 0%, transparent 70%);
  top:-150px; right:-150px; pointer-events:none;
}
.hero-eyebrow {
  font-size:.65rem; letter-spacing:.45em; text-transform:uppercase; color:var(--rose);
  margin-bottom:1.5rem; opacity:0; animation:fadeUp 1s .2s forwards;
}
.hero-name {
  font-family:'Playfair Display',serif;
  font-size:clamp(2.5rem, 5vw, 5rem);
  font-weight:400; /* Lighter weight for elegance */
  line-height:1.05; margin-bottom:.8rem;
  background:linear-gradient(135deg, var(--cream) 0%, var(--gold2) 80%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  opacity:0; animation:fadeUp 1s .4s forwards;
}
.hero-sub {
  font-family:'Playfair Display',serif; font-style:italic;
  font-size:clamp(1.1rem, 2vw, 1.5rem); color:var(--muted);
  margin-bottom:2.5rem; line-height:1.6;
  opacity:0; animation:fadeUp 1s .6s forwards;
}
.hero-sub em { color:var(--gold); font-style:normal; font-weight: 400; }
.hero-pills {
  display:flex; flex-wrap:wrap; gap:.6rem; margin-bottom:3rem;
  opacity:0; animation:fadeUp 1s .8s forwards;
}
.pill {
  font-size:.65rem; letter-spacing:.2em; text-transform:uppercase;
  padding:.4rem 1rem; border:1px solid var(--border); color:var(--muted);
  border-radius:2px; /* Sharper pills */ background:rgba(212,175,55,.03);
  transition: all var(--trans);
}
.pill:hover { border-color: var(--gold); color: var(--cream); background: rgba(212,175,55,.08); }
.hero-btns {
  display:flex; gap:1rem; flex-wrap:wrap;
  opacity:0; animation:fadeUp 1s 1s forwards;
}
.btn-wa {
  display:inline-flex; align-items:center; gap:.55rem;
  padding:.9rem 2rem; background:var(--wa); color:#fff;
  font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; font-weight:500;
  border-radius:var(--r); transition:background var(--trans), transform var(--trans), box-shadow var(--trans);
}
.btn-wa:hover { background:#1fba59; transform:translateY(-2px); box-shadow:0 8px 24px rgba(37,211,102,.32); }
.btn-wa svg { width:16px; height:16px; fill:#fff; }
.btn-ghost {
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.9rem 1.8rem; background:transparent; color:var(--cream);
  font-size:.72rem; letter-spacing:.16em; text-transform:uppercase;
  border:1px solid var(--border); border-radius:var(--r);
  transition:border-color var(--trans), color var(--trans), transform var(--trans);
}
.btn-ghost:hover { border-color:var(--gold); color:var(--gold); transform:translateY(-2px); }
.hero-scroll {
  position:absolute; bottom:2rem; right:3.5rem;
  display:flex; flex-direction:column; align-items:center; gap:.4rem;
  opacity:0; animation:fadeUp .8s 1.1s forwards;
}
.hero-scroll span { font-size:.54rem; letter-spacing:.3em; text-transform:uppercase; color:var(--muted); }
.scroll-bar { width:1px; height:46px; background:linear-gradient(to bottom, var(--gold), transparent); animation:scrollBar 2.2s ease-in-out infinite; }

/* ═══════════════════════════════
   MARQUEE
═══════════════════════════════ */
.marquee-band {
  overflow:hidden; border-top:1px solid var(--border); border-bottom:1px solid var(--border);
  padding:.9rem 0; background:var(--bg2);
}
.marquee-track { display:flex; gap:3rem; width:max-content; animation:marq 22s linear infinite; }
.marquee-band:hover .marquee-track { animation-play-state:paused; }
.m-item { font-family:'Playfair Display',serif; font-style:italic; font-size:.95rem; white-space:nowrap; color:var(--muted); }
.m-dot  { color:var(--rose); margin:0 .4rem; font-style:normal; }

/* ═══════════════════════════════
   SECTION SHARED
═══════════════════════════════ */
.sect-eyebrow { font-size:.65rem; letter-spacing:.4em; text-transform:uppercase; color:var(--gold); margin-bottom:1rem; font-weight: 500;}
.sect-title { font-family:'Playfair Display',serif; font-size:clamp(2.2rem,5vw,3.8rem); font-weight:400; line-height:1.15; margin-bottom:1.2rem; }
.sect-title em { font-style:italic; color:var(--gold); }
.body-text { color:var(--muted); line-height:1.9; font-size:.95rem; }
.sect-hdr  { text-align:center; margin-bottom:4.5rem; }
.gold-line { width:60px; height:1px; background:var(--gold); margin:1rem auto 0; }


/* ═══════════════════════════════
   ABOUT
═══════════════════════════════ */
#about { padding:7rem 0; background:var(--bg2); }
.about-grid { display:grid; grid-template-columns:1fr 1.2fr; gap:5rem; align-items:center; }
.about-img-wrap { position:relative; }
.about-frame {
  aspect-ratio:3/4; overflow:hidden;
  border:1px solid var(--border);
}
.about-frame img { width:100%; height:100%; object-fit:cover; object-position:center top; transition:transform .6s ease; }
.about-frame:hover img { transform:scale(1.04); }
.about-frame::after {
  content:''; position:absolute; inset:12px 12px -12px -12px;
  border:1px solid var(--border); z-index:-1; border-radius:2px;
}
.about-badge {
  position:absolute; bottom:-1.2rem; right:-1.2rem;
  width:100px; height:100px; background:var(--rose);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; border-radius:2px;
}
.ab-num { font-family:'Playfair Display',serif; font-size:2.6rem; color:#fff; line-height:1; }
.ab-lbl { font-size:.44rem; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.8); margin-top:.15rem; }
.about-avail {
  display:inline-flex; align-items:center; gap:.5rem;
  margin-top:1.5rem;
  font-size:.68rem; letter-spacing:.14em; text-transform:uppercase; color:var(--wa);
  border:1px solid rgba(37,211,102,.3); padding:.45rem 1rem; border-radius:20px;
}
.avail-dot { width:7px; height:7px; border-radius:50%; background:var(--wa); animation:pulse 2s infinite; }
.about-contact { margin-top:1.8rem; display:flex; flex-direction:column; gap:.55rem; }
.about-contact a {
  display:flex; align-items:center; gap:.7rem;
  font-size:.85rem; color:var(--muted); transition:color var(--trans);
}
.about-contact a:hover { color:var(--gold); }
.about-contact a svg { width:15px; height:15px; fill:var(--gold); flex-shrink:0; }

/* ═══════════════════════════════
   SERVICES — 3D flip cards (CSS only)
═══════════════════════════════ */
#services { padding:9rem 0; }
.svc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.svc-card { height:400px; perspective:1200px; }
.svc-inner {
  position:relative; width:100%; height:100%;
  transform-style:preserve-3d;
  transition:transform .8s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}
.svc-card:hover .svc-inner { transform:rotateY(180deg); }
.svc-front, .svc-back {
  position:absolute; inset:0;
  backface-visibility:hidden; -webkit-backface-visibility:hidden;
  border:1px solid var(--border);
  display:flex; flex-direction:column; padding:2.5rem;
}
.svc-front { background:var(--card); justify-content:flex-end; }
.svc-num { font-family:'Playfair Display',serif; font-size:4rem; color:rgba(212,175,55,.05); line-height:1; margin-bottom:1rem; }
.svc-name-f { font-family:'Playfair Display',serif; font-size:1.6rem; font-weight:400; margin-bottom:.6rem; }
.svc-price-row { display:flex; align-items:baseline; gap:.5rem; }
.svc-from { font-size:.65rem; letter-spacing:.15em; text-transform:uppercase; color:var(--muted); }
.svc-price { font-family:'Playfair Display',serif; font-size:2.2rem; color:var(--gold); }
.svc-line { width:40px; height:1px; background:var(--gold); margin:1rem 0; }
.svc-tagline { font-size:.9rem; color:var(--muted); line-height:1.65; }
.svc-back { background:var(--bg2); transform:rotateY(180deg); justify-content:space-between; }
.svc-back-name { font-family:'Playfair Display',serif; color:var(--gold); font-size:1.3rem; margin-bottom:1.5rem; }
.svc-feats { list-style:none; display:flex; flex-direction:column; gap:.7rem; margin-bottom:1.5rem; }
.svc-feats li { font-size:.85rem; color:var(--muted); display:flex; align-items:flex-start; gap:.8rem; line-height:1.5; }
.svc-feats li::before { content:'✦'; color:var(--gold); font-size:.5rem; flex-shrink:0; margin-top:.25rem; }
.svc-wa {
  display:flex; align-items:center; justify-content:center; gap:.5rem;
  padding:.8rem; background:var(--wa); color:#fff;
  font-size:.68rem; letter-spacing:.14em; text-transform:uppercase; font-weight:500;
  border-radius:var(--r); transition:background var(--trans);
}
.svc-wa:hover { background:#1fba59; }
.svc-wa svg { width:14px; height:14px; fill:#fff; }

/* ═══════════════════════════════
   GALLERY
═══════════════════════════════ */
#gallery { padding:7rem 0; background:var(--bg2); }
.gallery-tabs { display:flex; gap:.5rem; justify-content:center; flex-wrap:wrap; margin-bottom:2rem; }
.g-tab {
  font-size:.62rem; letter-spacing:.18em; text-transform:uppercase;
  padding:.45rem 1.2rem; background:transparent;
  border:1px solid var(--border); color:var(--muted);
  border-radius:20px; transition:all var(--trans);
}
.g-tab.active, .g-tab:hover { background:var(--gold); border-color:var(--gold); color:var(--bg); }
.g-panel { display:none; }
.g-panel.active { display:grid; grid-template-columns:repeat(3,1fr); gap:6px; }
.g-item { position:relative; overflow:hidden; aspect-ratio:3/4; background:var(--card); }
.g-item:first-child { grid-row:span 2; aspect-ratio:auto; }
.g-item img { width:100%; height:100%; object-fit:cover; object-position:center top; transition:transform .55s ease; display:block; }
.g-item:hover img { transform:scale(1.06); }
.g-cap {
  position:absolute; bottom:0; left:0; right:0;
  background:linear-gradient(to top, rgba(10,10,10,.85) 0%, transparent 100%);
  padding:1.2rem .9rem .7rem;
  opacity:0; transition:opacity var(--trans);
  font-family:'Playfair Display',serif; font-style:italic; font-size:.88rem;
}
.g-item:hover .g-cap { opacity:1; }
/* Placeholder tiles when no image */
.g-ph {
  width:100%; height:100%; min-height:200px;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:.5rem; background:var(--card);
}
.g-ph-i { font-size:2rem; opacity:.1; }
.g-ph-t { font-size:.56rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); opacity:.35; }

/* ═══════════════════════════════
   PROCESS
═══════════════════════════════ */
#process { padding:7rem 0; }
.proc-grid { display:grid; grid-template-columns:repeat(4,1fr); border:1px solid var(--border); }
.proc-step { padding:2.2rem 1.6rem; border-right:1px solid var(--border); }
.proc-step:last-child { border-right:none; }
.proc-n { font-family:'Playfair Display',serif; font-size:3.5rem; color:rgba(200,146,58,.08); line-height:1; margin-bottom:.6rem; }
.proc-name { font-family:'Playfair Display',serif; font-size:1.1rem; margin-bottom:.5rem; }
.proc-desc { font-size:.8rem; color:var(--muted); line-height:1.7; }

/* ═══════════════════════════════
   UPI PAYMENT
═══════════════════════════════ */
#payment { padding:7rem 0; background:var(--bg2); }
.upi-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; max-width:820px; margin:0 auto; }
.qr-card {
  background:#fff; border-radius:10px;
  padding:1.5rem; display:flex; flex-direction:column; align-items:center; gap:.8rem;
  max-width:240px; margin:0 auto;
}
/* Embed real QR code image here */
.qr-card img { width:200px; height:200px; border-radius:6px; }
.qr-ph {
  width:200px; height:200px; background:#f5f5f5; border:2px dashed #ddd;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:.4rem; border-radius:6px;
}
.qr-ph svg { width:40px; height:40px; fill:#ccc; }
.qr-ph p { font-size:.62rem; text-align:center; color:#999; font-family:'DM Sans',sans-serif; max-width:110px; line-height:1.4; }
.qr-lbl { font-size:.68rem; color:#666; font-family:'DM Sans',sans-serif; }

.upi-id-row {
  display:flex; align-items:center; gap:.6rem;
  background:var(--card); border:1px solid var(--border);
  padding:.8rem 1rem; border-radius:var(--r); margin-bottom:1.3rem;
}
.upi-id-val { flex:1; font-size:.88rem; font-family:monospace; color:var(--cream); }
.copy-btn {
  background:none; border:1px solid var(--border); color:var(--gold);
  font-size:.6rem; letter-spacing:.12em; text-transform:uppercase;
  padding:.3rem .7rem; border-radius:4px; transition:all var(--trans);
}
.copy-btn:hover { background:var(--gold); color:var(--bg); }
.amt-chips { display:flex; flex-wrap:wrap; gap:.5rem; margin-bottom:1.2rem; }
.amt-chip {
  padding:.42rem .9rem; border:1px solid var(--border); color:var(--muted);
  font-size:.76rem; border-radius:4px; background:none;
  transition:all var(--trans);
}
.amt-chip.sel, .amt-chip:hover { border-color:var(--gold); color:var(--gold); background:rgba(200,146,58,.06); }
.custom-inp {
  width:100%; background:var(--card); border:1px solid var(--border); color:var(--cream);
  font-family:'DM Sans',sans-serif; font-size:.88rem; padding:.7rem 1rem;
  border-radius:var(--r); margin-bottom:1rem; outline:none;
}
.custom-inp:focus { border-color:var(--gold); }
.custom-inp::placeholder { color:var(--muted); }
.upi-btn {
  width:100%; display:flex; align-items:center; justify-content:center; gap:.65rem;
  padding:1rem; background:var(--gold); color:var(--bg); border:none;
  font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; font-weight:500;
  border-radius:var(--r); transition:background var(--trans), transform var(--trans), box-shadow var(--trans);
}
.upi-btn:hover { background:var(--gold2); transform:translateY(-2px); box-shadow:0 8px 24px rgba(200,146,58,.3); }
.upi-note { font-size:.72rem; color:var(--muted); text-align:center; margin-top:1rem; line-height:1.7; }
.upi-apps { display:flex; gap:.6rem; justify-content:center; flex-wrap:wrap; margin-top:.8rem; }
.upi-app { font-size:.58rem; letter-spacing:.12em; text-transform:uppercase; padding:.28rem .7rem; border:1px solid var(--border); color:var(--muted); border-radius:3px; }

/* ═══════════════════════════════
   TESTIMONIALS
═══════════════════════════════ */
#testimonials { padding:7rem 0; }
.testi-scroll { overflow:hidden; }
.testi-track { display:flex; gap:1.2rem; width:max-content; animation:marq 28s linear infinite; }
.testi-track:hover { animation-play-state:paused; }
.testi-card { width:300px; flex-shrink:0; background:var(--card); border:1px solid var(--border); padding:1.8rem; }
.stars { display:flex; gap:2px; margin-bottom:.9rem; }
.star  { color:var(--gold); font-size:.65rem; }
.testi-text { font-family:'Playfair Display',serif; font-style:italic; font-size:.93rem; color:var(--cream); line-height:1.7; margin-bottom:1.2rem; position:relative; }
.testi-text::before { content:'\201C'; position:absolute; top:-.4rem; left:-.3rem; font-size:3rem; color:var(--gold); opacity:.1; line-height:1; }
.testi-auth { display:flex; align-items:center; gap:.7rem; }
.testi-av { width:36px; height:36px; border-radius:50%; background:linear-gradient(135deg, var(--gold), var(--rose)); display:flex; align-items:center; justify-content:center; font-size:.68rem; font-weight:500; color:var(--bg); flex-shrink:0; }
.testi-name { font-size:.78rem; font-weight:500; }
.testi-role { font-size:.6rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-top:.15rem; }

/* ═══════════════════════════════
   FAQ
═══════════════════════════════ */
#faq { padding:7rem 0; background:var(--bg2); }
.faq-wrap { max-width:700px; margin:0 auto; }
.faq-item { border-bottom:1px solid var(--border); }
.faq-q {
  width:100%; display:flex; justify-content:space-between; align-items:center;
  background:none; border:none; color:var(--cream); padding:1.3rem 0;
  text-align:left; font-family:'Playfair Display',serif; font-size:1rem;
  gap:1rem; transition:color var(--trans);
}
.faq-q:hover, .faq-q.open { color:var(--gold); }
.faq-icon { width:22px; height:22px; border:1px solid var(--border); border-radius:50%; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:.7rem; transition:transform .3s, background var(--trans), border-color var(--trans); }
.faq-q.open .faq-icon { transform:rotate(45deg); background:var(--gold); border-color:var(--gold); color:var(--bg); }
.faq-a { max-height:0; overflow:hidden; transition:max-height .4s ease, padding .3s; }
.faq-a.open { max-height:180px; padding-bottom:1.3rem; }
.faq-a p { font-size:.85rem; color:var(--muted); line-height:1.85; }

/* ═══════════════════════════════
   BOOK CTA
═══════════════════════════════ */
#book { padding:8rem 0; text-align:center; background:linear-gradient(135deg, var(--bg) 0%, #130a08 100%); position:relative; overflow:hidden; }
#book::before { content:''; position:absolute; width:600px; height:600px; border-radius:50%; background:radial-gradient(circle, rgba(232,85,122,.06) 0%, transparent 70%); top:50%; left:50%; transform:translate(-50%,-50%); pointer-events:none; }
.book-inner { position:relative; z-index:1; }
.book-eyebrow { font-size:.6rem; letter-spacing:.42em; text-transform:uppercase; color:var(--rose); margin-bottom:1rem; }
.book-title { font-family:'Playfair Display',serif; font-size:clamp(2.2rem,5vw,4.5rem); font-weight:400; line-height:1.12; margin-bottom:1.2rem; }
.book-title em { font-style:italic; color:var(--gold); }
.book-sub { color:var(--muted); font-size:.88rem; max-width:420px; margin:0 auto 2.5rem; line-height:1.85; }
.book-form { max-width:460px; margin:0 auto; display:flex; flex-direction:column; gap:.8rem; }
.b-row { display:flex; gap:.7rem; }
.b-inp {
  flex:1; background:var(--card); border:1px solid var(--border); color:var(--cream);
  font-family:'DM Sans',sans-serif; font-size:.85rem; padding:.8rem 1rem;
  border-radius:var(--r); outline:none; transition:border-color var(--trans);
  min-width:0;
}
.b-inp:focus { border-color:var(--gold); }
.b-inp::placeholder { color:var(--muted); }
.b-sel {
  width:100%; background:var(--card); border:1px solid var(--border); color:var(--muted);
  font-family:'DM Sans',sans-serif; font-size:.85rem; padding:.8rem 1rem;
  border-radius:var(--r); outline:none; appearance:none;
}
.book-wa {
  width:100%; display:flex; align-items:center; justify-content:center; gap:.65rem;
  padding:1.05rem; background:var(--wa); color:#fff; border:none;
  font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; font-weight:500;
  border-radius:var(--r); transition:background var(--trans), transform var(--trans), box-shadow var(--trans);
}
.book-wa:hover { background:#1fba59; transform:translateY(-2px); box-shadow:0 10px 28px rgba(37,211,102,.3); }
.book-wa svg { width:16px; height:16px; fill:#fff; }
.book-direct {
  margin-top:1rem; font-size:.75rem; color:var(--muted);
  display:flex; align-items:center; justify-content:center; gap:.4rem;
}
.book-direct a { color:var(--gold); transition:color var(--trans); }
.book-direct a:hover { color:var(--gold2); }

/* ═══════════════════════════════
   FOOTER
═══════════════════════════════ */
footer { padding:4rem 0 2rem; border-top:1px solid var(--border); }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr; gap:3rem; margin-bottom:2.5rem; }
.f-brand { font-family:'Playfair Display',serif; font-style:italic; font-size:1.4rem; margin-bottom:.7rem; color:var(--gold); }
.f-bio { font-size:.82rem; color:var(--muted); line-height:1.75; }
.f-ig {
  display:inline-flex; align-items:center; gap:.5rem; margin-top:1rem;
  font-size:.65rem; letter-spacing:.14em; text-transform:uppercase; color:var(--rose);
  border:1px solid rgba(232,85,122,.3); padding:.38rem .85rem; border-radius:20px;
  transition:border-color var(--trans), color var(--trans);
}
.f-ig:hover { border-color:var(--rose); }
.f-col-title { font-size:.6rem; letter-spacing:.28em; text-transform:uppercase; color:var(--gold); margin-bottom:1.2rem; }
.f-links { list-style:none; display:flex; flex-direction:column; gap:.65rem; }
.f-links a { font-size:.82rem; color:var(--muted); transition:color var(--trans); }
.f-links a:hover { color:var(--cream); }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; padding-top:2rem; border-top:1px solid var(--border); }
.f-copy { font-size:.66rem; color:var(--muted); }
.f-socials { display:flex; gap:1rem; flex-wrap:wrap; }
.f-btn-ig, .f-btn-wa {
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.6rem 1.2rem; border-radius:var(--r);
  font-size:.7rem; letter-spacing:.15em; text-transform:uppercase; font-weight:700;
  transition:all var(--trans);
}
.f-btn-ig {
  background:transparent; border:1px solid var(--rose); color:var(--rose);
}
.f-btn-ig:hover {
  background:var(--rose); color:#fff; transform:translateY(-2px); box-shadow:0 6px 16px rgba(232,85,122,.25);
}
.f-btn-ig svg, .f-btn-wa svg { width:16px; height:16px; fill:currentColor; }
.f-btn-wa {
  background:var(--wa); border:1px solid var(--wa); color:#fff;
}
.f-btn-wa:hover {
  background:#1fba59; border-color:#1fba59; transform:translateY(-2px); box-shadow:0 6px 16px rgba(37,211,102,.25);
}

/* ═══════════════════════════════
   RESPONSIVE
═══════════════════════════════ */
@media (max-width:1200px) {
  .hero-content-col { padding:6rem 3rem 4rem; }
  .wrap { max-width: 960px; }
}

@media (max-width:1024px) {
  /* Hero stacks instead of horizontal on tablet */
  #hero { grid-template-columns:1fr; min-height:100svh; }
  .hero-img-col { min-height:60svh; width:100%; order: 1; }
  .hero-content-col { 
    order: 2;
    padding:4.5rem 2.5rem 5rem; 
    align-items:center; text-align:center; 
    min-height: auto;
  }
  .hero-scroll { display:none; }
  .hero-pills { justify-content:center; }
  .hero-btns { justify-content:center; }

  /* Grids scale down */
  .svc-grid { grid-template-columns:repeat(2,1fr); }
  .footer-grid { grid-template-columns:1fr 1fr; gap:2rem; }
  .about-grid { grid-template-columns:1fr; gap:3.5rem; text-align:center; }
  .about-img-wrap { max-width:340px; margin:0 auto; }
  .about-avail { margin:1.5rem auto 0; }
  .about-contact { align-items:center; }

  .upi-grid { grid-template-columns:1fr; gap:2.5rem; text-align:center; }
  .upi-grid > div:last-child { display:flex; flex-direction:column; align-items:center; }
  .amt-chips, .upi-id-row { justify-content:center; }

  .proc-grid { grid-template-columns:repeat(2,1fr); }
  .proc-step:nth-child(2) { border-right:none; }
  .proc-step:nth-child(1), .proc-step:nth-child(2) { border-bottom:1px solid var(--border); }
}

@media (max-width:768px) {
  .hero-img-col { min-height:50svh; }
  .hero-content-col { padding:3.5rem 1.5rem 3.5rem; }
  .hero-name { font-size:clamp(2.5rem, 8vw, 4rem); }

  nav { padding:1rem 1.2rem; }
  nav.scrolled { padding:.8rem 1.2rem; }
  .nav-links, .nav-wa { display:none; }
  .ham { display:flex; }

  .svc-grid { grid-template-columns:1fr; }
  .svc-card { height:auto; perspective:none; }
  .svc-inner { transform-style:flat; transform:none !important; height:auto; }
  .svc-front { position:relative; }
  .svc-back { position:relative; transform:none; backface-visibility:visible; border-top:none; }
  
  .g-panel.active { grid-template-columns:1fr 1fr; }
  .g-item:first-child { grid-row:span 1; }
  
  .proc-grid { grid-template-columns:1fr; border:none; }
  .proc-step { border-right:none; border:none; border-bottom:1px solid var(--border); }
  .proc-step:last-child { border-bottom:none; }
  
  .footer-grid { grid-template-columns:1fr; gap:2rem; text-align:center; }
  .footer-bottom { flex-direction:column; gap:1rem; text-align:center; }
  
  .b-row { flex-direction:column; }
}

@media (max-width:480px) {
  .hero-btns { flex-direction:column; width:100%; }
  .btn-wa, .btn-ghost { width:100%; justify-content:center; }
  
  .g-panel.active { grid-template-columns:1fr; }
  .wrap { padding:0 1.2rem; }
  
  .proc-n { font-size:3rem; }
  .ab-num { font-size:2.2rem; }
}
