*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --forest:#1F3820;
  --forest-mid:#2E5230;
  --forest-light:#4A7C4E;
  --river:#1A3A4A;
  --river-mid:#2A5A72;
  --mist:#F2EDE4;
  --mist-dark:#E0D6C6;
  --wood:#C8A882;
  --wood-light:#DEC9AA;
  --stone:#7A7A72;
  --accent:#8B4B1A;
  --white:#FAFAF7;
  --text-dark:#1A1A14;
  --text-mid:#3A3A30;
  --text-muted:#7A7A68;
}
html{scroll-behavior:smooth}
body{font-family:'Plus Jakarta Sans',sans-serif;font-weight:400;background:var(--white);color:var(--text-dark);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}

/* NAV */
#main-nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:nowrap;transition:all .4s ease;background:linear-gradient(to bottom,rgba(10,20,10,.72) 0%,rgba(10,20,10,0) 100%)}
#main-nav.scrolled{background:rgba(31,56,32,.94);backdrop-filter:blur(8px)}
.nav-logo{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:400;color:var(--white);letter-spacing:.12em;text-decoration:none;display:flex;align-items:center}
.nav-logo span{font-style:italic;color:var(--wood-light)}
.nav-logo-img{height:38px;width:auto;display:block;object-fit:contain}
.nav-links{display:flex!important;flex-direction:row!important;gap:1rem;list-style:none;padding:0;margin:0;flex-wrap:nowrap;align-items:center}
.nav-links li{display:inline-flex;align-items:center}
.nav-links a{color:rgba(255,255,255,.85);text-decoration:none;font-size:.68rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;transition:color .3s}
.nav-links a:hover{color:var(--wood-light)}
.nav-cta{background:var(--wood);color:var(--white);border:none;padding:.55rem 1.4rem;font-family:'Plus Jakarta Sans',sans-serif;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:background .3s;text-decoration:none}
.nav-cta:hover{background:var(--accent)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.hamburger span{display:block;width:24px;height:1.5px;background:var(--white);transition:all .3s}
.mobile-menu{display:none!important;visibility:hidden;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--forest);z-index:150;flex-direction:column;align-items:center;justify-content:center;gap:2rem;pointer-events:none}
.mobile-menu.open{display:flex!important;visibility:visible;pointer-events:all}
.mobile-menu a{font-family:'Playfair Display',serif;font-size:2rem;color:var(--white);text-decoration:none;font-weight:400;letter-spacing:.1em}
.mobile-menu a:hover{color:var(--wood-light)}

/* HERO */
.hero{position:relative;height:100vh;min-height:600px;overflow:hidden;display:flex;align-items:center;justify-content:center}

/* ── KEN BURNS SLIDESHOW ── */
.kb-slides{position:absolute;inset:0;z-index:0}
.kb-slide{position:absolute;inset:0;opacity:0}
.kb-slide img{width:100%;height:100%;object-fit:cover;display:block}

/* Cada slide dura 7s visible + 1s fade = 8s; 3 slides = 24s ciclo total */
.kb-slide--1{animation:kbFade 24s 0s infinite}
.kb-slide--2{animation:kbFade 24s 8s infinite}
.kb-slide--3{animation:kbFade 24s 16s infinite}

/* Fade in/out del slide */
@keyframes kbFade{
  0%   {opacity:0}
  4%   {opacity:1}
  37%  {opacity:1}
  42%  {opacity:0}
  100% {opacity:0}
}

/* Ken Burns: zoom + paneo — cada slide con movimiento distinto */
.kb-slide--1 img{animation:kb1 24s 0s infinite ease-in-out}
.kb-slide--2 img{animation:kb2 24s 8s infinite ease-in-out}
.kb-slide--3 img{animation:kb3 24s 16s infinite ease-in-out}

@keyframes kb1{
  0%   {transform:scale(1.08) translate(0%,0%)}
  42%  {transform:scale(1.18) translate(-2%,-1.5%)}
  100% {transform:scale(1.08) translate(0%,0%)}
}
@keyframes kb2{
  0%   {transform:scale(1.12) translate(1.5%,1%)}
  42%  {transform:scale(1.04) translate(-1%,2%)}
  100% {transform:scale(1.12) translate(1.5%,1%)}
}
@keyframes kb3{
  0%   {transform:scale(1.06) translate(-1%,1.5%)}
  42%  {transform:scale(1.16) translate(2%,-1%)}
  100% {transform:scale(1.06) translate(-1%,1.5%)}
}

/* Overlay: oscurece la foto para que el texto sea legible */
.hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(160deg,rgba(10,28,12,.65) 0%,rgba(20,45,28,.5) 40%,rgba(15,30,42,.6) 100%)}
.hero-overlay-pattern{position:absolute;inset:0;z-index:2;background-image:radial-gradient(circle at 20% 50%,rgba(74,124,78,.12) 0%,transparent 60%),radial-gradient(circle at 80% 20%,rgba(42,90,114,.1) 0%,transparent 50%);pointer-events:none}

.hero-mist{position:absolute;bottom:35%;left:0;right:0;height:80px;z-index:3;background:linear-gradient(to bottom,transparent,rgba(240,235,225,.08),transparent);pointer-events:none;animation:mistFloat 8s ease-in-out infinite}
.hero-mist--2{bottom:25%;animation-delay:4s;animation-duration:11s;opacity:.6}
@keyframes mistFloat{0%,100%{opacity:.4;transform:translateY(0)}50%{opacity:.7;transform:translateY(-8px)}}
.hero-content{position:relative;z-index:4;text-align:center;max-width:750px;padding:0 2rem}
.hero-eyebrow{display:inline-block;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--wood-light);margin-bottom:1.5rem;font-weight:500}
.hero-eyebrow::before,.hero-eyebrow::after{content:'—';margin:0 .8rem;opacity:.6}
.hero-title{font-family:'Playfair Display',serif;font-size:clamp(3.2rem,8vw,6.5rem);font-weight:400;color:var(--white);line-height:1.05;letter-spacing:-.01em;margin-bottom:.5rem}
.hero-title em{font-style:italic;color:var(--wood-light)}
.hero-subtitle{font-family:'Playfair Display',serif;font-size:clamp(1rem,2.5vw,1.5rem);color:rgba(255,255,255,.75);font-weight:400;font-style:italic;margin-bottom:2.5rem;letter-spacing:.03em}
.hero-divider{width:60px;height:1px;background:var(--wood);margin:0 auto 2.5rem;opacity:.7}
.hero-desc{font-size:.95rem;color:rgba(255,255,255,.75);line-height:1.8;margin-bottom:3rem;font-weight:400;max-width:520px;margin-left:auto;margin-right:auto}
.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.btn-primary{background:var(--wood);color:var(--white);padding:.85rem 2.2rem;font-family:'Plus Jakarta Sans',sans-serif;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;transition:all .3s;border:none;cursor:pointer}
.btn-primary:hover{background:var(--accent)}
.btn-outline{background:transparent;color:var(--white);border:1px solid rgba(255,255,255,.35);padding:.85rem 2.2rem;font-family:'Plus Jakarta Sans',sans-serif;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;transition:all .3s}
.btn-outline:hover{border-color:var(--wood-light);color:var(--wood-light)}
.hero-scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:4;display:flex;flex-direction:column;align-items:center;gap:.5rem;color:rgba(255,255,255,.4);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase}
.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,rgba(255,255,255,.4),transparent);animation:scrollPulse 2s ease-in-out infinite;position:relative;overflow:visible}
@keyframes scrollPulse{0%,100%{opacity:.4;transform:scaleY(1)}50%{opacity:.9;transform:scaleY(1.1)}}
.hero-coords{position:absolute;bottom:2rem;right:2.5rem;z-index:4;font-family:'JetBrains Mono',monospace;font-size:.65rem;color:rgba(255,255,255,.3);letter-spacing:.08em;line-height:1.8}

/* STRIP */
.data-strip{background:var(--forest);display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid rgba(255,255,255,.06)}
.data-item{padding:1.8rem 2rem;text-align:center;border-right:1px solid rgba(255,255,255,.06)}
.data-item:last-child{border-right:none}
.data-num{font-family:'Playfair Display',serif;font-size:2.2rem;color:var(--wood-light);font-weight:400;display:block}
.data-label{font-size:.7rem;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:.15em;margin-top:.25rem}

/* SECTIONS */
section{padding:6rem 0}
.container{max-width:1100px;margin:0 auto;padding:0 2.5rem}
.section-label{font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:var(--wood);margin-bottom:1.2rem;display:block}
.section-title{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3rem);font-weight:400;color:var(--text-dark);line-height:1.2;margin-bottom:1.5rem}
.section-title em{font-style:italic;color:var(--forest-light)}
.section-divider{width:40px;height:2px;background:var(--wood);margin-bottom:2.5rem}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center}
.about-text p{font-size:1.05rem;line-height:1.9;color:var(--text-mid);margin-bottom:1.5rem;font-weight:400}
.about-quote{border-left:2px solid var(--wood);padding-left:1.5rem;margin:2.5rem 0;font-family:'Playfair Display',serif;font-size:1.4rem;font-style:italic;color:var(--forest);line-height:1.5;font-weight:400}
.about-visual{position:relative}
.about-img-main{width:100%;aspect-ratio:3/4;background:linear-gradient(160deg,var(--forest-mid),var(--river));position:relative;overflow:hidden}
.nature-illustration{width:100%;height:100%;display:flex;align-items:center;justify-content:center}
.about-tag{position:absolute;bottom:-1.5rem;left:-1.5rem;background:var(--forest);color:var(--white);padding:1.2rem 1.5rem;max-width:200px}
.about-tag strong{font-family:'Playfair Display',serif;font-size:1.1rem;display:block;margin-bottom:.25rem;font-weight:400;color:var(--wood-light)}
.about-tag span{font-size:.72rem;color:rgba(255,255,255,.55);letter-spacing:.08em;text-transform:uppercase}

/* FEATURES */
.features-bg{background:var(--mist)}
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem}
.feature-card{background:var(--white);padding:2.5rem 2rem;position:relative;border-bottom:2px solid transparent;transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease}
.feature-icon{width:48px;height:48px;margin-bottom:1.5rem}
.feature-card h3{font-family:'Playfair Display',serif;font-size:1.4rem;color:var(--text-dark);margin-bottom:.8rem;font-weight:400}
.feature-card p{font-size:.88rem;color:var(--text-muted);line-height:1.85;font-weight:400}
.feature-num{position:absolute;top:1.5rem;right:1.5rem;font-family:'JetBrains Mono',monospace;font-size:.65rem;color:var(--mist-dark);letter-spacing:.1em}

/* GALLERY */
.gallery-header{display:grid;grid-template-columns:1fr auto;align-items:end;gap:2rem;margin-bottom:3rem}
.gallery-grid{display:grid;grid-template-columns:repeat(12,1fr);grid-template-rows:repeat(2,240px);gap:1rem}
.gallery-cell{background:var(--mist-dark);overflow:hidden;position:relative;cursor:pointer}
.gallery-cell-inner{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative}
.g1{grid-column:1/6;grid-row:1/3}
.g2{grid-column:6/9;grid-row:1/2}
.g3{grid-column:9/13;grid-row:1/2}
.g4{grid-column:6/10;grid-row:2/3}
.g5{grid-column:10/13;grid-row:2/3}
.gallery-overlay{position:absolute;inset:0;background:var(--forest);opacity:0;transition:opacity .4s;display:flex;align-items:center;justify-content:center}
.gallery-cell:hover .gallery-overlay{opacity:.7}
.gallery-label{color:var(--white);font-family:'Playfair Display',serif;font-size:1.1rem;font-style:italic;opacity:0;transition:opacity .4s .1s}
.gallery-cell:hover .gallery-label{opacity:1}

/* NATURE SCENES (SVG placeholders) */
.scene{width:100%;height:100%}

/* LOTE */
.lote-section{background:var(--forest);color:var(--white);padding:7rem 0}
.lote-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.lote-badge{display:inline-block;background:var(--accent);color:var(--white);font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;padding:.4rem 1rem;margin-bottom:1.5rem}
.lote-title{font-family:'Playfair Display',serif;font-size:clamp(2.5rem,5vw,4rem);color:var(--white);font-weight:400;margin-bottom:1rem;line-height:1.1}
.lote-title em{color:var(--wood-light);font-style:italic}
.lote-desc{color:rgba(255,255,255,.75);font-size:1rem;line-height:1.9;font-weight:400;margin-bottom:2.5rem}
.lote-specs{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,.08);margin-bottom:2.5rem}
.spec-item{background:rgba(255,255,255,.04);padding:1.2rem 1.5rem}
.spec-val{font-family:'Playfair Display',serif;font-size:1.6rem;color:var(--wood-light);display:block}
.spec-key{font-size:.7rem;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.12em;margin-top:.2rem}
.map-placeholder{background:var(--river);position:relative;width:100%;aspect-ratio:1;overflow:hidden}
.map-frame{width:100%;height:100%;border:none}
.map-overlay-badge{position:absolute;top:1.5rem;left:1.5rem;background:var(--accent);color:var(--white);padding:.5rem 1rem;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase}

/* EXPERIENCE */
.exp-section{background:var(--mist)}
.exp-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.exp-items{display:flex;flex-direction:column;gap:2rem}
.exp-item{display:flex;gap:1.5rem;align-items:flex-start}
.exp-icon{width:42px;height:42px;background:var(--forest);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:.1rem}
.exp-item h4{font-family:'Playfair Display',serif;font-size:1.2rem;color:var(--text-dark);margin-bottom:.4rem;font-weight:400}
.exp-item p{font-size:.88rem;color:var(--text-muted);line-height:1.7;font-weight:400}
.exp-visual{background:var(--forest-mid);aspect-ratio:4/5;position:relative;overflow:hidden}

/* TESTIMONIAL */
.testimonial-section{padding:6rem 0;background:var(--white)}
.testimonial-inner{max-width:700px;margin:0 auto;text-align:center}
.quote-mark{font-family:'Playfair Display',serif;font-size:6rem;color:var(--mist-dark);line-height:.5;margin-bottom:1rem;display:block}
.testimonial-text{font-family:'Playfair Display',serif;font-size:clamp(1.3rem,2.5vw,2rem);font-style:italic;color:var(--text-dark);font-weight:400;line-height:1.6;margin-bottom:2rem}
.testimonial-author{font-size:.78rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted)}

/* ── CONTACT SECTION ── */
.contact-section{background:var(--text-dark);padding:7rem 0}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.contact-heading{font-family:'Playfair Display',serif;font-size:clamp(2rem,3.5vw,2.8rem);font-weight:400;color:var(--white);line-height:1.2;margin-bottom:1.5rem}
.contact-heading em{font-style:italic;color:var(--wood-light)}
.contact-info .section-label{color:var(--wood)}
.contact-desc{color:rgba(255,255,255,.55);font-size:.92rem;line-height:1.85;font-weight:400;margin-bottom:2.5rem}
.contact-links{display:flex;flex-direction:column;gap:.9rem;margin-bottom:2.5rem}
.contact-link{display:flex;align-items:center;gap:1rem;color:rgba(255,255,255,.6);text-decoration:none;font-size:.88rem;transition:color .3s;font-weight:400}
.contact-link:hover{color:var(--wood-light)}
.contact-link-icon{width:36px;height:36px;border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--wood-light);transition:border-color .3s,background .3s}
.contact-link:hover .contact-link-icon{border-color:var(--wood-light);background:rgba(200,168,130,.08)}
.contact-social{display:flex;gap:.75rem}
.contact-social-icon{width:38px;height:38px;border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.45);text-decoration:none;transition:all .3s}
.contact-social-icon:hover{border-color:var(--wood-light);color:var(--wood-light);background:rgba(200,168,130,.08)}

/* contact card */
.contact-card{background:var(--forest);border:1px solid rgba(255,255,255,.07);padding:2.5rem}
.contact-card-header{margin-bottom:2rem}
.contact-card-header h3{font-family:'Playfair Display',serif;font-size:1.35rem;font-weight:400;color:var(--white);margin-bottom:.75rem}
.contact-card-header p{font-size:.85rem;color:rgba(255,255,255,.45);line-height:1.7}
.contact-card-btn{display:flex;align-items:center;gap:1rem;padding:1.15rem 1.3rem;text-decoration:none;margin-bottom:.85rem;transition:all .3s;border:1px solid transparent}
.contact-card-btn--wa{background:#25D366;color:#fff;border-color:#25D366}
.contact-card-btn--wa:hover{background:#1ebe5d;box-shadow:0 8px 24px rgba(37,211,102,.3)}
.contact-card-btn--email{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.12);color:rgba(255,255,255,.8)}
.contact-card-btn--email:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.22);color:var(--white)}
.contact-card-btn-icon{width:42px;height:42px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:rgba(255,255,255,.18);border-radius:50%}
.contact-card-btn--email .contact-card-btn-icon{background:rgba(255,255,255,.08);color:var(--wood-light)}
.contact-card-btn-text{flex:1}
.contact-card-btn-text strong{display:block;font-size:.93rem;font-weight:600;letter-spacing:.01em}
.contact-card-btn-text span{font-size:.78rem;opacity:.75;margin-top:.15rem;display:block}
.contact-card-arrow{opacity:.5;flex-shrink:0;transition:transform .3s,opacity .3s}
.contact-card-btn:hover .contact-card-arrow{transform:translateX(3px);opacity:1}
.contact-card-note{font-size:.72rem;color:rgba(255,255,255,.28);text-align:center;letter-spacing:.06em;margin-top:1.2rem}

/* old form styles */
.form-wrap{background:rgba(255,255,255,.04);padding:2.5rem;border:1px solid rgba(255,255,255,.08)}
.form-group{margin-bottom:1.5rem}
.form-group label{display:block;font-size:.72rem;color:rgba(255,255,255,.4);letter-spacing:.12em;text-transform:uppercase;margin-bottom:.6rem}
.form-group input,.form-group select,.form-group textarea{width:100%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:var(--white);padding:.75rem 1rem;font-family:'Plus Jakarta Sans',sans-serif;font-size:.9rem;outline:none;transition:border-color .3s}
.form-group input::placeholder,.form-group textarea::placeholder{color:rgba(255,255,255,.2)}
.form-group input:focus,.form-group textarea:focus{border-color:var(--wood)}
.form-group select{color:rgba(255,255,255,.6)}
.form-group select option{background:var(--text-dark)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.btn-form{width:100%;background:var(--wood);color:var(--white);border:none;padding:1rem;font-family:'Plus Jakarta Sans',sans-serif;font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:background .3s;margin-top:.5rem}
.btn-form:hover{background:var(--accent)}

/* FOOTER */
footer{background:var(--forest);padding:3rem 0;border-top:1px solid rgba(255,255,255,.06)}
.footer-inner{display:flex;justify-content:space-between;align-items:center}
.footer-logo{font-family:'Playfair Display',serif;font-size:1.2rem;color:var(--white);font-weight:400;letter-spacing:.1em}
.footer-logo em{color:var(--wood-light);font-style:italic}
.footer-copy{font-size:.72rem;color:rgba(255,255,255,.35);letter-spacing:.06em}
.footer-links{display:flex;gap:1.5rem}
.footer-links a{font-size:.72rem;color:rgba(255,255,255,.35);text-decoration:none;letter-spacing:.08em;text-transform:uppercase;transition:color .3s}
.footer-links a:hover{color:var(--wood-light)}

/* WHATSAPP FLOATING */
.wa-float{position:fixed;bottom:2rem;right:2rem;z-index:98;display:flex;align-items:center;gap:.9rem}
.wa-tooltip{background:var(--forest);border:1px solid rgba(255,255,255,.1);padding:.6rem 1rem;pointer-events:none;opacity:0;transform:translateX(8px);transition:all .3s;white-space:nowrap;box-shadow:0 4px 20px rgba(0,0,0,.3)}
.wa-tooltip span{display:block;font-size:.82rem;font-weight:600;color:var(--white);letter-spacing:.02em}
.wa-tooltip p{font-size:.72rem;color:rgba(255,255,255,.45);margin-top:.1rem}
.wa-float:hover .wa-tooltip{opacity:1;transform:translateX(0)}
.wa-btn{width:54px;height:54px;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 24px rgba(37,211,102,.4);transition:transform .3s,box-shadow .3s;text-decoration:none;flex-shrink:0;position:relative;border-radius:50%}
.wa-btn:hover{transform:scale(1.08);box-shadow:0 6px 30px rgba(37,211,102,.5)}

/* FADE IN */
/* fade-in → moved to scroll reveal section below */

/* RESPONSIVE */
@media(max-width:768px){
  #main-nav{padding:1rem 1.5rem}
  .nav-links,.nav-cta{display:none!important}
  .hamburger{display:flex}
}
@media(max-width:900px){
  .about-grid,.lote-grid,.exp-grid,.contact-grid{grid-template-columns:1fr}
  .data-strip{grid-template-columns:repeat(2,1fr)}
  .data-item:nth-child(2){border-right:none}
  .features-grid{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .g1,.g2,.g3,.g4,.g5{grid-column:auto;grid-row:auto}
  .footer-inner{flex-direction:column;gap:1.5rem;text-align:center}
  .footer-links{flex-wrap:wrap;justify-content:center}
  .about-tag{display:none}
}
@media(max-width:600px){
  .features-grid{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .data-strip{grid-template-columns:1fr 1fr}
  section{padding:4rem 0}
  .hero-coords{display:none}
  .wa-tooltip{display:none}
  .contact-card{padding:1.8rem}
}

/* ===== PRECIO ===== */
.precio-inner{text-align:center;max-width:700px;margin:0 auto}
.precio-box{margin:3rem 0;display:flex;flex-direction:column;align-items:center;gap:2.5rem;border:1px solid rgba(200,168,130,.2);padding:3rem 2rem;background:rgba(255,255,255,.04)}
.precio-main{display:flex;flex-direction:column;align-items:center;gap:.5rem}
.precio-label{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.45);font-weight:500}
.precio-valor{font-family:'Playfair Display',serif;font-size:clamp(2.4rem,6vw,4rem);font-weight:400;color:var(--wood-light);letter-spacing:-.01em;line-height:1}
.precio-moneda{font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.45);font-weight:400}
.precio-detalles{display:flex;gap:2.5rem;flex-wrap:wrap;justify-content:center;padding-top:2rem;border-top:1px solid rgba(200,168,130,.15);width:100%}
.precio-det-item{display:flex;flex-direction:column;align-items:center;gap:.3rem}
.precio-det-num{font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:400;color:var(--white);letter-spacing:-.01em}
.precio-det-key{font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.45);font-weight:500}

/* ===== CÓMO LLEGAR ===== */
.llegar-flow{display:flex;flex-direction:column;align-items:center;max-width:380px;margin:0 auto}
.llegar-step{display:flex;align-items:center;gap:1.5rem;background:var(--white);border:1px solid rgba(31,56,32,.12);padding:1.4rem 2rem;width:100%;box-shadow:0 2px 16px rgba(31,56,32,.06)}
.llegar-step--destino{border-color:var(--wood);background:linear-gradient(135deg,rgba(200,168,130,.07),rgba(200,168,130,.02))}
.llegar-icon{width:64px;height:64px;border-radius:50%;background:rgba(46,82,48,.1);border:1.5px solid rgba(46,82,48,.15);display:flex;align-items:center;justify-content:center;color:var(--forest-mid);flex-shrink:0}
.llegar-icon--destino{background:rgba(200,168,130,.18);border-color:rgba(200,168,130,.3);color:var(--wood)}
.llegar-info{display:flex;flex-direction:column;gap:.2rem}
.llegar-info strong{font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:400;color:var(--text-dark);letter-spacing:.02em}
.llegar-info span{font-size:.78rem;color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;font-weight:500}
.llegar-connector{display:flex;flex-direction:column;align-items:center;padding:.4rem 0;gap:.2rem;position:relative}
.llegar-line{width:1px;height:30px;background:repeating-linear-gradient(to bottom,var(--forest-mid) 0,var(--forest-mid) 4px,transparent 4px,transparent 8px)}
.llegar-tiempo{display:flex;flex-direction:column;align-items:center;gap:.1rem;background:var(--white);border:1px solid rgba(46,82,48,.15);padding:.3rem .9rem;border-radius:2rem;box-shadow:0 1px 8px rgba(31,56,32,.06)}
.llegar-num{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:400;color:var(--forest-mid);line-height:1}
.llegar-unit{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted)}
.llegar-arrow{color:var(--forest-mid);font-size:1rem;opacity:.5}

/* ===== ACTIVIDADES ===== */
.actividades-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.actividad-card{background:var(--white);overflow:hidden;box-shadow:0 2px 20px rgba(31,56,32,.08);transition:transform .3s,box-shadow .3s;cursor:default}
.actividad-card:hover{transform:translateY(-4px);box-shadow:0 8px 32px rgba(31,56,32,.14)}
.actividad-img{height:200px;background:var(--stone) center/cover no-repeat;position:relative}
.actividad-info{padding:1.1rem 1.3rem 1.2rem}
.actividad-info h4{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:400;color:var(--text-dark);margin-bottom:.3rem;letter-spacing:.02em}
.actividad-dist{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);font-weight:500}

/* Actividades placeholder colors (replace with real images) */
.actividad-img--feria{background-color:#8B7355;background-image:url('../img/actividad-feria.webp');background-size:cover;background-position:center}
.actividad-img--aucar{background-color:#4A7C8E;background-image:url('../img/actividad-aucar.webp');background-size:cover;background-position:center}
.actividad-img--iglesia{background-color:#C8A850;background-image:url('../img/actividad-iglesia.webp');background-size:cover;background-position:center}
.actividad-img--palafitos{background-color:#5A7A9A;background-image:url('../img/actividad-palafitos.webp');background-size:cover;background-position:center}
.actividad-img--cascada{background-color:#3A6A3A;background-image:url('../img/actividad-cascada.webp');background-size:cover;background-position:center}
.actividad-img--muelle{background-color:#6A7A8A;background-image:url('../img/actividad-muelle.webp');background-size:cover;background-position:center}

@media(max-width:900px){
  .actividades-grid{grid-template-columns:repeat(2,1fr)}
  .precio-detalles{gap:1.5rem}
}
@media(max-width:600px){
  .actividades-grid{grid-template-columns:1fr 1fr}
  .actividad-img{height:140px}
  .llegar-flow{max-width:100%}
  .llegar-step{padding:1rem 1.2rem}
}

/* ===== TICKER ===== */
.ticker-wrap{overflow:hidden;background:var(--forest-mid);padding:.65rem 0;border-top:1px solid rgba(200,168,130,.15);border-bottom:1px solid rgba(200,168,130,.15)}
.ticker-track{display:flex;width:max-content;animation:ticker 40s linear infinite;will-change:transform}
.ticker-track:hover{animation-play-state:paused}
.ticker-item{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--wood-light);font-weight:400;white-space:nowrap;padding:0 .5rem}
.ticker-sep{color:var(--wood);opacity:.6;padding:0 .8rem;font-size:.65rem}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ===== HERO VIDEO BTN ===== */
.hero-video-btn{display:flex;align-items:center;gap:.6rem;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.3);color:var(--white);padding:.6rem 1.2rem;font-family:'Plus Jakarta Sans',sans-serif;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:all .3s;position:relative;backdrop-filter:blur(6px)}
.hero-video-btn:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.5)}
.hero-video-ring{position:absolute;inset:-4px;border:1px solid rgba(255,255,255,.25);animation:ring-pulse 2s ease-in-out infinite}
@keyframes ring-pulse{0%,100%{transform:scale(1);opacity:.6}50%{transform:scale(1.04);opacity:1}}

/* ===== HERO SCROLL DOT ===== */
.scroll-dot{width:4px;height:4px;background:var(--wood-light);border-radius:50%;position:absolute;left:50%;top:0;transform:translateX(-50%);animation:scroll-drop 1.8s ease-in-out infinite}
@keyframes scroll-drop{0%{transform:translateY(0);opacity:1}80%{transform:translateY(28px);opacity:0}100%{transform:translateY(0);opacity:0}}

/* ===== SCROLL REVEAL ===== */
.fade-in,.fade-in-left,.fade-in-right,.reveal-up{opacity:0;transition:opacity .7s ease,transform .7s ease}
.fade-in{transform:translateY(28px)}
.fade-in-left{transform:translateX(-32px)}
.fade-in-right{transform:translateX(32px)}
.reveal-up{transform:translateY(40px)}
.fade-in.visible,.fade-in-left.visible,.fade-in-right.visible,.reveal-up.visible{opacity:1;transform:none}

/* ===== MICRO-INTERACTIONS ===== */
.feature-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px rgba(31,56,32,.14);border-color:rgba(200,168,130,.35)}
.actividad-card{transition:transform .3s ease,box-shadow .3s ease}
.actividad-card:hover{transform:translateY(-5px);box-shadow:0 12px 32px rgba(31,56,32,.12)}

/* WA BUTTON PULSE */
.wa-btn::before{content:'';position:absolute;inset:0;border-radius:50%;background:inherit;animation:wa-pulse 2.2s ease-out infinite;z-index:-1}
@keyframes wa-pulse{0%{transform:scale(1);opacity:.7}70%{transform:scale(1.5);opacity:0}100%{transform:scale(1.5);opacity:0}}

/* FLOATING LABELS on form inputs */
.form-group{position:relative}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--wood);box-shadow:0 1px 0 0 var(--wood)}
.form-group input,.form-group select,.form-group textarea{transition:border-color .25s}

/* COUNTER NUMBERS */
.data-num[data-target],.precio-valor[data-target]{transition:none}

/* ===== FOOTER REDESIGN ===== */
footer{background:var(--forest);color:var(--white);padding:4rem 0 0}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-brand{}
.footer-logo{font-family:'Playfair Display',serif;font-size:1.7rem;font-weight:400;letter-spacing:.1em;color:var(--white);margin-bottom:1rem}
.footer-logo em{font-style:italic;color:var(--wood-light)}
.footer-tagline{font-size:.8rem;color:rgba(255,255,255,.5);line-height:1.8;font-weight:400;max-width:260px;margin-bottom:1.2rem}
.footer-coords-wrap{display:inline-block;border:1px solid rgba(200,168,130,.2);padding:.3rem .8rem}
.footer-coords{font-family:'JetBrains Mono',monospace;font-size:.68rem;letter-spacing:.15em;color:var(--wood);opacity:.8}
.footer-col-head{display:block;font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:var(--wood);opacity:.7;margin-bottom:1.2rem;font-weight:500}
.footer-nav{display:flex;flex-direction:column;gap:.7rem}
.footer-nav a{font-size:.82rem;color:rgba(255,255,255,.6);text-decoration:none;transition:color .25s;font-weight:400;letter-spacing:.04em}
.footer-nav a:hover{color:var(--wood-light)}
.footer-contact-items{display:flex;flex-direction:column;gap:.9rem}
.footer-contact-item{display:flex;align-items:center;gap:.6rem;font-size:.8rem;color:rgba(255,255,255,.6);text-decoration:none;transition:color .25s;font-weight:400}
.footer-contact-item:hover{color:var(--wood-light)}
.footer-contact-item svg{opacity:.6;flex-shrink:0}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:1.4rem 0;flex-wrap:wrap;gap:.8rem}
.footer-copy{font-size:.72rem;color:rgba(255,255,255,.3);letter-spacing:.06em}
.footer-keros{font-size:.72rem;color:rgba(255,255,255,.3);text-decoration:none;transition:color .3s;letter-spacing:.04em}
.footer-keros:hover{color:var(--wood-light)}
.footer-keros strong{font-weight:500}

/* ===== VIDEO MODAL ===== */
.video-modal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .35s ease}
.video-modal.open,.video-modal.active{opacity:1;pointer-events:all}
.video-modal-backdrop{position:absolute;inset:0;background:rgba(10,18,10,.88);backdrop-filter:blur(4px)}
.video-modal-inner{position:relative;z-index:1;width:min(860px,92vw);aspect-ratio:16/9;background:#000}
.video-modal-close{position:absolute;top:-2.5rem;right:0;background:none;border:none;cursor:pointer;padding:.3rem;opacity:.7;transition:opacity .2s}
.video-modal-close:hover{opacity:1}
.video-modal-frame{width:100%;height:100%}
.video-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:rgba(31,56,32,.4);border:1px solid rgba(200,168,130,.2);color:rgba(255,255,255,.5);font-size:.85rem;letter-spacing:.06em;gap:.5rem}
.video-placeholder-icon{font-size:2.5rem;opacity:.4;margin-bottom:.5rem}

/* ===== RESPONSIVE FOOTER ===== */
@media(max-width:760px){
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .footer-bottom{flex-direction:column;text-align:center}
  .ticker-item{font-size:.65rem}
}
