:root{--cream:#f5f0e8;--ivory:#faf7f2;--brown:#2c1f14;--gold:#b8952a;--gold-l:#d4ad45;--dark:#1a1209;--mid:#3d2b1a}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Josefin Sans',sans-serif;font-weight:300;background:var(--ivory);color:var(--brown);overflow-x:hidden}
@keyframes zoomBg{from{transform:scale(1.07)}to{transform:scale(1.0)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes scrollPulse{0%,100%{opacity:.4}50%{opacity:1}}
.serif{font-family:'Cormorant Garamond',serif;font-weight:300}
nav{position:fixed;top:0;left:0;width:100%;z-index:100;padding:24px 48px;display:flex;align-items:center;justify-content:space-between;transition:all .4s}
nav.scrolled{background:rgba(26,18,9,.93);backdrop-filter:blur(12px);padding:14px 48px}
.logo{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:300;letter-spacing:.1em;color:var(--cream);text-decoration:none}
.logo span{color:var(--gold);font-style:italic}
.nav-links{display:flex;gap:32px;list-style:none}
.nav-links a{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--cream);text-decoration:none;opacity:.8;transition:all .2s}
.nav-links a:hover{opacity:1;color:var(--gold-l)}
.nav-cta{background:var(--gold)!important;color:var(--dark)!important;padding:10px 22px;opacity:1!important;font-weight:400!important}
.hero{height:100vh;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;animation:zoomBg 18s ease-in-out infinite alternate}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(26,18,9,.68) 0%,rgba(44,31,20,.3) 55%,rgba(74,124,158,.2) 100%)}
.hero-content{position:relative;z-index:2;text-align:center;color:var(--cream);padding:0 24px;animation:fadeUp 1s .2s both}
.hero-eyebrow{font-size:.62rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.hero-title{font-family:'Cormorant Garamond',serif;font-size:clamp(4rem,10vw,8rem);font-weight:300;line-height:.9}
.hero-sub{font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;margin-top:18px;opacity:.65}
.hero-divider{width:56px;height:1px;background:var(--gold);margin:26px auto}
.hero-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn-gold{background:var(--gold);color:var(--dark);padding:14px 32px;font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;text-decoration:none;font-family:'Josefin Sans';font-weight:400;display:inline-block;transition:background .2s,transform .2s}
.btn-gold:hover{background:var(--gold-l);transform:translateY(-2px)}
.btn-outline{border:1px solid rgba(245,240,232,.4);color:var(--cream);padding:14px 32px;font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;text-decoration:none;font-family:'Josefin Sans';display:inline-block;transition:all .2s}
.btn-outline:hover{border-color:var(--gold);background:rgba(184,149,42,.1)}
.scroll-hint{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:10px;color:rgba(245,240,232,.45);font-size:.58rem;letter-spacing:.25em;text-transform:uppercase}
.scroll-line{width:1px;height:48px;background:linear-gradient(to bottom,var(--gold),transparent);animation:scrollPulse 2s ease-in-out infinite}
.strip{background:var(--gold);padding:16px 48px;display:flex;gap:24px;justify-content:center;align-items:center;flex-wrap:wrap}
.strip span{font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;color:var(--dark)}
section{padding:90px 48px}
.label{font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.section-title{font-family:'Cormorant Garamond',serif;font-size:clamp(2.2rem,5vw,3.8rem);font-weight:300;line-height:1.1;color:var(--brown)}
.section-title em{color:var(--gold);font-style:italic}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}
/* ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;max-width:1200px;margin:0 auto}
.about-text p{font-size:.88rem;line-height:1.9;color:var(--mid);margin-top:22px;max-width:460px}
.stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--gold);border:1px solid var(--gold);margin-top:40px}
.stat{background:var(--ivory);padding:24px 16px;text-align:center}
.stat-n{font-family:'Cormorant Garamond',serif;font-size:2.6rem;color:var(--gold);line-height:1}
.stat-l{font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mid);margin-top:6px}
.about-img{position:relative}
.about-img img{width:100%;aspect-ratio:3/4;object-fit:cover;display:block}
.img-tag{position:absolute;top:24px;right:-18px;background:var(--gold);padding:14px 18px;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:.95rem;color:var(--dark);max-width:140px;text-align:center;line-height:1.4;z-index:2}
/* ROOMS */
.rooms-section{background:var(--dark);padding:90px 48px}
.rooms-section .section-title{color:var(--cream)}
.rooms-intro{font-size:.84rem;line-height:1.8;color:rgba(245,240,232,.55);max-width:360px;margin-top:16px}
.rooms-header{display:flex;justify-content:space-between;align-items:flex-end;max-width:1200px;margin:0 auto 48px}
.rooms-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;max-width:1200px;margin:0 auto}
.rooms-grid .room-main{grid-column:span 2}
.room-card{position:relative;overflow:hidden;aspect-ratio:4/3}
.room-card.room-main{aspect-ratio:16/9}
.room-img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.22,1,.36,1);display:block}
.room-card:hover .room-img{transform:scale(1.06)}
.room-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(26,18,9,.9) 0%,transparent 55%);display:flex;flex-direction:column;justify-content:flex-end;padding:28px 24px;transition:background .4s}
.room-card:hover .room-overlay{background:linear-gradient(to top,rgba(26,18,9,.96) 0%,rgba(26,18,9,.15) 100%)}
.room-name{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:300;color:var(--cream)}
.room-detail{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-top:5px}
/* GALLERY STRIP */
.gallery-strip{display:flex;gap:3px;overflow-x:auto;scrollbar-width:none}
.gallery-strip::-webkit-scrollbar{display:none}
.gallery-strip img{flex:0 0 260px;height:340px;object-fit:cover;transition:flex .4s,filter .3s;filter:saturate(.85)}
.gallery-strip img:hover{flex:0 0 400px;filter:saturate(1.1)}
/* RESTAURANT */
.rest-grid{display:grid;grid-template-columns:1fr 1fr;min-height:520px;max-width:1200px;margin:0 auto}
.rest-img img{width:100%;height:100%;object-fit:cover;display:block}
.rest-content{padding:72px 56px;display:flex;flex-direction:column;justify-content:center}
.rest-content p{font-size:.86rem;line-height:1.85;color:var(--mid);opacity:.8;margin-top:18px}
.menu-list{margin-top:28px;border-top:1px solid rgba(44,31,20,.15)}
.menu-row{display:flex;justify-content:space-between;align-items:baseline;padding:15px 0;border-bottom:1px solid rgba(44,31,20,.1)}
.menu-name{font-family:'Cormorant Garamond',serif;font-size:1.05rem;color:var(--brown)}
.menu-desc{font-size:.62rem;color:var(--mid);opacity:.55;margin-top:2px}
.menu-price{font-family:'Cormorant Garamond',serif;font-size:.95rem;color:var(--gold);font-style:italic;margin-left:20px;white-space:nowrap}
/* EXPERIENCES */
.exp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;max-width:1200px;margin:48px auto 0}
.exp-card{background:white;padding:32px 26px;position:relative;overflow:hidden;transition:transform .3s,box-shadow .3s}
.exp-card::after{content:'';position:absolute;bottom:0;left:0;width:0;height:3px;background:var(--gold);transition:width .35s}
.exp-card:hover::after{width:100%}
.exp-card:hover{transform:translateY(-5px);box-shadow:0 20px 50px rgba(44,31,20,.1)}
.exp-icon{font-size:1.8rem;display:block;margin-bottom:16px}
.exp-name{font-family:'Cormorant Garamond',serif;font-size:1.2rem;font-weight:400;color:var(--brown);margin-bottom:10px}
.exp-desc{font-size:.78rem;line-height:1.75;color:var(--mid);opacity:.7}
/* EVENTS */
.events-section{background:var(--dark);padding:90px 48px}
.events-section .section-title{color:var(--cream)}
.events-grid{display:grid;grid-template-columns:1fr 1fr;gap:3px;max-width:1200px;margin:40px auto 0}
.event-card{position:relative;overflow:hidden;aspect-ratio:4/3}
.event-card img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .7s}
.event-card:hover img{transform:scale(1.05)}
.event-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(26,18,9,.88),transparent 55%);display:flex;flex-direction:column;justify-content:flex-end;padding:28px}
.event-title{font-family:'Cormorant Garamond',serif;font-size:1.3rem;color:var(--cream)}
.event-sub{font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-top:5px}
/* RENTAL */
.rental{position:relative;overflow:hidden;min-height:500px;display:flex;align-items:center;padding:90px 48px}
.rental-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.rental-overlay{position:absolute;inset:0;background:linear-gradient(100deg,rgba(26,18,9,.92) 45%,rgba(26,18,9,.45) 100%)}
.rental-content{position:relative;z-index:2;max-width:600px}
.rental-content .section-title{color:var(--cream)}
.rental-content p{font-size:.88rem;line-height:1.85;color:rgba(245,240,232,.7);margin:22px 0 28px}
.tags{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:32px}
.tag{border:1px solid rgba(212,173,69,.5);padding:6px 16px;font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-l)}
/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;max-width:1200px;margin:0 auto}
.detail-list{margin-top:32px}
.detail{display:flex;gap:16px;padding:14px 0;border-bottom:1px solid rgba(44,31,20,.1)}
.detail-icon{font-size:1rem;flex-shrink:0;margin-top:2px}
.detail-label{font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:4px}
.detail-val{font-size:.82rem;color:var(--mid)}
.map-img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
/* RESERVE */
.reserve{background:var(--gold);padding:80px 48px;text-align:center}
.reserve h2{font-family:'Cormorant Garamond',serif;font-size:clamp(2.4rem,6vw,4rem);font-weight:300;color:var(--dark);margin-bottom:12px}
.reserve p{font-size:.78rem;letter-spacing:.12em;color:var(--mid);margin-bottom:32px}
.btn-dark{background:var(--dark);color:var(--cream);padding:16px 50px;font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;text-decoration:none;font-family:'Josefin Sans';font-weight:300;display:inline-block;transition:background .2s,transform .2s}
.btn-dark:hover{background:var(--brown);transform:translateY(-2px)}
/* FOOTER */
footer{background:var(--dark);padding:60px 48px 28px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;max-width:1200px;margin:0 auto 48px;padding-bottom:48px;border-bottom:1px solid rgba(245,240,232,.08)}
.footer-logo{font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:300;color:var(--cream);margin-bottom:14px}
.footer-logo span{color:var(--gold);font-style:italic}
.footer-tag{font-size:.76rem;line-height:1.8;color:rgba(245,240,232,.45);max-width:250px}
.footer-col h4{font-size:.58rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:9px}
.footer-col a{font-size:.78rem;color:rgba(245,240,232,.5);text-decoration:none;transition:color .2s}
.footer-col a:hover{color:var(--gold-l)}
.footer-bottom{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;font-size:.62rem;color:rgba(245,240,232,.3);letter-spacing:.08em}
.socials{display:flex;gap:20px}
.socials a{color:rgba(245,240,232,.4);text-decoration:none;font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;transition:color .2s}
.socials a:hover{color:var(--gold)}
@media(max-width:1024px){nav{padding:18px 24px}.nav-links{display:none}.about-grid,.rest-grid,.contact-grid{grid-template-columns:1fr}.rooms-grid{grid-template-columns:1fr 1fr}.rooms-grid .room-main{grid-column:auto}.exp-grid{grid-template-columns:1fr 1fr}.footer-grid{grid-template-columns:1fr 1fr}section,.rooms-section,.events-section,.rental{padding:64px 24px}}
@media(max-width:640px){.rooms-grid,.exp-grid,.events-grid{grid-template-columns:1fr}.strip{display:none}.hero-btns{flex-direction:column;align-items:center}.footer-grid{grid-template-columns:1fr}.rental{padding:64px 24px}.img-tag{display:none}}

/* ── NAV MÓVIL ── */
.nav-toggle { display:none; background:none; border:1px solid rgba(245,240,232,.4); color:var(--cream); padding:8px 14px; font-size:1.1rem; cursor:pointer; }
@media(max-width:1024px) {
  .nav-toggle { display:block; }
  .nav-links { display:none; flex-direction:column; position:absolute; top:100%; left:0; width:100%; background:rgba(26,18,9,.97); padding:20px 24px; gap:16px; }
  .nav-links.open { display:flex; }
  .nav-links a { font-size:.78rem; padding:8px 0; border-bottom:1px solid rgba(245,240,232,.08); }
  .nav-cta { border:none !important; border-bottom:none !important; }
}

/* ── TARIFAS ── */
.tarifas-section { background:var(--ivory); padding:90px 48px; }
.tarifas-inner { max-width:1200px; margin:0 auto; }
.tarifas-grid { display:grid; grid-template-columns:1fr 1fr; gap:32px; }
.tarifa-block { background:white; border:1px solid rgba(44,31,20,.1); padding:32px; }
.tarifa-title { font-family:'Cormorant Garamond',serif; font-size:1.3rem; font-weight:400; color:var(--brown); margin-bottom:20px; padding-bottom:14px; border-bottom:2px solid var(--gold); }
.tarifa-cap { display:block; font-family:'Josefin Sans',sans-serif; font-size:.6rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); margin-top:4px; font-style:normal; }
.tarifa-rows { display:flex; flex-direction:column; }
.tarifa-row { display:flex; justify-content:space-between; align-items:baseline; padding:11px 0; border-bottom:1px solid rgba(44,31,20,.07); font-size:.82rem; color:var(--mid); flex-wrap:wrap; gap:8px; }
.tarifa-row small { font-size:.68rem; opacity:.6; }
.tarifa-prices { font-family:'Cormorant Garamond',serif; font-size:.95rem; color:var(--gold); white-space:nowrap; }
.tarifa-prices em { font-size:.6rem; font-family:'Josefin Sans',sans-serif; font-style:normal; letter-spacing:.12em; text-transform:uppercase; color:var(--mid); opacity:.7; }

/* ── RESERVE BTNS ── */
.reserve-btns { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }
.btn-dark-outline { border:2px solid var(--dark); color:var(--dark); padding:15px 36px; font-size:.68rem; letter-spacing:.2em; text-transform:uppercase; text-decoration:none; font-family:'Josefin Sans',sans-serif; font-weight:300; display:inline-block; transition:all .2s; }
.btn-dark-outline:hover { background:var(--dark); color:var(--cream); }

/* ── MAP IMG ── */
.map-img { width:100%; aspect-ratio:4/3; object-fit:cover; display:block; }

/* ── EXP SECTION ── */
.exp-section { background:var(--ivory); padding:90px 48px; }
.exp-header { max-width:1200px; margin:0 auto 0; text-align:center; }

/* ── EVENTS INNER ── */
.events-inner { max-width:1200px; margin:0 auto; padding:0 0 40px; }

/* ── RESPONSIVE tarifas y reserve ── */
@media(max-width:768px) {
  .tarifas-grid { grid-template-columns:1fr; }
  .tarifa-row { flex-direction:column; }
  .tarifa-prices { margin-top:4px; }
  .reserve-btns { flex-direction:column; align-items:center; }
  .tarifas-section { padding:64px 24px; }
}

/* ── CARTA RACIONES (thumbnail + lightbox) ── */
.carta-wrap { margin-top:28px; }
.carta-label { font-size:.6rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin-bottom:10px; }
.carta-thumb { display:inline-block; position:relative; overflow:hidden; border:1px solid rgba(44,31,20,.15); cursor:zoom-in; max-width:160px; }
.carta-thumb img { width:160px; height:220px; object-fit:cover; object-position:top; display:block; transition:transform .4s; filter:brightness(.95); }
.carta-thumb:hover img { transform:scale(1.04); filter:brightness(1); }
.carta-zoom { position:absolute; inset:0; background:rgba(26,18,9,.55); color:var(--cream); display:flex; align-items:center; justify-content:center; font-family:'Josefin Sans',sans-serif; font-size:.62rem; letter-spacing:.15em; text-transform:uppercase; opacity:0; transition:opacity .3s; text-align:center; padding:8px; }
.carta-thumb:hover .carta-zoom { opacity:1; }

/* Lightbox overlay */
.lightbox { display:none; position:fixed; inset:0; z-index:9999; background:rgba(26,18,9,.92); align-items:center; justify-content:center; padding:24px; }
.lightbox.active { display:flex; }
.lightbox img { max-width:90vw; max-height:90vh; object-fit:contain; display:block; box-shadow:0 40px 80px rgba(0,0,0,.6); animation:fadeUp .3s both; }
.lightbox-close { position:absolute; top:20px; right:24px; background:none; border:1px solid rgba(245,240,232,.3); color:var(--cream); font-size:1.2rem; width:40px; height:40px; cursor:pointer; transition:all .2s; border-radius:0; }
.lightbox-close:hover { background:var(--gold); border-color:var(--gold); color:var(--dark); }

/* ── LEGIBILIDAD: textos más oscuros sobre fondos claros ── */

/* Párrafos sobre fondo ivory/cream */
.about-text p,
.rest-content p,
.exp-desc,
.rooms-intro,
.tarifa-row,
.footer-tag {
  color: #1a1209 !important;
  opacity: 1 !important;
}

/* Labels dorados — más oscuros */
.label {
  color: #8a6a10 !important;
}

/* Subtítulos de menú y tarifa */
.menu-desc,
.tarifa-row small {
  color: #3d2b1a !important;
  opacity: 1 !important;
}

/* Texto de nota al pie tarifas */
.tarifas-section p[style] {
  color: #3d2b1a !important;
  opacity: 1 !important;
}

/* Títulos de sección sobre fondo claro */
.section-title {
  color: #1a1209 !important;
}

/* Nombres de experiencias */
.exp-name {
  color: #1a1209 !important;
}

/* Tarifa title */
.tarifa-title {
  color: #1a1209 !important;
}

/* ── FIX TARIFAS: forzar visibilidad (el reveal no dispara en esa sección) ── */
.tarifas-grid,
.tarifas-grid .tarifa-block,
.tarifas-inner h2,
.tarifas-inner p {
  opacity: 1 !important;
  transform: none !important;
}

/* ── FIX GLOBAL: forzar visibilidad de todos los elementos reveal ──
   El IntersectionObserver no dispara en algunas secciones.
   Se mantiene la animación solo si JS la activa correctamente. */
.reveal {
  opacity: 1 !important;
  transform: none !important;
}

/* Mantener transición suave cuando SÍ entra en vista */
.reveal.in {
  opacity: 1 !important;
  transform: none !important;
}

/* ── TAMAÑOS DE TEXTO: aumentar legibilidad global ── */
body {
  font-size: 16px !important;
}

/* Párrafos principales */
.about-text p,
.rest-content p,
.rental-content p {
  font-size: 1rem !important;
  line-height: 1.9 !important;
  color: #1a1209 !important;
  opacity: 1 !important;
}

/* Descripciones de tarjetas experiencias */
.exp-desc {
  font-size: .92rem !important;
  line-height: 1.8 !important;
  color: #1a1209 !important;
  opacity: 1 !important;
}

/* Nombres de experiencias */
.exp-name {
  font-size: 1.2rem !important;
  color: #1a1209 !important;
}

/* Filas de tarifas */
.tarifa-row {
  font-size: .92rem !important;
  color: #1a1209 !important;
  opacity: 1 !important;
}

/* Detalles de contacto */
.detail-val {
  font-size: .92rem !important;
  color: #1a1209 !important;
}

.detail-val a {
  color: #1a1209 !important;
}

/* Intro de habitaciones */
.rooms-intro {
  font-size: .92rem !important;
  color: #1a1209 !important;
  opacity: 1 !important;
}

/* Texto de casa rural */
.rental-content p {
  color: rgba(245,240,232,.9) !important;
}

/* Nota al pie tarifas */
.tarifas-section > .tarifas-inner > p:last-child {
  font-size: .78rem !important;
  color: #3d2b1a !important;
  opacity: 1 !important;
}

/* Texto intro tarifas */
.tarifas-inner > p {
  font-size: .95rem !important;
  color: #1a1209 !important;
  opacity: 1 !important;
}

/* Labels (etiquetas doradas pequeñas) */
.label {
  font-size: .68rem !important;
  color: #8a6a10 !important;
  opacity: 1 !important;
}

/* Footer */
.footer-tag {
  font-size: .82rem !important;
  color: rgba(245,240,232,.7) !important;
  opacity: 1 !important;
}

.footer-col a {
  font-size: .84rem !important;
  color: rgba(245,240,232,.65) !important;
}
