@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;1,300;1,400&display=swap');

/* ── UNAI Brand Tokens ──────────────────────────────────────────────────── */
:root {
  --arena:       #EAE5D8;
  --arena-dark:  #D8D0BE;
  --arena-dk:    #D8D0BE; /* alias for backward compatibility */
  --tierra:      #625A58;
  --hueso:       #ECE1CD;
  --plomo:       #343434;
  --white:       #FFFFFF;
  --f: 'Josefin Sans', sans-serif;
  --f-heading: 'Josefin Sans', sans-serif;

  /* ── Tipografía (controlable desde el back office) ── */
  --tipo-base-size:     20px;   /* font-size base del sitio (html) */
  --tipo-parrafo-size:  24px;   /* tamaño de párrafos de cuerpo */
  --tipo-parrafo-weight: 500;   /* peso de párrafos - Josefin Sans Medium para más grosor */
  --tipo-heading-weight: 700;   /* peso de títulos */
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: var(--tipo-base-size); }
body {
  font-family: var(--f);
  font-weight: var(--tipo-parrafo-weight);
  color: var(--plomo);
  background: var(--arena);
  -webkit-font-smoothing: antialiased;
}
img { display: block; max-width: 100%; }
a { text-decoration: none; }
p { text-align: justify; }
p.justified { text-align: justify; }

/* ── Focus visible (accessibility) ─────────────────────────────────────── */
:focus-visible {
  outline: 2px solid var(--tierra);
  outline-offset: 3px;
}

/* ── NAV ────────────────────────────────────────────────────────────────── */
#nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 50;
  padding: 24px 40px;
  display: flex; align-items: center; justify-content: space-between;
  transition: all .5s ease;
}
#nav.scrolled, #nav:hover {
  background: rgba(234,229,216,.97);
  backdrop-filter: blur(8px);
  box-shadow: 0 1px 0 rgba(98,90,88,.12);
}
#nav.scrolled {
  padding: 14px 40px;
}
.nav-logo-name {
  font-family: var(--f); font-weight: 700; font-size: 1.55rem;
  letter-spacing: .35em; text-transform: uppercase;
  color: #fff; transition: color .4s;
}
.nav-logo-sub {
  font-weight: 300; font-size: .6rem; letter-spacing: .32em;
  text-transform: uppercase; color: rgba(255,255,255,.65);
  margin-top: -2px; transition: color .4s;
}
#nav.scrolled .nav-logo-name, #nav:hover .nav-logo-name { color: var(--plomo); }
#nav.scrolled .nav-logo-sub, #nav:hover .nav-logo-sub  { color: var(--tierra); }
.nav-links { display: flex; align-items: center; gap: 32px; }
.nav-link {
  position: relative; font-family: var(--f); font-weight: 500;
  font-size: .725rem; letter-spacing: .22em; text-transform: uppercase;
  color: rgba(255,255,255,.9); transition: color .2s;
}
.nav-link::after {
  content: ''; position: absolute; bottom: -2px; left: 0;
  width: 0; height: 1px; background: #fff; transition: width .3s;
}
.nav-link:hover::after { width: 100%; }
.nav-link:hover { color: #fff; }
#nav.scrolled .nav-link, #nav:hover .nav-link { color: var(--plomo); }
#nav.scrolled .nav-link::after, #nav:hover .nav-link::after { background: var(--tierra); }
#nav.scrolled .nav-link:hover, #nav:hover .nav-link:hover { color: var(--tierra); }
.nav-cta {
  font-family: var(--f); font-weight: 500; font-size: .725rem;
  letter-spacing: .22em; text-transform: uppercase;
  padding: 9px 22px; border: 1px solid rgba(255,255,255,.55);
  color: #fff; transition: all .25s;
}
.nav-cta:hover { background: #fff; border-color: #fff; color: var(--plomo); }
#nav.scrolled .nav-cta, #nav:hover .nav-cta { border-color: var(--tierra); color: var(--tierra); }
#nav.scrolled .nav-cta:hover, #nav:hover .nav-cta:hover { background: var(--tierra); border-color: var(--tierra); color: #fff; }
.nav-hamburger { display: none; flex-direction: column; gap: 5px; cursor: pointer; background: none; border: none; padding: 4px; }
.nav-hamburger span { display: block; width: 22px; height: 1px; background: #fff; transition: all .3s; }
#nav.scrolled .nav-hamburger span, #nav:hover .nav-hamburger span { background: var(--plomo); }
.nav-mobile { display: none; position: fixed; top: 56px; left: 0; right: 0; z-index: 49; background: var(--arena); padding: 28px 40px; flex-direction: column; gap: 20px; border-bottom: 1px solid rgba(98,90,88,.15); }
.nav-mobile.open { display: flex; }
.nav-mobile .nav-link { color: var(--plomo); font-size: .875rem; }

/* ── SECTION REVEAL ─────────────────────────────────────────────────────── */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .9s ease, transform .9s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

/* ── HELPERS ────────────────────────────────────────────────────────────── */
.eyebrow {
  font-family: var(--f); font-weight: 500; font-size: .725rem;
  letter-spacing: .38em; text-transform: uppercase; color: var(--tierra);
  margin-left: .38em; /* Compensa el letter-spacing para que quede perfectamente centrado */
}
.rule { width: 36px; height: 1px; background: var(--tierra); }
.rule-center { margin: 0 auto; }
.btn {
  display: inline-block; font-family: var(--f); font-weight: 500;
  font-size: .725rem; letter-spacing: .22em; text-transform: uppercase;
  padding: 13px 32px; transition: all .25s; cursor: pointer; border: none;
}
.btn-dark  { background: var(--plomo); color: #fff; border: 1px solid var(--plomo); }
.btn-dark:hover  { background: transparent; color: var(--plomo); }
.btn-tierra { background: var(--tierra); color: #fff; border: 1px solid var(--tierra); }
.btn-tierra:hover { background: transparent; color: var(--tierra); }
.btn-outline { background: transparent; color: var(--tierra); border: 1px solid var(--tierra); }
.btn-outline:hover { background: var(--tierra); color: #fff; }
.section-pad { padding: 120px 40px; }

/* ── HERO ───────────────────────────────────────────────────────────────── */
#hero {
  position: relative; height: 100vh; min-height: 620px;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden; background: var(--plomo);
}
#hero-bg {
  position: absolute; inset: 0;
  background: linear-gradient(160deg, #343434 0%, #1A1816 55%, #2C2420 100%);
}
#hero-bg img { width: 100%; height: 100%; object-fit: cover; opacity: .75; }
#hero-content {
  position: relative; text-align: center;
  padding: 0 32px; max-width: 760px; z-index: 1;
}
#hero h1 {
  font-family: var(--f); font-weight: var(--tipo-heading-weight);
  font-size: clamp(2.6rem, 7vw, 5.5rem);
  letter-spacing: .18em; text-transform: uppercase;
  line-height: 1.08; color: #fff; margin: 0 0 32px;
}
#hero .eyebrow { margin-bottom: 36px; color: rgba(236,225,205,.7); }
#hero .rule { margin: 0 auto 32px; }
#hero p {
  font-weight: 300; font-size: 1.063rem; letter-spacing: .12em;
  color: rgba(255,255,255,.55); line-height: 1.9; margin-bottom: 52px;
  text-transform: uppercase;
}
.hero-ctas { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }
#hero-scroll {
  position: absolute; bottom: 40px; left: 50%;
  transform: translateX(-50%); display: flex;
  flex-direction: column; align-items: center; gap: 12px;
}
#hero-scroll span {
  font-size: .75rem; letter-spacing: .35em; text-transform: uppercase;
  color: rgba(255,255,255,.3);
}
#hero-scroll div { width: 1px; height: 53px; background: linear-gradient(to bottom, var(--tierra), transparent); }

/* ── HIGHLIGHTS ─────────────────────────────────────────────────────────── */
#highlights { background: var(--hueso); padding: 72px 40px; border-bottom: 1px solid var(--arena-dark); }
.highlights-grid { max-width: 1100px; margin: 0 auto; display: grid; grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); gap: 48px; }
.highlight-item { text-align: center; }
.highlight-item .rule { margin: 0 auto 20px; }
.highlight-item h3 { font-size: .8125rem; font-weight: 700; letter-spacing: .22em; text-transform: uppercase; color: var(--plomo); margin-bottom: 12px; }
.highlight-item p { font-size: var(--tipo-parrafo-size); font-weight: var(--tipo-parrafo-weight); color: var(--tierra); line-height: 1.75; }

/* ── NOSOTROS ───────────────────────────────────────────────────────────── */
#nosotros { background: var(--arena); }
.nosotros-grid { max-width: 1100px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 88px; align-items: center; }
.nosotros-text .eyebrow { margin-bottom: 20px; }
.nosotros-text h2 { font-size: clamp(1.6rem,3vw,2.6rem); font-weight: var(--tipo-heading-weight); letter-spacing: .18em; text-transform: uppercase; line-height: 1.2; color: var(--plomo); margin-bottom: 28px; }
.nosotros-text .rule { margin-bottom: 28px; }
.nosotros-text p { font-size: var(--tipo-parrafo-size); line-height: 1.9; color: var(--tierra); margin-bottom: 20px; }
.nosotros-text a { font-size: .75rem; letter-spacing: .22em; text-transform: uppercase; color: var(--tierra); border-bottom: 1px solid var(--tierra); padding-bottom: 3px; }
.nosotros-img { aspect-ratio: 4/5; background: linear-gradient(145deg, var(--hueso), var(--arena)); border: 1px solid var(--arena-dark); position: relative; overflow: hidden; }
.nosotros-img img { width: 100%; height: 100%; object-fit: cover; }
.nosotros-img .img-placeholder { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; }
.nosotros-img .img-placeholder span { font-size: .725rem; letter-spacing: .2em; text-transform: uppercase; color: var(--tierra); }
.nosotros-img .img-caption { position: absolute; bottom: 24px; left: 24px; right: 24px; font-size: .85rem; letter-spacing: .1em; text-transform: uppercase; color: var(--tierra); opacity: .7; }
.stats-grid { max-width: 1100px; margin: 80px auto 0; display: grid; grid-template-columns: repeat(auto-fit, minmax(180px,1fr)); border-top: 1px solid rgba(98,90,88,.15); border-left: 1px solid rgba(98,90,88,.15); }
.stat-item { text-align: center; padding: 40px 24px; border-right: 1px solid rgba(98,90,88,.15); border-bottom: 1px solid rgba(98,90,88,.15); }
.stat-item .stat-n { font-size: 2.75rem; font-weight: 700; letter-spacing: .12em; color: var(--plomo); margin-bottom: 6px; }
.stat-item .stat-l { font-size: .8125rem; letter-spacing: .2em; text-transform: uppercase; color: var(--tierra); font-weight: 300; }

/* ── TENTS ──────────────────────────────────────────────────────────────── */
#habitaciones { background: #fff; }
.tents-tabs { max-width: 860px; margin: 0 auto 56px; display: flex; border-bottom: 1px solid var(--arena); }
.tent-tab { flex: 1; font-family: var(--f); font-size: .775rem; font-weight: 300; letter-spacing: .22em; text-transform: uppercase; padding: 14px 8px; background: none; border: none; cursor: pointer; color: var(--tierra); border-bottom: 2px solid transparent; margin-bottom: -1px; transition: all .2s; }
.tent-tab.active { color: var(--plomo); font-weight: 500; border-bottom-color: var(--plomo); }
.tent-panel { max-width: 860px; margin: 0 auto; display: none; grid-template-columns: 1fr 1fr; gap: 72px; align-items: start; }
.tent-panel.active { display: grid; }
.tent-img { aspect-ratio: 4/5; background: linear-gradient(145deg, var(--hueso), var(--arena)); border: 1px solid var(--arena-dark); position: relative; overflow: hidden; }
.tent-img img { width: 100%; height: 100%; object-fit: cover; }
.tent-slider { position: absolute; inset: 0; width: 100%; height: 100%; }
.tent-slider-inner { display: flex; width: 100%; height: 100%; transition: transform 0.4s ease; }
.tent-slider-inner img { flex: 0 0 100%; width: 100%; height: 100%; object-fit: cover; }
.slider-btn { position: absolute; top: 50%; transform: translateY(-50%); background: rgba(0,0,0,0.3); color: white; border: none; font-size: 24px; padding: 4px 12px; cursor: pointer; z-index: 10; transition: background 0.3s; }
.slider-btn:hover { background: rgba(0,0,0,0.6); }
.slider-btn.prev { left: 10px; }
.slider-btn.next { right: 10px; }
.slider-dots { position: absolute; bottom: 16px; left: 0; right: 0; display: flex; justify-content: center; gap: 8px; z-index: 10; }
.slider-dot { width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,0.4); cursor: pointer; transition: background 0.3s ease; box-shadow: 0 1px 3px rgba(0,0,0,0.2); }
.slider-dot.active { background: #fff; }
.tent-badge { position: absolute; bottom: 20px; right: 20px; background: var(--plomo); padding: 5px 14px; font-size: .875rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; color: #fff; }
.tent-body { padding-top: 12px; }
.tent-body .tagline { font-size: .9375rem; letter-spacing: .12em; text-transform: uppercase; color: var(--tierra); font-style: italic; opacity: .8; margin-bottom: 16px; }
.tent-body h3 { font-size: 1.75rem; font-weight: var(--tipo-heading-weight); letter-spacing: .18em; text-transform: uppercase; color: var(--plomo); margin-bottom: 24px; }
.tent-body p { font-size: var(--tipo-parrafo-size); line-height: 1.9; color: var(--tierra); margin-bottom: 28px; }
.tent-body .detalle { font-size: .9rem; font-weight: 300; color: var(--tierra); opacity: .7; padding-top: 18px; border-top: 1px solid var(--arena); margin-bottom: 36px; }

/* ── GASTRONOMÍA ────────────────────────────────────────────────────────── */
#gastronomia { background: var(--plomo); color: #fff; }
.gastro-header { text-align: center; margin-bottom: 80px; }
.gastro-header h2 { font-size: clamp(1.6rem,4vw,3rem); font-weight: var(--tipo-heading-weight); letter-spacing: .18em; text-transform: uppercase; color: #fff; margin-bottom: 20px; line-height: 1.15; }
.gastro-header p { font-size: 1.025rem; letter-spacing: .1em; text-transform: uppercase; color: rgba(234,229,216,.5); max-width: 400px; margin: 0 auto; line-height: 1.9; }
.gastro-grid { max-width: 1100px; margin: 0 auto 80px; display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.gastro-img { aspect-ratio: 3/4; background: linear-gradient(160deg, #2C2420, #1A1510); border: 1px solid rgba(98,90,88,.3); position: relative; overflow: hidden; }
.gastro-img img { width: 100%; height: 100%; object-fit: cover; }
.gastro-text .intro { font-size: .975rem; letter-spacing: .12em; text-transform: uppercase; color: rgba(234,229,216,.55); margin-bottom: 28px; line-height: 1.8; }
.gastro-text p { font-size: var(--tipo-parrafo-size); line-height: 1.9; color: rgba(234,229,216,.6); margin-bottom: 20px; }
.gastro-text .btn-tierra { margin-bottom: 14px; display: block; width: fit-content; }
.gastro-text .link-ghost { font-size: .725rem; letter-spacing: .2em; text-transform: uppercase; color: rgba(234,229,216,.4); border-bottom: 1px solid rgba(234,229,216,.2); padding-bottom: 2px; }
.chefs-grid { max-width: 1100px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 48px; border-top: 1px solid rgba(98,90,88,.3); padding-top: 64px; }
.chef-card { display: flex; gap: 28px; align-items: flex-start; }
.chef-photo { width: 100px; height: 130px; flex-shrink: 0; background: rgba(98,90,88,.2); border: 1px solid rgba(98,90,88,.3); overflow: hidden; }
.chef-photo img { width: 100%; height: 100%; object-fit: cover; }
.chef-info { padding-top: 8px; }
.chef-info .eyebrow { margin-bottom: 8px; }
.chef-info h3 { font-size: 1.25rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; color: #fff; margin-bottom: 12px; }
.chef-info p { font-size: var(--tipo-parrafo-size); line-height: 1.8; color: rgba(234,229,216,.45); }
.gastro-cta-box { max-width: 1100px; margin: 72px auto 0; padding: 40px 48px; border: 1px solid rgba(98,90,88,.25); border-left: 3px solid var(--tierra); display: grid; grid-template-columns: 1fr auto; gap: 32px; align-items: center; }
.gastro-cta-box h3 { font-size: 1.25rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: #fff; margin-bottom: 10px; }
.gastro-cta-box p { font-size: 1rem; color: rgba(234,229,216,.45); line-height: 1.8; }

/* ── EXPERIENCIAS ───────────────────────────────────────────────────────── */
#experiencias { background: var(--hueso); }
.exp-header { text-align: center; margin-bottom: 72px; }
.exp-header h2 { font-size: clamp(1.6rem,3vw,2.6rem); font-weight: var(--tipo-heading-weight); letter-spacing: .18em; text-transform: uppercase; color: var(--plomo); margin: 16px 0 20px; }
.exp-grid { max-width: 1100px; margin: 0 auto; display: grid; grid-template-columns: repeat(auto-fit,minmax(300px,1fr)); gap: 2px; }
.exp-card { background: #fff; padding: 44px 40px; border: 1px solid var(--arena); height: 100%; }
.exp-card.coming { background: rgba(234,229,216,.5); opacity: .65; }
.exp-card .coming-tag { display: inline-block; font-size: .625rem; letter-spacing: .22em; text-transform: uppercase; padding: 4px 12px; background: var(--arena); color: var(--tierra); border: 1px solid rgba(98,90,88,.2); margin-bottom: 16px; }
.exp-card .rule { margin-bottom: 20px; }
.exp-card h3 { font-size: 1.125rem; font-weight: 700; letter-spacing: .22em; text-transform: uppercase; color: var(--plomo); margin-bottom: 6px; }
.exp-card .sub { font-size: .8125rem; letter-spacing: .12em; text-transform: uppercase; color: var(--tierra); margin-bottom: 18px; }
.exp-card p { font-size: var(--tipo-parrafo-size); line-height: 1.85; color: var(--tierra); }

/* ── GALERÍA ────────────────────────────────────────────────────────────── */
#galeria { background: #fff; }
.galeria-header { text-align: center; margin-bottom: 56px; }
.galeria-header h2 { font-size: clamp(1.6rem,3vw,2.6rem); font-weight: var(--tipo-heading-weight); letter-spacing: .18em; text-transform: uppercase; color: var(--plomo); margin: 16px 0 20px; }
.galeria-header p { font-size: .9375rem; letter-spacing: .1em; text-transform: uppercase; color: var(--tierra); }
.galeria-filters { display: flex; justify-content: center; max-width: 640px; margin: 0 auto 56px; border-bottom: 1px solid var(--arena); }
.gal-filter { font-family: var(--f); font-size: .75rem; letter-spacing: .22em; text-transform: uppercase; padding: 11px 18px; background: none; border: none; cursor: pointer; color: var(--tierra); border-bottom: 2px solid transparent; margin-bottom: -1px; font-weight: 300; transition: all .2s; }
.gal-filter.active { color: var(--plomo); font-weight: 500; border-bottom-color: var(--plomo); }
.galeria-masonry { max-width: 1100px; margin: 0 auto; columns: 3 280px; gap: 4px; }
.gal-item { break-inside: avoid; margin-bottom: 4px; position: relative; cursor: zoom-in; overflow: hidden; border: 1px solid var(--arena); }
.gal-item img { width: 100%; display: block; transition: transform .5s ease; }
.gal-item:hover img { transform: scale(1.03); }
.gal-item .gal-overlay { position: absolute; inset: 0; background: rgba(52,52,52,0); transition: background .3s; }
.gal-item:hover .gal-overlay { background: rgba(52,52,52,.2); }
.gal-placeholder { aspect-ratio: 4/3; background: linear-gradient(145deg, var(--hueso), var(--arena)); display: flex; align-items: center; justify-content: center; }
.gal-placeholder span { font-size: .6875rem; letter-spacing: .15em; text-transform: uppercase; color: var(--tierra); opacity: .6; }
.galeria-ig { text-align: center; margin-top: 72px; padding: 48px; background: var(--arena); border: 1px solid rgba(98,90,88,.15); }
.galeria-ig p:first-child { font-size: .8125rem; font-weight: 700; letter-spacing: .22em; text-transform: uppercase; color: var(--plomo); margin-bottom: 8px; }
.galeria-ig p { font-size: var(--tipo-parrafo-size); letter-spacing: .05em; color: var(--tierra); margin-bottom: 28px; }
.lightbox { display: none; position: fixed; inset: 0; background: rgba(52,52,52,.96); z-index: 999; align-items: center; justify-content: center; }
.lightbox.open { display: flex; }
.lightbox-inner { position: relative; max-width: 90vw; }
.lightbox-inner img { max-width: min(800px,90vw); max-height: 85vh; object-fit: contain; }
.lightbox-close { position: absolute; top: -36px; right: 0; background: none; border: none; color: rgba(255,255,255,.5); font-size: 1.2rem; cursor: pointer; font-family: var(--f); letter-spacing: .1em; }

/* ── NOTICIAS ───────────────────────────────────────────────────────────── */
#noticias { background: var(--hueso); }
.noticias-header { text-align: center; margin-bottom: 72px; }
.noticias-header h2 { font-size: clamp(1.6rem,3vw,2.6rem); font-weight: var(--tipo-heading-weight); letter-spacing: .18em; text-transform: uppercase; color: var(--plomo); margin: 16px 0 20px; }
.noticias-header p { font-size: .9375rem; letter-spacing: .1em; text-transform: uppercase; color: var(--tierra); }
.noticias-wrap { max-width: 1100px; margin: 0 auto; }
.noticia-featured { display: grid; grid-template-columns: 1fr 1fr; gap: 0; margin-bottom: 4px; border: 1px solid var(--arena); background: #fff; }
.noticia-featured-img { aspect-ratio: 16/9; min-height: 240px; background: linear-gradient(145deg, var(--arena), rgba(98,90,88,.4)); position: relative; overflow: hidden; }
.noticia-featured-img img { width: 100%; height: 100%; object-fit: cover; }
.noticia-tag { position: absolute; top: 20px; left: 20px; background: var(--plomo); padding: 4px 14px; font-size: .625rem; font-weight: 500; letter-spacing: .22em; text-transform: uppercase; color: #fff; }
.noticia-featured-body { padding: 48px 44px; display: flex; flex-direction: column; justify-content: center; }
.noticia-fecha { font-size: .775rem; letter-spacing: .18em; text-transform: uppercase; color: var(--tierra); margin-bottom: 16px; }
.noticia-featured-body h3 { font-size: 1.625rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; color: var(--plomo); margin-bottom: 20px; line-height: 1.25; }
.noticia-featured-body p { font-size: var(--tipo-parrafo-size); line-height: 1.9; color: var(--tierra); margin-bottom: 32px; }
.noticia-featured-body a { font-size: .725rem; font-weight: 500; letter-spacing: .2em; text-transform: uppercase; color: var(--plomo); border-bottom: 1px solid var(--plomo); padding-bottom: 3px; }
.noticias-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(300px,1fr)); gap: 4px; }
.noticia-card { background: var(--arena); padding: 36px 32px; border: 1px solid rgba(98,90,88,.15); transition: background .25s; height: 100%; display: flex; flex-direction: column; }
.noticia-card:hover { background: #fff; }
.noticia-card-meta { display: flex; justify-content: space-between; align-items: center; margin-bottom: 18px; }
.noticia-card-tipo { font-size: .65rem; font-weight: 500; letter-spacing: .22em; text-transform: uppercase; color: var(--tierra); }
.noticia-card .rule { margin-bottom: 16px; opacity: .5; }
.noticia-card h3 { font-size: 1.0625rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; color: var(--plomo); margin-bottom: 14px; line-height: 1.35; }
.noticia-card p { font-size: var(--tipo-parrafo-size); line-height: 1.85; color: var(--tierra); margin-bottom: 24px; flex: 1; }
.noticia-card a { font-size: .7rem; font-weight: 500; letter-spacing: .18em; text-transform: uppercase; color: var(--plomo); border-bottom: 1px solid rgba(98,90,88,.3); padding-bottom: 2px; }
.noticias-nota { margin-top: 40px; padding: 22px 32px; background: #fff; border-left: 2px solid rgba(98,90,88,.4); font-size: .9rem; color: var(--tierra); line-height: 1.8; }
.noticias-nota strong { font-weight: 500; text-transform: uppercase; letter-spacing: .1em; }

/* ── TESTIMONIOS ────────────────────────────────────────────────────────── */
#testimonios { background: var(--plomo); }
.test-header { text-align: center; margin-bottom: 72px; }
.test-header h2 { font-size: clamp(1.6rem,3vw,2.6rem); font-weight: var(--tipo-heading-weight); letter-spacing: .18em; text-transform: uppercase; color: #fff; margin: 16px 0 20px; }
.test-grid { max-width: 1100px; margin: 0 auto; display: grid; grid-template-columns: repeat(auto-fit,minmax(280px,1fr)); gap: 2px; }
.test-card { padding: 44px 36px; border: 1px solid rgba(98,90,88,.2); height: 100%; }
.test-card:nth-child(odd) { background: rgba(255,255,255,.03); }
.test-card:nth-child(even) { background: rgba(255,255,255,.02); }
.test-book-img { width: 100%; aspect-ratio: 3/2; background: rgba(98,90,88,.15); margin-bottom: 24px; overflow: hidden; }
.test-book-img img { width: 100%; height: 100%; object-fit: cover; }
.test-quote-mark { font-size: 2rem; color: rgba(98,90,88,.3); line-height: 1; margin-bottom: 16px; }
.test-card blockquote { font-size: var(--tipo-parrafo-size); font-style: italic; line-height: 1.85; color: rgba(234,229,216,.7); margin-bottom: 28px; }
.test-card .test-author { font-size: .775rem; font-weight: 500; letter-spacing: .15em; text-transform: uppercase; color: var(--tierra); margin-bottom: 4px; border-top: 1px solid rgba(98,90,88,.2); padding-top: 16px; }
.test-card .test-origen { font-size: .775rem; font-weight: 300; color: rgba(98,90,88,.5); letter-spacing: .08em; }

/* ── CONTACTO ───────────────────────────────────────────────────────────── */
#contacto { background: var(--arena); }
.contact-header { text-align: center; margin-bottom: 72px; }
.contact-header h2 { font-size: clamp(1.6rem,3vw,2.6rem); font-weight: var(--tipo-heading-weight); letter-spacing: .18em; text-transform: uppercase; color: var(--plomo); margin: 16px 0 20px; }
.contact-grid { max-width: 1100px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 88px; }
.contact-form-intro { font-size: var(--tipo-parrafo-size); letter-spacing: .05em; color: var(--tierra); margin-bottom: 40px; line-height: 1.8; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-bottom: 24px; }
.form-field { margin-bottom: 24px; }
.form-label { display: block; font-size: .65rem; font-weight: 500; letter-spacing: .25em; text-transform: uppercase; color: var(--tierra); margin-bottom: 6px; }
.form-input, .form-textarea, .form-select {
  width: 100%; font-family: var(--f); font-weight: 300; font-size: 1.025rem;
  padding: 12px 0; border: none; border-bottom: 1px solid rgba(98,90,88,.4);
  background: transparent; color: var(--plomo); outline: none;
}
.form-textarea { resize: vertical; }
.form-submit { width: 100%; }
.form-note { font-size: .75rem; color: rgba(98,90,88,.6); text-align: center; margin-top: 12px; letter-spacing: .08em; }
.form-success { padding: 40px 20px; text-align: center; }
.form-success h3 { font-size: 1.75rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--plomo); margin: 20px 0 16px; }
.form-success p { font-size: 1.025rem; color: var(--tierra); line-height: 1.8; max-width: 320px; margin: 0 auto; }
.contact-info-label { font-size: .6875rem; font-weight: 500; letter-spacing: .3em; text-transform: uppercase; color: var(--tierra); margin-bottom: 36px; }
.contact-pin { display: flex; gap: 20px; align-items: flex-start; padding: 24px 0; border-bottom: 1px solid rgba(98,90,88,.15); text-decoration: none; }
.contact-pin-num { font-size: .75rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; color: var(--tierra); margin-top: 2px; min-width: 20px; }
.contact-pin h4 { font-size: .8125rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--plomo); margin-bottom: 6px; }
.contact-pin p { font-size: var(--tipo-parrafo-size); font-weight: var(--tipo-parrafo-weight); color: var(--tierra); margin-bottom: 8px; }
.contact-pin span { font-size: .6875rem; font-weight: 500; letter-spacing: .15em; text-transform: uppercase; color: var(--tierra); opacity: .6; }
/* Contact quick info */
.contact-quick-row { border-bottom: 1px solid rgba(98,90,88,.1); padding-bottom: 10px; }
.contact-quick-row:last-child { border-bottom: none; padding-bottom: 0; }
.contact-quick-icon { font-size: 1rem; width: 28px; text-align: center; flex-shrink: 0; opacity: .7; }
.contact-quick-lbl { display: block; font-size: .6rem; letter-spacing: .2em; text-transform: uppercase; color: var(--tierra); font-weight: 500; margin-bottom: 2px; font-family: 'Josefin Sans', sans-serif; }
.contact-quick-val { display: block; font-size: .875rem; font-weight: 300; color: var(--plomo); font-family: 'Josefin Sans', sans-serif; }
.contact-quick-row:hover .contact-quick-val { color: var(--tierra); transition: color .2s; }
/* Contact map tabs */
.contact-pin-tab { transition: background .2s; }
/* Contact map */
.contact-map { width: 100%; aspect-ratio: 4/3; background: var(--hueso); border: 1px solid rgba(98,90,88,.15); position: relative; overflow: hidden; }
.contact-map iframe { width: 100%; height: 100%; border: 0; }

/* ── FOOTER ─────────────────────────────────────────────────────────────── */
footer { background: var(--plomo); padding: 64px 40px 40px; border-top: 1px solid rgba(98,90,88,.2); }
.footer-grid { max-width: 1100px; margin: 0 auto; display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 56px; margin-bottom: 56px; }
.footer-brand { display: flex; flex-direction: column; }
.footer-logo-name { font-size: 1.6rem; font-weight: 700; letter-spacing: .35em; text-transform: uppercase; color: #fff; }
.footer-logo-img { max-width: 160px; height: auto; display: block; filter: brightness(0) invert(1); }
.footer-logo-sub { font-size: .6rem; font-weight: 300; letter-spacing: .32em; text-transform: uppercase; color: var(--tierra); margin-top: -2px; }
.footer-tagline { font-size: .95rem; line-height: 1.9; color: var(--hueso); opacity: .7; max-width: 260px; letter-spacing: .04em; margin-top: 24px; margin-bottom: 20px; }
.footer-col h4 { font-size: .7rem; font-weight: 500; letter-spacing: .28em; text-transform: uppercase; color: var(--tierra); margin-bottom: 20px; padding-bottom: 10px; border-bottom: 1px solid rgba(255,255,255,.08); }
.footer-col a { display: block; font-size: .9rem; font-weight: 300; letter-spacing: .1em; text-transform: uppercase; color: var(--hueso); opacity: .7; margin-bottom: 12px; transition: opacity .2s; text-decoration: none; }
.footer-col a:hover { opacity: 1; color: var(--hueso); }
.footer-col p { font-size: .9rem; font-weight: 300; color: var(--hueso); opacity: .7; margin-bottom: 10px; letter-spacing: .04em; line-height: 1.6; }
.footer-bottom { max-width: 1100px; margin: 0 auto; border-top: 1px solid rgba(98,90,88,.15); padding-top: 24px; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 12px; }
.footer-bottom p { font-size: .7rem; font-weight: 300; letter-spacing: .12em; text-transform: uppercase; color: var(--hueso); opacity: .5; }

/* ── NOTICIAS PAGE ──────────────────────────────────────────────────────── */
.page-header { padding: 120px 40px 72px; text-align: center; }
.page-header h1 { font-size: clamp(2rem,5vw,3.75rem); font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--plomo); margin: 20px 0; }
.article-hero { width: 100%; aspect-ratio: 21/9; max-height: 520px; background: linear-gradient(145deg, var(--hueso), rgba(98,90,88,.4)); position: relative; overflow: hidden; }
.article-hero img { width: 100%; height: 100%; object-fit: cover; }
.article-hero-fade { position: absolute; bottom: 0; left: 0; right: 0; height: 160px; background: linear-gradient(to top, var(--arena), transparent); }
.article-body { max-width: 720px; margin: 0 auto; padding: 64px 40px 120px; }
.article-meta { display: flex; gap: 20px; align-items: center; margin-bottom: 32px; }
.article-meta span { font-size: .9rem; letter-spacing: .15em; text-transform: uppercase; }
.article-meta .meta-sep { width: 1px; height: 12px; background: rgba(98,90,88,.3); }
.article-body h1 { font-size: clamp(2rem,4vw,3.25rem); font-weight: 700; letter-spacing: .18em; text-transform: uppercase; line-height: 1.15; color: var(--plomo); margin-bottom: 24px; }
.article-extract { font-size: 1.3675rem; line-height: 1.85; color: var(--tierra); margin-bottom: 48px; font-style: italic; }
.article-content { font-size: 1.094rem; line-height: 1.9; color: var(--plomo); }
.article-content p { margin-bottom: 20px; }
.article-content h3 { font-size: 1.25rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; color: var(--plomo); margin: 36px 0 16px; }
.article-content ul { padding-left: 20px; margin-bottom: 20px; }
.article-content li { margin-bottom: 8px; line-height: 1.7; }
.article-cta { margin-top: 64px; padding-top: 40px; border-top: 1px solid rgba(98,90,88,.15); }
.more-noticias { background: var(--hueso); padding: 80px 40px; }
.more-noticias h2 { font-size: .9rem; font-weight: 500; letter-spacing: .3em; text-transform: uppercase; color: var(--tierra); margin-bottom: 40px; max-width: 1100px; margin-left: auto; margin-right: auto; }

/* ── PROMO PAGE ─────────────────────────────────────────────────────────── */
.promo-page { min-height: 100vh; }
.promo-page.arena { background: var(--arena); }
.promo-page.oscuro { background: var(--plomo); color: #fff; }
.promo-hero { width: 100%; aspect-ratio: 21/9; max-height: 560px; position: relative; overflow: hidden; }
.promo-hero img { width: 100%; height: 100%; object-fit: cover; }
.promo-content { max-width: 900px; margin: 0 auto; padding: 64px 40px 120px; }
.promo-eyebrow { display: flex; flex-wrap: wrap; gap: 24px; justify-content: space-between; align-items: flex-start; margin-bottom: 36px; }
.countdown { display: flex; gap: 8px; align-items: center; }
.countdown-cell { text-align: center; padding: 10px 14px; min-width: 52px; background: #fff; border: 1px solid rgba(98,90,88,.2); }
.oscuro .countdown-cell { background: rgba(255,255,255,.06); border-color: rgba(234,229,216,.12); }
.countdown-n { font-size: 1.375rem; font-weight: 700; letter-spacing: .05em; color: var(--plomo); line-height: 1; }
.oscuro .countdown-n { color: #fff; }
.countdown-l { font-size: .75rem; letter-spacing: .2em; text-transform: uppercase; color: var(--tierra); margin-top: 4px; font-weight: 300; }
.promo-title { font-size: clamp(2rem,5vw,3.75rem); font-weight: 700; letter-spacing: .18em; text-transform: uppercase; line-height: 1.1; color: var(--plomo); margin-bottom: 20px; }
.oscuro .promo-title { color: #fff; }
.promo-tagline { font-size: 1.094rem; letter-spacing: .06em; font-style: italic; color: var(--tierra); margin-bottom: 28px; }
.promo-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; margin-bottom: 64px; }
.promo-desc { font-size: 1.025rem; line-height: 1.9; color: var(--tierra); text-align: justify; }
.oscuro .promo-desc { color: rgba(234,229,216,.65); }
.promo-price { font-size: 1.094rem; font-weight: 700; letter-spacing: .1em; color: var(--tierra); margin-top: 32px; }
.promo-includes { background: #fff; border: 1px solid rgba(98,90,88,.15); padding: 36px 32px; border-left: 3px solid var(--tierra); }
.oscuro .promo-includes { background: rgba(255,255,255,.04); border-color: rgba(234,229,216,.08); }
.promo-includes h3 { font-size: .9rem; font-weight: 500; letter-spacing: .3em; text-transform: uppercase; color: var(--tierra); margin-bottom: 24px; }
.promo-include-item { display: flex; gap: 14px; margin-bottom: 14px; align-items: flex-start; }
.promo-include-item .diamond { color: var(--tierra); font-size: .75rem; margin-top: 4px; flex-shrink: 0; }
.promo-include-item p { font-size: 1.094rem; line-height: 1.6; color: var(--tierra); }
.oscuro .promo-include-item p { color: rgba(234,229,216,.65); }
.promo-actions { display: flex; gap: 16px; flex-wrap: wrap; align-items: center; }
.promo-legal { font-size: .9rem; color: rgba(98,90,88,.6); margin-top: 32px; border-top: 1px solid rgba(98,90,88,.15); padding-top: 20px; line-height: 1.7; }
.oscuro .promo-legal { color: rgba(234,229,216,.3); }

/* ── ADMIN ──────────────────────────────────────────────────────────────── */
.admin-body { background: var(--hueso); min-height: 100vh; font-family: var(--f); }
.admin-topbar { background: var(--plomo); padding: 0 40px; height: 56px; display: flex; align-items: center; justify-content: space-between; }
.admin-topbar-left { display: flex; align-items: center; gap: 16px; }
.admin-logo { font-size: 1rem; font-weight: 700; letter-spacing: .35em; text-transform: uppercase; color: #fff; }
.admin-sep { width: 1px; height: 20px; background: rgba(255,255,255,.15); }
.admin-tag { font-size: .8125rem; font-weight: 300; letter-spacing: .2em; text-transform: uppercase; color: rgba(255,255,255,.4); }
.admin-topbar-right { display: flex; align-items: center; gap: 20px; }
.admin-topbar-right a { font-size: .8125rem; letter-spacing: .18em; text-transform: uppercase; color: rgba(255,255,255,.4); }
.admin-topbar-right a:hover { color: rgba(255,255,255,.75); }
.admin-topbar-right .admin-user { font-size: .9rem; color: rgba(255,255,255,.55); }
.admin-layout { display: flex; min-height: calc(100vh - 56px); }
.admin-sidebar { width: 200px; background: var(--arena); border-right: 1px solid rgba(98,90,88,.15); padding: 32px 0; flex-shrink: 0; }
.admin-nav-link { display: block; width: 100%; text-align: left; padding: 13px 28px; background: none; border: none; cursor: pointer; font-family: var(--f); font-size: .85rem; font-weight: 300; letter-spacing: .2em; text-transform: uppercase; color: var(--tierra); border-left: 3px solid transparent; transition: all .15s; text-decoration: none; }
.admin-nav-link:hover { color: var(--plomo); }
.admin-nav-link.active { color: var(--plomo); font-weight: 500; border-left-color: var(--tierra); }
.admin-main { flex: 1; overflow: auto; padding: 40px 48px; }
.admin-section-title { font-size: 1.25rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--plomo); margin-bottom: 28px; }
.admin-list-row { display: flex; align-items: center; gap: 16px; padding: 16px 20px; background: #fff; border: 1px solid var(--arena); margin-bottom: 4px; }
.admin-list-thumb { width: 60px; height: 40px; object-fit: cover; flex-shrink: 0; background: var(--hueso); }
.admin-list-info { flex: 1; min-width: 0; }
.admin-list-info h4 { font-size: .9375rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--plomo); margin-bottom: 3px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.admin-list-info p { font-size: .875rem; font-weight: 300; color: var(--tierra); }
.admin-list-actions { display: flex; gap: 8px; }
.admin-btn { display: inline-block; font-family: var(--f); font-weight: 500; font-size: .8125rem; letter-spacing: .18em; text-transform: uppercase; padding: 9px 18px; cursor: pointer; border: 1px solid; transition: all .2s; text-align: center; }
.admin-btn-primary { background: var(--plomo); color: #fff; border-color: var(--plomo); }
.admin-btn-primary:hover { background: transparent; color: var(--plomo); }
.admin-btn-ghost { background: transparent; color: var(--tierra); border-color: rgba(98,90,88,.35); }
.admin-btn-ghost:hover { background: var(--tierra); color: #fff; border-color: var(--tierra); }
.admin-btn-danger { background: #8B1A1A; color: #fff; border-color: #8B1A1A; }
.admin-btn-danger:hover { background: transparent; color: #8B1A1A; }
.admin-btn-small { padding: 7px 14px; font-size: .725rem; }
.admin-form-label { display: block; font-size: .65rem; font-weight: 500; letter-spacing: .25em; text-transform: uppercase; color: var(--tierra); margin-bottom: 6px; }
.admin-form-input, .admin-form-textarea, .admin-form-select { width: 100%; font-family: var(--f); font-weight: 300; font-size: 1.025rem; padding: 10px 14px; border: 1px solid rgba(98,90,88,.3); background: #fff; color: var(--plomo); outline: none; margin-bottom: 20px; }
.admin-form-textarea { resize: vertical; }
.admin-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.admin-toggle { display: flex; align-items: center; gap: 12px; margin-bottom: 20px; cursor: pointer; }
.toggle-track { width: 44px; height: 24px; border-radius: 12px; position: relative; transition: background .2s; flex-shrink: 0; }
.toggle-track.on { background: var(--tierra); }
.toggle-track.off { background: #C9C0B4; }
.toggle-thumb { position: absolute; top: 3px; width: 18px; height: 18px; border-radius: 9px; background: #fff; transition: left .2s; }
.toggle-track.on .toggle-thumb { left: 23px; }
.toggle-track.off .toggle-thumb { left: 3px; }
.admin-toggle span { font-size: 1.025rem; font-weight: 300; color: var(--plomo); }
.alert { padding: 14px 20px; margin-bottom: 20px; font-size: .9375rem; font-weight: 300; letter-spacing: .05em; }
.alert-ok  { background: rgba(98,90,88,.1); color: var(--tierra); border-left: 3px solid var(--tierra); }
.alert-err { background: rgba(139,26,26,.08); color: #8B1A1A; border-left: 3px solid #8B1A1A; }
.include-item { display: flex; gap: 8px; align-items: center; margin-bottom: 8px; }
.include-item span { flex: 1; font-size: 1.025rem; color: var(--plomo); }
.include-item button { background: none; border: none; color: #8B1A1A; cursor: pointer; font-size: 1rem; }
.upload-preview { display: inline-block; position: relative; margin-bottom: 12px; }
.upload-preview img { height: 80px; width: 120px; object-fit: cover; border: 1px solid rgba(98,90,88,.2); }
.upload-clear { position: absolute; top: -8px; right: -8px; width: 20px; height: 20px; border-radius: 50%; background: #8B1A1A; color: #fff; border: none; cursor: pointer; font-size: .75rem; line-height: 20px; text-align: center; }
.gallery-thumb-grid { display: flex; flex-wrap: wrap; gap: 8px; }
.gallery-thumb { position: relative; cursor: pointer; }
.gallery-thumb img { width: 72px; height: 72px; object-fit: cover; border: 1px solid rgba(98,90,88,.15); transition: border-color .2s; }
.gallery-thumb.selected img { border: 2px solid var(--tierra); }
.color-picker { display: flex; gap: 12px; }
.color-swatch { padding: 8px 20px; cursor: pointer; font-family: var(--f); font-size: .875rem; letter-spacing: .15em; text-transform: uppercase; border: 1px solid rgba(98,90,88,.25); transition: border .2s; }
.color-swatch.selected { border: 2px solid var(--tierra); }

/* ── ADMIN LOGIN ────────────────────────────────────────────────────────── */
.admin-login-wrap { min-height: 100vh; background: var(--plomo); display: flex; align-items: center; justify-content: center; }
.admin-login-box { background: var(--arena); padding: 56px 48px; width: 100%; max-width: 400px; }
.admin-login-logo { text-align: center; margin-bottom: 40px; }
.admin-login-logo .name { font-size: 1.8rem; font-weight: 700; letter-spacing: .35em; text-transform: uppercase; color: var(--plomo); }
.admin-login-logo .sub { font-size: .55rem; font-weight: 300; letter-spacing: .32em; text-transform: uppercase; color: var(--tierra); margin-top: -2px; }

/* ── RESPONSIVE ─────────────────────────────────────────────────────────── */
/* ── RESPONSIVE ─────────────────────────────────────────────────────────── */

/* Tablet — 900px */
@media (max-width: 900px) {
  html { font-size: 17px; }

  /* Nav */
  .nav-links { display: none; }
  .nav-hamburger { display: flex; }
  #nav { padding: 16px 20px; }

  /* Grids → single col */
  .nosotros-grid,
  .gastro-grid,
  .chefs-grid,
  .contact-grid,
  .noticia-featured,
  .promo-grid,
  .footer-grid { grid-template-columns: 1fr; gap: 36px; }
  .tent-panel.active { grid-template-columns: 1fr; }
  .exp-grid, .test-grid, .noticias-grid { grid-template-columns: 1fr; }

  /* Padding */
  .section-pad { padding: 80px 24px; }

  /* Hero */
  #hero-content { padding: 0 24px; }

  /* Tents */
  .tents-tabs { overflow-x: auto; -webkit-overflow-scrolling: touch; }

  /* Gastro */
  .gastro-cta-box { grid-template-columns: 1fr; gap: 20px; padding: 28px 24px; }

  /* Contact map buttons */
  .contact-map + div { grid-template-columns: 1fr 1fr; }

  /* Footer */
  .footer-social { margin-top: 20px; }

  /* Admin */
  .admin-layout { flex-direction: column; }
  .admin-sidebar { width: 100%; border-right: none; border-bottom: 1px solid rgba(98,90,88,.15); padding: 12px 0; display: flex; overflow-x: auto; }
  .admin-nav-link { white-space: nowrap; border-left: none; border-bottom: 3px solid transparent; }
  .admin-nav-link.active { border-left-color: transparent; border-bottom-color: var(--tierra); }
  .admin-form-row { grid-template-columns: 1fr; }
}

/* Mobile — 600px */
@media (max-width: 600px) {
  html { font-size: 16px; }

  #nav { padding: 14px 16px; }
  .nav-logo-name { font-size: 1.25rem; }

  /* Hero — compact */
  #hero-content { padding: 0 20px; }
  #hero h1 { font-size: clamp(2rem, 10vw, 3.5rem); letter-spacing: .1em; }
  #hero p { font-size: .85rem; letter-spacing: .08em; }
  .hero-ctas { flex-direction: column; align-items: center; gap: 10px; }
  .hero-ctas .btn { width: 100%; max-width: 280px; text-align: center; }

  /* Sections */
  .section-pad { padding: 64px 20px; }
  #highlights { padding: 56px 20px; }
  .highlights-grid { gap: 32px; }

  /* Nosotros stats */
  .stats-grid { grid-template-columns: 1fr 1fr; }
  .stat-item .stat-n { font-size: 2.1rem; }

  /* Tents */
  .tent-tab { font-size: .65rem; padding: 12px 6px; }
  .tent-body { padding-top: 8px; }
  .tent-badge { font-size: .75rem; padding: 4px 10px; }

  /* Gastro chefs */
  .chefs-grid { grid-template-columns: 1fr; }
  .chef-card { flex-direction: column; gap: 16px; }
  .chef-photo { width: 80px; height: 100px; }

  /* Experiencias */
  .exp-card { padding: 32px 24px; }

  /* Testimonios */
  .test-card { padding: 32px 24px; }

  /* Contacto */
  .form-row { grid-template-columns: 1fr; gap: 0; }
  .contact-map { aspect-ratio: 1 / 1; }

  /* Footer */
  .footer-grid { gap: 32px; }
  .footer-brand { display: flex; flex-direction: column; }
.footer-logo-name { font-size: 1.4rem; }
  .footer-col a, .footer-col p { font-size: .82rem; }

  /* Noticias */
  .noticia-featured-body { padding: 28px 24px; }
  .noticias-nota { padding: 16px 20px; }

  /* Page header */
  .page-header { padding: 90px 20px 48px; }
}

/* Small phones — 380px */
@media (max-width: 380px) {
  html { font-size: 15.5px; }
  .section-pad { padding: 56px 16px; }
  #nav { padding: 12px 16px; }
  .hero-ctas .btn { max-width: 100%; }
  .stats-grid { grid-template-columns: 1fr; }
  .footer-grid { gap: 28px; }
}

/* ── POPUP ──────────────────────────────────────────────────────────────── */
#popup-overlay {
  position: fixed; inset: 0; z-index: 999;
  background: rgba(52,52,52,.75);
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
}
.popup-box {
  background: var(--arena);
  max-width: 480px; width: 100%;
  position: relative;
  overflow: hidden;
}
.popup-box.popup-with-img {
  display: grid;
  grid-template-columns: 200px 1fr;
  max-width: 720px;
}
.popup-img {
  overflow: hidden;
}
.popup-img img {
  width: 100%; height: 100%; object-fit: cover;
}
.popup-body {
  padding: 48px 44px;
}
.popup-close {
  position: absolute; top: 16px; right: 16px;
  background: none; border: none; cursor: pointer;
  font-family: var(--f); font-size: .75rem; letter-spacing: .15em;
  color: var(--tierra); opacity: .6; z-index: 2;
  transition: opacity .2s;
}
.popup-close:hover { opacity: 1; }
.popup-tag {
  display: inline-block;
  font-family: var(--f); font-weight: 500;
  font-size: .6rem; letter-spacing: .28em; text-transform: uppercase;
  color: var(--tierra); border: 1px solid rgba(98,90,88,.3);
  padding: 4px 12px; margin-bottom: 20px;
}
.popup-title {
  font-family: var(--f); font-weight: 700;
  font-size: clamp(1.3rem, 3vw, 1.8rem);
  letter-spacing: .15em; text-transform: uppercase;
  line-height: 1.15; color: var(--plomo);
  margin-bottom: 20px;
}
.popup-rule {
  width: 36px; height: 1px;
  background: var(--tierra); margin-bottom: 20px;
}
.popup-text {
  font-family: var(--f); font-weight: 300;
  font-size: .95rem; line-height: 1.85;
  color: var(--tierra); margin-bottom: 28px;
}
.popup-form { display: flex; flex-direction: column; gap: 0; }
.popup-input {
  width: 100%; font-family: var(--f); font-weight: 300;
  font-size: .95rem; padding: 11px 0;
  border: none; border-bottom: 1px solid rgba(98,90,88,.35);
  background: transparent; color: var(--plomo);
  outline: none; margin-bottom: 18px;
}
.popup-input::placeholder { color: rgba(98,90,88,.45); }
.popup-submit { margin-top: 8px; width: 100%; }
.popup-thanks { text-align: center; padding: 8px 0; }
.popup-skip {
  font-family: var(--f); font-weight: 300;
  font-size: .7rem; letter-spacing: .18em; text-transform: uppercase;
  color: rgba(98,90,88,.4); text-align: center;
  margin-top: 16px; cursor: pointer;
  transition: color .2s;
}
.popup-skip:hover { color: var(--tierra); }

@media (max-width: 640px) {
  .popup-box.popup-with-img { grid-template-columns: 1fr; }
  .popup-img { display: none; }
  .popup-body { padding: 36px 28px; }
}

/* ── LANGUAGE SWITCHER ──────────────────────────────────────────────────── */
.lang-switcher {
  display: flex; align-items: center; gap: 2px;
  margin-left: 16px;
}
.lang-btn {
  font-family: var(--f); font-weight: 500;
  font-size: .6rem; letter-spacing: .15em; text-transform: uppercase;
  padding: 4px 8px; color: rgba(255,255,255,.5);
  border: 1px solid transparent; transition: all .2s;
  text-decoration: none;
}
.lang-btn:hover { color: #fff; border-color: rgba(255,255,255,.3); }
.lang-btn.lang-active { color: #fff; border-color: rgba(255,255,255,.5); }
#nav.scrolled .lang-btn { color: rgba(52,52,52,.45); }
#nav.scrolled .lang-btn:hover { color: var(--plomo); border-color: rgba(98,90,88,.4); }
#nav.scrolled .lang-btn.lang-active { color: var(--plomo); border-color: var(--tierra); }

/* ── BE WILD, BE YOU ─────────────────────────────────────────────────────── */
#bewild {
  position: relative; overflow: hidden;
}

/* ── Solo texto / CTA Banner — imagen parallax + overlay ──────────────── */
#bewild.bw-solo {
  padding: 96px 0;
  text-align: center;
  color: #ffffff;
  background-color: #343434;               /* fallback si no hay imagen */
  background-size: cover;
  background-position: center center;
  background-attachment: fixed;             /* parallax */
  min-height: 551px;
  display: flex;
  align-items: center;
  justify-content: center;
}
/* Franja decorativa superior */
#bewild.bw-solo::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.15), transparent);
  opacity: .6;
}
/* Contenedor interior centrado */
#bewild.bw-solo .bw-container {
  max-width: 1400px;
  margin: 0 auto;
  text-align: center;
  display: block;
  position: relative;
  z-index: 2;
  padding: 0 40px;
  width: 100%;
  box-sizing: border-box;
}

/* Título h2 — BE WILD. BE YOU */
#bewild.bw-solo .bw-title {
  font-family: 'Josefin Sans', var(--f), sans-serif;
  font-weight: 500;
  font-size: 40px;
  line-height: 64px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #ffffff;
  margin: 0 0 24px 0;
}

/* Párrafo cuerpo */
#bewild.bw-solo .bw-paragraph {
  font-family: 'Josefin Sans', var(--f), sans-serif;
  font-weight: 300;
  font-size: 17.6px;
  line-height: 29.92px;
  letter-spacing: normal;
  color: #ffffff;
  text-align: center;
  margin: 0 auto 32px auto;
  max-width: 800px;
}

/* Subtexto */
#bewild.bw-solo .bw-sub {
  font-family: 'Josefin Sans', var(--f), sans-serif;
  font-weight: 400;
  font-size: .825rem;
  letter-spacing: .32em;
  text-transform: uppercase;
  margin-top: 0;
  color: rgba(255,255,255,.5);
  line-height: 1.7;
}

/* CTA button */
#bewild.bw-solo .bw-cta {
  margin-top: 40px;
  display: inline-block;
  background: transparent;
  color: rgba(255,255,255,.85);
  border: 1px solid rgba(255,255,255,.35);
  padding: 14px 40px;
  font-family: 'Josefin Sans', var(--f), sans-serif;
  font-weight: 400;
  font-size: .8rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  text-decoration: none;
  transition: all .35s ease;
}
#bewild.bw-solo .bw-cta:hover {
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.6);
  color: #fff;
}

/* Con imagen o video de fondo */
#bewild.bw-bg-mode {
  min-height: 560px;
  display: flex; align-items: center; justify-content: center;
  background: var(--plomo);
}
#bewild.bw-bg-mode .bw-media {
  position: absolute; inset: 0;
}
#bewild.bw-bg-mode .bw-media img,
#bewild.bw-bg-mode .bw-media video { width:100%; height:100%; object-fit:cover; display:block; }
#bewild.bw-bg-mode .bw-overlay { position:absolute; inset:0; background:rgba(28,24,20,.55); }
#bewild.bw-bg-mode .bw-content {
  position: relative; z-index: 2;
  text-align: center; padding: 80px 40px; max-width: 820px; width: 100%;
}

/* Lateral */
#bewild.bw-lateral { background: var(--arena); }
#bewild.bw-lateral .bw-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  max-width: 1100px; margin: 0 auto; min-height: 480px;
}
#bewild.bw-lateral .bw-img-col { position:relative; overflow:hidden; }
#bewild.bw-lateral .bw-img-col img { width:100%; height:100%; object-fit:cover; display:block; }
#bewild.bw-lateral .bw-text-col {
  display:flex; flex-direction:column; justify-content:center; padding: 80px 64px;
}

/* ── Tipografía Be Wild (bg-mode + lateral) ─── */
.bw-line1, .bw-line2 {
  font-family: var(--f);
  font-weight: 700;
  font-size: clamp(43px, 5.5vw, 90px);
  letter-spacing: .10em;
  text-transform: uppercase;
  line-height: 1.05;
  display: block;
  color: #fff;
}
.bw-line2 { color: inherit; }

/* Lateral colors */
#bewild.bw-lateral .bw-line1,
#bewild.bw-lateral .bw-line2 { color: var(--plomo); }

/* Línea divisoria */
.bw-rule {
  width: 52px; height: 2px;
  background: rgba(255,255,255,.5);
  margin: 36px auto;
}
#bewild.bw-lateral .bw-rule { background: var(--tierra); margin: 32px 0; }

/* Párrafo cuerpo — bg-mode y lateral */
.bw-paragraph {
  font-family: var(--f);
  font-weight: 300;
  font-size: 1.1rem;
  line-height: 1.9;
  letter-spacing: .02em;
  color: inherit;
  max-width: 700px;
  margin: 0 auto 2rem auto;
}
#bewild.bw-lateral .bw-paragraph { color: var(--tierra); text-align: left; margin: 0; }

/* Subtexto — bg-mode y lateral */
.bw-sub {
  font-family: var(--f);
  font-weight: 400;
  font-size: .825rem;
  letter-spacing: .32em;
  text-transform: uppercase;
  margin-top: 0;
  color: rgba(255,255,255,.5);
  line-height: 1.7;
}
#bewild.bw-lateral .bw-sub { color: var(--tierra); }

/* ── Responsive ────── */
@media (max-width: 900px) {
  .bw-line1, .bw-line2 { font-size: clamp(36px, 9vw, 58px); }
  #bewild.bw-solo { padding: 72px 28px; min-height: 380px; }
  #bewild.bw-solo .bw-title { font-size: 32px; line-height: 48px; letter-spacing: 1.5px; }
  #bewild.bw-solo .bw-paragraph { padding: 0 40px; font-size: 16px; line-height: 27px; margin: 0 auto 32px auto; }
  .bw-rule { margin: 28px auto; }
  #bewild.bw-lateral .bw-grid { grid-template-columns: 1fr; }
  #bewild.bw-lateral .bw-text-col { padding: 60px 32px; }
}
@media (max-width: 480px) {
  .bw-line1, .bw-line2 { font-size: clamp(32px, 11vw, 50px); letter-spacing: .06em; }
  #bewild.bw-solo { padding: 56px 20px; min-height: 320px; background-attachment: scroll; /* fix iOS */ }
  #bewild.bw-solo .bw-title { font-size: 26px; line-height: 40px; letter-spacing: 1px; }
  #bewild.bw-solo .bw-paragraph { padding: 0 10px; font-size: 15px; line-height: 25px; margin: 0 auto 24px auto; }
}


/* ── FOOTER SOCIAL ICONS ──────────────────────────────────────────────────── */
/* ── Footer social icons ─── */
.footer-social {
  display: flex; gap: 12px; align-items: center; margin-top: 24px;
}
.footer-social a {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px;
  border: 1px solid rgba(255,255,255,.28);
  color: rgba(255,255,255,.6);
  transition: border-color .2s, color .2s, background .2s;
  text-decoration: none; flex-shrink: 0; border-radius: 0;
}
.footer-social a:hover {
  border-color: var(--tierra);
  color: #fff;
  background: rgba(98,90,88,.35);
}
.footer-social svg { width: 16px; height: 16px; fill: currentColor; display: block; }

/* ── CARTA DISHES (Home & Gastronomía) ──────────────────────────────────── */
.carta-dishes {
  max-width: 900px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 2px;
}
.dish-card {
  background: #fff;
  padding: 36px 32px;
  border: 1px solid rgba(98,90,88,.1);
  transition: background .25s, border-color .25s;
}
.dish-card:hover {
  background: var(--hueso);
  border-color: rgba(98,90,88,.2);
}
.dish-cat {
  font-size: .575rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--tierra);
  margin-bottom: 12px;
  font-weight: 600;
}
.dish-rule { width: 28px; height: 1px; background: var(--tierra); margin-bottom: 16px; }
.dish-card h3 {
  font-size: .9375rem;
  font-weight: 700;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--plomo);
  margin-bottom: 12px;
  line-height: 1.3;
}
.dish-card p {
  font-size: .875rem;
  line-height: 1.85;
  color: var(--tierra);
  margin-bottom: 20px;
}
.dish-price {
  font-size: .8125rem;
  font-weight: 700;
  letter-spacing: .15em;
  color: var(--plomo);
  padding-top: 14px;
  border-top: 1px solid rgba(98,90,88,.12);
}
.dish-price::before { content: '$ '; opacity: .5; }
@media (max-width: 600px) {
  .carta-dishes { grid-template-columns: 1fr; }
}

/* ── 1920px / large screens ─────────────────────────────────────────────── */
@media (min-width: 1700px) {
  html { font-size: 22px; }

  .highlights-grid,
  .nosotros-grid,
  .stats-grid,
  .gastro-grid,
  .chefs-grid,
  .gastro-cta-box,
  .exp-grid,
  .galeria-masonry,
  .noticias-wrap,
  .test-grid,
  .contact-grid,
  .footer-grid,
  .footer-bottom { max-width: 1500px; }

  #nav         { padding: 28px 64px; }
  #nav.scrolled { padding: 16px 64px; }

  .tents-tabs,
  .tent-panel { max-width: 1100px; }

  .section-pad { padding: 140px 64px; }
}
