:root {
  --verde: #2d5a27;
  --verde-claro: #4a7c3f;
  --dorado: #c9a84c;
  --dorado-claro: #e8c96d;
  --crema: #f8f4ed;
  --blanco: #ffffff;
  --gris-oscuro: #1a1a1a;
  --gris: #555;
  --gris-claro: #f0ece5;
  --sombra: 0 4px 24px rgba(0,0,0,0.12);
  --sombra-hover: 0 8px 40px rgba(0,0,0,0.2);
  --radio: 12px;
  --transicion: 0.3s ease;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Inter',sans-serif;color:var(--gris-oscuro);background:var(--crema);line-height:1.7;}
a{text-decoration:none;color:inherit;}
img{max-width:100%;display:block;}
ul{list-style:none;}

/* ── NAVBAR ── */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;transition:background var(--transicion),box-shadow var(--transicion);}
.site-header.scrolled{background:rgba(255,255,255,0.97);box-shadow:var(--sombra);}
.navbar{display:flex;align-items:center;justify-content:space-between;padding:1rem 3rem;max-width:1400px;margin:0 auto;}
.logo{display:flex;align-items:center;gap:.75rem;color:var(--blanco);}
.site-header.scrolled .logo{color:var(--verde);}
.logo-icon{font-size:1.8rem;color:var(--dorado);}
.logo-name{display:block;font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:700;line-height:1.1;}
.logo-sub{display:block;font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;opacity:.8;}
.nav-links{display:flex;align-items:center;gap:.25rem;}
.nav-link{padding:.5rem 1rem;color:var(--blanco);font-size:.9rem;font-weight:500;border-radius:6px;transition:all var(--transicion);position:relative;}
.site-header.scrolled .nav-link{color:var(--gris-oscuro);}
.nav-link:hover,.nav-link.active{color:var(--dorado);}
.nav-btn{background:var(--dorado);color:var(--gris-oscuro)!important;padding:.6rem 1.4rem;border-radius:50px;font-weight:600;margin-left:.5rem;transition:all var(--transicion);}
.nav-btn:hover{background:var(--dorado-claro);transform:translateY(-2px);box-shadow:0 4px 16px rgba(201,168,76,.4);}
.menu-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.5rem;}
.menu-toggle span{display:block;width:25px;height:2px;background:var(--blanco);transition:all var(--transicion);}
.site-header.scrolled .menu-toggle span{background:var(--gris-oscuro);}

/* ── HERO ── */
.hero{position:relative;height:100vh;min-height:600px;display:flex;align-items:center;justify-content:center;overflow:hidden;}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;}
.hero-bg::after{content:'';position:absolute;inset:0;background:rgba(0,0,0,0.2);}
.hero-content{position:relative;z-index:1;text-align:center;color:var(--blanco);padding:0 1rem;transform:translateY(-8vh);}
.hero-badge{display:inline-flex;align-items:center;gap:.4rem;background:rgba(201,168,76,.2);border:1px solid var(--dorado);color:var(--dorado-claro);padding:.35rem 1rem;border-radius:50px;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:1.5rem;backdrop-filter:blur(8px);}
.hero-title{font-family:'Playfair Display',serif;font-size:clamp(2.5rem,6vw,5rem);font-weight:700;line-height:1.15;margin-bottom:1rem;text-shadow:0 2px 20px rgba(0,0,0,0.5);}
.hero-title span{color:var(--dorado-claro);}
.hero-subtitle{font-size:clamp(1rem,2vw,1.25rem);opacity:.9;max-width:600px;margin:0 auto 28vh;text-shadow:0 1px 10px rgba(0,0,0,0.5);}
.hero-ctas{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;}
.btn-primary{background:var(--dorado);color:var(--gris-oscuro);padding:.85rem 2rem;border-radius:50px;font-weight:700;font-size:.95rem;transition:all var(--transicion);border:2px solid var(--dorado);}
.btn-primary:hover{background:var(--dorado-claro);transform:translateY(-3px);box-shadow:0 8px 24px rgba(201,168,76,.5);}
.btn-outline{background:transparent;color:var(--blanco);padding:.85rem 2rem;border-radius:50px;font-weight:600;font-size:.95rem;border:2px solid rgba(255,255,255,0.7);transition:all var(--transicion);}
.btn-outline:hover{background:rgba(255,255,255,0.15);border-color:var(--blanco);transform:translateY(-3px);}
.hero-scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);color:var(--blanco);opacity:.7;animation:bounce 2s infinite;font-size:1.5rem;}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0);}50%{transform:translateX(-50%) translateY(-10px);}}

/* ── BOOKING BAR ── */
.booking-bar{background:var(--blanco);box-shadow:var(--sombra);padding:1.5rem 3rem;position:relative;z-index:10;}
.booking-form{display:flex;gap:1rem;align-items:flex-end;max-width:1100px;margin:0 auto;flex-wrap:wrap;}
.booking-field{flex:1;min-width:180px;}
.booking-field label{display:block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--gris);margin-bottom:.4rem;}
.booking-field input,.booking-field select{width:100%;padding:.7rem 1rem;border:1.5px solid #e0d9ce;border-radius:8px;font-family:'Inter',sans-serif;font-size:.95rem;background:var(--crema);color:var(--gris-oscuro);transition:border-color var(--transicion);}
.booking-field input:focus,.booking-field select:focus{outline:none;border-color:var(--dorado);}
.btn-booking{background:var(--verde);color:var(--blanco);padding:.8rem 2rem;border-radius:8px;border:none;font-family:'Inter',sans-serif;font-weight:600;font-size:.95rem;cursor:pointer;transition:all var(--transicion);white-space:nowrap;}
.btn-booking:hover{background:var(--verde-claro);transform:translateY(-2px);}

/* ── SECCIONES ── */
.section{padding:5rem 1.5rem;}
.section-alt{background:var(--gris-claro);}
.container{max-width:1200px;margin:0 auto;}
.section-header{text-align:center;margin-bottom:3.5rem;}
.section-label{display:inline-block;color:var(--dorado);font-size:.8rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;margin-bottom:.75rem;}
.section-title{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,2.8rem);font-weight:700;color:var(--gris-oscuro);margin-bottom:1rem;}
.section-title span{color:var(--verde);}
.section-desc{color:var(--gris);max-width:600px;margin:0 auto;font-size:1.05rem;}
.divider{width:60px;height:3px;background:linear-gradient(90deg,var(--dorado),var(--verde));margin:.75rem auto 0;border-radius:2px;}

/* ── CARDS HABITACIONES ── */
.rooms-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,500px));justify-content:center;gap:2rem;}
.room-card{background:var(--blanco);border-radius:var(--radio);overflow:hidden;box-shadow:var(--sombra);transition:all var(--transicion);}
.room-card:hover{transform:translateY(-8px);box-shadow:var(--sombra-hover);}
.room-img{height:240px;overflow:hidden;position:relative;}
.room-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;}
.room-card:hover .room-img img{transform:scale(1.08);}
.room-badge{position:absolute;top:1rem;left:1rem;background:var(--dorado);color:var(--gris-oscuro);padding:.3rem .75rem;border-radius:50px;font-size:.75rem;font-weight:700;z-index:10;}
.room-body{padding:1.5rem;}
.room-name{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:700;margin-bottom:.5rem;}
.room-desc{color:var(--gris);font-size:.9rem;margin-bottom:1rem;line-height:1.6;}
.room-features{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:1.25rem;}
.room-feature{display:flex;align-items:flex-start;gap:.4rem;font-size:.85rem;color:var(--gris);background:var(--crema);padding:.4rem .75rem;border-radius:10px;line-height:1.35;max-width:250px;}
.room-feature i{color:var(--verde);margin-top:2px;font-size:.85rem;}
.room-footer{display:flex;align-items:center;justify-content:space-between;border-top:1px solid #ece7df;padding-top:1.25rem;}
.room-price{display:flex;flex-direction:column;}
.room-price-amount{font-size:1.6rem;font-weight:700;color:var(--verde);line-height:1;}
.room-price-label{font-size:.75rem;color:var(--gris);}
.btn-room{background:var(--verde);color:var(--blanco);padding:.6rem 1.25rem;border-radius:50px;font-size:.85rem;font-weight:600;transition:all var(--transicion);}
.btn-room:hover{background:var(--verde-claro);}

/* ── CARDS HABITACIONES (FULL WIDTH) ── */
.room-card-full{display:grid;grid-template-columns:400px 1fr;background:#fff;border-radius:var(--radio);overflow:hidden;box-shadow:var(--sombra);margin-bottom:3rem;transition:all .3s;}
.room-card-full:hover{box-shadow:var(--sombra-hover);transform:translateY(-5px);}
.room-card-img{position:relative;overflow:hidden;background:#000;}
.room-card-img img{width:100%;height:100%;object-fit:cover;transition:opacity .5s ease, transform .6s;}
.room-card-full:hover .room-card-img img{transform:scale(1.05);}

/* Slider */
.room-slider { position: relative; width: 100%; height: 100%; }
.slider-track { width: 100%; height: 100%; position: relative; }
.slider-track img { position: absolute; top: 0; left: 0; opacity: 0; z-index: 1; }
.slider-track img.active { opacity: 1; z-index: 2; }
.slider-nav { position: absolute; top: 50%; transform: translateY(-50%); z-index: 10; background: rgba(255,255,255,0.8); border: none; width: 36px; height: 36px; border-radius: 50%; cursor: pointer; color: var(--verde); display: flex; align-items: center; justify-content: center; transition: all .3s; }
.slider-nav:hover { background: #fff; transform: translateY(-50%) scale(1.1); }
.slider-nav.prev { left: 10px; }
.slider-nav.next { right: 10px; }

.room-season-indicator{position:absolute; bottom: 1rem; left: 1rem; background: #fff; padding: 6px 12px; border-radius: 20px; font-size: .75rem; font-weight: 700; display: flex; align-items: center; gap: .5rem; box-shadow: 0 4px 10px rgba(0,0,0,0.1); z-index: 15;}
.pulse-dot{width: 8px; height: 8px; border-radius: 50%; animation: pulse 2s infinite;}
@keyframes pulse { 0% { transform: scale(0.95); opacity: 0.7; } 70% { transform: scale(1.2); opacity: 1; } 100% { transform: scale(0.95); opacity: 0.7; } }
.room-card-body{padding:2.5rem;}
.temp-list{display: flex; flex-direction: column; gap: .5rem;}
.temp-item{display: flex; justify-content: space-between; padding: .6rem .8rem; background: #f9f7f2; border-radius: 6px; font-size: .85rem;}
.temp-item strong{color: var(--verde)}
@media(max-width:991px){
  .room-card-full{grid-template-columns:1fr;}
  .room-card-img{height:280px;}
  .room-card-body{padding:2rem;}
}
@media(max-width:600px){
  .room-card-body > div { grid-template-columns: 1fr !important; gap: 1.5rem !important; }
}

/* ── OFERTAS ── */
.ofertas-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,500px));justify-content:center;gap:2rem;}
.oferta-card{border-radius:var(--radio);overflow:hidden;position:relative;box-shadow:var(--sombra);transition:all var(--transicion);}
.oferta-card:hover{transform:translateY(-6px);box-shadow:var(--sombra-hover);}
.oferta-img{height:220px;overflow:hidden;}
.oferta-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s;}
.oferta-card:hover .oferta-img img{transform:scale(1.08);}
.oferta-descuento{position:absolute;top:1rem;right:1rem;background:var(--dorado);color:var(--gris-oscuro);font-weight:800;font-size:1.1rem;width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-direction:column;line-height:1;box-shadow:0 4px 12px rgba(0,0,0,.2);}
.oferta-descuento small{font-size:.55rem;font-weight:600;}
.oferta-body{background:var(--blanco);padding:1.25rem 1.5rem;}
.oferta-title{font-family:'Playfair Display',serif;font-size:1.15rem;font-weight:700;margin-bottom:.4rem;}
.oferta-desc{color:var(--gris);font-size:.875rem;margin-bottom:1rem;}
.oferta-valido{font-size:.75rem;color:var(--dorado);font-weight:600;}
.btn-oferta{display:inline-block;background:var(--verde);color:var(--blanco);padding:.55rem 1.25rem;border-radius:50px;font-size:.85rem;font-weight:600;margin-top:.75rem;transition:all var(--transicion);}
.btn-oferta:hover{background:var(--verde-claro);}

/* ── AMENIDADES ── */
.amenities-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:2rem;margin-top:2rem;}
.amenity-item{background:var(--blanco);padding:2.5rem 1.5rem;border-radius:15px;text-align:center;box-shadow:0 10px 30px rgba(0,0,0,0.05);transition:all .3s ease;border:1px solid #f0f0f0;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.amenity-item:hover{transform:translateY(-10px);box-shadow:0 15px 40px rgba(0,0,0,0.1);border-color:var(--verde-claro);}
.amenity-icon-circle{width:70px;height:70px;background:var(--verde);color:var(--blanco);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;font-size:1.8rem;transition:all .3s ease;}
.amenity-item:hover .amenity-icon-circle{background:var(--verde-claro);transform:rotateY(360deg);}
.amenity-name{font-family:'Playfair Display',serif;font-size:1.15rem;font-weight:700;color:var(--gris-oscuro);margin-bottom:.5rem;display:block;}
.amenity-desc{font-size:.85rem;color:var(--gris);display:block;line-height:1.5;margin:0;}

/* ── GALERÍA ── */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;}
.gallery-item{border-radius:10px;overflow:hidden;position:relative;cursor:pointer;}
.gallery-item img{width:100%;height:220px;object-fit:cover;transition:transform .5s ease;}
.gallery-item:hover img{transform:scale(1.08);}
.gallery-overlay{position:absolute;inset:0;background:rgba(0,0,0,0);display:flex;align-items:center;justify-content:center;transition:background .3s;}
.gallery-item:hover .gallery-overlay{background:rgba(0,0,0,.35);}
.gallery-overlay i{color:var(--blanco);font-size:2rem;opacity:0;transform:scale(.5);transition:all .3s;}
.gallery-item:hover .gallery-overlay i{opacity:1;transform:scale(1);}

/* ── ENTORNO ── */
.entorno-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;}
.entorno-img{border-radius:var(--radio);overflow:hidden;box-shadow:var(--sombra-hover);}
.entorno-img img{width:100%;height:400px;object-fit:cover;}
.entorno-list{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem;}
.entorno-item{display:flex;align-items:flex-start;gap:1rem;padding:1rem;background:var(--blanco);border-radius:10px;box-shadow:0 2px 12px rgba(0,0,0,.06);}
.entorno-item-icon{width:44px;height:44px;min-width:44px;background:var(--crema);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--verde);font-size:1.1rem;}
.entorno-item h4{font-size:.95rem;font-weight:600;margin-bottom:.15rem;}
.entorno-item p{font-size:.82rem;color:var(--gris);}

/* ── REVIEWS ── */
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;}
.review-card{background:var(--blanco);border-radius:var(--radio);padding:1.75rem;box-shadow:var(--sombra);transition:all var(--transicion);}
.review-card:hover{transform:translateY(-4px);}
.review-stars{color:var(--dorado);font-size:1rem;margin-bottom:.75rem;}
.review-text{color:var(--gris);font-size:.92rem;font-style:italic;margin-bottom:1.25rem;line-height:1.7;}
.review-author{display:flex;align-items:center;gap:.75rem;}
.review-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--verde),var(--dorado));display:flex;align-items:center;justify-content:center;color:var(--blanco);font-weight:700;font-size:.9rem;}
.review-name{font-weight:600;font-size:.9rem;}
.review-date{font-size:.75rem;color:var(--gris);}
.score-badge{display:inline-flex;align-items:center;gap:.5rem;background:var(--verde);color:var(--blanco);padding:.5rem 1.25rem;border-radius:50px;font-size:1.1rem;font-weight:700;margin-bottom:.5rem;}

/* ── CONTACTO ── */
.contacto-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;}
.contacto-form{background:var(--blanco);padding:2.5rem;border-radius:var(--radio);box-shadow:var(--sombra);}
.form-group{margin-bottom:1.25rem;}
.form-group label{display:block;font-size:.82rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--gris);margin-bottom:.4rem;}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:.8rem 1rem;border:1.5px solid #e0d9ce;border-radius:8px;font-family:'Inter',sans-serif;font-size:.95rem;background:var(--crema);transition:border-color var(--transicion);}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--verde);}
.form-group textarea{height:130px;resize:vertical;}
.btn-submit{background:var(--verde);color:var(--blanco);padding:.85rem 2rem;border:none;border-radius:50px;font-family:'Inter',sans-serif;font-weight:600;font-size:1rem;cursor:pointer;transition:all var(--transicion);width:100%;}
.btn-submit:hover{background:var(--verde-claro);transform:translateY(-2px);}
.contacto-info{display:flex;flex-direction:column;gap:1.5rem;}
.contacto-info-item{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem;background:var(--blanco);border-radius:10px;box-shadow:var(--sombra);}
.contacto-info-icon{width:48px;height:48px;min-width:48px;background:linear-gradient(135deg,var(--verde),var(--verde-claro));border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--blanco);font-size:1.2rem;}
.contacto-info-item h4{font-weight:600;margin-bottom:.2rem;}
.contacto-info-item p,.contacto-info-item a{color:var(--gris);font-size:.9rem;}
.mapa-container{border-radius:var(--radio);overflow:hidden;box-shadow:var(--sombra);height:450px;background:var(--gris-claro);display:flex;align-items:center;justify-content:center;margin-top:1.5rem;}
.mapa-container iframe{width:100%;height:100%;border:0;}

/* ── STATS ── */
.stats-section{background:linear-gradient(135deg,var(--verde) 0%,var(--verde-claro) 100%);padding:4rem 1.5rem;}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:2rem;max-width:1000px;margin:0 auto;text-align:center;color:var(--blanco);}
.stat-number{font-family:'Playfair Display',serif;font-size:3rem;font-weight:700;color:var(--dorado-claro);}
.stat-label{font-size:.9rem;opacity:.85;margin-top:.25rem;}

/* ── FOOTER ── */
.site-footer{background:var(--gris-oscuro);color:rgba(255,255,255,.8);}
.footer-top{padding:4rem 3rem 3rem;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:3rem;max-width:1200px;margin:0 auto;}
.footer-logo{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;color:var(--blanco);}
.footer-logo i{font-size:1.8rem;color:var(--dorado);}
.footer-logo-name{display:block;font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;color:var(--blanco);}
.footer-logo-sub{display:block;font-size:.65rem;color:var(--dorado);letter-spacing:.1em;text-transform:uppercase;}
.footer-desc{font-size:.87rem;line-height:1.7;margin-bottom:1.25rem;}
.footer-social{display:flex;gap:.75rem;}
.footer-social a{width:36px;height:36px;background:rgba(255,255,255,.1);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--blanco);transition:all var(--transicion);}
.footer-social a:hover{background:var(--dorado);color:var(--gris-oscuro);}
.footer-col h4{font-family:'Playfair Display',serif;font-size:1rem;color:var(--blanco);margin-bottom:1.25rem;padding-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.1);}
.footer-col ul li{margin-bottom:.6rem;font-size:.87rem;display:flex;align-items:flex-start;gap:.5rem;}
.footer-col ul li i{color:var(--dorado);margin-top:4px;min-width:14px;}
.footer-col ul a:hover{color:var(--dorado);}
.footer-btn{display:inline-block;background:var(--dorado);color:var(--gris-oscuro);padding:.7rem 1.5rem;border-radius:50px;font-weight:700;font-size:.9rem;margin-bottom:1rem;transition:all var(--transicion);}
.footer-btn:hover{background:var(--dorado-claro);}
.footer-badges{display:flex;flex-direction:column;gap:.4rem;}
.footer-badges span{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:rgba(255,255,255,.6);}
.footer-badges i{color:var(--dorado);}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:1.25rem 3rem;display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;font-size:.83rem;color:rgba(255,255,255,.45);}
.footer-bottom a{color:rgba(255,255,255,.4);transition:color var(--transicion);}
.footer-bottom a:hover{color:var(--dorado);}

/* ── HERO PAGES ── */
.page-hero{height:40vh;min-height:280px;position:relative;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--blanco);}
.page-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;}
.page-hero-bg::after{content:'';position:absolute;inset:0;background:rgba(0,0,0,.55);}
.page-hero-content{position:relative;z-index:1;}
.page-hero-content h1{font-family:'Playfair Display',serif;font-size:clamp(2rem,5vw,3.5rem);font-weight:700;margin-bottom:.5rem;}
.page-hero-content p{font-size:1.1rem;opacity:.85;}

/* ── ALERT MESSAGES ── */
.alert{padding:1rem 1.5rem;border-radius:8px;margin-bottom:1.25rem;font-size:.92rem;}
.alert-success{background:#d4edda;color:#155724;border:1px solid #c3e6cb;}
.alert-error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb;}
.alert-info{background:#d1ecf1;color:#0c5460;border:1px solid #bee5eb;}

/* ── RESPONSIVE ── */
@media(max-width:1100px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:900px){
  .contacto-grid,.entorno-grid{grid-template-columns:1fr;}
  .navbar{padding:1rem 1.5rem;}
  .footer-top{padding:3rem 1.5rem;}
}
@media(max-width:768px){
  .nav-links{display:none;position:fixed;top:0;right:0;bottom:0;width:280px;background:rgba(255,255,255,.98);flex-direction:column;align-items:flex-start;padding:5rem 2rem 2rem;gap:.5rem;box-shadow:-4px 0 20px rgba(0,0,0,.15);z-index:999;}
  .nav-links.open{display:flex;}
  .nav-link{color:var(--gris-oscuro)!important;width:100%;padding:.75rem 1rem;}
  .menu-toggle{display:flex;z-index:1000;}
  .footer-grid{grid-template-columns:1fr;}
  .footer-bottom{flex-direction:column;gap:.5rem;text-align:center;}
  .booking-form{flex-direction:column;}
  .booking-field{min-width:100%;}
}

/* ── LIGHTBOX ── */
.lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:9999;align-items:center;justify-content:center;}
.lightbox.active{display:flex;}
.lightbox img{max-width:90vw;max-height:85vh;border-radius:8px;object-fit:contain;}
.lightbox-close{position:absolute;top:1.5rem;right:1.5rem;color:var(--blanco);font-size:2rem;cursor:pointer;background:none;border:none;}
.lightbox-prev,.lightbox-next{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.15);border:none;color:var(--blanco);font-size:1.5rem;width:50px;height:50px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transicion);}
.lightbox-prev{left:1.5rem;}
.lightbox-next{right:1.5rem;}
.lightbox-prev:hover,.lightbox-next:hover{background:rgba(255,255,255,.3);}

/* ── ANIMATIONS ── */
.fade-up{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease;}
.fade-up.visible{opacity:1;transform:translateY(0);}


