/* ============================================================
   BRAHMAJNANA — GLOBAL STYLESHEET
   astrologershankarprasad.in
   Style: pavanguruji.com inspired | Saffron theme
   Container: 1250px max-width
============================================================ */

/* ── AI SUMMARY CARD (separate file, loaded first) ── */
@import url('ai-summary.css');

/* ── GOOGLE FONTS (loaded via PHP head) ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

/* ── CRITICAL: Prevent horizontal overflow on mobile ── */
html{scroll-behavior:smooth;overflow-x:hidden;background:#e8e0d8}
body{
  font-family:'Poppins',sans-serif;font-size:15px;color:#444;
  background:#fff;line-height:1.7;overflow-x:hidden;

  /* ── BOXED LAYOUT ──
     Creates a centred content column with side gutters on wide screens.
     Max-width matches --W (1250px) — content never exceeds this.
     Side margins become visible background on screens > 1250px.     */
  max-width:var(--W);
  margin:0 auto;
  box-shadow:0 0 60px rgba(0,0,0,.18);
  position:relative;
}

/* Topbar, header, footer stretch edge-to-edge inside the box */
#topbar,#header,footer,#mob-cta{
  /* Already inside body so they inherit the 1250px box */
}

/* On very wide screens show a subtle background behind the box */
@media(min-width:1300px){
  html{background:linear-gradient(135deg,#f0e8df 0%,#e8ddd4 100%)}
}

img{max-width:100%;display:block;height:auto}
a{text-decoration:none;color:inherit}
ul{list-style:none}

/* ── VARIABLES ── */
:root{
  --sf:#E8620A;--sf-d:#C4510A;--sf-l:#FFF0E8;--sf-m:#FFDCC8;
  --gold:#F5A623;--gold-lt:#fde8c0;
  --maroon:#800000;
  --dark:#1A1A1A;--dark2:#2D2D2D;
  --text:#444;--text-muted:#777;--muted:#777;--border:#E8E8E8;
  --bg:#FDF8F5;--bgg:#F7F7F7;--white:#fff;
  --W:1250px;--r:8px;--rL:14px;
  --sh:0 4px 20px rgba(0,0,0,.08);
  --shH:0 8px 32px rgba(232,98,10,.15)
}

/* ── AI SUMMARY CARD (LLMO / GEO optimised) ── */
.ai-summary-card {
  background: linear-gradient(145deg, #ffffff, #fff9f0);
  border: 1px solid var(--gold-lt);
  border-radius: 16px;
  padding: 24px;
  position: relative;
  margin: 20px 0;
  box-shadow: 0 10px 30px rgba(232, 98, 10, 0.05);
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.ai-summary-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 15px 40px rgba(232, 98, 10, 0.12);
}
.ai-summary-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--maroon), var(--gold), var(--maroon));
  background-size: 200% auto;
  animation: celestialGlow 4s linear infinite;
}
@keyframes celestialGlow {
  0%   { background-position: 0% 50%; }
  100% { background-position: 200% 50%; }
}
.ai-heading-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 15px;
}
.ai-heading-label {
  font-family: 'Poppins', sans-serif;
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--maroon);
  text-transform: uppercase;
  letter-spacing: 1.2px;
  background: rgba(128, 0, 0, 0.05);
  padding: 4px 12px;
  border-radius: 20px;
}
.ai-text {
  font-size: 0.95rem;
  line-height: 1.8;
  color: var(--dark);
  margin: 0;
}
.ai-bullet-list {
  list-style: none;
  padding: 0;
  margin: 15px 0 0 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
@media (max-width: 768px) {
  .ai-bullet-list { grid-template-columns: 1fr; }
}
.ai-bullet-item {
  font-size: 0.88rem;
  display: flex;
  align-items: flex-start;
  gap: 8px;
  color: var(--text-muted);
}
.ai-bullet-item .ai-dot { color: var(--gold); font-size: 1rem; }

/* ── LAYOUT ── */
.container{width:100%;padding:0 28px}
.section-pad{padding:72px 0}
.section-pad-sm{padding:48px 0}
.tc{text-align:center}
.bg-white{background:#fff}
.bg-light{background:var(--bg)}
.bg-dark{background:var(--dark)}

/* ── TYPOGRAPHY ── */
.badge{display:inline-block;background:var(--sf-l);color:var(--sf);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 14px;border-radius:20px;margin-bottom:12px}
.badge-dark{display:inline-block;background:rgba(232,98,10,.15);color:var(--sf);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 14px;border-radius:20px;margin-bottom:12px}
.section-title{font-family:'Playfair Display',serif;font-size:clamp(24px,3.5vw,38px);color:var(--dark);margin-bottom:12px;line-height:1.25}
.section-title span,.section-title em{color:var(--sf);font-style:normal}
.section-title.light{color:#fff}
.section-sub{color:var(--muted);font-size:14px;max-width:620px;margin:0 auto;line-height:1.85}
.section-sub.light{color:rgba(255,255,255,.65)}
.divider{width:54px;height:3px;background:var(--sf);border-radius:2px;margin:14px 0 22px}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 26px;border-radius:6px;font-family:'Poppins',sans-serif;font-weight:600;font-size:13px;cursor:pointer;border:2px solid transparent;transition:all .22s;text-decoration:none;white-space:nowrap}
.btn-primary{background:var(--sf);color:#fff;border-color:var(--sf)}
.btn-primary:hover{background:var(--sf-d);border-color:var(--sf-d);transform:translateY(-2px);box-shadow:var(--shH)}
.btn-outline{background:transparent;color:var(--sf);border-color:var(--sf)}
.btn-outline:hover{background:var(--sf);color:#fff;transform:translateY(-2px)}
.btn-white{background:#fff;color:var(--sf);border-color:#fff}
.btn-white:hover{background:var(--sf-l)}
.btn-outline-w{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn-outline-w:hover{background:rgba(255,255,255,.15)}
.btn-wa{background:#25D366;color:#fff;border-color:#25D366}
.btn-wa:hover{background:#1EB85A;transform:translateY(-2px)}
.btn-sm{padding:9px 18px;font-size:12px}
.btn-full{width:100%;justify-content:center}
.btn-group{display:flex;gap:12px;flex-wrap:wrap}

/* ── IMAGE PLACEHOLDERS ── */
.img-ph{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:linear-gradient(135deg,var(--sf-l),var(--sf-m));border-radius:var(--rL);overflow:hidden;position:relative}
.img-ph .ph-icon{font-size:48px;line-height:1}
.img-ph .ph-lbl{font-size:10px;font-weight:600;color:var(--sf-d);letter-spacing:.04em;text-align:center;padding:0 14px;line-height:1.5}
.img-ph.ph-dark{background:linear-gradient(135deg,#2a1a08,var(--dark))}
.img-ph.ph-dark .ph-lbl{color:rgba(255,255,255,.5)}
/* When you replace placeholders with real <img> tags, use these classes: */
.hero-pandit-img{width:100%;height:100%;object-fit:cover;object-position:top center;border-radius:14px 14px 0 0;display:block}
.about-main-img{width:100%;height:480px;object-fit:cover;object-position:top center;border-radius:var(--rL);display:block}
.contact-img{width:100%;height:320px;object-fit:cover;object-position:top center;border-radius:var(--rL);display:block}
/* Logo: replace .logo-ph with <img src="/assets/images/logo.png" alt="Brahmajnana Logo" class="logo-img"> */
.logo-img{height:50px;width:auto;border-radius:8px;object-fit:contain}
.logo-ph{width:46px;height:46px;background:var(--sf);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}

/* ── TOPBAR ── */
#topbar{background:var(--dark);padding:8px 0;font-size:12px;color:rgba(255,255,255,.7)}
.tb-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:6px}
.tb-L,.tb-R{display:flex;align-items:center;gap:18px}
.tb-item{display:flex;align-items:center;gap:5px}
.tb-item a{color:rgba(255,255,255,.85);transition:color .2s}
.tb-item a:hover{color:var(--gold)}
.tb-icon{color:var(--sf)}

/* ── HEADER ── */
#header{background:#fff;position:sticky;top:0;z-index:1000;box-shadow:0 2px 12px rgba(0,0,0,.08)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:12px 0;gap:20px}
.logo-block{display:flex;align-items:center;gap:11px;text-decoration:none}
.logo-name{font-family:'Playfair Display',serif;font-size:17px;font-weight:700;color:var(--dark);line-height:1.2}
.logo-sub{font-size:10px;color:var(--sf);font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.nav-list{display:flex;align-items:center;gap:2px}
.nav-list>li{position:relative}
.nav-list a,.nav-drop-btn{padding:8px 13px;font-size:13px;font-weight:500;color:var(--dark2);border-radius:6px;transition:all .18s;cursor:pointer;border:none;background:none;font-family:'Poppins',sans-serif;display:flex;align-items:center;gap:4px;text-decoration:none}
.nav-list a:hover,.nav-drop-btn:hover,.nav-list a.active{color:var(--sf);background:var(--sf-l)}
.nav-dropdown{position:relative}
.ndrop-menu{display:none;position:absolute;top:calc(100% + 6px);left:0;background:#fff;border:1px solid var(--border);border-radius:var(--rL);box-shadow:0 12px 40px rgba(0,0,0,.12);padding:10px;min-width:250px;z-index:200}
.nav-dropdown:hover .ndrop-menu{display:block}
.ndrop-menu a{display:flex;align-items:center;gap:10px;padding:9px 14px;font-size:13px;color:var(--text);border-radius:6px;transition:background .15s;text-decoration:none}
.ndrop-menu a:hover{background:var(--sf-l);color:var(--sf)}
.drop-ic{width:28px;height:28px;background:var(--sf-l);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;font-style:normal}
.nav-phone{display:flex;align-items:center;gap:7px;background:var(--sf);color:#fff;padding:9px 16px;border-radius:6px;font-size:13px;font-weight:600;transition:background .2s;text-decoration:none}
.nav-phone:hover{background:var(--sf-d)}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.hamburger span{display:block;width:24px;height:2px;background:var(--dark);border-radius:2px;transition:all .3s}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ── PAGE HERO (inner pages) ── */
.page-hero{background:linear-gradient(135deg,var(--dark) 0%,#2C1A08 100%);padding:64px 0;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;right:-100px;top:-100px;width:420px;height:420px;background:radial-gradient(circle,rgba(232,98,10,.08) 0%,transparent 65%);pointer-events:none}
.ph-inner{position:relative;z-index:1}
.breadcrumb{display:flex;align-items:center;gap:6px;font-size:12px;color:rgba(255,255,255,.5);margin-bottom:14px}
.breadcrumb a{color:rgba(255,255,255,.65);transition:color .2s}
.breadcrumb a:hover{color:var(--gold)}
.bc-sep{color:rgba(255,255,255,.3)}
.page-hero h1{font-family:'Playfair Display',serif;font-size:clamp(26px,4vw,44px);color:#fff;margin-bottom:12px;line-height:1.22}
.page-hero h1 span{color:var(--gold)}
.page-hero .ph-sub{color:rgba(255,255,255,.65);font-size:14px;max-width:580px;line-height:1.85}

/* ── VIDEO SECTION ── */
.vid-section{background:var(--dark)}
.vid-wrap{position:relative;width:100%;max-width:860px;margin:36px auto 0;border-radius:var(--rL);overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.4);aspect-ratio:16/9}
.vid-wrap iframe{width:100%;height:100%;border:none;display:block}
.vid-note{text-align:center;margin-top:14px;font-size:12px;color:rgba(255,255,255,.4);font-style:italic}

/* ── HERO HOME ── */
.hero{background:linear-gradient(135deg,#FFF5EE 0%,#FFFDF9 100%);padding:60px 0 0;overflow:hidden;position:relative}
.hero::before{content:'';position:absolute;right:-80px;top:-80px;width:460px;height:460px;background:radial-gradient(circle,rgba(232,98,10,.06),transparent 70%);pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.hero-trusted{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--sf-m);border-radius:20px;padding:5px 14px;font-size:11px;font-weight:700;color:var(--sf);margin-bottom:18px}
.hero h1{font-family:'Playfair Display',serif;font-size:clamp(28px,4.5vw,52px);color:var(--dark);line-height:1.15;margin-bottom:16px}
.hero h1 span{color:var(--sf)}
.hero-desc{font-size:14px;color:var(--text);line-height:1.9;margin-bottom:10px}
.hero-loc{font-size:12px;color:var(--muted);margin-bottom:24px;display:flex;align-items:center;gap:5px}
.hero-stats{display:flex;gap:22px;flex-wrap:wrap;margin-bottom:28px}
.hs-num{font-family:'Playfair Display',serif;font-size:26px;font-weight:700;color:var(--sf);line-height:1}
.hs-lbl{font-size:11px;color:var(--muted);font-weight:500;margin-top:2px}
.hs-div{width:1px;background:var(--border);align-self:stretch}
/* AI Summary Box */
.ai-box{background:#fff;border:1.5px solid var(--sf-m);border-left:4px solid var(--sf);border-radius:var(--r);padding:18px 22px;margin-top:28px}
.ai-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--sf);margin-bottom:7px}
.ai-text{font-size:13px;color:var(--text);line-height:1.75;margin-bottom:10px}
.ai-bullets{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:5px}
.ai-bullets li{display:flex;align-items:flex-start;gap:8px;font-size:12px;color:var(--text)}
.ai-bullets li .ai-dot{color:var(--sf);font-weight:700;flex-shrink:0;margin-top:1px}
/* Hero visual */
.hero-vis{position:relative;display:flex;justify-content:center;align-items:flex-end;padding-top:10px}
.hero-vis-bg{position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:90%;height:86%;background:linear-gradient(160deg,var(--sf-m),var(--sf-l));border-radius:50% 50% 0 0;z-index:0}
.hero-img-wrap{position:relative;z-index:1;width:88%;max-width:400px}
.hero-bdg{position:absolute;background:#fff;border-radius:var(--r);padding:11px 15px;box-shadow:0 6px 24px rgba(0,0,0,.12);display:flex;align-items:center;gap:9px;z-index:3;white-space:nowrap}
.hero-bdg.b1{top:20px;left:12px}
.hero-bdg.b2{bottom:40px;right:12px}
.hb-val{font-size:15px;font-weight:700;color:var(--dark);line-height:1}
.hb-lbl{font-size:10px;color:var(--muted)}

/* ── STATS STRIP ── */
.stats-strip{background:var(--dark);padding:34px 0}
.stats-g{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.stat-n{font-family:'Playfair Display',serif;font-size:34px;font-weight:700;color:var(--sf);line-height:1}
.stat-l{font-size:12px;color:rgba(255,255,255,.6);margin-top:4px}
.stat-ic{font-size:24px;margin-bottom:6px}

/* ── ABOUT SECTION ── */
.about-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:56px;align-items:start}
.about-img-wrap{position:relative}
.exp-badge{position:absolute;bottom:22px;right:-14px;background:var(--sf);color:#fff;padding:16px 20px;border-radius:var(--r);text-align:center;box-shadow:var(--sh)}
.exp-y{font-size:28px;font-weight:700;line-height:1}
.exp-l{font-size:11px;opacity:.9;margin-top:2px}
.about-quote{background:var(--sf-l);border-left:3px solid var(--sf);padding:15px 18px;border-radius:0 var(--r) var(--r) 0;font-style:italic;font-size:13px;color:var(--dark2);margin-top:18px}
.about-pts{display:flex;flex-direction:column;gap:11px;margin:18px 0}
.about-pt{display:flex;align-items:flex-start;gap:11px;font-size:13px;color:var(--text)}
.apc{width:26px;height:26px;background:var(--sf-l);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0;margin-top:1px}

/* ── CREDENTIAL CARDS ── */
.cred-g{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.cred-c{background:var(--bg);border:1px solid var(--border);border-radius:var(--r);padding:20px;text-align:center;transition:all .2s}
.cred-c:hover{border-color:var(--sf-m);box-shadow:var(--sh)}
.cred-ic{font-size:28px;margin-bottom:10px;line-height:1}
.cred-c h4{font-size:13px;font-weight:600;color:var(--dark);margin-bottom:5px}
.cred-c p{font-size:12px;color:var(--muted);line-height:1.6}

/* ── TIMELINE ── */
.timeline{border-left:2px solid var(--sf-m);padding-left:24px}
.tl-item{margin-bottom:28px;position:relative}
.tl-item::before{content:'';position:absolute;left:-30px;top:7px;width:10px;height:10px;background:var(--sf);border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 2px var(--sf)}
.tl-yr{font-size:11px;font-weight:700;color:var(--sf);letter-spacing:.06em;margin-bottom:3px}
.tl-item h4{font-size:14px;font-weight:600;color:var(--dark);margin-bottom:4px}
.tl-item p{font-size:12px;color:var(--muted);line-height:1.65}

/* ── SERVICES GRID (Home preview) ── */
.srv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.srv-card{background:#fff;border:1px solid var(--border);border-radius:var(--rL);overflow:hidden;transition:all .25s;display:block;text-decoration:none;position:relative}
.srv-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--sf);transform:scaleX(0);transform-origin:left;transition:transform .25s;z-index:1}
.srv-card:hover{box-shadow:var(--shH);transform:translateY(-4px);border-color:var(--sf-m)}
.srv-card:hover::before{transform:scaleX(1)}
.sc-img-wrap{overflow:hidden}
.sc-img-wrap .img-ph,.sc-img-wrap img{transition:transform .35s}
.srv-card:hover .sc-img-wrap .img-ph,
.srv-card:hover .sc-img-wrap img{transform:scale(1.04)}
.sc-body{padding:18px 16px 20px}
.sc-body h3{font-size:14px;font-weight:600;color:var(--dark);margin-bottom:6px;transition:color .2s}
.srv-card:hover .sc-body h3{color:var(--sf)}
.sc-body p{font-size:12px;color:var(--muted);line-height:1.7}
.sc-lnk{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:var(--sf);margin-top:10px;transition:gap .2s}
.srv-card:hover .sc-lnk{gap:8px}

/* ── WHY CHOOSE ── */
.why-g{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.why-pts{display:flex;flex-direction:column;gap:14px;margin-top:22px}
.why-pt{display:flex;align-items:flex-start;gap:14px;padding:15px 17px;background:var(--bg);border:1px solid var(--border);border-radius:var(--r);transition:all .2s}
.why-pt:hover{border-color:var(--sf-m);box-shadow:0 4px 16px rgba(232,98,10,.08)}
.why-n{width:34px;height:34px;background:var(--sf);color:#fff;border-radius:7px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0}
.why-pt h4{font-size:13px;font-weight:600;color:var(--dark);margin-bottom:3px}
.why-pt p{font-size:12px;color:var(--muted);line-height:1.65}
.why-vis{background:var(--sf-l);border-radius:var(--rL);padding:28px;display:flex;flex-direction:column;gap:16px}
.wsc-g{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.wsc{background:#fff;border-radius:var(--r);padding:16px;text-align:center;box-shadow:var(--sh)}
.wsc-v{font-size:24px;font-weight:700;color:var(--sf);font-family:'Playfair Display',serif}
.wsc-l{font-size:11px;color:var(--muted);margin-top:3px}
.spec-tags{display:flex;flex-wrap:wrap;gap:7px}
.spec-tag{background:#fff;border:1px solid var(--sf-m);color:var(--sf-d);font-size:11px;font-weight:500;padding:4px 11px;border-radius:20px}

/* ── HOW IT WORKS ── */
.steps-g{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:44px;position:relative}
.steps-g::before{content:'';position:absolute;top:36px;left:calc(12.5% + 16px);right:calc(12.5% + 16px);height:2px;background:rgba(255,255,255,.08)}
.step{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:var(--rL);padding:26px 18px;text-align:center;position:relative;z-index:1;transition:background .25s}
.step:hover{background:rgba(232,98,10,.12);border-color:rgba(232,98,10,.3)}
.step-n{width:54px;height:54px;background:var(--sf);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;margin:0 auto 16px;font-family:'Playfair Display',serif;box-shadow:0 0 0 6px rgba(232,98,10,.15)}
.step h3{font-size:14px;font-weight:600;color:#fff;margin-bottom:7px}
.step p{font-size:12px;color:rgba(255,255,255,.55);line-height:1.65}

/* ── REVIEWS ── */
.rat-bar{display:flex;align-items:center;gap:20px;background:#fff;border:1px solid var(--border);border-radius:var(--rL);padding:22px 28px;max-width:420px;margin-bottom:32px}
.rat-big{font-family:'Playfair Display',serif;font-size:48px;font-weight:700;color:var(--sf);line-height:1}
.stars{color:#FBBF24;font-size:18px;letter-spacing:2px}
.rev-g{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.rev-c{background:#fff;border:1px solid var(--border);border-radius:var(--rL);padding:22px;transition:box-shadow .2s}
.rev-c:hover{box-shadow:var(--sh)}
.rev-stars{color:#FBBF24;font-size:13px;margin-bottom:10px}
.rev-txt{font-size:13px;color:var(--text);line-height:1.75;margin-bottom:16px;font-style:italic}
.rev-by{display:flex;align-items:center;gap:10px}
.rev-av{width:40px;height:40px;border-radius:50%;background:var(--sf);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}
.rev-nm{font-size:13px;font-weight:600;color:var(--dark)}
.rev-lc{font-size:11px;color:var(--muted)}

/* ── DOSHA CARDS ── */
.dsh-g{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:44px}
.dsh-c{border:1px solid var(--border);border-radius:var(--rL);overflow:hidden;transition:all .25s}
.dsh-c:hover{border-color:var(--sf-m);box-shadow:var(--shH)}
.dsh-head{background:var(--sf-l);padding:22px;text-align:center}
.dsh-ic{font-size:40px;margin-bottom:8px;line-height:1}
.dsh-c h3{font-size:15px;font-weight:600;color:var(--dark);margin-bottom:4px}
.dsh-body{padding:18px 22px}
.dsh-body p{font-size:12px;color:var(--muted);line-height:1.7;margin-bottom:12px}

/* ── SOCIAL PROOF STRIP ── */
.social-strip{background:var(--sf-l);padding:32px 0;border-top:1px solid var(--sf-m);border-bottom:1px solid var(--sf-m)}
.social-strip-g{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.ss-ic{font-size:28px;margin-bottom:8px}
.ss-val{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;color:var(--sf);line-height:1;margin-bottom:4px}
.ss-lbl{font-size:11px;color:var(--muted);font-weight:500}
.ss-link{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:var(--sf);margin-top:6px;text-decoration:none}
.ss-link:hover{color:var(--sf-d)}

/* ── FAQ ── */
.faq-wrap{max-width:780px;margin:36px auto 0}
.faq-item{border:1px solid var(--border);border-radius:var(--r);margin-bottom:10px;overflow:hidden;transition:border-color .2s}
.faq-item.open{border-color:var(--sf-m)}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:16px 20px;cursor:pointer;background:#fff;font-size:13px;font-weight:600;color:var(--dark);transition:background .2s;user-select:none}
.faq-item.open .faq-q{background:var(--sf-l);color:var(--sf-d)}
.faq-tog{width:26px;height:26px;border-radius:50%;background:var(--bgg);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:17px;color:var(--sf);flex-shrink:0;transition:all .2s;line-height:1}
.faq-item.open .faq-tog{background:var(--sf);color:#fff;transform:rotate(45deg)}
.faq-ans{display:none;padding:0 20px 16px;font-size:13px;color:var(--text);line-height:1.85;background:var(--sf-l)}
.faq-item.open .faq-ans{display:block}

/* ── CONTACT PAGE ── */
.ct-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:start}
.ct-info{background:#fff;border:1px solid var(--border);border-radius:var(--rL);padding:30px}
.ct-items{display:flex;flex-direction:column;gap:18px}
.ct-item{display:flex;gap:14px;align-items:flex-start}
.ct-ic{width:44px;height:44px;background:var(--sf-l);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;font-style:normal}
.ct-item h5{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--sf);margin-bottom:3px}
.ct-item p{font-size:13px;color:var(--text);line-height:1.6}
.ct-item a{color:var(--sf);font-weight:600}
.ct-hours{margin-top:20px;background:var(--bgg);border-radius:var(--r);padding:14px 18px;font-size:12px;color:var(--muted)}
.ct-map{margin-top:18px;border-radius:var(--rL);overflow:hidden;border:1px solid var(--border)}
.ct-form{background:var(--dark);border-radius:var(--rL);padding:30px}
.fg{margin-bottom:14px}
.fg label{display:block;font-size:11px;font-weight:700;color:rgba(255,255,255,.5);letter-spacing:.06em;text-transform:uppercase;margin-bottom:6px}
.fg input,.fg select,.fg textarea{width:100%;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.9);font-family:'Poppins',sans-serif;font-size:13px;padding:10px 14px;border-radius:var(--r);outline:none;transition:border-color .2s}
.fg input::placeholder,.fg textarea::placeholder{color:rgba(255,255,255,.3)}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--sf)}
.fg select option{background:#333}
.fg textarea{height:90px;resize:vertical}
.form-note{font-size:11px;color:rgba(255,255,255,.3);text-align:center;margin-top:10px}

/* ── CTA SECTION ── */
.cta-section{background:linear-gradient(135deg,var(--sf) 0%,var(--sf-d) 100%);padding:60px 0;text-align:center}
.cta-section h2{font-family:'Playfair Display',serif;font-size:clamp(22px,3.5vw,36px);color:#fff;margin-bottom:10px}
.cta-section p{color:rgba(255,255,255,.88);font-size:14px;margin-bottom:28px;line-height:1.7}
.cta-btns{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}

/* ══════════════════════════════════════════════════════
   FOOTER — Complete redesign
   Dark background, 4-col grid, proper hierarchy
══════════════════════════════════════════════════════ */
#footer{
  background:linear-gradient(180deg,#1a1208 0%,var(--dark) 100%);
  color:rgba(255,255,255,.6);
}

/* ── Top footer: 4-column grid ── */
.ft-main{padding:60px 0 40px}
.ft-g{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1.4fr;
  gap:40px;
  align-items:start;
}

/* Brand column */
.ft-logo{
  display:flex;align-items:center;gap:12px;
  margin-bottom:16px;
}
.ft-logo .logo-img{
  width:48px;height:48px;border-radius:10px;
  object-fit:cover;flex-shrink:0;
  border:2px solid rgba(255,255,255,.1);
}
.ft-logo .logo-ph{
  width:48px;height:48px;background:var(--sf);
  border-radius:10px;display:flex;align-items:center;
  justify-content:center;font-size:22px;flex-shrink:0;
}
.ft-brand-name{
  font-family:'Playfair Display',serif;
  font-size:17px;font-weight:700;color:#fff;line-height:1.2;
}
.ft-brand-tag{
  font-size:10px;color:var(--sf);font-weight:600;
  letter-spacing:.06em;text-transform:uppercase;margin-top:2px;
}
.ft-desc{
  font-size:12.5px;line-height:1.9;
  color:rgba(255,255,255,.48);
  margin-bottom:20px;max-width:280px;
}

/* Social icons */
.ft-soc{display:flex;gap:8px;flex-wrap:wrap}
.ft-s{
  width:36px;height:36px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.1);
  border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-size:15px;transition:all .2s;text-decoration:none;
  flex-shrink:0;
}
.ft-s:hover{background:var(--sf);border-color:var(--sf);transform:translateY(-2px)}

/* Column headings */
.ft-col h4{
  font-size:13px;font-weight:700;color:#fff;
  margin-bottom:18px;padding-bottom:10px;
  position:relative;letter-spacing:.02em;
  text-transform:uppercase;font-family:'Poppins',sans-serif;
}
.ft-col h4::after{
  content:'';position:absolute;bottom:0;left:0;
  width:28px;height:2px;
  background:var(--sf);border-radius:2px;
}

/* Link lists */
.ft-lks{display:flex;flex-direction:column;gap:9px}
.ft-lks a{
  font-size:13px;color:rgba(255,255,255,.52);
  transition:all .2s;text-decoration:none;
  display:flex;align-items:center;gap:6px;
  padding:2px 0;
}
.ft-lks a::before{
  content:'›';color:var(--sf);font-size:14px;
  opacity:0;transition:opacity .2s;
  margin-left:-8px;flex-shrink:0;
}
.ft-lks a:hover{color:rgba(255,255,255,.9);padding-left:6px}
.ft-lks a:hover::before{opacity:1}

/* Contact info */
.ft-ci{display:flex;flex-direction:column;gap:12px}
.ft-ci-i{
  display:flex;gap:10px;align-items:flex-start;
  font-size:12.5px;color:rgba(255,255,255,.5);
  line-height:1.6;
}
.ft-ci-i>span{
  font-size:15px;flex-shrink:0;
  margin-top:1px;opacity:.8;
}
.ft-ci-i a{color:rgba(255,255,255,.75);transition:color .2s}
.ft-ci-i a:hover{color:var(--sf)}

/* ── Divider between top and bottom footer ── */
.ft-divider{
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);
  margin:0;
}

/* ── Authority block ── */
.ft-bot{padding:28px 0 0}
.footer-authority-block{
  padding:0 0 20px;
  border-bottom:1px solid rgba(255,255,255,.07);
  margin-bottom:20px;
}
.footer-authority-block h5{
  font-size:13px;font-weight:600;
  color:var(--gold-lt);margin-bottom:10px;
  font-family:'Poppins',sans-serif;
  letter-spacing:.02em;
}
.footer-authority-block p{
  font-size:12px;color:rgba(255,255,255,.48);
  line-height:1.8;margin-bottom:14px;max-width:760px;
}
.footer-authority-block p strong{color:rgba(255,255,255,.8)}
.footer-authority-block p a{
  color:rgba(255,255,255,.55);
  text-decoration:underline;
  text-decoration-color:rgba(255,255,255,.2);
  transition:color .2s;
}
.footer-authority-block p a:hover{color:var(--sf)}

/* Keyword links */
.ft-kw-links{display:flex;flex-wrap:wrap;gap:8px}
.ft-kw-links a{
  font-size:11px;color:rgba(255,255,255,.42);
  text-decoration:none;
  padding:4px 12px;
  border:1px solid rgba(255,255,255,.1);
  border-radius:16px;
  transition:all .2s;font-weight:500;
}
.ft-kw-links a:hover{
  color:var(--sf);border-color:var(--sf);
  background:rgba(232,98,10,.08);
}

/* ── Copyright bar ── */
.ft-bot-in{
  display:flex;justify-content:space-between;
  align-items:center;flex-wrap:wrap;gap:8px;
  font-size:11px;color:rgba(255,255,255,.28);
  padding-bottom:24px;
}
.ft-bot-in a{color:rgba(255,255,255,.4);transition:color .2s}
.ft-bot-in a:hover{color:var(--sf)}

/* ── STICKY MOBILE CTA — 5-button bar ── */
#mob-cta{
  display:none;
  position:fixed;bottom:0;left:50%;
  transform:translateX(-50%);
  width:100%;max-width:var(--W);
  z-index:1001;
  background:#fff;
  border-top:2px solid var(--sf-m);
  box-shadow:0 -4px 20px rgba(0,0,0,.15);
  grid-template-columns:repeat(5,1fr);
  padding:0;
}
.mob-btn{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;padding:9px 4px 8px;font-size:9px;font-weight:700;
  text-decoration:none;transition:all .15s;border:none;
  letter-spacing:.02em;text-transform:uppercase;
  -webkit-tap-highlight-color:transparent;
}
.mob-btn svg{flex-shrink:0;width:18px;height:18px}
.mob-btn:active{opacity:.75;transform:scale(.96)}

/* Individual button colours */
.mob-home{color:#444;background:#f9f9f9;border-right:1px solid #eee}
.mob-home:hover,.mob-home:focus{background:var(--sf-l);color:var(--sf)}
.mob-call{color:#fff;background:var(--sf);border-right:1px solid rgba(255,255,255,.2)}
.mob-call:hover,.mob-call:focus{background:var(--sf-d)}
.mob-wa{color:#fff;background:#25D366;border-right:1px solid rgba(255,255,255,.2)}
.mob-wa:hover,.mob-wa:focus{background:#1da851}
.mob-dir{color:#fff;background:#4285F4;border-right:1px solid rgba(255,255,255,.2)}
.mob-dir:hover,.mob-dir:focus{background:#2a6dd9}
.mob-yt{color:#fff;background:#FF0000}
.mob-yt:hover,.mob-yt:focus{background:#cc0000}

/* ── WA FLOAT ── */
/* ── LOGO IMAGE ── */
.logo-img{width:44px;height:44px;border-radius:8px;object-fit:cover;flex-shrink:0}

/* ── HERO PANDIT IMAGE ── */
.hero-pandit-img{width:100%;max-width:420px;height:auto;border-radius:var(--rL);object-fit:cover;display:block}
.about-main-img{width:100%;height:auto;border-radius:var(--rL);object-fit:cover;display:block}

/* ── SERVICE / BLOG DETAIL PAGE GRIDS ── */
.service-detail-grid{display:grid;grid-template-columns:1fr 320px;gap:40px;align-items:start}
.blog-detail-grid{display:grid;grid-template-columns:1fr 300px;gap:40px;align-items:start}

/* ── SIDEBAR ── */
.sidebar{display:flex;flex-direction:column;gap:20px;position:sticky;top:90px}
.sidebar-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--rL);padding:22px}
.sidebar-card h4{font-family:'Playfair Display',serif;font-size:16px;color:var(--dark);margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid var(--sf-m)}
.sidebar-cta{background:var(--sf);border-radius:var(--rL);padding:22px;color:#fff}
.sidebar-cta h4{font-family:'Playfair Display',serif;font-size:15px;color:#fff;margin-bottom:8px}
.sidebar-cta p{font-size:12px;color:rgba(255,255,255,.8);line-height:1.7;margin-bottom:14px}
.sc-contact-item{display:flex;align-items:flex-start;gap:10px;margin-bottom:14px}
.sc-icon{font-size:18px;flex-shrink:0;margin-top:2px}
.sc-label{font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}
.sc-value{font-size:13px;font-weight:600;color:var(--dark)}
.sc-value a{color:var(--sf)}
.sc-value a:hover{text-decoration:underline}
.other-services{display:flex;flex-direction:column;gap:6px}
.other-services a{font-size:12px;color:var(--text);text-decoration:none;padding:6px 10px;border-radius:var(--r);background:#fff;border:1px solid var(--border);transition:all .2s;display:flex;align-items:center;gap:6px;font-weight:500}
.other-services a:hover{background:var(--sf-l);color:var(--sf);border-color:var(--sf-m)}

/* ── SERVICE PAGE CONTENT ── */
.service-content h2{font-family:'Playfair Display',serif;font-size:clamp(20px,2.5vw,26px);color:var(--dark);margin:28px 0 12px}
.service-content h3{font-size:15px;font-weight:700;color:var(--dark);margin:22px 0 10px}
.service-content p{font-size:14px;color:var(--text);line-height:1.85;margin-bottom:14px}
.service-content ul{padding-left:0;list-style:none;margin-bottom:18px;display:flex;flex-direction:column;gap:8px}
.service-content ul li{font-size:14px;color:var(--text);line-height:1.7;padding-left:20px;position:relative}
.service-content ul li::before{content:'✦';position:absolute;left:0;color:var(--sf);font-size:10px;top:4px}
.service-content blockquote{border-left:3px solid var(--sf);padding:14px 20px;background:var(--sf-l);border-radius:0 var(--r) var(--r) 0;margin:20px 0;font-size:13px;font-style:italic;color:var(--dark);line-height:1.75}
.highlight-box{background:var(--sf-l);border:1.5px solid var(--sf-m);border-radius:var(--r);padding:18px 22px;margin:20px 0}
.highlight-box h4{font-size:13px;font-weight:700;color:var(--sf-d);margin-bottom:10px}

/* ── BLOG BODY ── */
.blog-body h2{font-family:'Playfair Display',serif;font-size:clamp(18px,2.5vw,24px);color:var(--dark);margin:28px 0 12px;border-bottom:2px solid var(--sf-l);padding-bottom:8px}
.blog-body h3{font-size:15px;font-weight:700;color:var(--dark);margin:20px 0 10px}
.blog-body p{font-size:14px;color:var(--text);line-height:1.9;margin-bottom:16px}
.blog-body ul{padding-left:20px;margin-bottom:18px}
.blog-body ul li{font-size:14px;color:var(--text);line-height:1.75;margin-bottom:6px}
.blog-body blockquote{border-left:3px solid var(--sf);padding:14px 20px;background:var(--sf-l);border-radius:0 var(--r) var(--r) 0;margin:24px 0;font-size:13px;font-style:italic;color:var(--dark);line-height:1.75}
.blog-body .highlight-box{background:var(--sf-l);border:1.5px solid var(--sf-m);border-radius:var(--r);padding:18px 22px;margin:20px 0}
.blog-body .highlight-box h4{font-size:13px;font-weight:700;color:var(--sf-d);margin-bottom:10px}
.blog-body .highlight-box ul{margin:0;padding-left:18px}

/* ── BLOG GRID (listing page) ── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.blog-c{display:flex;flex-direction:column;border-radius:var(--rL);overflow:hidden;border:1px solid var(--border);text-decoration:none;color:inherit;transition:all .25s;background:#fff}
.blog-c:hover{box-shadow:var(--shH);transform:translateY(-4px)}
.bc-img{position:relative;overflow:hidden}
.bc-cat{position:absolute;top:12px;left:12px;font-size:10px;font-weight:700;background:var(--sf);color:#fff;padding:3px 10px;border-radius:12px;text-transform:uppercase;letter-spacing:.05em}
.bc-body{padding:18px;flex:1;display:flex;flex-direction:column;gap:8px}
.bc-date{font-size:11px;color:var(--muted);font-weight:500}
.bc-body h3{font-family:'Playfair Display',serif;font-size:16px;color:var(--dark);line-height:1.35}
.bc-body p{font-size:12px;color:var(--muted);line-height:1.7;flex:1}
.bc-rd{font-size:12px;font-weight:700;color:var(--sf);margin-top:auto}

/* ── FAQ ── */
.faq-wrap{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:10px;margin-top:28px}
.faq-item{background:#fff;border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.faq-q{padding:16px 20px;font-size:14px;font-weight:600;color:var(--dark);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:12px;transition:background .2s}
.faq-q:hover{background:var(--sf-l)}
.faq-tog{font-size:20px;font-weight:300;color:var(--sf);flex-shrink:0;transition:transform .25s}
.faq-item.open .faq-tog{transform:rotate(45deg)}
.faq-ans{font-size:13px;color:var(--text);line-height:1.8;padding:0 20px;max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease}
.faq-item.open .faq-ans{max-height:600px;padding:14px 20px 18px}

/* ── SERVICE GRID ── */
.srv-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.sc-body{padding:16px;flex:1;display:flex;flex-direction:column;gap:6px}
.sc-body h3{font-size:13px;font-weight:700;color:var(--dark);line-height:1.35}
.sc-body p{font-size:11px;color:var(--muted);line-height:1.65;flex:1}
.sc-lnk{font-size:11px;font-weight:700;color:var(--sf);margin-top:auto}

/* ── SERVICE DETAIL PAGE CTA BUTTONS ── */
.btn-full{width:100%;justify-content:center}

/* ── LOCATIONS INDEX PAGE ── */
.loc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.loc-card{display:block;padding:16px;background:#fff;border:1px solid var(--border);border-radius:var(--r);text-decoration:none;color:var(--text);transition:all .2s;font-size:13px;font-weight:500}
.loc-card:hover{background:var(--sf-l);border-color:var(--sf);color:var(--sf)}
.loc-card.loc-priority{border-color:var(--sf-m);background:var(--sf-l);font-weight:700}
.loc-card.loc-priority:hover{background:var(--sf);color:#fff}
.loc-area-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-top:4px;display:block}
.loc-priority .loc-area-label{color:var(--sf-d)}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .ft-g{grid-template-columns:1fr 1fr;gap:32px}
  .rev-g{grid-template-columns:repeat(2,1fr)}
  .dsh-g{grid-template-columns:repeat(2,1fr)}
  .service-detail-grid,.blog-detail-grid{grid-template-columns:1fr 280px;gap:28px}
  .sidebar{position:static}
  .srv-grid{grid-template-columns:repeat(3,1fr)}
  .loc-grid{grid-template-columns:repeat(3,1fr)}
  .blog-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:900px){
  .hero-grid,.about-grid,.why-g,.ct-grid{grid-template-columns:1fr}
  .hero-vis{display:none}
  .hero{padding-bottom:48px}
  .steps-g{grid-template-columns:repeat(2,1fr)}
  .steps-g::before{display:none}
  .stats-g{grid-template-columns:repeat(2,1fr)}
  .social-strip-g{grid-template-columns:repeat(2,1fr)}
  .srv-grid{grid-template-columns:repeat(2,1fr)}
  .tb-L{display:none}
  .exp-badge{right:10px}
  .service-detail-grid,.blog-detail-grid{grid-template-columns:1fr}
  .sidebar{position:static;display:grid;grid-template-columns:1fr 1fr;gap:16px}
}
@media(max-width:768px){
  .nav-list{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;align-items:stretch;gap:0;box-shadow:0 8px 24px rgba(0,0,0,.1);padding:8px 16px 14px;border-top:1px solid var(--border)}
  .nav-list.open{display:flex}
  .nav-list>li>a,.nav-list>li>.nav-drop-btn{border-bottom:1px solid var(--border);border-radius:0;padding:12px 8px}
  .ndrop-menu{position:static;box-shadow:none;border:none;padding:0 0 0 16px}
  .hamburger{display:flex}
  .nav-phone{display:none}
  /* Show 5-button mobile CTA */
  #mob-cta{display:grid;grid-template-columns:repeat(5,1fr)}
  body{padding-bottom:68px}
  .dsh-g,.steps-g{grid-template-columns:1fr}
  .rev-g{grid-template-columns:1fr}
  .cred-g{grid-template-columns:1fr 1fr}
  .ft-g{grid-template-columns:1fr 1fr;gap:24px}
  .ft-bot-in{flex-direction:column;text-align:center;gap:6px}
  .ft-desc{max-width:100%}
  .btn-group{flex-direction:column}
  .btn-group .btn{justify-content:center}
  .cta-btns{flex-direction:column;align-items:center}
  .srv-grid{grid-template-columns:repeat(2,1fr)}
  .hero-stats{gap:14px}
  .hs-div{display:none}
  .service-detail-grid,.blog-detail-grid{grid-template-columns:1fr}
  .sidebar{display:flex;flex-direction:column}
  .loc-grid{grid-template-columns:repeat(2,1fr)}
  .blog-grid{grid-template-columns:1fr}
  .ft-kw-links{gap:6px}
  /* Location page hero anchor link */
  .loc-hero-anchor{display:inline-flex;margin-top:10px}
}
@media(max-width:480px){
  .section-pad{padding:48px 0}
  .section-pad-sm{padding:36px 0}
  .cred-g{grid-template-columns:1fr}
  .wsc-g{grid-template-columns:1fr 1fr}
  .social-strip-g{grid-template-columns:1fr 1fr}
  .srv-grid{grid-template-columns:1fr}
  .loc-grid{grid-template-columns:1fr 1fr}
  /* Slightly smaller CTA text on tiny screens */
  .ft-g{grid-template-columns:1fr !important;gap:24px}
  .mob-btn{font-size:8px;padding:8px 2px 7px}
  .mob-btn svg{width:16px;height:16px}
}


/* ── RESPONSIVE FINAL PASS ── */
@media(max-width:900px){
  .stats-g{grid-template-columns:repeat(2,1fr)}
  .social-strip-g{grid-template-columns:repeat(2,1fr)}
  .dsh-g{grid-template-columns:repeat(2,1fr)}
  .ct-grid{grid-template-columns:1fr}
  .ct-row{grid-template-columns:1fr}
  .hero-vis{height:360px}
  .exp-badge{right:0;bottom:0}
}
@media(max-width:768px){
  .stats-g{grid-template-columns:repeat(2,1fr)}
  .social-strip-g{grid-template-columns:1fr 1fr}
  .dsh-g{grid-template-columns:1fr}
  .steps-g{grid-template-columns:1fr 1fr;gap:20px}
  .steps-g::before{display:none}
  .rev-g{grid-template-columns:1fr}
  .why-g,.about-grid,.ct-grid{grid-template-columns:1fr}
  .cred-g{grid-template-columns:1fr}
  .about-img-wrap{max-width:480px;margin:0 auto}
  .exp-badge{right:12px;bottom:12px}
  .hero-stats{gap:12px}
  .container{padding:0 16px}
}
@media(max-width:480px){
  .stats-g{grid-template-columns:1fr 1fr}
  .stat-c{padding:16px 10px}
  .container{padding:0 14px}
  .hero-stats{flex-wrap:wrap;gap:8px;padding:12px 0}
}

/* ══════════════════════════════════════════════════════
   INDEX PAGE — ALL GRID CLASSES (replaces broken inline styles)
══════════════════════════════════════════════════════ */

/* Info boxes (3 topic cards: Rashi Bhavishya, 2026 Predictions, Vastu) */
.info-boxes-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}

/* Quick facts (3 columns in the hero area) */
.quick-facts-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}

/* Video gallery (2 columns) */
.video-gallery-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:24px;
  margin-bottom:36px;
}

/* Why Bangalore families trust — 2-col case study cards */
.why-cards-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:22px;
}

/* Resources / external links grid */
.resources-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:36px;
}

/* ── HERO BADGE FIX: hide both badges on mobile ── */
/* The b2 badge (30+ Years Active) overlaps hero-stats on mobile */
/* hero-vis is already hidden at 900px, but badges are children of hero-content */
/* Move badge hiding to match screen where stats show */
@media(max-width:768px){
  .hero-bdg{display:none !important}
}

/* ── OPEN NOW BADGE: fix double pulse dot ── */
/* Remove pulse from the badge wrapper — keep only on the inner dot span */
.open-now-badge{animation:none !important}

/* ── RESPONSIVE: all new grid classes ── */
@media(max-width:900px){
  .info-boxes-grid{grid-template-columns:1fr}
  .quick-facts-grid{grid-template-columns:1fr}
  .video-gallery-grid{grid-template-columns:1fr}
  .why-cards-grid{grid-template-columns:1fr}
  .resources-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .info-boxes-grid{grid-template-columns:1fr}
  .quick-facts-grid{grid-template-columns:1fr}
  .video-gallery-grid{grid-template-columns:1fr}
  .why-cards-grid{grid-template-columns:1fr}
  .resources-grid{grid-template-columns:1fr}
  /* Footer: stack at 768 */
  .ft-g{grid-template-columns:1fr 1fr !important}
}
@media(max-width:480px){
  .info-boxes-grid{grid-template-columns:1fr}
  .quick-facts-grid{grid-template-columns:1fr}
  .ft-g{grid-template-columns:1fr !important}
  /* Rashi grid — 3 col at 480px */
  .rashi-grid{grid-template-columns:repeat(3,1fr) !important}
}

/* ══════════════════════════════════════════════════════
   MOBILE OVERFLOW — FINAL COMPREHENSIVE FIX
   Uses overflow-x:clip on key wrappers instead of [style*]
══════════════════════════════════════════════════════ */

/* Any element that could exceed viewport width */
.section-pad,.section-pad-sm,
.hero,.vid-section,.stats-strip,
.cta-section,.ft-main,.ft-bot,
#rashifal,#quick-facts,#why-bangalore,
#resources,#video-gallery,#videos,
#priority-areas,.keyword-section{
  overflow-x:clip;
  max-width:100%;
}

/* Prevent inline-style grids from overflowing on mobile */
@media(max-width:768px){
  /* Target remaining inline grids that weren't converted to classes */
  [style*="grid-template-columns"]{
    grid-template-columns:1fr !important;
  }
  [style*="grid-template-columns:repeat(2"]{
    grid-template-columns:1fr 1fr !important;
  }
  [style*="grid-template-columns:1fr 360px"],
  [style*="grid-template-columns:1fr 320px"],
  [style*="grid-template-columns:1fr 300px"],
  [style*="grid-template-columns:1fr 280px"],
  [style*="grid-template-columns:2fr 1fr"],
  [style*="grid-template-columns:1fr 1.1fr"]{
    grid-template-columns:1fr !important;
  }
  /* Sidebar stacks below on mobile */
  .sidebar{position:static !important;display:flex;flex-direction:column}
  /* Map aspect ratio on mobile */
  .ct-map{aspect-ratio:4/3;height:auto}
}

@media(max-width:480px){
  /* On very small screens, even 2-col grids stack */
  [style*="grid-template-columns:repeat(2"]{
    grid-template-columns:1fr !important;
  }
  [style*="grid-template-columns:1fr 1fr"]{
    grid-template-columns:1fr !important;
  }
  /* Keep rashi grid 3-col (icons are small) */
  #rashifal [style*="grid-template-columns"]{
    grid-template-columns:repeat(3,1fr) !important;
  }
  /* Keep service cards 2-col */
  .srv-grid{grid-template-columns:repeat(2,1fr) !important}
}

/* ══════════════════════════════════════════════════════
   LOCATION PAGES — responsive service grid
══════════════════════════════════════════════════════ */
@media(max-width:768px){
  /* Location service links grid (inline 2-col) */
  .service-detail-grid [style*="grid-template-columns:1fr 1fr"],
  .service-detail-grid [style*="grid-template-columns:repeat(2"]{
    grid-template-columns:1fr !important;
  }
  /* Local info box address grid */
  #local-info [style*="grid-template-columns:1fr 1fr"]{
    grid-template-columns:1fr !important;
  }
}

/* ══════════════════════════════════════════════════════
   FOOTER — Responsive fixes (override earlier rules)
══════════════════════════════════════════════════════ */
@media(max-width:600px){
  .ft-g{grid-template-columns:1fr !important}
  .footer-authority-block p{font-size:11px}
  .ft-kw-links a{font-size:10px;padding:3px 8px}
  .ft-bot-in{flex-direction:column;text-align:center;gap:6px;font-size:10px}
}

/* ══════════════════════════════════════════════════════
   MOBILE CTA BAR — pinned inside boxed layout
══════════════════════════════════════════════════════ */
@media(max-width:768px){
  #mob-cta{
    display:grid !important;
    grid-template-columns:repeat(5,1fr);
    position:fixed;
    bottom:0;
    left:50%;
    transform:translateX(-50%);
    width:100%;
    max-width:var(--W);
    z-index:1001;
  }
  body{padding-bottom:64px}
}
@media(max-width:480px){
  .mob-btn{font-size:8px;padding:7px 2px 6px}
  .mob-btn svg{width:16px;height:16px}
  .mob-btn span{font-size:8px}
}

/* ══════════════════════════════════════════════════════
   QUICK FACTS SECTION — replaces inline grids
══════════════════════════════════════════════════════ */
.qf-outer-grid{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:24px;
  align-items:start;
}
.qf-left-col{
  padding-right:24px;
  border-right:2px solid var(--sf-m);
}
@media(max-width:768px){
  .qf-outer-grid{grid-template-columns:1fr}
  .qf-left-col{
    border-right:none;
    border-bottom:2px solid var(--sf-m);
    padding-right:0;
    padding-bottom:14px;
  }
  .quick-facts-grid{grid-template-columns:1fr}
}

/* ══════════════════════════════════════════════════════
   ALL REMAINING INLINE GRID OVERRIDES FOR MOBILE
   Applied via universal selector on screens ≤768px
══════════════════════════════════════════════════════ */
@media(max-width:768px){
  /* Service detail & blog detail sidebar */
  .service-detail-grid,
  .blog-detail-grid{
    grid-template-columns:1fr !important;
  }
  .sidebar{
    position:static !important;
    width:100% !important;
  }
  /* Location page directions grid */
  #local-info > div[style*="grid-template-columns:1fr 1fr"],
  #local-info > div[style*="grid-template-columns:repeat(2"]{
    grid-template-columns:1fr !important;
  }
  /* Footer grid */
  .ft-g{grid-template-columns:1fr 1fr !important;gap:24px}
  /* Service links in location pages */
  div[style*="grid-template-columns:1fr 1fr"].svc-links-grid{
    grid-template-columns:1fr !important;
  }
}

@media(max-width:600px){
  .ft-g{grid-template-columns:1fr !important}
  .ft-bot-in{flex-direction:column;text-align:center;gap:6px}
}

/* ══════════════════════════════════════════════════════
   UNIVERSAL MOBILE OVERFLOW PREVENTION
   Applied last so it wins over all other rules
══════════════════════════════════════════════════════ */
@media(max-width:768px){
  body,html{
    overflow-x:hidden !important;
    max-width:100vw !important;
  }
  /* Every direct child of body must not overflow */
  body > *{
    max-width:100vw;
    overflow-x:hidden;
  }
  /* Prevent any element from being wider than viewport */
  img,iframe,video,embed,object{
    max-width:100% !important;
    height:auto;
  }
}

/* ══════════════════════════════════════════════════════
   INDEX PAGE — ALL CONVERTED GRID CLASSES
   Replaces all removed inline style= grid-template-columns
══════════════════════════════════════════════════════ */

/* Rashi / Moon Signs 6-column grid */
.rashi-grid{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:12px;
}

/* Trustindex skeleton 3-column */
.ti-skeleton-inner{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.ti-skeleton-grid{position:relative}

/* ── KEYFRAMES (moved from inline <style> blocks) ── */
@keyframes pulseDot {
  0%,100% { box-shadow:0 0 0 3px rgba(34,197,94,.25); }
  50%      { box-shadow:0 0 0 6px rgba(34,197,94,.1); }
}
@keyframes skeletonPulse {
  0%,100% { opacity:1 }
  50%      { opacity:.4 }
}
@keyframes aisGlow {
  0%   { background-position:0% 50% }
  50%  { background-position:100% 50% }
  100% { background-position:0% 50% }
}

/* ══════════════════════════════════════════════════════
   COMPLETE RESPONSIVE OVERRIDES FOR ALL GRID CLASSES
══════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .rashi-grid{grid-template-columns:repeat(4,1fr)}
  .ti-skeleton-inner{grid-template-columns:repeat(2,1fr)}
  .info-boxes-grid{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:768px){
  /* All index grids → single column */
  .rashi-grid{grid-template-columns:repeat(3,1fr)}
  .ti-skeleton-inner{grid-template-columns:1fr}
  .info-boxes-grid{grid-template-columns:1fr}
  .quick-facts-grid{grid-template-columns:1fr}
  .video-gallery-grid{grid-template-columns:1fr}
  .why-cards-grid{grid-template-columns:1fr}
  .resources-grid{grid-template-columns:1fr}
  /* Service detail / blog detail */
  .service-detail-grid{grid-template-columns:1fr !important}
  .blog-detail-grid{grid-template-columns:1fr !important}
  /* Sidebar always below on mobile */
  .sidebar{
    position:static !important;
    width:100%;
    display:flex;
    flex-direction:column;
  }
  /* Location page service links 2-col → 1-col */
  .service-detail-grid [style*="grid-template-columns:1fr 1fr"]{
    grid-template-columns:1fr !important;
  }
  /* Local info box address/hours */
  #local-info [style*="grid-template-columns"]{
    grid-template-columns:1fr !important;
  }
  /* Location sidebar cards */
  .sidebar.loc-sidebar{grid-template-columns:1fr}
}

@media(max-width:480px){
  .rashi-grid{grid-template-columns:repeat(3,1fr)}
  .srv-grid{grid-template-columns:repeat(2,1fr)}
  .info-boxes-grid{grid-template-columns:1fr}
  .why-cards-grid{grid-template-columns:1fr}
}

/* ══════════════════════════════════════════════════════
   FINAL UNIVERSAL OVERFLOW GUARD
   Ensures nothing ever causes horizontal scroll on mobile
══════════════════════════════════════════════════════ */
@media(max-width:768px){
  html,body{
    overflow-x:hidden !important;
    width:100% !important;
    max-width:100% !important;
  }
  img,video,iframe,embed{
    max-width:100% !important;
    width:auto;
  }
  img{width:100%}
}

/* ══════════════════════════════════════════════════════
   LOCATION PAGE GRIDS
══════════════════════════════════════════════════════ */
.local-info-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-top:12px;
}
.loc-services-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}
@media(max-width:600px){
  .local-info-grid{grid-template-columns:1fr}
  .loc-services-grid{grid-template-columns:1fr}
}

/* ══════════════════════════════════════════════════════
   PALMISTRY PAGE GRIDS
══════════════════════════════════════════════════════ */
.palm-5grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:8px;
  margin-top:18px;
}
.palm-2grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-top:10px;
}
@media(max-width:768px){
  .palm-5grid{grid-template-columns:repeat(3,1fr)}
  .palm-2grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  .palm-5grid{grid-template-columns:repeat(2,1fr)}
}
