/* =================================================
   VITALIA PEDIATRÍA - CSS FINAL
   ================================================= */
:root{
  --color-primary:#1B2A4E;
  --color-primary-light:#2C3F66;
  --color-secondary:#C9A961;
  --color-secondary-light:#D9BC7B;
  --color-cream:#F5EFEA;
  --color-beige:#E8E0D5;
  --color-beige-light:#F8F4ED;
  --color-text-dark:#3D2F26;
  --color-text-muted:#7B6E62;
  --color-white:#FFFFFF;
  --color-success:#25D366;
  --shadow-sm:0 4px 12px rgba(27,42,78,.08);
  --shadow-md:0 10px 30px rgba(27,42,78,.12);
  --shadow-lg:0 20px 50px rgba(27,42,78,.18);
  --transition:all .35s cubic-bezier(.25,.46,.45,.94);
}

*{box-sizing:border-box}
html{overflow-x:hidden;scroll-behavior:smooth;scroll-padding-top:90px}
body{
  line-height:1.7;
  font-family:'Montserrat',sans-serif;
  -webkit-font-smoothing:antialiased;
  font-size:16px;
  color:var(--color-text-dark);
  overflow-x:hidden;
  background:var(--color-white);
}
h1,.h1,h2,.h2,h3,.h3,h4,.h4,h5,.h5,h6,.h6{
  font-family:'Cormorant Garamond',serif;
  font-weight:600;
  color:var(--color-primary);
  margin-top:0;
}
h1,.h1{font-size:3rem;line-height:1.2}
h2,.h2{font-size:2.8rem;line-height:1.2}
h3,.h3{font-size:2rem}
h4,.h4{font-size:1.4rem;line-height:1.5;font-weight:500}
h5,.h5{font-size:1.2rem}
h6,.h6{font-size:1rem;font-family:'Montserrat',sans-serif;font-weight:600}
p{line-height:1.8;color:var(--color-text-muted)}
a{color:var(--color-primary);text-decoration:none;transition:var(--transition)}
a:hover,a:focus{color:var(--color-secondary);outline:none;text-decoration:none}
img{max-width:100%;height:auto}

/* === BOTONES === */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:13px;
  font-weight:500;
  letter-spacing:1.5px;
  padding:.85rem 2.2rem;
  font-family:'Montserrat',sans-serif;
  text-transform:uppercase;
  border-radius:5px;
  border:2px solid transparent;
  transition:var(--transition);
  cursor:pointer;
}
.btn:focus{outline:0;box-shadow:none}
.btn-sm{padding:.6rem 1.4rem;font-size:11px}

.btn-main{
  background:var(--color-primary);
  color:#fff;
  border-color:var(--color-primary);
  box-shadow:0 4px 15px rgba(27,42,78,.25);
}
.btn-main:hover{
  background:var(--color-secondary);
  border-color:var(--color-secondary);
  color:#fff;
  transform:translateY(-3px);
  box-shadow:0 8px 25px rgba(201,169,97,.4);
}
.btn-main-2{
  background:var(--color-secondary);
  color:#fff;
  border-color:var(--color-secondary);
  box-shadow:0 4px 15px rgba(201,169,97,.25);
}
.btn-main-2:hover{
  background:var(--color-primary);
  color:#fff;
  border-color:var(--color-primary);
  transform:translateY(-3px);
}
.btn-white{background:#fff;color:var(--color-primary);border-color:#fff}
.btn-white:hover{background:transparent;color:#fff;border-color:#fff}
.btn-google{
  background:#fff;
  color:#3c4043;
  border:1px solid #dadce0;
  font-weight:600;
}
.btn-google:hover{background:#f8f9fa;color:#1a73e8;border-color:#dadce0;transform:translateY(-2px)}
.btn-round-full{border-radius:50px}

/* === SECCIONES === */
.section{padding:100px 0}
.cream-bg{background:var(--color-cream)}
.section-title{margin-bottom:70px}
.section-title h2{color:var(--color-primary);margin-top:10px}
.section-subtitle{
  color:var(--color-secondary);
  font-family:'Montserrat',sans-serif;
  font-size:12px;
  letter-spacing:4px;
  text-transform:uppercase;
  font-weight:600;
  display:inline-block;
  position:relative;
  padding:0 30px;
}
.section-subtitle::before,.section-subtitle::after{
  content:'';
  position:absolute;
  top:50%;
  width:20px;
  height:1px;
  background:var(--color-secondary);
}
.section-subtitle::before{left:0}
.section-subtitle::after{right:0}
.divider{
  width:60px;
  height:2px;
  background:var(--color-secondary);
  position:relative;
}
.divider::after{
  content:'';
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  width:8px;
  height:8px;
  background:var(--color-secondary);
  border-radius:50%;
  border:2px solid var(--color-cream);
}
.title-color{color:var(--color-primary)}

/* === HEADER === */
#site-header{position:relative;z-index:100}
.header-top-bar{
  background:var(--color-primary);
  font-size:13px;
  padding:12px 0;
  color:#fff;
}
.top-bar-info li a{color:#fff;margin-right:20px}
.top-bar-info li a:hover{color:var(--color-secondary)}
.top-right-bar a{color:#fff}
.top-right-bar a span{color:#fff}
.top-right-bar a:hover span{color:var(--color-secondary)}

/* === NAVBAR === */
.navigation{
  background:#fff;
  box-shadow:0 2px 15px rgba(0,0,0,.05);
  padding:15px 0;
  transition:all .4s ease;
}
.navigation.is-sticky{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:1000;
  padding:10px 0;
  box-shadow:0 5px 20px rgba(0,0,0,.08);
  animation:slideDown .5s ease;
}
@keyframes slideDown{from{transform:translateY(-100%)}to{transform:translateY(0)}}
.navbar-brand img{max-width:80px;transition:transform .3s}
.navbar-brand:hover img{transform:scale(1.05)}

#navbarmain .nav-link{
  font-weight:500;
  padding:12px 18px !important;
  color:var(--color-primary);
  font-family:'Montserrat',sans-serif;
  text-transform:uppercase;
  font-size:12px;
  letter-spacing:1.5px;
  position:relative;
}
#navbarmain .nav-link::after{
  content:'';
  position:absolute;
  bottom:5px;
  left:50%;
  transform:translateX(-50%);
  width:0;
  height:2px;
  background:var(--color-secondary);
  transition:width .3s;
}
#navbarmain .nav-link:hover,#navbarmain .nav-link.active{color:var(--color-secondary)}
#navbarmain .nav-link:hover::after,#navbarmain .nav-link.active::after{width:25px}

.navbar-toggler{border:none;padding:8px}
.navbar-toggler:focus{outline:none;box-shadow:none}
.navbar-toggler-icon-custom{width:30px;height:22px;display:inline-block;position:relative}
.navbar-toggler-icon-custom span{
  display:block;
  position:absolute;
  height:3px;
  width:100%;
  background:var(--color-primary);
  border-radius:3px;
  transition:all .3s;
}
.navbar-toggler-icon-custom span:nth-child(1){top:0}
.navbar-toggler-icon-custom span:nth-child(2){top:9px}
.navbar-toggler-icon-custom span:nth-child(3){top:18px}
.navbar-toggler:not(.collapsed) .navbar-toggler-icon-custom span:nth-child(1){top:9px;transform:rotate(135deg)}
.navbar-toggler:not(.collapsed) .navbar-toggler-icon-custom span:nth-child(2){opacity:0}
.navbar-toggler:not(.collapsed) .navbar-toggler-icon-custom span:nth-child(3){top:9px;transform:rotate(-135deg)}

.navigation .dropdown-menu{
  padding:0;
  border:0;
  border-top:3px solid var(--color-secondary);
  background:#fff;
  border-radius:0 0 8px 8px;
  box-shadow:0 8px 20px rgba(0,0,0,.08);
  margin-top:0;
}
.navigation .dropdown-toggle::after{display:none}
.navigation .dropdown-item{
  padding:14px 22px;
  font-weight:400;
  color:var(--color-text-dark);
  border-bottom:1px solid var(--color-cream);
  font-size:13px;
  transition:all .3s;
}
.navigation li:last-child .dropdown-item{border-bottom:0}
.navigation .dropdown-item:hover{background:var(--color-cream);color:var(--color-secondary);padding-left:28px}
.navigation .dropdown-item i{color:var(--color-secondary)}

@media (min-width:992px){
  .navigation .dropdown-menu{
    display:block;
    opacity:0;
    visibility:hidden;
    transform:translateY(10px);
    transition:all .3s;
    min-width:240px;
  }
  .navigation .dropdown:hover>.dropdown-menu{
    visibility:visible;
    opacity:1;
    transform:translateY(0);
  }
}

/* === BANNER CON IMAGEN SL2.jpg === */
.banner{
  position:relative;
  overflow:hidden;
  color:#fff;
  min-height:650px;
}
.banner-bg{
  position:absolute;
  inset:0;
  z-index:0;
  background-image:
    linear-gradient(135deg,rgba(27,42,78,0.85) 0%,rgba(27,42,78,0.6) 50%,rgba(27,42,78,0.85) 100%),
    url('../images/SL2.jpg');
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
}
.banner-decorations{
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  overflow:hidden;
}
.deco-circle{
  position:absolute;
  border-radius:50%;
  border:1px solid rgba(201,169,97,.25);
  animation:float 8s ease-in-out infinite;
}
.deco-1{width:300px;height:300px;top:-100px;right:-100px}
.deco-2{width:200px;height:200px;bottom:50px;left:5%;animation-delay:2s}
.deco-3{width:100px;height:100px;top:50%;right:10%;animation-delay:4s}
@keyframes float{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-30px) rotate(180deg)}}

.banner .container{position:relative;z-index:2}
.banner .block{padding:100px 0 160px}
.banner .block h1{
  color:#fff !important;
  font-size:4.5rem;
  letter-spacing:1px;
  text-shadow:0 2px 10px rgba(0,0,0,.4);
  font-weight:600;
}
.banner .block h1 em{
  font-style:italic;
  color:var(--color-secondary);
  font-weight:500;
}
.banner .block p{
  color:rgba(255,255,255,.95) !important;
  font-size:1.1rem;
  line-height:1.8;
  text-shadow:0 1px 4px rgba(0,0,0,.4);
  max-width:680px;
}
.brand-tag{
  color:var(--color-secondary) !important;
  font-weight:600 !important;
  letter-spacing:4px !important;
  font-size:13px !important;
}
.banner .divider{background:var(--color-secondary)}

/* === FEATURES === */
.features{margin-top:-90px;position:relative;z-index:5;padding:0}
.feature-block{gap:20px}
.feature-item{
  flex:1;
  padding:45px 32px;
  background:#fff;
  border-radius:12px;
  box-shadow:var(--shadow-md);
  transition:var(--transition);
  border-top:3px solid transparent;
  margin-bottom:0;
}
.feature-item:hover{
  transform:translateY(-10px);
  box-shadow:var(--shadow-lg);
  border-top-color:var(--color-secondary);
}
.feature-item .feature-icon i{
  font-size:50px;
  color:var(--color-secondary);
  transition:transform .4s;
  display:inline-block;
}
.feature-item:hover .feature-icon i{transform:scale(1.1) rotate(5deg)}
.feature-item span{
  color:var(--color-secondary);
  font-size:11px;
  letter-spacing:2px;
  text-transform:uppercase;
  font-weight:600;
}
.feature-item h4{color:var(--color-primary);margin-top:8px;font-size:1.3rem}
.feature-item p{font-size:14px}
.feature-buttons{display:flex;flex-wrap:wrap;gap:8px}
.feature-item-highlight{
  background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);
}
.feature-item-highlight h4,
.feature-item-highlight p,
.feature-item-highlight .feature-icon i{color:#fff !important}
.feature-item-highlight span{color:var(--color-secondary) !important}

/* === ESTADÍSTICAS === */
.stats-section{
  background:var(--color-primary);
  padding:60px 0;
  position:relative;
  overflow:hidden;
}
.stats-section::before,.stats-section::after{
  content:'';
  position:absolute;
  border-radius:50%;
}
.stats-section::before{
  top:-50%;left:-10%;
  width:300px;height:300px;
  background:radial-gradient(circle,rgba(201,169,97,.15) 0%,transparent 70%);
}
.stats-section::after{
  bottom:-50%;right:-10%;
  width:400px;height:400px;
  background:radial-gradient(circle,rgba(201,169,97,.1) 0%,transparent 70%);
}
.stat-item{text-align:center;color:#fff;padding:20px;position:relative;z-index:2}
.stat-item i{
  font-size:45px;
  color:var(--color-secondary);
  margin-bottom:15px;
  display:block;
}
.stat-item .counter{
  font-family:'Cormorant Garamond',serif;
  font-size:3rem;
  font-weight:700;
  color:#fff;
  line-height:1;
  display:inline-block;
}
.stat-item span:last-of-type{
  font-family:'Cormorant Garamond',serif;
  font-size:2.5rem;
  color:var(--color-secondary);
  font-weight:700;
}
.stat-item p{
  color:rgba(255,255,255,.85);
  margin:10px 0 0;
  font-size:13px;
  letter-spacing:2px;
  text-transform:uppercase;
  font-weight:500;
}

/* === EQUIPO - IMÁGENES MEJORADAS === */
.team-section{background:var(--color-beige-light)}
.team-section .team-slide{padding:30px 20px}
.team-section .team-media{
  height:550px;
  overflow:hidden;
  border-radius:15px;
  box-shadow:var(--shadow-lg);
  border:6px solid #fff;
  position:relative;
  background:var(--color-cream);
}
.team-section .team-media::before{
  content:'';
  position:absolute;
  inset:6px;
  border:1px solid var(--color-secondary);
  border-radius:10px;
  pointer-events:none;
  z-index:2;
  opacity:.4;
}
.team-section .team-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 20%;
}
.team-content h3{color:var(--color-primary);font-size:2.3rem;margin-bottom:5px}
.team-content h4{
  color:var(--color-secondary);
  font-size:1.05rem;
  margin-bottom:20px;
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:2px;
  font-family:'Montserrat',sans-serif;
}
.team-content h4 i{margin-right:8px}
.quote-text{
  font-style:italic;
  font-family:'Cormorant Garamond',serif;
  color:var(--color-primary);
  font-size:1.3rem;
  border-left:3px solid var(--color-secondary);
  padding-left:18px;
  margin:18px 0 22px;
  line-height:1.5;
  font-weight:500;
}
.benefits-list li{
  padding:12px 0;
  border-bottom:1px solid var(--color-beige);
  display:flex;
  align-items:flex-start;
}
.benefits-list li:last-child{border-bottom:none}
.benefits-list i{
  color:var(--color-secondary);
  font-size:1.4rem;
  margin-right:15px;
  margin-top:3px;
  flex-shrink:0;
}
.benefit-content{display:flex;flex-direction:column}
.benefit-content strong{
  color:var(--color-primary);
  font-weight:600;
  margin-bottom:3px;
  font-size:.95rem;
}
.benefit-content span{color:var(--color-text-muted);font-size:.92rem}

/* === CARRUSEL EQUIPO ARROWS === */
.team-carousel{position:relative}
.team-carousel .slick-arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  z-index:10;
  border:none;
  background:var(--color-primary);
  color:#fff;
  width:55px;
  height:55px;
  border-radius:50%;
  font-size:18px;
  cursor:pointer;
  transition:all .3s;
  display:flex;
  justify-content:center;
  align-items:center;
  box-shadow:var(--shadow-md);
  padding:0;
}
.team-carousel .slick-arrow:hover{
  background:var(--color-secondary);
  transform:translateY(-50%) scale(1.1);
}
.team-carousel .slick-prev{left:-28px}
.team-carousel .slick-next{right:-28px}
.team-carousel .slick-arrow::before{display:none}

.slick-dots{padding:0;margin-top:30px}
.slick-dots li button:before{color:var(--color-secondary);font-size:10px}
.slick-dots li.slick-active button:before{color:var(--color-primary)}

/* === SERVICIOS === */
.service-item{
  background:#fff;
  padding:35px 28px;
  border-radius:12px;
  box-shadow:var(--shadow-sm);
  transition:var(--transition);
  width:100%;
  text-align:center;
  position:relative;
  overflow:hidden;
  margin-bottom:20px;
}
.service-item::before{
  content:'';
  position:absolute;
  top:0;left:0;
  width:100%;height:4px;
  background:var(--color-secondary);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .4s;
}
.service-item:hover{
  transform:translateY(-8px);
  box-shadow:var(--shadow-lg);
}
.service-item:hover::before{transform:scaleX(1)}
.service .icon{
  width:80px;
  height:80px;
  background:var(--color-cream);
  border-radius:50%;
  margin:0 auto 20px;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:all .4s;
}
.service-item:hover .icon{
  background:var(--color-secondary);
  transform:rotate(360deg);
}
.service .icon i{
  font-size:34px;
  color:var(--color-secondary);
  transition:color .3s;
}
.service-item:hover .icon i{color:#fff}
.service h4{color:var(--color-primary);font-size:1.3rem;margin-bottom:15px}
.service-item p{font-size:14px}

/* === GALERÍA - IMÁGENES MÁS GRANDES === */
.gallery-section{background:#fff}
.gallery-item{padding:0 12px}
.gallery-item img{
  border-radius:10px;
  box-shadow:var(--shadow-sm);
  width:100%;
  height:320px;
  object-fit:cover;
  transition:transform .4s,box-shadow .4s;
}
.gallery-item:hover img{
  transform:scale(1.02);
  box-shadow:var(--shadow-md);
}

.slick-prev,.slick-next{
  width:45px !important;
  height:45px !important;
  background:var(--color-primary) !important;
  border-radius:50% !important;
  z-index:10;
}
.slick-prev:hover,.slick-next:hover{background:var(--color-secondary) !important}

/* === TIPS - VIDEOS VERTICALES MEJORADOS === */
.tips-section .tips-carousel{margin:0 -10px}
.tip-slide{padding:0 10px}
.video-card-mini{
  background:#fff;
  border-radius:10px;
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:var(--transition);
  cursor:pointer;
  position:relative;
}
.video-card-mini:hover{
  transform:translateY(-5px);
  box-shadow:var(--shadow-md);
}
.video-card-mini img{
  width:100%;
  height:340px;
  object-fit:cover;
  display:block;
}
.video-card-mini .play-icon{
  position:absolute;
  top:150px;
  left:50%;
  transform:translateX(-50%);
  width:55px;
  height:55px;
  background:rgba(201,169,97,.95);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  font-size:22px;
  box-shadow:0 4px 12px rgba(0,0,0,.3);
  transition:transform .3s;
}
.video-card-mini:hover .play-icon{transform:translateX(-50%) scale(1.15)}
.video-card-mini h5{
  margin:0;
  padding:15px 12px;
  color:var(--color-primary);
  font-size:.95rem;
  font-weight:600;
  font-family:'Cormorant Garamond',serif;
  text-align:center;
  background:#fff;
}

/* === CALENDARIO === */
.calendar-section{padding:100px 0;background:var(--color-cream)}
.calendar-container{
  background:#fff;
  padding:30px;
  border-radius:12px;
  box-shadow:var(--shadow-md);
  border:1px solid var(--color-beige);
  min-height:400px;
}
.calendar-container>a{
  display:block;
  text-align:center;
  padding:80px 20px;
  background:var(--color-cream);
  color:var(--color-primary);
  border-radius:8px;
  font-weight:600;
  font-size:1.1rem;
}
.calendar-container iframe{
  width:100% !important;
  border:none !important;
  border-radius:8px;
}
.alternative-booking{
  padding-top:20px;
  border-top:1px solid var(--color-beige);
}
.alternative-booking p{color:var(--color-text-muted);font-size:14px}

/* === FILOSOFÍA === */
.about-img img{
  border-radius:10px;
  box-shadow:var(--shadow-md);
  transition:transform .4s;
}
.about-img img:hover{transform:scale(1.02)}
.about-content{padding-left:30px}

/* === RESEÑAS GOOGLE === */
.testimonial-2{background:var(--color-cream)}
.google-rating-summary{
  display:inline-flex;
  align-items:center;
  gap:15px;
  background:#fff;
  padding:15px 25px;
  border-radius:50px;
  box-shadow:var(--shadow-sm);
  margin-top:20px;
}
.google-logo{
  width:40px;
  height:40px;
  background:#fff;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  border:1px solid #dadce0;
  flex-shrink:0;
}
.rating-info{text-align:left;line-height:1.3}
.rating-info .testimonial-stars{font-size:18px;color:#fbbc05;margin-bottom:2px}
.rating-info span{font-size:13px;color:var(--color-text-muted)}
.rating-info strong{color:var(--color-primary);font-size:15px}

.reviews-loading{
  text-align:center;
  padding:60px 20px;
  color:var(--color-text-muted);
}
.spinner{
  width:40px;
  height:40px;
  border:3px solid var(--color-cream);
  border-top-color:var(--color-secondary);
  border-radius:50%;
  margin:0 auto 15px;
  animation:spin .8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

.reviews-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:20px;
  margin-top:20px;
}
.review-card{
  background:#fff;
  border:1px solid var(--color-beige);
  border-radius:12px;
  padding:22px;
  box-shadow:var(--shadow-sm);
  transition:var(--transition);
  position:relative;
}
.review-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
  border-color:var(--color-secondary);
}
.review-card::before{
  content:'';
  position:absolute;
  top:15px;
  right:15px;
  width:18px;
  height:18px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%234285F4' d='M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92c-.26 1.37-1.04 2.53-2.21 3.31v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.09z'/%3E%3Cpath fill='%2334A853' d='M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z'/%3E%3Cpath fill='%23FBBC05' d='M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18C1.43 8.55 1 10.22 1 12s.43 3.45 1.18 4.93l2.85-2.22.81-.62z'/%3E%3Cpath fill='%23EA4335' d='M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z'/%3E%3C/svg%3E");
  background-size:contain;
  background-repeat:no-repeat;
  opacity:0.7;
}
.review-header{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:12px;
  padding-right:30px;
}
.review-avatar{
  width:42px;
  height:42px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  font-weight:600;
  font-size:18px;
  font-family:'Cormorant Garamond',serif;
  flex-shrink:0;
  overflow:hidden;
}
.review-avatar img{width:100%;height:100%;object-fit:cover}
.review-author{flex:1;min-width:0}
.review-author h5{
  margin:0;
  font-size:.95rem;
  font-weight:600;
  color:var(--color-primary);
  font-family:'Montserrat',sans-serif;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.review-author span{font-size:11px;color:var(--color-text-muted)}
.review-stars{
  color:#fbbc05;
  font-size:14px;
  letter-spacing:1px;
  margin-bottom:10px;
}
.review-card p{
  font-size:13.5px;
  line-height:1.6;
  color:var(--color-text-dark);
  margin:0;
  display:-webkit-box;
  -webkit-line-clamp:6;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.review-location{
  display:inline-flex;
  align-items:center;
  gap:4px;
  margin-top:12px;
  padding:4px 10px;
  background:var(--color-cream);
  border-radius:20px;
  font-size:11px;
  color:var(--color-text-muted);
  font-weight:500;
}
.review-location i{
  color:var(--color-secondary);
  font-size:11px;
}

/* === LISTA DE SERVICIOS (sin precios) === */
.services-list-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:15px;
}
.service-list-item{
  background:#fff;
  padding:20px 25px;
  border-radius:10px;
  display:flex;
  align-items:center;
  gap:15px;
  box-shadow:var(--shadow-sm);
  transition:var(--transition);
  border-left:3px solid transparent;
}
.service-list-item:hover{
  transform:translateX(5px);
  box-shadow:var(--shadow-md);
  border-left-color:var(--color-secondary);
}
.service-list-item i{
  font-size:1.6rem;
  color:var(--color-secondary);
  flex-shrink:0;
  width:35px;
}
.service-list-item span{
  color:var(--color-text-dark);
  font-weight:500;
  font-size:.95rem;
}
.lead{font-size:1.2rem;color:var(--color-primary);font-weight:500}

/* === UBICACIONES === */
.location-card{
  background:#fff;
  border-radius:12px;
  padding:30px;
  box-shadow:var(--shadow-sm);
  transition:var(--transition);
  height:100%;
  border:1px solid var(--color-beige);
}
.location-card:hover{
  transform:translateY(-5px);
  box-shadow:var(--shadow-md);
  border-color:var(--color-secondary);
}
.location-card h3{color:var(--color-primary)}
.location-card h3 i{color:var(--color-secondary);margin-right:8px}
.location-info p{margin-bottom:12px;color:var(--color-text-muted)}
.location-info i{color:var(--color-secondary);margin-right:6px}
.location-info a{color:var(--color-primary);font-weight:600}
.location-info a:hover{color:var(--color-secondary)}
.embed-responsive iframe{border-radius:8px}

/* === FOOTER === */
.footer{
  background:linear-gradient(180deg,var(--color-cream) 0%,var(--color-beige) 100%);
  border-top:4px solid var(--color-secondary);
  padding-top:80px;
  padding-bottom:10px;
}
.footer .logo img{max-width:140px}
.footer p{color:var(--color-text-dark)}
.footer p i{color:var(--color-secondary);margin-right:6px}
.widget h4{color:var(--color-primary)}
.widget .divider{background:var(--color-secondary)}
.footer-contact-block i{color:var(--color-secondary);font-size:22px}
.footer-contact-block a{color:var(--color-primary);font-weight:600}
.footer-contact-block a:hover{color:var(--color-secondary)}
.footer-socials{padding-left:0}
.footer-socials li a{
  width:45px;
  height:45px;
  background:var(--color-primary);
  color:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  transition:all .4s;
}
.footer-socials li a:hover{
  background:var(--color-secondary);
  transform:translateY(-3px) rotate(360deg);
  color:#fff;
}
.footer-btm{border-top:1px solid var(--color-beige)}
.copyright{color:var(--color-text-muted);font-size:13px}
.copyright a{color:var(--color-secondary)}

/* === BOTONES FLOTANTES === */
.floating-buttons{
  position:fixed;
  bottom:30px;
  right:20px;
  z-index:999;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.floating-btn{
  width:55px;
  height:55px;
  border-radius:50%;
  color:#fff !important;
  display:flex !important;
  justify-content:center;
  align-items:center;
  font-size:24px;
  box-shadow:0 5px 15px rgba(0,0,0,.2);
  transition:all .3s;
  text-decoration:none;
  line-height:1;
}
.floating-btn i{
  display:flex;
  align-items:center;
  justify-content:center;
  line-height:1;
}
.floating-btn:hover{
  transform:translateY(-3px) scale(1.05);
  box-shadow:0 8px 20px rgba(0,0,0,.3);
  color:#fff;
}
.calendar-btn{background:var(--color-primary)}
.calendar-btn:hover{background:var(--color-secondary)}
.whatsapp-btn{
  background:var(--color-success);
  animation:pulse-wa 2s infinite;
}
.whatsapp-btn:hover{background:#1EAE54}
@keyframes pulse-wa{
  0%{box-shadow:0 0 0 0 rgba(37,211,102,.7)}
  70%{box-shadow:0 0 0 18px rgba(37,211,102,0)}
  100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}
}
.backtop{
  background:var(--color-primary);
  display:none !important;
}
.backtop.show{display:flex !important}
.backtop:hover{background:var(--color-secondary)}
.backtop i{color:#fff;font-size:20px}

/* === MODAL VIDEO === */
#videoModal .modal-dialog{
  max-width:90vw;
  margin:1.75rem auto;
  display:flex;
  align-items:center;
  min-height:calc(100% - 3.5rem);
}
#videoModal .modal-content{background:transparent;border:none;box-shadow:none}
#videoModal .modal-body{padding:0}
#modalVideoPlayer{width:100%;max-height:85vh;height:auto;border-radius:8px}
#videoModal .modal-header{
  position:absolute;
  top:-45px;
  right:-10px;
  z-index:10;
  border:none;
  padding:0;
}
#videoModal .modal-header .close{
  font-size:2.5rem;
  color:#fff;
  opacity:.95;
  text-shadow:0 2px 4px rgba(0,0,0,.7);
}
@media (max-width:767px){
  #videoModal .embed-responsive-16by9{
    padding-top:177.77% !important;
    background:#000;
    border-radius:8px;
  }
  #modalVideoPlayer{
    position:absolute;
    top:0;left:0;
    width:100%;height:100%;
    object-fit:contain;
  }
}

/* === FALLBACK IMÁGENES === */
.img-fallback{
  width:100%;
  height:100%;
  min-height:300px;
  background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--color-secondary);
  font-family:'Cormorant Garamond',serif;
  font-size:8rem;
  font-weight:600;
  border-radius:10px;
  position:relative;
  overflow:hidden;
}
.img-fallback::before{
  content:'';
  position:absolute;
  inset:15px;
  border:1px solid var(--color-secondary);
  border-radius:8px;
  opacity:0.3;
}
.review-avatar .img-fallback{min-height:auto;font-size:1.1rem;border-radius:50%}
.team-media .img-fallback{min-height:550px}

/* === ANIMACIONES AOS === */
[data-aos]{
  opacity:0;
  transition:all .8s ease;
  will-change:transform,opacity;
}
[data-aos].aos-animate{opacity:1}
[data-aos="fade-up"]{transform:translateY(40px)}
[data-aos="fade-up"].aos-animate{transform:translateY(0)}
[data-aos="fade-left"]{transform:translateX(40px)}
[data-aos="fade-left"].aos-animate{transform:translateX(0)}
[data-aos="fade-right"]{transform:translateX(-40px)}
[data-aos="fade-right"].aos-animate{transform:translateX(0)}
[data-aos="zoom-in"]{transform:scale(.9)}
[data-aos="zoom-in"].aos-animate{transform:scale(1)}

/* === SCROLLBAR === */
::-webkit-scrollbar{width:10px}
::-webkit-scrollbar-track{background:var(--color-cream)}
::-webkit-scrollbar-thumb{background:var(--color-primary);border-radius:5px}
::-webkit-scrollbar-thumb:hover{background:var(--color-secondary)}
::selection{background:var(--color-secondary);color:#fff}

/* ==========================================
   RESPONSIVE
   ========================================== */
@media (max-width:1199px){
  h1,.h1{font-size:2.5rem}
  h2,.h2{font-size:2.3rem}
  .banner .block h1{font-size:3.5rem}
}

@media (max-width:991px){
  h1,.h1{font-size:2.2rem}
  h2,.h2{font-size:2rem}
  h3,.h3{font-size:1.6rem}

  .banner{min-height:550px}
  .banner .block h1{font-size:2.8rem !important}
  .banner .block{padding:70px 0 110px}
  .banner .block p{font-size:1rem}

  .features{margin-top:-50px}
  .feature-block{flex-wrap:wrap;gap:15px;display:block !important}
  .feature-item{margin-bottom:20px;flex:none}

  .section{padding:70px 0}
  .section-title{margin-bottom:50px}

  .stat-item .counter,.stat-item span:last-of-type{font-size:2.5rem}

  /* === FLECHAS DOCTORES SOBRE LA IMAGEN EN MOBILE === */
  .team-carousel{padding-bottom:50px}
  .team-carousel .slick-arrow{
    top:230px;
    width:42px;
    height:42px;
    font-size:14px;
  }
  .team-carousel .slick-prev{left:15px}
  .team-carousel .slick-next{right:15px}
  
  .team-section .team-media{height:480px}
  .team-content{margin-top:30px}
  .team-content h3{font-size:1.9rem}

  .top-bar-info{text-align:center;padding:0}
  .top-bar-info li{display:block;margin:5px 0}
  .top-bar-info li a{margin-right:0}
  .header-top-bar{font-size:12px}

  .navbar-collapse{
    background:#fff;
    padding:20px;
    margin-top:15px;
    border-radius:10px;
    box-shadow:0 5px 20px rgba(0,0,0,.1);
  }
  #navbarmain .nav-link{
    padding:12px 15px !important;
    border-bottom:1px solid var(--color-beige);
  }
  #navbarmain .nav-item:last-child .nav-link{border-bottom:none}

  .navigation .dropdown-menu{
    background:var(--color-cream);
    border-top:none;
    margin-top:10px;
  }

  .about-content{padding-left:0;margin-top:30px}

  .deco-1{width:200px;height:200px}
  .deco-2{width:150px;height:150px}

  /* Galería más grande en tablet */
  .gallery-item img{height:340px}
  
  /* Videos más altos en tablet */
  .video-card-mini img{height:380px}
  .video-card-mini .play-icon{top:170px}
}

@media (max-width:767px){
  h1,.h1{font-size:1.9rem}
  h2,.h2{font-size:1.7rem;line-height:1.3}
  h3,.h3{font-size:1.4rem}
  h4,.h4{font-size:1.15rem}

  .banner{min-height:500px}
  .banner .block h1{font-size:2rem !important;line-height:1.3}
  .banner .block{padding:50px 0 80px}
  .banner .block p{font-size:.95rem;padding-right:0 !important}
  .brand-tag{font-size:11px !important;letter-spacing:2px !important}

  .btn{font-size:11px;padding:.7rem 1.5rem;margin-bottom:10px}

  .section{padding:50px 0}
  .section-title{margin-bottom:40px}

  .feature-item{padding:35px 25px}
  .feature-icon i{font-size:42px !important}

  .stats-section{padding:40px 0}
  .stat-item{padding:15px 5px}
  .stat-item i{font-size:32px}
  .stat-item .counter,.stat-item span:last-of-type{font-size:2rem}
  .stat-item p{font-size:11px;letter-spacing:1px}

  /* === DOCTORES MOBILE - IMÁGENES MÁS GRANDES === */
  .team-carousel .slick-arrow{
    top:240px;
    width:40px;
    height:40px;
    font-size:13px;
  }
  .team-section .team-media{height:480px}
  .team-content h3{font-size:1.6rem}
  .team-content h4{font-size:.95rem}
  .team-content p{font-size:.95rem}
  .quote-text{font-size:1.1rem}

  .service-item{padding:30px 22px}
  .service .icon{width:65px;height:65px}
  .service .icon i{font-size:28px}

  /* === GALERÍA MOBILE - IMÁGENES MÁS GRANDES === */
  .gallery-item img{height:380px}
  
  /* === TIPS VIDEOS MOBILE - VERTICAL FORMATO === */
  .video-card-mini img{height:420px}
  .video-card-mini .play-icon{
    top:190px;
    width:50px;
    height:50px;
    font-size:20px;
  }
  .video-card-mini h5{font-size:.9rem;padding:14px 10px}

  .review-card{padding:18px}
  .review-card p{-webkit-line-clamp:5}
  .google-rating-summary{padding:12px 18px;gap:10px}

  .footer{padding-top:50px}
  .footer .widget{text-align:center}
  .footer-socials{justify-content:center;display:flex;flex-wrap:wrap;gap:8px}

  .calendar-container{padding:20px;min-height:400px}
  .calendar-section{padding:60px 0}

  .navbar-brand img{max-width:60px}

  .floating-buttons{bottom:15px;right:12px;gap:8px}
  .floating-btn{width:48px;height:48px;font-size:20px}

  .top-right-bar a span.h5{font-size:13px}

  .location-card{padding:22px}

  .services-list-grid{grid-template-columns:1fr;gap:12px}
  .service-list-item{padding:16px 20px}
  .service-list-item i{font-size:1.4rem}
  .service-list-item span{font-size:.9rem}

  .reviews-grid{
    grid-template-columns:1fr;
    gap:15px;
  }

  .team-media .img-fallback{min-height:480px}
}

@media (max-width:480px){
  .banner .block h1{font-size:1.7rem !important}
  h2,.h2{font-size:1.5rem}

  .btn{display:block;width:100%;margin-bottom:10px;padding:.7rem 1rem}
  .feature-buttons .btn,.feature-item .btn{width:auto;display:inline-flex}
  .banner .btn{display:inline-flex;width:auto}

  .calendar-container{padding:15px}

  /* Imágenes aún más grandes en móviles pequeños */
  .gallery-item img{height:340px}
  .video-card-mini img{height:380px}
  .video-card-mini .play-icon{top:170px}
  .team-section .team-media{height:430px}
  .team-carousel .slick-arrow{top:215px}
  
  .review-author h5{font-size:.9rem}
}