/* ===========================================================
   Pandit Sujay Dixit Guruji — styles
   Palette: temple cream, saffron, gold, deep maroon
   =========================================================== */
:root{
  --cream:#fdf7ec;
  --cream-2:#f6ecd8;
  --ink:#3a2417;
  --ink-soft:#6b5544;
  --maroon:#5a1d12;
  --saffron:#e08a2b;
  --saffron-deep:#c66f1d;
  --gold:#c9962b;
  --gold-light:#e8c272;
  --line:rgba(90,29,18,.12);
  --shadow:0 18px 50px -22px rgba(90,29,18,.45);
  --radius:18px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Jost',system-ui,sans-serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  overflow-x:hidden;
  position:relative;
}

/* ---------- ornamental backdrop ---------- */
.aura{
  position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(60% 45% at 50% -5%, rgba(232,194,114,.55), transparent 70%),
    radial-gradient(40% 30% at 85% 15%, rgba(224,138,43,.18), transparent 70%),
    radial-gradient(50% 40% at 10% 85%, rgba(201,150,43,.16), transparent 70%),
    var(--cream);
}
.om-watermark{
  position:fixed;z-index:-1;pointer-events:none;
  top:14%;left:50%;transform:translateX(-50%);
  font-family:'Tiro Devanagari Sanskrit',serif;
  font-size:46vw;line-height:1;color:rgba(201,150,43,.05);
  user-select:none;
}

/* ---------- typography ---------- */
h1,h2,h3,.brand strong{font-family:'Cormorant Garamond',serif;font-weight:600;line-height:1.08;color:var(--maroon)}
.sanskrit{font-family:'Tiro Devanagari Sanskrit',serif;color:var(--saffron-deep);letter-spacing:.04em}
.eyebrow{font-size:.78rem;letter-spacing:.32em;text-transform:uppercase;color:var(--saffron-deep);font-weight:600;margin-bottom:.6rem}

/* ---------- buttons ---------- */
.btn{
  --bg:transparent;
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:'Jost',sans-serif;font-weight:500;font-size:1rem;
  padding:.85rem 1.6rem;border-radius:999px;border:1.5px solid transparent;
  cursor:pointer;text-decoration:none;transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .3s;
  white-space:nowrap;position:relative;overflow:hidden;
  -webkit-tap-highlight-color:transparent;
}
.btn .ripple{
  position:absolute;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(255,236,190,.55),rgba(255,236,190,.25) 60%,transparent 70%);
  transform:scale(0);animation:ripple .65s ease-out forwards;
}
@keyframes ripple{to{transform:scale(2.8);opacity:0}}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn-gold{
  background:linear-gradient(135deg,var(--saffron),var(--gold));
  color:#fff;box-shadow:0 12px 26px -12px rgba(198,111,29,.8);
  position:relative;overflow:hidden;
}
.btn-gold::before{
  content:"";position:absolute;top:0;left:-80%;width:55%;height:100%;
  background:linear-gradient(105deg,transparent,rgba(255,255,255,.5),transparent);
  transform:skewX(-20deg);animation:shimmer 4s ease-in-out infinite;pointer-events:none;
}
@keyframes shimmer{0%,55%{left:-80%}90%,100%{left:135%}}
.btn-gold:hover{box-shadow:0 18px 36px -12px rgba(198,111,29,.9)}
.btn-ghost{background:rgba(255,255,255,.4);color:var(--maroon);border-color:var(--gold)}
.btn-ghost:hover{background:#fff}
.btn-lg{padding:1rem 2rem;font-size:1.08rem}
.btn-sm{padding:.55rem 1.1rem;font-size:.92rem}
.btn-block{width:100%}

/* ---------- nav ---------- */
.nav{
  position:sticky;top:0;z-index:40;
  display:flex;align-items:center;justify-content:space-between;
  padding:.9rem clamp(1rem,4vw,3rem);
  backdrop-filter:blur(14px);
  background:rgba(253,247,236,.72);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:.7rem;text-decoration:none;color:var(--ink)}
.brand-mark{
  font-family:'Tiro Devanagari Sanskrit',serif;font-size:1.7rem;color:var(--saffron-deep);
  width:44px;height:44px;display:grid;place-items:center;border-radius:50%;
  background:radial-gradient(circle,var(--gold-light),transparent 70%);
}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-text strong{font-size:1.25rem}
.brand-text em{font-style:normal;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft)}
.nav-links{display:flex;align-items:center;gap:1.6rem}
.nav-links a{color:var(--ink);text-decoration:none;font-size:.98rem;position:relative}
.nav-links a:not(.btn):hover{color:var(--saffron-deep)}
.nav-links a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:2px;background:var(--saffron);transition:width .3s}
.nav-links a:not(.btn):hover::after{width:100%}

/* ---------- hero ---------- */
.hero{
  text-align:center;position:relative;
  padding:clamp(3rem,9vw,7rem) clamp(1rem,5vw,2rem) clamp(2rem,5vw,4rem);
  max-width:1000px;margin:0 auto;
}
.hero .sanskrit{font-size:1.25rem;margin-bottom:1.2rem}
.hero h1{font-size:clamp(2.6rem,8vw,5.4rem);margin-bottom:1.1rem}
.hero h1 span{
  display:block;
  background:linear-gradient(120deg,var(--saffron-deep),var(--gold),var(--gold-light),var(--gold),var(--saffron-deep));
  background-size:250% auto;
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  animation:goldflow 7s linear infinite;
}
@keyframes goldflow{to{background-position:250% center}}
.hero-sub{max-width:640px;margin:0 auto 2rem;color:var(--ink-soft);font-size:1.12rem}
.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:3rem}

.stats{
  list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;
  max-width:820px;margin:0 auto;
}
.stats li{
  background:rgba(255,255,255,.55);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.2rem .6rem;backdrop-filter:blur(6px);
}
.stats b{display:block;font-family:'Cormorant Garamond',serif;font-size:2rem;color:var(--saffron-deep);line-height:1}
.stats span{font-size:.8rem;color:var(--ink-soft);letter-spacing:.03em}

/* ---------- trust marquee ---------- */
.trust{overflow:hidden;border-block:1px solid var(--line);background:rgba(255,255,255,.35);padding:.85rem 0;margin-top:1rem}
.trust-track{display:flex;gap:3rem;width:max-content;animation:marquee 28s linear infinite}
.trust-track span{color:var(--maroon);font-size:.95rem;white-space:nowrap;font-weight:500}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---------- sections ---------- */
.section{padding:clamp(3.5rem,8vw,6rem) clamp(1rem,5vw,3rem);max-width:1180px;margin:0 auto}
.section-head{text-align:center;max-width:680px;margin:0 auto 3rem}
.section-head h2{font-size:clamp(2rem,5vw,3.2rem)}
.lede{color:var(--ink-soft);margin-top:.8rem;font-size:1.05rem}

/* ---------- puja cards ---------- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.4rem}
.card{
  background:linear-gradient(180deg,rgba(255,255,255,.85),rgba(255,255,255,.55));
  border:1px solid var(--line);border-radius:var(--radius);
  padding:2rem 1.6rem;display:flex;flex-direction:column;gap:.55rem;
  box-shadow:0 10px 30px -24px rgba(90,29,18,.5);
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s;
  position:relative;overflow:hidden;
}
.card::before{
  content:"";position:absolute;inset:0;border-radius:var(--radius);padding:1px;pointer-events:none;
  background:linear-gradient(135deg,var(--gold-light),transparent 40%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .4s;
}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:transparent}
.card:hover::before{opacity:1}
.card-icon{font-size:2.4rem;line-height:1}
.card h3{font-size:1.7rem}
.card-tag{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--saffron-deep);font-weight:600}
.card p:not(.card-tag){color:var(--ink-soft);font-size:.98rem;flex:1}
.card .btn{margin-top:.9rem}
.card-accent{background:linear-gradient(180deg,rgba(248,236,216,.95),rgba(246,236,216,.7));border-color:var(--gold)}

/* ---------- about ---------- */
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.about-portrait{
  position:relative;aspect-ratio:4/5;border-radius:var(--radius);
  background:radial-gradient(circle at 50% 35%,#fff,var(--cream-2));
  border:1px solid var(--gold);display:grid;place-content:center;text-align:center;
  box-shadow:var(--shadow);overflow:hidden;
}
.portrait-glow{position:absolute;inset:0;background:radial-gradient(circle at 50% 30%,rgba(232,194,114,.6),transparent 60%)}
.portrait-om{font-family:'Tiro Devanagari Sanskrit',serif;font-size:9rem;color:var(--saffron-deep);line-height:1;position:relative}
.portrait-name{position:relative;font-family:'Cormorant Garamond',serif;font-size:1.6rem;color:var(--maroon);margin-top:.4rem}
.portrait-role{position:relative;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}
.about-text h2{font-size:clamp(1.9rem,4.5vw,3rem);margin:.4rem 0 1rem}
.about-text p{color:var(--ink-soft);margin-bottom:1rem}
.about-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1.4rem}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.4rem}
.contact-card{
  background:rgba(255,255,255,.7);border:1px solid var(--line);border-radius:var(--radius);
  padding:2rem 1.5rem;text-align:center;text-decoration:none;color:var(--ink);
  display:flex;flex-direction:column;gap:.4rem;align-items:center;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);
}
a.contact-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.contact-icon{font-size:2rem}
.contact-card b{font-family:'Cormorant Garamond',serif;font-size:1.5rem;color:var(--maroon)}
.contact-card span{color:var(--ink-soft);font-size:.95rem}

/* ---------- footer ---------- */
.footer{
  text-align:center;padding:3rem 1.5rem 2.4rem;border-top:1px solid var(--line);
  background:rgba(255,255,255,.4);
}
.brand-foot{justify-content:center;margin-bottom:1rem}
.footer-note{color:var(--ink-soft);font-size:.9rem}

/* ---------- floating action button ---------- */
.fab{
  position:fixed;right:clamp(1rem,3vw,2rem);
  bottom:calc(clamp(1rem,3vw,2rem) + env(safe-area-inset-bottom,0px));z-index:45;
  display:inline-flex;align-items:center;gap:.55rem;
  padding:.85rem 1.4rem;border:none;border-radius:999px;cursor:pointer;
  background:linear-gradient(135deg,#25D366,#128C7E);color:#fff;font-weight:600;font-size:1rem;
  box-shadow:0 14px 30px -10px rgba(18,140,126,.7);
  animation:floatpulse 3s ease-in-out infinite;
}
.fab:hover{transform:translateY(-3px)}
.fab-icon{font-size:1.2rem}
@keyframes floatpulse{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}

/* ---------- modal ---------- */
.modal{position:fixed;inset:0;z-index:60;display:none}
.modal.open{display:block}
.modal-backdrop{position:absolute;inset:0;background:rgba(58,36,23,.55);backdrop-filter:blur(4px);animation:fade .3s}
.modal-card{
  position:relative;z-index:2;max-width:460px;width:calc(100% - 2rem);
  margin:6vh auto;max-height:88vh;overflow-y:auto;
  background:var(--cream);border:1px solid var(--gold);border-radius:24px;
  padding:2.2rem clamp(1.4rem,4vw,2.2rem);box-shadow:0 30px 80px -20px rgba(58,36,23,.6);
  animation:pop .4s var(--ease);
}
.modal-close{position:absolute;top:1rem;right:1.1rem;background:none;border:none;font-size:1.8rem;color:var(--ink-soft);cursor:pointer;line-height:1}
.modal-om{font-family:'Tiro Devanagari Sanskrit',serif;font-size:2.2rem;text-align:center;color:var(--saffron-deep)}
.modal-card h3{font-size:1.9rem;text-align:center;margin:.2rem 0 .4rem}
.modal-sub{text-align:center;color:var(--ink-soft);font-size:.92rem;margin-bottom:1.4rem}
#bookingForm{display:flex;flex-direction:column;gap:.85rem}
#bookingForm label{display:flex;flex-direction:column;gap:.3rem;font-size:.85rem;font-weight:500;color:var(--maroon)}
#bookingForm label small{color:var(--ink-soft);font-weight:400}
#bookingForm input,#bookingForm select,#bookingForm textarea{
  font-family:'Jost',sans-serif;font-size:1rem;color:var(--ink);
  padding:.7rem .9rem;border:1px solid var(--line);border-radius:12px;background:#fff;
  transition:border-color .25s,box-shadow .25s;resize:vertical;
}
#bookingForm input:focus,#bookingForm select:focus,#bookingForm textarea:focus{
  outline:none;border-color:var(--saffron);box-shadow:0 0 0 3px rgba(224,138,43,.15)
}
#bookingForm input:invalid:not(:placeholder-shown){border-color:#c0392b}
.btn-sms{margin-top:.2rem;font-size:.95rem;padding:.7rem}
.modal-fine{text-align:center;font-size:.78rem;color:var(--ink-soft);margin-top:.3rem}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ===========================================================
   Fable magic — particles, glow, shimmer, breathing light
   =========================================================== */
.magic-canvas{position:fixed;inset:0;z-index:-1;pointer-events:none}

/* the aura slowly breathes */
.aura{animation:breathe 10s ease-in-out infinite}
@keyframes breathe{0%,100%{opacity:1}50%{opacity:.72}}

/* the Om watermark pulses like a heartbeat of the page */
.om-watermark{animation:om-pulse 14s ease-in-out infinite}
@keyframes om-pulse{
  0%,100%{opacity:1;transform:translateX(-50%) scale(1)}
  50%{opacity:.55;transform:translateX(-50%) scale(1.04)}
}

/* halo behind the brand Om */
.brand-mark{animation:halo 5s ease-in-out infinite}
@keyframes halo{
  0%,100%{text-shadow:0 0 0 rgba(232,194,114,0)}
  50%{text-shadow:0 0 18px rgba(224,138,43,.65)}
}

/* lotus divider under every section heading */
.section-head h2::after{
  content:"❁";display:block;margin-top:1.1rem;
  font-size:1.05rem;line-height:1;color:var(--gold);
  background:
    linear-gradient(90deg,transparent,var(--gold-light)) calc(50% - 72px) 50%/70px 1px no-repeat,
    linear-gradient(90deg,var(--gold-light),transparent) calc(50% + 72px) 50%/70px 1px no-repeat;
}

/* cursor-following gold glow on cards */
.card::after,.contact-card::after{
  content:"";position:absolute;inset:0;border-radius:var(--radius);pointer-events:none;
  opacity:0;transition:opacity .45s var(--ease);
  background:radial-gradient(240px circle at var(--mx,50%) var(--my,50%),rgba(232,194,114,.32),transparent 65%);
}
.card:hover::after,.contact-card:hover::after,
.card.glow::after,.contact-card.glow::after{opacity:1}
.contact-card{position:relative;overflow:hidden}

/* puja icons sway like diya flames */
.card-icon{animation:icon-sway 4.5s ease-in-out infinite;transform-origin:50% 90%}
.card:nth-child(2n) .card-icon{animation-delay:-1.6s}
.card:nth-child(3n) .card-icon{animation-delay:-3s}
@keyframes icon-sway{0%,100%{transform:rotate(-3deg)}50%{transform:rotate(3deg) translateY(-2px)}}

/* nav lifts off the page once you scroll */
.nav{transition:box-shadow .4s var(--ease)}
.nav.scrolled{box-shadow:0 12px 34px -18px rgba(90,29,18,.35)}

/* the sanskrit blessing glows softly */
.hero .sanskrit{animation:bless 6s ease-in-out infinite}
@keyframes bless{
  0%,100%{text-shadow:0 0 0 rgba(224,138,43,0)}
  50%{text-shadow:0 0 14px rgba(224,138,43,.5)}
}

/* ===========================================================
   The diya — a hand-built lamp that opens the page
   =========================================================== */
.diya{position:relative;width:72px;height:72px;margin:0 auto .6rem;display:block}
.diya i{position:absolute;display:block}
.diya-bowl{
  bottom:8px;left:50%;width:56px;height:20px;margin-left:-28px;
  background:linear-gradient(180deg,#9c4a22 0%,#6e2816 55%,var(--maroon) 100%);
  border-radius:6px 6px 30px 30px / 6px 6px 22px 22px;
  box-shadow:inset 0 2px 0 rgba(232,194,114,.85),0 6px 14px -6px rgba(90,29,18,.55);
}
.diya-flame{
  bottom:24px;left:50%;width:15px;height:15px;margin-left:-7.5px;
  background:radial-gradient(circle at 62% 62%,#fff6d8 0%,#ffce55 42%,#f08c14 78%,rgba(240,140,20,0) 100%);
  border-radius:80% 0 55% 50% / 55% 0 80% 50%;
  transform:rotate(-45deg);
  transform-origin:bottom;
  animation:flicker 2.1s ease-in-out infinite;
}
.diya-flame::after{ /* the hot blue-white heart of the flame */
  content:"";position:absolute;inset:35% 22% 18% 35%;
  background:radial-gradient(circle,#fffbe9,rgba(255,251,233,0) 70%);
  border-radius:inherit;
}
.diya-glow{
  bottom:8px;left:50%;width:84px;height:84px;margin-left:-42px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,196,92,.5),transparent 62%);
  animation:lampglow 2.1s ease-in-out infinite;
}
@keyframes flicker{
  0%,100%{transform:rotate(-45deg) scale(1,1)}
  22%{transform:rotate(-43deg) scale(1.06,1.14)}
  46%{transform:rotate(-46.5deg) scale(.95,.9)}
  64%{transform:rotate(-44deg) scale(1.04,1.08)}
  82%{transform:rotate(-45.5deg) scale(.98,.97)}
}
@keyframes lampglow{
  0%,100%{opacity:.75;transform:scale(1)}
  50%{opacity:1;transform:scale(1.12)}
}

/* ===========================================================
   Jyoti — golden reading thread along the top edge
   =========================================================== */
.jyoti{position:fixed;top:0;left:0;right:0;height:3px;z-index:55;pointer-events:none}
.jyoti i{
  display:block;height:100%;width:0;position:relative;
  background:linear-gradient(90deg,var(--saffron),var(--gold-light));
  box-shadow:0 0 10px rgba(232,170,60,.7);
}
.jyoti i::after{ /* the travelling flame-tip */
  content:"";position:absolute;right:-3px;top:50%;width:7px;height:7px;margin-top:-3.5px;
  border-radius:50%;background:#ffd97a;
  box-shadow:0 0 12px 3px rgba(255,200,90,.85);
}

/* ===========================================================
   Pushpa Vrishti — flower shower & blessing on booking
   =========================================================== */
.petal{
  position:fixed;top:-3rem;z-index:70;pointer-events:none;user-select:none;
  animation:petal-fall linear forwards;
}
@keyframes petal-fall{
  0%{transform:translate(0,-3rem) rotate(0deg);opacity:1}
  100%{transform:translate(var(--drift,0px),108vh) rotate(420deg);opacity:.85}
}
.bless-toast{
  position:fixed;left:50%;bottom:6.5rem;z-index:72;transform:translate(-50%,16px);
  background:var(--cream);border:1px solid var(--gold);border-radius:16px;
  padding:.9rem 1.6rem;text-align:center;box-shadow:var(--shadow);
  font-family:'Tiro Devanagari Sanskrit',serif;font-size:1.2rem;color:var(--saffron-deep);
  opacity:0;transition:opacity .5s var(--ease),transform .5s var(--ease);pointer-events:none;
}
.bless-toast small{
  display:block;font-family:'Jost',sans-serif;font-size:.8rem;color:var(--ink-soft);margin-top:.15rem;
}
.bless-toast.show{opacity:1;transform:translate(-50%,0)}

/* ===========================================================
   Kaal — the page keeps temple time (ambient light only)
   =========================================================== */
/* dawn (5–8): rose-gold morning light */
body.kaal-dawn .aura{
  background:
    radial-gradient(60% 45% at 50% -5%, rgba(255,206,150,.6), transparent 70%),
    radial-gradient(40% 30% at 85% 15%, rgba(255,150,110,.22), transparent 70%),
    radial-gradient(50% 40% at 10% 85%, rgba(255,190,90,.18), transparent 70%),
    #fdf8ef;
}
/* dusk (17–20): sandhya aarti — deep saffron sky */
body.kaal-dusk .aura{
  background:
    radial-gradient(60% 45% at 50% -5%, rgba(235,150,60,.5), transparent 72%),
    radial-gradient(45% 35% at 80% 18%, rgba(180,70,35,.2), transparent 70%),
    radial-gradient(50% 40% at 10% 85%, rgba(201,150,43,.22), transparent 70%),
    #faf1de;
}
/* night (20–5): candlelit, embers glowing deeper */
body.kaal-night .aura{
  background:
    radial-gradient(60% 45% at 50% -5%, rgba(201,120,40,.38), transparent 70%),
    radial-gradient(45% 35% at 80% 20%, rgba(110,40,22,.22), transparent 70%),
    radial-gradient(50% 40% at 10% 85%, rgba(160,100,30,.2), transparent 70%),
    #f6ead3;
}
body.kaal-night .om-watermark{color:rgba(160,100,30,.07)}

/* ===========================================================
   Premium & traditional finishing
   =========================================================== */
/* toran — a scalloped gold valance hanging below the nav */
.nav::after{
  content:"";position:absolute;left:0;right:0;top:100%;height:9px;pointer-events:none;
  background:radial-gradient(circle at 9px -4px, rgba(201,150,43,.5) 8px, transparent 9px);
  background-size:18px 9px;background-repeat:repeat-x;
}

/* the great mandala turning behind the hero */
.mandala{
  position:absolute;left:50%;top:46%;z-index:-1;pointer-events:none;
  width:min(840px,150vw);aspect-ratio:1;
  transform:translate(-50%,-50%);
  color:var(--gold);opacity:.16;
  animation:mandala-spin 200s linear infinite;
}
@keyframes mandala-spin{to{transform:translate(-50%,-50%) rotate(360deg)}}

/* language toggle — a small gold pill */
.lang-switch{
  display:flex;align-items:center;border:1px solid var(--gold);border-radius:999px;
  background:rgba(255,255,255,.55);overflow:hidden;flex:none;
}
.lang-switch button{
  border:none;background:none;cursor:pointer;
  font-family:'Jost','Mukta',sans-serif;font-size:.84rem;font-weight:500;
  color:var(--ink-soft);padding:.38rem .7rem;line-height:1.2;
  transition:background .25s,color .25s;
}
.lang-switch button:hover{color:var(--saffron-deep)}
.lang-switch button.active{
  background:linear-gradient(135deg,var(--saffron),var(--gold));color:#fff;
}

/* Devanagari typography when Hindi / Marathi is chosen */
body.lang-deva{font-family:'Mukta','Jost',system-ui,sans-serif}
body.lang-deva h1,body.lang-deva h2,body.lang-deva h3,
body.lang-deva .portrait-name,body.lang-deva .contact-card b,
body.lang-deva .brand strong{
  font-family:'Tiro Devanagari Sanskrit','Mukta',serif;line-height:1.25;
}
body.lang-deva .hero h1{font-size:clamp(2.2rem,7vw,4.6rem)}
body.lang-deva .stats b{font-family:'Mukta',sans-serif;font-weight:600}
body.lang-deva .eyebrow,body.lang-deva .card-tag{letter-spacing:.14em}

/* premium details */
::selection{background:var(--gold-light);color:var(--maroon)}
::-webkit-scrollbar{width:11px}
::-webkit-scrollbar-track{background:var(--cream-2)}
::-webkit-scrollbar-thumb{
  background:linear-gradient(var(--saffron),var(--gold));
  border-radius:8px;border:2.5px solid var(--cream-2);
}
.btn-gold{box-shadow:0 12px 26px -12px rgba(198,111,29,.8),inset 0 1px 0 rgba(255,255,255,.4)}
.card,.contact-card{will-change:transform}

@media(max-width:760px){
  .nav-links{gap:.7rem}
  .lang-switch button{padding:.34rem .55rem;font-size:.8rem}
  .mandala{width:200vw;opacity:.12}
}

/* ===========================================================
   Mobile magic — the phone is the temple courtyard
   =========================================================== */
@media(max-width:640px){
  /* the booking form becomes a native-feeling bottom sheet */
  .modal-card{
    position:absolute;left:0;right:0;bottom:0;margin:0;width:100%;max-width:none;
    border-radius:26px 26px 0 0;border-bottom:none;max-height:92dvh;
    padding-bottom:calc(1.8rem + env(safe-area-inset-bottom,0px));
    animation:sheet-up .45s var(--ease);
    touch-action:pan-y;
  }
  .modal-card::before{ /* grab handle */
    content:"";display:block;width:46px;height:5px;border-radius:3px;
    background:rgba(90,29,18,.18);margin:-8px auto 12px;
  }
  .modal-close{top:.85rem;right:1rem}
  @keyframes sheet-up{from{transform:translateY(45%);opacity:.5}to{transform:none;opacity:1}}
}

@media(max-width:430px){
  .nav{padding:.65rem .8rem}
  .brand-text em{display:none}
  .brand-text strong{font-size:1.05rem}
  .brand-mark{width:38px;height:38px;font-size:1.45rem}
  .btn-sm{padding:.5rem .8rem;font-size:.85rem}

  .hero{padding-top:2.6rem}
  .hero .sanskrit{font-size:1.05rem}
  /* full-width ceremonial CTAs, thumb-reach friendly */
  .hero-cta{flex-direction:column;align-items:stretch;max-width:340px;margin-inline:auto;margin-bottom:2.4rem}
  .stats{gap:.7rem}
  .stats li{padding:1rem .5rem}
  .stats b{font-size:1.75rem}

  .section-head{margin-bottom:2.2rem}
  .card{padding:1.7rem 1.3rem}
  .about-actions .btn{flex:1;justify-content:center}
  .footer{padding-bottom:calc(2.4rem + env(safe-area-inset-bottom,0px))}
}

@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes pop{from{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:none}}

/* ---------- responsive ---------- */
@media(max-width:760px){
  .nav-links a:not(.btn){display:none}
  .stats{grid-template-columns:repeat(2,1fr)}
  .about-grid{grid-template-columns:1fr}
  .about-portrait{max-width:320px;margin:0 auto;aspect-ratio:1/1}
  .fab-text{display:none}
  .fab{padding:1rem}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}
