/* ============================================================
   Ayodhya Dharshan — Design System
   Warm spiritual premium: ivory · saffron · maroon · gold
   ============================================================ */

:root{
  /* Surfaces */
  --bg:        #FBF5EA;
  --bg-panel:  #F4E8D4;
  --bg-deep:   #2A140E;   /* maroon-black for inverted sections */
  --cream:     #FEFCF7;

  /* Ink */
  --ink:   #2B1A10;
  --ink-2: #5C4838;
  --ink-3: #8C7862;

  /* Brand */
  --saffron:      #DD7A1F;
  --saffron-deep: #BC5C10;
  --marigold:     #EFA53E;
  --maroon:       #5C1A12;
  --maroon-2:     #7C261A;
  --gold:         #B68A38;
  --gold-soft:    #D8B877;

  /* Lines */
  --line:      rgba(92,26,18,0.14);
  --line-soft: rgba(92,26,18,0.07);

  /* Type */
  --font-display: 'Marcellus', 'Cormorant Garamond', serif;
  --font-script:  'Cormorant Garamond', serif;
  --font-body:    'Mukta', system-ui, sans-serif;

  /* Shape */
  --r-sm: 8px;
  --r-md: 14px;
  --r-lg: 22px;
  --shadow-sm: 0 2px 10px rgba(60,20,10,0.06);
  --shadow-md: 0 14px 40px -18px rgba(60,20,10,0.28);
  --shadow-lg: 0 40px 90px -40px rgba(60,20,10,0.45);

  --maxw: 1240px;
  --gut: clamp(20px, 5vw, 64px);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

/* Subtle paper texture on body */
body::before{
  content:"";
  position:fixed; inset:0; z-index:-1; pointer-events:none;
  background:
    radial-gradient(900px 500px at 80% -10%, rgba(239,165,62,0.10), transparent 60%),
    radial-gradient(700px 500px at -5% 25%, rgba(220,122,31,0.07), transparent 55%);
}

/* ---------- Layout ---------- */
.container{ width:100%; max-width:var(--maxw); margin:0 auto; padding-inline:var(--gut); }
.section{ padding-block:clamp(64px,9vw,128px); position:relative; }
.section--tight{ padding-block:clamp(48px,6vw,80px); }
.center{ text-align:center; }

/* ---------- Typography ---------- */
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:400; line-height:1.08; margin:0; letter-spacing:.005em; }
.display{ font-size:clamp(2.8rem,6.6vw,5.4rem); line-height:1.02; letter-spacing:-.01em; }
h1{ font-size:clamp(2.4rem,5.2vw,4.2rem); }
h2{ font-size:clamp(2rem,3.8vw,3.2rem); }
h3{ font-size:clamp(1.35rem,2vw,1.7rem); }
p{ margin:0 0 1.1em; }
.lead{ font-size:clamp(1.1rem,1.5vw,1.32rem); line-height:1.6; color:var(--ink-2); }
.muted{ color:var(--ink-3); }
strong{ font-weight:600; }

/* Eyebrow with diya ornament */
.eyebrow{
  display:inline-flex; align-items:center; gap:.7em;
  font-family:var(--font-body); font-weight:600;
  font-size:.78rem; letter-spacing:.28em; text-transform:uppercase;
  color:var(--saffron-deep);
  margin:0 0 1.1rem;
}
.eyebrow::before{
  content:""; width:26px; height:1px; background:linear-gradient(90deg,transparent,var(--gold));
}
.eyebrow.center{ justify-content:center; }
.eyebrow.center::after{
  content:""; width:26px; height:1px; background:linear-gradient(90deg,var(--gold),transparent);
}

.sanskrit{ font-family:var(--font-script); font-style:italic; color:var(--maroon); }

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--maroon);
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--font-body); font-weight:600; font-size:.95rem;
  letter-spacing:.02em;
  padding:.92em 1.7em; border-radius:999px;
  border:1px solid transparent; cursor:pointer;
  transition:transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s, background .25s, color .25s;
  white-space:nowrap;
}
.btn svg{ width:1.05em; height:1.05em; }
.btn-primary{
  background:linear-gradient(180deg,var(--maroon-2),var(--maroon));
  color:#FCEFD9; box-shadow:0 10px 26px -12px rgba(92,26,18,.7), inset 0 1px 0 rgba(255,255,255,.12);
}
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 18px 34px -14px rgba(92,26,18,.75); }
.btn-saffron{
  background:linear-gradient(180deg,var(--marigold),var(--saffron));
  color:#3a1503; box-shadow:0 10px 26px -12px rgba(220,122,31,.7), inset 0 1px 0 rgba(255,255,255,.3);
}
.btn-saffron:hover{ transform:translateY(-2px); }
.btn-ghost{
  background:transparent; color:var(--maroon);
  border-color:var(--line);
}
.btn-ghost:hover{ border-color:var(--maroon); background:rgba(92,26,18,.04); transform:translateY(-2px); }
.btn-light{ background:#FCEFD9; color:var(--maroon); }
.btn-light:hover{ transform:translateY(-2px); box-shadow:var(--shadow-md); }
.link-arrow{
  display:inline-flex; align-items:center; gap:.5em; font-weight:600; color:var(--saffron-deep);
  letter-spacing:.01em;
}
.link-arrow svg{ width:1.1em; height:1.1em; transition:transform .25s; }
.link-arrow:hover svg{ transform:translateX(4px); }

/* ---------- Navigation ---------- */
.site-nav{
  position:sticky; top:0; z-index:60;
  background:rgba(251,245,234,.82);
  backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid var(--line-soft);
}
.nav-inner{ display:flex; align-items:center; justify-content:space-between; gap:24px;
  height:74px; max-width:var(--maxw); margin:0 auto; padding-inline:var(--gut); }
.brand{ display:flex; align-items:center; gap:12px; }
.brand-mark{ width:38px; height:38px; flex:none; }
.brand-name{ font-family:var(--font-display); font-size:1.32rem; line-height:1; color:var(--maroon); letter-spacing:.01em; }
.brand-name small{ display:block; font-family:var(--font-body); font-size:.6rem; letter-spacing:.34em;
  text-transform:uppercase; color:var(--saffron-deep); margin-top:4px; font-weight:600; }
.nav-links{ display:flex; align-items:center; gap:34px; }
.nav-links a{ font-size:.97rem; font-weight:500; color:var(--ink-2); position:relative; padding-block:6px; }
.nav-links a::after{ content:""; position:absolute; left:0; right:100%; bottom:0; height:1.5px;
  background:var(--saffron); transition:right .3s cubic-bezier(.2,.8,.2,1); }
.nav-links a:hover{ color:var(--ink); }
.nav-links a:hover::after,.nav-links a.active::after{ right:0; }
.nav-links a.active{ color:var(--maroon); }
.nav-cta{ display:flex; align-items:center; gap:14px; }
.nav-toggle{ display:none; background:none; border:none; cursor:pointer; padding:8px; color:var(--maroon); }
.nav-toggle svg{ width:26px; height:26px; }

@media(max-width:940px){
  .nav-links{ position:fixed; inset:74px 0 auto 0; flex-direction:column; gap:0;
    background:var(--cream); border-bottom:1px solid var(--line); padding:8px var(--gut) 20px;
    transform:translateY(-130%); transition:transform .35s cubic-bezier(.2,.8,.2,1); box-shadow:var(--shadow-md); }
  .nav-links.open{ transform:translateY(0); }
  .nav-links a{ width:100%; padding:14px 0; border-bottom:1px solid var(--line-soft); }
  .nav-links a::after{ display:none; }
  .nav-toggle{ display:block; }
  .nav-cta .btn-text{ display:none; }
}

/* ---------- Cards & motifs ---------- */
.arch{ border-radius:999px 999px var(--r-md) var(--r-md); overflow:hidden; }
.card{
  background:var(--cream); border:1px solid var(--line-soft);
  border-radius:var(--r-lg); box-shadow:var(--shadow-sm);
  transition:transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s, border-color .35s;
}
.card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:var(--line); }

/* Image placeholder fallback */
.ph{
  background:
    radial-gradient(120% 90% at 50% 0%, rgba(255,255,255,.5), transparent 60%),
    linear-gradient(150deg,#E9C98A,#DD7A1F 55%,#7C261A);
  position:relative; color:#fff; display:grid; place-items:center; isolation:isolate;
}
.ph::after{
  content:""; position:absolute; inset:0; opacity:.16; mix-blend-mode:overlay;
  background-image:radial-gradient(circle at 30% 30%, #fff 0 1px, transparent 1.5px);
  background-size:14px 14px;
}
image-slot{ --is-bg:#E9C98A; }

/* Dividers */
.lotus-div{ display:flex; align-items:center; justify-content:center; gap:16px; color:var(--gold); }
.lotus-div span{ height:1px; width:min(120px,18vw); background:linear-gradient(90deg,transparent,var(--gold)); }
.lotus-div span:last-child{ background:linear-gradient(90deg,var(--gold),transparent); }

/* ---------- Footer ---------- */
.site-foot{ background:var(--bg-deep); color:#E8D8C2; padding-block:72px 32px; position:relative; overflow:hidden; }
.site-foot::before{ content:""; position:absolute; inset:0;
  background:radial-gradient(700px 300px at 80% -20%, rgba(239,165,62,.16), transparent 60%); }
.foot-grid{ position:relative; display:grid; grid-template-columns:1.6fr 1fr 1fr 1.2fr; gap:40px; }
.site-foot h4{ font-family:var(--font-body); font-weight:700; font-size:.82rem; letter-spacing:.2em;
  text-transform:uppercase; color:var(--gold-soft); margin-bottom:18px; }
.site-foot a{ color:#D8C3AB; display:block; padding:5px 0; font-size:.97rem; transition:color .2s,transform .2s; }
.site-foot a:hover{ color:#fff; transform:translateX(3px); }
.foot-brand p{ color:#C3AD93; max-width:30ch; }
.foot-bottom{ position:relative; margin-top:48px; padding-top:24px; border-top:1px solid rgba(255,255,255,.12);
  display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:.85rem; color:#B49C82; }
@media(max-width:820px){ .foot-grid{ grid-template-columns:1fr 1fr; gap:32px; } .foot-brand{ grid-column:1/-1; } }

/* ---------- Utility grids ---------- */
.grid{ display:grid; gap:clamp(18px,2.4vw,30px); }
.cols-2{ grid-template-columns:repeat(2,1fr); }
.cols-3{ grid-template-columns:repeat(3,1fr); }
.cols-4{ grid-template-columns:repeat(4,1fr); }
@media(max-width:900px){ .cols-3,.cols-4{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:620px){ .cols-2,.cols-3,.cols-4{ grid-template-columns:1fr; } }

/* Reveal on scroll */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s ease, transform .8s cubic-bezier(.2,.8,.2,1); }
.reveal.in{ opacity:1; transform:none; }

/* ---------- Inner page hero ---------- */
.page-hero{ background:var(--bg-panel); border-bottom:1px solid var(--line-soft); padding-block:clamp(48px,7vw,92px); position:relative; overflow:hidden; }
.page-hero::before{ content:"ॐ"; position:absolute; right:4%; top:50%; transform:translateY(-50%);
  font-family:var(--font-display); font-size:clamp(8rem,20vw,18rem); color:rgba(124,38,26,.05); pointer-events:none; }
.page-hero .container{ position:relative; }
.crumb{ font-size:.85rem; color:var(--ink-3); letter-spacing:.04em; margin-bottom:16px; }
.crumb a{ color:var(--saffron-deep); } .crumb a:hover{ text-decoration:underline; }
.page-hero h1{ max-width:16ch; }
.page-hero p.lead{ max-width:54ch; margin-top:14px; }

/* ---------- Pill row ---------- */
.pills{ display:flex; flex-wrap:wrap; gap:10px; }
.pill{ font-size:.85rem; font-weight:500; color:var(--maroon); background:var(--cream);
  border:1px solid var(--line); border-radius:999px; padding:.45em 1em; display:inline-flex; align-items:center; gap:.5em; }
.pill svg{ width:1em; height:1em; color:var(--saffron); }

/* ---------- City blocks (destinations) ---------- */
.city{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,60px); align-items:center; }
.city:nth-child(even) .city-media{ order:2; }
.city-media{ height:clamp(300px,42vw,440px); }
.city-media .frame{ width:100%; height:100%; }
.city-media .frame .ph,.city-media .frame image-slot{ width:100%; height:100%; }
.city-body .num{ font-family:var(--font-display); font-size:1.1rem; color:var(--gold); letter-spacing:.1em; }
.city-body h2{ color:var(--maroon); margin:.1em 0 .3em; }
.city-body .where{ font-weight:600; color:var(--saffron-deep); letter-spacing:.02em; margin-bottom:1rem; display:flex; align-items:center; gap:.5em; font-size:.95rem; }
.highlights{ list-style:none; padding:0; margin:1.2rem 0 1.6rem; display:grid; gap:10px; }
.highlights li{ display:flex; gap:12px; align-items:flex-start; font-size:.98rem; color:var(--ink-2); }
.highlights li svg{ flex:none; width:20px; height:20px; color:var(--saffron); margin-top:3px; }
@media(max-width:840px){ .city{ grid-template-columns:1fr; } .city:nth-child(even) .city-media{ order:0; } .city-media{ height:300px; } }

/* ---------- Service detail cards ---------- */
.svc-lg{ padding:30px; display:flex; flex-direction:column; gap:14px; height:100%; }
.svc-lg .ic{ width:56px; height:56px; border-radius:16px; display:grid; place-items:center;
  background:linear-gradient(160deg,#F6E3C2,#EFC98C); color:var(--maroon); }
.svc-lg .ic svg{ width:28px; height:28px; }
.svc-lg h3{ color:var(--ink); }
.svc-lg p{ font-size:.97rem; color:var(--ink-2); margin:0; }
.svc-lg ul{ margin:4px 0 0; padding-left:0; list-style:none; display:grid; gap:7px; }
.svc-lg ul li{ font-size:.92rem; color:var(--ink-2); display:flex; gap:9px; }
.svc-lg ul li::before{ content:"✦"; color:var(--saffron); }

/* ---------- Packages ---------- */
.pkg{ display:flex; flex-direction:column; overflow:hidden; }
.pkg .pkg-top{ height:170px; position:relative; overflow:hidden; }
.pkg .pkg-top img.pkg-img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.pkg .pkg-top::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(20,8,4,.25),transparent 45%); }
.pkg .pkg-top .badge{ position:absolute; top:14px; left:14px; background:var(--maroon); color:#FCEFD9;
  font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; padding:.4em .9em; border-radius:999px; }
.pkg .pkg-body{ padding:22px 24px 26px; display:flex; flex-direction:column; gap:8px; flex:1; }
.pkg .pkg-body h3{ color:var(--maroon); }
.pkg .days{ font-size:.85rem; color:var(--ink-3); letter-spacing:.05em; }
.pkg .price{ font-family:var(--font-display); font-size:1.7rem; color:var(--ink); margin-top:auto; }
.pkg .price small{ font-family:var(--font-body); font-size:.8rem; color:var(--ink-3); font-weight:400; }
.pkg .route{ font-size:.92rem; color:var(--ink-2); }

/* ---------- FAQ accordion ---------- */
.faq{ border-bottom:1px solid var(--line); }
.faq summary{ list-style:none; cursor:pointer; padding:22px 4px; display:flex; justify-content:space-between;
  gap:20px; align-items:center; font-family:var(--font-display); font-size:1.2rem; color:var(--ink); }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary .pm{ flex:none; width:30px; height:30px; border-radius:50%; border:1px solid var(--line);
  display:grid; place-items:center; color:var(--saffron-deep); transition:transform .3s, background .3s; }
.faq[open] summary .pm{ transform:rotate(45deg); background:var(--saffron); color:#fff; border-color:var(--saffron); }
.faq .ans{ padding:0 4px 24px; color:var(--ink-2); max-width:70ch; }

/* ---------- Forms ---------- */
.form-card{ background:var(--cream); border:1px solid var(--line); border-radius:var(--r-lg); padding:clamp(26px,3.5vw,40px); box-shadow:var(--shadow-md); }
.field{ margin-bottom:18px; }
.field label{ display:block; font-size:.85rem; font-weight:600; color:var(--ink-2); margin-bottom:7px; letter-spacing:.02em; }
.field input,.field select,.field textarea{ width:100%; font-family:var(--font-body); font-size:1rem; color:var(--ink);
  background:var(--bg); border:1px solid var(--line); border-radius:var(--r-sm); padding:.8em 1em; transition:border-color .2s, box-shadow .2s; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--saffron); box-shadow:0 0 0 3px rgba(221,122,31,.15); }
.field textarea{ resize:vertical; min-height:110px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media(max-width:560px){ .field-row{ grid-template-columns:1fr; } }
.contact-grid{ display:grid; grid-template-columns:1fr 1.1fr; gap:clamp(30px,4vw,56px); align-items:start; }
@media(max-width:860px){ .contact-grid{ grid-template-columns:1fr; } }
.contact-line{ display:flex; gap:16px; align-items:flex-start; padding:18px 0; border-bottom:1px solid var(--line-soft); }
.contact-line .ic{ flex:none; width:46px; height:46px; border-radius:12px; display:grid; place-items:center;
  background:linear-gradient(160deg,#F6E3C2,#EFC98C); color:var(--maroon); }
.contact-line .ic svg{ width:22px; height:22px; }
.contact-line b{ display:block; font-size:1.02rem; color:var(--ink); }
.contact-line span,.contact-line a{ color:var(--ink-2); font-size:.95rem; }
.contact-line a:hover{ color:var(--saffron-deep); }
.form-ok{ display:none; background:linear-gradient(160deg,#EAF6E8,#D6EFD2); border:1px solid #B6DDA9;
  color:#2C5E22; border-radius:var(--r-md); padding:16px 18px; margin-bottom:18px; font-size:.95rem; }
.form-ok.show{ display:block; }

/* ---------- About specifics ---------- */
.value{ padding:26px; }
.value .ic{ width:50px; height:50px; border-radius:14px; display:grid; place-items:center; margin-bottom:16px;
  background:linear-gradient(160deg,#F6E3C2,#EFC98C); color:var(--maroon); }
.value .ic svg{ width:26px; height:26px; }
.value h3{ color:var(--maroon); margin-bottom:8px; }
.value p{ font-size:.96rem; color:var(--ink-2); margin:0; }
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,4vw,64px); align-items:center; }
@media(max-width:840px){ .split{ grid-template-columns:1fr; } }
.media-tall{ height:clamp(340px,45vw,520px); }
.media-tall .frame{ width:100%; height:100%; }
.media-tall .frame .ph,.media-tall .frame image-slot{ width:100%; height:100%; }

/* ---------- Blog ---------- */
.blog-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,2.6vw,30px); }
@media(max-width:900px){ .blog-grid{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:620px){ .blog-grid{ grid-template-columns:1fr; } }
.blog-card{ display:flex; flex-direction:column; overflow:hidden; }
.blog-card .bc-img{ height:200px; position:relative; overflow:hidden; }
.blog-card .bc-img img{ width:100%; height:100%; object-fit:cover; transition:transform .6s cubic-bezier(.2,.8,.2,1); }
.blog-card:hover .bc-img img{ transform:scale(1.06); }
.blog-card .bc-body{ padding:20px 22px 24px; display:flex; flex-direction:column; gap:9px; flex:1; }
.blog-card .bc-meta{ font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--saffron-deep); font-weight:600; }
.blog-card h3{ color:var(--maroon); font-size:1.3rem; line-height:1.2; }
.blog-card p{ font-size:.94rem; color:var(--ink-2); margin:0; }
.blog-card .bc-foot{ margin-top:auto; padding-top:10px; }

/* Article body */
.post{ max-width:760px; margin:0 auto; }
.post-hero{ height:clamp(260px,38vw,420px); border-radius:var(--r-lg); overflow:hidden; margin-bottom:40px; box-shadow:var(--shadow-md); }
.post-hero img{ width:100%; height:100%; object-fit:cover; }
.post-meta{ display:flex; gap:14px; flex-wrap:wrap; align-items:center; font-size:.85rem; color:var(--ink-3); margin-bottom:14px; }
.post-meta .chip{ background:var(--bg-panel); color:var(--saffron-deep); font-weight:600; padding:.3em .9em; border-radius:999px; letter-spacing:.04em; }
.post-body{ font-size:1.08rem; line-height:1.72; color:var(--ink); }
.post-body h2{ font-size:clamp(1.6rem,2.6vw,2.1rem); color:var(--maroon); margin:1.6em 0 .5em; }
.post-body h3{ font-size:1.25rem; color:var(--ink); margin:1.4em 0 .4em; }
.post-body p{ margin:0 0 1.1em; color:var(--ink-2); }
.post-body ul{ margin:0 0 1.2em; padding-left:0; list-style:none; display:grid; gap:9px; }
.post-body ul li{ display:flex; gap:11px; align-items:flex-start; color:var(--ink-2); }
.post-body ul li::before{ content:"✦"; color:var(--saffron); flex:none; margin-top:2px; }
.post-body .callout{ background:var(--bg-panel); border-left:3px solid var(--saffron); border-radius:0 var(--r-md) var(--r-md) 0;
  padding:18px 22px; margin:1.4em 0; color:var(--ink); }
.post-body .callout b{ color:var(--maroon); }
.post-toc{ background:var(--cream); border:1px solid var(--line); border-radius:var(--r-md); padding:22px 26px; margin-bottom:34px; }
.post-toc h4{ font-family:var(--font-body); font-weight:700; font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; color:var(--saffron-deep); margin:0 0 12px; }
.post-toc ol{ margin:0; padding-left:1.2em; color:var(--ink-2); display:grid; gap:6px; }
.post-toc a:hover{ color:var(--saffron-deep); text-decoration:underline; }
.post-cta{ background:linear-gradient(160deg,#F6E7CC,#EFD3A6); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:clamp(28px,4vw,44px); text-align:center; margin:48px auto 0; max-width:760px; }

@media(prefers-reduced-motion:reduce){ *{ animation:none!important; transition:none!important; } .reveal{opacity:1;transform:none;} }

/* Spinner animation */
.spin {
  display: inline-block;
  animation: spin 1s linear infinite;
}
@keyframes spin {
  to { transform: rotate(360deg); }
}


/* Floating WhatsApp Button */
.whatsapp-float {
  position: fixed;
  width: 60px;
  height: 60px;
  bottom: 30px;
  right: 30px;
  background-color: #25d366;
  color: #fff;
  border-radius: 50px;
  text-align: center;
  font-size: 30px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.3);
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  transition: transform 0.3s, background-color 0.3s;
}
.whatsapp-float:hover {
  transform: scale(1.1);
  background-color: #20ba5a;
}
.whatsapp-float svg {
  width: 32px;
  height: 32px;
  fill: currentColor;
}
@media (max-width: 768px) {
  .whatsapp-float {
    width: 50px;
    height: 50px;
    bottom: 20px;
    right: 20px;
  }
  .whatsapp-float svg {
    width: 26px;
    height: 26px;
  }
}
