@charset "utf-8";

:root{
  --y:#FDDA24;
  --n:#002147;
  --s:#46B1E1;
  --w:#fff;
  --ink:#4a5468;
  --line:#e7eaf0;
  --bg:#f4f7fb;
  --blk:#0a0a0a;
  --t:cubic-bezier(.22,1,.36,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:"Carlito",Calibri,system-ui,-apple-system,"Segoe UI",sans-serif;
  color:var(--n);background:var(--w);
  font-size:17px;line-height:1.65;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a,button,[role="button"],input,textarea,select,label{cursor:pointer}
a{color:inherit;text-decoration:none}
img,svg{max-width:100%;display:block}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:0;padding:0}
:focus-visible{outline:2px solid var(--s);outline-offset:3px;border-radius:4px}
body.no-scroll{overflow:hidden}
.lang-es .en,.lang-en .es{display:none}


/* ── nav ── */
nav#nav{
  position:fixed;inset:0 0 auto 0;height:72px;z-index:300;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 2.4rem;
  background:var(--w);
  transition:box-shadow .25s;
}
nav#nav.solid{box-shadow:0 4px 24px -4px rgba(0,33,71,.14)}

/* logo directo — el propio nav blanco es el fondo que exige el manual */
.nav-logo{display:inline-flex;align-items:center;line-height:0;transition:opacity .2s}
.nav-logo:hover{opacity:.82}
.nav-logo img{height:46px;width:auto}

.nav-links{display:flex;gap:1.4rem;list-style:none;align-items:center;margin:0;padding:0}
.nav-links a{
  font-family:"Manrope",sans-serif;font-size:.84rem;font-weight:600;
  letter-spacing:.04em;color:rgba(0,33,71,.7);
  transition:color .2s;position:relative;
}
.nav-links a:not(.nav-cta){
  padding:.28rem .6rem;
}
.nav-links a:not(.nav-cta)::after{
  content:"";position:absolute;inset:0;
  background:rgba(253,218,36,.18);
  clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,8px 100%,0 calc(100% - 8px));
  opacity:0;transform:scaleX(.6);transform-origin:left center;
  transition:opacity .22s var(--t),transform .25s var(--t);
  z-index:-1;
}
.nav-links a:not(.nav-cta):hover::after{opacity:1;transform:scaleX(1)}
.nav-links a:hover{color:var(--n)}
.nav-cta{
  background:var(--n);color:var(--w) !important;
  padding:.55rem 1.6rem .55rem 1.3rem;
  border-radius:0;
  clip-path:polygon(0 0,calc(100% - 14px) 0,100% 14px,100% 100%,0 100%);
  font-weight:800 !important;
  transition:background .2s,transform .2s;
}
.nav-cta:hover{background:var(--y) !important;color:var(--n) !important;transform:translateY(-2px)}
.nav-toggle{display:none;padding:.4rem}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--n);margin:5px 0;transition:.3s}
.lang-switch{display:inline-flex;align-items:stretch;margin-left:.8rem;list-style:none;
  background:rgba(0,33,71,.06);clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,0 100%);
}
.lang-btn{
  font-family:"Manrope",sans-serif;font-size:.68rem;font-weight:800;
  letter-spacing:.12em;padding:.32rem .7rem;
  border:none;background:transparent;
  color:rgba(0,33,71,.38);transition:color .2s,background .2s;
}
.lang-btn:hover{color:var(--n);background:rgba(0,33,71,.06)}
.lang-btn[aria-pressed="true"]{
  background:var(--y);color:var(--n);
  clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,0 100%);
}

/* ── btn ── */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  padding:.95rem 2rem;border-radius:999px;
  font-family:"Manrope",sans-serif;font-size:.9rem;font-weight:700;
  letter-spacing:.01em;
  transition:transform .25s var(--t),background .25s,color .25s,box-shadow .25s,border-color .25s;
}
.btn-w{background:var(--w);color:var(--n)}
.btn-w:hover{background:var(--y);transform:translateY(-2px);box-shadow:0 12px 28px -8px rgba(253,218,36,.55)}
.btn-ow{background:transparent;color:rgba(255,255,255,.85);border:1.5px solid rgba(255,255,255,.4)}
.btn-ow:hover{border-color:var(--y);color:var(--y)}
.btn-n{background:var(--n);color:var(--w)}
.btn-n:hover{background:var(--s);transform:translateY(-2px)}
.btn-y{background:var(--y);color:var(--n)}
.btn-y:hover{background:var(--n);color:var(--y);transform:translateY(-2px)}
.btn-full{width:100%;justify-content:center}
.btn-arrow::after{content:"→";transition:transform .25s var(--t)}
.btn-arrow:hover::after{transform:translateX(5px)}

/* ── reveal ── */
.reveal,.reveal-l,.reveal-r{opacity:0;transition:opacity .85s var(--t),transform .85s var(--t)}
.reveal{transform:translateY(28px)}
.reveal-l{transform:translateX(-40px)}
.reveal-r{transform:translateX(40px)}
.reveal.in,.reveal-l.in,.reveal-r.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .reveal,.reveal-l,.reveal-r{opacity:1;transform:none;transition:none}
  *,*::before,*::after{animation:none !important;transition:none !important}
}

/* ── hero ── */
.hero{
  position:relative;height:100vh;min-height:640px;overflow:hidden;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding-top:72px;padding-bottom:0;
}
.hero-bg{
  position:absolute;inset:0;
  background:#0c1a2e url("https://images.unsplash.com/photo-1529156069898-49953e39b3ac?w=1920&q=85&auto=format&fit=crop") center 40% / cover no-repeat;
  animation:heroZ 14s ease-out forwards;
}
@keyframes heroZ{from{transform:scale(1.07)}to{transform:scale(1)}}
.hero-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,5,20,.9) 0%,rgba(0,5,20,.45) 50%,rgba(0,5,20,.1) 100%)}
.hero-shape1{position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(253,218,36,.18) 0%,transparent 70%);top:-150px;right:-100px;pointer-events:none;animation:floatA 10s ease-in-out infinite}
.hero-shape2{position:absolute;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(70,177,225,.14) 0%,transparent 70%);bottom:10%;left:-80px;pointer-events:none;animation:floatB 13s ease-in-out infinite}
.hero-shape3{position:absolute;right:8%;top:30%;width:5px;height:200px;background:linear-gradient(to bottom,transparent,var(--y),transparent);opacity:.5;animation:floatC 6s ease-in-out infinite}
@keyframes floatA{0%,100%{transform:translate(0,0)}50%{transform:translate(-24px,18px)}}
@keyframes floatB{0%,100%{transform:translate(0,0)}50%{transform:translate(18px,-20px)}}
@keyframes floatC{0%,100%{opacity:.5;transform:scaleY(1)}50%{opacity:.25;transform:scaleY(.7)}}
.hero-inner{position:relative;z-index:1;padding:0 2.8rem 3rem;max-width:1320px;width:100%;margin:0 auto;animation:heroReveal .9s 1.1s cubic-bezier(.22,1,.36,1) both}
.hero-pill{display:none}
.hero h1{
  font-family:"Manrope",sans-serif;
  font-size:clamp(3rem,7.5vw,7rem);
  font-weight:900;line-height:.93;letter-spacing:-.045em;color:var(--w);
}
.hero h1 .pre{display:block;font-weight:300;font-size:.42em;letter-spacing:-.01em;color:rgba(255,255,255,.55);margin-bottom:.4em}
.rotator{display:block;position:relative;overflow:hidden;height:1.06em}
.rword{position:absolute;left:0;top:0;opacity:0;transform:translateY(105%);transition:opacity .65s var(--t),transform .65s var(--t);color:var(--y)}
.rword.active{opacity:1;transform:translateY(0)}
.rword.out{opacity:0;transform:translateY(-105%)}
.hero-bottom{margin-top:2.5rem;display:flex;align-items:flex-end;justify-content:space-between;gap:2rem;flex-wrap:wrap;padding-top:2rem;border-top:1px solid rgba(255,255,255,.18)}
.hero-sub{font-size:1.08rem;color:rgba(255,255,255,.75);max-width:480px;line-height:1.75}
.hero-btns{display:flex;gap:.9rem;flex-wrap:wrap}
.scroll-hint{position:absolute;bottom:4rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.4rem;z-index:1;color:rgba(255,255,255,.35);font-family:"Manrope",sans-serif;font-size:.62rem;letter-spacing:.15em;text-transform:uppercase}
.scroll-hint i{display:block;width:1px;height:36px;background:linear-gradient(to bottom,rgba(255,255,255,.4),transparent);animation:scrollLine 2s ease-in-out infinite}
@keyframes scrollLine{0%,100%{opacity:.35}50%{opacity:.1}}

/* ── stag ── */
.stag{display:block;font-family:"Manrope",sans-serif;font-size:.72rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--s);margin-bottom:1.2rem}

/* ── about ── */
.about{background:var(--w);padding:0}
.about-grid{display:block;max-width:1100px;margin:0 auto;padding:0 3.5rem}
.about-text{background:var(--w);padding:7rem 0 0;display:flex;flex-direction:column}
.about-text>.stag{margin-bottom:1.4rem}
.about-text h2{font-family:"Manrope",sans-serif;font-size:clamp(2.6rem,5vw,4.2rem);font-weight:900;letter-spacing:-.05em;line-height:1.0;margin-bottom:2.8rem;max-width:820px}
.about-text h2 mark{background:none;color:inherit;padding:0;position:relative;font-style:italic}
.about-text h2 mark::after{content:'';position:absolute;bottom:.06em;left:0;right:0;height:4px;background:var(--y);border-radius:2px}
.about-text h2 em{font-style:normal;color:var(--s)}
.about-body{display:block;margin-bottom:0}
.about-copy{display:flex;flex-direction:column;gap:1.2rem;max-width:760px}
.about-text p{color:#3d4f66;font-size:1.08rem;line-height:1.85;margin-bottom:0}

/* ── blockquote ── */
.bq{
  border:none;border-left:4px solid var(--y);background:transparent;
  padding:0.6rem 0 0.6rem 1.8rem;margin:3.2rem 0 0;
  font-style:normal;font-family:"Manrope",sans-serif;font-weight:800;
  font-size:clamp(1.15rem,2vw,1.45rem);color:var(--n);line-height:1.48;
  letter-spacing:-.03em;
}
.bq::before{content:none}
.bq::after{content:none}

/* ── MVV — tres columnas limpias ── */
.mvv-3col{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  margin-top:4.5rem;padding:0;background:transparent;
  border-top:1px solid rgba(0,33,71,.1);border-radius:0;
  margin-left:0;margin-right:0;overflow:visible;box-shadow:none;
}
.mvv-col{
  padding:3rem 3rem 3.5rem 3rem;position:relative;overflow:hidden;
  border-left:none;border-right:none;border-radius:0;box-shadow:none;
  background:transparent;transition:background .35s;
}
.mvv-col:not(:first-child){
  padding-left:3rem;border-left:1px solid rgba(0,33,71,.1);
}
.mvv-col::before{
  content:'';position:absolute;inset:0;background:var(--n);z-index:0;
  clip-path:circle(0% at 2.2rem 4rem);
  transition:clip-path .7s cubic-bezier(.4,0,.15,1);
}
.mvv-col:hover::before{clip-path:circle(180% at 2.2rem 4rem)}
.mvv-num{display:none}
.mvv-accent{
  position:relative;top:auto;left:auto;inset:auto;
  width:2.8rem;height:3px;border-radius:2px;
  background:var(--y);margin-bottom:1.8rem;
  transform:none;transition:width .4s var(--t);z-index:1;
}
.mvv-col:hover .mvv-accent{width:100%}
.mvv-accent-s{background:var(--s)}
.mvv-accent-n{background:var(--n)}
.mvv-col:hover .mvv-accent-n{background:rgba(255,255,255,.6)}
.mvv-title{
  font-family:"Manrope",sans-serif;font-size:clamp(1.4rem,2.2vw,1.75rem);
  font-weight:900;color:var(--n);letter-spacing:-.03em;margin-bottom:.8rem;
  position:relative;z-index:1;transition:color .28s .05s;
}
.mvv-col:hover .mvv-title{color:var(--w)}
.mvv-col p{
  font-size:.92rem;color:#4a5e78;line-height:1.78;
  position:relative;z-index:1;transition:color .28s .05s;margin-bottom:0;
}
.mvv-col:hover p{color:rgba(255,255,255,.72)}

/* ── midbanner ── */
.midbanner{position:relative;height:400px;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#10243f}
.mb-bg{position:absolute;inset:0;background:url("https://images.unsplash.com/photo-1464366400600-7168b8af9bc3?w=1600&q=85&auto=format&fit=crop") center 40%/cover no-repeat}
.mb-ov{position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,33,71,.88),rgba(0,33,71,.72))}
.mb-content{position:relative;z-index:1;text-align:center;padding:0 2rem}
.mb-content h2{font-family:"Manrope",sans-serif;font-size:clamp(1.7rem,3.8vw,3.2rem);font-weight:900;letter-spacing:-.04em;line-height:1.12;color:var(--w);max-width:820px;margin:0 auto 1.5rem}
.mb-content h2 strong{color:var(--y)}

/* ── dosieres ── */
.dosieres{background:var(--blk);padding:8rem 2.8rem;border-top:2px solid rgba(253,218,36,.18)}
.sh-top{display:flex;justify-content:space-between;align-items:flex-end;max-width:1200px;margin:0 auto 4rem;flex-wrap:wrap;gap:1rem}
.sh-top h2{font-family:"Manrope",sans-serif;font-size:clamp(2rem,4vw,3.5rem);font-weight:900;letter-spacing:-.04em;line-height:1.05;color:var(--w)}
.sh-top h2 em{font-style:italic;color:var(--y)}
.sh-top .stag{color:rgba(255,255,255,.45)}
.dos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;max-width:1200px;margin:0 auto}
.dc{position:relative;overflow:hidden;aspect-ratio:4/3;cursor:pointer;background:#1a1a1a;border:0}
.dc img:not(.dc-bibo-logo):not(.dc-partner-logo){width:100%;height:100%;object-fit:cover;transition:transform .35s var(--t),filter .25s}
.dc:hover img,.dc:focus-visible img{transform:scale(1.09);filter:brightness(.85) saturate(1.1)}
.dc-ov{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,5,20,.92) 0%,rgba(0,5,20,.25) 55%,transparent 100%);
  transition:background .25s;
}
.dc:hover .dc-ov{
  background:linear-gradient(to top,rgba(0,5,20,.97) 0%,rgba(0,20,60,.6) 55%,rgba(253,218,36,.07) 100%);
}
/* yellow sweep line */
.dc::after{
  content:"";position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--y),var(--s));
  transform:scaleX(0);transform-origin:left;
  transition:transform .3s var(--t);z-index:10;
}
.dc:hover::after,.dc:focus-visible::after{transform:scaleX(1)}
.dc-info{
  position:absolute;bottom:0;left:0;right:0;padding:1.5rem 1.8rem;
  transform:translateY(8px);transition:transform .22s var(--t);
}
.dc:hover .dc-info,.dc:focus-visible .dc-info{transform:translateY(0)}
.dc-badge{
  display:inline-block;font-family:"Manrope",sans-serif;font-size:.62rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.18em;color:var(--n);background:var(--y);
  padding:.25rem .7rem;border-radius:999px;margin-bottom:.7rem;
  transition:background .2s,color .2s,letter-spacing .2s;
}
.dc:hover .dc-badge{background:var(--w);letter-spacing:.22em}
.dc h3{font-family:"Manrope",sans-serif;font-size:1.35rem;font-weight:800;color:var(--w);line-height:1.2;margin-bottom:.5rem}
.dc-chips{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:1rem;justify-content:center;opacity:0;transform:translateY(8px);transition:opacity .2s,transform .22s var(--t)}
.dc:hover .dc-chips,.dc:focus-visible .dc-chips{opacity:1;transform:translateY(0)}
.chip{font-size:.7rem;background:rgba(255,255,255,.12);color:rgba(255,255,255,.85);padding:.25rem .6rem;border-radius:6px;font-weight:600;backdrop-filter:blur(4px)}
.dc-cta{display:inline-flex;align-items:center;gap:.4rem;font-family:"Manrope",sans-serif;font-size:.78rem;font-weight:700;color:var(--y);opacity:0;transform:translateY(8px);transition:opacity .2s .05s,transform .22s .05s var(--t)}
.dc:hover .dc-cta,.dc:focus-visible .dc-cta{opacity:1;transform:translateY(0)}

/* ── tarjeta CTA ── */
.dc.dc-call{display:flex;align-items:flex-end;text-decoration:none;background:linear-gradient(135deg,#010d24 0%,#001e4a 60%,#003070 100%);border:2px solid rgba(253,218,36,.25);transition:border-color .3s,transform .3s}
.dc.dc-call:hover{border-color:rgba(253,218,36,.7);transform:translateY(-3px)}
.dc-call-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 70% 30%,rgba(253,218,36,.12) 0%,transparent 65%)}
.dc.dc-call .dc-info{position:relative;transform:none;padding:2rem 1.8rem}
.dc.dc-call:hover .dc-info{transform:none}
.dc-partner-logo{position:absolute;top:1.4rem;right:1.4rem;height:54px;width:auto;max-width:180px;object-fit:contain;display:block;filter:drop-shadow(0 1px 8px rgba(0,0,0,.7));opacity:1;z-index:5;pointer-events:none}
.dc-bibo-logo{position:absolute;top:1.4rem;right:1.4rem;height:44px;width:auto;max-width:150px;object-fit:contain;opacity:0;transform:translateY(-6px);transition:opacity .2s .05s,transform .22s .05s var(--t);z-index:10;pointer-events:none;filter:brightness(0) invert(1)}
.dc:hover .dc-bibo-logo,.dc:focus-visible .dc-bibo-logo,.dc:active .dc-bibo-logo{opacity:1;transform:translateY(0)}
.dc-call-sub{font-size:.85rem;color:rgba(255,255,255,.6);line-height:1.55;margin-bottom:1.1rem}
.dc.dc-call .dc-cta{opacity:1;transform:none;font-size:.88rem}
.dc.dc-call .dc-chips,.dc.dc-call .dc-badge{opacity:1;transform:none}
.dc.dc-call::after{display:none}

/* ── soñar despierto ── */
.sonar{
  background:var(--w);
  padding:0;position:relative;overflow:hidden;
  border-top:4px solid var(--y);
}
.sonar::before{display:none}
.sonar-inner{
  max-width:none;margin:0;
  display:grid;grid-template-columns:44% 1fr;
  gap:0;align-items:stretch;min-height:580px;
}
.sonar-media{
  position:relative;overflow:hidden;
  clip-path:polygon(0 0,100% 0,84% 100%,0 100%);
  display:block;padding:0;
}
.sonar-media::before{display:none}
.sonar-logo-inline{height:72px;width:auto;max-width:200px;margin-bottom:1rem;display:block;align-self:flex-start;object-fit:contain}
.sonar-img-wrap{
  position:absolute;inset:0;
  border-radius:0;overflow:hidden;
  box-shadow:none;height:100%;min-height:unset;
}
.sonar-img-wrap img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;object-position:center 35%;
  filter:saturate(1.12) brightness(1.03);
}
.sonar-text{
  padding:5rem 4rem 5rem 4rem;
  display:flex;flex-direction:column;justify-content:center;
  background:linear-gradient(135deg,var(--w) 70%,#eef4fb 100%);
}
.sonar-text h2{font-family:"Manrope",sans-serif;font-size:clamp(1.9rem,3.2vw,2.7rem);font-weight:900;letter-spacing:-.04em;line-height:1.1;margin-bottom:1.4rem;color:var(--n)}
.sonar-text h2 mark{background:none;color:inherit;padding:0;position:relative;font-style:italic}
.sonar-text h2 mark::after{content:'';position:absolute;bottom:.06em;left:0;right:0;height:3px;background:var(--y);border-radius:2px}
.sonar-text p{color:var(--ink);font-size:1rem;line-height:1.78;margin-bottom:1rem}
.sonar-stats{display:flex;gap:2.5rem;margin-top:2rem;flex-wrap:wrap}
.sonar-stat strong{display:block;font-family:"Manrope",sans-serif;font-size:2.4rem;font-weight:900;color:var(--n);letter-spacing:-.04em;line-height:1}
.sonar-stat span{font-size:.75rem;color:var(--ink);font-family:"Manrope",sans-serif;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-top:.2rem;display:block}

/* ── valores — editorial oscuro ── */
.valores{background:var(--blk);padding:0;overflow:hidden;border-top:2px solid var(--y);border-bottom:2px solid var(--y)}
.vals-split{display:grid;grid-template-columns:1fr 1fr;min-height:680px}
.vals-img-col{position:relative;overflow:hidden;min-height:480px;background:var(--n)}
.vals-img-col img{position:absolute;inset:-6% 0 0 0;width:100%;height:106%;object-fit:contain;object-position:center top;filter:sepia(38%) saturate(1.7) hue-rotate(-10deg) brightness(1.05);transition:transform .8s var(--t)}
.vals-img-col:hover img{transform:scale(1.03)}
.vals-img-ov{position:absolute;inset:0;background:linear-gradient(to right,#0a0a0a 0%,transparent 14%,transparent 82%,#0a0a0a 100%)}
.vals-text-col{padding:6rem 5rem;display:flex;flex-direction:column;justify-content:center;background:var(--blk)}
.vals-text-col .stag{color:var(--y);margin-bottom:1rem}
.vals-text-col h2{font-family:"Manrope",sans-serif;font-size:clamp(2rem,3.5vw,2.8rem);font-weight:900;letter-spacing:-.04em;color:var(--w);margin-bottom:2.5rem;line-height:1.05}
.vals-text-col h2 em{font-style:italic;color:var(--y)}
.vals-list{display:flex;flex-direction:column}
.vitem{display:flex;gap:1.4rem;align-items:flex-start;padding:1.4rem 0;border-bottom:1px solid rgba(255,255,255,.08);transition:background .2s}
.vitem:first-child{border-top:1px solid rgba(255,255,255,.08)}
.vitem:hover{background:rgba(253,218,36,.04);margin:0 -1rem;padding-left:1rem;padding-right:1rem;border-radius:8px;border-color:transparent}
.vnum{font-family:"Manrope",sans-serif;font-size:.82rem;font-weight:900;color:var(--y);opacity:.55;letter-spacing:.05em;flex-shrink:0;min-width:1.8rem;padding-top:.25rem}
.vitem h3{font-family:"Manrope",sans-serif;font-weight:700;font-size:1rem;color:var(--w);margin-bottom:.3rem;letter-spacing:.01em}
.vitem p{font-size:.86rem;color:rgba(255,255,255,.48);line-height:1.65}

/* ── proceso ── */
.proceso{background:var(--w);padding:0;position:relative;overflow:hidden;border-top:2px solid rgba(0,33,71,.12)}
.proc-split{display:grid;grid-template-columns:1fr 42%;min-height:600px}
.proc-content{padding:5rem 4rem 5rem 2.8rem;display:flex;flex-direction:column;justify-content:flex-start}
.proc-header{margin-bottom:2rem}
.proc-header h2{font-family:"Manrope",sans-serif;font-size:clamp(1.8rem,2.6vw,2.4rem);font-weight:900;letter-spacing:-.04em;color:var(--n);line-height:1.1;margin-bottom:.75rem}
.proc-sub{color:var(--ink);font-size:.95rem;max-width:400px;line-height:1.7;margin-top:.5rem}
.steps{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:2rem}
.step{
  background:var(--bg);border:1px solid var(--line);border-radius:10px;
  padding:1.4rem 1.5rem;
  transition:border-color .25s,background .25s;
  position:relative;
}
.step:hover{border-color:rgba(253,218,36,.55);background:rgba(253,218,36,.04)}
.sn{
  font-family:"Manrope",sans-serif;font-weight:900;font-size:2.6rem;
  color:var(--y);opacity:1;letter-spacing:-.06em;line-height:1;
  margin-bottom:.35rem;display:block;
  text-shadow:0 2px 12px rgba(253,218,36,.35);
}
.step h4{font-family:"Manrope",sans-serif;font-weight:700;font-size:.95rem;margin-bottom:.3rem;color:var(--n);letter-spacing:.01em}
.step p{font-size:.83rem;color:var(--ink);line-height:1.65}
.proc-photo{position:relative;overflow:hidden}
.proc-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}

/* ── equipo ── */
.equipo{background:var(--blk);padding:8rem 2.8rem;border-top:2px solid rgba(253,218,36,.18)}
.equipo-head{text-align:center;margin-bottom:1.5rem}
.equipo-head .stag{color:rgba(255,255,255,.4);margin-bottom:1rem}
.equipo-head h2{font-family:"Manrope",sans-serif;font-size:clamp(2.2rem,4.5vw,3.8rem);font-weight:900;letter-spacing:-.045em;color:var(--w);line-height:1.05;margin-bottom:1rem}
.equipo-head h2 em{font-style:italic;color:var(--y)}
.equipo-head p{color:rgba(255,255,255,.55);font-size:1.05rem;max-width:640px;margin:0 auto 3rem;line-height:1.75}
.equipo-head p em{font-style:italic;color:var(--y)}
.team-div{width:180px;height:1px;background:rgba(255,255,255,.15);margin:0 auto 1.4rem}
.team-label{font-family:"Manrope",sans-serif;font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.35);text-align:center;margin-bottom:3rem}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem;max-width:1000px;margin:0 auto}
.tcard{display:flex;flex-direction:column;align-items:center;text-align:center;padding:2rem 1.5rem;border:1px solid rgba(255,255,255,.08);border-radius:16px;transition:border-color .3s,transform .3s}
.tcard:hover{border-color:rgba(253,218,36,.35);transform:translateY(-4px)}
.tcard h3{font-family:"Manrope",sans-serif;font-size:1.15rem;font-weight:700;color:var(--w);margin-bottom:.3rem}
.tcard .role{font-family:"Manrope",sans-serif;font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--y);margin-bottom:.6rem}
.tcard p{color:rgba(255,255,255,.55);font-size:.88rem;line-height:1.6;max-width:260px}

/* ── blog ── */
.blog{background:var(--bg);padding:8rem 2.8rem}
.blog-head{display:flex;justify-content:space-between;align-items:flex-end;max-width:1200px;margin:0 auto 4rem;flex-wrap:wrap;gap:1rem}
.blog-head .stag{color:var(--s)}
.blog-head h2{font-family:"Manrope",sans-serif;font-size:clamp(2rem,4vw,3.5rem);font-weight:900;letter-spacing:-.04em;line-height:1.05;color:var(--n)}
.blog-head h2 em{font-style:italic;color:var(--y)}
.blog-head p{color:var(--ink);font-size:.9rem;margin-top:.4rem}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;max-width:1200px;margin:0 auto}
.bc{border-radius:20px;overflow:hidden;background:var(--w);box-shadow:0 4px 24px -8px rgba(0,33,71,.1);transition:transform .3s var(--t),box-shadow .3s}
.bc:hover{transform:translateY(-6px);box-shadow:0 24px 50px -12px rgba(0,33,71,.18)}
.bc-photo{position:relative;height:220px;overflow:hidden;background:#1a1a1a}
.bc-photo img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--t)}
.bc:hover .bc-photo img{transform:scale(1.06)}
.bc-cat{position:absolute;top:.9rem;left:.9rem;font-family:"Manrope",sans-serif;font-size:.62rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--n);background:var(--y);padding:.25rem .65rem;border-radius:999px}
.bc-body{padding:1.6rem}
.bc-body h3{font-family:"Manrope",sans-serif;font-size:1.05rem;font-weight:700;color:var(--n);line-height:1.35;margin-bottom:.5rem}
.bc-body p{color:var(--ink);font-size:.88rem;line-height:1.6;margin-bottom:.9rem}
.bc-link{font-family:"Manrope",sans-serif;font-size:.78rem;font-weight:700;color:var(--n);letter-spacing:.04em;display:inline-flex;align-items:center;gap:.3rem;transition:color .2s}
.bc:hover .bc-link{color:var(--s)}

/* ── presupuesto ── */
.presupuesto{position:relative;overflow:hidden;padding:9rem 2.8rem;background:#020810;border-top:1px solid rgba(253,218,36,.12)}
.pres-bg{position:absolute;inset:0;background:url("https://images.unsplash.com/photo-1497366216548-37526070297c?w=1600&q=85&auto=format&fit=crop") center/cover no-repeat;opacity:.13;mix-blend-mode:luminosity}
.pres-ov{position:absolute;inset:0;background:linear-gradient(135deg,rgba(2,7,18,.97) 0%,rgba(0,20,55,.88) 55%,rgba(0,30,70,.8) 100%)}
.presupuesto::before{content:'';position:absolute;top:-140px;right:-100px;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(253,218,36,.13) 0%,transparent 65%);pointer-events:none;animation:floatA 12s ease-in-out infinite}
.presupuesto::after{content:'';position:absolute;bottom:-80px;left:-80px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(70,177,225,.11) 0%,transparent 65%);pointer-events:none;animation:floatB 15s ease-in-out infinite}
.pres-wrap{position:relative;z-index:1;max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:7rem;align-items:center}
.pres-left{position:relative}
.pres-left::before{content:'"';position:absolute;top:-4rem;left:-1.5rem;font-family:"Manrope",sans-serif;font-size:16rem;font-weight:900;color:var(--y);opacity:.07;line-height:1;pointer-events:none;z-index:0;user-select:none}
.pres-left .stag{color:var(--y);margin-bottom:1rem;position:relative;z-index:1}
.pres-left h2{font-family:"Manrope",sans-serif;font-size:clamp(2.6rem,4.8vw,4.4rem);font-weight:900;letter-spacing:-.048em;line-height:.95;color:var(--w);margin-bottom:1.6rem;position:relative;z-index:1}
.pres-left h2 em{font-style:italic;color:var(--y);text-shadow:0 0 40px rgba(253,218,36,.35)}
.pres-pitch{color:rgba(255,255,255,.7);font-size:1.05rem;line-height:1.85;margin-bottom:2.8rem;position:relative;z-index:1}
.pres-trust{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem;margin-bottom:2.5rem;position:relative;z-index:1}
.ptrust{display:flex;flex-direction:column;align-items:flex-start;gap:.3rem;padding:1.2rem 1rem;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:16px;transition:border-color .3s,background .3s,transform .3s}
.ptrust:hover{border-color:rgba(253,218,36,.4);background:rgba(253,218,36,.06);transform:translateY(-3px)}
.ptrust strong{display:block;font-family:"Manrope",sans-serif;font-size:2rem;font-weight:900;color:var(--y);letter-spacing:-.04em;line-height:1}
.ptrust span{font-size:.65rem;color:rgba(255,255,255,.55);font-family:"Manrope",sans-serif;font-weight:700;letter-spacing:.12em;text-transform:uppercase;display:block}
.pres-q{font-family:"Manrope",sans-serif;font-size:1rem;font-style:italic;color:rgba(255,255,255,.45);line-height:1.75;border-left:3px solid var(--y);padding-left:1.2rem;position:relative;z-index:1;background:rgba(253,218,36,.04);padding:1rem 1.2rem;border-radius:0 10px 10px 0}
.pform{position:relative;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.13);border-top:2px solid var(--y);border-radius:28px;padding:2.8rem;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);box-shadow:0 0 80px rgba(253,218,36,.08),0 40px 100px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.08)}
.pform-head{display:flex;align-items:center;gap:.7rem;font-family:"Manrope",sans-serif;font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--y);margin-bottom:1.8rem;padding-bottom:1.4rem;border-bottom:1px solid rgba(255,255,255,.08)}
.pform-dot{width:8px;height:8px;border-radius:50%;background:var(--y);box-shadow:0 0 8px var(--y);flex-shrink:0;animation:pulseDot 2.2s ease-in-out infinite}
@keyframes pulseDot{0%,100%{box-shadow:0 0 6px var(--y)}50%{box-shadow:0 0 16px var(--y),0 0 28px rgba(253,218,36,.4)}}
.f2{display:grid;grid-template-columns:1fr 1fr;gap:.9rem;margin-bottom:.9rem}
.fg{margin-bottom:.9rem;text-align:left}
.fg input,.fg textarea,.fg select{
  width:100%;padding:.95rem 1.1rem;background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.13);border-radius:14px;
  color:var(--w);font:inherit;font-size:.95rem;
  transition:border-color .2s,background .2s,box-shadow .2s;
}
.fg input::placeholder,.fg textarea::placeholder{color:rgba(255,255,255,.45)}
.fg input:focus,.fg textarea:focus,.fg select:focus{
  outline:none;border-color:var(--y);background:rgba(255,255,255,.1);
  box-shadow:0 0 0 3px rgba(253,218,36,.18);
}
.fg input[aria-invalid="true"],.fg textarea[aria-invalid="true"]{border-color:#f88}
.fg textarea{min-height:110px;resize:vertical}
.fglabel{display:block;font-family:"Manrope",sans-serif;font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:.7rem}
.check-group{display:flex;flex-wrap:wrap;gap:.55rem}
.check-item{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.55rem .9rem;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);border-radius:999px;
  font-size:.84rem;color:rgba(255,255,255,.85);cursor:pointer;
  transition:background .2s,border-color .2s,color .2s;
}
.check-item input{accent-color:var(--y);width:auto;margin:0}
.check-item:hover{border-color:rgba(253,218,36,.4)}
.check-item:has(input:checked){background:rgba(253,218,36,.14);border-color:var(--y);color:var(--w)}
.honey{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}
.fok{display:none;margin-top:1rem;padding:1rem 1.2rem;background:rgba(253,218,36,.14);border:1px solid var(--y);border-radius:12px;color:var(--w);font-size:.95rem}
.fok.show{display:block}
.ferr{display:none;margin-top:.8rem;padding:.8rem 1rem;background:rgba(255,99,99,.14);border:1px solid rgba(255,99,99,.45);border-radius:10px;color:#fff;font-size:.88rem}
.ferr.show{display:block}

/* ── legal / privacidad ── */
.legal-section{background:var(--blk);color:rgba(255,255,255,.75);padding:5rem 2.5rem;border-top:1px solid rgba(255,255,255,.08)}
.legal-inner{max-width:860px;margin:0 auto}
.legal-title{font-family:"Manrope",sans-serif;font-size:clamp(1.4rem,2.5vw,2rem);font-weight:900;color:var(--w);margin-bottom:2.5rem;letter-spacing:-.03em}
.legal-block{margin-bottom:2rem}
.legal-block h3{font-family:"Manrope",sans-serif;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--y);margin-bottom:.6rem}
.legal-block p,.legal-block ul{font-size:.9rem;line-height:1.8;color:rgba(255,255,255,.65)}
.legal-block ul{padding-left:1.2rem;display:flex;flex-direction:column;gap:.4rem}
.legal-block a{color:var(--y);text-decoration:underline}

/* ── footer ── */
footer{background:var(--blk);color:var(--w);padding:4rem 2.5rem 2rem;border-top:1px solid rgba(255,255,255,.08)}
footer::before{content:"";display:block;height:4px;background:linear-gradient(to right,var(--y),var(--s));margin:-4rem -2.5rem 4rem;opacity:.8}
.fg-grid{max-width:1200px;margin:0 auto 2.4rem;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:3rem}
.flogo{display:flex;align-items:flex-end;gap:1.2rem;margin-bottom:1.2rem;flex-wrap:wrap}
.flogo > img{height:62px;width:auto;opacity:.92}
.flogo > img:first-child{filter:brightness(0) invert(1) drop-shadow(0 0 1px rgba(255,255,255,.1))}
.flogo-aurea{display:flex;align-items:center;gap:.75rem;border-left:1px solid rgba(255,255,255,.2);padding-left:1.2rem;flex-shrink:0}
.flogo-aurea-icon{height:62px;width:auto;opacity:.9;flex-shrink:0}
.flogo-aurea-words{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.18rem}
.flogo-aurea-name{font-family:"Manrope",sans-serif;font-size:1.55rem;font-weight:800;letter-spacing:.1em;color:#fff;line-height:1;text-transform:uppercase}
.flogo-aurea-sub{font-family:"Manrope",sans-serif;font-size:.6rem;font-weight:600;letter-spacing:.28em;color:rgba(255,255,255,.8);text-transform:uppercase;line-height:1}
.ftagline{color:rgba(255,255,255,.75);max-width:320px;font-size:.95rem}
.fcol h5{font-family:"Manrope",sans-serif;font-size:.85rem;letter-spacing:.15em;text-transform:uppercase;color:var(--y);margin-bottom:.9rem;font-weight:700}
.fcol a{display:block;color:rgba(255,255,255,.8);font-size:.95rem;margin-bottom:.45rem;transition:color .2s}
.fcol a:hover{color:var(--y)}
.fbot{max-width:1200px;margin:0 auto;padding-top:1.7rem;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;font-size:.82rem;color:rgba(255,255,255,.35);flex-wrap:wrap;gap:1rem}

/* ── page loader ── */
.page-loader{
  position:fixed;inset:0;background:var(--w);z-index:10000;
  display:flex;align-items:center;justify-content:center;
  transition:transform .82s cubic-bezier(.86,0,.07,1);
  overflow:hidden;
}
.page-loader::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--y),var(--s));
  transform:scaleX(0);transform-origin:left;
  transition:transform .6s .1s cubic-bezier(.22,1,.36,1);
}
.page-loader.done{transform:translateY(-100%);pointer-events:none}
.page-loader.done::after{transform:scaleX(1)}
@keyframes heroReveal{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.pl-grid{display:none}
.pl-corner{display:none}
.pl-ring{display:none}
.pl-inner{text-align:center;position:relative;z-index:1}
.pl-logo{width:140px;height:auto;margin:0 auto 1rem;animation:plRise .7s .1s cubic-bezier(.22,1,.36,1) both}
@keyframes plRise{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
.pl-sub{font-family:"Manrope",sans-serif;font-size:.62rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--n);margin-bottom:2rem;animation:plFade .5s .5s both}
@keyframes plFade{from{opacity:0}to{opacity:1}}
.pl-bar{width:180px;height:2px;background:rgba(0,0,0,.08);border-radius:2px;overflow:hidden;margin:0 auto .7rem}
.pl-fill{height:100%;width:0;background:linear-gradient(90deg,var(--s) 0%,var(--n) 100%);border-radius:2px;animation:plFill 1.1s .3s cubic-bezier(.22,1,.36,1) both}
@keyframes plFill{to{width:100%}}
.pl-count{font-family:"Manrope",sans-serif;font-size:.62rem;font-weight:700;color:rgba(0,0,0,.35);letter-spacing:.1em;animation:plFade .5s .4s both}

/* ── hero grain ── */
.hero-grain{
  position:absolute;inset:0;z-index:4;pointer-events:none;
  opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:300px 300px;
  mix-blend-mode:overlay;
}

/* ── stagger reveal delays ── */
.dos-grid .dc:nth-child(2).reveal{transition-delay:.08s}
.dos-grid .dc:nth-child(3).reveal{transition-delay:.16s}
.dos-grid .dc:nth-child(4).reveal{transition-delay:.06s}
.dos-grid .dc:nth-child(5).reveal{transition-delay:.14s}
.dos-grid .dc:nth-child(6).reveal{transition-delay:.22s}
.dos-grid .dc:nth-child(7).reveal{transition-delay:.04s}
.dos-grid .dc:nth-child(8).reveal{transition-delay:.12s}
.steps .step:nth-child(2).reveal{transition-delay:.12s}
.steps .step:nth-child(3).reveal{transition-delay:.24s}
.steps .step:nth-child(4).reveal{transition-delay:.36s}
.vals-list .vitem:nth-child(2).reveal{transition-delay:.08s}
.vals-list .vitem:nth-child(3).reveal{transition-delay:.16s}
.vals-list .vitem:nth-child(4).reveal{transition-delay:.24s}
.blog-grid .bc:nth-child(2).reveal{transition-delay:.1s}
.blog-grid .bc:nth-child(3).reveal{transition-delay:.2s}

/* ── rword glow ── */
.rword.active{}

/* ── btn shimmer ── */
.btn-y,.btn-n{overflow:hidden}
.btn-y::before,.btn-n::before{
  content:"";position:absolute;top:0;left:-120%;width:55%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);
  transition:left .55s var(--t);pointer-events:none;
}
.btn-y:hover::before,.btn-n:hover::before{left:160%}
.btn{position:relative}

/* ── scroll progress ── */
.scroll-progress{
  position:fixed;top:0;left:0;height:2px;width:0%;z-index:400;transition:width .08s linear;pointer-events:none;
  background:linear-gradient(90deg,var(--y) 0%,var(--s) 60%,var(--y) 100%);
  background-size:200% 100%;
  animation:progressShimmer 2.5s linear infinite;
}
@keyframes progressShimmer{from{background-position:100% 0}to{background-position:-100% 0}}

/* ── marquee ── */
.marquee-wrap{overflow:hidden;background:rgba(0,21,47,.72);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:.85rem 0;position:relative;z-index:2;border-top:1px solid rgba(255,255,255,.08)}
.marquee-track{display:flex;gap:2.2rem;width:max-content;animation:marquee 28s linear infinite;white-space:nowrap;align-items:center}
.marquee-track span{font-family:"Manrope",sans-serif;font-size:.8rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.55)}
.mdot{color:var(--y) !important;font-size:1.2rem;line-height:1}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee-wrap:hover .marquee-track{animation-play-state:paused}

/* ── magnetic btn ── */
.btn-mag{position:relative;transition:transform .25s var(--t)}

/* ── card tilt ── */
.dc{transform-style:preserve-3d;transition:transform .18s ease,box-shadow .18s ease}

/* ── counter stat ── */
.sonar-stat strong{transition:color .3s}
.sonar-stat.counted strong{color:var(--s)}


/* ── modal ── */
.moverlay{position:fixed;inset:0;background:rgba(0,33,71,.75);backdrop-filter:blur(6px);z-index:500;display:none;align-items:center;justify-content:center;padding:2rem}
.moverlay.open{display:flex}
.modal-box{background:var(--w);border-radius:28px;max-width:540px;width:100%;padding:2.6rem;max-height:90vh;overflow-y:auto;position:relative}
.modal-close{position:absolute;top:1rem;right:1rem;background:var(--bg);width:36px;height:36px;border-radius:50%;font-size:1.2rem;color:var(--n);display:flex;align-items:center;justify-content:center;transition:background .2s}
.modal-close:hover{background:var(--y)}
.modal-box h3{font-family:"Manrope",sans-serif;font-size:1.35rem;font-weight:700;margin-bottom:.35rem;color:var(--n);padding-right:2rem}
.modal-sub{color:var(--ink);margin-bottom:1.5rem;font-size:.95rem}
.modal-input{width:100%;padding:.85rem 1rem;margin-bottom:.8rem;border:1.5px solid var(--line);border-radius:14px;background:var(--bg);color:var(--n);font:inherit;transition:border-color .2s,background .2s,box-shadow .2s}
.modal-input:focus{outline:none;border-color:var(--n);background:var(--w);box-shadow:0 0 0 3px rgba(70,177,225,.2)}
.modal-input--area{min-height:85px;resize:vertical}

/* ── responsive ── */
@media(max-width:980px){
  .sonar-inner{grid-template-columns:1fr}
  .sonar-media{height:280px;clip-path:none}
  .sonar-img-wrap img{object-position:center 45%}
  .sonar-text{padding:3.5rem 2.5rem}
  .about-text{padding:3.5rem 0}
  .mvv-3col{grid-template-columns:1fr}
  .mvv-col:not(:first-child){border-left:none;border-top:1px solid rgba(0,33,71,.1);padding-left:0}
  .mvv-col{padding:2.5rem 0}
  .steps,.team-grid,.blog-grid,.dos-grid{grid-template-columns:repeat(2,1fr)}
  .vals-split{grid-template-columns:1fr}
  .vals-img-col{min-height:380px}
  .vals-text-col{padding:4rem 2.5rem}
  .pres-wrap{grid-template-columns:1fr;gap:3.5rem}
  .pres-trust{padding-left:1.2rem}
}
@media(max-width:820px){
  .presupuesto{padding-top:5rem;padding-bottom:5rem}
  .pres-left::before{font-size:9rem;top:-2rem;left:-1rem;opacity:.05}
  nav#nav{padding:0 1.2rem}
  .nav-links{
    position:fixed;top:72px;left:0;right:0;
    flex-direction:column;gap:0;
    background:var(--w);
    padding:0;max-height:0;overflow:hidden;
    border-bottom:3px solid var(--y);
    box-shadow:0 16px 32px -8px rgba(0,33,71,.12);
    transition:max-height .3s,padding .3s;
  }
  .nav-links.open{max-height:540px;padding:.8rem 0}
  .nav-links li{width:100%;text-align:center;padding:.5rem 0}
  .nav-toggle{display:block}
  .nav-cta{display:inline-block;margin:.4rem auto}
  .lang-switch{margin:.4rem auto 0;justify-content:center}
  .hero-inner{padding:0 1.4rem 3rem}
  .hero h1 .pre{font-size:.5em}
  .hero-bottom{flex-direction:column;align-items:flex-start}
  .dosieres,.equipo,.blog,.presupuesto{padding-left:1.4rem;padding-right:1.4rem}
  .sonar-text{padding:3rem 1.4rem}
  .proc-content{padding:3rem 1.4rem}
  .steps,.team-grid,.blog-grid,.dos-grid{grid-template-columns:1fr}
  .f2{grid-template-columns:1fr;gap:0}
  .fg-grid{grid-template-columns:1fr;gap:2rem}
  .fbot{flex-direction:column;align-items:flex-start}
  .pform,.modal-box{padding:1.7rem}
  .about-text{padding:3rem 1.4rem}
  .sonar-inner{gap:3rem}
  .vals-text-col{padding:3rem 1.4rem}
  .sn{font-size:2.2rem}
  .step{padding:1.2rem}
  .mvv-row{grid-template-columns:70px 1fr;gap:.8rem}
  .pres-trust{grid-template-columns:1fr 1fr 1fr}
}
@media(max-width:660px){
  .proc-split{grid-template-columns:1fr}
  .proc-photo{height:280px;position:relative}
  .proc-content{padding:3rem 1.4rem}
  .steps{grid-template-columns:1fr}
  .presupuesto{padding-top:3.5rem;padding-bottom:3.5rem}
  .pres-left::before{display:none}
  .pres-trust{grid-template-columns:1fr 1fr;gap:.6rem}
  .ptrust{padding:1rem .8rem}
  .ptrust strong{font-size:1.5rem}
  .pform{padding:1.4rem}
  .pform-head{font-size:.65rem;margin-bottom:1.2rem;padding-bottom:1rem}
}

/* ── botón flotante calendario ── */
@keyframes calPulse{
  0%,100%{transform:scale(1);opacity:.55}
  50%{transform:scale(1.55);opacity:0}
}
.float-cal{
  position:fixed;bottom:2rem;right:2rem;z-index:8000;
  display:inline-flex;align-items:center;gap:.65rem;
  background:var(--n);
  color:var(--w);text-decoration:none;
  font-family:"Manrope",sans-serif;font-size:.78rem;font-weight:800;
  letter-spacing:.04em;white-space:nowrap;
  padding:.78rem 1.3rem .78rem 1rem;
  border-radius:999px;
  border:2px solid var(--y);
  box-shadow:0 6px 24px rgba(0,0,0,.35);
  transition:transform .22s,box-shadow .22s,background .2s;
}
.float-cal:hover{
  background:var(--y);color:var(--n);
  transform:translateY(-4px);
  box-shadow:0 12px 32px rgba(0,0,0,.4);
}
.float-cal:hover .float-cal-pulse{display:none}
.float-cal-pulse{
  position:absolute;inset:-4px;border-radius:inherit;
  border:2px solid var(--y);
  animation:calPulse 2s ease-out infinite;
  pointer-events:none;
}
.float-cal svg{width:20px;height:20px;flex-shrink:0;color:var(--y);transition:color .2s}
.float-cal:hover svg{color:var(--n)}
.float-cal-label{transition:color .2s}
@media(max-width:600px){
  .float-cal{bottom:1.2rem;right:1.2rem;padding:.7rem 1rem .7rem .9rem;font-size:.72rem}
  .float-cal svg{width:18px;height:18px}
}

/* ── cookie banner ── */
.cookie-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:9000;
  background:var(--n);border-top:3px solid var(--y);
  padding:1.2rem 2rem;
  transform:translateY(100%);transition:transform .4s cubic-bezier(.22,1,.36,1);
  box-shadow:0 -4px 32px rgba(0,0,0,.25);
}
.cookie-banner--visible{transform:translateY(0)}
.cookie-inner{
  max-width:1200px;margin:0 auto;
  display:flex;align-items:center;gap:2rem;flex-wrap:wrap;
}
.cookie-text{flex:1;min-width:220px}
.cookie-text strong{font-family:"Manrope",sans-serif;font-size:1rem;font-weight:800;color:var(--w);display:block;margin-bottom:.3rem}
.cookie-text p{font-size:.85rem;color:rgba(255,255,255,.75);margin:0;line-height:1.5}
.cookie-text a{color:var(--y);text-decoration:underline}
.cookie-actions{display:flex;gap:.75rem;flex-shrink:0}
.cookie-btn{
  font-family:"Manrope",sans-serif;font-size:.82rem;font-weight:700;
  padding:.55rem 1.4rem;border-radius:999px;cursor:pointer;
  border:2px solid transparent;transition:all .2s;
}
.cookie-btn--accept{background:var(--y);color:var(--n)}
.cookie-btn--accept:hover{background:#ffe44d}
.cookie-btn--reject{background:transparent;color:rgba(255,255,255,.7);border-color:rgba(255,255,255,.25)}
.cookie-btn--reject:hover{border-color:rgba(255,255,255,.6);color:var(--w)}
@media(max-width:600px){
  .cookie-banner{padding:1.2rem 1.2rem}
  .cookie-inner{flex-direction:column;gap:1rem;align-items:flex-start}
  .cookie-actions{width:100%;justify-content:flex-end}
}

/* ── móvil: sin hover, mostrar info de cards siempre ── */
@media(hover:none){
  .dc-info{transform:translateY(0);text-align:center}
  .dc-chips{opacity:1;transform:translateY(0);justify-content:center}
  .dc-cta{opacity:1;transform:translateY(0)}
  .dc-bibo-logo{opacity:1;transform:translateY(0);height:34px;top:1.2rem;right:1.2rem}
  .dc-partner-logo{height:42px;max-width:145px;top:1.2rem;right:1.2rem}
  .dc::after{display:none}
  /* hero: usar svh para excluir el chrome del navegador */
  .hero{height:100svh;min-height:580px}
  .scroll-hint{display:none}
  .hero-inner{padding-bottom:1.5rem}
}
