/* ================== Variables globales ================== */
:root{
  --brand:#00B5FF; --brand2:#6A00FF; --ink:#0f172a; --light:#fff;
  --radius:18px; --shadow:0 10px 30px rgba(0,0,0,.35);
  --maxw:1200px;
  --navw:1600px;    /* ancho máximo SOLO para el header */
  --navh:88px;      /* altura del header */
}

/* ================== Base ================== */
*{box-sizing:border-box}
html,body{margin:0;font:16px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Inter,Helvetica,Arial}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.container{max-width:var(--maxw);margin-inline:auto;padding:0 20px}

/* ================== Header ================== */
header.site-header{
  position:fixed; top:0; left:0; right:0; z-index:50;
  background:transparent; color:var(--light);
  transition:background .18s ease, box-shadow .18s ease, color .18s ease;
}
header.site-header .container{ max-width:var(--navw); padding-inline:24px; }

.nav{display:flex;align-items:center;justify-content:space-between;height:var(--navh)}
.brand{display:flex;align-items:center;gap:12px;font-weight:900}
.brand__mark{display:none}
.nav__links{display:flex;gap:22px;align-items:center}
.nav__cta{display:inline-block;padding:10px 16px;border-radius:999px;background:linear-gradient(90deg,var(--brand),var(--brand2));color:#00122a;font-weight:800;box-shadow:var(--shadow)}
.burger{display:none;cursor:pointer;border:1px solid rgba(255,255,255,.45);padding:8px 10px;border-radius:10px}

header.site-header.scrolled{ background:#fff; color:#0b1220; box-shadow:0 6px 18px rgba(0,0,0,.08); }
.brand .logo{height:50px;width:auto;display:block}
.brand .logo--dark{display:none}
header.site-header.scrolled .logo--light{display:none}
header.site-header.scrolled .logo--dark{display:block}

@media (max-width:860px){.nav__links{display:none}.burger{display:inline-flex}}
.drawer{display:none}
@media (max-width:860px){
  .drawer{
    position:fixed; inset:var(--navh) 0 0 auto; background:#0f172a;
    border-left:1px solid #1f2937; width:min(86vw,360px);
    transform:translateX(100%); transition:transform .2s ease; box-shadow:var(--shadow); display:block
  }
  .drawer.open{transform:none}
  .drawer a{display:block;padding:14px 18px;border-bottom:1px solid #1f2937;color:#fff}
}

/* ================== Hero con slideshow ================== */
.hero{
  min-height:92vh; display:grid; position:relative;
  color:#e5f0ff; text-align:center; overflow:hidden;
}
.hero__inner{
  width:100%;
  display:grid; align-content:start; justify-items:center; row-gap:16px;
  padding-top:calc(var(--navh) ); /* + 4px sube/baja el bloque del hero */
}
.hero::after{ content:""; position:absolute; inset:0; background:linear-gradient(rgba(0,0,0,.35), rgba(0,0,0,.35)); z-index:0; }


.slideshow{position:absolute; inset:0; z-index:-1; overflow:hidden}
.slideshow span{
  position:absolute; inset:0; background:var(--bg) center/cover no-repeat;
  opacity:0; animation:fade 12s infinite; will-change:opacity;
}
.slideshow span:nth-of-type(1){animation-delay:0s}
.slideshow span:nth-of-type(2){animation-delay:4s}
.slideshow span:nth-of-type(3){animation-delay:8s}
@keyframes fade{ 0%{opacity:0} 10%{opacity:1} 35%{opacity:1} 45%{opacity:0} 100%{opacity:0} }

.hero__cta{display:flex;gap:12px;justify-content:center;margin-top:18px;flex-wrap:wrap;z-index:1}
.btn{display:inline-block;padding:12px 18px;border-radius:999px;background:linear-gradient(90deg,var(--brand),var(--brand2));color:#00122a;font-weight:800;box-shadow:var(--shadow);transition:transform .12s ease}
.btn:active{transform:scale(.98)}
.btn--ghost{background:transparent;border:1px solid rgba(255,255,255,.5);color:#fff}

/* ================== Secciones ================== */
.section{padding:72px 0}
.section h2{margin:0 0 10px;font-size:clamp(22px,4vw,34px)}
.muted{color:#6b7280}
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
@media (max-width:920px){.grid{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid #e5e7eb;color:#0f172a;border-radius:var(--radius);box-shadow:0 12px 30px rgba(2,8,20,.06);overflow:hidden}
.card__media{aspect-ratio:16/9;background:#e5e7eb}
.card__body{padding:18px}
.pill{display:inline-block;padding:6px 10px;border-radius:999px;background:#eef2ff;color:#3730a3;font-weight:700}
.card__kpis{display:flex;gap:14px;flex-wrap:wrap;margin:10px 0}
.card__actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.btn--light{background:#0f172a;color:#fff}
.btn--outline{background:transparent;border:1px solid #cbd5e1;color:#0f172a}
footer{padding:40px 0;border-top:1px solid #e5e7eb;color:#6b7280}

/* ================== Notice Carousel (avisos en el hero) ================== */
.notice-carousel{
  position:relative; z-index:1; margin-top:0;
  display:grid; justify-items:center; text-align:center; color:#fff;
}

/* --- Tamaño del carrusel (más pequeño) --- */
.nc-track{
  position:relative;
  width:min(100%, 1000px);           /* ancho del carrusel (antes 1180/1320) */
  min-height:220px;                 /* alto base sin imagen */
}
.nc-track:has(.nc-inner.has-media){
  min-height:500px;                 /* alto cuando el slide trae imagen (antes 500+) */
}

/* Slides */
.nc-slide{
  position:absolute; inset:0;
  opacity:0; transform:translateY(6px);
  transition:opacity .3s ease, transform .3s ease;
  display:grid; place-content:center; padding:0 16px;
}
.nc-slide.is-active{opacity:1; transform:none}

/* Caja de contenido centrada */
.nc-inner{
  display:grid; gap:12px; justify-items:center;
  padding:22px 24px; border-radius:20px;             /* menos padding */
  background:rgba(8,12,20,.40);
  -webkit-backdrop-filter:saturate(130%) blur(3px);
  backdrop-filter:saturate(130%) blur(3px);
  box-shadow:0 14px 32px rgba(0,0,0,.22);
}

/* Tipografías (más contenidas) */
.nc-title{margin:0 0 6px; font-weight:900; font-size:clamp(24px, 4vw, 38px)}
.nc-sub  {margin:0 0 4px; font-style:italic; font-size:clamp(15px, 2vw, 19px); line-height:1.5}
.nc-foot {margin:6px 0 0; font-size:clamp(14px, 1.8vw, 18px); opacity:.95}
.nc-cta  {margin-top:12px; padding:12px 18px; font-weight:800}

/* Flechas (más chicas) */
.nc-prev, .nc-next{
  position:absolute; top:50%; transform:translateY(-50%);
  width:36px; height:36px; border-radius:999px;
  border:1px solid rgba(255,255,255,.5);
  background:rgba(0,0,0,.25);
  color:#fff; font-size:20px; display:grid; place-items:center;
  cursor:pointer; user-select:none;
}
.nc-prev{left:10px} .nc-next{right:10px}
.nc-prev:hover, .nc-next:hover{background:rgba(0,0,0,.35)}

/* Dots */
.nc-dots{display:flex; gap:10px; justify-content:center; margin-top:12px}
.nc-dot{width:10px; height:10px; border-radius:999px; background:#fff; opacity:.45; border:none; cursor:pointer}
.nc-dot.is-active{opacity:1}

/* ===== Imagen opcional en el slide ===== */
.nc-inner.has-media{ gap:14px; }
@media (min-width:980px){
  .nc-inner.has-media{
    grid-template-columns:1fr;      /* una sola columna: centrado */
    align-items:center; justify-items:center;
  }
}

/* Tarjeta de imagen (más pequeña y centrada) */
.nc-media { 
  position: relative;
  aspect-ratio: 16 / 9;
  border-radius: 16px;
  overflow: hidden;
  background: #0b0b0b; /* color de “letterbox” si sobra espacio */
}
@media (max-width: 640px){
  .nc-media { aspect-ratio: 4 / 3; }
}
.nc-media img{
  width: 100%;
  height: 100%;
  display: block;
  object-position: center; /* Puedes ajustar: top, 50% 30%, etc. */
}
.nc-media::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(to top, rgba(0,0,0,.4), rgba(0,0,0,0) 40%);
  pointer-events:none;
}
/* Modo recorte (default) */
.nc-media.is-cover img { object-fit: cover; }

/* Modo ver-entera (sin recorte) */
.nc-media.is-contain img { object-fit: contain; background: #0b0b0b; }

/* Botón dentro de la imagen (más contenido) */
.nc-media__cta{
  position:absolute; right:14px; bottom:14px;
  padding:10px 16px; border-radius:999px;
  background:linear-gradient(90deg,var(--brand),var(--brand2));
  color:#00122a; font-weight:800; box-shadow:var(--shadow);
  transition:transform .12s ease;
}
.nc-media__cta:active{ transform:scale(.98) }

/* Badge PRONTO */
.nc-badge{
  position: absolute;
  bottom: 16px;     /* 📍 lo baja hacia la parte inferior */
  right: 18px;      /* 📍 lo mueve a la derecha */
  background:#f59e0b; color:#0b1220; box-shadow:0 6px 18px rgba(0,0,0,.25);
  color: #fff;
  font-weight: 700;
  font-size: 18px;
  padding: 8px 14px;
  border-radius: 8px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* ================== Responsivo ================== */
@media (max-width:1200px){ .brand .logo{height:44px} }
@media (max-width:980px){
  .brand .logo{height:36px}
  .nc-track{min-height:220px}
  .nc-inner{padding:18px 14px; border-radius:18px}
  .nc-media{max-width:100%; aspect-ratio:4/3}
  .nc-prev, .nc-next{width:34px; height:34px; font-size:18px}
}

/* ================== Páginas sin hero ================== */
body.no-hero main{ padding-top:var(--navh); }

/* --- Fix de clic: asegurar capas correctas --- */
.nc-inner{ position: relative; z-index: 2; }  /* contenido del slide por encima del fondo */
.nc-media{ position: relative; }              /* crea stacking context para hijos */

.nc-media img{
  position: relative;
  z-index: 0;                                 /* imagen al fondo */
}

.nc-media::after{
  position: absolute;
  z-index: 1;                                 /* degradado sobre la imagen */
  inset: 0;
  pointer-events: none;                       /* NO bloquea clicks */
}

.nc-media__cta{
  position: absolute;
  right: 14px; bottom: 14px;
  z-index: 2;                                 /* botón POR ENCIMA de todo */
  pointer-events: auto;
  cursor: pointer;
}


/* ===== Ondas en el borde inferior del hero ===== */
.hero{ position: relative; }
.hero-wave{
  position: absolute;
  left: 0; right: 0; bottom: -1px;
  height: 140px;
  pointer-events: none;
  z-index: 2; /* por encima del overlay oscuro del hero */
  filter: drop-shadow(0 -6px 18px rgba(0,0,0,.12));
}

/* 3 capas (colores pastel) */
.hero-wave,
.hero-wave::before,
.hero-wave::after{
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 140px;
  background-repeat: no-repeat;
  background-position: bottom center;
  background-size: 100% 100%;
}

/* capa 1 */
.hero-wave{
  background-image: url("data:image/svg+xml;utf8,\
<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 120' preserveAspectRatio='none'>\
<path d='M0,64 C240,120 480,0 720,48 C960,96 1200,32 1440,80 L1440,120 L0,120 Z' fill='%23E4F6FF'/>\
</svg>");
}

/* capa 2 (ligeramente desplazada) */
.hero-wave::before{
  transform: translateY(10px) scaleY(1.04);
  background-image: url("data:image/svg+xml;utf8,\
<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 120' preserveAspectRatio='none'>\
<path d='M0,70 C240,110 480,20 720,60 C960,100 1200,40 1440,90 L1440,120 L0,120 Z' fill='%23EFE4FF'/>\
</svg>");
  opacity: .95;
}

/* capa 3 (verde menta) */
.hero-wave::after{
  transform: translateY(20px) scaleY(1.06);
  background-image: url("data:image/svg+xml;utf8,\
<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 120' preserveAspectRatio='none'>\
<path d='M0,76 C240,120 480,28 720,68 C960,108 1200,54 1440,100 L1440,120 L0,120 Z' fill='%23FFF0F4'/>\
</svg>");
  opacity: .95;
}

/* Asegura que el carrusel quede por encima de las ondas */
.notice-carousel{ position: relative; z-index: 3; }






/* Fondo general (Paleta 1) */
body{
  background:
    radial-gradient(1200px 700px at 8% -10%,  #E4F6FF 0%, rgba(228,246,255,0) 60%),
    radial-gradient(1000px 600px at 108% 0%, #EFE4FF 0%, rgba(239,228,255,0) 55%),
    radial-gradient(800px 500px at 80% 100%, #E6FFF6 0%, rgba(230,255,246,0) 55%),
    #F7F9FC; /* base clara */
}

/* Puntitos muy sutiles */
body::before{
  content:"";
  position:fixed; inset:-10%;
  z-index:-1; pointer-events:none;
  background-image:
    radial-gradient(rgba(0,181,255,.08) 1px, transparent 1px),
    radial-gradient(rgba(106,0,255,.08) 1px, transparent 1px);
  background-size:26px 26px, 36px 36px;
  background-position:0 0, 10px 8px;
}






/* Fondo decorativo INTENSO solo para la sección Sucursales */
#sucursales{
  position: relative;
  z-index: 0;
  background: transparent;
}

/* blobs más saturados y grandes */
#sucursales::before{
  content:"";
  position:absolute;
  inset:-72px -32px -40px -32px;  /* halo alrededor de la sección */
  border-radius:36px;
  z-index:-1;
  pointer-events:none;
  background:
    /* azul aqua (izquierda/arriba) */
    radial-gradient(900px 320px at 18% -4%,
      #BFE9FF 0%, rgba(191,233,255,.90) 35%, transparent 70%),
    /* lila (derecha/arriba) */
    radial-gradient(900px 320px at 82% -4%,
      #DEC8FF 0%, rgba(222,200,255,.90) 35%, transparent 70%),
    /* menta (abajo/centro) */
    radial-gradient(1200px 480px at 50% 104%,
      #CFFCEB 0%, rgba(207,252,235,.92) 28%, transparent 78%);
  filter: saturate(110%);
  box-shadow:
    inset 0 18px 40px rgba(11,18,32,.06),
    0 8px 26px rgba(11,18,32,.05);
}



/* Subrayado animado (hover + activo) */
.nav__links a{
  position:relative;
  display:inline-block;
  padding:10px 0;
}
.nav__links a::after{
  content:"";
  position:absolute; left:0; right:0; bottom:-4px;
  height:3px; border-radius:3px;
  background:currentColor;           /* usa el color del texto */
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .18s ease;
  opacity:.9;
}
.nav__links a:hover::after,
.nav__links a.is-active::after{ transform:scaleX(1); }

/* Scroll suave + compensación por header fijo */
html{ scroll-behavior:smooth; }
section[id]{ scroll-margin-top: calc(var(--navh) + 8px); }

/* --- Subrayado animado del menú (robusto) --- */
header.site-header,
header.site-header .nav { overflow: visible; }

header.site-header .nav__links a{
  position: relative;
  display: inline-flex;
  align-items: center;
  padding: 12px 0;                 /* da espacio al subrayado */
}

header.site-header .nav__links a::after{
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -6px; /* que no quede pegado al texto */
  height: 3px;
  border-radius: 3px;
  background: #FF6B6B;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .18s ease;
  pointer-events: none;
  z-index: 5;                      /* por encima de todo en el header */
  opacity: .95;
}

/* hover y activo */
header.site-header .nav__links a:hover::after,
header.site-header .nav__links a.is-active::after{
  transform: scaleX(1);
}

/* Fallback (si algún navegador no respeta ::after): simula subrayado con inset box-shadow */
header.site-header .nav__links a:hover{
  box-shadow: inset 0 -3px 0 0 currentColor;
}

/* Centrar el menú en desktop, dejando el logo a la izquierda */
@media (min-width: 1024px){
  .nav{
    position: relative;
    justify-content: flex-start;        /* logo alineado a la izquierda */
  }
  .nav__links{
    position: absolute;                 /* centrado real respecto al header */
    left: 50%;
    transform: translateX(-50%);
    margin-left: 0 !important;          /* anula margen que pusimos antes */
  }
}


/* ===== Footer grande ===== */
.site-footer{ background:#0f172a; color:#e5e7eb; margin-top:60px }
.site-footer .container{ max-width:var(--maxw); }

.footer__grid{
  display:grid; gap:28px; padding:48px 0 36px;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
}
@media (max-width: 980px){
  .footer__grid{ grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px){
  .footer__grid{ grid-template-columns: 1fr; }
}

.f-logo img{ height:30px; width:auto; display:block; filter:brightness(1.1); }
.f-tag{ color:#cbd5e1; margin:10px 0 14px; }

.f-address{ margin:10px 0; }
.f-address strong{ display:block; color:#fff; }
.f-address p{ margin:2px 0; color:#cbd5e1; }

.f-social{ display:flex; gap:10px; margin-top:10px; }
.f-social a{
  width:36px; height:36px; border-radius:999px; display:grid; place-items:center;
  background:rgba(255,255,255,.06); color:#e5e7eb; border:1px solid rgba(255,255,255,.08);
}
.f-social a:hover{ background:rgba(255,255,255,.12); }

.f-col h4{ margin:0 0 10px; color:#fff; font-size:16px; letter-spacing:.02em }
.f-col ul{ list-style:none; margin:0; padding:0; display:grid; gap:6px }
.f-col a{ color:#cbd5e1 }
.f-col a:hover{ color:#fff; text-decoration:underline }

.footer__bar{ border-top:1px solid #1f2937; background:#0b1220; }
.bar__inner{
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:12px 0;
}
.bar__inner small{ color:#94a3b8 }
.bar__links{ display:flex; gap:16px }
.bar__links a{ color:#a1a1aa }
.bar__links a:hover{ color:#fff; text-decoration:underline }

/* ===== Botón flotante volver arriba ===== */
.backtop{
  position: fixed; right: 18px; bottom: 18px;
  width: 44px; height: 44px; border: none; border-radius: 999px;
  background: linear-gradient(90deg, var(--brand), var(--brand2));
  color: #00122a; font-weight: 900; font-size: 20px;
  box-shadow: 0 10px 24px rgba(2,8,20,.25);
  cursor: pointer; opacity: 0; transform: translateY(8px) scale(.9);
  transition: opacity .18s ease, transform .18s ease, box-shadow .18s ease;
  z-index: 60;
}
.backtop:hover{ box-shadow: 0 14px 28px rgba(2,8,20,.28) }
.backtop.show{ opacity: 1; transform: none; }

/* El scroll suave ya lo tienes, pero por si acaso: */
html{ scroll-behavior: smooth; }


/* ===== Opiniones / Reseñas ===== */
#opiniones .rating-head{
  display:flex; align-items:center; gap:12px; margin:6px 0 16px;
}
#opiniones .stars .star{ font-size:20px; color:#d1d5db; line-height:1; }
#opiniones .stars .star.is-full{ color:#f59e0b; } /* estrella llena */
#opiniones .rating-text{ color:#6b7280; font-weight:600 }

.reviews-grid{
  display:grid; gap:18px;
  grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 980px){ .reviews-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px){ .reviews-grid{ grid-template-columns: 1fr; } }

.review{
  background:#fff; color:#0f172a; border:1px solid #e5e7eb;
  border-radius:16px; padding:16px; box-shadow:0 10px 24px rgba(2,8,20,.06);
}
.review__head{ display:flex; align-items:baseline; gap:8px; margin-bottom:6px; }
.review__head strong{ font-weight:800 }
.review__date{ color:#9ca3af }
.review__stars .star{ font-size:16px; color:#d1d5db }
.review__stars .star.is-full{ color:#f59e0b }
.review__text{ margin:8px 0 10px }
.review__source{ color:#6366f1; font-weight:700 }
.review__source:hover{ text-decoration:underline }

.review__cta{ margin-top:14px; }






/* ===== Página de sucursal ===== */
.branch-hero{position:relative;min-height:52vh;display:grid;align-items:end;overflow:hidden}
.branch-hero__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.8)}
.branch-hero__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.1),rgba(0,0,0,.55))}
.branch-hero__content{position:relative;padding:40px 20px 28px;color:#fff}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0}
.chip{background:rgba(255,255,255,.85);color:#111827;font-weight:700;padding:6px 10px;border-radius:999px}
.chip--soon{background:#fde68a}
.cta-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.grid-branch{display:grid;grid-template-columns:320px 1fr;gap:22px}
@media (max-width:900px){.grid-branch{grid-template-columns:1fr}}
.p{padding:18px}
.list{margin:0;padding-left:20px}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.gallery img{border-radius:14px;aspect-ratio:4/3;object-fit:cover}
.map-embed{border:1px solid #e5e7eb;border-radius:18px;overflow:hidden}
.map-embed iframe{width:100%;height:360px;border:0}
/* Badge PRONTO en cards */
.badge-soon{position:absolute;right:16px;bottom:10px;background:rgba(0,0,0,.6);color:#fff;font-weight:900;padding:6px 10px;border-radius:999px}


/* === Nosotros (sección hero moderna) === */
.about-hero{
  position: relative;
  background: linear-gradient(145deg, #00c7a9 0%, #0099ff 60%, #70e0cf 100%);
  padding: 80px 0 100px;
  color: #111;
}

.about-grid{
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 40px;
  align-items: center;
}

.about-card{
  background: #fff;
  border-radius: 24px;
  padding: 40px 36px;
  box-shadow: 0 14px 45px rgba(0,0,0,.12);
}

.about-card h2{
  font-size: clamp(32px, 4vw, 46px);
  margin-bottom: 18px;
  line-height: 1.1;
}

.about-text{
  font-size: clamp(18px, 2vw, 22px);
  color: #00a36c;
  line-height: 1.6;
}

.about-text strong{
  color: #008060;
}

.about-media{
  margin: 0;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 18px 50px rgba(0,0,0,.2);
  transform: translateY(8px);
}

.about-media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  max-height: 520px;
}

/* Fondo decorativo inferior */
.about-wave{
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 100px;
  background: radial-gradient(140px 60px at 15% 20px, rgba(255,255,255,.25), transparent 60%),
              radial-gradient(140px 60px at 45% 40px, rgba(255,255,255,.22), transparent 60%),
              radial-gradient(140px 60px at 75% 25px, rgba(255,255,255,.20), transparent 60%);
  pointer-events: none;
}

/* Responsive */
@media (max-width: 980px){
  .about-grid{
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .about-media{
    order: -1;
    max-height: 360px;
  }
}

.back-btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 14px;
  background:#0f172a;            /* gris/negro elegante */
  color:#fff; border-radius:999px;
  font-weight:600; text-decoration:none;
  box-shadow:0 6px 18px rgba(0,0,0,.15);
}
.back-btn:hover{ background:#111827; }

/* === FAB WhatsApp para páginas de sucursales === */
.fab-wsp{
  position: fixed;
  right: 70px;
  bottom: 22px;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  z-index: 1050; /* por encima del mapa */
  filter: drop-shadow(0 10px 24px rgba(0,0,0,.22));
}

.fab-icon{
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: #25D366;               /* verde WhatsApp */
  display: grid;
  place-items: center;
  transition: transform .15s ease;
}

.fab-label{
  background: #25D366;
  color: #fff;
  font-weight: 700;
  padding: 10px 18px;
  border-radius: 14px;
  white-space: nowrap;
  box-shadow: 0 10px 20px rgba(37,211,102,.35);
}

.fab-wsp:hover .fab-icon{ transform: scale(1.05); }
.fab-wsp:hover .fab-label{ filter: brightness(1.05); }

/* En móvil mostramos solo el círculo para no tapar contenido */
@media (max-width: 720px){
  .fab-label{ display: none; }
  .fab-icon{ width: 56px; height: 56px; }
}

/* === Equipo (estilo de tarjetas como imagen) === */
.team-title{ text-align:center; font-size:clamp(28px,4vw,42px); margin-bottom:18px; }
.team-carousel{ display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:24px; }

.pro-card{
  background:#fff; border-radius:18px; box-shadow:0 10px 30px rgba(0,0,0,.12);
  padding:16px 16px 18px; display:flex; flex-direction:column; align-items:center;
}

.pro-photo{
  width:340px; max-width:100%; aspect-ratio:1/1; border-radius:50%; overflow:hidden;
  padding:12px; background:radial-gradient(120% 120% at 50% 40%, rgba(0,200,255,.25), rgba(0,0,0,0) 60%);
  box-shadow:0 8px 24px rgba(0,0,0,.18); border:0; cursor:pointer;
}
.pro-photo img{ width:100%; height:100%; object-fit:cover; border-radius:50%; display:block; }

.pro-body{ text-align:center; margin-top:12px; }
.pro-name{ font-size:22px; margin:2px 0 4px; }
.pro-role{ color:#778; font-style:italic; margin:0 0 8px; }

.pro-social{ display:flex; gap:14px; justify-content:center; }
.pro-ico{ width:38px; height:38px; display:grid; place-items:center; border-radius:50%; background:#eef2f7; color:#111; }
.pro-ico.ig{ color:#E1306C; } .pro-ico.in{ color:#0A66C2; } .pro-ico.wa{ color:#25D366; }
.pro-ico:hover{ filter:brightness(.95); box-shadow:0 6px 16px rgba(0,0,0,.12); }

/* Modal dialog */
.pro-modal{ border:none; border-radius:16px; padding:0; width:min(860px,92vw); box-shadow:0 30px 80px rgba(0,0,0,.35); }
.pro-modal::backdrop{ background:rgba(15,23,42,.55); }
.pro-close{ position:absolute; top:8px; right:12px; border:0; background:transparent; font-size:28px; line-height:1; cursor:pointer; color:#444; }
.pro-modal__content{ display:grid; grid-template-columns:280px 1fr; gap:18px; padding:18px; }
.pro-modal__photo{ width:100%; border-radius:12px; object-fit:cover; aspect-ratio:3/4; }
.pro-modal__text h3{ margin:6px 0 2px; font-size:26px; }
.pro-bio p{ margin:6px 0; color:#2e333a; }

@media (max-width:760px){ .pro-modal__content{ grid-template-columns:1fr; } }

/* === Galería estilo Masonry (irregular) === */
.gallery-grid {
  column-count: 3; /* número de columnas */
  column-gap: 1rem;
  orphans: 1;
  widows: 1;
  padding: 1rem 0;
}

.gallery-grid img {
  width: 100%;
  border-radius: 12px;
  margin-bottom: 1rem;
  break-inside: avoid;
  box-shadow: 0 2px 10px rgba(0,0,0,.1);
  object-fit: cover;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.gallery-grid img:hover {
  transform: scale(1.03);
  box-shadow: 0 6px 18px rgba(0,0,0,.15);
}

/* Responsive */
@media (max-width: 992px) {
  .gallery-grid {
    column-count: 2;
  }
}

@media (max-width: 600px) {
  .gallery-grid {
    column-count: 1;
  }
}


/* === Lightbox minimal sin librerías === */
.lb{
  position: fixed; inset: 0;
  background: rgba(0,0,0,.9);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 9999;
}
.lb.is-open{ display:flex; }

.lb__stage{
  max-width: min(92vw, 1280px);
  max-height: 86vh;
  margin: 0 56px;
  text-align: center;
}
.lb__stage img{
  max-width: 100%;
  max-height: 80vh;
  object-fit: contain;
  border-radius: 8px;
  box-shadow: 0 10px 40px rgba(0,0,0,.6);
}
.lb__stage figcaption{
  color: #fff;
  font-size: .95rem;
  opacity: .85;
  margin-top: 10px;
}

.lb__close{
  position: absolute; top: 16px; right: 20px;
  font-size: 38px; line-height: 1;
  background: transparent; color: #fff; border: 0; cursor: pointer;
  opacity: .9; transition: opacity .2s ease;
}
.lb__close:hover{ opacity: 1; }

.lb__nav{
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 46px; height: 46px; border-radius: 50%;
  border: 0; color: #fff; background: rgba(255,255,255,.15);
  backdrop-filter: blur(2px);
  cursor: pointer; font-size: 30px; line-height: 46px;
  display: grid; place-items: center;
  transition: background .2s ease;
}
.lb__nav:hover{ background: rgba(255,255,255,.25); }
.lb__prev{ left: 12px; }
.lb__next{ right: 12px; }

/* Mejoras touch / responsivo */
@media (max-width: 640px){
  .lb__stage{ margin: 0 44px; }
  .lb__nav{ width: 40px; height: 40px; font-size: 26px; }
  .lb__close{ font-size: 32px; right: 14px; }
}

/* ===== Evaluaciones (estilo tipo imagen 1) ===== */
.t-section { margin-top: 40px; margin-bottom: 24px; }
.t-title { font-size: clamp(28px, 3.4vw, 40px); margin: 0 0 18px; }

.t-rating-head{
  display: flex; align-items: center; gap: 16px;
  font-size: 18px; margin-bottom: 14px;
}
.t-rating{ display:flex; align-items:center; gap:12px; }
.t-score{ font-weight: 800; font-size: 32px; }
.t-stars .t-star{ color:#E2E8F0; font-size: 20px; }
.t-stars .t-star.is-full{ color:#f7b500; }

.t-summary{ color:#4a5568; }

.t-note{
  display:flex; align-items:center; gap:12px;
  background:#F7FAFC; border:1px solid #EDF2F7;
  padding:14px 16px; border-radius:14px; margin: 12px 0 22px;
  color:#2D3748;
}
.t-lock{ font-size: 18px; }

.t-cards{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
@media (max-width: 1100px){
  .t-cards{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 650px){
  .t-cards{ grid-template-columns: 1fr; }
}

.t-card{
  background:#fff;
  border:1px solid #E6ECF3;
  border-radius:18px;
  padding:22px 22px 18px;
  box-shadow: 0 2px 10px rgba(17,24,39,.04);
}
.t-card__head{
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  margin-bottom: 8px;
}
.t-card__name{ font-size: clamp(18px, 2.2vw, 22px); margin:0; }
.t-card__stars .t-star{ color:#E2E8F0; font-size: 18px; }
.t-card__stars .t-star.is-full{ color:#f7b500; }

.t-card__meta{
  color:#4A5568; font-size: 14px; margin-bottom: 12px;
}
.t-card__text{
  color:#1A202C; line-height: 1.6; margin: 0 0 8px;
}
.t-card__source{
  display:inline-block; color:#3b82f6; font-weight:600; font-size: 14px;
  text-decoration:none;
}

.t-pager{
  display:flex; align-items:center; justify-content:center; gap: 14px;
  margin: 18px 0 6px;
}
.t-nav{
  width:40px; height:40px; border-radius:12px; border:1px solid #E6ECF3; background:#fff;
  display:grid; place-items:center; font-size:22px; cursor:pointer;
  transition: background .2s ease, transform .04s ease;
}
.t-nav:hover{ background:#F7FAFC; }
.t-nav:active{ transform: scale(.98); }
.t-page{ color:#2D3748; font-weight: 500; }

.t-cta{ display:flex; justify-content:flex-start; margin-top: 12px; }
.t-btn{
  display:inline-block; padding:12px 18px; border-radius:14px;
  color:#fff; font-weight:700; text-decoration:none;
  background: linear-gradient(135deg, #4f46e5, #06b6d4);
  box-shadow: 0 6px 20px rgba(79,70,229,.25);
  transition: transform .06s ease, box-shadow .2s ease;
}
.t-btn:hover{ box-shadow:0 10px 26px rgba(79,70,229,.3); }
.t-btn:active{ transform: translateY(1px); }


/* --- Testimonios --- */
#testimonios .pretty-rating {
  display:flex; align-items:center; gap:12px; margin:12px 0 16px;
}
#testimonios .rating-number {
  font-size:2rem; font-weight:800; color:#111827;
}
#testimonios .rating-txt { color:#6b7280; }
#testimonios .stars .star { color:#e5e7eb; font-size:20px; }
#testimonios .stars .star.is-full { color:#f59e0b; }

#testimonios .reviews-grid {
  display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:18px;
}
@media (max-width: 980px) {
  #testimonios .reviews-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
}
@media (max-width: 620px) {
  #testimonios .reviews-grid { grid-template-columns:1fr; }
}

#testimonios .card {
  border-radius:16px; background:#fff; box-shadow:0 6px 24px rgba(0,0,0,.06); padding:16px 18px;
}
#testimonios .review__head {
  display:flex; align-items:baseline; justify-content:space-between; gap:8px; margin-bottom:6px;
}
#testimonios .review__head strong { font-weight:700; color:#111827; }
#testimonios .review__date { color:#9ca3af; }
#testimonios .review__stars .star { color:#e5e7eb; }
#testimonios .review__stars .star.is-full { color:#f59e0b; }
#testimonios .review__for { color:#6b7280; margin:2px 0 8px; }
#testimonios .review__text { color:#374151; line-height:1.5; }

#testimonios .reviews-pager {
  display:flex; align-items:center; justify-content:center; gap:10px; margin-top:16px;
}
#testimonios .reviews-pager .pill {
  min-width:34px; height:34px; border-radius:9999px; border:1px solid #e5e7eb; background:#fff;
  display:inline-flex; align-items:center; justify-content:center; cursor:pointer;
}
#testimonios .reviews-pager .pill:disabled { opacity:.4; cursor:not-allowed; }

#testimonios .btn-grad {
  display:inline-block; padding:12px 18px; border-radius:10px;
  background:linear-gradient(90deg,#6366f1,#22d3ee); color:#fff; font-weight:700;
  box-shadow:0 8px 20px rgba(99,102,241,.25);
}
