/* ===== Google Fonts: Playfair Display (Regular) ===== */
@import url("https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400&display=swap");

/* ===== Reset y variables ===== */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
:root{
  --accent:#f4dda3;  /* color arena */
  --ink:#000;        /* negro principal */
  --muted:#6b6b6b;
  --bg:#ffffff; --white:#ffffff;
  --maxw:1100px; --radius:16px;   --header-h:64px; --footer-h:64px;
}
/* Century Gothic (si está instalada en el sistema) */
body{
  font-family:"Century Gothic","CenturyGothic","Avant Garde",Arial,Helvetica,sans-serif;
  color:var(--ink); background:var(--bg); line-height:1.55
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(100% - 10px,var(--maxw));margin-inline:auto}

/* ===== Header & nav ===== */
.site-header{background:var(--white);border-bottom:1px solid #ececec}
.topbar{display:flex;align-items:center;justify-content:space-between;height:var(--header-h)}
.brand{display:flex;align-items:center;gap:.75rem;font-weight:700}
.brand-logo{width:36px;height:36px;border-radius:8px;object-fit:cover}

/* Nombre del header con Playfair Display Regular */
.brand span{
  font-family:"Playfair Display", serif;
  font-weight:400;
  letter-spacing:.02em;
}

nav ul{list-style:none;display:flex;gap:1.25rem;padding:0;margin:0}
nav a{padding:.5rem .25rem;border-radius:10px}
nav a:hover,nav a:focus-visible{background:#f4f4f4;outline:none}

/* Hamburguesa */
.burger{background:transparent;border:0;width:40px;height:40px;display:grid;place-items:center;border-radius:10px}
.burger svg{width:24px;height:24px;stroke:var(--ink);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.burger:focus-visible{outline:2px solid var(--ink);outline-offset:2px}

/* Menú móvil */
.mobile-menu{position:fixed;inset:var(--header-h) 0 auto 0;background:var(--white);
  border-bottom:1px solid #ececec;transform:translateY(-8px);opacity:0;pointer-events:none;
  transition:transform .2s ease,opacity .2s ease}
.mobile-menu.open{transform:translateY(0);opacity:1;pointer-events:auto}
.mobile-menu[hidden]{display:none!important}
.mobile-menu ul{list-style:none;padding:8px 16px 12px;margin:0;display:grid;gap:6px}
.mobile-menu a{display:block;padding:12px;border-radius:12px}
.mobile-menu a:hover,.mobile-menu a:focus-visible{background:#f4f4f4;outline:none}

/* ===== Hero ===== */
.hero{position:relative}
.hero-img{width:100%;height:clamp(260px,60vh,520px);object-fit:cover}
.hero-overlay{position:absolute;inset:auto 0 20px 0;display:grid;gap:12px}

/* Títulos con Playfair Display Regular */
h1,h2,h3,.split-title{
  font-family:"Playfair Display", serif;
  font-weight:400;
}

.hero-overlay h1{
  color:var(--ink);
  font-size:clamp(1.4rem,1rem + 2vw,2.4rem);
  margin:0;
  background:rgba(255,255,255,.7);
  display:inline-block;
  padding:.25rem .5rem;
  border-radius:8px
}

.cta{display:flex;flex-wrap:wrap;gap:12px;margin-top:4px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;border-radius:999px;border:1px solid #000;background:#000;color:#fff}
.btn.secondary{background:var(--accent);color:#000;border-color:var(--accent)}

/* ===== Secciones & tarjetas ===== */
.section{padding-block:40px}
h1,h2,h3{margin:0 0 8px;line-height:1.2}
h2{font-size:clamp(2.25rem,1rem + 1vw,2.6rem);color:var(--muted)}
.card{background:var(--white);border-radius:var(--radius);padding:24px}
.grid{display:grid;gap:16px}
.grid.cols-3{grid-template-columns:repeat(1,1fr)}
.bullets{padding-left:1rem}
.bullets li{margin:.25rem 0}
.bullets.two-cols{columns:1}

/* ===== Split (foto + caja) ===== */
/* ===== Tono cálido tipo #f4dda3 sobre imágenes split ===== */
.split-media {
  position: relative;
  overflow: hidden;
  border-radius: 12px;
}


.split-media img {
  width: 100%;
  height: clamp(320px, 50vh, 540px);
  object-fit: cover;
  border-radius: 12px;
  transition: transform .4s ease;
}

/* Pequeño efecto al pasar el ratón (opcional) */
.split-media:hover img {
  transform: scale(1.03);
}


.split{position:relative;padding-block:clamp(0px,6vw,25px)}
.split .container{display:grid;gap:24px}
.split-card{text-align:left;background:var(--white);border-radius:var(--radius);padding:clamp(18px,2.2vw,32px)}
.split-title{font-size:clamp(1.6rem,1.2rem + 1.4vw,2.2rem);letter-spacing:.02em;margin:0 0 .6rem;color:#222}
.split-lead{color:var(--muted);margin:0 0 1rem;max-width:58ch;line-height:1.7}
.split-media img{width:100%;height:clamp(320px,70vh,540px);object-fit:none;border-radius:12px}
.card-split{display:grid;gap:16px}
.card-media img{border-radius:12px}
.schedule{display:grid;gap:10px;margin-top:8px}

/* ===== Footer fijo (barra de acciones) — fondo #f4dda3, textos e iconos NEGROS ===== */
.actionbar{position:fixed;left:0;right:0;bottom:0;height:var(--footer-h);
  background:var(--accent);
  display:grid;grid-template-columns:repeat(4,1fr);
  border-top:1px solid rgba(0,0,0,.15)}
.actionbar a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  font-size:.8rem;color:#000} /* textos en negro */
.actionbar svg{width:22px;height:22px;stroke:currentColor;fill:none} /* iconos en negro */

/* ===== Responsive ===== */
@media (max-width:899px){
  body{padding-top:var(--header-h);padding-bottom:var(--footer-h)}
  .site-header{position:fixed;left:0;right:0;top:0;z-index:50}
  nav.desktop{display:none}
  .burger{display:inline-grid}
}
@media (min-width:900px){
  :root{--header-h:76px}
  .burger{display:none}
  .mobile-menu{display:none}
  .actionbar{display:none}
  .split .container{grid-template-columns:1fr 1fr;align-items:center}
  .split--image-right .split-media{margin-right:calc((100vw - var(--maxw))/ -2)}
  .split--image-left  .split-media{margin-left: calc((100vw - var(--maxw))/ -2)}
  .grid.cols-3{grid-template-columns:repeat(3,1fr)}
  .bullets.two-cols{columns:2}
}

/* Accesibilidad */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
}

/* ===== Header centrado con logo a la izquierda del texto (solo escritorio) ===== */
@media (min-width: 900px) {
  .site-header {
    background: var(--white);
    border-bottom: 1px solid #ececec;
    text-align: center;
    padding-block: 1.5rem 1rem; /* espacio arriba y abajo */
  }

  .topbar {
    display: flex;
    flex-direction: column;     /* apila logo/texto y menú */
    align-items: center;
    justify-content: center;
    gap: 1.2rem;
    height: auto;
  }

  /* Contenedor logo + texto */
  .brand {
    display: flex;
    flex-direction: row;        /* imagen y texto lado a lado */
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
  }

  .brand-logo {
    width: 80px;
    height: auto;
    border-radius: 0;           /* elimina borde redondeado si no lo quieres */
    object-fit: contain;
  }

  .brand span {
    font-family: "Playfair Display", serif;
    font-weight: 400;
    font-size: 1.6rem;
    letter-spacing: .02em;
    color: var(--ink);
  }

  /* Menú debajo centrado */
  nav.desktop ul {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 1.25rem;
    margin: 0;
    padding: 0;
  }

  nav.desktop li {
    list-style: none;
  }

  nav.desktop a {
    font-size: 1rem;
    padding: 0.5rem 1rem;
    border-radius: 8px;
  }

  nav.desktop a:hover,
  nav.desktop a:focus-visible {
    background: #f4f4f4;
    outline: none;
  }
}
/* ===== Mapa a ancho completo fuera del container ===== */
#mapa {
  width: 100vw;               /* ocupa todo el ancho de la ventana */
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;         /* rompe los límites del container */
  margin-right: -50vw;
  margin-top: 2rem;
  margin-bottom: 0;
}

#mapa iframe {
  width: 100%;
  height: 400px;              /* puedes ajustar la altura */
  border: 0;
  display: block;
  filter: brightness(95%) sepia(10%) hue-rotate(330deg); /* leve tono cálido #f4dda3 */
}





/* ===== Acordeón (2 columnas) ===== */
.accordion-grid{
  display:grid;
  gap:18px;
  align-items:start;
}

/* 2 columnas en escritorio, 1 en móvil */
@media (min-width: 900px){
  .accordion-grid{
    grid-template-columns: repeat(2, 1fr);
    gap:22px 28px;
  }
}

.accordion-item{
  border:1px solid rgba(0,0,0,.18);
  border-radius: var(--radius);
  background: var(--white);
  overflow:hidden;
}

.accordion-trigger{
  list-style:none;
  cursor:pointer;
  user-select:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;

  padding:18px 18px;
  background: #f4dda3;
}

.accordion-title{
  font-family:"Playfair Display", serif;
  font-weight:400;
  font-size:1.3rem;
  line-height:1.2;
}

.accordion-trigger::-webkit-details-marker{display:none;}
.accordion-trigger::marker{content:"";}

/* Panel del acordeón */
.accordion-panel{
  display:grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows .28s ease;
  background: var(--white);
  border-top:1px solid rgba(0,0,0,.10);
}

.accordion-item[open] .accordion-panel{
  grid-template-rows: 1fr;
}

.accordion-panel > *{
  overflow:hidden;
}

/* Texto interior con padding de 10px */
.accordion-panel p,
.accordion-panel ul{
  margin:0 0 12px;
  padding:10px;
}


/* Icono redondo */
.acc-icon{
  width:34px;
  height:34px;
  flex:0 0 auto;
  border-radius:999px;
  background: #bab8b8;
  position:relative;
}

/* Líneas del + */
.acc-icon::before,
.acc-icon::after{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  background:#fff;
  transform:translate(-50%, -50%);
  transition: transform .25s ease, opacity .25s ease;
}

/* Línea horizontal */
.acc-icon::before{
  width:14px;
  height:2px;
}

/* Línea vertical */
.acc-icon::after{
  width:2px;
  height:14px;
}

/* Estado abierto: se convierte en “–” */
.accordion-item[open] .acc-icon::after{
  transform:translate(-50%, -50%) scaleY(0);
  opacity:0;
}

/* Estado inicial del contenido */
.accordion-panel p,
.accordion-panel ul,
.accordion-panel li{
  opacity:0;
  transform:translateY(10px);
  transition: opacity .3s ease, transform .3s ease;
}

/* Cuando el acordeón está abierto */
.accordion-item[open] .accordion-panel p,
.accordion-item[open] .accordion-panel ul,
.accordion-item[open] .accordion-panel li{
  opacity:1;
  transform:translateY(0);
}

.schedule-table{
  width:100%;
  border-collapse:collapse;
}
.schedule-table th{
  text-align:left;
  vertical-align:top;
  width: 100px;
  padding: 10px 12px;
  border-bottom: 1px solid rgba(0,0,0,.1);
  font-weight:700;
}
.schedule-table td{
  padding: 10px 12px;
  border-bottom: 1px solid rgba(0,0,0,.1);
}
.schedule-table ul{
  margin:0;
  padding-left: 1.1rem;
}
.schedule-table li{ margin: .2rem 0; }
.schedule-table th {
  font-weight: 400;
  color: inherit;
}
/* ===== Instagram menú ===== */
.menu-instagram{
  display:flex;
  align-items:center;
  gap:.4rem;
  font-weight:500;
}

.menu-instagram svg{
  width:18px;
  height:18px;
  stroke:currentColor;
  fill:none;
  stroke-width:2;
}
/* ===== Banner Instagram ===== */
.instagram-banner{
  width:100vw;
  margin-left:-50vw;
  left:50%;
  position:relative;
  background:#f4dda3;
}

.instagram-banner a{
  display:block;
  padding:20px 20px;
  margin-bottom: 30px;
  text-align:center;
  color:#000;
}

.instagram-content{
  max-width:900px;
  margin:auto;
  display:grid;
  gap:14px;
  justify-items:center;
}

.instagram-content svg{
  width:48px;
  height:48px;
  stroke:#000;
  fill:none;
  stroke-width:1.8;
}

.instagram-content h2{
  font-size:clamp(2rem,3vw,3rem);
  margin:0;
}

.instagram-content p{
  font-size:1.1rem;
  letter-spacing:.08em;
}

/* efecto elegante */
.instagram-banner:hover{
  filter:brightness(0.97);
  transition:.3s ease;
}