:root{
  --marfil:#faf6ef;
  --marfil-2:#f2ebdd;
  --arena:#e3d5b8;
  --carbon:#1c1814;
  --carbon-soft:#453e34;
  --piedra:#8c8171;
  --bronce:#a4855a;
  --bronce-soft:#c9ac7c;
  --linea:#e3d8c2;
  --cal:#ffffff;
  --display:'Fraunces', serif;
  --body:'Inter', sans-serif;
  --maxw:1280px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:var(--body); background:var(--marfil); color:var(--carbon); -webkit-font-smoothing:antialiased; font-weight:400;}
img,svg{display:block; max-width:100%;}
a{color:inherit; text-decoration:none;}
ul{list-style:none;}
button{font:inherit; cursor:pointer; background:none; border:none;}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 40px;}
@media(max-width:720px){.wrap{padding:0 22px;}}
::selection{background:var(--carbon); color:var(--marfil);}
@media (prefers-reduced-motion: reduce){*{animation-duration:.001ms !important; transition-duration:.001ms !important; scroll-behavior:auto !important;}}

h1,h2,h3{font-family:var(--display); font-weight:500; letter-spacing:-.01em; line-height:1.1; color:var(--carbon);}
.label{font-family:var(--body); font-size:11.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--bronce); font-weight:600; display:flex; align-items:center; gap:10px; margin-bottom:16px;}
.label::before{content:""; width:24px; height:1px; background:var(--bronce);}
.lede{font-size:16.5px; line-height:1.75; color:var(--carbon-soft); max-width:56ch; font-weight:400;}
a:focus-visible, button:focus-visible, select:focus-visible, input:focus-visible{outline:1.5px solid var(--bronce); outline-offset:3px;}

/* ===== header ===== */
header{position:sticky; top:0; z-index:300; background:rgba(250,246,239,.92); backdrop-filter:blur(10px); border-bottom:1px solid var(--linea);}
.navbar{display:flex; align-items:center; justify-content:space-between; padding:16px 0;}
.brand{display:flex; align-items:center; gap:13px;}
.brand img{height:38px; width:auto;}
.brand-text{display:flex; flex-direction:column; line-height:1;}
.brand-text .b1{font-family:var(--display); font-size:16.5px; letter-spacing:.14em; font-weight:600; color:var(--carbon);}
.brand-text .b2{font-family:var(--body); font-size:8.5px; letter-spacing:.28em; color:var(--piedra); font-weight:500; margin-top:4px;}
nav.links{display:flex; gap:4px; align-items:center;}
nav.links > a, .has-dropdown > button{
  font-family:var(--body); font-size:14.5px; font-weight:500; letter-spacing:0; text-transform:none;
  color:var(--carbon-soft); padding:10px 16px; transition:.2s; display:flex; align-items:center; gap:5px;
}
nav.links > a:hover, .has-dropdown > button:hover{color:var(--bronce);}
.has-dropdown{position:relative;}
.has-dropdown svg{width:8px; opacity:.6; transition:.2s;}
.has-dropdown:hover svg{transform:rotate(180deg);}
.dropdown{
  position:absolute; top:100%; left:0; margin-top:4px; background:var(--cal); border:1px solid var(--linea);
  min-width:300px; padding:8px; opacity:0; visibility:hidden; transform:translateY(6px); transition:.2s ease;
  box-shadow:0 24px 50px rgba(28,24,20,.1);
}
.has-dropdown:hover .dropdown{opacity:1; visibility:visible; transform:translateY(0);}
.dropdown a.dev-item{display:flex; flex-direction:column; gap:2px; padding:12px 14px;}
.dropdown a.dev-item:hover{background:var(--marfil-2);}
.dropdown a.dev-item .dcity{font-family:var(--body); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--bronce); font-weight:600;}
.dropdown a.dev-item .dname{font-family:var(--display); font-size:16.5px; color:var(--carbon); margin-top:2px;}
.nav-right{display:flex; align-items:center; gap:22px;}
.nav-phone{font-family:var(--body); font-size:12.5px; color:var(--carbon-soft); letter-spacing:.02em;}
.nav-phone strong{color:var(--carbon);}
.nav-cta{font-family:var(--body); font-size:12px; font-weight:600; letter-spacing:.06em; text-transform:uppercase; background:var(--carbon); color:var(--marfil); padding:12px 24px; transition:.25s;}
.nav-cta:hover{background:var(--bronce);}
.burger{display:none; flex-direction:column; gap:5px; padding:6px;}
.burger span{width:22px; height:1.5px; background:var(--carbon);}
@media(max-width:980px){nav.links{display:none;} .nav-phone{display:none;} .burger{display:flex;}}
.mobile-menu{position:fixed; inset:0; background:var(--carbon); z-index:400; padding:28px; transform:translateX(100%); transition:.45s cubic-bezier(.6,0,.2,1); overflow-y:auto;}
.mobile-menu.open{transform:translateX(0);}
.mobile-menu .close{position:absolute; top:24px; right:24px; color:var(--marfil); font-size:26px;}
.mobile-menu a{display:block; font-family:var(--display); font-size:25px; color:var(--marfil); padding:14px 0; border-bottom:1px solid rgba(255,255,255,.1);}
.mobile-menu .mm-sub a{font-family:var(--body); font-size:14.5px; font-weight:500; color:var(--bronce-soft); border-bottom:none; padding:9px 0; padding-left:14px;}
.mobile-menu .mm-cta{margin-top:20px; display:inline-block; background:var(--bronce); color:var(--carbon); padding:14px 26px; font-family:var(--body); font-size:12.5px; text-transform:uppercase; letter-spacing:.06em; font-weight:600;}

/* ===== hero (ken burns motion, real photography) ===== */
.hero{position:relative; min-height:92vh; display:flex; align-items:flex-end; overflow:hidden; background:var(--carbon);}
.kb-slide{position:absolute; inset:0; opacity:0; animation:kbfade 24s infinite; overflow:hidden;}
.kb-slide img{width:100%; height:100%; object-fit:cover; animation:kbzoom 24s infinite ease-in-out; transform-origin:center;}
.kb-slide:nth-child(1){animation-delay:0s;}
.kb-slide:nth-child(2){animation-delay:-6s;}
.kb-slide:nth-child(3){animation-delay:-12s;}
.kb-slide:nth-child(4){animation-delay:-18s;}
@keyframes kbfade{0%{opacity:0;} 4%{opacity:1;} 25%{opacity:1;} 29%{opacity:0;} 100%{opacity:0;}}
@keyframes kbzoom{0%{transform:scale(1.0);} 100%{transform:scale(1.12);}}
.hero-scrim{position:absolute; inset:0; background:linear-gradient(0deg, rgba(20,17,13,.86) 0%, rgba(20,17,13,.4) 46%, rgba(20,17,13,.18) 70%, rgba(20,17,13,.4) 100%); z-index:1;}
.hero-grain{position:absolute; inset:0; opacity:.04; mix-blend-mode:overlay; z-index:1;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
.hero-caption{position:absolute; left:40px; bottom:120px; z-index:2; font-family:var(--body); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:rgba(250,246,239,.65);}
.hero-content{position:relative; z-index:3; width:100%; padding:0 0 90px;}
.hero-content .wrap{max-width:820px;}
.hero-eyebrow{font-family:var(--body); font-size:12px; letter-spacing:.22em; text-transform:uppercase; font-weight:500; color:var(--bronce-soft); margin-bottom:22px; display:flex; align-items:center; gap:12px;}
.hero-eyebrow::before{content:""; width:30px; height:1px; background:var(--bronce-soft);}
.hero h1{color:var(--marfil); font-size:clamp(34px,5.6vw,72px); font-weight:500; max-width:14ch; margin-bottom:22px;}
.hero h1 em{font-style:normal; color:var(--bronce-soft); font-weight:600;}
.hero-sub{color:#e6dcc9; font-size:16px; line-height:1.7; max-width:50ch; margin-bottom:34px; font-weight:400;}
.hero-actions{display:flex; gap:16px; flex-wrap:wrap;}
.btn{font-family:var(--body); font-size:12.5px; font-weight:600; letter-spacing:.05em; text-transform:uppercase; padding:16px 30px; transition:.25s; display:inline-flex; align-items:center; gap:10px; border:1px solid transparent;}
.btn-primary{background:var(--marfil); color:var(--carbon);}
.btn-primary:hover{background:var(--bronce-soft);}
.btn-outline{border-color:rgba(250,246,239,.45); color:var(--marfil);}
.btn-outline:hover{border-color:var(--marfil); background:rgba(250,246,239,.08);}
.btn-dark{background:var(--carbon); color:var(--marfil);}
.btn-dark:hover{background:var(--bronce);}

/* ===== statement ===== */
.statement{padding:130px 0; text-align:center;}
.statement .label{justify-content:center;}
.statement h2{font-size:clamp(26px,3.4vw,42px); max-width:20ch; margin:0 auto; font-weight:400; line-height:1.35;}
.statement h2 em{font-style:normal; color:var(--bronce); font-weight:600;}

/* ===== reveal ===== */
.reveal{opacity:0; transform:translateY(26px); transition:opacity .8s cubic-bezier(.2,.6,.2,1), transform .8s cubic-bezier(.2,.6,.2,1);}
.reveal.in{opacity:1; transform:translateY(0);}

section{padding:110px 0;}
@media(max-width:720px){section{padding:70px 0;} .statement{padding:80px 0;}}
.section-head{max-width:640px; margin-bottom:56px;}
.section-head h2{font-size:clamp(28px,3.6vw,44px); font-weight:500;}

/* ===== proyectos (editorial tiles) ===== */
.proyectos{background:var(--marfil-2);}
.proy-grid{display:grid; grid-template-columns:1fr 1fr; gap:2px;}
@media(max-width:860px){.proy-grid{grid-template-columns:1fr;}}
.proy-tile{position:relative; aspect-ratio:4/5; overflow:hidden; display:flex; align-items:flex-end; background:var(--carbon);}
.proy-tile img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform 1.2s cubic-bezier(.2,.7,.2,1);}
.proy-tile:hover img{transform:scale(1.06);}
.proy-scrim{position:absolute; inset:0; background:linear-gradient(0deg, rgba(20,17,13,.86) 0%, rgba(20,17,13,.2) 55%, rgba(20,17,13,0) 75%); z-index:1;}
.proy-body{position:relative; z-index:2; padding:36px; width:100%;}
.proy-tag{font-family:var(--body); font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--bronce-soft); font-weight:600; margin-bottom:10px; display:block;}
.proy-body h3{color:var(--marfil); font-size:clamp(24px,2.6vw,32px); font-weight:500; margin-bottom:8px;}
.proy-body .ploc{font-family:var(--body); font-size:12.5px; color:#d8cbae; margin-bottom:18px;}
.proy-body p.desc{color:#e6dcc9; font-size:13.5px; line-height:1.65; max-width:40ch; margin-bottom:22px;}
.proy-facts{display:flex; gap:22px; margin-bottom:24px;}
.proy-facts div b{display:block; font-family:var(--display); font-size:20px; color:var(--marfil); font-weight:500;}
.proy-facts div span{font-family:var(--body); font-size:9.5px; text-transform:uppercase; letter-spacing:.08em; color:#c3b494;}
.proy-status{position:absolute; top:28px; right:28px; z-index:2; font-family:var(--body); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--marfil); font-weight:600; border:1px solid rgba(250,246,239,.5); padding:7px 14px;}

/* ===== stats strip ===== */
.stats{padding:64px 0; border-top:1px solid var(--linea); border-bottom:1px solid var(--linea);}
.stats .wrap{display:grid; grid-template-columns:repeat(4,1fr); gap:30px; text-align:center;}
@media(max-width:820px){.stats .wrap{grid-template-columns:repeat(2,1fr); gap:40px;}}
.stat b{font-family:var(--display); font-size:clamp(30px,3.6vw,46px); font-weight:500; display:block; color:var(--carbon);}
.stat span{font-family:var(--body); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--piedra);}

/* ===== quienes somos ===== */
.somos{display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center;}
@media(max-width:900px){.somos{grid-template-columns:1fr; gap:44px;}}
.somos p{margin-top:16px; color:var(--carbon-soft); line-height:1.75; font-size:15.5px;}
.somos-figure{position:relative; aspect-ratio:4/5; overflow:hidden;}
.somos-figure img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover;}
.somos-quote{margin-top:28px; padding-left:24px; border-left:1px solid var(--bronce); font-family:var(--display); font-style:normal; font-size:19px; color:var(--carbon-soft); max-width:44ch; font-weight:500;}

/* ===== gallery tres (obra / urbanización) ===== */
.gallery-tres{display:grid; grid-template-columns:repeat(3,1fr); gap:2px;}
@media(max-width:820px){.gallery-tres{grid-template-columns:1fr;}}
.gt-item{position:relative; aspect-ratio:4/5; overflow:hidden;}
.gt-item img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform 1s ease;}
.gt-item:hover img{transform:scale(1.06);}
.gt-cap{position:absolute; left:0; right:0; bottom:0; padding:18px 20px; background:linear-gradient(0deg, rgba(20,17,13,.78), rgba(20,17,13,0)); color:var(--marfil); font-family:var(--body); font-size:12px; letter-spacing:.03em;}

/* ===== diferenciadores ===== */
.diff-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--linea); border-top:1px solid var(--linea); border-bottom:1px solid var(--linea);}
@media(max-width:860px){.diff-grid{grid-template-columns:1fr 1fr;}}
.diff-card{background:var(--marfil); padding:40px 30px;}
.diff-card .n{font-family:var(--body); font-size:11.5px; letter-spacing:.1em; font-weight:700; color:var(--bronce); font-style:normal; margin-bottom:18px;}
.diff-card h4{font-size:17px; font-weight:600; margin-bottom:10px; font-family:var(--body);}
.diff-card p{color:var(--carbon-soft); font-size:13.5px; line-height:1.6;}

/* ===== historia (timeline narrativo) ===== */
.historia{background:var(--carbon); color:var(--marfil);}
.historia .label{color:var(--bronce-soft);}
.historia .section-head h2{color:var(--marfil);}
.historia .section-head .lede{color:#c3b899;}
.tl{display:flex; flex-direction:column;}
.tl-item{display:grid; grid-template-columns:140px 1fr; gap:36px; padding:34px 0; border-top:1px solid rgba(250,246,239,.12);}
.tl-item:last-child{border-bottom:1px solid rgba(250,246,239,.12);}
@media(max-width:640px){.tl-item{grid-template-columns:1fr; gap:10px;}}
.tl-year{font-family:var(--body); font-size:12.5px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--bronce-soft);}
.tl-body h4{font-size:19px; font-weight:600; font-family:var(--body); margin-bottom:8px; color:var(--marfil);}
.tl-body p{color:#c3b899; font-size:14.5px; line-height:1.7; max-width:64ch;}

/* ===== financiamiento ===== */
.fin-grid{display:grid; grid-template-columns:repeat(5,1fr); gap:1px; background:var(--linea); border-top:1px solid var(--linea); border-bottom:1px solid var(--linea);}
@media(max-width:980px){.fin-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.fin-grid{grid-template-columns:1fr;}}
.fin-card{background:var(--marfil); padding:32px 24px;}
.fin-card h4{font-family:var(--body); font-size:14.5px; font-weight:600; margin-bottom:9px;}
.fin-card p{font-size:12.5px; color:var(--carbon-soft); line-height:1.6;}

/* ===== testimonios ===== */
.testi-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--linea); border-top:1px solid var(--linea); border-bottom:1px solid var(--linea);}
@media(max-width:860px){.testi-grid{grid-template-columns:1fr;}}
.testi-card{background:var(--marfil); padding:36px 30px;}
.testi-card .stars{color:var(--bronce); font-size:12px; letter-spacing:3px; margin-bottom:18px;}
.testi-card p{font-size:15px; line-height:1.7; color:var(--carbon-soft); font-family:var(--display); font-style:normal; font-weight:500;}
.testi-who{margin-top:22px; font-family:var(--body); font-size:12px; letter-spacing:.05em; text-transform:uppercase; color:var(--piedra);}
.testi-who b{color:var(--carbon); font-weight:600; text-transform:none; letter-spacing:0; font-size:13.5px; display:block; margin-bottom:2px;}

/* ===== cta banda ===== */
.cta-banda{background:var(--carbon); color:var(--marfil); text-align:center;}
.cta-banda .label{justify-content:center; color:var(--bronce-soft);}
.cta-banda h2{font-size:clamp(28px,3.8vw,46px); max-width:20ch; margin:0 auto 18px; color:var(--marfil); font-weight:500;}
.cta-banda p{max-width:52ch; margin:0 auto 32px; color:#c3b899; font-size:15.5px;}
.cta-actions{display:flex; gap:14px; justify-content:center; flex-wrap:wrap;}

/* ===== contacto ===== */
.contact-grid{display:grid; grid-template-columns:1fr 1.15fr; gap:80px;}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr; gap:44px;}}
.cinfo-item{padding:22px 0; border-top:1px solid var(--linea);}
.cinfo-item:last-child{border-bottom:1px solid var(--linea);}
.cinfo-item h5{font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--piedra); font-weight:600; margin-bottom:6px;}
.cinfo-item p{font-size:15px; color:var(--carbon); font-family:var(--display); font-weight:400;}
.form{display:flex; flex-direction:column; gap:22px;}
.form-row{display:grid; grid-template-columns:1fr 1fr; gap:22px;}
@media(max-width:560px){.form-row{grid-template-columns:1fr;}}
.field{display:flex; flex-direction:column; gap:8px;}
.field label{font-family:var(--body); font-size:10.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--piedra); font-weight:600;}
.field input, .field select, .field textarea{
  font-family:var(--body); font-size:15px; padding:12px 0; border:none; border-bottom:1.5px solid var(--linea); background:transparent; color:var(--carbon); transition:.2s;
}
.field input:focus, .field select:focus, .field textarea:focus{border-color:var(--bronce);}
.field select{appearance:none; -webkit-appearance:none; background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%238c8171'/%3E%3C/svg%3E") no-repeat right 4px center;}
.field textarea{resize:vertical; min-height:80px;}
.form .btn-dark{justify-content:center; margin-top:8px; align-self:flex-start;}
.form-note{font-size:11.5px; color:var(--piedra); line-height:1.5;}

/* ===== síguenos en redes ===== */
.social-section{padding:90px 0; text-align:center; border-top:1px solid var(--linea); border-bottom:1px solid var(--linea); background:var(--marfil-2);}
.social-section .label{justify-content:center;}
.social-section h3{font-family:var(--display); font-weight:500; font-size:clamp(24px,2.8vw,34px); color:var(--carbon);}
.social-section .lede{margin:14px auto 0; text-align:center;}
.social-grid{display:flex; justify-content:center; gap:36px; margin-top:44px; flex-wrap:wrap;}
.social-card{display:flex; flex-direction:column; align-items:center; gap:14px; text-decoration:none;}
.social-icon{width:68px; height:68px; border-radius:50%; background:var(--cal); border:1.5px solid var(--linea); display:flex; align-items:center; justify-content:center; transition:.25s; color:var(--carbon);}
.social-icon svg{width:26px; height:26px;}
.social-card:hover .social-icon{background:var(--carbon); border-color:var(--carbon); color:var(--marfil); transform:translateY(-4px);}
.social-card span{font-family:var(--body); font-size:12.5px; font-weight:600; letter-spacing:.03em; color:var(--carbon-soft);}
.social-card:hover span{color:var(--carbon);}

/* ===== footer ===== */
footer{background:var(--carbon); color:var(--marfil); padding:80px 0 30px; border-top:1px solid rgba(250,246,239,.08);}
.foot-top{display:flex; justify-content:space-between; align-items:flex-start; gap:40px; flex-wrap:wrap; padding-bottom:50px; border-bottom:1px solid rgba(250,246,239,.12);}
.foot-brand{display:flex; align-items:center; gap:14px;}
.foot-brand img{height:42px;}
.foot-brand .b1{font-family:var(--display); font-size:18px; letter-spacing:.14em; color:var(--marfil); font-weight:500;}
.foot-brand .b2{font-family:var(--body); font-size:9px; letter-spacing:.28em; color:var(--piedra); margin-top:4px;}
.foot-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:44px; padding:44px 0; border-bottom:1px solid rgba(250,246,239,.12);}
@media(max-width:700px){.foot-grid{grid-template-columns:1fr;}}
.foot-grid h5{font-family:var(--body); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--piedra); margin-bottom:16px;}
.foot-grid li{margin-bottom:10px; font-size:14px; color:#d8cbae;}
.foot-social{display:flex; gap:12px;}
.foot-social a{width:36px; height:36px; border-radius:50%; border:1px solid rgba(250,246,239,.25); display:flex; align-items:center; justify-content:center; font-size:12px;}
.foot-social a:hover{border-color:var(--bronce-soft); color:var(--bronce-soft);}
.foot-bottom{display:flex; justify-content:space-between; padding-top:24px; font-family:var(--body); font-size:11px; color:var(--piedra); letter-spacing:.02em; flex-wrap:wrap; gap:10px;}

/* ===== whatsapp float (subtle) ===== */
.wa-float{position:fixed; right:26px; bottom:26px; z-index:500; width:54px; height:54px; border-radius:50%; background:var(--carbon);
  display:flex; align-items:center; justify-content:center; box-shadow:0 12px 28px rgba(28,24,20,.28); transition:.25s; border:1px solid var(--bronce-soft);}
.wa-float:hover{background:var(--bronce);}
/* ===== proy tile "ver más" link ===== */
.proy-more{display:inline-block; margin-top:6px; font-family:var(--body); font-size:12.5px; font-weight:600; color:var(--bronce-soft);}

/* ===== santa cecilia detail section — narrative journey ===== */
.sc-detalle{background:var(--marfil); padding-bottom:0;}

/* mini Ken Burns hero (reuses .kb-slide/.hero-scrim/.hero-grain keyframes) */
.sc-hero{position:relative; min-height:78vh; display:flex; align-items:flex-end; overflow:hidden; background:var(--carbon);}
.sc-hero .kb-slide img{width:100%; height:100%; object-fit:cover;}
.sc-hero-content{position:relative; z-index:3; padding:60px 0 56px;}
.sc-hero-content h2{color:var(--marfil); font-size:clamp(32px,5vw,58px); font-weight:500;}
.sc-back{display:inline-block; margin-bottom:22px; font-family:var(--body); font-size:12.5px; font-weight:600; letter-spacing:.02em; color:#e6dcc9; opacity:.9;}
.sc-back:hover{color:var(--marfil); opacity:1;}
.sc-hero-actions{display:flex; gap:14px; flex-wrap:wrap; margin-top:26px;}

/* intro stat strip */
.sc-stats{border-top:1px solid var(--linea); border-bottom:1px solid var(--linea); padding:44px 0;}
.sc-stats .wrap{display:grid; grid-template-columns:repeat(4,1fr); gap:24px; text-align:center;}
@media(max-width:820px){.sc-stats .wrap{grid-template-columns:1fr 1fr;}}
.sc-stats b{display:block; font-family:var(--display); font-size:clamp(22px,2.6vw,32px); color:var(--carbon); font-weight:500;}
.sc-stats span{font-family:var(--body); font-size:10.5px; text-transform:uppercase; letter-spacing:.06em; color:var(--piedra);}

.sc-intro{max-width:760px; margin:80px auto 0; padding:0 40px; text-align:center;}
@media(max-width:720px){.sc-intro{padding:0 22px; margin-top:56px;}}
.sc-intro .label{justify-content:center;}
.sc-h3{font-family:var(--display); font-weight:500; font-size:clamp(22px,2.6vw,30px); color:var(--carbon);}

/* numbered journey chapters, alternating media/text */
.journey-head{max-width:640px; margin:110px auto 60px; padding:0 40px; text-align:center;}
@media(max-width:720px){.journey-head{padding:0 22px; margin-top:70px;}}
.journey-head .label{justify-content:center;}

.chapter{padding:70px 0;}
.chapter .wrap{max-width:var(--maxw);}
.chapter-grid{display:grid; grid-template-columns:1fr 1fr; gap:6vw; align-items:center;}
@media(max-width:860px){.chapter-grid{grid-template-columns:1fr; gap:32px;}}
.chapter-rev .chapter-media{order:2;}
@media(max-width:860px){.chapter-rev .chapter-media{order:0;}}
.chapter-num{font-family:var(--body); font-style:normal; font-size:11.5px; letter-spacing:.1em; font-weight:700; text-transform:uppercase; color:var(--bronce); margin-bottom:14px; display:block;}
.chapter-body h3{font-size:clamp(24px,2.8vw,34px); margin-bottom:16px;}
.chapter-body p{font-size:15px; line-height:1.75; color:var(--carbon-soft); max-width:46ch;}
.chapter-media{position:relative; aspect-ratio:4/5; overflow:hidden;}
.chapter-media img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform 1.6s cubic-bezier(.2,.7,.2,1);}
.chapter:hover .chapter-media img{transform:scale(1.06);}

/* cinematic full-bleed interlude with continuous motion + quote */
.interlude{position:relative; min-height:64vh; display:flex; align-items:center; justify-content:center; overflow:hidden;}
.interlude img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; animation:kbslow 16s ease-in-out infinite alternate;}
@keyframes kbslow{0%{transform:scale(1);} 100%{transform:scale(1.1);}}
.interlude-scrim{position:absolute; inset:0; background:linear-gradient(180deg, rgba(20,17,13,.55) 0%, rgba(20,17,13,.72) 100%);}
.interlude blockquote{position:relative; z-index:2; text-align:center; color:var(--marfil); font-family:var(--display); font-style:normal; font-weight:500;
  font-size:clamp(22px,3.4vw,38px); max-width:820px; padding:0 30px; line-height:1.42;}
.interlude cite{position:relative; z-index:2; display:block; margin-top:22px; font-family:var(--body); font-style:normal; font-size:11.5px; letter-spacing:.12em;
  text-transform:uppercase; color:var(--bronce-soft); text-align:center;}

/* ===== logo del residencial ===== */
.sc-logo-section{padding:70px 0 90px; text-align:center; border-bottom:1px solid var(--linea);}
.sc-logo-badge{display:inline-flex; align-items:center; justify-content:center; padding:34px 42px; background:var(--marfil-2); border:1px solid var(--linea);}
.sc-logo-badge img{max-height:100px; width:auto;}
.sc-logo-caption{margin-top:18px; font-family:var(--body); font-size:12px; letter-spacing:.06em; color:var(--piedra);}

/* ===== proto carousel (varias fotos por prototipo) ===== */
.proto-media{position:relative; aspect-ratio:4/3; overflow:hidden;}
.proto-media .proto-slide{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:0; transition:opacity .5s ease;}
.proto-media .proto-slide.is-active{opacity:1;}
.proto-arrow{position:absolute; top:50%; transform:translateY(-50%); z-index:3; width:32px; height:32px; border-radius:50%;
  background:rgba(20,17,13,.55); color:#fff; display:flex; align-items:center; justify-content:center; border:none; cursor:pointer; transition:.2s;}
.proto-arrow:hover{background:rgba(20,17,13,.85);}
.proto-arrow.prev{left:10px;}
.proto-arrow.next{right:10px;}
.proto-dots{position:absolute; left:0; right:0; bottom:10px; z-index:3; display:flex; justify-content:center; gap:6px;}
.proto-dot{width:6px; height:6px; border-radius:50%; background:rgba(255,255,255,.55); border:none; padding:0; cursor:pointer; transition:.2s;}
.proto-dot.is-active{background:#fff; transform:scale(1.3);}
.proto-zoom{position:absolute; top:10px; right:10px; z-index:3; width:32px; height:32px; border-radius:50%; background:rgba(20,17,13,.55);
  color:#fff; border:none; display:flex; align-items:center; justify-content:center; cursor:pointer; transition:.2s;}
.proto-zoom:hover{background:rgba(20,17,13,.85);}
.proto-zoom svg{width:16px; height:16px;}

/* ===== lightbox (zoom de fotos y plantas) ===== */
.lightbox{position:fixed; inset:0; z-index:1000; background:rgba(15,13,10,.95); display:none; align-items:center; justify-content:center; padding:26px;}
.lightbox.is-open{display:flex;}
.lightbox img{max-width:92vw; max-height:86vh; width:auto; height:auto; object-fit:contain; box-shadow:0 30px 80px rgba(0,0,0,.5); touch-action:pinch-zoom;}
.lightbox-caption{position:absolute; left:0; right:0; bottom:22px; text-align:center; color:var(--marfil); font-family:var(--body); font-size:12.5px; letter-spacing:.04em; opacity:.75;}
.lightbox-close{position:absolute; top:22px; right:26px; width:42px; height:42px; border-radius:50%; border:1px solid rgba(250,246,239,.3); background:transparent;
  color:var(--marfil); font-size:22px; display:flex; align-items:center; justify-content:center; cursor:pointer; transition:.2s;}
.lightbox-close:hover{background:rgba(250,246,239,.1);}
.lightbox-nav{position:absolute; top:50%; transform:translateY(-50%); width:48px; height:48px; border-radius:50%; border:1px solid rgba(250,246,239,.3);
  background:transparent; color:var(--marfil); font-size:24px; display:flex; align-items:center; justify-content:center; cursor:pointer; transition:.2s;}
.lightbox-nav:hover{background:rgba(250,246,239,.1);}
.lightbox-nav.prev{left:20px;}
.lightbox-nav.next{right:20px;}
@media(max-width:600px){.lightbox-nav{width:38px; height:38px;} .lightbox-nav.prev{left:8px;} .lightbox-nav.next{right:8px;}}

/* ===== proto grid ===== */
.proto-grid{max-width:var(--maxw); margin:50px auto 0; padding:0 40px; display:grid; grid-template-columns:repeat(3,1fr); gap:26px;}
@media(max-width:900px){.proto-grid{grid-template-columns:1fr; padding:0 22px;}}
.proto-card{border:1px solid var(--linea); background:var(--cal);}
.proto-body{padding:26px;}
.proto-tag{font-family:var(--display); font-size:19px; color:var(--carbon); display:block; margin-bottom:16px;}
.proto-specs{display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:18px; padding-bottom:18px; border-bottom:1px solid var(--linea);}
.proto-specs div b{display:block; font-family:var(--display); font-size:20px; color:var(--bronce); font-weight:500;}
.proto-specs div span{font-family:var(--body); font-size:10.5px; text-transform:uppercase; letter-spacing:.06em; color:var(--piedra);}
.proto-body .desc{font-size:13.5px; color:var(--carbon-soft); line-height:1.6; margin-bottom:18px;}
.proto-wa{font-family:var(--body); font-size:12.5px; font-weight:600; color:var(--bronce);}
.proto-wa:hover{color:var(--carbon);}

.sc-split{display:grid; grid-template-columns:1fr 1fr; gap:70px; max-width:var(--maxw); margin:0 auto; padding:0 40px;}
@media(max-width:820px){.sc-split{grid-template-columns:1fr; gap:40px; padding:0 22px;}}
@media(max-width:860px){.sc-split{padding:0 22px;}}
.ventajas-list{margin-top:14px;}
.ventajas-list li{padding:13px 0; border-top:1px solid var(--linea); font-size:14.5px; color:var(--carbon-soft); padding-left:20px; position:relative;}
.ventajas-list li:last-child{border-bottom:1px solid var(--linea);}
.ventajas-list li::before{content:"—"; position:absolute; left:0; color:var(--bronce);}

.sc-amenidades{display:grid; grid-template-columns:1.3fr 1fr; gap:50px; align-items:center; max-width:var(--maxw); margin:0 auto; padding:0 40px;}
@media(max-width:820px){.sc-amenidades{grid-template-columns:1fr; gap:26px; padding:0 22px;}}
.sc-amen-photo{aspect-ratio:1/1; overflow:hidden;}
.sc-amen-photo img{width:100%; height:100%; object-fit:cover;}
.amen-list li{padding:12px 0; border-top:1px solid var(--linea); font-size:14.5px; color:var(--carbon-soft); padding-left:20px; position:relative;}
.amen-list li:last-child{border-bottom:1px solid var(--linea);}
.amen-list li::before{content:"✓"; position:absolute; left:0; color:var(--bronce);}

.sc-gallery{max-width:var(--maxw); margin:0 auto; padding:0 40px; display:grid; grid-template-columns:repeat(4,1fr); gap:2px;}
@media(max-width:820px){.sc-gallery{grid-template-columns:1fr 1fr; padding:0 22px;}}
.sc-g-item{aspect-ratio:3/4; overflow:hidden; cursor:zoom-in;}
.sc-g-item img{width:100%; height:100%; object-fit:cover; transition:transform .8s ease;}
.sc-g-item:hover img{transform:scale(1.06);}


.sc-cta{background:var(--carbon); padding:60px; text-align:center;}
@media(max-width:600px){.sc-cta{padding:40px 24px;}}
