/* =============================================================================
   Javier Jorge Larraza García — Nedi Consultores  ·  v2 Architectural Editorial
   Palette: Concrete bone · Teal-petrol · Copper · True black
   Typography: Marcellus (display) · Outfit (body)
   ============================================================================= */

/* ---------- 1. Tokens ---------- */
:root{
  --bg:           #ebe7df;
  --bg-alt:       #d6cfbd;
  --bg-warm:      #e0d8c3;
  --bg-dark:      #0a0a0a;
  --bg-deep:      #051a1c;
  --paper:        #fafaf7;
  --paper-soft:   #f3eee2;
  --ink:          #0a0a0a;
  --ink-soft:     #2c2c2c;
  --ink-mute:     #6c6c68;
  --accent:       #0e3a3d;
  --accent-dark:  #062425;
  --accent-soft:  #b8d1cf;
  --accent-fade:  #dcebea;
  --gold:         #c4905a;
  --gold-soft:    #dab086;
  --gold-deep:    #966a3c;
  --line:         #1a1a1a;
  --line-soft:    #c2b9a3;
  --border:       #b4ab94;
  --border-soft:  #d6cfbd;
  --shadow-fine:  0 1px 0 rgba(10,10,10,.06);
  --shadow-md:    0 8px 24px rgba(10,10,10,.10), 0 2px 6px rgba(10,10,10,.05);
  --shadow-deep:  0 24px 80px rgba(10,10,10,.16), 0 8px 24px rgba(10,10,10,.10);
  --serif:        'Marcellus', 'Cormorant Garamond', Georgia, serif;
  --serif-italic: 'Cormorant Garamond', Georgia, serif;
  --sans:         'Outfit', system-ui, -apple-system, 'Helvetica Neue', sans-serif;
  --mono:         'JetBrains Mono', 'IBM Plex Mono', monospace;
  --tx:           cubic-bezier(.2,.8,.2,1);
  --tx-out:       cubic-bezier(.16,1,.3,1);
  --max:          1320px;
  --max-narrow:   920px;
  --max-text:     680px;
  --pad:          clamp(1.25rem, 3vw, 2.25rem);
  --gut:          clamp(1.5rem, 3vw, 2.5rem);
}

/* ---------- 2. Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  font-size:16.5px;
  font-weight:300;
  line-height:1.62;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,picture,video{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea,select{font:inherit;color:inherit}
ul,ol{list-style:none}
::selection{background:var(--accent);color:var(--paper)}

/* ---------- 3. Typography ---------- */
h1,h2,h3,h4,h5,h6{
  font-family:var(--serif);
  font-weight:400;
  letter-spacing:-.012em;
  color:var(--ink);
  line-height:1.04;
}
h1{
  font-size:clamp(2.8rem, 7vw, 6rem);
  letter-spacing:-.025em;
  line-height:.96;
}
h2{
  font-size:clamp(2.1rem, 4.6vw, 3.8rem);
  letter-spacing:-.018em;
  line-height:1.04;
}
h3{font-size:clamp(1.5rem, 2.6vw, 2.15rem);letter-spacing:-.005em;line-height:1.15}
h4{font-size:clamp(1.2rem, 1.7vw, 1.45rem);font-weight:400}
h5{font-size:1.05rem;letter-spacing:.04em}
p{font-size:1.0625rem;line-height:1.78;color:var(--ink-soft);font-weight:300}
.lead{
  font-family:var(--sans);
  font-size:clamp(1.15rem, 1.85vw, 1.45rem);
  line-height:1.5;
  color:var(--ink-soft);
  font-weight:300;
  max-width:48ch;
}
.lead.serif{font-family:var(--serif-italic);font-style:italic;font-size:clamp(1.3rem, 2.2vw, 1.7rem);font-weight:400}
.eyebrow{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--sans);
  font-size:.7rem;
  font-weight:500;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:1.6rem;
}
.eyebrow::before{
  content:'';
  width:24px;height:1px;
  background:var(--accent);
  display:inline-block;
}
.eyebrow.gold{color:var(--gold-deep)}
.eyebrow.gold::before{background:var(--gold-deep)}
.eyebrow.light{color:var(--gold-soft)}
.eyebrow.light::before{background:var(--gold-soft)}
strong,b{font-weight:500;color:var(--ink)}
em,i{font-style:italic;font-family:var(--serif-italic)}

/* ---------- 4. Layout ---------- */
.container{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
.container-narrow{max-width:var(--max-narrow);margin:0 auto;padding:0 var(--pad)}
.container-text{max-width:var(--max-text);margin:0 auto;padding:0 var(--pad)}
section{padding:clamp(4.5rem, 9vw, 8rem) 0;position:relative}
section.tight{padding:clamp(3rem, 6vw, 5rem) 0}
.divider{height:1px;background:var(--line-soft);max-width:var(--max);margin:0 auto}
.section-marker{
  position:absolute;
  top:clamp(1.5rem, 4vw, 3rem);
  left:clamp(1rem, 3vw, 2rem);
  font-family:var(--sans);
  font-size:.72rem;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--ink-mute);
  font-weight:500;
  display:flex;align-items:center;gap:.6rem;
  z-index:2;
}
.section-marker .num{
  font-family:var(--serif);
  font-size:1.4rem;
  color:var(--accent);
  letter-spacing:0;
  font-weight:400;
}
@media (max-width:900px){.section-marker{position:static;margin-bottom:2rem}}

/* ---------- 5. Scroll progress bar ---------- */
.scroll-progress{
  position:fixed;
  top:0;left:0;
  height:2px;
  background:var(--accent);
  width:0%;
  z-index:200;
  transition:width .1s linear;
}

/* ---------- 6. Header ---------- */
.site-header{
  position:fixed;
  top:0;left:0;right:0;
  z-index:100;
  padding:1.4rem var(--pad);
  display:flex;align-items:center;justify-content:space-between;
  gap:1.5rem;
  transition:background .35s var(--tx), backdrop-filter .35s var(--tx), border-color .35s var(--tx);
  background:rgba(235,231,223,0);
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(235,231,223,.94);
  backdrop-filter:blur(20px) saturate(140%);
  -webkit-backdrop-filter:blur(20px) saturate(140%);
  border-bottom-color:var(--line-soft);
}
.brand{display:flex;align-items:center;gap:.85rem;flex-shrink:0;z-index:2;mix-blend-mode:normal}
.brand .mono{
  width:46px;height:46px;
  display:flex;align-items:center;justify-content:center;
  background:var(--ink);
  color:var(--paper);
  font-family:var(--serif);
  font-size:.92rem;
  font-weight:400;
  letter-spacing:.08em;
  flex-shrink:0;
  position:relative;
  transition:background .3s var(--tx);
}
.brand:hover .mono{background:var(--accent)}
.brand .mono::after{
  content:'';
  position:absolute;inset:3px;
  border:1px solid rgba(255,255,255,.22);
  pointer-events:none;
}
.brand-txt{display:flex;flex-direction:column;line-height:1.05}
.brand-txt .top{
  font-family:var(--serif);
  font-size:1.05rem;
  font-weight:400;
  color:var(--ink);
  letter-spacing:-.005em;
}
.brand-txt .sub{
  font-family:var(--sans);
  font-size:.66rem;
  font-weight:500;
  color:var(--ink-mute);
  letter-spacing:.18em;
  text-transform:uppercase;
  margin-top:5px;
}
.nav{display:flex;align-items:center;gap:1.85rem}
.nav a{
  font-size:.85rem;
  font-weight:400;
  color:var(--ink-soft);
  letter-spacing:.02em;
  position:relative;
  padding:.4rem 0;
  transition:color .25s var(--tx);
}
.nav a::after{
  content:'';
  position:absolute;
  bottom:0;left:0;
  width:0;height:1px;
  background:var(--accent);
  transition:width .3s var(--tx);
}
.nav a:hover,.nav a.active{color:var(--ink)}
.nav a:hover::after,.nav a.active::after{width:100%}
.nav-cta{
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--ink);
  color:var(--paper)!important;
  padding:.78rem 1.35rem!important;
  font-size:.78rem!important;
  font-weight:500;
  letter-spacing:.12em;
  text-transform:uppercase;
  transition:background .3s var(--tx), letter-spacing .35s var(--tx);
  border:1px solid var(--ink);
}
.nav-cta:hover{background:var(--accent);border-color:var(--accent);letter-spacing:.16em}
.nav-cta::after{display:none}
.nav-cta svg{width:14px;height:14px}
.menu-toggle{display:none;width:42px;height:42px;align-items:center;justify-content:center;flex-direction:column;gap:5px}
.menu-toggle span{width:22px;height:1px;background:var(--ink);transition:all .35s var(--tx)}
.menu-toggle.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.menu-toggle.open span:nth-child(2){opacity:0}
.menu-toggle.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

@media (max-width:900px){
  .site-header{padding:1rem var(--pad)}
  .nav{
    position:fixed;top:0;left:0;right:0;bottom:0;
    background:var(--bg);
    flex-direction:column;
    align-items:flex-start;justify-content:center;
    gap:0;
    padding:6rem 2rem 3rem;
    transform:translateY(-100%);
    transition:transform .5s var(--tx-out);
    z-index:1;
    overflow-y:auto;
  }
  .nav.open{transform:translateY(0)}
  .nav a{
    padding:1rem 0;
    font-family:var(--serif);
    font-size:2rem;
    color:var(--ink);
    letter-spacing:-.01em;
    border-bottom:1px solid var(--line-soft);
    width:100%;
  }
  .nav a:last-child{border-bottom:none}
  .nav-cta{margin-top:1.5rem;font-size:.85rem!important;padding:1rem 1.4rem!important}
  .menu-toggle{display:flex;z-index:3}
}

/* ---------- 7. Hero (architectural full-bleed with parallax) ---------- */
.hero{
  position:relative;
  min-height:100vh;
  min-height:100dvh;
  display:flex;
  align-items:flex-end;
  padding:8rem 0 4rem;
  overflow:hidden;
  background:var(--bg-dark);
  color:var(--paper);
}
.hero-img-wrap{
  position:absolute;inset:0;
  overflow:hidden;
  z-index:0;
  will-change:transform;
}
.hero-img{
  width:100%;height:120%;
  object-fit:cover;
  position:absolute;top:0;left:0;
  filter:saturate(.88) contrast(1.04);
  will-change:transform;
}
.hero::after{
  content:'';
  position:absolute;
  inset:0;
  background:
    linear-gradient(115deg, rgba(0,0,0,.78) 0%, rgba(0,0,0,.55) 30%, rgba(0,0,0,.25) 55%, rgba(0,0,0,.05) 100%),
    linear-gradient(to top, rgba(0,0,0,.62) 0%, rgba(0,0,0,.18) 40%, rgba(0,0,0,0) 70%);
  z-index:1;
}
.hero > .container{position:relative;z-index:2;width:100%}
.hero h1{
  color:var(--paper);
  max-width:14ch;
  letter-spacing:-.03em;
  text-shadow:
    0 4px 28px rgba(0,0,0,.85),
    0 2px 8px rgba(0,0,0,.7),
    0 1px 2px rgba(0,0,0,.6);
}
.hero h1 em{
  font-family:var(--serif-italic);
  font-style:italic;
  color:var(--gold-soft);
  font-weight:400;
}
.hero .lead{
  color:rgba(255,255,255,.93);
  margin-top:2rem;
  max-width:48ch;
  text-shadow:0 2px 12px rgba(0,0,0,.7), 0 1px 3px rgba(0,0,0,.55);
}
.hero .eyebrow{
  color:var(--gold-soft);
  text-shadow:0 2px 8px rgba(0,0,0,.6), 0 1px 2px rgba(0,0,0,.5);
}
.hero .eyebrow::before{background:var(--gold-soft)}
.hero-bottom-row{
  margin-top:3.5rem;
  display:flex;justify-content:space-between;align-items:flex-end;
  flex-wrap:wrap;gap:2.5rem;
}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap}
.hero-meta{
  display:flex;gap:3rem;
  flex-wrap:wrap;
}
.hero-meta-item{
  display:flex;flex-direction:column;
  text-shadow:0 2px 8px rgba(0,0,0,.6);
  border-left:1px solid rgba(255,255,255,.3);
  padding-left:1.4rem;
}
.hero-meta-item .num{
  font-family:var(--serif);
  font-size:clamp(2rem, 3.8vw, 2.8rem);
  font-weight:400;
  color:var(--paper);
  line-height:1;
  letter-spacing:-.015em;
}
.hero-meta-item .lbl{
  font-size:.65rem;
  font-weight:500;
  color:rgba(255,255,255,.78);
  letter-spacing:.22em;
  text-transform:uppercase;
  margin-top:.8rem;
}
.hero-scroll-hint{
  position:absolute;
  bottom:1.8rem;left:50%;
  transform:translateX(-50%);
  z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:.6rem;
  font-size:.62rem;
  letter-spacing:.36em;
  text-transform:uppercase;
  color:rgba(255,255,255,.7);
  font-weight:500;
}
.hero-scroll-hint .line{
  width:1px;height:36px;
  background:rgba(255,255,255,.5);
  position:relative;overflow:hidden;
}
.hero-scroll-hint .line::after{
  content:'';
  position:absolute;
  top:-100%;left:0;width:100%;height:100%;
  background:var(--gold-soft);
  animation:scrollLine 2.4s ease-in-out infinite;
}
@keyframes scrollLine{
  0%{top:-100%}
  60%{top:100%}
  100%{top:100%}
}

.hero-compact{
  min-height:60vh;
  padding:9rem 0 3rem;
}
.hero-compact h1{font-size:clamp(2.4rem, 5.2vw, 4.4rem)}

/* ---------- 8. Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.75rem;
  font-family:var(--sans);
  font-size:.78rem;
  font-weight:500;
  letter-spacing:.18em;
  text-transform:uppercase;
  padding:1.05rem 1.95rem;
  cursor:pointer;
  transition:all .4s var(--tx);
  border:1px solid transparent;
  white-space:nowrap;
  position:relative;
  overflow:hidden;
}
.btn-primary{background:var(--accent);color:var(--paper);border-color:var(--accent)}
.btn-primary:hover{background:var(--accent-dark);border-color:var(--accent-dark);letter-spacing:.22em}
.btn-ink{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn-ink:hover{background:var(--accent);border-color:var(--accent);letter-spacing:.22em}
.btn-ghost{background:transparent;color:var(--paper);border-color:rgba(255,255,255,.5)}
.btn-ghost:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:var(--paper);letter-spacing:.22em}
.btn-gold{background:var(--gold);color:var(--paper);border-color:var(--gold)}
.btn-gold:hover{background:var(--gold-deep);border-color:var(--gold-deep);letter-spacing:.22em}
.btn-large{padding:1.2rem 2.4rem;font-size:.82rem}
.btn-small{padding:.78rem 1.3rem;font-size:.7rem}
.btn svg{width:14px;height:14px;flex-shrink:0;transition:transform .35s var(--tx)}
.btn:hover svg{transform:translateX(3px)}

/* ---------- 9. Section heading ---------- */
.sec-head{margin-bottom:clamp(3rem, 5.5vw, 5rem)}
.sec-head.center{text-align:center}
.sec-head h2{margin-bottom:1.2rem;max-width:24ch}
.sec-head.center h2{margin-left:auto;margin-right:auto}
.sec-head .lead{max-width:62ch;color:var(--ink-soft);font-size:1.15rem}
.sec-head.center .lead{margin-left:auto;margin-right:auto}

/* Two-column header for asymmetric layouts */
.sec-head-split{
  display:grid;grid-template-columns:1fr 1.3fr;
  gap:clamp(2rem, 5vw, 4.5rem);
  align-items:flex-end;
  margin-bottom:clamp(3rem, 5vw, 4.5rem);
}
@media (max-width:900px){.sec-head-split{grid-template-columns:1fr}}
.sec-head-split .right{padding-bottom:.5rem}
.sec-head-split .right p{font-size:1.05rem;max-width:54ch}

/* ---------- 10. Stagger reveals ---------- */
.reveal{
  opacity:0;
  transform:translateY(40px);
  transition:opacity 1s var(--tx-out), transform 1s var(--tx-out);
  transition-delay:var(--delay, 0s);
}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-mask{
  display:inline-block;
  overflow:hidden;
  vertical-align:bottom;
}
.reveal-mask > span{
  display:inline-block;
  transform:translateY(110%);
  transition:transform 1.1s var(--tx-out);
  transition-delay:var(--delay, 0s);
}
.reveal-mask.in > span{transform:translateY(0)}
.reveal-img{
  position:relative;overflow:hidden;
  clip-path:inset(0 0 100% 0);
  transition:clip-path 1.4s var(--tx-out);
}
.reveal-img.in{clip-path:inset(0 0 0 0)}

/* ---------- 11. Cards & grids ---------- */
.grid{display:grid;gap:var(--gut)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-auto-md{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
@media (max-width:900px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.grid-3.keep-2{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.grid-3.keep-2{grid-template-columns:1fr}}

/* Property card — editorial vertical with overlay number */
.prop-card{
  background:transparent;
  display:flex;flex-direction:column;
  position:relative;
  transition:transform .5s var(--tx);
}
.prop-card:hover{transform:translateY(-4px)}
.prop-card-img{
  aspect-ratio:4/5;
  overflow:hidden;
  position:relative;
  background:var(--bg-alt);
  margin-bottom:1.6rem;
}
.prop-card-img img{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform 1.2s var(--tx);
}
.prop-card:hover .prop-card-img img{transform:scale(1.06)}
.prop-card-tag{
  position:absolute;top:1rem;left:1rem;
  background:var(--paper);
  color:var(--ink);
  padding:.45rem .9rem;
  font-size:.62rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:500;
  z-index:2;
}
.prop-card-num{
  position:absolute;
  bottom:1rem;right:1rem;
  font-family:var(--serif);
  font-size:1.2rem;
  color:var(--paper);
  letter-spacing:.05em;
  z-index:2;
  text-shadow:0 2px 8px rgba(0,0,0,.5);
}
.prop-card-loc{
  font-size:.7rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold-deep);
  font-weight:500;
  margin-bottom:.5rem;
}
.prop-card h3{
  font-size:clamp(1.3rem, 1.8vw, 1.55rem);
  letter-spacing:-.005em;
  font-weight:400;
  line-height:1.18;
  color:var(--ink);
}
.prop-card h3 a{transition:color .25s var(--tx)}
.prop-card h3 a:hover{color:var(--accent)}
.prop-card-price{
  font-family:var(--serif);
  font-size:1.5rem;
  color:var(--ink);
  font-weight:400;
  letter-spacing:-.012em;
  margin-top:.6rem;
}
.prop-card-meta{
  display:flex;gap:.4rem;flex-wrap:wrap;
  font-size:.72rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--ink-mute);
  margin-top:1.1rem;
  padding-top:1rem;
  border-top:1px solid var(--line-soft);
  font-weight:500;
}
.prop-card-meta span{position:relative;padding-right:.4rem}
.prop-card-meta span:not(:last-child)::after{
  content:'/';margin-left:.4rem;color:var(--border);
}

/* ---------- 12. Asymmetric two-column ---------- */
.split{
  display:grid;
  grid-template-columns:.85fr 1.15fr;
  gap:clamp(2rem, 6vw, 6rem);
  align-items:center;
}
.split.left-img{grid-template-columns:1.15fr .85fr}
.split.left-img .split-text{order:2}
.split.left-img .split-img{order:1}
@media (max-width:900px){
  .split,.split.left-img{grid-template-columns:1fr}
  .split.left-img .split-text{order:1}
  .split.left-img .split-img{order:2}
}
.split-img{
  aspect-ratio:4/5;
  overflow:hidden;
  background:var(--bg-alt);
  position:relative;
}
.split-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--tx)}
.split-img:hover img{transform:scale(1.04)}
.split-img .number-overlay{
  position:absolute;
  bottom:1.2rem;left:1.4rem;
  font-family:var(--serif);
  font-size:clamp(3.2rem, 7vw, 5.5rem);
  color:var(--paper);
  font-weight:400;
  line-height:1;
  letter-spacing:-.03em;
  text-shadow:0 4px 24px rgba(0,0,0,.5);
}
.split-text h2{margin-bottom:1.5rem;max-width:18ch}
.split-text p{margin-bottom:1.2rem;max-width:52ch}
.split-text .btn{margin-top:1.5rem}

/* ---------- 13. Stat ribbon ---------- */
.stats-ribbon{
  background:var(--bg-dark);
  color:var(--paper);
  padding:clamp(3.5rem, 6vw, 5.5rem) 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.stats-ribbon .container{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
@media (max-width:900px){.stats-ribbon .container{grid-template-columns:repeat(2,1fr)}}
.stat{
  padding:0 2rem;
  border-right:1px solid rgba(255,255,255,.14);
  display:flex;flex-direction:column;gap:.5rem;
}
.stat:last-child{border-right:none}
@media (max-width:900px){
  .stat{padding:1.5rem 1rem;border-right:1px solid rgba(255,255,255,.14)}
  .stat:nth-child(2){border-right:none}
  .stat:nth-last-child(-n+2){border-bottom:none}
  .stat:not(:nth-last-child(-n+2)){border-bottom:1px solid rgba(255,255,255,.14)}
}
.stat .num{
  font-family:var(--serif);
  font-size:clamp(3rem, 5vw, 4rem);
  color:var(--paper);
  font-weight:400;
  line-height:1;
  letter-spacing:-.025em;
}
.stat .num em{color:var(--gold-soft);font-family:var(--serif-italic);font-style:italic}
.stat .lbl{
  font-size:.66rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:rgba(255,255,255,.6);
  font-weight:500;
  margin-top:.5rem;
}
.stat .desc{font-size:.92rem;color:rgba(255,255,255,.65);margin-top:.4rem;max-width:24ch;line-height:1.55;font-weight:300}

/* ---------- 14. Marquee testimonials ---------- */
.marquee-wrap{
  overflow:hidden;
  position:relative;
  width:100%;
  padding:clamp(3rem, 5vw, 4.5rem) 0;
}
.marquee-wrap::before,
.marquee-wrap::after{
  content:'';
  position:absolute;top:0;bottom:0;width:120px;
  z-index:2;pointer-events:none;
}
.marquee-wrap::before{left:0;background:linear-gradient(to right, var(--bg-warm), transparent)}
.marquee-wrap::after{right:0;background:linear-gradient(to left, var(--bg-warm), transparent)}
.marquee{
  display:flex;
  gap:1.6rem;
  animation:marquee 60s linear infinite;
  width:max-content;
}
.marquee:hover{animation-play-state:paused}
@keyframes marquee{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
.testimonial{
  flex-shrink:0;
  width:clamp(300px, 32vw, 460px);
  background:var(--paper);
  padding:2.4rem 2.2rem;
  border:1px solid var(--line-soft);
  display:flex;flex-direction:column;
  gap:1.4rem;
}
.testimonial-stars{
  display:flex;gap:.2rem;
  color:var(--gold);
  font-size:.85rem;
  letter-spacing:.1em;
}
.testimonial blockquote{
  font-family:var(--serif);
  font-size:1.18rem;
  line-height:1.45;
  color:var(--ink);
  font-weight:400;
  flex:1;
}
.testimonial-meta{
  display:flex;justify-content:space-between;align-items:flex-end;
  padding-top:1.2rem;
  border-top:1px solid var(--line-soft);
}
.testimonial cite{
  font-style:normal;
  font-size:.92rem;
  font-weight:400;
  color:var(--ink);
  display:block;font-family:var(--serif);
}
.testimonial .city{
  font-size:.66rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold-deep);
  margin-top:.3rem;
  font-weight:500;
}
.testimonial-num{
  font-family:var(--serif);
  font-size:1rem;
  color:var(--ink-mute);
  letter-spacing:.05em;
}

/* ---------- 15. Services ---------- */
.service-list{
  display:flex;flex-direction:column;
  border-top:1px solid var(--line-soft);
}
.service-list .service-row{
  display:grid;
  grid-template-columns:60px 1fr 2.2fr auto;
  gap:1.6rem;
  align-items:center;
  padding:2.2rem 0;
  border-bottom:1px solid var(--line-soft);
  position:relative;
  transition:padding-left .4s var(--tx);
}
.service-list .service-row:hover{padding-left:1rem}
.service-list .service-row::before{
  content:'';
  position:absolute;
  left:0;top:0;bottom:0;
  width:0;
  background:var(--accent);
  transition:width .4s var(--tx);
  z-index:-1;
  opacity:.05;
}
.service-list .service-row:hover::before{width:100%}
.service-list .num{
  font-family:var(--serif);
  font-size:1.4rem;
  color:var(--ink-mute);
  letter-spacing:.05em;
  font-weight:400;
}
.service-list .service-row h3{
  font-size:clamp(1.4rem, 2.4vw, 1.85rem);
  letter-spacing:-.005em;
  font-weight:400;
}
.service-list .service-row p{
  font-size:1rem;
  color:var(--ink-soft);
  line-height:1.6;
  max-width:60ch;
}
.service-list .more{
  font-size:.7rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--accent);
  font-weight:500;
  white-space:nowrap;
  display:flex;align-items:center;gap:.5rem;
  transition:gap .3s var(--tx);
}
.service-list .more::after{content:'→'}
.service-list .service-row:hover .more{gap:.85rem}
@media (max-width:900px){
  .service-list .service-row{grid-template-columns:auto 1fr;gap:1rem}
  .service-list .service-row .num{grid-row:1/3;align-self:start;font-size:1.1rem}
  .service-list .service-row p{grid-column:2}
  .service-list .more{grid-column:2;justify-self:start;margin-top:.8rem}
}

/* ---------- 16. Cities (vertical asymmetric stack) ---------- */
.cities-stack{
  display:flex;flex-direction:column;
  gap:0;
}
.city-row{
  display:grid;
  grid-template-columns:.25fr 1fr 1.4fr;
  gap:clamp(1.5rem, 4vw, 3rem);
  align-items:center;
  padding:clamp(2.5rem, 4vw, 3.5rem) 0;
  border-bottom:1px solid var(--line-soft);
  position:relative;
  cursor:pointer;
}
.city-row:first-child{border-top:1px solid var(--line-soft)}
.city-row .num{
  font-family:var(--serif);
  font-size:clamp(2.5rem, 4vw, 3.5rem);
  color:var(--ink-mute);
  letter-spacing:-.02em;
  font-weight:400;
  line-height:1;
  transition:color .4s var(--tx);
}
.city-row:hover .num{color:var(--gold-deep)}
.city-row h3{
  font-size:clamp(2rem, 4vw, 3rem);
  letter-spacing:-.02em;
  font-weight:400;
  transition:transform .5s var(--tx);
}
.city-row:hover h3{transform:translateX(8px)}
.city-row h3 em{font-family:var(--serif-italic);font-style:italic;color:var(--accent);font-weight:400}
.city-row p{
  font-size:.96rem;
  color:var(--ink-soft);
  line-height:1.65;
  max-width:50ch;
}
.city-row .city-img{
  position:absolute;
  right:0;top:50%;transform:translateY(-50%) translateX(20%);
  width:280px;height:340px;
  overflow:hidden;
  opacity:0;
  transition:opacity .5s var(--tx), transform .8s var(--tx);
  pointer-events:none;
}
.city-row:hover .city-img{
  opacity:1;
  transform:translateY(-50%) translateX(0);
}
.city-row .city-img img{width:100%;height:100%;object-fit:cover}
@media (max-width:1100px){.city-row .city-img{display:none}}
@media (max-width:900px){
  .city-row{grid-template-columns:auto 1fr}
  .city-row .num{grid-row:1/3;align-self:start;font-size:1.6rem;line-height:1.2}
  .city-row p{grid-column:2;margin-top:.6rem}
}

/* ---------- 17. FAQ accordion ---------- */
.faq{max-width:var(--max-narrow);margin:0 auto}
.faq details{
  border-bottom:1px solid var(--line-soft);
  padding:1.7rem 0;
  position:relative;
}
.faq details summary{
  cursor:pointer;
  font-family:var(--serif);
  font-size:clamp(1.15rem, 2vw, 1.4rem);
  color:var(--ink);
  list-style:none;
  position:relative;
  padding-right:3rem;
  font-weight:400;
  letter-spacing:-.005em;
  line-height:1.3;
  transition:color .25s var(--tx);
}
.faq details summary:hover{color:var(--accent)}
.faq details summary::-webkit-details-marker{display:none}
.faq details summary::after{
  content:'';
  position:absolute;
  right:0;top:50%;
  width:24px;height:1px;
  background:var(--accent);
  transition:transform .35s var(--tx);
}
.faq details summary::before{
  content:'';
  position:absolute;
  right:11.5px;top:50%;
  width:1px;height:24px;
  background:var(--accent);
  transform:translateY(-50%);
  transition:transform .35s var(--tx);
}
.faq details[open] summary::before{transform:translateY(-50%) scaleY(0)}
.faq details > p{
  margin-top:1.2rem;
  font-size:1rem;
  color:var(--ink-soft);
  line-height:1.75;
  max-width:64ch;
}

/* ---------- 18. Property detail ---------- */
.prop-hero{
  padding:9rem 0 0;
  background:var(--bg);
}
.prop-hero-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(2rem, 5vw, 4rem);
  align-items:flex-end;
  margin-bottom:2.5rem;
}
@media (max-width:800px){.prop-hero-grid{grid-template-columns:1fr}}
.prop-hero h1{
  font-size:clamp(2rem, 4.2vw, 3.4rem);
  max-width:18ch;
  letter-spacing:-.022em;
  line-height:1.05;
}
.prop-hero h1 em{font-family:var(--serif-italic);font-style:italic;color:var(--accent)}
.prop-hero .loc{
  font-size:.78rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--gold-deep);
  font-weight:500;
  margin-bottom:1.4rem;
}
.prop-hero-price{
  font-family:var(--serif);
  font-size:clamp(2.4rem, 4vw, 3.4rem);
  color:var(--ink);
  letter-spacing:-.025em;
  font-weight:400;
  line-height:1;
}
.prop-hero-price small{
  display:block;
  font-family:var(--sans);
  font-size:.66rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-mute);
  font-weight:500;
  margin-top:.7rem;
}

.gallery{margin-top:2rem;position:relative}
.gallery-main{
  aspect-ratio:16/9;
  overflow:hidden;
  background:var(--bg-alt);
  position:relative;
}
.gallery-slide{
  position:absolute;inset:0;
  opacity:0;
  transition:opacity .65s var(--tx);
}
.gallery-slide.active{opacity:1}
.gallery-slide img{width:100%;height:100%;object-fit:cover}
.gallery-counter{
  position:absolute;
  bottom:1.4rem;right:1.4rem;
  z-index:3;
  font-family:var(--serif);
  font-size:1rem;
  color:var(--paper);
  letter-spacing:.05em;
  background:rgba(10,10,10,.55);
  padding:.5rem .95rem;
  backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.15);
}
.gallery-counter .now{color:var(--gold-soft)}
.gallery-thumbs{
  display:grid;grid-template-columns:repeat(6,1fr);gap:.55rem;
  margin-top:.55rem;
}
@media (max-width:600px){.gallery-thumbs{grid-template-columns:repeat(3,1fr)}}
.gallery-thumb{
  aspect-ratio:4/3;
  overflow:hidden;
  cursor:pointer;
  background:var(--bg-alt);
  position:relative;
  opacity:.55;
  transition:opacity .3s var(--tx);
}
.gallery-thumb:hover{opacity:.85}
.gallery-thumb.active{opacity:1}
.gallery-thumb.active::after{
  content:'';
  position:absolute;inset:0;
  border:2px solid var(--accent);
  pointer-events:none;
}
.gallery-thumb img{width:100%;height:100%;object-fit:cover}

/* Property body */
.prop-body{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(2rem, 5vw, 5rem);margin-top:clamp(3rem, 6vw, 5rem)}
@media (max-width:1000px){.prop-body{grid-template-columns:1fr}}
.prop-content > h2{margin-top:2.2rem;margin-bottom:1.2rem;font-size:clamp(1.6rem, 2.8vw, 2.2rem)}
.prop-content > h2:first-child{margin-top:0}
.prop-content p{margin-bottom:1.2rem;max-width:60ch}
.prop-content > ul{margin:1.5rem 0;display:grid;grid-template-columns:repeat(2,1fr);gap:1.1rem}
@media (max-width:600px){.prop-content > ul{grid-template-columns:1fr}}
.prop-content > ul li{
  position:relative;padding-left:1.5rem;
  font-size:.94rem;color:var(--ink-soft);font-weight:300;
  line-height:1.5;
}
.prop-content > ul li::before{
  content:'';
  position:absolute;left:0;top:.7em;
  width:8px;height:1px;
  background:var(--accent);
}

/* Highlights */
.prop-highlights{
  background:var(--ink);
  color:var(--paper);
  padding:clamp(2.4rem, 4vw, 3.5rem);
  margin:2.4rem 0;
  position:relative;
  overflow:hidden;
}
.prop-highlights::before{
  content:'';
  position:absolute;
  top:0;left:0;
  width:80px;height:1px;
  background:var(--gold-soft);
}
.prop-highlights .eyebrow{color:var(--gold-soft)}
.prop-highlights .eyebrow::before{background:var(--gold-soft)}
.prop-highlights blockquote{
  font-family:var(--serif);
  font-size:clamp(1.3rem, 2.1vw, 1.7rem);
  line-height:1.4;
  margin-top:1rem;
  color:var(--paper);
  font-weight:400;
  letter-spacing:-.005em;
  font-style:italic;
  font-family:var(--serif-italic);
}
.prop-highlights cite{
  display:block;font-style:normal;
  font-size:.7rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold-soft);
  margin-top:1.4rem;
  font-weight:500;
  font-family:var(--sans);
}

/* Mini features (4 cards) */
.prop-features{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  background:var(--bg);
  border:1px solid var(--line-soft);
  margin:2.4rem 0;
}
@media (max-width:700px){.prop-features{grid-template-columns:repeat(2,1fr)}}
.prop-feature{
  padding:1.7rem 1.3rem;
  text-align:center;
  display:flex;flex-direction:column;gap:.4rem;
  align-items:center;
  border-right:1px solid var(--line-soft);
  border-bottom:1px solid var(--line-soft);
}
.prop-feature:last-child{border-right:none}
@media (max-width:700px){
  .prop-feature{border-right:none}
  .prop-feature:nth-child(2),.prop-feature:nth-child(4){border-right:none}
  .prop-feature:nth-child(odd){border-right:1px solid var(--line-soft)}
}
.prop-feature .lbl{
  font-size:.62rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-mute);
  font-weight:500;
}
.prop-feature .val{
  font-family:var(--serif);
  font-size:1.95rem;
  color:var(--ink);
  font-weight:400;
  letter-spacing:-.02em;
  line-height:1;
  margin-top:.4rem;
}
.prop-feature .sub{
  font-size:.78rem;
  color:var(--ink-soft);
  font-family:var(--serif-italic);
  font-style:italic;
}

/* Sidebar */
.prop-sidebar{position:sticky;top:120px;align-self:start}
.spec-list{
  background:var(--paper);
  border:1px solid var(--line-soft);
  padding:2.2rem 1.95rem;
}
.spec-list h3{
  font-size:.7rem;
  margin-bottom:1.5rem;
  letter-spacing:.28em;
  font-family:var(--sans);
  font-weight:500;
  text-transform:uppercase;
  color:var(--ink-mute);
}
.spec-list dl{display:flex;flex-direction:column}
.spec-list dl > div{
  display:flex;justify-content:space-between;
  padding:.95rem 0;
  border-bottom:1px solid var(--line-soft);
  font-size:.92rem;
  gap:1rem;
}
.spec-list dl > div:last-child{border-bottom:none}
.spec-list dt{color:var(--ink-mute);font-weight:300}
.spec-list dd{color:var(--ink);font-weight:400;text-align:right;font-family:var(--serif);font-size:.96rem}

.contact-card{
  margin-top:1.5rem;
  background:var(--bg-dark);
  color:var(--paper);
  padding:2.4rem 2rem;
  text-align:center;
  position:relative;
}
.contact-card::before{
  content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:48px;height:1px;background:var(--gold-soft);
}
.contact-card .mono-lg{
  width:64px;height:64px;
  display:flex;align-items:center;justify-content:center;
  background:var(--accent);
  color:var(--paper);
  font-family:var(--serif);
  font-size:1.1rem;font-weight:400;
  letter-spacing:.08em;
  margin:0 auto 1.4rem;
  position:relative;
}
.contact-card .mono-lg::after{
  content:'';position:absolute;inset:4px;
  border:1px solid rgba(255,255,255,.22);
}
.contact-card h4{color:var(--paper);font-size:1.15rem;margin-bottom:.4rem;font-weight:400}
.contact-card .role{
  font-size:.62rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold-soft);margin-bottom:1.5rem;font-weight:500;
}
.contact-card .btn{width:100%;margin-bottom:.6rem}
.contact-card .tel{
  display:block;color:var(--paper);font-size:.95rem;
  margin-top:1.2rem;padding-top:1.2rem;
  border-top:1px solid rgba(255,255,255,.18);
  font-family:var(--serif);
  letter-spacing:-.005em;
}

/* ---------- 19. Forms ---------- */
.form-card{
  background:var(--paper);
  padding:clamp(2.4rem, 4vw, 3.4rem);
  border:1px solid var(--line-soft);
  max-width:var(--max-narrow);
  margin:0 auto;
  position:relative;
}
.form-card::before{
  content:'';position:absolute;top:0;left:0;width:80px;height:1px;background:var(--accent);
}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem 1.6rem}
@media (max-width:680px){.form-grid{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:.45rem}
.field.full{grid-column:1/-1}
.field label{
  font-size:.7rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-mute);
  font-weight:500;
}
.field input,.field select,.field textarea{
  padding:1rem 0;
  border:none;
  border-bottom:1px solid var(--border);
  background:transparent;
  font-size:1rem;
  font-family:var(--sans);
  color:var(--ink);
  font-weight:300;
  transition:border-color .25s var(--tx);
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;
  border-bottom-color:var(--accent);
}
.field textarea{resize:vertical;min-height:120px;line-height:1.6}
.form-card .btn{margin-top:.5rem}

/* Consent block (RGPD) */
.field label.checkbox-row,
label.checkbox-row{
  display:flex;align-items:flex-start;gap:.8rem;
  font-size:.88rem;color:var(--ink-soft);
  line-height:1.55;
  cursor:pointer;
  text-transform:none;
  letter-spacing:0;
  font-weight:300;
  font-family:var(--sans);
  margin-bottom:0;
}
.checkbox-row input{margin-top:.3rem;width:17px;height:17px;flex-shrink:0;accent-color:var(--accent);cursor:pointer}
.checkbox-row a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.checkbox-row strong{color:var(--ink);font-weight:500}
.checkbox-row .req{color:var(--accent);font-weight:500;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;margin-left:.2rem}
.checkbox-row .opt{color:var(--ink-mute);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;margin-left:.2rem}

.consent-block{
  margin-top:.8rem;
  padding:1.6rem 1.6rem 1.4rem;
  background:var(--bg);
  border:1px solid var(--line-soft);
  display:flex;flex-direction:column;gap:1rem;
}
.consent-block .checkbox-row{margin:0}
.privacy-notice{
  margin:.6rem 0 0;
  padding-top:1.1rem;
  border-top:1px solid var(--line-soft);
  font-size:.74rem;
  line-height:1.55;
  color:var(--ink-mute);
  font-weight:300;
}
.privacy-notice a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}

/* ---------- 20. Blog list ---------- */
.blog-card{
  background:transparent;
  display:flex;flex-direction:column;
  transition:transform .5s var(--tx);
}
.blog-card:hover{transform:translateY(-4px)}
.blog-card-img{aspect-ratio:4/5;overflow:hidden;background:var(--bg-alt);margin-bottom:1.4rem}
.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--tx)}
.blog-card:hover .blog-card-img img{transform:scale(1.05)}
.blog-card-meta{
  display:flex;gap:1rem;margin-bottom:.85rem;
  font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-mute);font-weight:500;
}
.blog-card-meta span:first-child{color:var(--gold-deep)}
.blog-card h3{
  font-size:clamp(1.4rem, 2vw, 1.7rem);
  letter-spacing:-.005em;
  font-weight:400;
  line-height:1.2;
  margin-bottom:.85rem;
}
.blog-card h3 a{transition:color .25s var(--tx)}
.blog-card h3 a:hover{color:var(--accent)}
.blog-card p{font-size:.96rem;color:var(--ink-soft);font-weight:300;max-width:46ch}
.blog-card .more{
  margin-top:1.2rem;
  font-size:.68rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--accent);
  font-weight:500;
}

/* Blog post body */
.post-hero{
  padding:9rem 0 4rem;
  background:var(--paper-soft);
  border-bottom:1px solid var(--line-soft);
}
.post-hero h1{
  font-size:clamp(2.2rem, 4.6vw, 3.8rem);
  max-width:24ch;
  letter-spacing:-.022em;
  line-height:1.04;
}
.post-hero .lead{margin-top:1.5rem;max-width:62ch}
.post-meta-row{
  display:flex;gap:1.5rem;flex-wrap:wrap;
  margin-top:2rem;padding-top:1.6rem;
  border-top:1px solid var(--line-soft);
  font-size:.7rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ink-mute);font-weight:500;
}
.post-meta-row span:first-child{color:var(--gold-deep)}

.post-body{
  max-width:var(--max-text);
  margin:0 auto;
  padding:clamp(3rem, 6vw, 5rem) var(--pad);
}
.post-body h2{
  font-size:clamp(1.7rem, 3vw, 2.3rem);
  margin:3rem 0 1.2rem;
  letter-spacing:-.018em;
}
.post-body h3{
  font-size:1.4rem;
  margin:2.2rem 0 .9rem;
}
.post-body p{margin-bottom:1.4rem;font-size:1.075rem;line-height:1.8;color:var(--ink-soft);font-weight:300}
.post-body p strong{color:var(--ink);font-weight:500}
.post-body em{font-family:var(--serif-italic);font-style:italic;color:var(--ink)}
.post-body ul,.post-body ol{margin:1.2rem 0 1.6rem 1.6rem}
.post-body ul li,.post-body ol li{font-size:1.025rem;line-height:1.7;color:var(--ink-soft);margin-bottom:.6rem;list-style:disc;font-weight:300}
.post-body ol li{list-style:decimal}
.post-body blockquote{
  border-left:2px solid var(--accent);
  padding:.8rem 0 .8rem 1.8rem;
  margin:2.4rem 0;
  font-family:var(--serif);
  font-size:1.45rem;
  color:var(--ink);
  line-height:1.4;
  font-weight:400;
}

/* Author box */
.author-box{
  background:var(--bg-warm);
  padding:2.4rem 2.2rem;
  margin:3rem 0 1.5rem;
  display:flex;gap:1.6rem;align-items:flex-start;
  border-left:2px solid var(--accent);
}
.author-box .mono-lg{
  width:72px;height:72px;
  display:flex;align-items:center;justify-content:center;
  background:var(--accent);color:var(--paper);
  font-family:var(--serif);
  font-size:1.2rem;font-weight:400;
  letter-spacing:.08em;
  flex-shrink:0;
  position:relative;
}
.author-box .mono-lg::after{content:'';position:absolute;inset:4px;border:1px solid rgba(255,255,255,.22)}
.author-box-text h4{font-size:1.18rem;margin-bottom:.3rem;font-weight:400}
.author-box-text .role{
  font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold-deep);font-weight:500;margin-bottom:.95rem;
}
.author-box-text p{font-size:.92rem;line-height:1.6;font-weight:300}

/* ---------- 21. Filter bar (catálogo) ---------- */
.filter-bar{
  background:var(--paper);
  padding:1.7rem 1.7rem;
  border:1px solid var(--line-soft);
  display:grid;grid-template-columns:1.1fr 1fr 1fr 1fr auto;gap:1rem;
  align-items:end;
  margin-bottom:3rem;
}
@media (max-width:900px){.filter-bar{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.filter-bar{grid-template-columns:1fr}}
.filter-bar .field label{margin-bottom:.4rem}
.filter-bar select,.filter-bar input{
  padding:.7rem 0;font-size:.92rem;
  border:none;
  border-bottom:1px solid var(--border);
  background:transparent;
}
.filter-bar .btn{padding:.85rem 1.4rem;font-size:.7rem}
.filter-status{
  margin:0 0 1.8rem;
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-mute);
  font-weight:500;
}
.filter-status .num{font-family:var(--serif);color:var(--accent);font-size:1.3rem;letter-spacing:0;margin-right:.2rem;font-weight:400;text-transform:none}

/* ---------- 22. Breadcrumbs ---------- */
.breadcrumbs{
  padding:1.5rem 0 0;
  font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-mute);font-weight:500;
}
.breadcrumbs ol{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}
.breadcrumbs li:not(:last-child)::after{content:'/';margin-left:.5rem;color:var(--border)}
.breadcrumbs a{color:var(--ink-mute);transition:color .25s}
.breadcrumbs a:hover{color:var(--accent)}
.breadcrumbs li:last-child{color:var(--ink)}

/* ---------- 23. CTA band ---------- */
.cta-band{
  background:var(--accent);
  color:var(--paper);
  padding:clamp(4rem, 8vw, 7rem) 0;
  position:relative;
  overflow:hidden;
}
.cta-band::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:1px;background:rgba(255,255,255,.15);
}
.cta-band .container{position:relative;z-index:2}
.cta-band-inner{
  display:grid;grid-template-columns:1.4fr 1fr;
  gap:clamp(2rem, 5vw, 4rem);
  align-items:flex-end;
}
@media (max-width:900px){.cta-band-inner{grid-template-columns:1fr}}
.cta-band h2{color:var(--paper);max-width:18ch;font-weight:400;letter-spacing:-.025em}
.cta-band h2 em{font-family:var(--serif-italic);font-style:italic;color:var(--gold-soft)}
.cta-band p{color:rgba(255,255,255,.85);max-width:46ch;font-size:1rem;margin-top:1.2rem}
.cta-band .eyebrow{color:var(--gold-soft);margin-bottom:1.5rem}
.cta-band .eyebrow::before{background:var(--gold-soft)}
.cta-band-row{display:flex;gap:1rem;flex-wrap:wrap;justify-content:flex-end}
@media (max-width:900px){.cta-band-row{justify-content:flex-start}}
.cta-band .btn-gold{background:var(--gold);border-color:var(--gold);color:var(--paper)}
.cta-band .btn-gold:hover{background:var(--paper);border-color:var(--paper);color:var(--accent-dark)}
.cta-band .btn-ghost{border-color:rgba(255,255,255,.5);color:var(--paper)}
.cta-band .btn-ghost:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}

/* ---------- 24. Footer ---------- */
.site-footer{
  background:var(--bg-deep);
  color:rgba(255,255,255,.78);
  padding:clamp(4rem, 7vw, 6rem) 0 2rem;
  font-size:.92rem;
}
.footer-grid{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;
  gap:clamp(1.5rem, 4vw, 4rem);
  padding-bottom:3rem;
  border-bottom:1px solid rgba(255,255,255,.1);
}
@media (max-width:900px){.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr}}
.footer-grid h5{
  font-family:var(--sans);
  font-size:.68rem;
  font-weight:500;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--gold-soft);
  margin-bottom:1.6rem;
}
.footer-grid ul li{margin-bottom:.7rem}
.footer-grid a{
  color:rgba(255,255,255,.68);
  font-size:.9rem;
  font-weight:300;
  transition:color .25s var(--tx);
}
.footer-grid a:hover{color:var(--paper)}
.footer-brand .brand{margin-bottom:1.6rem}
.footer-brand .brand-txt .top,.footer-brand .brand-txt .sub{color:var(--paper)}
.footer-brand .brand-txt .sub{color:rgba(255,255,255,.55)}
.footer-brand .brand .mono{background:var(--accent)}
.footer-brand p{
  font-size:.92rem;color:rgba(255,255,255,.65);
  max-width:36ch;line-height:1.6;font-weight:300;
}
.footer-faq{
  padding:2.5rem 0;
  border-bottom:1px solid rgba(255,255,255,.1);
}
.footer-faq h5{
  font-family:var(--serif);
  font-size:1.3rem;
  font-weight:400;
  color:var(--paper);
  margin-bottom:1.4rem;
  letter-spacing:-.005em;
  text-transform:none;
}
.footer-faq ul{
  display:grid;grid-template-columns:repeat(2,1fr);gap:.7rem 2rem;
}
@media (max-width:680px){.footer-faq ul{grid-template-columns:1fr}}
.footer-faq a{
  font-size:.88rem;
  color:rgba(255,255,255,.7);
  display:inline-flex;gap:.65rem;align-items:center;font-weight:300;
}
.footer-faq a::before{content:'→';color:var(--gold-soft);font-size:.85rem;flex-shrink:0}
.footer-faq a:hover{color:var(--paper)}
.footer-bottom{
  padding-top:2rem;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;
  font-size:.78rem;color:rgba(255,255,255,.5);
}
.footer-bottom a{color:rgba(255,255,255,.6)}
.footer-bottom a:hover{color:var(--paper)}
.footer-bottom .legal-links{display:flex;gap:1.5rem;flex-wrap:wrap}

/* ---------- 25. Floating WhatsApp ---------- */
.fab-wa{
  position:fixed;bottom:1.5rem;right:1.5rem;
  width:60px;height:60px;
  background:#25D366;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 12px 28px rgba(37,211,102,.45),0 4px 10px rgba(0,0,0,.18);
  z-index:90;
  transition:transform .3s var(--tx), background .3s var(--tx);
}
.fab-wa:hover{transform:scale(1.08)}
.fab-wa svg{width:30px;height:30px;color:#fff}
.fab-wa::before{
  content:'';
  position:absolute;inset:0;
  background:#25D366;
  z-index:-1;
  animation:pulse-wa 2.4s ease-out infinite;
}
@keyframes pulse-wa{
  0%{transform:scale(1);opacity:.7}
  100%{transform:scale(1.7);opacity:0}
}

/* ---------- 26. Modal ---------- */
.modal{
  position:fixed;inset:0;
  background:rgba(10,10,10,.75);
  display:none;
  align-items:center;justify-content:center;
  z-index:200;padding:1.5rem;
  backdrop-filter:blur(6px);
}
.modal.active{display:flex;animation:fadein .35s var(--tx)}
.modal-card{
  background:var(--paper);
  padding:3.4rem 2.6rem 2.6rem;
  max-width:460px;width:100%;
  text-align:center;
  position:relative;
  border-top:2px solid var(--accent);
}
.modal-card .check{
  width:64px;height:64px;
  background:var(--accent);color:var(--paper);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 1.5rem;
  position:relative;
}
.modal-card .check::after{content:'';position:absolute;inset:4px;border:1px solid rgba(255,255,255,.22)}
.modal-card .check svg{width:32px;height:32px}
.modal-card h3{font-size:1.6rem;margin-bottom:.95rem;font-weight:400}
.modal-card p{margin-bottom:1.6rem}
.modal-card .close{
  position:absolute;top:1rem;right:1rem;
  width:32px;height:32px;
  display:flex;align-items:center;justify-content:center;
  color:var(--ink-mute);font-size:1.4rem;
}
@keyframes fadein{from{opacity:0}to{opacity:1}}

/* ---------- 27. Cookie banner ---------- */
.cookies{
  position:fixed;bottom:1rem;left:1rem;right:1rem;
  max-width:540px;
  background:var(--ink);
  color:rgba(255,255,255,.85);
  padding:1.6rem 1.8rem;
  z-index:80;
  display:none;
  font-size:.88rem;
  line-height:1.55;
  border-top:2px solid var(--accent);
}
.cookies.show{display:block;animation:fadein .4s var(--tx)}
.cookies h5{font-family:var(--serif);font-size:1.1rem;font-weight:400;text-transform:none;letter-spacing:0;color:var(--paper);margin-bottom:.55rem}
.cookies p{color:rgba(255,255,255,.72);margin-bottom:1.1rem;font-size:.85rem;font-weight:300}
.cookies .row{display:flex;gap:.7rem;flex-wrap:wrap;align-items:center}
.cookies .btn{padding:.7rem 1.1rem;font-size:.7rem}
.cookies .btn-primary{background:var(--gold);border-color:var(--gold)}
.cookies .btn-primary:hover{background:var(--gold-deep);border-color:var(--gold-deep)}
.cookies .btn-outline{background:transparent;color:var(--paper);border-color:rgba(255,255,255,.4)}
.cookies .btn-outline:hover{background:var(--paper);color:var(--ink)}
.cookies .btn-text{
  background:none;color:rgba(255,255,255,.7);
  text-decoration:underline;border:none;padding:.6rem .4rem;
  font-size:.78rem;
}

/* ---------- 28. Page shell (legales) ---------- */
.page-shell{
  background:var(--paper);
  padding:clamp(2.4rem, 4vw, 3.6rem);
  border:1px solid var(--line-soft);
  max-width:var(--max-text);
  margin:0 auto;
  border-top:2px solid var(--accent);
}
.page-shell h2{font-size:1.8rem;margin:2.4rem 0 1rem;font-weight:400}
.page-shell h2:first-child{margin-top:0}
.page-shell h3{font-size:1.3rem;margin:1.8rem 0 .9rem;font-weight:400}
.page-shell p{margin-bottom:1.1rem;line-height:1.78;font-weight:300}
.page-shell ul{margin:1rem 0 1.4rem 1.6rem}
.page-shell ul li{list-style:disc;color:var(--ink-soft);margin-bottom:.6rem;line-height:1.7;font-weight:300}
.page-shell strong{color:var(--ink);font-weight:500}
.page-shell address{font-style:normal;line-height:1.75;color:var(--ink-soft);font-weight:300}

/* ---------- 29. Misc utilities ---------- */
.center{text-align:center}
.muted{color:var(--ink-mute)}
.mt-0{margin-top:0!important}
.mt-2{margin-top:1.5rem}
.mt-3{margin-top:2.5rem}
.mt-4{margin-top:4rem}
.mb-0{margin-bottom:0!important}
.serif{font-family:var(--serif)}
.italic{font-family:var(--serif-italic);font-style:italic}

/* ---------- 30. Reduce motion ---------- */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01s!important;transition-duration:.01s!important}
  .marquee{animation:none}
  .reveal,.reveal-mask > span,.reveal-img{opacity:1!important;transform:none!important;clip-path:none!important}
}
