@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);
  border-bottom:1px solid rgba(0,33,71,.08);
  box-shadow:0 1px 0 rgba(0,33,71,.04);
  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)::after{
  content:"";position:absolute;left:0;bottom:-3px;width:0;height:2px;
  background:var(--y);border-radius:2px;transition:width .25s var(--t);
}
.nav-links a:not(.nav-cta):hover::after{width:100%}
.nav-links a:hover{color:var(--n)}
.nav-cta{
  background:var(--n);color:var(--w) !important;
  padding:.55rem 1.3rem;border-radius:999px;
  font-weight:800 !important;
  transition:background .2s,transform .2s,box-shadow .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;gap:.3rem;align-items:center;margin-left:.5rem;list-style:none}
.lang-btn{
  font-family:"Manrope",sans-serif;font-size:.72rem;font-weight:700;
  letter-spacing:.08em;padding:.3rem .55rem;border-radius:6px;
  border:1px solid rgba(0,33,71,.2);color:rgba(0,33,71,.5);
  background:transparent;transition:all .2s;
}
.lang-btn:hover{color:var(--n);border-color:rgba(0,33,71,.5)}
.lang-btn[aria-pressed="true"]{background:var(--y);color:var(--n);border-color:var(--y)}

/* ── 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:inline-flex;align-items:center;gap:.5rem;
  font-family:"Manrope",sans-serif;font-size:.72rem;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--n);background:var(--y);
  padding:.4rem 1rem;border-radius:999px;margin-bottom:2rem;
}
.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(--bg);padding:0}
.about-grid{display:grid;grid-template-columns:1fr 1fr}
.about-photo{
  position:relative;min-height:580px;overflow:hidden;
  background:#1a2440 url("https://images.unsplash.com/photo-1492366254240-43affaefc3e3?w=1200&q=85&auto=format&fit=crop") center/cover no-repeat;
  filter:sepia(38%) saturate(1.7) hue-rotate(-10deg) brightness(1.08);
}
.about-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,33,71,.25),transparent 55%)}
.about-photo-badge{position:absolute;bottom:2rem;left:2rem;background:var(--y);color:var(--n);border-radius:14px;padding:1rem 1.4rem;font-family:"Manrope",sans-serif;font-weight:700;font-size:.82rem;line-height:1.4}
.about-photo-badge strong{display:block;font-size:1.7rem;font-weight:900;letter-spacing:-.04em}
.about-text{background:var(--w);padding:5rem 4.5rem;display:flex;flex-direction:column;justify-content:center}
.about-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.05;margin-bottom:1.4rem}
.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:3px;background:var(--y);border-radius:2px}
.about-text h2 em{font-style:normal;color:var(--s)}
.about-text p{color:var(--ink);font-size:1rem;line-height:1.78;margin-bottom:1.1rem}
.bq{border-left:4px solid var(--y);padding:.5rem 0 .5rem 1.4rem;margin:1.8rem 0;font-family:"Manrope",sans-serif;font-weight:600;font-size:1.02rem;color:var(--n);line-height:1.5}
.mvv-3col{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:2.5rem;padding-top:2.5rem;border-top:1px solid var(--line)}
.mvv-col{padding:0 1.5rem 0 0;position:relative}
.mvv-col:not(:first-child){padding-left:1.5rem;border-left:1px solid var(--line)}
.mvv-accent{height:3px;width:2.5rem;margin-bottom:1.1rem;border-radius:2px;background:var(--y);transition:width .3s var(--t)}
.mvv-col:hover .mvv-accent{width:100%}
.mvv-accent-s{background:var(--s)}
.mvv-accent-n{background:var(--n)}
.mvv-title{font-family:"Manrope",sans-serif;font-size:1.25rem;font-weight:800;color:var(--n);margin-bottom:.55rem;letter-spacing:-.02em}
.mvv-col p{font-size:.85rem;color:var(--ink);line-height:1.7}

/* ── 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-1515169067868-5387ec356754?w=1600&q=85&auto=format&fit=crop") center 55%/cover no-repeat;transition:transform .6s var(--t)}
.midbanner:hover .mb-bg{transform:scale(1.02)}
.mb-ov{position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,33,71,.78),rgba(0,33,71,.52))}
.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}
.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{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--t),filter .5s}
.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 .5s;
}
.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 .5s 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(10px);transition:transform .45s 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 .3s,color .3s,letter-spacing .3s;
}
.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;opacity:0;transform:translateY(10px);transition:opacity .3s .08s,transform .35s .08s 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(10px);transition:opacity .3s .15s,transform .35s .15s var(--t)}
.dc:hover .dc-cta,.dc:focus-visible .dc-cta{opacity:1;transform:translateY(0)}

/* ── 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}
.vals-split{display:grid;grid-template-columns:1fr 1fr;min-height:680px}
.vals-img-col{position:relative;overflow:hidden;min-height:480px}
.vals-img-col img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s var(--t)}
.vals-img-col:hover img{transform:scale(1.04)}
.vals-img-ov{position:absolute;inset:0;background:linear-gradient(to right,rgba(10,10,10,.2),rgba(10,10,10,.5))}
.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:1px solid var(--line)}
.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:center}
.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}
.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}
.tcard-photo{
  width:190px;height:190px;border-radius:50%;overflow:hidden;margin-bottom:1.5rem;
  border:3px solid rgba(255,255,255,.1);
  transition:border-color .3s,transform .3s,box-shadow .3s;background:#1a1a1a;
}
.tcard:hover .tcard-photo{border-color:var(--y);transform:translateY(-5px);box-shadow:0 20px 40px -12px rgba(253,218,36,.25)}
.tcard-photo img{width:100%;height:100%;object-fit:cover;object-position:top}
.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:#04091a}
.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:.08}
.pres-ov{position:absolute;inset:0;background:linear-gradient(135deg,rgba(2,7,18,.98) 0%,rgba(0,25,60,.9) 60%,rgba(0,33,71,.75) 100%)}
.presupuesto::before{content:'';position:absolute;top:-120px;right:-80px;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(253,218,36,.09) 0%,transparent 70%);pointer-events:none}
.presupuesto::after{content:'';position:absolute;bottom:-60px;left:-60px;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(70,177,225,.08) 0%,transparent 70%);pointer-events:none}
.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:.06;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.4rem,4.5vw,4rem);font-weight:900;letter-spacing:-.045em;line-height:.98;color:var(--w);margin-bottom:1.4rem;position:relative;z-index:1}
.pres-left h2 em{font-style:italic;color:var(--y)}
.pres-pitch{color:rgba(255,255,255,.65);font-size:1.05rem;line-height:1.8;margin-bottom:2.5rem;position:relative;z-index:1}
.pres-trust{display:flex;flex-direction:column;gap:0;margin-bottom:2.2rem;position:relative;z-index:1;border-left:2px solid rgba(253,218,36,.35);padding-left:1.6rem}
.ptrust{display:flex;align-items:baseline;gap:1.4rem;padding:.8rem 0;border-bottom:1px solid rgba(255,255,255,.07)}
.ptrust:last-child{border-bottom:none;padding-bottom:0}
.ptrust:first-child{padding-top:0}
.ptrust strong{display:block;font-family:"Manrope",sans-serif;font-size:1.9rem;font-weight:900;color:var(--y);letter-spacing:-.04em;line-height:1;white-space:nowrap;min-width:5rem}
.ptrust span{font-size:.7rem;color:rgba(255,255,255,.5);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,.4);line-height:1.75;border-left:2px solid var(--y);padding-left:1.2rem;position:relative;z-index:1}
.pform{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);border-radius:28px;padding:2.8rem;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 32px 80px rgba(0,0,0,.35),inset 0 1px 0 rgba(255,255,255,.1)}
.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}

/* ── 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:inline-block;background:none;border-radius:0;padding:0;margin-bottom:1.2rem;box-shadow:none}
.flogo img{height:44px;width:auto;filter:brightness(0) invert(1) drop-shadow(0 0 1px rgba(255,255,255,.1));opacity:.92}
.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(--n);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{
  position:absolute;inset:0;pointer-events:none;
  background-image:repeating-linear-gradient(0deg,rgba(255,255,255,.03) 0,rgba(255,255,255,.03) 1px,transparent 1px,transparent 64px),
  repeating-linear-gradient(90deg,rgba(255,255,255,.03) 0,rgba(255,255,255,.03) 1px,transparent 1px,transparent 64px);
}
.pl-corner{position:absolute;width:40px;height:40px;border-color:var(--y);border-style:solid;border-width:0;opacity:.4}
.pl-tl{top:2rem;left:2rem;border-top-width:1px;border-left-width:1px;animation:plFade .5s .6s both}
.pl-br{bottom:2rem;right:2rem;border-bottom-width:1px;border-right-width:1px;animation:plFade .5s .6s both}
.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:rgba(255,255,255,.28);margin-bottom:2rem;animation:plFade .5s .5s both}
@keyframes plFade{from{opacity:0}to{opacity:1}}
.pl-bar{width:180px;height:2px;background:rgba(255,255,255,.1);border-radius:2px;overflow:hidden;margin:0 auto .7rem}
.pl-fill{height:100%;width:0;background:linear-gradient(90deg,var(--y) 0%,var(--s) 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(255,255,255,.28);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}
.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{text-shadow:0 0 80px rgba(253,218,36,.3)}

/* ── 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)}

/* ── midbanner parallax ── */
.midbanner{overflow:hidden}

/* ── 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){
  .about-grid{grid-template-columns:1fr}
  .sonar-inner{grid-template-columns:1fr}
  .sonar-media{height:360px;clip-path:polygon(0 0,100% 0,100% 82%,0 100%)}
  .sonar-text{padding:3.5rem 2.5rem}
  .about-photo{min-height:360px}
  .about-text{padding:3.5rem 2rem}
  .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){
  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}
}
