/* ==========================================================================
   Pabby Women's & Children's Clinic Hospital
   Main Stylesheet
   Design tokens:
     Primary Blue   : #0B6EFD
     Secondary Sky  : #00A8E8
     Deep Navy      : #0A2540
     Blush Accent   : #FF6B9D  (used sparingly – women & children warmth)
     Background     : #F8FAFC
     Cards          : #FFFFFF
     Display font   : Poppins
     Body font      : Nunito Sans
   ========================================================================== */

:root{
  --primary:#0B6EFD;
  --primary-dark:#0955c9;
  --secondary:#00A8E8;
  --navy:#0A2540;
  --blush:#FF6B9D;
  --bg:#F8FAFC;
  --white:#FFFFFF;
  --text-muted:#5B6B7C;
  --border-soft:#E6ECF3;
  --radius-lg:24px;
  --radius-md:16px;
  --radius-sm:10px;
  --shadow-soft:0 10px 40px -12px rgba(10,37,64,0.12);
  --shadow-hover:0 20px 50px -14px rgba(11,110,253,0.28);
  --grad-primary:linear-gradient(135deg,#0B6EFD 0%,#00A8E8 100%);
  --grad-soft:linear-gradient(135deg, rgba(11,110,253,0.08), rgba(0,168,232,0.08));
  --font-display:'Poppins', sans-serif;
  --font-body:'Nunito Sans', sans-serif;
}

*{box-sizing:border-box;}

html{scroll-behavior:smooth;}

body{
  font-family:var(--font-body);
  color:var(--navy);
  background:var(--bg);
  line-height:1.7;
  overflow-x:hidden;
}

html,
body {
    overflow-x: clip;
}

h1,h2,h3,h4,h5,h6{
  font-family:var(--font-display);
  color:var(--navy);
  font-weight:700;
  margin:0;
}

a{text-decoration:none; color:inherit;}
img{max-width:100%; display:block;}
ul{list-style:none; margin:0; padding:0;}
button{font-family:inherit;}

:focus-visible{
  outline:3px solid var(--secondary);
  outline-offset:3px;
}

.section{padding:100px 0;}

.section-eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-display);
  font-weight:600; font-size:.85rem; letter-spacing:.06em; text-transform:uppercase;
  color:var(--primary);
  background:rgba(11,110,253,0.08);
  padding:8px 18px; border-radius:50px;
  margin-bottom:16px;
}
.section-eyebrow.light{color:#fff; background:rgba(255,255,255,0.15);}

.section-title{
  font-size:clamp(1.8rem, 3vw, 2.6rem);
  line-height:1.25;
  margin-bottom:18px;
}
.section-title.light{color:#fff;}

.section-text{color:var(--text-muted); font-size:1.02rem;}
.section-text.light{color:rgba(255,255,255,0.85);}

/* ==========================================================================
   PRELOADER
   ========================================================================== */
.preloader{
  position:fixed; inset:0; z-index:9999;
  background:var(--navy);
  display:flex; align-items:center; justify-content:center;
  transition:opacity .5s ease, visibility .5s ease;
}
.preloader.loaded{opacity:0; visibility:hidden;}
.preloader-heart{width:220px;}
.pulse-line{width:100%; height:60px; fill:none; stroke:var(--secondary); stroke-width:2.5; stroke-linecap:round; stroke-linejoin:round;
  stroke-dasharray:300; stroke-dashoffset:300;
  animation:drawLine 1.4s ease-in-out infinite;
}
@keyframes drawLine{
  0%{stroke-dashoffset:300;}
  50%{stroke-dashoffset:0;}
  100%{stroke-dashoffset:-300;}
}

/* ==========================================================================
   SCROLL PROGRESS BAR
   ========================================================================== */
.scroll-progress{
  position:fixed; top:0; left:0; height:4px; width:0%;
  background:var(--grad-primary);
  z-index:2000;
  transition:width .1s ease-out;
}

/* ==========================================================================
   TOP BAR
   ========================================================================== */
.topbar{
  background:var(--navy);
  color:#cfe0f5;
  font-size:.85rem;
  padding:9px 0;
}
.topbar-left span{margin-right:26px;}
.topbar-left i{color:var(--secondary); margin-right:6px;}
.topbar-left a{color:#cfe0f5;}
.topbar-right{display:flex; align-items:center; gap:16px;}
.topbar-right a{color:#cfe0f5; font-size:1rem; transition:color .2s;}
.topbar-right a:hover{color:var(--secondary);}
.topbar-cta{
  background:var(--grad-primary);
  color:#fff !important;
  padding:6px 18px;
  border-radius:50px;
  font-weight:600;
  font-size:.8rem;
}

/* ==========================================================================
   HEADER / NAV
   ========================================================================== */
.main-header{
  position:sticky; top:0; z-index:1000;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(10px);
  box-shadow:0 2px 20px rgba(10,37,64,0.06);
  transition:all .3s ease;
}
.main-header.scrolled{box-shadow:0 4px 25px rgba(10,37,64,0.1);}
.navbar{padding:14px 0;}
.navbar-brand{display:flex; align-items:center; gap:12px;}
.brand-icon{
  width:46px; height:46px; border-radius:14px;
  background:var(--grad-primary);
  color:#fff; display:flex; align-items:center; justify-content:center;
  font-size:1.3rem;
  box-shadow:0 8px 18px -4px rgba(11,110,253,0.45);
}
.brand-text{display:flex; flex-direction:column; line-height:1.15;}
.brand-text strong{font-family:var(--font-display); font-size:1.25rem; color:var(--navy);}
.brand-text small{font-size:.68rem; color:var(--text-muted); letter-spacing:.03em;}

.nav-link{
  font-family:var(--font-display);
  font-weight:500; font-size:.95rem;
  color:var(--navy) !important;
  margin:0 10px; position:relative;
  padding:8px 2px !important;
}
.nav-link::after{
  content:''; position:absolute; left:0; bottom:0; width:0; height:2px;
  background:var(--grad-primary); transition:width .3s ease;
}
.nav-link:hover::after, .nav-link.active::after{width:100%;}
.nav-link.active{color:var(--primary) !important;}

.btn-nav-cta{
  background:var(--grad-primary);
  color:#fff; font-family:var(--font-display); font-weight:600; font-size:.9rem;
  padding:11px 24px; border-radius:50px;
  box-shadow:0 10px 20px -6px rgba(11,110,253,0.5);
  transition:transform .25s ease, box-shadow .25s ease;
  display:inline-block;
}
.btn-nav-cta:hover{transform:translateY(-2px); box-shadow:0 14px 26px -6px rgba(11,110,253,0.6); color:#fff;}

.navbar-toggler{border:none; background:none; padding:6px; display:flex; flex-direction:column; gap:5px;}
.toggler-bar{width:26px; height:2.5px; background:var(--navy); border-radius:2px; transition:.3s;}

/* ==========================================================================
   HERO
   ========================================================================== */
.hero{
  position:relative;
  padding:60px 0 90px;
  overflow:hidden;
  color:#fff;
}
.hero-bg{position:absolute; inset:0; z-index:0;}
.hero-bg img{width:100%; height:100%; object-fit:cover;}
.hero-overlay{
  position:absolute; inset:0;
  background:linear-gradient(115deg, rgba(10,37,64,0.92) 20%, rgba(11,110,253,0.75) 60%, rgba(0,168,232,0.55) 100%);
}
.hero-ribbon{
  position:absolute; bottom:-20px; left:0; width:100%; height:140px; z-index:1; opacity:.35;
}
.hero-ribbon path{fill:none; stroke:#fff; stroke-width:2;}
.hero .container{position:relative; z-index:2; padding-top:40px;}

.hero-eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(255,255,255,0.14);
  border:1px solid rgba(255,255,255,0.25);
  padding:8px 18px; border-radius:50px;
  font-family:var(--font-display); font-size:.82rem; font-weight:600;
  margin-bottom:22px;
}
.hero-title{
  font-size:clamp(2.2rem, 4.2vw, 3.4rem);
  line-height:1.2;
  margin-bottom:22px;
  color: #fff;
}
.hero-title span{
  background:linear-gradient(90deg,#fff, #cfe9ff);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero-sub{
  font-size:1.08rem; color:rgba(255,255,255,0.88);
  max-width:560px; margin-bottom:34px;
}
.hero-actions{display:flex; flex-wrap:wrap; gap:14px;}
.btn-hero-primary, .btn-hero-outline, .btn-hero-whatsapp{
  font-family:var(--font-display); font-weight:600; font-size:.95rem;
  padding:14px 28px; border-radius:50px;
  display:inline-flex; align-items:center; gap:8px;
  transition:transform .25s ease, box-shadow .25s ease;
  border:none;
}
.btn-hero-primary{background:#fff; color:var(--primary); box-shadow:0 12px 26px -8px rgba(0,0,0,0.35);}
.btn-hero-primary:hover{transform:translateY(-3px); color:var(--primary-dark);}
.btn-hero-outline{background:transparent; color:#fff; border:1.5px solid rgba(255,255,255,0.6);}
.btn-hero-outline:hover{background:rgba(255,255,255,0.12); transform:translateY(-3px); color:#fff;}
.btn-hero-whatsapp{background:#25D366; color:#fff;}
.btn-hero-whatsapp:hover{transform:translateY(-3px); color:#fff; box-shadow:0 12px 26px -8px rgba(37,211,102,0.6);}

/* Floating appointment card */
.floating-card{
  background:rgba(255,255,255,0.97);
  border-radius:var(--radius-lg);
  padding:30px;
  color:var(--navy);
  box-shadow:0 30px 60px -20px rgba(0,0,0,0.4);
  animation:floatCard 5s ease-in-out infinite;
}
@keyframes floatCard{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(-14px);}
}
.floating-card-head{display:flex; align-items:center; gap:14px; margin-bottom:20px; padding-bottom:18px; border-bottom:1px solid var(--border-soft);}
.floating-card-head i{font-size:2rem; color:var(--primary);}
.floating-card-head strong{display:block; font-family:var(--font-display); font-size:1.1rem;}
.floating-card-head span{font-size:.82rem; color:var(--text-muted);}
.floating-card-list li{display:flex; align-items:center; gap:10px; padding:8px 0; font-size:.92rem;}
.floating-card-list i{color:var(--secondary);}
.btn-floating-cta{
  display:flex; align-items:center; justify-content:center; gap:8px;
  background:var(--grad-primary); color:#fff; font-family:var(--font-display); font-weight:600;
  padding:13px; border-radius:50px; margin-top:16px;
  transition:opacity .25s ease;
}
.btn-floating-cta:hover{opacity:.9; color:#fff;}

/* Hero stats */
.hero-stats-row{margin-top:60px;}
.stat-card{
  background:rgba(255,255,255,0.1);
  border:1px solid rgba(255,255,255,0.18);
  backdrop-filter:blur(6px);
  border-radius:var(--radius-md);
  padding:24px 16px;
  text-align:center;
  transition:transform .3s ease, background .3s ease;
}
.stat-card:hover{transform:translateY(-6px); background:rgba(255,255,255,0.18);}
.stat-card i{font-size:1.6rem; color:var(--secondary); margin-bottom:10px;}
.stat-card h3{color:#fff; font-size:1.9rem; margin-bottom:4px;}
.stat-card p{color:rgba(255,255,255,0.8); font-size:.85rem; margin:0;}

/* ==========================================================================
   ABOUT
   ========================================================================== */
.about-media{position:relative; padding:20px 30px 30px 0;}
.about-img-main{border-radius:var(--radius-lg); box-shadow:var(--shadow-soft); width:100%; height:420px; object-fit:cover;}
.about-img-float{
  position:absolute; bottom:0; right:0; width:52%;
  border-radius:var(--radius-md); border:6px solid #fff;
  box-shadow:0 20px 40px -12px rgba(10,37,64,0.3);
}
.about-badge{
  position:absolute; top:0; left:0;
  background:#fff; border-radius:var(--radius-md);
  padding:16px 20px; display:flex; align-items:center; gap:12px;
  box-shadow:var(--shadow-soft);
}
.about-badge i{font-size:1.6rem; color:var(--primary);}
.about-badge strong{display:block; font-family:var(--font-display); font-size:1rem;}
.about-badge span{font-size:.78rem; color:var(--text-muted);}

.about-values{margin-top:26px;}
.value-box{
  display:flex; gap:14px; align-items:flex-start;
  background:#fff; border-radius:var(--radius-md); padding:18px;
  box-shadow:0 6px 20px -10px rgba(10,37,64,0.12);
  height:100%;
}
.value-box i{font-size:1.4rem; color:var(--primary); margin-top:2px;}
.value-box strong{display:block; font-family:var(--font-display); font-size:.98rem; margin-bottom:4px;}
.value-box span{font-size:.86rem; color:var(--text-muted);}

/* ==========================================================================
   WHY CHOOSE US
   ========================================================================== */
.why-section{background:var(--grad-soft);}
.col-lg-2-4{flex:0 0 auto; width:20%;}
.why-box{
  background:#fff; border-radius:var(--radius-md);
  text-align:center; padding:30px 14px;
  box-shadow:0 8px 24px -14px rgba(10,37,64,0.18);
  transition:transform .3s ease, box-shadow .3s ease;
  height:100%;
}
.why-box:hover{transform:translateY(-8px); box-shadow:var(--shadow-hover);}
.why-box i{font-size:1.9rem; color:var(--primary); margin-bottom:14px; display:block;}
.why-box h4{font-size:.95rem;}

/* ==========================================================================
   SERVICES
   ========================================================================== */
.service-card{
  background:#fff; border-radius:var(--radius-md);
  padding:32px 26px; height:100%;
  box-shadow:0 8px 24px -14px rgba(10,37,64,0.15);
  border:1px solid transparent;
  transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.service-card:hover{
  transform:translateY(-8px);
  box-shadow:var(--shadow-hover);
  border-color:rgba(11,110,253,0.25);
}
.service-icon{
  width:58px; height:58px; border-radius:16px;
  background:var(--grad-soft);
  display:flex; align-items:center; justify-content:center;
  font-size:1.5rem; color:var(--primary);
  margin-bottom:20px;
  transition:background .3s ease, color .3s ease;
}
.service-card:hover .service-icon{background:var(--grad-primary); color:#fff;}
.service-card h4{font-size:1.08rem; margin-bottom:10px;}
.service-card p{font-size:.9rem; color:var(--text-muted); margin:0;}

/* ==========================================================================
   DOCTORS
   ========================================================================== */
.doctors-section{background:var(--grad-soft);}
.doctor-card{
  background:#fff; border-radius:var(--radius-lg); overflow:hidden;
  box-shadow:0 10px 30px -16px rgba(10,37,64,0.2);
  transition:transform .3s ease, box-shadow .3s ease;
  height:100%;
}
.doctor-card:hover{transform:translateY(-8px); box-shadow:var(--shadow-hover);}
.doctor-photo{height:270px; overflow:hidden;}
.doctor-photo img{width:100%; height:100%; object-fit:cover; transition:transform .5s ease;}
.doctor-card:hover .doctor-photo img{transform:scale(1.08);}
.doctor-info{padding:24px;}
.doctor-info h4{font-size:1.1rem; margin-bottom:4px;}
.doctor-spec{display:block; color:var(--primary); font-size:.85rem; font-weight:600; margin-bottom:8px;}
.doctor-info p{font-size:.82rem; color:var(--text-muted); margin-bottom:18px;}
.doctor-actions{display:flex; gap:8px; flex-wrap:wrap;}
.btn-doc-primary{
  background:var(--grad-primary); color:#fff; font-size:.8rem; font-weight:600;
  padding:9px 16px; border-radius:50px; flex:1; text-align:center;
}
.btn-doc-outline{
  border:1.5px solid var(--border-soft); color:var(--navy); font-size:.8rem; font-weight:600;
  padding:9px 16px; border-radius:50px; flex:1; text-align:center; transition:border-color .3s ease;
}
.btn-doc-outline:hover{border-color:var(--primary); color:var(--primary);}

/* ==========================================================================
   FACILITIES
   ========================================================================== */
.facility-tile{
  position:relative; border-radius:var(--radius-md); overflow:hidden;
  height:220px; box-shadow:0 8px 22px -12px rgba(10,37,64,0.2);
}
.facility-tile img{width:100%; height:100%; object-fit:cover; transition:transform .5s ease;}
.facility-tile:hover img{transform:scale(1.1);}
.facility-tile span{
  position:absolute; left:0; right:0; bottom:0;
  background:linear-gradient(0deg, rgba(10,37,64,0.85), transparent);
  color:#fff; font-family:var(--font-display); font-weight:600; font-size:.92rem;
  padding:16px 16px 12px;
}

/* ==========================================================================
   TIMELINE
   ========================================================================== */
.journey-section{background:#fff;}
.timeline{position:relative; max-width:900px; margin:0 auto; padding-left:20px;}
.timeline-line{
  position:absolute; left:49px; top:6px; bottom:6px; width:2px;
  background:linear-gradient(180deg, var(--primary), var(--secondary));
}
.timeline-item{display:flex; gap:22px; margin-bottom:34px; position:relative;}
.timeline-item:last-child{margin-bottom:0;}
.timeline-icon{
  flex:0 0 auto; width:60px; height:60px; border-radius:50%;
  background:var(--grad-primary); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:1.3rem; box-shadow:0 8px 18px -6px rgba(11,110,253,0.5);
  z-index:1;
}
.timeline-content{
  background:#fff; border-radius:var(--radius-md); padding:18px 22px;
  box-shadow:0 8px 22px -14px rgba(10,37,64,0.18);
  flex:1;
}
.timeline-content h4{font-size:1.02rem; margin-bottom:6px;}
.timeline-content p{font-size:.88rem; color:var(--text-muted); margin:0;}

/* ==========================================================================
   PEDIATRIC / INFERTILITY (shared split layout styles)
   ========================================================================== */
.pediatric-section{background:var(--grad-soft);}
.pediatric-media img, .infertility-media img{
  border-radius:var(--radius-lg); box-shadow:var(--shadow-soft);
  width:100%; height:420px; object-fit:cover;
}
.mini-feature{
  display:flex; align-items:center; gap:10px;
  background:#fff; border-radius:var(--radius-sm); padding:14px 16px;
  font-size:.88rem; font-weight:600; font-family:var(--font-display);
  box-shadow:0 6px 16px -10px rgba(10,37,64,0.15);
}
.mini-feature i{color:var(--primary); font-size:1.1rem;}
.btn-section-cta{
  display:inline-flex; align-items:center; gap:8px;
  background:var(--grad-primary); color:#fff; font-family:var(--font-display); font-weight:600;
  padding:14px 30px; border-radius:50px;
  box-shadow:0 12px 24px -8px rgba(11,110,253,0.45);
  transition:transform .25s ease;
}
.btn-section-cta:hover{transform:translateY(-3px); color:#fff;}

.infertility-list{margin-top:20px;}
.infertility-item{
  display:flex; align-items:center; gap:12px;
  padding:11px 0; border-bottom:1px dashed var(--border-soft);
  font-size:.95rem;
}
.infertility-item:last-child{border-bottom:none;}
.infertility-item i{color:var(--secondary); font-size:1.1rem;}

/* ==========================================================================
   SUCCESS STORIES
   ========================================================================== */
.success-section{background:#fff;}
.story-card{
  background:#fff; border-radius:var(--radius-lg); overflow:hidden;
  box-shadow:0 10px 30px -16px rgba(10,37,64,0.2);
  transition:transform .3s ease;
  height:100%;
}
.story-card:hover{transform:translateY(-8px);}
.story-card img{height:220px; object-fit:cover; width:100%;}
.story-body{padding:22px;}
.story-body h4{font-size:1rem; margin-bottom:10px;}
.story-body p{font-size:.88rem; color:var(--text-muted); font-style:italic; margin:0;}

/* ==========================================================================
   TESTIMONIALS
   ========================================================================== */
.testimonials-section{background:var(--grad-soft);}
.google-rating{
  display:inline-flex; align-items:center; gap:8px;
  background:#fff; border-radius:50px; padding:10px 22px;
  box-shadow:0 6px 18px -10px rgba(10,37,64,0.2);
  font-family:var(--font-display); font-weight:600; margin-top:10px;
}
.google-rating i.bi-google{color:#EA4335;}
.google-rating .stars i{color:#FFB800; font-size:.85rem;}
.testimonial-card{
  background:#fff; border-radius:var(--radius-md); padding:32px 28px;
  box-shadow:0 8px 24px -14px rgba(10,37,64,0.18);
  height:100%; margin:6px 4px 40px;
}
.testimonial-card i.bi-quote{font-size:1.8rem; color:var(--primary); opacity:.4; margin-bottom:10px; display:block;}
.testimonial-card p{font-size:.95rem; color:var(--navy); margin-bottom:20px; min-height:90px;}
.testi-author strong{display:block; font-family:var(--font-display); font-size:.95rem;}
.testi-author span{font-size:.78rem; color:var(--text-muted);}
.swiper-pagination-bullet-active{background:var(--primary) !important;}

/* ==========================================================================
   GALLERY
   ========================================================================== */
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  grid-auto-rows:180px;
  gap:16px;
}
.gallery-item{
  position:relative; border-radius:var(--radius-md); overflow:hidden;
  display:block;
}
.gallery-item.item-tall{grid-row:span 2;}
.gallery-item img{width:100%; height:100%; object-fit:cover; transition:transform .5s ease;}
.gallery-item:hover img{transform:scale(1.1);}
.gallery-caption{
  position:absolute; left:0; right:0; bottom:0;
  background:linear-gradient(0deg, rgba(10,37,64,0.85), transparent);
  color:#fff; font-family:var(--font-display); font-weight:600; font-size:.85rem;
  padding:14px 14px 10px;
}

/* ==========================================================================
   FAQ
   ========================================================================== */
.accordion-item{
  border:none; border-radius:var(--radius-md) !important; overflow:hidden;
  margin-bottom:14px; box-shadow:0 6px 18px -12px rgba(10,37,64,0.15);
}
.accordion-button{
  font-family:var(--font-display); font-weight:600; font-size:.98rem;
  color:var(--navy); background:#fff; padding:20px 24px;
}
.accordion-button:not(.collapsed){color:var(--primary); background:var(--grad-soft);}
.accordion-button:focus{box-shadow:none;}
.accordion-button::after{
  background-size:20px;
}
.accordion-body{font-size:.9rem; color:var(--text-muted); padding:6px 24px 22px;}

/* ==========================================================================
   APPOINTMENT
   ========================================================================== */
.appointment-section{
  background:var(--navy);
  background-image:radial-gradient(circle at 20% 20%, rgba(11,110,253,0.35), transparent 45%), radial-gradient(circle at 85% 80%, rgba(0,168,232,0.3), transparent 50%);
  position:relative;
}
.appointment-contacts{display:flex; flex-direction:column; gap:14px; margin-top:26px;}
.appointment-contact{
  display:inline-flex; align-items:center; gap:10px;
  color:#fff; font-family:var(--font-display); font-weight:600; font-size:1rem;
}
.appointment-contact i{
  width:42px; height:42px; border-radius:50%;
  background:rgba(255,255,255,0.14);
  display:flex; align-items:center; justify-content:center;
}
.appointment-form{
  background:#fff; border-radius:var(--radius-lg); padding:36px;
  box-shadow:0 30px 60px -20px rgba(0,0,0,0.5);
}
.form-label{font-family:var(--font-display); font-weight:600; font-size:.88rem; margin-bottom:6px;}
.opt{font-weight:400; color:var(--text-muted); font-size:.8rem;}
.form-control, .form-select{
  border:1.5px solid var(--border-soft); border-radius:var(--radius-sm);
  padding:12px 14px; font-size:.92rem;
}
.form-control:focus, .form-select:focus{
  border-color:var(--primary); box-shadow:0 0 0 4px rgba(11,110,253,0.12);
}
.btn-appt-submit{
  background:var(--grad-primary); color:#fff; font-family:var(--font-display); font-weight:700;
  padding:15px; border-radius:50px; border:none; font-size:1rem;
  display:flex; align-items:center; justify-content:center; gap:10px;
  transition:transform .25s ease; position:relative; overflow:hidden;
}
.btn-appt-submit:hover{transform:translateY(-2px);}
.form-success-msg{
  background:rgba(25,135,84,0.1); color:#198754; border-radius:var(--radius-sm);
  padding:14px 18px; font-size:.9rem; font-weight:600;
  display:flex; align-items:center; gap:10px;
}

/* ripple effect */
.ripple{
  position:absolute; border-radius:50%; transform:scale(0);
  animation:rippleAnim .6s linear; background:rgba(255,255,255,0.5);
  pointer-events:none;
}
@keyframes rippleAnim{ to{transform:scale(3); opacity:0;} }

/* ==========================================================================
   CONTACT
   ========================================================================== */
.contact-info-card{
  background:#fff; border-radius:var(--radius-lg); padding:34px;
  box-shadow:var(--shadow-soft); height:100%;
}
.contact-info-item{display:flex; gap:16px; padding:16px 0; border-bottom:1px solid var(--border-soft);}
.contact-info-item:last-of-type{border-bottom:none;}
.contact-info-item i{font-size:1.3rem; color:var(--primary); margin-top:2px;}
.contact-info-item strong{display:block; font-family:var(--font-display); font-size:.95rem; margin-bottom:3px;}
.contact-info-item span, .contact-info-item a{font-size:.88rem; color:var(--text-muted);}
.contact-buttons{display:flex; gap:10px; margin-top:20px; flex-wrap:wrap;}
.btn-contact-action{
  flex:1; text-align:center; padding:12px; border-radius:50px;
  background:var(--grad-soft); color:var(--primary); font-family:var(--font-display); font-weight:600; font-size:.85rem;
  transition:background .3s ease, color .3s ease;
}
.btn-contact-action:hover{background:var(--grad-primary); color:#fff;}
.btn-contact-action.whatsapp{background:rgba(37,211,102,0.12); color:#1a9e4f;}
.btn-contact-action.whatsapp:hover{background:#25D366; color:#fff;}
.map-wrapper{
  border-radius:var(--radius-lg); overflow:hidden; height:100%; min-height:400px;
  box-shadow:var(--shadow-soft);
}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.site-footer{
  background:var(--navy); color:rgba(255,255,255,0.75);
  padding:70px 0 24px; font-size:.9rem;
}
.footer-brand{display:flex; align-items:center; gap:12px; margin-bottom:18px;}
.footer-brand .brand-text strong{color:#fff;}
.footer-brand .brand-text small{color:rgba(255,255,255,0.6);}
.footer-about{color:rgba(255,255,255,0.65); font-size:.88rem; max-width:340px;}
.footer-socials{display:flex; gap:12px; margin-top:18px;}
.footer-socials a{
  width:38px; height:38px; border-radius:50%; background:rgba(255,255,255,0.1);
  display:flex; align-items:center; justify-content:center; transition:background .3s ease;
}
.footer-socials a:hover{background:var(--grad-primary);}
.site-footer h5{color:#fff; font-size:1rem; margin-bottom:20px;}
.site-footer ul li{margin-bottom:12px;}
.site-footer ul li a{color:rgba(255,255,255,0.65); transition:color .2s ease;}
.site-footer ul li a:hover{color:var(--secondary);}
.footer-contact li{display:flex; align-items:flex-start; gap:10px; color:rgba(255,255,255,0.65);}
.footer-contact i{color:var(--secondary); margin-top:3px;}
.site-footer hr{border-color:rgba(255,255,255,0.1); margin:36px 0 20px;}
.footer-bottom{display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; font-size:.82rem; color:rgba(255,255,255,0.55);}

/* ==========================================================================
   FLOATING WHATSAPP + BACK TO TOP
   ========================================================================== */
.whatsapp-float{
  position:fixed; bottom:26px; left:26px; z-index:900;
  width:58px; height:58px; border-radius:50%;
  background:#25D366; color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:1.7rem;
  box-shadow:0 12px 26px -8px rgba(37,211,102,0.6);
  animation:pulseGlow 2.5s ease-in-out infinite;
}
@keyframes pulseGlow{
  0%,100%{box-shadow:0 12px 26px -8px rgba(37,211,102,0.6);}
  50%{box-shadow:0 12px 32px -4px rgba(37,211,102,0.9);}
}
.back-to-top{
  position:fixed; bottom:26px; right:26px; z-index:900;
  width:52px; height:52px; border-radius:50%; border:none;
  background:var(--grad-primary); color:#fff; font-size:1.2rem;
  box-shadow:0 12px 26px -8px rgba(11,110,253,0.6);
  opacity:0; visibility:hidden; transform:translateY(10px);
  transition:all .3s ease;
}
.back-to-top.show{opacity:1; visibility:visible; transform:translateY(0);}

/* ==========================================================================
   MISC / ACCESSIBILITY
   ========================================================================== */
@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; scroll-behavior:auto !important;}
}

::selection{background:var(--primary); color:#fff;}
