*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--navy:#090A39;--sand:#CBC0B6;--brown:#927A6D;--cream:#FFFFFD;--sl:#EDE6E0;--nd:#060727;--wa:#25D366}
html{scroll-behavior:smooth}
body{font-family:'Open Sans',sans-serif;background:var(--cream);color:var(--navy);overflow-x:hidden;-webkit-font-smoothing:antialiased}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:200;height:60px;display:flex;align-items:center;justify-content:space-between;padding:0 2rem;background:rgba(255,255,253,.96);backdrop-filter:blur(12px);border-bottom:.5px solid rgba(9,10,57,.07)}
.nav-links{display:flex;gap:1.8rem;list-style:none}
.nav-links a{font-family:'Montserrat',sans-serif;font-size:10.5px;letter-spacing:.18em;text-decoration:none;color:var(--navy);text-transform:uppercase;opacity:.5;transition:opacity .2s}
.nav-links a:hover{opacity:1}
.nav-right{display:flex;align-items:center;gap:.75rem}
.nav-ig{display:flex;align-items:center;color:rgba(9,10,57,.4);text-decoration:none;transition:color .2s;padding:.4rem}
.nav-ig:hover{color:var(--navy)}
.nav-wa{display:inline-flex;align-items:center;gap:.45rem;background:var(--wa);color:#fff;font-family:'Montserrat',sans-serif;font-size:10.5px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:.5rem 1.1rem;border-radius:20px;text-decoration:none;transition:opacity .2s}
.nav-wa:hover{opacity:.88}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.4rem}
.nav-burger span{display:block;width:22px;height:1.5px;background:var(--navy)}

/* HERO */
#hero{min-height:100svh;display:grid;grid-template-columns:1fr 1fr;padding-top:60px}
.hero-l{background:var(--navy);padding:4rem 3rem;display:flex;flex-direction:column;justify-content:center}

.hero-logo{width:100%;max-width:340px;margin-bottom:2.5rem;padding-bottom:2.2rem;border-bottom:.5px solid rgba(255,255,255,.1)}
.hero-logo img{display:block;width:100%;height:auto;max-height:130px;object-fit:contain}
.hero-tag{font-family:'Montserrat',sans-serif;font-size:9.5px;letter-spacing:.35em;text-transform:uppercase;color:var(--sand);opacity:.7;margin-bottom:1.2rem}
.hero-title{font-family:'Raleway',sans-serif;font-size:clamp(2.2rem,3.5vw,3.6rem);font-weight:200;line-height:1.08;color:#fff;margin-bottom:1rem}
.hero-title em{font-style:normal;color:var(--sand)}
.hero-desc{font-size:14px;line-height:1.8;color:rgba(255,255,255,.55);margin-bottom:2.2rem;max-width:360px;text-align:justify}
.hero-actions{display:flex;flex-direction:column;gap:.7rem;max-width:280px}
.btn-wa-hero{display:flex;align-items:center;justify-content:center;gap:.6rem;background:var(--wa);color:#fff;font-family:'Montserrat',sans-serif;font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:.85rem 1.5rem;border-radius:6px;text-decoration:none;transition:opacity .2s}
.btn-wa-hero:hover{opacity:.88}
.btn-sec-hero{display:flex;align-items:center;justify-content:center;gap:.5rem;color:rgba(255,255,255,.5);font-family:'Montserrat',sans-serif;font-size:10.5px;letter-spacing:.15em;text-transform:uppercase;text-decoration:none;padding:.7rem;border:.5px solid rgba(255,255,255,.13);border-radius:6px;transition:all .2s}
.btn-sec-hero:hover{color:#fff;border-color:rgba(255,255,255,.38)}
.hero-r{overflow:hidden;position:relative}
.hero-r img{width:100%;height:100%;object-fit:cover;object-position:center 35%;display:block}

/* SHARED */
.stag{font-family:'Montserrat',sans-serif;font-size:9.5px;letter-spacing:.32em;text-transform:uppercase;color:var(--brown);margin-bottom:.7rem}
.stit{font-family:'Raleway',sans-serif;font-size:clamp(1.6rem,2.8vw,2.4rem);font-weight:200;line-height:1.15;color:var(--navy);margin-bottom:.9rem}
.sdiv{width:30px;height:1px;background:var(--sand);margin-bottom:1.8rem}
.btn-outline{font-family:'Montserrat',sans-serif;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;padding:.75rem 1.8rem;border:1px solid var(--navy);color:var(--navy);text-decoration:none;display:inline-block;transition:all .25s}
.btn-outline:hover{background:var(--navy);color:var(--cream)}

/* RESEÑAS */
#resenas{padding:4.5rem 2rem;background:var(--sl)}
.res-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:2.5rem;gap:2rem;flex-wrap:wrap}
.res-score{display:flex;align-items:baseline;gap:.6rem}
.res-num{font-family:'Raleway',sans-serif;font-size:2.8rem;font-weight:200;color:var(--navy);line-height:1}
.res-right .res-stars{font-size:1rem;color:#F9A825}
.res-right .res-label{font-family:'Montserrat',sans-serif;font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--brown)}
.res-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5px}
.res-card{background:var(--cream);padding:1.6rem}
.res-stars{color:#F9A825;font-size:.85rem;margin-bottom:.7rem}
.res-text{font-size:13.5px;line-height:1.75;color:rgba(9,10,57,.65);font-style:italic;margin-bottom:.8rem}
.res-autor{font-family:'Montserrat',sans-serif;font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--brown)}
.res-cta{text-align:center;margin-top:2rem}

/* MINI-ASESORAMIENTO */
#servicios{display:grid;grid-template-columns:1fr 1fr;background:var(--navy);min-height:500px}
.mini-left{padding:4rem 3rem;display:flex;flex-direction:column;justify-content:center}
.mini-eyebrow{font-family:'Montserrat',sans-serif;font-size:9.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--sand);opacity:.75;margin-bottom:1.2rem}
.mini-title{font-family:'Raleway',sans-serif;font-size:clamp(1.8rem,2.8vw,2.8rem);font-weight:200;line-height:1.12;color:#fff;margin-bottom:1rem}
.mini-desc{font-size:14px;line-height:1.78;color:rgba(255,255,255,.55);margin-bottom:1rem;max-width:380px}
.mini-priv{font-size:11.5px;color:rgba(255,255,255,.28)}
.mini-right{display:flex;align-items:center;justify-content:center;padding:3rem 2.5rem 3rem 0}
.mini-card{background:#fff;border-radius:14px;padding:2rem 1.8rem;width:100%;max-width:440px;box-shadow:0 24px 64px rgba(0,0,0,.22)}
.mini-progress{display:flex;gap:5px;margin-bottom:1.8rem}
.mini-bar{flex:1;height:3px;background:rgba(9,10,57,.1);border-radius:2px;transition:background .4s}
.mini-bar.active{background:var(--navy)}
.mini-bar.done{background:var(--navy)}
.mini-step{display:none;animation:mFadeUp .3s ease both}
.mini-step.active{display:block}
@keyframes mFadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.mini-q{font-family:'Raleway',sans-serif;font-size:1.2rem;font-weight:300;color:var(--navy);margin-bottom:.3rem;line-height:1.3}
.mini-hint{font-size:12.5px;color:rgba(9,10,57,.42);margin-bottom:1.4rem}
.mini-opts{display:flex;flex-direction:column;gap:2px}
.mini-opt{display:flex;align-items:center;justify-content:space-between;padding:.88rem 1rem;background:#f7f5f2;border:none;cursor:pointer;font-family:'Raleway',sans-serif;font-size:.92rem;font-weight:300;color:var(--navy);text-align:left;transition:background .18s;border-radius:7px}
.mini-opt svg{width:17px;height:17px;opacity:.25;flex-shrink:0;transition:all .18s}
.mini-opt:hover{background:#ede9e4}
.mini-opt:hover svg{opacity:.7;transform:translateX(3px)}
.mini-back{background:none;border:none;cursor:pointer;font-family:'Montserrat',sans-serif;font-size:10.5px;letter-spacing:.1em;color:rgba(9,10,57,.35);margin-top:1.1rem;padding:0;transition:color .2s;display:block}
.mini-back:hover{color:var(--navy)}
.mini-result-label{font-family:'Montserrat',sans-serif;font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--brown);margin-bottom:.5rem}
.mini-result-tags{font-size:1rem;font-family:'Raleway',sans-serif;font-weight:300;color:var(--navy);margin-bottom:.7rem;line-height:1.5}
.mini-result-desc{font-size:13px;line-height:1.7;color:rgba(9,10,57,.52);margin-bottom:1.2rem}
.mini-name{width:100%;padding:.65rem .85rem;border:.5px solid rgba(9,10,57,.14);background:#f7f5f2;font-family:'Open Sans',sans-serif;font-size:13.5px;color:var(--navy);outline:none;border-radius:7px;margin-bottom:.9rem}
.mini-name::placeholder{color:rgba(9,10,57,.3)}
.mini-name:focus{border-color:var(--navy)}
.mini-wa{display:flex;align-items:center;justify-content:center;gap:.6rem;width:100%;padding:.9rem;background:var(--wa);color:#fff;font-family:'Montserrat',sans-serif;font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;border-radius:7px;transition:opacity .2s;margin-bottom:.6rem}
.mini-wa:hover{opacity:.9}
.mini-note{font-size:11px;color:rgba(9,10,57,.32);text-align:center}

/* STATS */
#dip-strip{background:var(--nd);padding:2.5rem 2rem;display:flex;align-items:center;justify-content:center}
.stats-row{display:flex;align-items:stretch;justify-content:center;width:100%;max-width:700px}
.stat-block{flex:1;text-align:center;padding:1.2rem 1rem;border-right:.5px solid rgba(255,255,255,.08)}
.stat-block:last-child{border-right:none}
.stat-big{font-family:'Raleway',sans-serif;font-size:2.8rem;font-weight:200;color:#fff;display:block;line-height:1;margin-bottom:.35rem}
.stat-lbl{font-family:'Montserrat',sans-serif;font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:var(--sand);opacity:.65;display:block}

/* CÓMO TRABAJAMOS — sin pasos, solo header */
#como-trabajamos{background:var(--cream);padding:5rem 2rem}
.como-header{max-width:540px;margin:0 auto;text-align:center}
.como-tag{font-family:'Montserrat',sans-serif;font-size:9.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--brown);margin-bottom:.9rem}
.como-title{font-family:'Raleway',sans-serif;font-size:clamp(1.7rem,3.2vw,2.6rem);font-weight:200;line-height:1.15;color:var(--navy);margin-bottom:.9rem}
.como-title em{font-style:normal;color:var(--brown)}
.como-sub{font-size:14.5px;color:rgba(9,10,57,.5);line-height:1.75;margin-bottom:2rem}
.como-cta{display:inline-flex;align-items:center;gap:.6rem;background:var(--wa);color:#fff;font-family:'Montserrat',sans-serif;font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:.85rem 1.8rem;border-radius:6px;text-decoration:none;transition:opacity .2s}
.como-cta:hover{opacity:.88}

/* SEDES */
#sedes{background:var(--navy);padding:4rem 2rem}
#sedes .stit{color:var(--cream)}
#sedes .stag{color:var(--sand)}
#sedes .sdiv{background:rgba(203,192,182,.3)}
.sedes-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5px;margin-top:2rem}
.sede{background:rgba(255,255,253,.04);border:.5px solid rgba(255,255,253,.07);padding:1.8rem}
.sede-city{font-family:'Raleway',sans-serif;font-size:1.2rem;font-weight:300;color:var(--cream);margin-bottom:.3rem}
.sede-addr{font-size:13.5px;line-height:1.7;color:rgba(255,255,253,.45);margin-bottom:.4rem}
.sede-det{font-family:'Montserrat',sans-serif;font-size:9.5px;letter-spacing:.14em;color:var(--sand);opacity:.6}

/* CTA FINAL */
#contacto{background:var(--cream);padding:5rem 2rem;text-align:center}
.cta-eyebrow{font-family:'Montserrat',sans-serif;font-size:9.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--brown);margin-bottom:1rem}
.cta-title{font-family:'Raleway',sans-serif;font-size:clamp(1.8rem,3.5vw,3rem);font-weight:200;line-height:1.12;color:var(--navy);margin-bottom:.8rem}
.cta-sub{font-size:15px;color:rgba(9,10,57,.5);line-height:1.75;margin-bottom:2.2rem;max-width:420px;margin-left:auto;margin-right:auto}
.cta-wa-btn{display:inline-flex;align-items:center;gap:.7rem;background:var(--wa);color:#fff;font-family:'Montserrat',sans-serif;font-size:12px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;padding:1rem 2.2rem;border-radius:8px;text-decoration:none;transition:all .25s;box-shadow:0 4px 20px rgba(37,211,102,.25)}
.cta-wa-btn:hover{opacity:.9;transform:translateY(-2px);box-shadow:0 8px 28px rgba(37,211,102,.35)}
.cta-data{display:flex;align-items:center;justify-content:center;gap:2rem;margin-top:2.5rem;flex-wrap:wrap}
.cta-data-item{display:flex;align-items:center;gap:.5rem;font-size:13px;color:rgba(9,10,57,.45)}
.cta-data-item a{color:inherit;text-decoration:none;transition:color .2s}
.cta-data-item a:hover{color:var(--navy)}
.cta-divider{width:.5px;height:14px;background:rgba(9,10,57,.15)}

/* FOOTER */
footer{background:var(--nd);padding:1.8rem 2rem;border-top:.5px solid rgba(255,255,255,.05)}
.foot-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1.2rem;max-width:1100px;margin:0 auto}
.foot-logo img{height:26px;width:auto;opacity:.38}
.foot-links{display:flex;gap:1.5rem;list-style:none;flex-wrap:wrap}
.foot-links a{font-family:'Montserrat',sans-serif;font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.24);text-decoration:none;transition:color .2s}
.foot-links a:hover{color:rgba(255,255,255,.6)}
.foot-right{display:flex;align-items:center;gap:1rem}
.foot-ig{color:rgba(255,255,255,.3);text-decoration:none;display:flex;align-items:center;transition:color .2s}
.foot-ig:hover{color:rgba(255,255,255,.7)}
.foot-wa{display:flex;align-items:center;gap:.4rem;background:rgba(37,211,102,.15);color:rgba(255,255,255,.5);font-family:'Montserrat',sans-serif;font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;padding:.4rem .9rem;border-radius:20px;text-decoration:none;transition:all .2s}
.foot-wa:hover{background:rgba(37,211,102,.3);color:#fff}
.foot-copy{font-family:'Montserrat',sans-serif;font-size:9px;color:rgba(255,255,255,.18)}

/* WA FLOTANTE */
.wa-float{position:fixed;bottom:1.5rem;right:1.5rem;z-index:500;width:50px;height:50px;background:var(--wa);border-radius:50%;display:flex;align-items:center;justify-content:center;text-decoration:none;box-shadow:0 4px 20px rgba(37,211,102,.35);transition:transform .2s}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:24px;height:24px;fill:#fff}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.hero-logo{animation:fadeUp .5s ease both}
.hero-tag{animation:fadeUp .6s .1s ease both}
.hero-title{animation:fadeUp .65s .18s ease both}
.hero-desc{animation:fadeUp .65s .26s ease both}
.hero-actions{animation:fadeUp .65s .34s ease both}

/* RESPONSIVE */
@media(max-width:768px){
  nav{padding:0 1.2rem}
  .nav-links{display:none}
  .nav-burger{display:flex}
  #hero{grid-template-columns:1fr;min-height:auto}
  .hero-l{padding:3rem 1.5rem 2.5rem}
  .hero-logo img{height:52px}
  .hero-r{height:65vw}
  .hero-actions{max-width:100%}
  #servicios{grid-template-columns:1fr}
  .mini-left{padding:2.5rem 1.5rem 1rem}
  .mini-right{padding:0 1.2rem 2.5rem}
  .mini-card{max-width:100%}
  #resenas{padding:3rem 1.2rem}
  .res-header{align-items:flex-start}
  .res-score{justify-content:flex-start}
  .res-grid .res-card{text-align:left}
  .res-grid{grid-template-columns:1fr}
  .res-header{flex-direction:column;gap:1rem;align-items:flex-start;width:100%}
  .res-score{flex-direction:row;align-items:baseline}
  #resenas{overflow-x:hidden}
  #dip-strip{padding:2rem 1.2rem}
  .stats-row{flex-direction:column}
  .stat-block{border-right:none;border-bottom:.5px solid rgba(255,255,255,.08);padding:1rem}
  .stat-block:last-child{border-bottom:none}
  #como-trabajamos{padding:3.5rem 1.2rem}
  #sedes{padding:3rem 1.2rem}
  .sedes-grid{grid-template-columns:1fr}
  #contacto{padding:3.5rem 1.2rem}
  .cta-data{gap:1rem}
  .cta-divider{display:none}
  footer{padding:1.8rem 1.2rem}
  .foot-inner{flex-direction:column;align-items:flex-start;gap:1.2rem}
}

@media(max-width:768px){
  .hero-r img{object-position:center 30%}
  .hero-logo{max-width:260px}
  .hero-logo img{max-height:105px}
}

/* HERO LOGO */
.hero-logo,.hero-logo-big{width:340px!important;max-width:340px!important;margin-bottom:2.5rem;padding-bottom:2.2rem;border-bottom:.5px solid rgba(255,255,255,.1)}
.hero-logo img,.hero-logo-big img{width:100%!important;height:auto!important;display:block;object-fit:contain}

/* HERO PHOTO — cover, recorte bajo para mostrar manos */
.hero-r{overflow:hidden}
.hero-r img{width:100%!important;height:100%!important;object-fit:cover!important;object-position:center 12%!important;display:block}

@media(max-width:768px){
  .hero-logo,.hero-logo-big{width:220px!important;max-width:220px!important}
  .hero-r{min-height:660px!important}.hero-r img{width:100%;height:100%;object-fit:cover!important;object-position:center 8%!important}
}