/* ============================================================
   VISTAMAR DE GUANAQUEROS
   Editorial · natural · luxury land-development experience
   ============================================================ */

/* ---------- TOKENS ---------- */
:root{
  /* greens (brand) */
  --green-950:#0c1712;
  --green-900:#10211a;
  --green-850:#142a20;
  --green-800:#193227;
  --green-700:#244534;
  --green-600:#315a44;
  --green-500:#3f6e53;
  --green-400:#5d8a6e;

  /* sand / cream */
  --cream:#f4efe3;
  --cream-2:#ece4d2;
  --sand:#e0d4ba;
  --sand-deep:#c9b58f;

  /* accents */
  --gold:#c2a35e;
  --gold-bright:#dcc07c;
  --teal:#5e928b;

  /* ink */
  --ink:#13231b;
  --ink-soft:#3a4a40;

  --bg:var(--green-900);
  --fg:var(--cream);

  --font-display:"Fraunces", Georgia, serif;
  --font-body:"Hanken Grotesk", system-ui, sans-serif;

  --maxw:1480px;
  --gutter:clamp(20px, 5vw, 80px);

  --ease:cubic-bezier(.6,.01,.05,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

/* ---------- RESET ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--fg);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  font-weight:300;
}
img,video,svg,iframe{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:none}
ul{list-style:none}
::selection{background:var(--gold);color:var(--green-950)}

body.is-loading{overflow:hidden;height:100vh}
body.menu-open{overflow:hidden}

/* ---------- TYPE SCALE ---------- */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:400;line-height:1.02;letter-spacing:-.01em}
em{font-style:italic}

.section-head{padding:0 var(--gutter);max-width:var(--maxw);margin:0 auto clamp(40px,6vw,90px)}
.section-head__index{
  display:inline-block;font-family:var(--font-body);font-size:.72rem;letter-spacing:.28em;
  text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:1.2rem;
}
.section-head__title{font-size:clamp(2.4rem,7vw,6rem)}
.section-head__title em{color:var(--gold-bright)}
.section-head--light .section-head__index{color:var(--green-600)}

/* ============================================================
   PRELOADER
   ============================================================ */
.preloader{
  position:fixed;inset:0;z-index:1000;background:var(--green-950);
  display:grid;place-content:center;text-align:center;gap:1.4rem;
  transition:opacity .6s ease, visibility .6s ease;
}
.preloader.done{opacity:0;visibility:hidden}
.preloader__waves{width:78px;height:auto;margin:0 auto;overflow:visible}
.preloader__waves path{fill:none;stroke:var(--gold);stroke-width:3;stroke-linecap:round;
  stroke-dasharray:160;stroke-dashoffset:160;animation:draw 2s var(--ease) infinite alternate}
.preloader__waves path:last-child{animation-delay:.25s;stroke:var(--green-400)}
@keyframes draw{to{stroke-dashoffset:0}}
.preloader__name{font-family:var(--font-display);letter-spacing:.34em;font-size:.8rem;color:var(--cream);
  text-indent:.34em;opacity:.85}
.preloader__bar{width:200px;height:1px;background:rgba(244,239,227,.18);margin:.4rem auto 0;overflow:hidden}
.preloader__bar span{display:block;height:100%;width:0;background:var(--gold)}
.preloader__pct{font-size:.7rem;letter-spacing:.2em;color:var(--green-400)}

/* ============================================================
   GRAIN · CURSOR · PROGRESS
   ============================================================ */
.grain{
  position:fixed;inset:-50%;z-index:900;pointer-events:none;opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 8s steps(8) infinite;
}
@keyframes grain{
  0%,100%{transform:translate(0,0)} 10%{transform:translate(-5%,-5%)}
  30%{transform:translate(3%,-8%)} 50%{transform:translate(-4%,6%)}
  70%{transform:translate(6%,3%)} 90%{transform:translate(-3%,5%)}
}

.cursor{
  position:fixed;top:0;left:0;width:10px;height:10px;border-radius:50%;
  background:var(--gold);z-index:1001;pointer-events:none;
  transform:translate(-50%,-50%);mix-blend-mode:difference;
  transition:width .3s var(--ease-out),height .3s var(--ease-out),background .3s;
  display:grid;place-content:center;
}
.cursor__label{font-family:var(--font-body);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--green-950);opacity:0;white-space:nowrap;font-weight:600;transition:opacity .2s}
.cursor.is-active{width:92px;height:92px;background:var(--gold-bright);mix-blend-mode:normal}
.cursor.is-active .cursor__label{opacity:1}
@media (hover:none){.cursor{display:none}}

.scroll-progress{position:fixed;top:0;left:0;right:0;height:2px;z-index:950;background:transparent}
.scroll-progress span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--gold),var(--teal))}

/* ============================================================
   HEADER
   ============================================================ */
.header{
  position:fixed;top:0;left:0;right:0;z-index:800;
  display:flex;align-items:center;justify-content:space-between;
  padding:clamp(14px,2vw,26px) var(--gutter);
  transition:background .5s var(--ease),padding .5s var(--ease),backdrop-filter .5s;
}
.header.scrolled{background:rgba(12,23,18,.72);backdrop-filter:blur(14px);padding-top:12px;padding-bottom:12px}
.header.hide{transform:translateY(-110%);transition:transform .5s var(--ease)}
.header__brand img{height:clamp(34px,4vw,46px);width:auto}
.nav{display:flex;gap:clamp(18px,2vw,34px)}
.nav a{font-size:.82rem;letter-spacing:.04em;position:relative;padding:4px 0;color:rgba(244,239,227,.82);transition:color .3s}
.nav a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--gold);transition:width .4s var(--ease-out)}
.nav a:hover{color:var(--cream)}
.nav a:hover::after{width:100%}

.burger{display:none;width:38px;height:38px;position:relative}
.burger span{position:absolute;left:7px;right:7px;height:1.5px;background:var(--cream);transition:.4s var(--ease)}
.burger span:first-child{top:15px}.burger span:last-child{top:21px}
.burger.open span:first-child{top:18px;transform:rotate(45deg)}
.burger.open span:last-child{top:18px;transform:rotate(-45deg)}
body.menu-open .header__brand{opacity:0;pointer-events:none;transition:opacity .3s}
body.menu-open .header{background:transparent!important;backdrop-filter:none!important}

/* header right cluster + language toggle */
.header__right{display:flex;align-items:center;gap:clamp(12px,1.4vw,20px)}
.lang-toggle{display:inline-flex;align-items:center;gap:.32em;font-family:var(--font-body);
  font-size:.74rem;font-weight:600;letter-spacing:.06em;padding:.5em .8em;border-radius:100px;
  border:1px solid rgba(244,239,227,.28);color:rgba(244,239,227,.6);z-index:801}
.lang-toggle .lang-sep{opacity:.4;font-weight:300}
.lang-toggle [data-lang]{transition:color .3s}
.lang-toggle [data-lang].active{color:var(--gold-bright)}
.lang-toggle:hover{border-color:var(--gold)}
body.menu-open .lang-toggle{color:rgba(244,239,227,.85)}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;position:relative;
  font-family:var(--font-body);font-size:.86rem;font-weight:500;letter-spacing:.02em;
  padding:.95em 1.7em;border-radius:100px;overflow:hidden;white-space:nowrap;
  transition:transform .4s var(--ease-out),color .4s,border-color .4s;
}
.btn::before{content:"";position:absolute;inset:0;background:var(--gold-bright);
  transform:translateY(101%);transition:transform .5s var(--ease-out);z-index:-1;border-radius:100px}
.btn:hover::before{transform:translateY(0)}
.btn--gold{background:var(--gold);color:var(--green-950)}
.btn--gold:hover{color:var(--green-950)}
.btn--ghost{border:1px solid rgba(244,239,227,.35);color:var(--cream)}
.btn--ghost:hover{color:var(--green-950)}
.btn--dark{background:var(--green-800);color:var(--cream);border:1px solid var(--green-700)}
.btn--dark:hover{color:var(--green-950)}
.btn--pill{border:1px solid rgba(244,239,227,.3);font-size:.78rem;padding:.7em 1.3em}
.btn--pill:hover{color:var(--green-950)}
.btn--block{width:100%;justify-content:center;padding-top:1.1em;padding-bottom:1.1em}

/* ============================================================
   MOBILE MENU
   ============================================================ */
.mobile-menu{
  position:fixed;inset:0;z-index:790;background:var(--green-950);
  display:flex;flex-direction:column;justify-content:center;padding:104px var(--gutter) 0;
  clip-path:circle(0% at calc(100% - 38px) 38px);transition:clip-path .7s var(--ease);
  visibility:hidden;overflow-y:auto;
}
.mobile-menu.open{clip-path:circle(150% at calc(100% - 38px) 38px);visibility:visible}
.mobile-menu__nav{display:flex;flex-direction:column;gap:.2rem}
.mobile-menu__nav a{font-family:var(--font-display);font-size:clamp(2rem,9vw,3.2rem);display:flex;align-items:baseline;gap:1rem;padding:.18em 0;color:var(--cream);opacity:0;transform:translateY(20px)}
.mobile-menu.open .mobile-menu__nav a{opacity:1;transform:none;transition:opacity .5s var(--ease) calc(.2s + var(--i,0)*.06s),transform .5s var(--ease) calc(.2s + var(--i,0)*.06s)}
.mobile-menu__nav a span{font-family:var(--font-body);font-size:.8rem;color:var(--gold);letter-spacing:.1em}
.mobile-menu__foot{margin-top:auto;margin-bottom:8vh;display:flex;flex-direction:column;gap:1rem;align-items:flex-start}
.mobile-menu__foot a:last-child{color:var(--green-400);letter-spacing:.05em}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;height:100svh;min-height:600px;overflow:hidden;display:flex;flex-direction:column;justify-content:center}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__video{width:100%;height:100%;object-fit:cover;transform:scale(1.06)}
.hero__scrim{position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg,rgba(12,23,18,.55) 0%,rgba(12,23,18,.15) 30%,rgba(12,23,18,.35) 65%,rgba(12,23,18,.92) 100%),
    radial-gradient(120% 80% at 50% 0%,transparent 40%,rgba(12,23,18,.4) 100%);
}
.hero__content{position:relative;z-index:2;padding:0 var(--gutter);max-width:var(--maxw);margin:0 auto;width:100%}
.hero__eyebrow{font-size:.78rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-bright);margin-bottom:1.4rem;font-weight:600;overflow:hidden}
.hero__title{font-size:clamp(3rem,12vw,10.5rem);line-height:.92;font-weight:300;letter-spacing:-.02em}
.hero__title .line{display:block;overflow:hidden}
.hero__title .line span{display:block}
.hero__title .line--serif span{font-style:italic;color:var(--gold-bright);font-weight:400}
.hero__sub{max-width:46ch;margin-top:1.8rem;font-size:clamp(1rem,1.5vw,1.25rem);color:rgba(244,239,227,.86);overflow:hidden;font-weight:300}
.hero__actions{display:flex;gap:1rem;margin-top:2.4rem;flex-wrap:wrap}

.hero__meta{position:absolute;z-index:2;bottom:clamp(28px,5vh,56px);left:var(--gutter);right:var(--gutter);
  max-width:var(--maxw);margin:0 auto;display:flex;gap:clamp(24px,5vw,72px);flex-wrap:wrap}
.hero__meta-item{display:flex;flex-direction:column;gap:.2rem}
.hero__meta-item strong{font-family:var(--font-display);font-size:clamp(1.3rem,2.4vw,2rem);font-weight:400;color:var(--cream)}
.hero__meta-item span{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(244,239,227,.6)}

.hero__scroll{position:absolute;z-index:2;bottom:clamp(28px,5vh,56px);right:var(--gutter);display:flex;flex-direction:column;align-items:center;gap:.8rem}
.hero__scroll span:first-child{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(244,239,227,.7);writing-mode:vertical-rl}
.hero__scroll-line{width:1px;height:54px;background:linear-gradient(var(--gold),transparent);position:relative;overflow:hidden}
.hero__scroll-line::after{content:"";position:absolute;top:0;left:0;width:100%;height:40%;background:var(--gold);animation:scrolldot 2s var(--ease) infinite}
@keyframes scrolldot{0%{transform:translateY(-100%)}100%{transform:translateY(250%)}}
@media (max-width:760px){.hero__scroll{display:none}}

/* ============================================================
   MANIFESTO
   ============================================================ */
.manifesto{position:relative;background:var(--green-950);padding:clamp(90px,16vh,200px) var(--gutter);overflow:hidden}
.manifesto__canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;opacity:.8}
.manifesto__inner{position:relative;z-index:1;max-width:1100px;margin:0 auto;text-align:center}
.manifesto__eyebrow{font-size:.75rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:2rem;font-weight:600}
.manifesto__text{font-family:var(--font-display);font-weight:300;font-size:clamp(1.7rem,4.4vw,3.6rem);line-height:1.18;letter-spacing:-.01em}
.manifesto__text .word{display:inline-block;opacity:.12;transition:opacity .3s}
.manifesto__sign{margin-top:2.4rem;font-size:.85rem;letter-spacing:.1em;color:var(--green-400);overflow:hidden}

/* ============================================================
   STATS
   ============================================================ */
.stats{background:var(--cream);color:var(--ink);padding:clamp(80px,12vh,160px) 0}
.stats .section-head__index{color:var(--gold)}
.stats .section-head__title{color:var(--ink)}
.stats .section-head__title em{color:var(--green-600)}
.stats__grid{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter);
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(19,35,27,.12)}
.stat{background:var(--cream);padding:clamp(28px,3.5vw,52px) clamp(20px,2.5vw,40px)}
.stat__num{display:block;font-family:var(--font-display);font-weight:300;font-size:clamp(2.6rem,5.5vw,4.6rem);line-height:1;color:var(--green-600);letter-spacing:-.02em}
.stat__label{display:block;margin-top:.9rem;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);font-weight:600}
.stat__desc{margin-top:.7rem;font-size:.95rem;color:var(--ink-soft);max-width:32ch}

/* ============================================================
   TERRENO
   ============================================================ */
.terreno{background:var(--green-900);padding:clamp(80px,12vh,160px) 0}
.terreno__feature{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter);
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,5vw,80px);align-items:center}
.parallax-wrap{position:relative;overflow:hidden;border-radius:2px;aspect-ratio:4/5}
.parallax-img{width:100%;height:120%;object-fit:cover;will-change:transform}
.terreno__lead{font-family:var(--font-display);font-weight:300;font-size:clamp(1.5rem,2.6vw,2.3rem);line-height:1.22;margin-bottom:2.4rem}
.terreno__list li{display:flex;gap:1.2rem;padding:1.4rem 0;border-top:1px solid rgba(244,239,227,.14)}
.terreno__list li:last-child{border-bottom:1px solid rgba(244,239,227,.14)}
.terreno__list span{font-family:var(--font-display);color:var(--gold);font-size:1rem;padding-top:.2rem;min-width:1.6em}
.terreno__list h4{font-size:1.18rem;font-weight:500;margin-bottom:.3rem}
.terreno__list p{font-size:.95rem;color:rgba(244,239,227,.66)}

.terreno__plot{max-width:var(--maxw);margin:clamp(60px,9vw,130px) auto 0;padding:0 var(--gutter);
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,80px);align-items:center}
.terreno__plot-text h3{font-size:clamp(1.7rem,3.2vw,2.8rem);margin-bottom:1.3rem}
.terreno__plot-text p{color:rgba(244,239,227,.74);max-width:46ch;font-size:1.02rem}
.terreno__plot-text strong{color:var(--gold-bright);font-weight:500}
.terreno__tags{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.8rem}
.terreno__tags span{font-size:.76rem;letter-spacing:.05em;padding:.5em 1em;border:1px solid rgba(244,239,227,.2);border-radius:100px;color:rgba(244,239,227,.8)}
/* satellite plot map with animated boundary overlay */
.terreno__plot-map{position:relative;aspect-ratio:1448/1086;border-radius:4px;overflow:hidden;
  border:1px solid rgba(244,239,227,.14);box-shadow:0 30px 60px -30px rgba(0,0,0,.6)}
.terreno__plot-map img{width:100%;height:100%;object-fit:cover;filter:saturate(1.06) contrast(1.03)}
.plot-map__grad{position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(12,23,18,.18) 0%,transparent 28%,transparent 62%,rgba(12,23,18,.72) 100%)}
.plot-overlay{position:absolute;inset:0;width:100%;height:100%;overflow:visible}
.plot-shape{fill:rgba(220,192,116,.12);stroke:var(--gold-bright);stroke-width:6;stroke-linejoin:round;
  filter:drop-shadow(0 0 9px rgba(220,192,116,.9))}
.plot-dot{fill:#fff;stroke:var(--gold-bright);stroke-width:5;opacity:0;
  transform-box:fill-box;transform-origin:center;
  filter:drop-shadow(0 0 8px rgba(220,192,116,.95));
  animation:dotBlink 1.9s ease-in-out infinite}
.plot-dot:nth-child(3){animation-delay:.5s}
.plot-dot:nth-child(4){animation-delay:1s}
.plot-dot:nth-child(5){animation-delay:1.45s}
@keyframes dotBlink{
  0%,100%{transform:scale(1);filter:drop-shadow(0 0 5px rgba(220,192,116,.6))}
  50%{transform:scale(1.28);filter:drop-shadow(0 0 17px rgba(220,192,116,1))}
}
.plot-tag{position:absolute;left:16px;bottom:14px;z-index:2;display:flex;flex-direction:column;line-height:1.05;
  background:rgba(12,23,18,.5);backdrop-filter:blur(6px);border:1px solid rgba(244,239,227,.18);
  padding:.6rem .9rem;border-radius:4px}
.plot-tag strong{font-family:var(--font-display);font-size:1.5rem;color:var(--cream);font-style:italic}
.plot-tag span{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-bright);margin-top:.2rem}
.plot-compass{position:absolute;top:14px;right:14px;z-index:2;display:flex;flex-direction:column;align-items:center;
  color:var(--cream);opacity:.85}
.plot-compass span{font-size:.62rem;letter-spacing:.1em;font-weight:600}
.plot-compass svg{width:16px;height:16px;fill:var(--gold-bright)}

/* ============================================================
   LOCATION
   ============================================================ */
.location{background:var(--cream);color:var(--ink);padding:clamp(80px,12vh,160px) 0}
.location .section-head__title{color:var(--ink)}
.location .section-head__title em{color:var(--green-600)}
.location__intro{max-width:60ch;margin:0 auto clamp(40px,6vw,80px);padding:0 var(--gutter);
  font-family:var(--font-display);font-weight:300;font-size:clamp(1.4rem,2.6vw,2.1rem);line-height:1.3;color:var(--ink)}

.gallery{overflow:hidden;padding-left:var(--gutter)}
.gallery__track{display:flex;gap:clamp(16px,2vw,28px);will-change:transform}
.gallery__item{position:relative;flex:0 0 auto;width:clamp(280px,42vw,560px);aspect-ratio:3/4;overflow:hidden;border-radius:2px}
/* mobile/tablet: native swipe gallery (no pin) */
@media (max-width:1023px){
  .gallery{overflow-x:auto;overflow-y:hidden;scroll-snap-type:x proximity;
    -webkit-overflow-scrolling:touch;padding-right:var(--gutter);scrollbar-width:none}
  .gallery::-webkit-scrollbar{display:none}
  .gallery__track{transform:none!important}
  .gallery__item{scroll-snap-align:start;width:78vw}
}
.gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease-out)}
.gallery__item:hover img{transform:scale(1.05)}
.gallery__item figcaption{position:absolute;left:18px;bottom:16px;color:var(--cream);font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;
  text-shadow:0 2px 14px rgba(0,0,0,.5);z-index:2}
.gallery__item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(12,23,18,.7));z-index:1}

.location__grid{max-width:var(--maxw);margin:clamp(50px,8vw,110px) auto 0;padding:0 var(--gutter);
  display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(30px,4vw,64px);align-items:stretch}
.location__connect h3{font-size:clamp(1.6rem,3vw,2.5rem);color:var(--ink);margin-bottom:1.6rem}
.location__connect ul{display:flex;flex-direction:column;gap:1.1rem}
.location__connect li{font-size:1.02rem;color:var(--ink-soft);padding-left:1.5rem;position:relative}
.location__connect li::before{content:"";position:absolute;left:0;top:.6em;width:8px;height:8px;border-radius:50%;background:var(--gold)}
.location__connect strong{color:var(--ink);font-weight:600}
.location__map{min-height:340px;border-radius:4px;overflow:hidden;border:1px solid rgba(19,35,27,.15)}
.location__map iframe{width:100%;height:100%;min-height:340px;border:0;filter:saturate(.85) contrast(1.02)}

/* ============================================================
   POTENTIAL
   ============================================================ */
.potential{background:var(--green-950);padding:clamp(80px,12vh,160px) 0}
.potential__list{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}
.pcard{display:grid;grid-template-columns:auto 1fr auto;gap:clamp(20px,4vw,60px);align-items:center;
  padding:clamp(28px,4vw,52px) 0;border-top:1px solid rgba(244,239,227,.14);position:relative;transition:padding-left .5s var(--ease)}
.pcard:last-child{border-bottom:1px solid rgba(244,239,227,.14)}
.pcard__n{font-family:var(--font-display);font-size:clamp(1rem,1.5vw,1.3rem);color:var(--gold)}
.pcard h3{font-size:clamp(1.6rem,4vw,3.4rem);font-weight:300;transition:color .4s,transform .5s var(--ease)}
.pcard p{font-size:.98rem;color:rgba(244,239,227,.6);max-width:34ch;justify-self:end;text-align:right}
.pcard::before{content:"";position:absolute;left:0;top:0;bottom:0;width:0;background:linear-gradient(90deg,rgba(194,163,94,.08),transparent);transition:width .5s var(--ease);z-index:-1}
.pcard:hover::before{width:100%}
.pcard:hover{padding-left:clamp(12px,2vw,30px)}
.pcard:hover h3{color:var(--gold-bright)}
@media (max-width:760px){
  .pcard{grid-template-columns:auto 1fr;gap:1rem}
  .pcard p{grid-column:1/-1;justify-self:start;text-align:left;max-width:none}
}

/* ============================================================
   SPEC
   ============================================================ */
.spec{background:var(--cream);color:var(--ink);padding:clamp(80px,12vh,160px) 0}
.spec .section-head__title{color:var(--ink)}
.spec .section-head__title em{color:var(--green-600)}
.spec__grid{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter);display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,80px)}
.spec__block h3{font-size:1.4rem;font-weight:500;font-family:var(--font-body);letter-spacing:.02em;margin-bottom:1.4rem;color:var(--green-600)}
.spec__table{width:100%;border-collapse:collapse}
.spec__table tr{border-bottom:1px solid rgba(19,35,27,.14)}
.spec__table th{text-align:left;font-weight:400;color:var(--ink-soft);padding:.95rem 0;font-size:.96rem}
.spec__table td{text-align:right;font-weight:600;color:var(--ink);padding:.95rem 0;font-size:.96rem;font-family:var(--font-display)}
.spec__cta{max-width:var(--maxw);margin:clamp(40px,6vw,72px) auto 0;padding:0 var(--gutter);
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}
.spec__cta p{font-size:1.05rem;color:var(--ink-soft);max-width:40ch}

/* ============================================================
   CONTACT
   ============================================================ */
.contact{position:relative;overflow:hidden;padding:clamp(80px,14vh,180px) 0}
.contact__media{position:absolute;inset:0;z-index:0}
.contact__video{width:100%;height:100%;object-fit:cover}
.contact__scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,23,18,.86),rgba(12,23,18,.94))}
.contact__inner{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter);
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,100px);align-items:start}
.contact__title{font-size:clamp(2.2rem,5.5vw,4.6rem);font-weight:300;margin:1.2rem 0 1.6rem}
.contact__title em{color:var(--gold-bright)}
.contact__lead{color:rgba(244,239,227,.82);max-width:42ch;font-size:1.05rem}
.contact__direct{margin-top:2.6rem;display:flex;flex-direction:column;gap:1rem}
.contact__direct a,.contact__loc{display:flex;flex-direction:column;gap:.1rem;font-size:1.1rem;color:var(--cream);font-family:var(--font-display);transition:color .3s}
.contact__direct a:hover{color:var(--gold-bright)}
.contact__direct span:first-child{font-family:var(--font-body);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}

.contact__form{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem;
  background:rgba(244,239,227,.04);border:1px solid rgba(244,239,227,.12);
  padding:clamp(24px,3vw,40px);border-radius:6px;backdrop-filter:blur(6px)}
.field{position:relative}
.field--full{grid-column:1/-1}
.field input,.field textarea,.field select{
  width:100%;background:transparent;border:0;border-bottom:1px solid rgba(244,239,227,.28);
  color:var(--cream);padding:1.4rem 0 .6rem;font-family:var(--font-body);font-size:1rem;font-weight:300;
  transition:border-color .3s}
.field select{padding:1.1rem 0 .6rem}
.field select option{background:var(--green-850);color:var(--cream)}
.field textarea{resize:vertical;min-height:70px}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--gold)}
.field label{position:absolute;left:0;top:1.3rem;color:rgba(244,239,227,.5);font-size:1rem;pointer-events:none;transition:.3s var(--ease)}
.field input:focus+label,.field input:not(:placeholder-shown)+label,
.field textarea:focus+label,.field textarea:not(:placeholder-shown)+label{top:.1rem;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold)}
.field--select{display:flex;flex-direction:column;gap:.45rem;justify-content:flex-end}
.field--select .field__label-static{position:static;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);font-weight:600;line-height:1}
.field--select select{padding:.5rem 0}
.contact__form .btn--block{grid-column:1/-1}
.contact__pdf{margin-top:-.35rem}
.contact__note{grid-column:1/-1;font-size:.78rem;color:rgba(244,239,227,.5);text-align:center;margin-top:-.3rem}
.field.invalid input,.field.invalid textarea{border-color:#d98b6a}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--green-950);padding:clamp(60px,8vw,110px) var(--gutter) 0;overflow:hidden}
.footer__top{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1.4fr;gap:clamp(36px,5vw,80px);padding-bottom:clamp(40px,6vw,80px)}
.footer__brand img{height:46px;margin-bottom:1.4rem}
.footer__brand p{color:rgba(244,239,227,.6);max-width:30ch}
.footer__cols{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.footer__col h5{font-family:var(--font-body);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:1.2rem;font-weight:600}
.footer__col a{display:block;padding:.35rem 0;color:rgba(244,239,227,.72);font-size:.95rem;transition:color .3s}
.footer__col a:hover{color:var(--cream)}
.footer__bottom{max-width:var(--maxw);margin:0 auto;border-top:1px solid rgba(244,239,227,.12);
  display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;padding-top:1.4rem}
.footer__legal{display:flex;flex-direction:column;gap:.4rem}
.footer__legal>span{font-size:.8rem;color:rgba(244,239,227,.5)}
.footer__credit{font-size:.8rem;color:rgba(244,239,227,.45);transition:color .3s;width:fit-content}
.footer__credit strong{font-weight:600;color:var(--gold)}
.footer__credit:hover{color:var(--cream)}
.footer__credit:hover strong{color:var(--gold-bright)}
.footer__big{font-family:var(--font-display);font-style:italic;font-weight:300;
  font-size:clamp(2.6rem,12vw,12rem);line-height:.8;color:rgba(244,239,227,.06);letter-spacing:-.02em;
  transform:translateY(.12em)}

/* ============================================================
   REVEAL HELPERS (GSAP toggles these via JS where needed)
   ============================================================ */
.reveal-line span{display:block;transform:translateY(110%);transition:transform .9s var(--ease-out)}
.reveal-line.in span{transform:translateY(0)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .nav{display:none}
  .header__cta{display:none}
  .burger{display:block}
  .terreno__feature,.terreno__plot,.location__grid,.spec__grid,.contact__inner,.footer__top{grid-template-columns:1fr}
  .contact__form{grid-template-columns:1fr 1fr}
  .footer__top{gap:40px}
  .stats__grid{grid-template-columns:1fr 1fr}
  .terreno__plot-svg{max-width:520px;margin:0 auto;width:100%}
}
@media (max-width:760px){
  .stats__grid{grid-template-columns:1fr 1fr}
  .hero__meta{gap:20px}
  .hero__meta-item:nth-child(3){display:none}
  .parallax-wrap{aspect-ratio:4/3}
  .footer__cols{grid-template-columns:1fr 1fr}
  .spec__cta{flex-direction:column;align-items:flex-start}
  .footer__bottom{flex-direction:column;align-items:flex-start}
}
@media (max-width:480px){
  .stats__grid{grid-template-columns:1fr}
  .contact__form{grid-template-columns:1fr}
  .footer__cols{grid-template-columns:1fr}
  .hero__actions .btn{flex:1;justify-content:center}
}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .hero__video{transform:none}
  .manifesto__text .word{opacity:1}
}
