
/* Importa Montserrat arriba de todo tu CSS si aún no está */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@600;700&display=swap');
/* Paleta */
:root{
  --turquesa:#49C6C2;
  --aqua:#A8D5BA;
  --azul:#41C0F4;
  --beige:#F6EBD9;
  --gris:#E6E6E6;
  --texto:#1F2937;
  --white:#fff;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,'Helvetica Neue',Arial,sans-serif;color:var(--texto);scroll-behavior:smooth}
img{max-width:100%;display:block}

/* Topbar: fija con Instagram centrado */
.topbar{position:fixed;top:0;left:0;right:0;height:56px;background:var(--turquesa);z-index:1000;box-shadow:0 1px 8px rgba(0,0,0,.08);display:flex;align-items:center;justify-content:center}
.topbar--ig .center-ig{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:999px;background:rgba(255,255,255,.15);backdrop-filter:saturate(140%);}
.social{color:var(--white);font-size:22px;display:inline-flex;align-items:center;gap:8px}

/* Segunda barra (no fija): logo izq + hamburguesa der */
.subheader{position:relative;top:56px;background:var(--white);z-index:900;border-bottom:1px solid #eee}
.subheader .container{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:10px 16px}
.brand{display:flex;align-items:center;gap:12px}
.brand-logo{height:44px}
.brand-text h1{font-size:20px;margin:0 0 2px;font-weight:800}
.brand-text p{margin:0;font-size:13px;color:#555}

/* Hamburguesa decorada (también en escritorio) */
.hamburger.deco{background:var(--white);border:1px solid var(--gris);border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:5px;padding:10px 12px;transition:box-shadow .2s, transform .15s}
.hamburger.deco:hover{box-shadow:0 6px 18px rgba(0,0,0,.08)}
.hamburger.deco:active{transform:scale(.98)}
.hamburger.deco span{display:block;width:26px;height:3px;background:var(--turquesa);border-radius:3px;transition:transform .25s, opacity .25s}
.hamburger.deco.is-open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.hamburger.deco.is-open span:nth-child(2){opacity:0}
.hamburger.deco.is-open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* Panel del menú desplegable (corregido para quedar arriba) */
.mobile-menu.panel{
  position:fixed;
  top:56px;
  right:16px;
  z-index:2000; /* <-- clave para que quede por encima del hero */
  background:#fff;
  border:1px solid #eee;
  border-radius:14px;
  padding:10px;
  width:min(92vw, 320px);
  box-shadow:0 14px 40px rgba(0,0,0,.12);
  display:flex;
  flex-direction:column;
  gap:6px;
  max-height:calc(100vh - 72px); /* evita que se corte en pantallas pequeñas */
  overflow:auto;
}
.mobile-menu.panel a{padding:12px 10px;border-radius:10px;text-decoration:none;color:#1F2937;font-weight:600}
.mobile-menu.panel a:hover{background:var(--beige)}
.mobile-menu.panel a.btn{background:var(--azul);color:#fff;text-align:center}
.mobile-menu[hidden]{display:none !important}

/* Evitar que el hero tape el panel del menú */
.hero, .carousel, .carousel .slides, .carousel .slide, .hero-overlay{
  position:relative;
  z-index:0;
}

/* Bloquear scroll del fondo cuando el menú está abierto */
body.no-scroll{ overflow:hidden; }

/* Hero Carousel */
.hero{position:relative;margin-top:56px} /* margen por topbar */
.carousel{position:relative;overflow:hidden}
.carousel .slides{display:flex;transition:transform .5s ease;will-change:transform}
.carousel .slide{min-width:100%;height:56vh;position:relative}
.carousel .slide img{width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;background:linear-gradient( to bottom, rgba(0,0,0,.15), rgba(0,0,0,.35) );color:#fff;padding:0 16px}
.hero-overlay h2{font-size:clamp(22px,4vw,36px);margin:0 0 14px}
.btn{display:inline-block;padding:10px 16px;border-radius:12px;text-decoration:none;font-weight:700}
.btn-primary{background:var(--turquesa);color:#fff}

/* Controles carrusel (ajustados con transparencia elegante) */
.ctrl{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:40px; height:40px; border-radius:50%;
  display:grid; place-items:center; cursor:pointer;
  background:transparent;           /* antes: rgba(255,255,255,.85) */
  color:rgba(255,255,255,.1);       /* blanco 40% */
  border:0;
  transition:color .3s ease;
}
.ctrl.prev{left:10px}
.ctrl.next{right:10px}
.ctrl:hover{ color:rgba(255,255,255,.9); } /* al pasar mouse, casi blanco */
.ctrl i{ font-size:2rem; }                  /* tamaño del icono */

/* Dots (sin cambios) */
.dots{position:absolute;left:0;right:0;bottom:10px;display:flex;gap:8px;justify-content:center}
.dot{width:10px;height:10px;border-radius:50%;border:2px solid #fff;background:transparent;opacity:.8;cursor:pointer}
.dot.is-active{background:#fff}

/* Secciones */
.section{padding:56px 0}
.section.alt{background:var(--beige)}
.container{max-width:1100px;margin:0 auto;padding:0 16px}
h3{font-size:26px;margin:0 0 18px}

/* ---- Tarjetas (layout base) ---- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}
.card{background:#fff;border:1px solid #eee;border-radius:16px;padding:18px;box-shadow:0 6px 16px rgba(0,0,0,.04)}
.card h4{margin:0 0 8px}

/* Contacto */
.contact-list{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.contact-list i{margin-right:8px;color:var(--azul)}

/* Barra inferior fija (auto-ocultar) */
.bottombar{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #eee;display:flex;justify-content:space-around;gap:8px;padding:10px 8px;z-index:1000;transition:transform .5s ease}
.bottombar a{flex:1;text-decoration:none;color:#111;display:flex;flex-direction:column;align-items:center;font-size:12px;font-weight:700}
.bottombar i{font-size:18px;margin-bottom:4px;color:var(--turquesa)}
.bottombar.hide{transform:translateY(110%)}

/* Espacios para que el contenido no quede escondido */
body{padding-top:56px}
.content{padding-bottom:64px}

/* Ajuste de altura y foco del carrusel en escritorio (evita cortes de rostro) */
@media (min-width: 900px){
  .carousel .slide{ height: 70vh; }           /* más alto en desktop */
  .carousel .slide img{ object-position: 50% 18%; } /* sube el encuadre */
}

/* Sección Nuestro equipo (texto izq + imagen der) */
.equipo-content{display:flex;flex-direction:column;align-items:center;gap:24px}
.equipo-texto{flex:1}
.equipo-texto h3{font-size:28px;margin-bottom:14px}
.equipo-texto p{font-size:16px;line-height:1.65}
.equipo-imagen{flex:1;width:100%}
.equipo-imagen img{width:100%;border-radius:16px;box-shadow:0 6px 18px rgba(0,0,0,.1);display:block}
@media(min-width:900px){
  .equipo-content{flex-direction:row;align-items:center}
  .equipo-texto{padding-right:28px}
}

/* Ajustes de foco por slide del carrusel */
.carousel .slide:first-child img { object-position: 50% 40%; }
.carousel .slide:nth-child(2) img { object-position: 50% 32%; }
.carousel .slide:nth-child(3) img { object-position: 50% 10%; }

/* Botón Volver Arriba */
#btnVolverArriba{
  display:none; position:fixed; bottom:40px; right:40px; z-index:9999;
  font-size:20px; background-color:#49C6C2; color:#fff; border:none;
  padding:12px 16px; border-radius:50%; cursor:pointer;
  box-shadow:0 4px 8px rgba(0,0,0,0.2); transition:opacity .3s, transform .3s;
}
#btnVolverArriba:hover{ background-color:#41C0F4; transform:scale(1.1) }

/* Siempre hamburguesa (también en desktop) */
@media(min-width:900px){ .hamburger{display:flex} }

/* --- Tarjetas bonitas para Servicios --- */
.cards-pretty{ gap:22px }
.card.pretty{
  position:relative; overflow:hidden; border-radius:18px;
  border:1px solid rgba(255,255,255,.6);
  background:linear-gradient(180deg,rgba(255,255,255,.85),rgba(255,255,255,.9));
  box-shadow:0 12px 28px rgba(0,0,0,.06);
  transition:transform .25s ease, box-shadow .25s ease;
  backdrop-filter:saturate(130%) blur(2px);
}
.card.pretty:hover{ transform:translateY(-4px); box-shadow:0 16px 36px rgba(0,0,0,.10) }

.card-media{ position:relative; overflow:hidden; border-radius:16px; margin:12px 12px 0; height:180px }
.card-media img{ width:100%; height:100%; object-fit:cover; transform:scale(1.02); transition:transform .5s ease }
.card.pretty:hover .card-media img{ transform:scale(1.06) }

.badge{
  position:absolute; left:12px; top:12px;
  font-size:12px; font-weight:700; color:#04363d;
  background:rgba(255,255,255,.9); padding:6px 10px; border-radius:999px;
  border:1px solid rgba(0,0,0,.05);
}

.card-body{ padding:16px 16px 18px }
.card-body h4{ margin:10px 0 6px; font-size:20px }
.card-body p{ margin:0 0 12px; color:#384555; line-height:1.55 }

/* Botón estilo píldora */
.card-cta{
  display:inline-block; font-weight:700; text-decoration:none;
  padding:12px 18px; border-radius:9999px; border:0;
  background:#fff; box-shadow:0 6px 16px rgba(0,0,0,.08);
  transition:background .2s ease, transform .2s ease;
}
.card-cta:hover{ background:var(--beige); transform:translateY(-1px) }
.card-cta:focus{ outline:2px solid var(--azul); outline-offset:3px }

/* Variantes de color (degradado más visible y con prioridad) */
.pretty--turquesa{
  background: linear-gradient(180deg, rgba(73,198,194,.25), rgba(73,198,194,.08)) !important;
}
.pretty--aqua{
  background: linear-gradient(180deg, rgba(168,213,186,.25), rgba(168,213,186,.08)) !important;
}
.pretty--azul{
  background: linear-gradient(180deg, rgba(65,192,244,.25), rgba(65,192,244,.08)) !important;
}

/* --- Sección Campamento (flyer completo, sin recortes) --- */
#campamento .intro-text{
  margin-bottom:20px; color:#555; font-size:16px;
}

.cards-campamento{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:20px;
}

.camp-card{
  background:#fff; border-radius:16px; overflow:hidden;
  box-shadow:0 4px 16px rgba(0,0,0,.08);
  transition:transform .25s ease, box-shadow .25s ease;
}
.camp-card:hover{ transform:translateY(-4px); box-shadow:0 8px 20px rgba(0,0,0,.12) }

/* 🔹 Mostrar la imagen completa, respetando proporción 1545×2000 */
.camp-img{
  width:100%;
  max-width:1545px;     /* opcional: no exceder el tamaño original */
  margin:0 auto;        /* centrada dentro de la tarjeta */
  background:#f5f5f5;   /* color de fondo si quedan “bandas” */
}
.camp-img img{
  width:100%;
  height:auto;          /* mantiene proporción exacta */
  object-fit:contain;   /* si en el futuro fijas altura, no recorta */
  display:block;
}

.camp-body{ padding:16px }
.camp-body h4{ font-size:18px; margin:0 0 8px }
.camp-body p{ font-size:14px; color:#555; margin:0 0 12px }

.estado{
  display:inline-block; padding:6px 10px; font-size:12px;
  border-radius:999px; color:#fff;
}
.realizado .estado{ background:#4CAF50 }  /* Verde para realizados */
.proximo .estado{   background:#F4A261 }  /* Naranja para próximos */

/* Responsive */
@media (min-width:900px){ .card-media{ height:200px } }
@media (min-width:1200px){ .card-media{ height:220px } }

/* === Estilos sección Artículos recientes === */
section.articulos-recientes .ar-grid {
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
}

section.articulos-recientes .ar-card {
  border: 1px solid var(--gris, #E6E6E6);
  border-radius: 14px;
  overflow: hidden;
  background: #fff;
  display: flex;
  flex-direction: column;
  box-shadow: 0 6px 16px rgba(0,0,0,.04);
}

section.articulos-recientes .ar-img img {
  width: 100%;
  aspect-ratio: 16/10;
  object-fit: cover;
  display: block;
}

section.articulos-recientes .ar-body {
  padding: 12px;
}

section.articulos-recientes .ar-title,
section.articulos-recientes .ar-title a {
  margin: 4px 0 6px;
  font-size: 1.1rem;
  font-family: 'Montserrat', Arial, sans-serif;
  font-weight: 700;
  color: var(--turquesa, #49C6C2);
  text-decoration: none;
}

section.articulos-recientes .ar-title a:hover {
  text-decoration: underline;
}

section.articulos-recientes .ar-meta {
  color: var(--texto, #1F2937);
  opacity: .7;
  font-size: .9rem;
  margin: 0 0 8px;
  font-family: 'Montserrat', Arial, sans-serif;
}

section.articulos-recientes .ar-excerpt {
  margin: 0;
  color: var(--texto, #1F2937);
  font-size: .95rem;
  line-height: 1.4;
}

section.articulos-recientes .ar-cta {
  margin-top: 10px;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

/* Botones de la sección */
section.articulos-recientes .btn {
  display: inline-block;
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid var(--gris, #E6E6E6);
  text-decoration: none;
  font-weight: 700;
  font-family: 'Montserrat', Arial, sans-serif;
}

section.articulos-recientes .btn-primary {
  background: var(--turquesa, #49C6C2);
  color: #fff;
  border-color: transparent;
}

section.articulos-recientes .btn-ghost {
  background: #E1306C;
  color: var(--texto, #1F2937);
  border: 1px solid var(--gris, #E6E6E6);
}

/* Responsivo */
@media (max-width:560px){
  section.articulos-recientes .ar-grid {
    grid-template-columns: 1fr;
  }
}
