:root{
  --blanco1:#ffffff;

  --gris1:#808080;  /* texto normal / bordes suaves */
  --gris2:#999999;  /* texto secundario */
  --gris3:#c7c7c7;  /* complemento */

  --negro1:#000000;
  --negro2:#141414;  /* texto destacado */

  --fondoGris1:#e4e4e4;
  --fondoGris2:#f2f2f2;

  --azul1:#2b6cb0; /* color icono hamburguesa */
}

/* Fondo general gris a toda la página */
html{ background: var(--fondoGris1); }

*{ box-sizing:border-box }
html,body{ height:100% }
body{
  margin:0;
  max-width:1170px;
  width:100%;
  margin-inline:auto;
  font-family:'Open Sans', Arial, sans-serif;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  background: var(--blanco1);
  color: var(--negro1);
}

h1,h2,h3,h4,h5,h6{ font-family:'Sedan', serif; letter-spacing:.2px; }

/* Enlaces */
a{ text-decoration:none; color:inherit }
a:hover{ text-decoration:none }

/* ========== Header / Nav ========== */
.header{ position:sticky; top:0; z-index:50; background: rgba(255,255,255,.9); backdrop-filter:saturate(180%) blur(10px); }
.header .topbar{
  width:min(98%, 1100px);
  margin:0 auto .5rem;
  display:flex; align-items:center; justify-content:space-between;
  gap:1rem; padding:1.4rem 0 .4rem;
  font-size:.8rem; color:var(--gris2); letter-spacing:1px; font-weight:300;
  border-bottom:1px solid var(--gris1);
}
.header .topbar .info{ display:flex; align-items:center; gap:1.25rem; flex-wrap:wrap; }
.header .topbar .info-item{ display:flex; align-items:center; gap:.5rem; }

.container{ width:100%; }
.nav{
  position:relative;
  display:flex; align-items:center; justify-content:center;
  min-height:64px;
  width:min(100%, 1170px);
  margin:0 auto;
}

.hamburger{
  position:absolute; left:.5rem; top:50%;
  transform:translateY(-50%);
  background:none; border:none; padding:.5rem; border-radius:10px;
  color: var(--azul1);
}

.menu-logo{ text-align:center; }
.menu-logo img{ width:110px; height:auto; display:block; margin-inline:auto; }
.menu-logo span{ display:block; margin-top:.25rem; font-size:.9rem; font-style:italic; font-family:'Sedan', serif; letter-spacing:1px; }

.menu{
  position:absolute; top:100%; left:0; right:0;
  transform: translateY(-10px);
  opacity:0; pointer-events:none;
  transition: transform .2s ease, opacity .2s ease;
  z-index: 60;
  background: var(--blanco1);
  box-shadow: 0 12px 40px rgba(0,0,0,.15);
}
.menu.open{ transform:none; opacity:1; pointer-events:auto; }

.menu ul{
  list-style:none; padding:.5rem 0; margin:0;
  display:grid; grid-template-columns:1fr; gap:.5rem;
  justify-items:center; text-align:center;
}
.menu li{ padding: 0 .6rem; }
.menu a{ display:block; padding:.35rem .5rem; color: var(--negro1); }
.menu a .es{ display:block; font-weight:700; letter-spacing:.4px; }
.menu a .en{ display:block; font-size:.72rem; line-height:1.15; color: var(--gris2); letter-spacing:4px;}
.menu a:hover{ color: var(--negro1); }
.menu a:hover .en{ color: var(--negro1); }

/* Escritorio */
@media (min-width:900px){
  .hamburger{ display:none; }
  .menu{ all:unset; display:block; }
  .menu ul{
    display:grid;
    grid-template-columns: repeat(3, minmax(80px,1fr)) auto repeat(3, minmax(80px,1fr));
    gap:.5rem; align-items:center; justify-items:center; text-align:center;
  }
  .nav > .menu-logo{ display:none; }
  .menu .menu-logo{ display:block; }
}

/* Móvil */
@media (max-width:899px){
  .nav > .menu-logo{ display:block; }
  .menu .menu-logo{ display:none; }
}

/* ========== Banner simple ========== */
.hero{ position:relative }
.banner{
  position:relative; overflow:hidden;
  height: clamp(500px, 60vh, 640px);
  background:#000;
}
.banner-slide{
  position:absolute; inset:0;
  opacity:0; pointer-events:none;
  transition: opacity .4s ease;
}
.banner-slide.is-active{ opacity:1; pointer-events:auto; }
.banner-slide img{ width:100%; height:100%; object-fit:cover; display:block; }

.banner-overlay{
  position:absolute; left:50%; top:50%; transform:translate(-50%, -50%);
  padding: 1rem 1.25rem; border-radius: 12px;
  max-width: min(100%, 900px); min-width: min(55%, 600px);
  text-align:center; background: rgba(0,0,0,.4); color: var(--blanco1);
}
.banner-overlay h1{ margin:0; font-size: clamp(1.25rem, 4vw + .4rem, 2.4rem); line-height:1.25; }
.banner-overlay p{ margin:.5rem 0 0; font-size: clamp(.85rem, 1.2vw + .45rem, 1.05rem); letter-spacing:.08em; }
@media (max-width:480px){
  .banner-overlay{ padding:.75rem 1rem; border-radius:10px; }
}

/* ========== Utilidades layout ========== */
.container-narrow{ width:min(98%,1100px); margin:0 auto; }

.row{
  display:flex; flex-wrap:wrap; gap:2rem; align-items:center;
}
.row > *{ width:100%; }
@media (min-width:900px){
  .row > *{ width:calc(50% - 1rem); }
}

/* ========== Sección Nosotros ========== */
#nosotros{ background: var(--fondoGris2); padding:3rem 0; }
.section-title{ text-align:center; margin-bottom:1.5rem; }
.section-title h2{
  color: var(--negro1); margin:0; font-family:'Open Sans', sans-serif;
  font-weight:300; letter-spacing:.5px; font-size:.9rem;
}

/* Imagen con marco + lupa */
.nosotros-card{ background:#fff; padding:.6rem; border-radius:12px; box-shadow:0 10px 30px rgba(0,0,0,.08); }
.nosotros-img{ display:block; width:100%; height:auto; border-radius:8px; cursor:zoom-in; }
.zoom-btn{
  position:absolute; inset:0; display:grid; place-items:center;
  background:transparent; border:0; cursor:zoom-in; opacity:0; transition:opacity .2s ease; color:#fff;
}
figure:hover .zoom-btn{ opacity:1; }

/* Stack idiomas */
.lang-toggle{ background:none; border:0; padding:0; margin:0 0 1rem 0; font:inherit; cursor:pointer; color:var(--gris2); }

/* Lightbox */
.lightbox{
  position:fixed; inset:0; display:grid; place-items:center;
  background:rgba(0,0,0,.75); padding:1.5rem; z-index:1000;
}
.lightbox[hidden]{ display:none; }
.lightbox figure{ margin:0; position:relative; max-width:min(96vw, 1100px); }
.lightbox img{ max-width:100%; max-height:82vh; display:block; border-radius:10px; box-shadow:0 20px 60px rgba(0,0,0,.35); }
.lightbox .close{
  position:absolute; top:-12px; right:-12px;
  background:#fff; color:#111; border:0; width:38px; height:38px; border-radius:50%;
  display:grid; place-items:center; box-shadow:0 12px 30px rgba(0,0,0,.25); cursor:pointer;
}

/* Accesibilidad: oculto visual */
.sr-only{
  position:absolute !important; width:1px !important; height:1px !important; padding:0 !important;
  margin:-1px !important; overflow:hidden !important; clip:rect(0,0,0,0) !important; white-space:nowrap !important; border:0 !important;
}

/* ========== SECCIÓN GALERÍA (UNIFICADO) ========== */

#galeria-hostal.gh-wrap{
  --ff-head:'Sedan', Georgia, 'Times New Roman', serif;
  --ff-body:'Open Sans', Arial, Helvetica, sans-serif;

  --c-text:#222;
  --c-muted:#6b6b6b;
  --c-eyebrow:#8a8a8a;
  --c-overlay:rgba(0,0,0,.60);

  --hero-h:min(62vh,560px);
  --caption-w:88%;
  --caption-pad:clamp(.9rem,2.2vw,1.6rem);
  --radius:16px;

  background:#fff;
  color:var(--c-text);
  padding:clamp(1.2rem,2.5vw,2rem);
}

/* ===== Layout general ===== */
#galeria-hostal .gh-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(1rem,2vw,1.5rem);
}
@media (min-width:960px){
  #galeria-hostal .gh-grid{
    grid-template-columns:1.05fr 1.2fr;
    gap:clamp(1.5rem,3vw,3rem);
  }
}

/* ===== Textos de cabecera izquierda ===== */
#galeria-hostal .gh-eyebrow{
  margin:.2rem 0 .7rem 0;
  font:600 .8rem/1 var(--ff-body);
  letter-spacing:.18em;
  color:var(--c-eyebrow);
}
#galeria-hostal .gh-title{
  margin:0 0 .3rem 0;
  font:400 clamp(1.4rem,3.2vw,2rem)/1.2 var(--ff-body);
}
#galeria-hostal .gh-sublead{
  margin:.15rem 0 1.2rem 0;
  font:400 .9rem/1.4 var(--ff-body);
  color:var(--c-muted);
  letter-spacing:.04em;
}

/* ===== Categorías (enlaces) ===== */
#galeria-hostal .gh-cats{
  display:flex;
  flex-wrap:wrap;
  gap:1rem;
  margin:0 0 1rem 0;
}
#galeria-hostal .gh-cats .cat{
  display:inline-block;
  cursor:pointer;
  font:600 .78rem/1 var(--ff-body);
  letter-spacing:.08em;
  color:#1f1f1f;
  position:relative;
  padding-bottom:.35rem;
  text-decoration:none;
  transition:color .2s ease, font-weight .2s ease, text-decoration .2s ease;
}
#galeria-hostal .gh-cats .cat:hover{
  font-weight:700;
  text-decoration:underline;
}
#galeria-hostal .gh-cats .cat.is-active{
  font-weight:700;
}
#galeria-hostal .gh-cats .cat.is-active::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:0;
  height:2px; background:#1f1f1f;
}

/* ===== Miniaturas ===== */
#galeria-hostal .gh-thumbs{
  list-style:none; margin:0; padding:0;
  display:grid; grid-template-columns:repeat(4,1fr); gap:.6rem;
}
#galeria-hostal .gh-thumbs li a{
  display:block; border-radius:10px; overflow:hidden;
}
#galeria-hostal .gh-thumbs img{
  width:100%; aspect-ratio:4/3; object-fit:cover; display:block;
  transition:transform .28s ease;
}
#galeria-hostal .gh-thumbs a:hover img{ transform:scale(1.03); }

/* ===== Columna derecha (Hero) ===== */
#galeria-hostal .gh-right{
  min-height:var(--hero-h);
  height:100%;
  display:flex;
}
#galeria-hostal .gh-hero{
  flex:1 1 auto;
  width:100%; height:100%;
  min-height:clamp(360px,62vh,680px);
  background:transparent !important;       /* quita recuadro negro */
  border-radius:0 !important;
  padding:0; overflow:hidden; box-shadow:none;
  position:relative;
}

/* reset márgenes figure (evita halo alrededor) */
#galeria-hostal .gh-hero figure{ margin:0 !important; padding:0; border:0; }

/* Slides a pantalla completa */
#galeria-hostal .gh-slide{
  position:absolute; top:0; right:0; bottom:0; left:0;
  opacity:0; visibility:hidden; transform:scale(1.02);
  background-size:cover !important;
  background-position:center center !important;
  background-repeat:no-repeat !important;
  background-color:transparent !important;
  border-radius:0 !important;
  transition:opacity .7s ease, visibility .7s ease, transform .7s ease;
}
#galeria-hostal .gh-slide.is-active{
  opacity:1; visibility:visible; transform:scale(1);
}

/* Faja caption (déjalo o comenta la línea display para ocultarlo) */
#galeria-hostal .gh-caption{
  position:absolute; right:0; bottom:.9rem;
  width:var(--caption-w);
  background:var(--c-overlay); color:#fff;
  padding:var(--caption-pad);
  border-radius:var(--radius) 0 0 var(--radius);
  backdrop-filter:blur(1.5px);
  box-shadow:-8px 0 24px rgba(0,0,0,.15);
  /* display:none !important; */
}
#galeria-hostal .cap-title{
  margin:0 0 .25rem 0;
  font-family:var(--ff-head); font-weight:400;
  font-size:clamp(1.4rem,3.2vw,2.2rem);
  letter-spacing:.2px;
}
#galeria-hostal .cap-sub{
  margin:0; font-family:var(--ff-body);
  font-size:clamp(.82rem,1.2vw,.95rem); opacity:.92;
}

/* Flechas: ocultas hasta hover/focus */
#galeria-hostal .gh-nav{
  position:absolute; top:50%; transform:translateY(-50%);
  width:44px; height:44px; border:0; border-radius:999px;
  background:rgba(0,0,0,.35); color:#fff;
  cursor:pointer; display:grid; place-items:center; font-size:1.1rem;
  box-shadow:0 2px 12px rgba(0,0,0,.18);
  opacity:0; transition:opacity .18s ease, transform .18s ease;
}
#galeria-hostal .gh-hero:hover .gh-nav,
#galeria-hostal .gh-nav:focus-visible{ opacity:1; }
#galeria-hostal .gh-nav.prev{ left:.75rem; }
#galeria-hostal .gh-nav.next{ right:.75rem; }

/* Dots ocultos */
#galeria-hostal .gh-dots{ display:none !important; }

/* ===== Responsive ===== */
@media (max-width:600px){
  #galeria-hostal .gh-thumbs{ grid-template-columns:repeat(3,1fr); }
  #galeria-hostal .gh-caption{ width:96%; right:2%; left:2%; border-radius:12px; }
}


/* ============ RESERVAS ============ */
.rs-wrap{ background:#fff; padding:2.5rem 1rem }
.rs-container{ max-width:1180px; margin:auto; display:grid; gap:2.2rem }
.rs-h{ font-size:1.6rem; font-weight:600; letter-spacing:.3px; margin:0 }
.rs-h2{ font-size:1.6rem; margin:.2rem 0 1.2rem }
.rs-sub{ color:#999; font-size:.8rem; margin:.2rem 0 1.6rem }

.rs-form .rs-grid2{ display:grid; grid-template-columns:1fr; gap:1rem }
.rs-field{ display:flex; flex-direction:column; gap:.4rem; margin-bottom:1rem }
.rs-field label, .rs-rooms legend{ font-size:.8rem; color:#222; letter-spacing:.5px }
.rs-field input, .rs-field textarea{
  border:none; border-bottom:1px solid #e1e1e1; padding:.7rem .2rem;
  outline:none; transition:border-color .2s ease; background:#fafafa
}
.rs-field input:focus, .rs-field textarea:focus{ border-color:#2a66ff; background:#fff }
.rs-rooms{ display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:.4rem 1.2rem; margin-top:.4rem }
.rs-chk{ display:flex; align-items:center; gap:.45rem; font-size:.92rem }

.rs-btn{
  width:100%; padding:.95rem 1.1rem; border:none; border-radius:4px;
  background:#2b2b2b; color:#fff; font-weight:700; letter-spacing:.8px; cursor:pointer
}
.rs-btn:hover{ filter:brightness(1.05) }

.rs-rates{ border-left:0; padding-left:0 }
.rs-rate-list{ list-style:none; padding:0; margin:0 0 1rem; border-top:1px solid #eee }
.rs-rate-list li{
  display:grid;
  grid-template-columns:1fr auto;
  gap:1rem;
  padding:.65rem 0;
  border-bottom:1px solid #eee;
  font-size:.95rem;
  position:relative;
  line-height: 0.5;
  letter-spacing: 2px;
  color: var(--gris1);
}
.rs-rate-list b{ font-weight:600 }
.rs-rate-list > li[hidden]{ display:none !important; }
.rs-includes ul{ margin:.4rem 0 0 1rem; color: var(--gris1); }
.rs-legal{ color:var(--gris1); font-size:.85rem; margin-top:.6rem; letter-spacing:2px; }
.rs-note{ margin-top:.75rem; font-size:.9rem }

.rs-mini{ font-size:.78rem; color: var(--negro1); margin:2rem 0; font-weight:700; }

.rs-rate-list li::after{
  content:"";
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  height:1px;
  background:#ccc;
  opacity:.6;
  pointer-events:none;
}

/* Desktop reservas */
@media (min-width: 980px){
  .rs-container{ grid-template-columns: 1fr 0.9fr; align-items:start }
  .rs-form .rs-grid2{ grid-template-columns:1fr 1fr }
  .rs-btn{ width:auto; min-width:320px }
  .rs-rates{ border-left:1px solid #eee; padding-left:2rem }
}

/* Toast */
#toast{
  position: fixed; inset: 0;
  background: rgba(0,0,0,.4);
  display: flex; align-items: center; justify-content: center;
  z-index: 9999;
}
#toast[hidden]{ display:none !important; }
.toast-box{
  position: relative;
  background:#fff; color:#111;
  padding:1.5rem 2.25rem 1.25rem;
  border-radius:12px;
  box-shadow:0 8px 25px rgba(0,0,0,.2);
  max-width:420px; width:90%;
  text-align:center; font-size:1rem;
  animation:fadeIn .25s ease-out;
  border-left:6px solid #2ecc71; /* éxito */
}
.toast-error{ border-left-color:#e74c3c; } /* error */

#toast-close{
  position:absolute; top:.35rem; right:.35rem;
  background:none; border:none; cursor:pointer;
  font-size:1.1rem; line-height:1; color:#666;
}
#toast-close:hover{ color:#000; }

@keyframes fadeIn{
  from{opacity:0; transform:translateY(-8px)}
  to{opacity:1; transform:translateY(0)}
}

/* ============ CONTACTOS ============ */
.contacto-grid{
  max-width:1170px;
  margin:0 auto;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:2rem;
  align-items:start;
}
@media(max-width:768px){
  .contacto-grid{
    grid-template-columns: 1fr !important;
  }
  .contacto-mapa, .contacto-info{
    order:unset;
  }
}

/* ============ FOOTER ============ */
footer{ width:100%; }
footer p{ font-family:'Open Sans', Arial, sans-serif; }

/* ============ WHATSAPP FLOAT ============ */
.whatsapp-float {
  position: fixed;
  width: 55px;
  height: 55px;
  bottom: 20px;
  right: 20px;
  background-color: #25D366;
  color: #fff;
  border-radius: 50%;
  text-align: center;
  font-size: 28px;
  box-shadow: 0 4px 8px rgba(0,0,0,.25);
  z-index: 999;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform .2s ease-in-out;
}
.whatsapp-float:hover {
  transform: scale(1.1);
  background-color: #20b358;
}
