/* ============================================================
   ORKESTRA — sistema "La Función de Gala"
   Página blanca, azul real de marca, rosa profundo de acción,
   y sombras/tintes azules. Hoja de estilos independiente:
   NO carga main.css (ese es el sistema oscuro archivado).
   ============================================================ */

:root{
  --sheet:#fdfdfe;
  --ink:#19223f;
  --body:#4a5168;       /* texto de cuerpo — ~7:1 sobre papel */
  --soft:#646b80;       /* texto chico secundario — 4.5:1+ */
  --blue:#2f4da6;       /* azul real de marca — texto 7.7:1 sobre papel */
  --blue-bright:#4a6fd4;/* gráficos, detalles */
  --blue-deep:#1c2b5e;  /* bandas drenched y footer */
  --pink:#d83a72;       /* acción (botones, con texto blanco) */
  --pink-deep:#b02458;  /* acción como texto — 6+:1 sobre papel */
  --wm:#cdd9f3;         /* marca de agua periwinkle */
  --line:#dfe6f5;
  --card:#ffffff;
  --tint:#f1f5fc;       /* escala tonal azul: tint → mid → deep */
  --tint-mid:#e4ebf9;
  --tint-deep:#cfdcf4;
  /* semánticos (estados) */
  --ok:#2e7d4f;
  --warn:#9c5d0a;
  --due:#b02458;
  --radius:16px;
  --maxw:1180px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body.v2{
  margin:0;
  background:var(--sheet);
  color:var(--ink);
  font-family:"Hanken Grotesk",system-ui,sans-serif;
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
::selection{background:var(--wm);color:var(--ink);}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}

h1,h2,h3{
  font-family:"Fraunces",Georgia,serif;
  font-weight:700;
  letter-spacing:-.015em;
  color:var(--ink);
  text-wrap:balance;
}
.lede,.hero-sub,.csub,.svc p,.prod p{text-wrap:pretty;}

/* salto al contenido (teclado / lector de pantalla) */
.skip{
  position:fixed;left:16px;top:-60px;z-index:60;
  background:var(--ink);color:var(--sheet);
  padding:10px 18px;border-radius:10px;font-weight:600;font-size:.92rem;
  transition:top .2s ease;
}
.skip:focus-visible{top:14px;}
section{padding:88px 0;}
#puerta{padding-top:0;}
/* ritmo de color: banda tintada → blanco con tiles → banda más profunda → CTA drenched → footer */
#hacemos{background:var(--tint);padding:76px 0;}
#metodo{padding:84px 0;}
#productos{background:linear-gradient(180deg,var(--tint-mid),var(--tint-deep));padding:76px 0;}

.sec-title{font-size:clamp(1.9rem,3.6vw,2.7rem);line-height:1.12;margin:0 0 16px;max-width:24ch;}
.lede{color:var(--body);font-size:1.1rem;max-width:60ch;margin:0;}

/* ---------------- LA HOJA (full-bleed) ---------------- */
.sheet{position:relative;}

/* ---------------- NAV ---------------- */
header.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(253,253,254,0);
  border-bottom:1px solid transparent;
  transition:background .3s ease,border-color .3s ease,box-shadow .3s ease;
}
header.nav.scrolled{
  background:rgba(253,253,254,.94);
  border-bottom:1px solid var(--line);
  box-shadow:0 10px 30px -18px rgba(28,43,94,.2);
}
header.nav.menu-open{background:var(--sheet);border-bottom:1px solid var(--line);}
.nav-row{display:flex;align-items:center;justify-content:space-between;height:78px;gap:18px;position:relative;z-index:50;}
.brand{
  font-family:"Hanken Grotesk",sans-serif;font-weight:800;
  font-size:1.22rem;letter-spacing:.04em;color:var(--ink);
  display:flex;align-items:center;gap:9px;
}
.brand .baton{
  width:11px;height:11px;border-radius:50%;flex:none;
  background:radial-gradient(circle at 35% 30%,#f06a9b,var(--pink) 60%);
}
.nav-links{display:flex;align-items:center;gap:34px;}
.nav-links a.link{font-size:.95rem;font-weight:500;color:var(--ink);transition:color .2s;}
.nav-links a.link:hover{color:var(--pink-deep);}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:"Hanken Grotesk",sans-serif;font-weight:700;font-size:.95rem;
  padding:12px 24px;border-radius:12px;border:1px solid var(--pink);
  color:#fff;background:var(--pink);
  transition:transform .18s ease,background .2s ease,box-shadow .2s ease,border-color .2s ease;
  cursor:pointer;
}
.btn:hover{background:var(--pink-deep);border-color:var(--pink-deep);transform:translateY(-1px);box-shadow:0 10px 26px -10px rgba(176,36,88,.5);}
.btn:active{transform:translateY(0);box-shadow:0 4px 12px -6px rgba(176,36,88,.45);}
.btn:focus-visible,a:focus-visible,button:focus-visible{outline:2px solid var(--pink-deep);outline-offset:3px;border-radius:6px;}
.btn.ghost{background:transparent;border-color:var(--ink);color:var(--ink);}
.btn.ghost:hover{background:var(--ink);color:var(--sheet);box-shadow:none;}
.btn.lg{padding:15px 30px;font-size:1.02rem;}

/* mobile menu */
.menu-btn{
  display:none;background:none;border:0;cursor:pointer;padding:10px;margin:-10px;
  flex-direction:column;gap:5px;
}
.menu-btn span{display:block;width:22px;height:2px;background:var(--ink);transition:transform .25s ease,opacity .25s ease;}
.menu-open .menu-btn span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.menu-open .menu-btn span:nth-child(2){opacity:0;}
.menu-open .menu-btn span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
.nav-drawer{
  display:none;
  position:fixed;top:0;bottom:0;left:0;right:0;z-index:49;
  background:var(--sheet);
  padding:calc(78px + 26px) 28px 34px;overflow-y:auto;
  flex-direction:column;gap:6px;
}
.nav-drawer.open{display:flex;}
.nav-drawer a{
  font-family:"Fraunces",Georgia,serif;font-weight:600;font-size:1.8rem;color:var(--ink);
  padding:12px 0;border-bottom:1px solid var(--line);
}
.nav-drawer a:hover{color:var(--pink-deep);}
.nav-drawer a.btn{margin-top:22px;font-family:"Hanken Grotesk",sans-serif;font-size:1.05rem;border-bottom:0;color:#fff;}
@media(max-width:840px){
  .nav-links{display:none;}
  .menu-btn{display:flex;}
}

/* ---------------- HERO ---------------- */
.v2-hero{
  position:relative;overflow:hidden;padding:64px 0 90px;
  /* lavado azul: fuerte arriba, se funde a blanco antes de la card */
  background:
    radial-gradient(1100px 640px at 72% 8%, rgba(157,180,229,.45), transparent 70%),
    linear-gradient(180deg, var(--tint) 0%, rgba(241,245,252,.35) 60%, rgba(241,245,252,0) 100%);
  margin-top:-78px;padding-top:calc(64px + 78px); /* el lavado pasa por detrás del nav transparente */
}
.v2-wm{
  position:absolute;left:50%;top:42%;transform:translate(-50%,-50%);
  font-family:"Fraunces",Georgia,serif;font-weight:800;
  font-size:clamp(6rem,20vw,17.5rem);
  line-height:.9;white-space:nowrap;
  color:var(--wm);
  letter-spacing:-.01em;
  pointer-events:none;user-select:none;
}
.v2-hero-grid{
  position:relative;
  display:grid;grid-template-columns:1.06fr .94fr;
  gap:24px;align-items:center;
}
.hero-title{
  font-size:clamp(2.5rem,4.9vw,4.2rem);
  font-weight:800;
  line-height:1.06;
  margin:0 0 22px;
  max-width:15ch;
}
.hero-title em{font-style:italic;color:var(--pink-deep);}
.hero-sub{color:var(--body);font-size:clamp(1.02rem,1.4vw,1.16rem);max-width:46ch;margin:0 0 32px;}
.hero-ctas{display:flex;flex-wrap:wrap;gap:14px;align-items:center;}

.v2-robot{position:relative;display:flex;justify-content:center;}
.v2-robot::before{
  content:"";position:absolute;left:50%;top:55%;transform:translate(-50%,-50%);
  width:120%;aspect-ratio:1;
  background:radial-gradient(circle,rgba(74,111,212,.3),transparent 62%);
  pointer-events:none;
}
.v2-robot img{
  position:relative;
  width:min(100%,540px);height:auto;
  filter:drop-shadow(0 36px 50px rgba(28,43,94,.3));
  animation:v2-float 7s ease-in-out infinite;
}
@keyframes v2-float{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(-12px);}
}
@media(max-width:880px){
  .v2-hero{padding:40px 0 64px;}
  .v2-hero-grid{grid-template-columns:1fr;gap:6px;}
  .v2-robot{order:-1;margin-bottom:4px;}
  .v2-robot img{width:min(62vw,310px);}
  .v2-wm{top:26%;font-size:clamp(3.2rem,16.5vw,5.5rem);} /* entra completo: nada de fragmentos cortados */
}

/* ---------------- PUERTA ---------------- */
#puerta{overflow:clip;}
.puerta-card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:22px;
  box-shadow:0 40px 80px -45px rgba(28,43,94,.3);
  padding:clamp(28px,5vw,64px);
}
.puerta-grid{
  display:grid;grid-template-columns:.95fr 1.05fr;
  gap:clamp(30px,5vw,60px);align-items:center;
}
.puerta-grid > *{min-width:0;}
@media(max-width:880px){.puerta-grid{grid-template-columns:1fr;gap:36px;}}
.puerta-copy .sec-title{max-width:17ch;}
.puerta-copy .lede{margin-bottom:22px;}

.check{list-style:none;margin:0;padding:0;}
.check li{position:relative;padding:0 0 0 28px;margin-bottom:13px;color:var(--body);font-size:1rem;}
.check li:last-child{margin-bottom:0;}
.check li::before{
  content:"";position:absolute;left:2px;top:.5em;width:10px;height:10px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#f06a9b,var(--pink));
}
.check li strong{color:var(--ink);font-weight:700;}

/* halo punteado */
.halo{position:relative;}
.halo::before{
  content:"";position:absolute;inset:-10% -8%;
  background-image:radial-gradient(rgba(74,111,212,.45) 1.3px,transparent 1.5px);
  background-size:17px 17px;
  -webkit-mask-image:radial-gradient(ellipse 62% 58% at center,#000 28%,transparent 72%);
  mask-image:radial-gradient(ellipse 62% 58% at center,#000 28%,transparent 72%);
  pointer-events:none;
}

/* mock window: la maquinaria — chrome azul profundo */
.mockwin{
  position:relative;
  background:#fff;border:1px solid var(--line);border-radius:16px;
  box-shadow:0 30px 60px -30px rgba(28,43,94,.35);
  overflow:hidden;
}
.mw-bar{display:flex;align-items:center;gap:6px;padding:11px 14px;background:var(--blue-deep);}
.mw-bar i{width:9px;height:9px;border-radius:50%;background:rgba(241,245,252,.25);display:block;}
.mw-bar i:first-child{background:var(--pink);}
.mw-bar i:nth-child(2){background:#9db4e0;}
.mw-bar .mw-ttl{margin-left:8px;font-size:.66rem;font-weight:700;letter-spacing:.08em;color:#c8d4f0;text-transform:uppercase;}
.mw-body{display:flex;min-height:280px;}
.mw-side{width:120px;border-right:1px solid var(--line);padding:16px 12px;background:var(--tint);}
.mw-side span{display:block;height:8px;border-radius:4px;background:var(--tint-deep);margin-bottom:12px;}
.mw-side span:first-child{background:var(--blue-bright);width:70%;}
.mw-main{flex:1;padding:18px;}
.mw-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:16px;}
.mw-stat{border:1px solid var(--line);border-radius:10px;padding:12px;}
.mw-stat b{display:block;font-size:1.15rem;color:var(--ink);font-family:"Fraunces",serif;font-weight:700;}
.mw-stat span{font-size:.6rem;font-weight:700;letter-spacing:.06em;color:var(--soft);text-transform:uppercase;}
.mw-bars{display:flex;align-items:flex-end;gap:8px;height:90px;border:1px solid var(--line);border-radius:10px;padding:12px;}
.mw-bars i{flex:1;display:block;background:linear-gradient(180deg,var(--blue-bright),var(--blue));border-radius:4px 4px 0 0;}
.mw-rows .row{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid var(--line);border-radius:10px;padding:11px 13px;margin-top:9px;}
.mw-rows .row span{height:8px;border-radius:4px;background:var(--tint-mid);flex:1;max-width:46%;display:block;}
.chip{font-size:.6rem;font-weight:700;letter-spacing:.05em;border-radius:100px;padding:3px 10px;text-transform:uppercase;font-style:normal;}
.chip.ok{background:rgba(46,125,79,.12);color:var(--ok);}
.chip.warn{background:rgba(214,158,32,.16);color:var(--warn);}
.chip.due{background:rgba(216,58,114,.12);color:var(--due);}
@media(max-width:480px){
  .mw-side{display:none;}
  .mw-stat b{font-size:1rem;}
}

/* ---------------- SERVICIOS ---------------- */
.services{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:50px;}
@media(max-width:760px){.services{grid-template-columns:1fr;}}
.svc{
  background:var(--card);border:1px solid var(--line);border-radius:18px;
  padding:34px 32px;display:block;
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
}
.svc:hover{transform:translateY(-3px);box-shadow:0 24px 50px -28px rgba(28,43,94,.35);border-color:#c9d7f3;}
.svc .idx{
  display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:10px;
  background:rgba(47,77,166,.12);color:var(--blue);
  font-family:"Fraunces",serif;font-weight:700;font-size:.95rem;
}
.svc h3{font-size:1.45rem;margin:16px 0 10px;}
.svc p{color:var(--body);margin:0;font-size:1rem;}
.svc .tags{margin-top:18px;display:flex;flex-wrap:wrap;gap:7px;}
.svc .tag{font-size:.74rem;font-weight:600;color:var(--blue);background:var(--tint);border:1px solid var(--line);border-radius:100px;padding:3px 11px;}
.svc .more{margin-top:20px;display:inline-flex;align-items:center;gap:7px;font-weight:700;font-size:.92rem;color:var(--pink-deep);transition:gap .2s ease;}
.svc:hover .more{gap:11px;}

/* ---------------- MÉTODO ---------------- */
.method-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:50px;}
@media(max-width:880px){.method-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:520px){.method-grid{grid-template-columns:1fr;}}
.mv{background:linear-gradient(180deg,var(--tint),var(--tint-mid));border-radius:18px;padding:30px 26px;}
.mv .num{font-family:"Fraunces",serif;font-weight:700;font-size:2.1rem;color:var(--pink-deep);line-height:1;}
.mv h3{font-size:1.3rem;margin:14px 0 8px;}
.mv p{color:var(--body);margin:0;font-size:.96rem;}

/* ---------------- PRODUCTOS ---------------- */
.prod-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:50px;}
@media(max-width:760px){.prod-grid{grid-template-columns:1fr;}}
.prod{
  background:var(--card);border:1px solid var(--line);border-radius:18px;padding:34px 32px;
  transition:transform .2s ease,box-shadow .2s ease;display:block;
}
.prod:hover{transform:translateY(-3px);box-shadow:0 24px 50px -28px rgba(28,43,94,.35);}
.prod .ptag{
  display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:var(--pink-deep);background:rgba(216,58,114,.12);border-radius:100px;padding:4px 12px;
}
.prod .ptag.cool{color:#fff;background:var(--blue);} /* GestioBox: el producto-sistema lleva el azul */
.prod h3{font-size:1.7rem;margin:14px 0 10px;}
.prod p{color:var(--body);margin:0 0 18px;font-size:1rem;}
.prod .more{font-weight:700;font-size:.92rem;color:var(--ink);display:inline-flex;align-items:center;gap:7px;border-bottom:2px solid var(--pink);padding-bottom:2px;}
.prod .more:hover{color:var(--pink-deep);}

/* ---------------- CTA BAND (drenched azul, como la referencia) ---------------- */
.cta-band{
  text-align:center;position:relative;overflow:hidden;
  background:
    radial-gradient(700px 380px at 50% -30%, rgba(74,111,212,.55), transparent 70%),
    linear-gradient(180deg,var(--blue),var(--blue-deep));
  border-radius:22px;
  margin:72px clamp(14px,3vw,56px) 56px;
  padding:clamp(60px,8vw,96px) 24px;
}
.cta-band .thesis{
  font-family:"Fraunces",Georgia,serif;font-weight:800;
  font-size:clamp(1.9rem,4.2vw,3.3rem);line-height:1.12;margin:0 auto 14px;max-width:20ch;
  letter-spacing:-.015em;text-wrap:balance;color:#fff;
}
.cta-band .thesis em{font-style:italic;color:#f8a8c6;}
.cta-band .csub{color:#d4def5;max-width:52ch;margin:0 auto 36px;font-size:1.08rem;}
.cta-band .hero-ctas{justify-content:center;}
.cta-band .btn.ghost{border-color:#fff;color:#fff;}
.cta-band .btn.ghost:hover{background:#fff;color:var(--blue-deep);}
.cta-band .btn:focus-visible,.cta-band a:focus-visible{outline-color:#f8a8c6;}

/* ---------------- FOOTER (el cierre profundo) ---------------- */
footer{background:var(--blue-deep);padding:56px 0 44px;}
footer .brand{color:var(--tint);}
.foot-row{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;align-items:flex-start;}
.foot-brand{max-width:34ch;}
.foot-brand .brand{margin-bottom:14px;}
.foot-brand p{color:#aebbdf;font-size:.95rem;margin:0;}
.foot-col h4{font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#8fa1cf;margin:0 0 14px;}
.foot-col a{display:block;color:#cfd9f2;font-size:.95rem;margin-bottom:9px;transition:color .2s;}
.foot-col a:hover{color:#f8a8c6;}
.foot-bottom{margin-top:42px;padding-top:22px;border-top:1px solid rgba(241,245,252,.16);display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;color:#8fa1cf;font-size:.85rem;}
footer a:focus-visible{outline-color:#f8a8c6;}

/* ---------------- REVEAL ----------------
   gated por html.js: sin JavaScript el contenido es visible por defecto */
html.js .reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s ease;}
html.js .reveal.in{opacity:1;transform:none;}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important;transition:none!important;}
  .reveal{opacity:1;transform:none;}
}

/* ---------------- PÁGINAS INTERNAS ---------------- */
.page-hero{
  position:relative;overflow:hidden;
  margin-top:-78px;padding:calc(56px + 78px) 0 64px;
  background:
    radial-gradient(900px 520px at 75% 0%, rgba(157,180,229,.4), transparent 70%),
    linear-gradient(180deg, var(--tint) 0%, rgba(241,245,252,.3) 60%, rgba(241,245,252,0) 100%);
}
.page-hero h1{
  font-size:clamp(2.3rem,4.4vw,3.6rem);font-weight:800;line-height:1.08;
  margin:0 0 18px;max-width:18ch;
}
.page-hero h1 em{font-style:italic;color:var(--pink-deep);}
.page-hero .lede{font-size:clamp(1.02rem,1.4vw,1.16rem);max-width:56ch;}

/* nav: página activa */
.nav-links a.link.active{color:var(--ink);font-weight:700;position:relative;}
.nav-links a.link.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-7px;height:3px;
  background:var(--pink);border-radius:2px;
}
.nav-drawer a.active{color:var(--pink-deep);}

/* detalle de servicio: bandas alternadas (La Regla de la Marea) */
.svc-band{padding:76px 0;overflow:clip;}
.svc-band.tinted{background:linear-gradient(180deg,var(--tint),var(--tint-mid));}
.svc-detail{
  display:grid;grid-template-columns:1.08fr .92fr;
  gap:clamp(30px,5vw,60px);align-items:start;
}
.svc-detail > *{min-width:0;}
@media(max-width:860px){.svc-detail{grid-template-columns:1fr;gap:32px;}}
.svc-kicker{display:flex;align-items:center;gap:12px;margin-bottom:18px;}
.svc-kicker .knum{
  display:inline-flex;align-items:center;justify-content:center;flex:none;
  width:34px;height:34px;border-radius:10px;
  background:rgba(47,77,166,.12);color:var(--blue);
  font-family:"Fraunces",serif;font-weight:700;font-size:.95rem;
}
.svc-kicker .kname{
  font-weight:700;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;
  color:var(--blue);
}
.svc-detail h2{font-size:clamp(1.8rem,3.2vw,2.5rem);line-height:1.12;margin:0 0 14px;max-width:18ch;}
.svc-detail .body p{color:var(--body);margin:0 0 14px;text-wrap:pretty;}
.svc-detail .body p:last-child{margin-bottom:0;}
.svc-cta{margin-top:26px;}

/* panel lateral técnico: superficie azul clara (la maquinaria) */
.panel{background:linear-gradient(180deg,var(--tint),var(--tint-mid));border-radius:18px;padding:30px 28px;}
.svc-band.tinted .panel{background:var(--card);border:1px solid var(--line);}
.panel h4{
  font-family:"Hanken Grotesk",sans-serif;font-weight:700;font-size:.72rem;
  letter-spacing:.08em;text-transform:uppercase;color:var(--blue);margin:0 0 16px;
}
.panel .check li::before{background:radial-gradient(circle at 35% 30%,#8aa6e2,var(--blue-bright));}

/* ---------------- PRODUCTOS ---------------- */
.prod-feature{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(30px,5vw,56px);align-items:center;}
.prod-feature > *{min-width:0;}
.prod-feature.flip .prod-copy{order:2;}
.prod-feature.flip .prod-visual{order:1;}
@media(max-width:880px){
  .prod-feature,.prod-feature.flip{grid-template-columns:1fr;gap:34px;}
  .prod-feature.flip .prod-copy{order:1;}
  .prod-feature.flip .prod-visual{order:2;}
}
.prod-copy h2{font-size:clamp(2rem,3.8vw,3rem);margin:12px 0 14px;}
.prod-copy > p{color:var(--body);margin:0 0 18px;text-wrap:pretty;}
.ptag{
  display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:var(--pink-deep);background:rgba(216,58,114,.12);border-radius:100px;padding:4px 12px;
}
.ptag.cool{color:#fff;background:var(--blue);}
.centered{text-align:center;}
.centered .sec-title,.centered .lede{margin-left:auto;margin-right:auto;}
.centered .hero-ctas{justify-content:center;}

/* ---------------- NOSOTROS ---------------- */
.vision-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(30px,5vw,54px);align-items:start;}
@media(max-width:820px){.vision-grid{grid-template-columns:1fr;gap:24px;}}
.lede-big{
  font-family:"Fraunces",Georgia,serif;font-weight:600;
  font-size:clamp(1.35rem,2.4vw,1.75rem);line-height:1.3;
  color:var(--ink);max-width:26ch;margin:0;text-wrap:balance;
}
.vision-body p{color:var(--body);margin:0 0 16px;text-wrap:pretty;}
.vision-body p:last-child{margin-bottom:0;}
.mv ul{margin:14px 0 0;padding:0;list-style:none;}
.mv ul li{position:relative;padding-left:18px;color:var(--body);font-size:.9rem;margin-bottom:8px;}
.mv ul li::before{content:"";position:absolute;left:0;top:.55em;width:6px;height:6px;border-radius:50%;background:var(--blue-bright);}
.tinted .mv{background:#fff;border:1px solid var(--line);}
.principles{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:50px;}
@media(max-width:760px){.principles{grid-template-columns:1fr;}}
.principle{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:30px 28px;}
.principle h3{font-size:1.5rem;margin:0 0 10px;}
.principle h3 em{font-style:italic;color:var(--pink-deep);}
.principle p{color:var(--body);margin:0;font-size:.99rem;}

/* ---------------- CONTACTO ---------------- */
.page-hero.compact{padding-bottom:30px;}
.pt-tight{padding-top:40px;}
.contact-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,54px);align-items:start;}
.contact-grid > *{min-width:0;}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr;gap:34px;}}
.field{margin-bottom:22px;}
.field label{display:block;font-weight:600;font-size:.88rem;color:var(--ink);margin-bottom:8px;}
.field input,.field textarea{
  width:100%;background:#fff;border:1px solid var(--line);border-radius:12px;
  color:var(--ink);font-family:"Hanken Grotesk",sans-serif;font-size:1rem;
  padding:14px 16px;transition:border-color .2s ease,box-shadow .2s ease;
}
.field input::placeholder,.field textarea::placeholder{color:var(--soft);}
.field input:focus,.field textarea:focus{border-color:var(--blue);outline:none;box-shadow:0 0 0 3px rgba(47,77,166,.14);}
.field textarea{min-height:130px;resize:vertical;}
.form-note{color:var(--soft);font-size:.86rem;margin-top:14px;}
.contact-aside .panel{margin-bottom:22px;}
.contact-direct a{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  background:var(--card);border:1px solid var(--line);border-radius:14px;padding:17px 19px;margin-bottom:13px;
  transition:border-color .2s ease,box-shadow .2s ease;
}
.contact-direct a:hover{border-color:var(--blue);box-shadow:0 12px 30px -18px rgba(28,43,94,.3);}
.contact-direct .lbl{font-weight:700;}
.contact-direct .val{font-size:.88rem;color:var(--blue);font-weight:600;}

/* pasos: círculos numerados como la referencia (rosa, azul claro, azul) */
.steps{counter-reset:step;list-style:none;margin:56px 0 0;padding:0;display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
@media(max-width:760px){.steps{grid-template-columns:1fr;}}
.steps li{counter-increment:step;background:linear-gradient(180deg,var(--tint),var(--tint-mid));border-radius:18px;padding:28px 26px;}
.steps li::before{
  content:counter(step);
  display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:50%;
  color:#fff;font-family:"Fraunces",serif;font-weight:700;font-size:1rem;
  margin-bottom:14px;
}
.steps li:nth-child(1)::before{background:var(--pink);}
.steps li:nth-child(2)::before{background:var(--blue-bright);}
.steps li:nth-child(3)::before{background:var(--blue);}
.steps li strong{display:block;font-size:1.08rem;margin-bottom:7px;color:var(--ink);}
.steps li span{color:var(--body);font-size:.95rem;}
.mw-stats.two{grid-template-columns:repeat(2,minmax(0,1fr));}
