/* --- HERO CAROUSEL --- */
.hero-carousel { position: relative; }
.hero-slides { position: relative; width: 100%; min-height: 480px; display: flex; align-items: stretch; }
.hero-slide { display: none; opacity: 0; transition: opacity 0.6s; position: absolute; width: 100%; left: 0; top: 0; height: 100%; }
.hero-slide.active { display: block; opacity: 1; position: relative; }
.hero-carousel-control { position: absolute; top: 50%; transform: translateY(-50%); background: var(--primary); color: #fff; border: none; border-radius: 50%; width: 50px; height: 50px; font-size: 1.4rem; cursor: pointer; z-index: 10; opacity: 0.85; display: flex; align-items: center; justify-content: center; transition: all 0.3s ease; box-shadow: 0 4px 12px rgba(0,0,0,0.1); }
.hero-carousel-control.prev { left: -75px; }
.hero-carousel-control.next { right: -75px; }

@media (max-width: 1440px) {
  .hero-carousel-control.prev { left: 15px; }
  .hero-carousel-control.next { right: 15px; }
  .hero-carousel-control { 
    background: rgba(255, 255, 255, 0.9); 
    color: var(--primary);
    backdrop-filter: blur(4px);
  }
}

.hero-nav-group {
  display: contents; /* Keeps absolute positioning working on desktop */
}

@media (max-width: 768px) {
  .hero-carousel { margin-bottom: 90px; }
  .hero-nav-group {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 15px;
    position: absolute;
    bottom: -75px;
    left: 0;
    right: 0;
    z-index: 20;
  }
  .hero-carousel-control {
    position: static;
    transform: none;
    width: 46px;
    height: 46px;
    background: var(--primary);
    color: #fff;
    flex-shrink: 0;
  }
}

.hero-carousel-control:hover { 
  opacity: 1; 
  background: var(--primary); 
  color: #fff;
  transform: translateY(-50%) scale(1.1); 
  box-shadow: 0 6px 16px rgba(25, 118, 210, 0.2);
}

@media (max-width: 768px) {
  .hero-carousel-control:hover { transform: scale(1.1); }
}

.hero-carousel-control:focus { outline: 2px solid var(--accent); outline-offset: 4px; }

/* --- HERO DOTS --- */
.hero-dots {
  position: absolute;
  bottom: 25px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 12px;
  z-index: 15;
  padding: 8px 16px;
  background: rgba(255, 255, 255, 0.5);
  backdrop-filter: blur(10px);
  border-radius: 30px;
  box-shadow: 0 4px 15px rgba(0,0,0,0.05);
}
.dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(25, 118, 210, 0.2);
  border: 1.5px solid var(--primary);
  cursor: pointer;
  transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}
.dot.active {
  background: var(--primary);
  width: 28px;
  border-radius: 10px;
}
@media (max-width: 768px) {
  .hero-dots { 
    position: static; 
    transform: none; 
    background: transparent; 
    backdrop-filter: none; 
    box-shadow: none;
    padding: 0;
    gap: 8px;
  }
}

/* --- DOCTOR CARD HOVER BIOS --- */
.doctor-card { position: relative; overflow: visible; transition: box-shadow 0.2s, transform 0.2s; }
.doctor-hover { display: none; position: absolute; left: 0; right: 0; top: 100%; background: var(--surface); box-shadow: 0 8px 32px rgba(25,118,210,0.13); border-radius: 14px; padding: 1.1rem; z-index: 10; margin-top: 0.5rem; min-width: 220px; max-width: 340px; }
.doctor-card.show-bio .doctor-hover, .doctor-card:focus-within .doctor-hover, .doctor-card:hover .doctor-hover { display: block; }
.doctor-contact { margin-top: 0.7rem; display: flex; gap: 1rem; }
.doctor-contact a { color: var(--primary-600); text-decoration: none; font-weight: 600; }
.doctor-contact a:hover { text-decoration: underline; color: var(--primary); }
@media (max-width: 700px) {
  .doctor-hover { position: static; margin-top: 0.7rem; box-shadow: 0 2px 8px rgba(25,118,210,0.07); }
}

/* --- SERVICES SECTION --- */
.service-desc { color: var(--muted); font-size: 1.01rem; margin: 0.7rem 0 0 0; text-align: center; }

/* --- BLOG/HEALTH TIPS --- */
.blog-card { background: var(--card-bg); border-radius: var(--card-radius); box-shadow: var(--card-shadow); padding: 1.5rem 1.1rem; display: flex; flex-direction: column; gap: 0.7rem; }
.blog-card h3 { margin: 0 0 0.5rem 0; font-size: 1.13rem; color: var(--primary-600); }
.blog-card p { color: var(--muted); font-size: 1.01rem; margin: 0 0 0.7rem 0; }

/* --- PATIENT RESOURCES --- */
.resource-card { background: var(--card-bg); border-radius: var(--card-radius); box-shadow: var(--card-shadow); padding: 1.5rem 1.1rem; display: flex; flex-direction: column; align-items: center; gap: 0.7rem; text-align: center; }
.resource-icon { font-size: 2.2rem; margin-bottom: 0.5rem; color: var(--primary-600); }
.resource-card h3 { margin: 0 0 0.5rem 0; font-size: 1.13rem; color: var(--primary-600); }
.resource-card p { color: var(--muted); font-size: 1.01rem; margin: 0 0 0.7rem 0; }

/* --- FIND US SECTION --- */
.find-us-section .btn { margin-bottom: 0.5rem; }
/* Sticky WhatsApp Button */
.whatsapp-float {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 60px;
  height: 60px;
  background: #25d366;
  border-radius: 50%;
  box-shadow: 0 4px 16px rgba(37,211,102,0.18);
  transition: box-shadow 0.2s, transform 0.2s;
  opacity: 1;
  visibility: visible;
  animation: whatsapp-fade-in 0.3s ease;
}

@keyframes whatsapp-fade-in {
  from { opacity: 0; transform: translateY(32px); }
  to { opacity: 1; transform: none; }
}
}
.whatsapp-float:hover {
  box-shadow: 0 8px 32px rgba(37,211,102,0.28);
  transform: scale(1.08);
}
.whatsapp-float svg {
  display: block;
  width: 32px;
  height: 32px;
  color: #fff;
}
.root-font-fallback{font-family:Inter,system-ui,Segoe UI,Roboto,'Helvetica Neue',Arial}
:root{
  --bg:#f7fafd;
  --surface:#fff;
  --primary:#1976d2;
  --primary-600:#125ea2;
  --muted:#4b5563;
  --accent:#43e6b0;
  --radius:18px;
  --container:1200px;
  --max-width:1200px;
  --shadow:0 4px 24px rgba(25,118,210,0.07);
  --card-bg:#fff;
  --card-radius:18px;
  --card-shadow:0 2px 16px rgba(25,118,210,0.08);
  --font-main:'Lato', 'Montserrat', 'Inter', system-ui, Arial, sans-serif;
}
*{box-sizing:border-box}
body{font-family:var(--font-main);line-height:1.6;color:#1a2a3a;background:var(--bg);margin:0;-webkit-font-smoothing:antialiased}
.container{max-width:var(--container);margin:0 auto;padding:2.5rem 1.5rem}
.site-header{background:var(--card-bg);box-shadow:var(--shadow);position:sticky;top:0;z-index:30;border-bottom:1px solid #e3eaf3;}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 0}
.logo{font-weight:800;color:var(--primary);font-size:1.5rem;text-decoration:none;letter-spacing:0.04em;}
.main-nav ul{display:flex;gap:2.2rem;list-style:none;margin:0;padding:0}
.main-nav a{color:var(--muted);text-decoration:none;padding:0.6rem 1.1rem;border-radius:12px;font-weight:600;font-size:1.08rem;transition:background 0.2s,color 0.2s;}
.main-nav a:hover,.main-nav a:focus{color:var(--primary);background:rgba(30,136,229,0.07);outline:2px solid rgba(30,136,229,0.10);outline-offset:2px}
.header-actions{display:flex;gap:1.2rem;align-items:center}
.btn{display:inline-block;padding:0.7rem 1.5rem;border-radius:14px;text-decoration:none;font-weight:700;font-size:1.08rem;box-shadow:0 2px 8px rgba(30,136,229,0.04);transition:background 0.2s,color 0.2s,box-shadow 0.2s;}

@media (max-width: 1250px) {
  .main-nav ul { gap: 0.8rem; }
  .main-nav a { padding: 0.5rem 0.6rem; font-size: 1rem; }
  .header-actions { gap: 0.8rem; }
}

.btn-primary{background:var(--primary);color:white;}
.btn-primary:hover{background:var(--primary-600);box-shadow:0 4px 16px rgba(30,136,229,0.10);}
.btn-outline{background:transparent;border:2px solid var(--primary);color:var(--primary);}
.btn-outline:hover{background:var(--primary);color:#fff;}
.nav-toggle{display:none;border:0;background:transparent;font-size:1.5rem}

.hero{padding:5.5rem 0 4.5rem 0;position:relative;background:var(--surface);box-shadow:0 2px 16px rgba(25,118,210,0.04);}
.hero-bg{position:absolute;inset:0;z-index:0;background:linear-gradient(90deg,#e3f2fd 0%,#f7fafd 100%);pointer-events:none;}
.hero-grid{display:grid;grid-template-columns:1fr 520px;gap:4rem;align-items:center;position:relative;z-index:1;}
.hero-content h1{font-size:3.1rem;margin:0 0 1.1rem;line-height:1.08;font-weight:900;letter-spacing:-0.01em;}
.hero-content h1 span{color:var(--primary)}
.hero-content p{color:var(--muted);max-width:60ch;font-size:1.22rem;margin-bottom:2.2rem;}
.hero-ctas{margin:1.5rem 0 0 0;display:flex;gap:1.2rem}
.hero-quicklinks{margin-top:2.2rem;display:flex;gap:1.2rem;flex-wrap:wrap;}
.quicklink{background:var(--primary);color:#fff;padding:0.5rem 1.1rem;border-radius:8px;text-decoration:none;font-weight:600;font-size:1.01rem;transition:background 0.2s;}
.quicklink:hover{background:var(--primary-600);}
.clinic-info{list-style:none;padding:0;margin:1.2rem 0 0;color:var(--muted)}
.hero-media { width: 100%; height: 450px; background: #fff; display: flex; align-items: center; justify-content: center; overflow: hidden; border-radius: var(--radius); margin: 0; }
.hero-media img{width:100%;height:100%;object-fit:contain;box-shadow:0 10px 30px rgba(25,118,210,0.10)}
/* Why Choose Us section */
.why-grid{display:grid;grid-template-columns:1fr 420px;gap:3.5rem;align-items:center;}
.why-text h2{font-size:2rem;font-weight:800;color:var(--primary-600);margin-bottom:1.2rem;}
.why-text ul{padding-left:1.2rem;list-style:square;color:var(--muted);font-size:1.13rem;line-height:1.7;}
.why-img img{width:100%;border-radius:var(--radius);box-shadow:0 4px 24px rgba(25,118,210,0.08);}

.section{padding:3.5rem 0}
.section.alt{background:var(--surface)}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:2rem;padding:0;margin-top:2.2rem;}
.service-card{background:var(--card-bg);border-radius:var(--card-radius);box-shadow:var(--card-shadow);padding:2.2rem 1.2rem;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:box-shadow 0.2s,transform 0.2s;cursor:pointer;}
.service-card:hover{box-shadow:0 8px 32px rgba(30,136,229,0.13);transform:translateY(-4px) scale(1.03);}
.service-card h3{margin:1.2rem 0 0 0;font-size:1.18rem;font-weight:700;color:var(--primary-600);text-align:center;}
.service-icon{display:flex;align-items:center;justify-content:center;width:54px;height:54px;background:var(--surface);border-radius:50%;box-shadow:0 2px 8px rgba(30,136,229,0.07);margin-bottom:1.1rem;}

.doctors-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:2.2rem;margin-top:2.2rem;}
.doctor-card{background:var(--card-bg);padding:2.2rem 1.2rem;border-radius:var(--card-radius);box-shadow:var(--card-shadow);display:flex;flex-direction:row;align-items:center;gap:1.5rem;transition:box-shadow 0.2s,transform 0.2s;}
.doctor-card:hover{box-shadow:0 8px 32px rgba(30,136,229,0.13);transform:translateY(-4px) scale(1.03);}
.avatar{height:90px;width:90px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--primary));overflow:hidden;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(30,136,229,0.07);}
.avatar img{width:100%;height:100%;object-fit:cover;display:block;border-radius:50%}
.doctor-info h3{margin:0 0 0.3rem 0;font-size:1.15rem;font-weight:700;color:var(--primary-600);}
.doctor-info p{margin:0;color:var(--muted);font-size:1.02rem;}

/* Testimonials Scrollable */
.testimonials-carousel {
  overflow-x: auto;
  overflow-y: hidden;
  margin-top: 2.2rem;
  padding-bottom: 1.5rem;
  display: flex;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x mandatory;
  scrollbar-width: none; /* Hide scrollbar for Firefox */
}
.testimonials-carousel::-webkit-scrollbar {
  display: none; /* Hide scrollbar for Chrome/Safari */
}
.testimonials-track {
  display: flex;
  gap: 1.5rem;
  padding: 0.5rem 0;
}
.testimonials-track blockquote {
  min-width: 300px;
  max-width: 400px;
  flex: 0 0 calc(90vw - 2rem);
  background: var(--card-bg);
  padding: 2.2rem 2rem;
  border-radius: var(--card-radius);
  box-shadow: var(--card-shadow);
  margin: 0;
  scroll-snap-align: center;
  transition: box-shadow 0.3s ease;
}
@media (min-width: 768px) {
  .testimonials-track blockquote {
    flex: 0 0 400px;
  }
}
.testimonials-track blockquote p {
  font-size: 1.08rem;
  margin: 0 0 1.1rem 0;
}
.testimonials-track blockquote cite {
  display: block;
  margin-top: 1.2rem;
  color: var(--muted);
  font-size: 1.08rem;
  font-style: normal;
}

.faq-list{margin-top:2.2rem;}
.faq-list details{background:var(--card-bg);padding:1.2rem 1rem;border-radius:var(--card-radius);margin-bottom:1.2rem;box-shadow:var(--card-shadow);}
.faq-list summary{font-weight:700;cursor:pointer;font-size:1.08rem;color:var(--primary-600);}

.contact-grid{display:grid;grid-template-columns:1fr 420px;gap:2.5rem;align-items:start;margin-top:2.2rem;}
.book-form{display:flex;flex-direction:column;gap:1.2rem;background:var(--card-bg);padding:2.2rem 1.2rem;border-radius:var(--card-radius);box-shadow:var(--card-shadow);}
.book-form label{display:flex;flex-direction:column;font-size:1.05rem;color:var(--muted);font-weight:600;gap:0.3rem;}
.book-form input,.book-form select{padding:0.7rem;border-radius:10px;border:1.5px solid #e3eaf3;font-size:1.05rem;}

.site-footer{padding:2.2rem 0;background:var(--surface);border-top:1px solid #e3eaf3;color:var(--muted);font-size:1.08rem;}
.footer-grid{display:grid;grid-template-columns:2fr 2fr 1.5fr 2fr;gap:2.2rem;align-items:start;}
.footer-brand{font-size:1.2rem;font-weight:800;color:var(--primary-600);margin-bottom:0.7rem;}
.footer-contact,.footer-social,.footer-legal{font-size:1.01rem;}
.footer-social a{color:var(--primary-600);margin-right:0.5rem;text-decoration:none;}
.footer-social a:hover{color:var(--primary);text-decoration:underline;}
.footer-legal a{color:var(--muted);text-decoration:none;margin-right:0.5rem;}
.footer-legal a:hover{color:var(--primary-600);text-decoration:underline;}
@media (max-width:1100px){
  .why-grid{grid-template-columns:1fr;gap:2.2rem;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:1.2rem;}
}
@media (max-width:700px){
  .footer-grid{grid-template-columns:1fr;gap:1.2rem;}
}

@media (max-width:1100px){
  .container{padding:2.5rem 1.5rem;}
  .hero-grid{grid-template-columns:1fr;gap:3rem;text-align:center;}
  .hero-content { display: flex; flex-direction: column; align-items: center; }
  .hero-content h1 { font-size: 2.5rem; }
  .hero-content p { margin: 0 auto 2.2rem; }
  .hero-ctas { width: 100%; flex-direction: column; gap: 1rem; }
  .hero-ctas .btn { width: 100%; padding: 1rem; }
  .hero-quicklinks { justify-content: center; gap: 0.8rem; }
  .hero-media { height: 350px; order: -1; background: transparent; } /* Image on top for better mobile flow, transparent bg to blend */
  .contact-grid{grid-template-columns:1fr;gap:2.2rem;}
}
@media (max-width:1080px){
  .main-nav ul{display:none}
  .main-nav.open ul{display:flex;flex-direction:column;gap:0.5rem;padding:1rem;background:var(--card-bg);border-radius:14px;position:absolute;top:70px;right:16px;box-shadow:0 10px 30px rgba(30,136,229,0.10)}
  .nav-toggle{display:inline-block}
  .header-actions .btn-primary{display:none}
}

@media (max-width:600px){
  .header-inner { padding: 1rem 0.8rem; }
  .logo { font-size: 1.25rem; }
  .header-actions { gap: 0.5rem; }
  .header-actions .btn { padding: 0.5rem 0.8rem; font-size: 0.95rem; }
  
  .hero-content h1{ 
    font-size: 2.1rem; 
    padding: 0 0.5rem; 
    line-height: 1.2; 
    margin-bottom: 1rem;
    max-width: 100%;
  }
  .hero-content p { 
    font-size: 1.05rem; 
    line-height: 1.5; 
    margin: 0 auto 1.8rem;
    padding: 0 0.5rem;
  }
  .hero-media { height: 300px; }
  .hero-media img { object-fit: contain; box-shadow: none; }
  .hero-quicklinks { gap: 0.5rem; justify-content: center; }
  .quicklink { font-size: 0.85rem; padding: 0.4rem 0.8rem; }
  .doctor-card{flex-direction:column;align-items:center;text-align:center;}
  .avatar{margin-bottom:1.2rem;}
  .services-grid{grid-template-columns:1fr;}
  .testimonials{grid-template-columns:1fr;}
}

.main-nav.open + .header-actions .nav-toggle{transform:rotate(90deg)}
