/* =============================================
   VISTA HERMOSA — DARK EDITION
   ============================================= */

:root {
  --fondo-base:      #070C09;
  --fondo-card:      #0E1610;
  --fondo-elevado:   #141F16;
  --fondo-medio:     #1A2A1D;
  --fondo-superficie:#203024;
  --verde-bosque:    #1B4332;
  --verde-medio:     #2D6A4F;
  --verde-claro:     #52B788;
  --verde-glow:      #74C69D;
  --dorado:          #C9A030;
  --dorado-claro:    #E4BF58;
  --texto:           #D8EDE0;
  --texto-suave:     #7A9E87;
  --texto-muted:     #4A6B54;
  --borde:           rgba(82,183,136,.1);
  --borde-suave:     rgba(255,255,255,.05);
  --blanco:          #FFFFFF;
  --fuente-display: 'Playfair Display', Georgia, serif;
  --fuente-body:    'Raleway', sans-serif;
  --radio:          6px;
  --sombra-suave:   0 4px 30px rgba(0,0,0,.4);
  --sombra-media:   0 12px 50px rgba(0,0,0,.6);
  --sombra-glow:    0 0 40px rgba(82,183,136,.12);
  --transicion:     all .35s cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--fuente-body);color:var(--texto);background:var(--fondo-base);line-height:1.7;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

h1,h2,h3,h4,h5{font-family:var(--fuente-display);line-height:1.2;color:var(--texto);font-weight:700}
.eyebrow{font-family:var(--fuente-body);font-size:.72rem;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:var(--verde-claro);display:block;margin-bottom:.85rem}
.container{max-width:1200px;margin:0 auto;padding:0 2rem}
.container--narrow{max-width:840px}
section{padding:100px 0}

/* BOTONES */
.btn{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--fuente-body);font-size:.8rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:1rem 2.2rem;border-radius:var(--radio);cursor:pointer;border:1px solid transparent;transition:var(--transicion);line-height:1}
.btn--primary{background:var(--dorado);color:var(--fondo-base);border-color:var(--dorado)}
.btn--primary:hover{background:var(--dorado-claro);transform:translateY(-2px);box-shadow:0 8px 28px rgba(228,191,88,.3)}
.btn--outline{background:transparent;color:var(--texto);border-color:rgba(216,237,224,.25)}
.btn--outline:hover{border-color:var(--verde-claro);color:var(--verde-claro)}
.btn--verde{background:var(--verde-medio);color:var(--blanco);border-color:var(--verde-medio)}
.btn--verde:hover{background:var(--verde-claro);color:var(--fondo-base);transform:translateY(-2px);box-shadow:0 8px 28px rgba(82,183,136,.25)}
.btn--whatsapp{background:#25D366;color:var(--blanco);border-color:#25D366;font-size:1rem;padding:1.1rem 2.5rem}
.btn--whatsapp:hover{background:#1ebe5a;transform:translateY(-2px);box-shadow:0 8px 28px rgba(37,211,102,.3)}
.btn--whatsapp svg{width:22px;height:22px}

/* HEADER */
#site-header{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1.5rem 0;transition:var(--transicion)}
#site-header.scrolled{background:rgba(7,12,9,.96);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:1rem 0;border-bottom:1px solid var(--borde);box-shadow:0 4px 30px rgba(0,0,0,.5)}
.header-inner{display:flex;align-items:center;justify-content:space-between}
.site-logo{display:flex;flex-direction:column;line-height:1}
.site-logo .logo-top{font-family:var(--fuente-display);font-size:1.45rem;font-weight:700;color:var(--blanco);letter-spacing:.04em}
.site-logo .logo-sub{font-family:var(--fuente-body);font-size:.58rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--verde-claro);margin-top:3px}
.main-nav{display:flex;align-items:center;gap:2.5rem}
.main-nav a{font-size:.75rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(216,237,224,.7);transition:color .25s;position:relative}
.main-nav a::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:1px;background:var(--dorado-claro);transform:scaleX(0);transition:transform .3s}
.main-nav a:hover{color:var(--blanco)}
.main-nav a:hover::after{transform:scaleX(1)}
.nav-reserva{background:var(--dorado)!important;color:var(--fondo-base)!important;padding:.65rem 1.5rem!important;border-radius:var(--radio)!important;font-weight:700!important}
.nav-reserva::after{display:none!important}
.nav-reserva:hover{background:var(--dorado-claro)!important}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:.4rem;background:none;border:none}
.hamburger span{width:26px;height:2px;background:var(--texto);transition:var(--transicion);display:block}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mobile-nav{display:none;background:var(--fondo-base);padding:2rem;position:fixed;top:0;left:0;right:0;bottom:0;z-index:999;flex-direction:column;align-items:center;justify-content:center;gap:2rem;border-right:1px solid var(--borde)}
.mobile-nav.open{display:flex}
.mobile-nav a{font-family:var(--fuente-display);font-size:2rem;color:var(--texto);transition:color .25s}
.mobile-nav a:hover{color:var(--verde-claro)}

/* HERO */
.hero{position:relative;height:100vh;min-height:700px;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-image:url('assets/images/hero.jpg');background-size:cover;background-position:center 30%;transform:scale(1.06);transition:transform 10s ease-out;filter:brightness(.7)}
.hero-bg.loaded{transform:scale(1)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(7,12,9,.88) 0%,rgba(7,12,9,.45) 55%,rgba(7,12,9,.2) 100%)}
.hero-overlay-bottom{position:absolute;bottom:0;left:0;right:0;height:200px;background:linear-gradient(to top,var(--fondo-base),transparent)}
.hero-content{position:relative;z-index:2;max-width:760px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.75rem;font-family:var(--fuente-body);font-size:.72rem;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:var(--verde-claro);margin-bottom:1.5rem;opacity:0;animation:fadeUp .8s .3s forwards}
.hero-eyebrow::before{content:'';display:inline-block;width:32px;height:1px;background:var(--verde-claro)}
.hero h1{font-size:clamp(3rem,6vw,5.8rem);color:var(--blanco);margin-bottom:1.5rem;line-height:1.06;opacity:0;animation:fadeUp .8s .5s forwards;text-shadow:0 2px 30px rgba(0,0,0,.5)}
.hero h1 em{font-style:italic;color:var(--dorado-claro)}
.hero-desc{font-size:1.1rem;color:rgba(216,237,224,.8);max-width:520px;margin-bottom:2.5rem;opacity:0;animation:fadeUp .8s .7s forwards;font-weight:400;line-height:1.75}
.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap;opacity:0;animation:fadeUp .8s .9s forwards}
.hero-scroll{position:absolute;bottom:3rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.6rem;z-index:2;opacity:0;animation:fadeIn 1s 1.6s forwards}
.hero-scroll span{font-size:.62rem;letter-spacing:.25em;text-transform:uppercase;color:rgba(216,237,224,.4);font-weight:600}
.scroll-line{width:1px;height:50px;background:linear-gradient(to bottom,var(--verde-claro),transparent);animation:scrollPulse 2s ease-in-out infinite}

/* STATS */
.stats-bar{background:var(--fondo-elevado);border-top:1px solid var(--borde);border-bottom:1px solid var(--borde)}
.stats-inner{display:grid;grid-template-columns:repeat(4,1fr)}
.stat-item{padding:2.5rem 2rem;text-align:center;border-right:1px solid var(--borde);transition:background .3s;position:relative}
.stat-item::before{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:0;height:2px;background:var(--dorado);transition:width .4s}
.stat-item:hover::before{width:60%}
.stat-item:last-child{border-right:none}
.stat-item:hover{background:rgba(82,183,136,.04)}
.stat-num{font-family:var(--fuente-display);font-size:2.8rem;font-weight:700;color:var(--dorado-claro);display:block;line-height:1}
.stat-label{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--texto-suave);font-weight:600;margin-top:.5rem;display:block}

/* BIENVENIDA */
.bienvenida{background:var(--fondo-base)}
.bienvenida-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.bienvenida-text h2{font-size:clamp(2rem,3.5vw,3rem);margin-bottom:1.25rem}
.bienvenida-text p{color:var(--texto-suave);margin-bottom:1rem;font-size:1.02rem}
.bienvenida-text p:last-of-type{margin-bottom:2rem}
.bienvenida-img{position:relative}
.bienvenida-img .img-principal{border-radius:8px;width:100%;aspect-ratio:4/5;object-fit:cover;box-shadow:var(--sombra-media);filter:brightness(.88) saturate(1.1)}
.bienvenida-img .img-badge{position:absolute;bottom:-2rem;left:-2rem;background:var(--fondo-elevado);border:1px solid var(--borde);padding:1.5rem 2rem;border-radius:8px;box-shadow:var(--sombra-media);text-align:center}
.img-badge .badge-num{font-family:var(--fuente-display);font-size:2.5rem;font-weight:700;color:var(--dorado-claro);display:block;line-height:1}
.img-badge .badge-text{font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--texto-suave);margin-top:.3rem}

/* LA ZONA */
.la-zona{background:var(--fondo-elevado)}
.zona-header{text-align:center;max-width:640px;margin:0 auto 60px}
.zona-header h2{font-size:clamp(2rem,3.5vw,2.8rem);margin-bottom:1rem}
.zona-header p{color:var(--texto-suave);font-size:1.02rem}
.zona-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.zona-card{background:var(--fondo-card);border:1px solid var(--borde);border-radius:10px;overflow:hidden;transition:var(--transicion)}
.zona-card:hover{transform:translateY(-8px);border-color:rgba(82,183,136,.25);box-shadow:var(--sombra-glow)}
.zona-card-img{width:100%;aspect-ratio:3/2;object-fit:cover;filter:brightness(.82) saturate(1.1);transition:filter .4s,transform .5s}
.zona-card:hover .zona-card-img{filter:brightness(.95) saturate(1.25);transform:scale(1.04)}
.zona-card-body{padding:1.75rem}
.zona-card-icon{width:44px;height:44px;background:var(--fondo-elevado);border:1px solid var(--borde);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;color:var(--verde-claro)}
.zona-card h3{font-size:1.15rem;margin-bottom:.5rem}
.zona-card p{color:var(--texto-suave);font-size:.92rem;line-height:1.65}

/* ALOJAMIENTO */
.alojamiento{background:var(--fondo-base)}
.aloj-header{text-align:center;max-width:600px;margin:0 auto 60px}
.aloj-header h2{font-size:clamp(2rem,3.5vw,2.8rem);margin-bottom:1rem}
.aloj-header p{color:var(--texto-suave)}
.aloj-tabs{display:flex;justify-content:center;gap:1rem;margin-bottom:3rem}
.tab-btn{font-family:var(--fuente-body);font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:.75rem 2rem;border-radius:50px;border:1px solid var(--borde);background:transparent;color:var(--texto-suave);cursor:pointer;transition:var(--transicion)}
.tab-btn.active{background:var(--verde-medio);border-color:var(--verde-medio);color:var(--blanco);box-shadow:0 4px 20px rgba(45,106,79,.3)}
.tab-btn:hover:not(.active){border-color:var(--verde-claro);color:var(--verde-claro)}
.tab-panel{display:none}
.tab-panel.active{display:block}

.cabanas-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.cabana-card{border-radius:10px;overflow:hidden;border:1px solid var(--borde);background:var(--fondo-card);transition:var(--transicion)}
.cabana-card:hover{transform:translateY(-6px);border-color:rgba(82,183,136,.25);box-shadow:var(--sombra-glow)}
.cabana-card-img{width:100%;aspect-ratio:3/2;object-fit:cover;filter:brightness(.82) saturate(1.1);transition:filter .4s}
.cabana-card:hover .cabana-card-img{filter:brightness(.95) saturate(1.2)}
.cabana-card-body{padding:1.75rem}
.cabana-tag{display:inline-block;background:var(--fondo-elevado);border:1px solid var(--borde);color:var(--verde-claro);font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:.3rem .85rem;border-radius:50px;margin-bottom:.8rem}
.cabana-card h3{font-size:1.25rem;margin-bottom:.75rem}
.cabana-features{display:flex;flex-direction:column;gap:.45rem;margin-bottom:1.25rem}
.cabana-feature{display:flex;align-items:center;gap:.5rem;font-size:.88rem;color:var(--texto-suave)}
.cabana-feature svg{color:var(--verde-claro);flex-shrink:0}
.cabana-precio{display:flex;align-items:baseline;gap:.4rem;padding-top:1rem;border-top:1px solid var(--borde)}
.cabana-precio .precio{font-family:var(--fuente-display);font-size:1.5rem;color:var(--dorado-claro);font-weight:700}
.cabana-precio .por-noche{font-size:.8rem;color:var(--texto-muted)}

.camping-layout{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.camping-img{border-radius:10px;width:100%;aspect-ratio:4/3;object-fit:cover;box-shadow:var(--sombra-media);filter:brightness(.82) saturate(1.1)}
.camping-info h3{font-size:1.8rem;margin-bottom:1rem}
.camping-info p{color:var(--texto-suave);margin-bottom:1.25rem}
.sitios-list{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1.5rem}
.sitio-item{display:flex;align-items:center;gap:.5rem;font-size:.88rem;font-weight:600;color:var(--texto)}
.sitio-item svg{color:var(--dorado)}
.camping-precio{background:var(--fondo-elevado);padding:1.25rem 1.5rem;border-radius:8px;border-left:3px solid var(--verde-claro)}
.camping-precio .c-precio{font-family:var(--fuente-display);font-size:1.6rem;color:var(--dorado-claro);font-weight:700}
.camping-precio span{font-size:.85rem;color:var(--texto-suave)}

/* ACTIVIDADES */
.actividades{background:var(--fondo-elevado);position:relative;overflow:hidden}
.actividades::before{content:'';position:absolute;inset:0;background-image:url('assets/images/actividades-bg.jpg');background-size:cover;background-position:center;opacity:.1;filter:saturate(0)}
.actividades-inner{position:relative;z-index:1}
.actividades-header{text-align:center;max-width:600px;margin:0 auto 60px}
.actividades-header h2{font-size:clamp(2rem,3.5vw,2.8rem);margin-bottom:1rem}
.actividades-header p{color:var(--texto-suave)}
.actividades-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
.actividad-card{background:var(--fondo-card);border:1px solid var(--borde);border-radius:10px;padding:1.75rem 1.5rem;text-align:center;transition:var(--transicion)}
.actividad-card:hover{background:var(--fondo-elevado);border-color:rgba(82,183,136,.3);transform:translateY(-4px);box-shadow:var(--sombra-glow)}
.actividad-icon{font-size:2rem;margin-bottom:1rem;display:block}
.actividad-card h3{font-size:1.05rem;margin-bottom:.5rem;color:var(--texto)}
.actividad-card p{color:var(--texto-suave);font-size:.88rem;line-height:1.6}

/* GALERÍA */
.galeria{background:var(--fondo-base);padding:80px 0}
.galeria-header{text-align:center;margin-bottom:50px}
.galeria-header h2{font-size:clamp(1.8rem,3vw,2.5rem)}
.galeria-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:auto auto;gap:8px}
.galeria-item{overflow:hidden;border-radius:6px;cursor:pointer;position:relative;background:var(--fondo-card)}
.galeria-item img{width:100%;height:100%;object-fit:cover;filter:brightness(.78) saturate(1.1);transition:transform .6s cubic-bezier(.4,0,.2,1),filter .4s}
.galeria-item:hover img{transform:scale(1.07);filter:brightness(.95) saturate(1.3)}
.galeria-item--grande{grid-column:span 2;grid-row:span 2;aspect-ratio:1/1}
.galeria-item--normal{aspect-ratio:3/2}
.galeria-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(82,183,136,.15),rgba(7,12,9,.6));display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .35s}
.galeria-item:hover .galeria-overlay{opacity:1}
.galeria-overlay svg{color:var(--blanco);width:36px;height:36px}

/* RESERVAS */
.reservas{background:var(--fondo-elevado);border-top:1px solid var(--borde);border-bottom:1px solid var(--borde);position:relative;overflow:hidden}
.reservas::before{content:'';position:absolute;top:-100px;right:-100px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(82,183,136,.06) 0%,transparent 70%);pointer-events:none}
.reservas-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:80px;align-items:center;position:relative;z-index:1}
.reservas-info h2{font-size:clamp(2rem,3.5vw,2.8rem);margin-bottom:1rem}
.reservas-info p{color:var(--texto-suave);margin-bottom:1.5rem;font-size:1.02rem}
.politicas{margin-top:2rem}
.politica-item{display:flex;gap:1rem;margin-bottom:1.25rem;align-items:flex-start}
.politica-icon{width:40px;height:40px;background:var(--fondo-superficie);border:1px solid var(--borde);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--verde-claro)}
.politica-text strong{display:block;color:var(--texto);font-size:.9rem;margin-bottom:.2rem}
.politica-text p{color:var(--texto-suave);font-size:.875rem;margin:0}

.reserva-form-card{background:var(--fondo-card);border:1px solid var(--borde);border-radius:14px;padding:2.5rem;box-shadow:var(--sombra-media)}
.reserva-form-card h3{font-size:1.35rem;margin-bottom:1.75rem;padding-bottom:1rem;border-bottom:1px solid var(--borde);color:var(--texto)}
.form-group{margin-bottom:1.2rem}
.form-group label{display:block;font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--texto-suave);margin-bottom:.45rem}
.form-group input,.form-group select{width:100%;padding:.85rem 1rem;border:1px solid var(--borde);border-radius:var(--radio);font-family:var(--fuente-body);font-size:.95rem;color:var(--texto);background:var(--fondo-elevado);transition:border-color .25s,box-shadow .25s;appearance:none;color-scheme:dark}
.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--verde-claro);box-shadow:0 0 0 3px rgba(82,183,136,.12)}
.form-group select option{background:var(--fondo-card);color:var(--texto)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
#cabana-selector,#sitio-selector{display:none}
#cabana-selector.visible,#sitio-selector.visible{display:block}
.reserva-resumen{background:var(--fondo-elevado);border:1px solid var(--borde);border-radius:8px;padding:1.25rem 1.5rem;margin:1.5rem 0;display:none}
.reserva-resumen.visible{display:block}
.resumen-row{display:flex;justify-content:space-between;font-size:.9rem;padding:.35rem 0;color:var(--texto-suave)}
.resumen-row.total{border-top:1px solid var(--borde);margin-top:.6rem;padding-top:.8rem;font-weight:700;font-size:1.05rem;color:var(--texto)}
.resumen-row.total span:last-child{font-family:var(--fuente-display);font-size:1.4rem;color:var(--dorado-claro)}
.reserva-aviso{font-size:.78rem;color:var(--texto-muted);text-align:center;margin-top:1rem;line-height:1.6}
.reserva-aviso strong{color:var(--verde-claro)}

/* TESTIMONIOS */
.testimonios{background:var(--fondo-base)}
.test-header{text-align:center;max-width:580px;margin:0 auto 50px}
.test-header h2{font-size:clamp(1.8rem,3vw,2.5rem);margin-bottom:.75rem}
.test-header p{color:var(--texto-suave)}
.test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.test-card{background:var(--fondo-card);border:1px solid var(--borde);border-radius:10px;padding:2rem;transition:var(--transicion)}
.test-card:hover{border-color:rgba(82,183,136,.2);transform:translateY(-4px);box-shadow:var(--sombra-glow)}
.test-quote{font-family:var(--fuente-display);font-size:4rem;color:var(--verde-claro);opacity:.2;line-height:.8;margin-bottom:.5rem;user-select:none}
.test-card p{color:var(--texto-suave);font-size:.965rem;line-height:1.72;margin-bottom:1.5rem;font-style:italic}
.test-autor{display:flex;align-items:center;gap:.75rem}
.test-autor img{width:44px;height:44px;border-radius:50%;object-fit:cover;filter:grayscale(.3)}
.test-autor-info strong{display:block;font-size:.9rem;color:var(--texto)}
.test-autor-info span{font-size:.78rem;color:var(--texto-muted)}
.test-stars{color:var(--dorado);font-size:.8rem;margin-bottom:1rem;letter-spacing:.1em}

/* CÓMO LLEGAR */
.como-llegar{background:var(--fondo-elevado)}
.llegar-inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.llegar-info h2{font-size:clamp(1.8rem,3vw,2.5rem);margin-bottom:1rem}
.llegar-info p{color:var(--texto-suave);margin-bottom:2rem}
.info-contacto{display:flex;flex-direction:column;gap:1rem}
.info-item{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem;background:var(--fondo-card);border:1px solid var(--borde);border-radius:8px;transition:border-color .25s}
.info-item:hover{border-color:rgba(82,183,136,.2)}
.info-item-icon{width:44px;height:44px;background:var(--fondo-elevado);border:1px solid var(--borde);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--verde-claro)}
.info-item-text strong{display:block;font-size:.85rem;font-weight:700;color:var(--texto);margin-bottom:.2rem}
.info-item-text a,.info-item-text span{color:var(--texto-suave);font-size:.9rem}
.info-item-text a:hover{color:var(--verde-claro)}
.mapa-embed{border-radius:10px;overflow:hidden;box-shadow:var(--sombra-media);border:1px solid var(--borde);height:420px}
.mapa-embed iframe{width:100%;height:100%;border:none}

/* FOOTER */
.site-footer{background:var(--fondo-card);border-top:1px solid var(--borde);padding:70px 0 0;color:var(--texto-suave)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:3rem;padding-bottom:50px}
.footer-brand>p{margin-top:1rem;font-size:.9rem;line-height:1.75}
.footer-col h4{font-family:var(--fuente-body);font-size:.7rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--verde-claro);margin-bottom:1.25rem}
.footer-col ul{display:flex;flex-direction:column;gap:.65rem}
.footer-col ul a{font-size:.9rem;transition:color .25s}
.footer-col ul a:hover{color:var(--texto)}
.footer-social{display:flex;gap:.75rem;margin-top:1.5rem}
.social-btn{width:38px;height:38px;background:var(--fondo-elevado);border:1px solid var(--borde);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:var(--transicion);color:var(--texto-suave)}
.social-btn:hover{background:var(--verde-medio);border-color:var(--verde-medio);color:var(--blanco)}
.footer-bottom{border-top:1px solid var(--borde);padding:1.5rem 0;display:flex;justify-content:space-between;align-items:center;font-size:.78rem;color:var(--texto-muted)}

/* WHATSAPP */
.whatsapp-float{position:fixed;bottom:2rem;right:2rem;z-index:900;width:58px;height:58px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.4);transition:var(--transicion);animation:waPulse 3s ease-in-out infinite}
.whatsapp-float:hover{transform:scale(1.12);box-shadow:0 8px 30px rgba(37,211,102,.5)}
.whatsapp-float svg{width:28px;height:28px;color:var(--blanco)}

/* ANIMACIONES */
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes scrollPulse{0%,100%{opacity:.5;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.2)}}
@keyframes waPulse{0%,100%{box-shadow:0 4px 20px rgba(37,211,102,.4)}50%{box-shadow:0 4px 30px rgba(37,211,102,.65),0 0 0 8px rgba(37,211,102,.12)}}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.12s}
.reveal-delay-2{transition-delay:.24s}
.reveal-delay-3{transition-delay:.36s}
.reveal-delay-4{transition-delay:.48s}

/* RESPONSIVE */
@media(max-width:1024px){.actividades-grid{grid-template-columns:repeat(2,1fr)}.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}}
@media(max-width:900px){.bienvenida-grid,.reservas-inner,.llegar-inner,.camping-layout{grid-template-columns:1fr;gap:3rem}.zona-grid,.cabanas-grid{grid-template-columns:1fr 1fr}.test-grid{grid-template-columns:1fr 1fr}.stats-inner{grid-template-columns:repeat(2,1fr)}.galeria-grid{grid-template-columns:repeat(2,1fr)}.galeria-item--grande{grid-column:span 1;grid-row:span 1;aspect-ratio:3/2}.bienvenida-img .img-badge{left:1rem;bottom:1rem}.main-nav{display:none}.hamburger{display:flex}}
@media(max-width:600px){section{padding:70px 0}.zona-grid,.cabanas-grid,.test-grid,.actividades-grid{grid-template-columns:1fr}.stats-inner{grid-template-columns:repeat(2,1fr)}.sitios-list{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr}.form-row{grid-template-columns:1fr}.hero-ctas{flex-direction:column;align-items:flex-start}.footer-bottom{flex-direction:column;gap:1rem;text-align:center}.galeria-grid{grid-template-columns:1fr 1fr;gap:6px}}

/* LOGO IMAGEN */
.site-logo { text-decoration: none; }
.logo-img {
  height: 52px;
  width: auto;
  max-width: 200px;
  object-fit: contain;
  display: block;
  /* Mantener visibilidad sobre fondos oscuros: el PNG debe tener fondo transparente */
  filter: brightness(1);
  transition: opacity .3s;
}
.logo-img:hover { opacity: .85; }
#site-header.scrolled .logo-img { height: 44px; }
.logo-fallback .logo-top { font-family: var(--fuente-display); font-size:1.45rem; font-weight:700; color:var(--blanco); }
.logo-fallback .logo-sub { font-family: var(--fuente-body); font-size:.58rem; font-weight:600; letter-spacing:.28em; text-transform:uppercase; color:var(--verde-claro); margin-top:3px; }
@media(max-width:600px){ .logo-img { height:42px; } }
