:root{--gold:#B38B13;--gold-light:#D4A820;--gold-dark:#916010;--black:#000000;--black-soft:#0A0A0A;--black-mid:#111111;--black-card:#161616;--gray-mid:#2A2A2A;--gray-text:#888888;--gray-light:#B2B2B2;--white:#FFFFFF}
*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}
body{font-family:'Montserrat',sans-serif;background:var(--black);color:var(--white);overflow-x:hidden;cursor:none}
::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:var(--black)}::-webkit-scrollbar-thumb{background:var(--gold)}
.cursor{position:fixed;width:12px;height:12px;background:var(--gold);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .3s,height .3s,opacity .3s}
.cursor-ring{position:fixed;width:36px;height:36px;border:1px solid rgba(179,139,19,.5);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .3s,height .3s}
.cursor.expand{width:20px;height:20px}.cursor-ring.expand{width:56px;height:56px}
.section-tag{display:inline-flex;align-items:center;gap:12px;font-size:9px;font-weight:700;letter-spacing:.3em;color:var(--gold);text-transform:uppercase;margin-bottom:20px}
.section-tag::before{content:'';display:block;width:30px;height:1px;background:var(--gold)}
.section-title{font-size:clamp(36px,4vw,60px);font-weight:900;line-height:1.05;letter-spacing:-.02em;color:var(--white)}
.section-title em{font-style:normal;color:var(--gold)}
.btn-primary{display:inline-flex;align-items:center;gap:10px;background:var(--gold);color:var(--black);padding:16px 36px;font-size:11px;font-weight:800;letter-spacing:.15em;text-transform:uppercase;text-decoration:none;transition:all .3s;position:relative;overflow:hidden}
.btn-primary::before{content:'';position:absolute;inset:0;background:var(--gold-light);transform:translateX(-100%);transition:transform .4s}
.btn-primary:hover::before{transform:translateX(0)}.btn-primary span{position:relative;z-index:1}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 20px 60px rgba(179,139,19,.3)}
.btn-secondary{display:inline-flex;align-items:center;gap:10px;color:var(--white);font-size:11px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;text-decoration:none;border-bottom:1px solid rgba(255,255,255,.2);padding-bottom:4px;transition:all .3s}
.btn-secondary:hover{color:var(--gold);border-color:var(--gold)}
.btn-dark{display:inline-flex;align-items:center;justify-content:center;gap:10px;background:var(--black);color:var(--white);padding:16px 36px;font-size:11px;font-weight:800;letter-spacing:.15em;text-transform:uppercase;text-decoration:none;transition:all .3s;white-space:nowrap}
.btn-dark:hover{background:var(--black-mid);transform:translateY(-2px);box-shadow:0 20px 40px rgba(0,0,0,.4)}
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:28px 60px;transition:all .4s}
nav.scrolled{background:rgba(0,0,0,.95);backdrop-filter:blur(20px);padding:18px 60px;border-bottom:1px solid rgba(179,139,19,.15)}
.nav-logo{display:flex;align-items:center;gap:14px;text-decoration:none}.nav-monogram{width:44px;height:44px;flex-shrink:0}
.nav-wordmark{display:flex;flex-direction:column;line-height:1}
.w-torre{font-size:10px;font-weight:700;letter-spacing:.15em;color:var(--white)}
.w-fortal{font-size:14px;font-weight:900;letter-spacing:.1em;color:var(--gold)}
.w-pinares{font-size:7px;font-weight:500;letter-spacing:.25em;color:var(--gray-text);margin-top:1px}
.nav-links{display:flex;align-items:center;gap:36px;list-style:none}
.nav-links a{text-decoration:none;font-size:11px;font-weight:600;letter-spacing:.12em;color:var(--gray-light);text-transform:uppercase;transition:color .3s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--gold);transition:width .3s}
.nav-links a:hover{color:var(--white)}.nav-links a:hover::after{width:100%}
.nav-cta{background:var(--gold)!important;color:var(--black)!important;padding:10px 22px;font-weight:700!important}.nav-cta::after{display:none!important}
.nav-cta:hover{background:var(--gold-light)!important;transform:translateY(-1px)}
.nav-hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.nav-hamburger span{display:block;width:24px;height:2px;background:var(--white);transition:all .3s}
.mobile-menu{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.97);z-index:99;align-items:center;justify-content:center}
.mobile-menu.open{display:flex}.mobile-menu ul{list-style:none;text-align:center}.mobile-menu ul li{margin:24px 0}
.mobile-link{text-decoration:none;font-size:22px;font-weight:700;color:var(--white);letter-spacing:.1em;text-transform:uppercase;transition:color .3s}
.mobile-link:hover{color:var(--gold)}
.hero{position:relative;height:100vh;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover!important;background-position:center!important}
.hero-grid-overlay{position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 80px,rgba(179,139,19,.03) 80px,rgba(179,139,19,.03) 81px),repeating-linear-gradient(90deg,transparent,transparent 80px,rgba(179,139,19,.03) 80px,rgba(179,139,19,.03) 81px)}
.hero-monogram-bg{position:absolute;right:-60px;top:50%;transform:translateY(-50%);opacity:.04;width:700px;height:700px;animation:slowRotate 60s linear infinite}
@keyframes slowRotate{from{transform:translateY(-50%) rotate(0deg)}to{transform:translateY(-50%) rotate(360deg)}}
.hero-content{position:relative;z-index:2;padding:0 60px;max-width:820px;animation:fadeInUp 1.2s ease both}
@keyframes fadeInUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}
.hero-label{display:inline-flex;align-items:center;gap:12px;font-size:10px;font-weight:700;letter-spacing:.3em;color:var(--gold);text-transform:uppercase;margin-bottom:28px;animation:fadeInUp 1.2s .2s ease both}
.hero-label::before{content:'';display:block;width:40px;height:1px;background:var(--gold)}
.hero-title{font-size:clamp(52px,6vw,90px);font-weight:900;line-height:.95;letter-spacing:-.02em;color:var(--white);margin-bottom:10px;animation:fadeInUp 1.2s .3s ease both}
.hero-title span{color:var(--gold);display:block}
.hero-subtitle{font-size:clamp(36px,4.5vw,68px);font-weight:300;line-height:1;letter-spacing:.05em;color:rgba(255,255,255,.3);margin-bottom:36px;animation:fadeInUp 1.2s .4s ease both}
.hero-desc{font-size:14px;font-weight:400;line-height:1.8;color:var(--gray-light);max-width:500px;margin-bottom:48px;animation:fadeInUp 1.2s .5s ease both}
.hero-actions{display:flex;align-items:center;gap:24px;animation:fadeInUp 1.2s .6s ease both}
.hero-stats{position:absolute;bottom:0;left:0;right:0;display:flex;align-items:stretch;z-index:2;animation:fadeInUp 1.2s .8s ease both}
.hero-stat{flex:1;padding:28px 36px;background:rgba(10,10,10,.92);backdrop-filter:blur(20px);border-top:1px solid rgba(179,139,19,.2);border-right:1px solid rgba(179,139,19,.1);transition:background .3s}
.hero-stat:last-child{border-right:none}.hero-stat:hover{background:rgba(25,25,25,.98)}
.hero-stat-num{font-size:34px;font-weight:900;color:var(--gold);line-height:1;letter-spacing:-.02em}
.hero-stat-label{font-size:9px;font-weight:600;letter-spacing:.18em;color:var(--gray-text);text-transform:uppercase;margin-top:6px}
.proyecto{background:var(--black-soft);padding:0}.proyecto-inner{display:grid;grid-template-columns:1fr 1fr}
.proyecto-visual{position:relative;min-height:600px;overflow:hidden}
.proyecto-img{width:100%;height:100%;object-fit:cover;opacity:.55;transition:transform 8s,opacity .5s;display:block}
.proyecto-visual:hover .proyecto-img{transform:scale(1.04);opacity:.65}
.proyecto-visual-overlay{position:absolute;inset:0;background:linear-gradient(to right,transparent 60%,rgba(10,10,10,1) 100%)}
.proyecto-badge-ubicacion{position:absolute;bottom:40px;left:40px;background:var(--gold);padding:12px 20px;display:flex;flex-direction:column;gap:2px}
.badge-label{font-size:8px;font-weight:700;letter-spacing:.2em;color:rgba(0,0,0,.6);text-transform:uppercase}
.badge-value{font-size:12px;font-weight:800;color:var(--black)}
.proyecto-content{padding:80px 70px;background:var(--black-mid);display:flex;flex-direction:column;justify-content:center}
.proyecto-text{font-size:14px;font-weight:400;line-height:1.9;color:var(--gray-light)}.proyecto-text strong{color:var(--white);font-weight:700}
.proyecto-stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(179,139,19,.1);border:1px solid rgba(179,139,19,.1);margin-top:40px}
.pstat{padding:24px;background:var(--black-mid);transition:background .3s}.pstat:hover{background:var(--black-card)}
.pstat-num{font-size:36px;font-weight:900;color:var(--gold);line-height:1}
.pstat-label{font-size:10px;font-weight:600;color:var(--gray-text);letter-spacing:.1em;text-transform:uppercase;margin-top:4px}
.ubicacion{background:var(--black);padding:0}.ubicacion-inner{display:grid;grid-template-columns:1fr 1fr}
.ubicacion-content{padding:100px 70px;background:var(--black-card)}
.ubicacion-desc{font-size:14px;color:var(--gray-light);margin:16px 0 40px;letter-spacing:.05em}
.ubicacion-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(179,139,19,.1);border:1px solid rgba(179,139,19,.1)}
.ubic-card{padding:28px 24px;background:var(--black-card);transition:background .3s}.ubic-card:hover{background:var(--black-mid)}
.ubic-icon{font-size:20px;margin-bottom:12px}
.ubic-card h4{font-size:12px;font-weight:800;color:var(--gold);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}
.ubic-card p{font-size:12px;color:var(--gray-text);line-height:1.7}
.ubicacion-map{position:relative;overflow:hidden}.ubicacion-map img{width:100%;height:100%;object-fit:cover;opacity:.7;display:block}
.tipologias{background:var(--black-soft);padding:100px 60px}
.tipologias-sub{font-size:13px;color:var(--gray-text);text-align:center;margin-bottom:60px;letter-spacing:.05em}
.tipo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px}
.tipo-card{background:var(--black-mid);transition:transform .3s}.tipo-card:hover{transform:translateY(-4px)}
.tipo-header{padding:28px 28px 0}.tipo-name{font-size:22px;font-weight:900;color:var(--gold);letter-spacing:.05em}
.tipo-sub{font-size:10px;font-weight:600;color:var(--gray-text);letter-spacing:.2em;text-transform:uppercase;margin-top:4px}
.tipo-img{width:100%;height:200px;object-fit:cover;opacity:.7;margin-top:20px;transition:opacity .5s;display:block}
.tipo-card:hover .tipo-img{opacity:.9}.tipo-body{padding:24px 28px 32px}
.tipo-specs{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.tipo-area{font-size:12px;font-weight:700;color:var(--gray-light);background:rgba(255,255,255,.06);padding:6px 10px}
.tipo-price{font-size:14px;font-weight:900;color:var(--gold)}
.tipo-desc{font-size:12px;color:var(--gray-text);line-height:1.7;margin-bottom:20px}
.tipo-cta{display:inline-block;font-size:10px;font-weight:700;color:var(--gold);text-decoration:none;letter-spacing:.1em;border-bottom:1px solid rgba(179,139,19,.3);padding-bottom:2px;transition:all .3s}
.tipo-cta:hover{color:var(--gold-light);border-color:var(--gold)}
.arquitectura{padding:0;background:var(--black)}.arq-inner{display:grid;grid-template-columns:1fr 1fr}
.arq-content{padding:100px 70px;background:var(--black-card);display:flex;flex-direction:column;justify-content:center}
.arq-text{font-size:14px;color:var(--gray-light);line-height:1.9}
.arq-tech{margin-top:40px;display:flex;flex-wrap:wrap;gap:10px}
.arq-tech span{font-size:10px;font-weight:700;color:var(--gold);letter-spacing:.1em;background:rgba(179,139,19,.08);border:1px solid rgba(179,139,19,.2);padding:8px 14px;text-transform:uppercase}
.arq-visual{position:relative;overflow:hidden;min-height:550px}
.arq-visual img{width:100%;height:100%;object-fit:cover;opacity:.55;display:block;transition:opacity .5s,transform 8s}
.arq-visual:hover img{opacity:.7;transform:scale(1.03)}
.amenidades{background:var(--black-soft);padding:100px 60px}
.amenidades-sub{font-size:13px;color:var(--gray-text);text-align:center;margin-bottom:60px;max-width:600px;margin-left:auto;margin-right:auto}
.amenidades-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.amen-card{position:relative;min-height:280px;overflow:hidden}
.amen-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.35;transition:opacity .5s,transform .8s;display:block}
.amen-card:hover .amen-bg{opacity:.55;transform:scale(1.05)}
.amen-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.3) 60%,transparent 100%)}
.amen-content{position:absolute;bottom:0;left:0;right:0;padding:32px}
.amen-icon{font-size:24px;margin-bottom:10px}
.amen-content h4{font-size:16px;font-weight:900;color:var(--white);margin-bottom:6px}
.amen-content p{font-size:12px;color:var(--gray-light);line-height:1.6}
.inversion{background:var(--black-mid);padding:100px 60px}.inversion-inner{max-width:1200px;margin:0 auto}
.inversion-header{margin-bottom:60px}
.inversion-numeros{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;background:rgba(179,139,19,.1);margin-bottom:40px}
.inv-num{padding:36px 28px;background:var(--black-mid);transition:background .3s}.inv-num:hover{background:var(--black-card)}
.inv-num.highlight{background:var(--gold)}.inv-num.highlight .inv-valor{color:var(--black)}.inv-num.highlight .inv-label{color:rgba(0,0,0,.7)}
.inv-valor{font-size:36px;font-weight:900;color:var(--gold);line-height:1}
.inv-label{font-size:10px;font-weight:600;color:var(--gray-text);text-transform:uppercase;letter-spacing:.15em;margin-top:8px}
.escenario{background:var(--black-card);border:1px solid rgba(179,139,19,.2);padding:40px}
.escenario-title{font-size:14px;font-weight:800;color:var(--gold);letter-spacing:.05em;margin-bottom:24px}
.escenario-grid{display:grid;grid-template-columns:1fr 1fr;gap:0}
.esc-item{padding:16px 0;border-bottom:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;gap:4px}
.esc-item:nth-child(odd){padding-right:40px;border-right:1px solid rgba(255,255,255,.06)}
.esc-item:nth-child(even){padding-left:40px}
.esc-label{font-size:10px;font-weight:600;color:var(--gray-text);text-transform:uppercase;letter-spacing:.1em}
.esc-value{font-size:16px;font-weight:900;color:var(--gold)}
.escenario-nota{font-size:11px;color:var(--gray-text);margin-top:20px;font-style:italic}
.diferenciadores{background:var(--black);padding:100px 60px}
.dif-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.dif-card{padding:40px 36px;background:var(--black-card);transition:background .3s,border-top .3s;border-top:2px solid transparent}
.dif-card:hover{background:var(--black-mid);border-top-color:var(--gold)}
.dif-num{font-size:11px;font-weight:900;color:var(--gold);letter-spacing:.15em;margin-bottom:20px}
.dif-card h4{font-size:14px;font-weight:800;color:var(--white);margin-bottom:12px;letter-spacing:.02em}
.dif-card p{font-size:12px;color:var(--gray-text);line-height:1.7}
.pago{background:var(--black-soft);padding:100px 60px}.pago-inner{max-width:1000px;margin:0 auto}
.pago-sub{font-size:12px;color:var(--gray-text);text-align:center;margin-bottom:60px;letter-spacing:.05em}
.pago-steps{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;gap:0;align-items:center;margin-bottom:60px}
.pago-step{padding:40px 32px;background:var(--black-mid);border:1px solid rgba(179,139,19,.15);text-align:center}
.pago-num{width:48px;height:48px;background:var(--gold);color:var(--black);font-size:18px;font-weight:900;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.pago-step h4{font-size:14px;font-weight:800;color:var(--white);margin-bottom:8px}
.pago-monto{font-size:18px;font-weight:900;color:var(--gold);margin-bottom:12px}
.pago-step p{font-size:12px;color:var(--gray-text);line-height:1.6}
.pago-arrow{font-size:24px;color:var(--gold);padding:0 16px;opacity:.5}
.pago-timeline{display:flex;align-items:center;justify-content:center}
.timeline-item{text-align:center}
.tl-dot{width:16px;height:16px;border:2px solid var(--gold);border-radius:50%;margin:0 auto 12px;background:var(--black-soft);transition:background .3s}
.timeline-item.active .tl-dot{background:var(--gold)}
.tl-label{font-size:9px;font-weight:700;color:var(--gray-text);text-transform:uppercase;letter-spacing:.15em}
.tl-date{font-size:14px;font-weight:900;color:var(--white);margin-top:4px}
.timeline-line{flex:1;height:1px;background:rgba(179,139,19,.3);max-width:120px;margin:0 20px}
.cta-banner{padding:100px 60px;background:var(--gold);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:space-between;gap:40px}
.cta-banner::before{content:'TF';position:absolute;right:-40px;top:50%;transform:translateY(-50%);font-size:320px;font-weight:900;color:rgba(0,0,0,.07);line-height:1;pointer-events:none;user-select:none}
.cta-content{position:relative;z-index:1}
.cta-label{font-size:9px;font-weight:700;letter-spacing:.3em;color:rgba(0,0,0,.5);text-transform:uppercase;margin-bottom:12px}
.cta-title{font-size:clamp(28px,3.5vw,52px);font-weight:900;color:var(--black);line-height:1.1}
.cta-actions{position:relative;z-index:1;display:flex;flex-direction:column;gap:14px;flex-shrink:0}
.cta-phone{font-size:12px;font-weight:600;color:rgba(0,0,0,.7);text-align:center}
.cta-phone a{color:var(--black);text-decoration:none;font-weight:800}
.contacto{background:var(--black-mid);display:grid;grid-template-columns:1fr 1fr}
.contacto-left{padding:100px 70px}.contacto-right{padding:100px 70px;background:var(--black-card);border-left:1px solid rgba(179,139,19,.1)}
.contact-info{margin-top:48px;display:flex;flex-direction:column;gap:28px}
.contact-info-item{display:flex;gap:20px;align-items:flex-start}
.contact-info-icon{width:40px;height:40px;border:1px solid rgba(179,139,19,.3);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px}
.contact-info-label{font-size:9px;font-weight:700;letter-spacing:.2em;color:var(--gold);text-transform:uppercase;margin-bottom:4px}
.contact-info-value{font-size:13px;font-weight:500;color:var(--white);line-height:1.5}
.contact-offices{margin-top:40px;padding-top:32px;border-top:1px solid rgba(255,255,255,.06)}
.contact-offices-title{font-size:9px;font-weight:700;letter-spacing:.2em;color:var(--gold);text-transform:uppercase;margin-bottom:16px}
.offices-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.office-item{display:flex;flex-direction:column;gap:2px}
.office-country{font-size:9px;font-weight:700;color:var(--gray-text);letter-spacing:.1em;text-transform:uppercase}
.office-phone{font-size:12px;font-weight:600;color:var(--white)}
.contact-form-title{font-size:22px;font-weight:900;color:var(--white);margin-bottom:28px}
.form-group{margin-bottom:18px}
.form-label{display:block;font-size:9px;font-weight:700;letter-spacing:.2em;color:var(--gray-text);text-transform:uppercase;margin-bottom:8px}
.form-input,.form-select,.form-textarea{width:100%;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);color:var(--white);padding:13px 16px;font-family:'Montserrat',sans-serif;font-size:13px;font-weight:500;outline:none;transition:border-color .3s,background .3s;appearance:none}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--gold);background:rgba(179,139,19,.04)}
.form-input::placeholder,.form-textarea::placeholder{color:var(--gray-mid)}
.form-textarea{resize:none;height:90px}.form-select{cursor:pointer}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.btn-submit{width:100%;background:var(--gold);color:var(--black);border:none;padding:16px;font-family:'Montserrat',sans-serif;font-size:11px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;transition:all .3s;margin-top:6px}
.btn-submit:hover{background:var(--gold-light);transform:translateY(-2px);box-shadow:0 16px 40px rgba(179,139,19,.25)}
footer{background:var(--black);padding:60px;border-top:1px solid rgba(179,139,19,.1);display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:40px;align-items:start}
.footer-logo{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.footer-desc{font-size:11px;line-height:1.7;color:var(--gray-text);max-width:240px}
.footer-social{display:flex;gap:10px;margin-top:20px}
.social-link{width:34px;height:34px;border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--gray-text);text-decoration:none;transition:all .3s;font-weight:700}
.social-link:hover{border-color:var(--gold);color:var(--gold)}
.footer-col-title{font-size:10px;font-weight:800;letter-spacing:.2em;color:var(--gold);text-transform:uppercase;margin-bottom:16px}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:8px}
.footer-links a{font-size:12px;color:var(--gray-text);text-decoration:none;transition:color .3s}
.footer-links a:hover{color:var(--white)}
.footer-bottom{padding:20px 60px;background:var(--black);border-top:1px solid rgba(255,255,255,.04);display:flex;justify-content:space-between;align-items:center}
.footer-copy{font-size:11px;color:var(--gray-text)}.footer-copy span{color:var(--gold)}
.footer-legal{display:flex;gap:24px}
.footer-legal a{font-size:11px;color:var(--gray-text);text-decoration:none;transition:color .3s}
.footer-legal a:hover{color:var(--gold)}
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}.reveal-delay-4{transition-delay:.4s}
@media(max-width:1200px){.tipo-grid{grid-template-columns:repeat(2,1fr)}.inversion-numeros{grid-template-columns:repeat(2,1fr)}.dif-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:1024px){nav{padding:20px 30px}nav.scrolled{padding:14px 30px}.nav-links{display:none}.nav-hamburger{display:flex}.hero-content{padding:0 30px}.hero-stats{position:relative;flex-wrap:wrap}.hero-stat{min-width:50%}.proyecto-inner,.ubicacion-inner,.arq-inner,.contacto{grid-template-columns:1fr}.proyecto-visual,.ubicacion-map,.arq-visual{min-height:350px}.proyecto-visual-overlay{display:none}.proyecto-content,.ubicacion-content,.arq-content,.contacto-left,.contacto-right{padding:60px 30px}.amenidades-grid{grid-template-columns:repeat(2,1fr)}.pago-steps{grid-template-columns:1fr;gap:2px}.pago-arrow{display:none}.cta-banner{flex-direction:column;text-align:center;padding:60px 30px}footer{grid-template-columns:1fr 1fr;padding:40px 30px}.footer-bottom{padding:20px 30px;flex-direction:column;gap:10px;text-align:center}.form-row{grid-template-columns:1fr}}
@media(max-width:768px){.tipo-grid{grid-template-columns:1fr}.inversion-numeros{grid-template-columns:1fr 1fr}.dif-grid{grid-template-columns:1fr}.amenidades-grid{grid-template-columns:1fr}.ubicacion-grid{grid-template-columns:1fr}.proyecto-stats{grid-template-columns:1fr 1fr}.escenario-grid{grid-template-columns:1fr}.esc-item:nth-child(odd){padding-right:0;border-right:none}.esc-item:nth-child(even){padding-left:0}.pago-timeline{flex-direction:column;gap:20px}.timeline-line{width:1px;height:40px;margin:0}footer{grid-template-columns:1fr}}
.hero-bg-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: 0;
  opacity: 0.45;
}
.hero-grid-overlay {
  z-index: 1;
}
.hero-content {
  z-index: 2;
}
.hero-stats {
  z-index: 2;
}
.hero-monogram-bg {
  z-index: 1;
}

/* ============================================================
   RESPONSIVE COMPLETO — CORRECCIONES
   ============================================================ */

/* ---- TABLETS GRANDES (max 1200px) ---- */
@media (max-width: 1200px) {
  .tipo-grid { grid-template-columns: repeat(2, 1fr); }
  .inversion-numeros { grid-template-columns: repeat(2, 1fr); }
  .dif-grid { grid-template-columns: repeat(2, 1fr); }
  footer { grid-template-columns: 1fr 1fr; padding: 50px 40px; }
  .footer-bottom { padding: 20px 40px; }
  nav { padding: 24px 40px; }
  nav.scrolled { padding: 16px 40px; }
}

/* ---- TABLETS (max 1024px) ---- */
@media (max-width: 1024px) {
  /* Nav */
  nav { padding: 20px 30px; }
  nav.scrolled { padding: 14px 30px; }
  .nav-links { display: none; }
  .nav-hamburger { display: flex; }

  /* Hero */
  .hero-content { padding: 120px 30px 0; max-width: 100%; }
  .hero-title { font-size: clamp(42px, 8vw, 70px); }
  .hero-subtitle { font-size: clamp(30px, 6vw, 54px); }
  .hero-desc { font-size: 13px; max-width: 90%; }
  .hero-stats { position: relative; flex-wrap: wrap; }
  .hero-stat { min-width: 50%; border-right: none; border-bottom: 1px solid rgba(179,139,19,0.1); }
  .hero-stat:nth-child(odd) { border-right: 1px solid rgba(179,139,19,0.1); }
  .hero-bg-img { opacity: 0.35; }

  /* Secciones en 1 columna */
  .proyecto-inner,
  .ubicacion-inner,
  .arq-inner,
  .contacto { grid-template-columns: 1fr; }

  /* Proyecto */
  .proyecto-visual { min-height: 400px; }
  .proyecto-visual-overlay { display: none; }
  .proyecto-content { padding: 60px 40px; }
  .proyecto-stats { grid-template-columns: 1fr 1fr; }

  /* Ubicacion */
  .ubicacion-content { padding: 60px 40px; }
  .ubicacion-map { min-height: 300px; }
  .ubicacion-map img { max-height: 350px; }
  .ubicacion-grid { grid-template-columns: 1fr 1fr; }

  /* Arquitectura */
  .arq-content { padding: 60px 40px; order: 2; }
  .arq-visual { min-height: 350px; order: 1; }

  /* Tipologias */
  .tipologias { padding: 80px 30px; }
  .tipo-grid { grid-template-columns: repeat(2, 1fr); }

  /* Amenidades */
  .amenidades { padding: 80px 30px; }
  .amenidades-grid { grid-template-columns: repeat(2, 1fr); }

  /* Inversion */
  .inversion { padding: 80px 30px; }
  .inversion-numeros { grid-template-columns: repeat(2, 1fr); }
  .escenario { padding: 28px; }

  /* Diferenciadores */
  .diferenciadores { padding: 80px 30px; }
  .dif-grid { grid-template-columns: repeat(2, 1fr); }

  /* Pago */
  .pago { padding: 80px 30px; }
  .pago-steps { grid-template-columns: 1fr; gap: 2px; }
  .pago-arrow { display: none; }
  .pago-timeline { gap: 0; }
  .timeline-line { max-width: 80px; }

  /* CTA */
  .cta-banner { flex-direction: column; text-align: center; padding: 60px 30px; gap: 32px; }
  .cta-banner::before { font-size: 200px; right: -20px; }
  .cta-title { font-size: clamp(26px, 5vw, 44px); }

  /* Contacto */
  .contacto-left { padding: 60px 40px; }
  .contacto-right { padding: 60px 40px; }
  .form-row { grid-template-columns: 1fr; }

  /* Footer */
  footer { grid-template-columns: 1fr 1fr; padding: 40px 30px; gap: 32px; }
  .footer-bottom { padding: 20px 30px; flex-direction: column; gap: 10px; text-align: center; }
}

/* ---- MÓVILES GRANDES (max 768px) ---- */
@media (max-width: 768px) {
  /* Hero */
  .hero { min-height: 100vh; height: auto; }
  .hero-content { padding: 110px 20px 20px; }
  .hero-title { font-size: clamp(38px, 9vw, 58px); line-height: 1; }
  .hero-subtitle { font-size: clamp(26px, 7vw, 44px); margin-bottom: 24px; }
  .hero-desc { font-size: 13px; margin-bottom: 32px; }
  .hero-actions { flex-direction: column; align-items: flex-start; gap: 16px; }
  .hero-actions .btn-primary,
  .hero-actions .btn-secondary { width: 100%; justify-content: center; }
  .hero-stat { min-width: 50%; padding: 20px 24px; }
  .hero-stat-num { font-size: 28px; }

  /* Proyecto */
  .proyecto-content { padding: 50px 20px; }
  .proyecto-stats { grid-template-columns: 1fr 1fr; gap: 1px; }
  .pstat-num { font-size: 28px; }

  /* Ubicacion */
  .ubicacion-content { padding: 50px 20px; }
  .ubicacion-grid { grid-template-columns: 1fr; }

  /* Tipologias */
  .tipologias { padding: 60px 20px; }
  .tipo-grid { grid-template-columns: 1fr; }
  .tipo-img { height: 220px; }

  /* Arquitectura */
  .arq-content { padding: 50px 20px; }
  .arq-tech { gap: 8px; }
  .arq-tech span { font-size: 9px; padding: 6px 10px; }

  /* Amenidades */
  .amenidades { padding: 60px 20px; }
  .amenidades-grid { grid-template-columns: 1fr; }
  .amen-card { min-height: 240px; }

  /* Inversion */
  .inversion { padding: 60px 20px; }
  .inversion-numeros { grid-template-columns: 1fr 1fr; }
  .inv-valor { font-size: 28px; }
  .escenario { padding: 24px 20px; }
  .escenario-grid { grid-template-columns: 1fr; }
  .esc-item:nth-child(odd) { padding-right: 0; border-right: none; }
  .esc-item:nth-child(even) { padding-left: 0; }
  .esc-value { font-size: 14px; }

  /* Diferenciadores */
  .diferenciadores { padding: 60px 20px; }
  .dif-grid { grid-template-columns: 1fr; }
  .dif-card { padding: 28px 24px; }

  /* Pago */
  .pago { padding: 60px 20px; }
  .pago-inner { max-width: 100%; }
  .pago-step { padding: 28px 20px; }
  .pago-timeline { flex-direction: column; gap: 16px; align-items: flex-start; padding: 0 20px; }
  .timeline-line { width: 1px; height: 30px; max-width: none; margin: 0; }
  .timeline-item { display: flex; align-items: center; gap: 16px; text-align: left; }
  .tl-dot { margin: 0; flex-shrink: 0; }

  /* CTA */
  .cta-banner { padding: 50px 20px; }
  .cta-actions { width: 100%; }
  .btn-dark { width: 100%; }

  /* Contacto */
  .contacto-left { padding: 50px 20px; }
  .contacto-right { padding: 50px 20px; }
  .offices-grid { grid-template-columns: 1fr 1fr; }

  /* Footer */
  footer { grid-template-columns: 1fr; padding: 40px 20px; gap: 32px; }
  .footer-bottom { padding: 20px; }
  .footer-legal { flex-direction: column; gap: 8px; align-items: center; }

  /* Secciones generales */
  section { padding: 60px 20px; }
  .section-title { font-size: clamp(28px, 7vw, 46px); }
}

/* ---- MÓVILES PEQUEÑOS (max 480px) ---- */
@media (max-width: 480px) {
  nav { padding: 16px 20px; }
  nav.scrolled { padding: 12px 20px; }
  .nav-monogram { width: 36px; height: 36px; }
  .w-fortal { font-size: 12px; }

  .hero-content { padding: 100px 16px 16px; }
  .hero-title { font-size: clamp(32px, 10vw, 48px); }
  .hero-subtitle { font-size: clamp(22px, 8vw, 36px); }
  .hero-stat { min-width: 50%; padding: 16px 18px; }
  .hero-stat-num { font-size: 24px; }
  .hero-stat-label { font-size: 8px; }

  .btn-primary { padding: 14px 24px; font-size: 10px; }
  .btn-dark { padding: 14px 24px; font-size: 10px; }

  .proyecto-content { padding: 40px 16px; }
  .ubicacion-content { padding: 40px 16px; }
  .arq-content { padding: 40px 16px; }
  .contacto-left,
  .contacto-right { padding: 40px 16px; }

  .inversion-numeros { grid-template-columns: 1fr 1fr; }
  .inv-valor { font-size: 24px; }

  .pago-monto { font-size: 15px; }
  .cta-title { font-size: 24px; }

  footer { padding: 32px 16px; }
  .footer-bottom { padding: 16px; font-size: 10px; }

  .tipo-grid { grid-template-columns: 1fr; }
  .proyecto-stats { grid-template-columns: 1fr 1fr; }
  .offices-grid { grid-template-columns: 1fr; }
}

/* Logo imagen */
.nav-monogram {
  width: auto !important;
  height: 130px !important;
}
.footer-logo img {
  width: auto !important;
  height: 60px !important;
  object-fit: contain;
}

/* Logo tamaño corregido */
.nav-monogram {
  width: auto !important;
  height: 130px !important;
}
.footer-logo img {
  width: auto !important;
  height: 70px !important;
  object-fit: contain;
}
.nav-logo {
  gap: 0 !important;
}

/* Logo más grande */
.nav-monogram {
  width: auto !important;
  height: 120px !important;
}
.footer-logo img {
  width: auto !important;
  height: 100px !important;
  object-fit: contain;
}

/* Logo tamaño final */
.nav-monogram {
  width: auto !important;
  height: 80px !important;
}
.footer-logo img {
  width: auto !important;
  height: 80px !important;
  object-fit: contain;
}

/* ============ LOGO RESPONSIVE FIX ============ */
.nav-logo {
  display: flex !important;
  align-items: center !important;
  gap: 0 !important;
}
.nav-monogram {
  width: auto !important;
  height: 70px !important;
  max-width: 160px !important;
  object-fit: contain !important;
}
.footer-logo img {
  width: auto !important;
  height: 70px !important;
  max-width: 160px !important;
  object-fit: contain !important;
}

@media (max-width: 1024px) {
  .nav-monogram {
    height: 60px !important;
    max-width: 140px !important;
  }
}

@media (max-width: 768px) {
  .nav-monogram {
    height: 50px !important;
    max-width: 120px !important;
  }
  .footer-logo img {
    height: 50px !important;
    max-width: 120px !important;
  }
}

@media (max-width: 480px) {
  .nav-monogram {
    height: 44px !important;
    max-width: 100px !important;
  }
  .footer-logo img {
    height: 44px !important;
    max-width: 100px !important;
  }
}

/* Footer centrado en responsive */
@media (max-width: 1024px) {
  footer {
    text-align: center !important;
  }
  .footer-logo {
    justify-content: center !important;
  }
  .footer-social {
    justify-content: center !important;
  }
  .footer-links {
    align-items: center !important;
  }
  .footer-desc {
    margin: 0 auto !important;
  }
}

@media (max-width: 768px) {
  footer {
    text-align: center !important;
  }
  .footer-logo {
    justify-content: center !important;
  }
  .footer-social {
    justify-content: center !important;
  }
  .footer-links {
    align-items: center !important;
  }
  .footer-desc {
    margin: 0 auto !important;
  }
  .footer-bottom {
    text-align: center !important;
  }
  .footer-legal {
    justify-content: center !important;
  }
}

/* ============ LIGHTBOX ============ */
.lightbox-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.95);
  z-index: 9999;
  align-items: center;
  justify-content: center;
  cursor: zoom-out;
  animation: fadeIn 0.3s ease;
}
.lightbox-overlay.active {
  display: flex;
}
.lightbox-img {
  max-width: 90vw;
  max-height: 90vh;
  object-fit: contain;
  border: 1px solid rgba(179,139,19,0.3);
  animation: zoomIn 0.3s ease;
}
.lightbox-close {
  position: absolute;
  top: 24px; right: 32px;
  font-size: 40px;
  color: var(--gold);
  cursor: pointer;
  line-height: 1;
  transition: transform 0.2s;
}
.lightbox-close:hover { transform: scale(1.2); }
.lightbox-caption {
  position: absolute;
  bottom: 32px;
  font-size: 13px;
  font-weight: 700;
  color: var(--white);
  letter-spacing: 0.15em;
  text-transform: uppercase;
}
.amen-card { cursor: zoom-in; }
@keyframes zoomIn {
  from { opacity: 0; transform: scale(0.85); }
  to { opacity: 1; transform: scale(1); }
}
@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}
