:root{
  --bg-1:#0b1020; --bg-2:#0f1530; --bg-3:#121839;
  --ink:#0e1324; --text:#e9eeff; --muted:#a9b4da;
  --brand:#2563eb; --brand-700:#1d4ed8; --violet:#8b5cf6;
  --card:#0f1736; --card-light:#eaf0ff;
  --radius:22px; --shadow:0 12px 40px rgba(3,7,18,.35);
  --max:1200px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:Inter,system-ui,Segoe UI,Roboto,Helvetica,Arial;background:var(--bg-1);color:var(--text)}
img{display:block;max-width:100%}

.container{max-width:var(--max);margin-inline:auto;padding:0 24px}


.btn{display:inline-flex;align-items:center;gap:.6rem;padding:.9rem 1.2rem;border-radius:999px;
  font-weight:700;text-decoration:none;transition:.2s;box-shadow:0 8px 24px rgba(37,99,235,.28)}
.btn.primary{background:var(--brand);color:#fff}
.btn.primary:hover{background:var(--brand-700);transform:translateY(-1px)}
.btn.ghost{border:1px solid rgba(255,255,255,.24);color:#e6ecff;background:transparent}
.btn.ghost:hover{border-color:#fff;transform:translateY(-1px)}


.hero{position:relative;padding:90px 0 50px;background:
  radial-gradient(900px 400px at 85% -10%, rgba(139,92,246,.35), transparent 60%),
  radial-gradient(800px 360px at 10% 0%, rgba(37,99,235,.35), transparent 55%),
  linear-gradient(180deg,#0b1020 0%,#101632 60%,#0b1020 100%);
  border-bottom:1px solid rgba(255,255,255,.06)}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:32px;align-items:center}
.hero-copy h1{font-family:Outfit;font-size:clamp(2rem,3.2vw+1rem,3.2rem);line-height:1.05;margin:0 0 .6rem}
.subtitle{color:#c7d3ff;margin:0 0 1rem}
.cta-row{display:flex;gap:12px;flex-wrap:wrap}
.hero-visual{position:relative;aspect-ratio:1.3/1;border-radius:28px;overflow:hidden}
.hero-visual img{width:120%;max-width:none;object-fit:cover;transform:translateX(-8%)}
.hero-glow{position:absolute;inset:0;background:radial-gradient(60% 60% at 60% 50%, rgba(255,255,255,.08), transparent 70%)}
.hero-bottom-shadow{position:absolute;left:0;right:0;bottom:-24px;height:24px;filter:blur(10px);background:linear-gradient(180deg,rgba(0,0,0,.35),transparent)}

.section{padding:92px 0}
.section-dark{background:linear-gradient(180deg,#0d1224,#0f1530)}
.section-light{background:#f5f7ff;color:#2b3454}
.section-light h2{color:#11183a}
.center{text-align:center}
.kicker{letter-spacing:.28em;text-transform:uppercase;color:#8b5cf6;font-weight:800}

/* Split */
.split{display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:start}
.panel{background:var(--card);border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:22px;box-shadow:var(--shadow)}
.panel {
  display: flex;
  flex-direction: column;
  justify-content: center; 
  height: 100%;
  transition: all 0.3s ease; 
}

.panel:hover {
  box-shadow: 0 0 25px rgba(37, 99, 235, 0.4); 
  transform: translateY(-4px); 
  border: 1px solid rgba(139, 92, 246, 0.5); 
}

.panel h3 {
  margin-top: 0;   
  margin-bottom: 12px; 
}

.muted{color:var(--muted)}
.mt-24{margin-top:24px}
.risk-list {
  list-style: none;
  margin: 12px 0 0;
  padding: 0;
  display: grid;
  gap: 12px;
}

.risk-list li {
  display: flex;
  align-items: center;
  gap: 10px;
  color: #e9eeff; 
}

.dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--brand), var(--violet));
  flex-shrink: 0;
}


.cards{margin-top:14px;display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.card{grid-column:span 3;background:#fff;color:var(--ink);border-radius:18px;padding:22px;box-shadow:0 12px 34px rgba(15,23,42,.08)}
.card .icon{width:44px;height:44px;border-radius:12px;margin-bottom:8px;background:linear-gradient(135deg,var(--brand),var(--violet))}


.timeline{position:relative;margin-top:14px;display:grid;grid-template-columns:repeat(7,1fr);gap:16px}
.timeline:before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:34px;
  height:4px;
  border-radius:999px;
  background:linear-gradient(90deg,rgba(139,92,246,.22),rgba(37,99,235,.22));
}
.step{position:relative;background:#fff;color:var(--ink);border-radius:18px;padding:20px;box-shadow:0 10px 28px rgba(15,23,42,.08);transition:.2s}
.step:hover{transform:translateY(-2px)}
.step .num{position:absolute;top:-12px;left:18px;width:26px;height:26px;border-radius:999px;background:linear-gradient(135deg,var(--brand),var(--violet));color:#fff;display:grid;place-items:center;font-weight:800;border:3px solid #fff;box-shadow:0 8px 22px rgba(139,92,246,.45)}
.step h4{margin:4px 0 6px}


.cta{background:#eef3ff;color:#2b3454;border-top:1px solid rgba(15,23,42,.06);text-align:center}
.cta h2{color:#11183a}
.cta .muted{color:#4a5576}


.faq-grid{margin-top:12px;display:grid;grid-template-columns:repeat(12,1fr);gap:16px}
.faq-item{grid-column:span 4;background:#fff;color:var(--ink);border-radius:18px;padding:16px 20px;box-shadow:0 10px 26px rgba(15,23,42,.08)}
.faq-item summary{font-weight:800;cursor:pointer;list-style:none}
.faq-item p{margin-top:8px;color:#384164}


.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:18px}
.card h3{margin:0 0 8px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-grid .span-2{grid-column:span 2}
input,textarea{width:100%;padding:12px 14px;border-radius:12px;border:1px solid #e6e9f5;outline-color:#93c5fd;font-family:inherit}
.aside{background:var(--card);border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:22px;box-shadow:var(--shadow)}
.contact-list{list-style:none;margin:14px 0 0;padding:0;display:grid;gap:8px}


.footer{background:#0a0f1f;color:#c3cff5;border-top:1px solid rgba(255,255,255,.06);padding:36px 0}
.foot{display:grid;grid-template-columns:1.1fr 1fr 1fr;gap:24px}
.brand{font-family:Outfit;font-weight:800;letter-spacing:.4px}
.linkcol{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.linkcol a{color:#deebff;text-decoration:none;opacity:.9}
.linkcol a:hover{opacity:1}
.tiny{font-size:.92rem}


.reveal{opacity:0;transform:translateY(14px);transition:opacity .6s ease, transform .6s ease}
.reveal.show{opacity:1;transform:none}


@media (max-width:1024px){
  .hero-grid,.split,.contact-grid{grid-template-columns:1fr}
  .cards .card{grid-column:span 6}
  .timeline{grid-template-columns:repeat(2,1fr)}
  .mosaic{grid-template-columns:1fr}
  .faq-item{grid-column:span 12}
  .foot{grid-template-columns:1fr}
}
@media (max-width:640px){
  .cards .card{grid-column:span 12}
  .timeline{grid-template-columns:1fr}
}


.mosaic{
  display: grid;
  grid-template-columns: 1.05fr 1.05fr 1.25fr;   
  grid-auto-rows: auto;                         
  gap: 18px;                                     
  margin: 0;
}

.compas { grid-column: 1;            grid-row: 1; }
.meta   { grid-column: 2;            grid-row: 1; }
.apple  { grid-column: 1 / span 2;   grid-row: 2 ; }      
.amazon { grid-column: 3;            grid-row: 1 / span 2; } 


.tile{
  margin: 0; padding: 0;
  background: transparent;
  border: 0; border-radius: 0;
  box-shadow: none;
  overflow: hidden;                                  
}

.tile img{
  display: block;
  width: 100%;
  height: 100%;
  object-position: center;
}

.compas img,
.meta img{
  object-fit: contain;
}

.apple img{
   object-fit: contain !important;   
  object-position: center !important;    
}


.amazon img{
  object-fit: contain;
}

@media (max-width: 1100px){
  .mosaic{
    grid-template-columns: 1fr 1fr;
    grid-auto-rows: 270px;
    gap: 16px;
  }
  .compas { grid-column:1; grid-row:1; }
  .meta   { grid-column:2; grid-row:1; }
  .apple  { grid-column:1 / span 2; grid-row:2; }
  .amazon { grid-column:1 / span 2; grid-row:3; }
}

@media (max-width: 640px){
  .mosaic{
    grid-template-columns: 1fr;
    grid-auto-rows: 240px;
    gap: 16px;
  }
 
  .compas, .meta, .apple, .amazon{
    grid-column: 1; grid-row: auto;
  }
}


.tile {
  transition: transform 0.3s ease;
  border-radius: 15px; 
}

.tile:hover {
  transform: translateY(-6px) scale(1.00); 
  z-index: 1; 
}


.tile img {
  transition: transform 0.4s ease, filter 0.4s ease;
}

.tile:hover img {
  transform: scale(1.00);       
  filter: brightness(1.10);     
}


:root{ --icon-size: 80px; --icon-radius: 16px; }


.icon-wrap{
  width: var(--icon-size, 80px);
  height: var(--icon-size, 80px);
  border-radius: var(--icon-radius, 16px);
  overflow: hidden;
  flex: 0 0 var(--icon-size, 80px);
  box-shadow: none !important;   
  background: transparent !important; 
}

.icon-wrap img{
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;    
  border-radius: inherit;
  background: transparent !important;
}


.card:hover .icon-wrap img{
  transform: scale(1.05);
  filter: brightness(1.05);
  transition: transform .25s ease, filter .25s ease;
}

.card{
  display: flex;
  flex-direction: column;
  align-items: flex-start; 
  text-align: left;         
}

.card .icon-wrap img {
  display: block;
  width: 80px;      
  height: 80px;
  object-fit: contain;

  margin-left: -18px;   
}


.hero{
  position: relative;
  padding: clamp(48px, 6vw, 84px) 0;
  background:
    radial-gradient(900px 420px at 85% -10%, rgba(139,92,246,.28), transparent 60%),
    radial-gradient(800px 360px at 10% 0%, rgba(37,99,235,.28), transparent 55%),
    linear-gradient(180deg,#0b1020 0%,#101632 60%,#0b1020 100%);
  border-bottom:1px solid rgba(255,255,255,.06);
}

.hero-grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;     
  gap: clamp(24px, 4vw, 48px);
  align-items:center;
}

.hero-copy .kicker{
  letter-spacing:.28em;
  text-transform:uppercase;
  color:#0088FF;            
  font-weight:800;
  margin:0 0 10px;
}


.hero-title{
  font-family: "Outfit", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  font-weight: 800;
  line-height: 1.06;
  margin: 0 0 12px;
  font-size: clamp(1.9rem, 3.6vw + .5rem, 3.6rem);
  letter-spacing: .2px;
}


.subtitle{ color:#c7d3ff; margin: 36px 0px 36px; max-width:62ch; }
.cta-row{ display:flex; gap:12px; flex-wrap:wrap; }


.hero-card{
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  height: clamp(280px, 36vw, 420px);
  isolation: isolate;
  background: radial-gradient(60% 60% at 60% 50%, rgba(255,255,255,.05), transparent 70%),
              rgba(12,17,37,.35);
  box-shadow:
    0 20px 60px rgba(2,6,23,.45),
    inset 0 1px 0 rgba(255,255,255,.06);
}
.hero-card img{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit: cover;
  object-position: 55% 50%;   
  transform: translateZ(0);
  filter: saturate(1.02) contrast(1.02);
}
.hero-card-glow{
  position:absolute; inset:-20%;
  background:
    radial-gradient(40% 40% at 70% 35%, rgba(84,149,255,.35), transparent 65%),
    radial-gradient(30% 30% at 35% 65%, rgba(110,76,255,.28), transparent 60%);
  pointer-events:none;
  mix-blend-mode: screen;
}
.hero-card-border{
  position:absolute; inset:0;
  border-radius:24px;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.08);
  pointer-events:none;
}
.hero-card:hover{
  transform: translateY(-2px);
  transition: transform .22s ease, box-shadow .22s ease;
  box-shadow:
    0 26px 72px rgba(2,6,23,.55),
    inset 0 1px 0 rgba(255,255,255,.08);
}


@media (max-width:1024px){
  .hero-grid{ grid-template-columns:1fr; }
  .hero-card{ order:2; height: clamp(260px, 48vw, 380px); }
  .hero-copy{ order:1; }
}


.hero-visual{
  position: relative;
  aspect-ratio: 1.25 / 1;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  overflow: visible; 
}


.hero-visual::before,
.hero-visual::after,
.hero-glow,
.hero-bottom-shadow{
  content: none !important;
  display: none !important;
}

.hero-visual .hand-img {
  display: block;
  width: 200%;          
  max-width: none;
  height: auto;
  object-fit: contain;   
  transform: translateX(-10%) scale(1.20); 
  transition: transform .35s ease;
}


@media (hover:hover){
  .hero-visual .hand-img{
    transition: transform .35s ease, filter .35s ease;
  }
  .hero-visual:hover .hand-img{
    transform: translateX(-8%) scale(1.22);
    filter: drop-shadow(0 14px 28px rgba(0,0,0,.4));
  }
}



.hero-visual:hover .hand-img {
  transform: translateX(-10%) scale(1.15); 
}


.hero-visual img.hand,
.hero-visual > img.hand {
  display:block;
  width:120% !important;        
  max-width:none !important;
  height:auto !important;
  object-fit:contain !important;
  transform: translateX(-10%) translateY(-15%) scale(1.0) !important; 
  transition: transform .35s ease;
}


.hero-visual:hover img.hand {
  transform: translateX(-10%) translateY(-15%) scale(1.06) !important;
}


@media (max-width: 1024px){
  .hero-visual img.hand{
    width:150% !important;
    transform: translateX(-14%) translateY(0) scale(1.0) !important;
  }
}
@media (max-width: 640px){
  .hero-visual img.hand{
    width:135% !important;
    transform: translateX(-10%) translateY(0) scale(1.0) !important;
  }
}


.step {
  position: relative;
  background: #fff;
  color: var(--ink);
  border-radius: 18px;
  padding: 20px;
  box-shadow: 0 10px 28px rgba(15,23,42,.08);
  transition: all 0.35s ease;
}

.step:hover {
  transform: translateY(-6px);
  box-shadow: 0 0 25px rgba(139,92,246,0.35), 
              0 0 45px rgba(37,99,235,0.25);
  border: 1px solid rgba(139,92,246,0.4);
  background: inherit; 
}


.step{
  position: relative;
  background: #fff;                
  color: var(--ink);
  border-radius: 18px;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  will-change: transform;
}


.step:hover{
  background: #fff !important;     
  transform: translateY(-6px);
  box-shadow:
    0 0 25px rgba(139,92,246,.28),
    0 0 45px rgba(37,99,235,.22);
  border: 1px solid rgba(139,92,246,.38);
}


.step::after{
  content: "";
  position: absolute;
  inset: -2px;
  border-radius: 20px;
  pointer-events: none;
  box-shadow: 0 0 0 0 rgba(139,92,246,.0);
  opacity: 0;
  transition: opacity .25s ease, box-shadow .25s ease;
}
.step:hover::after{
  opacity: 1;
  box-shadow:
    0 0 22px rgba(139,92,246,.22),
    0 0 36px rgba(37,99,235,.16);
}

/*sección manita  */
.cta-pro{
  position: relative;
  overflow: hidden;
  background: #eef3ff;          
  color: #2b3454;
  text-align: center;
  padding: 84px 0;              
  border-top: 1px solid rgba(15,23,42,.06);
}

.cta-pro .kicker{
  letter-spacing:.28em;
  text-transform:uppercase;
  color:#2563EB;                 
  font-weight:800;
  margin:0 0 10px;
}

.cta-pro .cta-title{
  font-family: "Outfit", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  font-weight: 800;
  line-height: 1.12;
  margin: 0 0 12px;
  color: #0f183a;
  font-size: clamp(1.6rem, 2.2vw + 1rem, 2.4rem);
}

.cta-pro .cta-sub{
  margin: 0 0 18px;
  color: #44507a;
  font-size: clamp(.95rem, .35vw + .8rem, 1.05rem);
}


.cta-pro .cta-ill{
  position: absolute;
  right: max(4vw, 28px);
  bottom: -8%;
  width: min(38vw, 560px);       
  pointer-events: none;          
  filter: drop-shadow(0 24px 36px rgba(2,6,23,.20));
}
.cta-pro .cta-ill img{
  width: 100%;
  height: auto;
  display: block;
}


.cta-pro .btn.primary{
  box-shadow: 0 10px 28px rgba(37,99,235,.25);
}


@media (max-width: 1024px){
  .cta-pro .cta-ill{ width: min(44vw, 480px); bottom: -10%; }
}
@media (max-width: 820px){
  .cta-pro{ padding: 68px 0; }
  .cta-pro .cta-ill{ opacity:.25; right:-12vw; bottom:-18%; width: 78vw; }
}
@media (max-width: 560px){
  .cta-pro .cta-ill{ display:none; }
}


.cta-pro{
  position: relative;
  overflow: hidden;
  background: #eef3ff;
  color: #2b3454;
  text-align: center;
  padding: 84px 0;
  border-top: 1px solid rgba(15,23,42,.06);
}


.cta-pro .cta-sub{
  margin: 0 0 18px;
  color: #44507a;
  font-size: clamp(.95rem, .35vw + .8rem, 1.05rem);
  max-width: 760px;
  margin-inline: auto;
}

.cta-pro .cta-title{
  font-family: "Outfit", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  font-weight: 800;
  line-height: 1.12;
  margin: 0 0 12px;
  color: #0f183a;
  font-size: clamp(1.6rem, 2.2vw + 1rem, 2.4rem);
}


.cta-pro .kicker{
  letter-spacing:.28em;
  text-transform:uppercase;
  color:#2563EB;
  font-weight:800;
  margin:0 0 10px;
}


.cta-pro .cta-ill{
  position: absolute;
  right: max(4vw, 28px);
  bottom: -8%;
  width: min(38vw, 560px);   
  pointer-events: none;
  filter: drop-shadow(0 24px 36px rgba(2,6,23,.20));
}
.cta-pro .cta-ill img{
  width: 100%;
  height: auto;
  display: block;
}


.cta-pro .btn.primary{ box-shadow: 0 10px 28px rgba(37,99,235,.25); }


@media (max-width: 1024px){
  .cta-pro{ padding: 68px 0; }
  .cta-pro .cta-ill{ width: min(44vw, 480px); bottom: -10%; }
}
@media (max-width: 820px){
  .cta-pro .cta-ill{ opacity:.25; right:-12vw; bottom:-18%; width: 78vw; }
}
@media (max-width: 560px){
  .cta-pro .cta-ill{ display:none; }
}


.cta-pro .cta-ill{
  position: absolute;
  right: max(0vw, 0px);   
  bottom: 0%;             
  width: min(32vw, 300px); 
  pointer-events: none;
  filter: drop-shadow(0 18px 28px rgba(2,6,23,.20));
}

.cta-pro .cta-ill img{
  width: 100%;
  height: auto;
  display: block;
}


.faq-grid{
  margin-top: 18px;
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 18px;
}

.faq-item{
  grid-column: span 4;
  background:#fff;
  color:#0e1324;
  border-radius:18px;
  padding:18px 20px;
  box-shadow:0 10px 22px rgba(15,23,42,.08);
  border:1px solid rgba(15,23,42,.06);
  transition: box-shadow .25s ease, transform .25s ease, border-color .25s ease, background .25s ease;
  overflow:hidden;
}

.faq-item:hover{
  transform: translateY(-3px);
  box-shadow: 0 16px 36px rgba(37,99,235,.18);
  border-color: rgba(37,99,235,.25);
  background:#ffffff;
}


.faq-item > summary{
  list-style: none;
  cursor: pointer;
  font-weight: 800;
  margin: 0;
  outline: none;
  position: relative;
  padding-right: 28px; 
}

.faq-item > summary::-webkit-details-marker{ display:none; }

.faq-item > summary::after{
  content:"";
  position:absolute;
  right:0;
  top:8px;
  width:10px; height:10px;
  border-right:2px solid #2563eb;
  border-bottom:2px solid #2563eb;
  transform: rotate(-45deg);
  transition: transform .25s ease, opacity .25s ease;
  opacity:.9;
}

.faq-item[open] > summary::after{
  transform: rotate(45deg);
}


.faq-item .answer{
  display:grid;
  gap:10px;
  margin-top:10px;
  color:#384164;
  animation: faqFade .25s ease both;
}

@keyframes faqFade{
  from{ opacity:0; transform: translateY(-4px); }
  to{ opacity:1; transform: none; }
}


@media (max-width: 1024px){
  .faq-item{ grid-column: span 6; }
}
@media (max-width: 640px){
  .faq-item{ grid-column: span 12; }
}


.faq-grid{
  display: grid;
  grid-template-columns: 1fr 1fr 1fr; 
  gap: 18px;
  align-items: start;  
}


.faq-item{
  display: block;
  background: #fff;
  border-radius: 18px;
  padding: 18px 20px;
  box-shadow: 0 10px 22px rgba(15,23,42,.08);
  border: 1px solid rgba(15,23,42,.06);
  transition: box-shadow .25s ease, transform .25s ease;
}

.faq-item[open]{
  background:#fff;
  box-shadow: 0 16px 32px rgba(37,99,235,.15);
  transform: translateY(-2px);
}


.faq-item > summary{
  cursor:pointer;
  font-weight:800;
  list-style:none;
  outline:none;
  padding-right:28px;
  position:relative;
}

.faq-item > summary::-webkit-details-marker{ display:none; }


.faq-item > summary::after{
  content:"";
  position:absolute;
  right:0; top:8px;
  width:10px; height:10px;
  border-right:2px solid #2563eb;
  border-bottom:2px solid #2563eb;
  transform:rotate(-45deg);
  transition:transform .25s ease;
}

.faq-item[open] > summary::after{
  transform:rotate(45deg);
}


.faq-item .answer{
  margin-top:10px;
  color:#384164;
  font-size:.95rem;
  line-height:1.5;
}


@media(max-width:1024px){
  .faq-grid{ grid-template-columns: 1fr 1fr; }
}
@media(max-width:640px){
  .faq-grid{ grid-template-columns: 1fr; }
}


.contact-slab{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:28px;
  align-items:start;
}


.contact-card{
  background:#fff;
  color:var(--ink);
  border-radius:18px;
  padding:20px 22px;
  box-shadow:0 14px 34px rgba(15,23,42,.18);
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px 14px;
}

.contact-card .tiny{ color:#334063; margin:0 0 4px; font-weight:800; grid-column:span 2 }

.form-row{ display:flex; flex-direction:column; gap:6px }
.form-row label{ font-size:.85rem; color:#47506c; font-weight:600 }
.form-row input,
.form-row textarea{
  width:100%;
  padding:12px 14px;
  border-radius:12px;
  border:1px solid #e6e9f5;
  outline-color:#93c5fd;
  font-family:inherit;
  background:#fbfcff;
}
.form-row.span-2{ grid-column:span 2 }

.btn-block{ width:100%; justify-content:center; grid-column:span 2 }


.contact-aside{
  background:var(--card);
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  padding:22px;
  box-shadow:var(--shadow);
  color:#deebff;
}

.aside-title{
  font-family:Outfit, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  font-weight:800;
  font-size:clamp(1.6rem, 1.6vw + .6rem, 2.2rem);
  margin:2px 0 10px;
}

.aside-sub{ color:#b9c6ee; margin:0 0 14px; max-width:46ch }

.aside-line{
  display:flex; align-items:center; gap:10px;
  padding:10px 0;
  border-top:1px solid rgba(255,255,255,.06);
}
.aside-line:first-of-type{ border-top:0 }
.aside-ico{ width:60px; height:60px; display:block; }

.contact-aside a{
  color:#e6f0ff; text-decoration:none;
}
.contact-aside a:hover{ text-decoration:underline }


@media (max-width:1024px){
  .contact-slab{ grid-template-columns:1fr; }
  .contact-aside{ order:2 }
}

.aside-line {
  display: flex;
  align-items: center;   
  gap: 14px;             
  padding: 14px 0;
  border-top: 1px solid rgba(255,255,255,.06);
}

.aside-line:first-of-type { border-top: 0; }

.aside-ico {
  width: 60px;
  height: 60px;
  flex-shrink: 0;        
  display: block;
}

.contact-aside a {
  color: #e6f0ff;
  text-decoration: none;
  font-size: 1.1rem;     
}

.contact-aside a:hover {
  text-decoration: underline;
}

.aside-line {
  display: flex;
  align-items: center;   
  gap: 14px;
  padding: 12px 0;
  border-top: 1px solid rgba(255,255,255,.06);
}

.aside-line:first-of-type { border-top: 0; }

.aside-ico {
  width: 24px;          
  height: 24px;
  flex-shrink: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}

.aside-ico img {
  width: 100%;
  height: auto;
  display: block;
}

.contact-aside a {
  color: #e6f0ff;
  text-decoration: none;
  font-size: 1rem;
  line-height: 1.4;      
}

.contact-aside a:hover {
  text-decoration: underline;
}


.contact-aside{
  position: relative;
  transition: transform .30s ease, box-shadow .30s ease, border-color .30s ease;
  will-change: transform;
}

.contact-aside:hover{
  transform: translateY(-4px);
  border-color: rgba(139,92,246,.45);
  box-shadow: 0 16px 44px rgba(37,99,235,.32);
}


.contact-aside::after{
  content:"";
  position:absolute;
  inset:-2px;
  border-radius:18px;
  pointer-events:none;
  opacity:0;
  transition: opacity .25s ease, box-shadow .25s ease;
  box-shadow:
    0 0 22px rgba(139,92,246,.22),
    0 0 36px rgba(37,99,235,.16);
}

.contact-aside:hover::after{
  opacity:1;
}


.pro-footer{ background:#0a0f1f; color:#cfe3ff; border-top:1px solid rgba(255,255,255,.06); }
.pro-footer .foot-pro{
  display:grid;
  grid-template-columns: 1.4fr 1fr 1.2fr .8fr; 
  gap: 32px 40px;
  align-items:start;
  padding-top: 28px;
  padding-bottom: 8px;
}

.foot-brand .brand-mark{
  width: 180px; 
  height:auto; display:block; margin-bottom:14px;
}
.foot-brand .brand-copy{ color:#b8c7ea; margin:14px 0 14px; max-width:46ch; line-height:1.5; }


.btn.btn-sm{ padding:.65rem 1rem; font-size:.95rem; box-shadow:0 8px 24px rgba(37,99,235,.28); }

.foot-col h4{
  color:#dbe7ff; margin:2px 0 10px; font-weight:800; font-size:1rem; letter-spacing:.2px;
}
.foot-col a{
  display:block; color:#deebff; opacity:.9; text-decoration:none; padding:6px 0;
  transition:opacity .2s ease, transform .2s ease;
}
.foot-col a:hover{ opacity:1; transform: translateX(2px); }


.foot-legal{ position:relative; padding-bottom:36px; }
.li-badge{
  position:absolute; right:0; bottom:0;
  display:inline-grid; place-items:center;
  width:40px; height:40px; border-radius:10px;
  background: rgba(255,255,255,.04);
  transition: transform .2s ease, box-shadow .3s ease, background .2s ease;
}
.li-badge img{ width:26px; height:auto; display:block; }
.li-badge:hover{
  transform: translateY(-2px) scale(1.05);
  box-shadow: 0 10px 26px rgba(37,99,235,.55), 0 0 0 1px rgba(139,92,246,.35) inset;
  background: rgba(255,255,255,.08);
}


.foot-bottom{
  border-top:1px solid rgba(255,255,255,.06);
  padding:14px 0 26px;
}
.foot-bottom small{ color:#9fb2df; display:block; }


@media (max-width: 1080px){
  .pro-footer .foot-pro{ grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px){
  .pro-footer .foot-pro{ grid-template-columns: 1fr; gap: 24px; }
  .foot-legal{ padding-bottom:56px; }
  .li-badge{ right:2px; }
}


.footer .btn.primary{
  /* base */
  background: transparent !important;
  color: #eaf0ff !important;
  border: 1px solid rgba(255,255,255,.22) !important;
  border-radius: 999px !important;
  padding: 12px 22px !important;
  line-height: 1 !important;
  letter-spacing: .2px;
 
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.06),
    0 12px 28px rgba(2,6,23,.35),
    0 0 0 0 rgba(59,130,246,.0);         
  transition: transform .22s ease, box-shadow .22s ease, background-color .22s ease, border-color .22s ease;
}


.footer .btn.primary:hover{
  background: rgba(255,255,255,.06) !important;
  border-color: rgba(255,255,255,.30) !important;
  transform: translateY(-2px);
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.08),
    0 16px 36px rgba(2,6,23,.50),
    0 0 0 10px rgba(59,130,246,.16);     
}


.footer .btn.primary:active{
  transform: translateY(-1px);
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.08),
    0 10px 26px rgba(2,6,23,.45),
    0 0 0 6px rgba(59,130,246,.14);
}


.footer .btn.primary{
  background: transparent !important;
  color: #eaf0ff !important;
  border: 1px solid rgba(255,255,255,.28) !important;
  border-radius: 999px !important;
  padding: 12px 28px !important;
  font-weight: 700;
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.05),
    0 10px 24px rgba(2,6,23,.30);
  transition: all 0.25s ease;
}


.footer .btn.primary:hover{
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.38) !important;
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.08),
    0 14px 28px rgba(2,6,23,.35);  
}


.footer .btn.primary:active{
  transform: translateY(-1px);
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.08),
    0 10px 22px rgba(2,6,23,.32),
    0 0 0 4px rgba(59,130,246,.10);
}

.footer-logo{
  height: 56px;        
  width: auto;
  display: block;
  filter: drop-shadow(0 0 0 rgba(255,255,255,0));
  transition: filter .25s ease, transform .25s ease;
}

.footer-li img{
  height: 32px;       
  width: auto;
  display: block;
  border-radius: 6px;
  transition: transform .2s ease, box-shadow .25s ease, filter .25s ease;
}
.footer-li:hover img{
  transform: translateY(-1px);
  box-shadow: 0 0 16px rgba(59,130,246,.25);
  filter: brightness(1.05);
}


.site-nav{
  position: sticky;
  top: 0;
  z-index: 1000;
  backdrop-filter: saturate(1.1) blur(10px);
  -webkit-backdrop-filter: saturate(1.1) blur(10px);
  background: rgba(9,14,26,.42);                    
  border-bottom: 1px solid rgba(255,255,255,.06);
  transition: background .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.site-nav .nav-inner{
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 18px;
  padding: 12px 16px;                               
}


.site-nav .logo-img{
  height: 28px;
  width: auto;
  display: block;
  transition: filter .25s ease, opacity .25s ease;
}

/* Links */
.nav-links{
  display: flex;
  justify-content: center;
  gap: 22px;
}
.nav-link{
  position: relative;
  color: #e7eeff;
  text-decoration: none;
  font-weight: 600;
  padding: 8px 6px;
  transition: color .2s ease, opacity .2s ease;
  opacity: .92;
}

.nav-link::after{
  content:"";
  position:absolute; left:0; right:0; bottom:2px;
  height:2px; border-radius:999px;
  background: linear-gradient(90deg, rgba(37,99,235,.0), rgba(37,99,235,.9), rgba(139,92,246,.0));
  transform: scaleX(0);
  transform-origin: center;
  transition: transform .2s ease;
}
.nav-link:hover{ opacity: 1; }
.nav-link:hover::after{ transform: scaleX(1); }


.nav-cta{
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.7rem 1.1rem; border-radius:999px;
  background: #2563eb; color:#fff; font-weight:700;
  box-shadow: 0 8px 22px rgba(37,99,235,.28);
  text-decoration:none; transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.nav-cta:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 26px rgba(37,99,235,.36);
}


.site-nav.scrolled{
  background: rgba(255,255,255,.9);
  border-bottom: 1px solid rgba(15,23,42,.08);
  box-shadow: 0 8px 28px rgba(15,23,42,.18);
  backdrop-filter: blur(10px) saturate(1.2);
  -webkit-backdrop-filter: blur(10px) saturate(1.2);
}
.site-nav.scrolled .nav-link{
  color: #0f183a; opacity: .9;
}
.site-nav.scrolled .nav-link::after{
  background: linear-gradient(90deg, rgba(37,99,235,0), rgba(37,99,235,.9), rgba(139,92,246,0));
}
.site-nav.scrolled .nav-cta{
  background:#0f183a;       
  color:#fff;
  box-shadow: 0 8px 22px rgba(15,23,42,.22);
}


.site-nav.scrolled .logo-img{
  filter: saturate(1.05) contrast(1.05);
}

/* Mobile */
@media (max-width: 900px){
  .nav-links{ display:none; }         
  .site-nav .nav-inner{ grid-template-columns:auto 1fr auto; }
}

.nav-logo-img {
  height: 50px;              
  display: block;
  transition: filter 0.3s ease, transform 0.3s ease;
}

.navbar.scrolled .nav-logo-img {
  filter: brightness(0) invert(1);  
}


.site-header{
  position: sticky; top:0; z-index: 2000;
  height: 72px;
}
.site-header::before{
  content:"";
  position:absolute; inset:0;
  background: rgba(9,12,24,.40);            
  border-bottom: 1px solid rgba(255,255,255,.06);
  transition: background .3s ease, border-color .3s ease, backdrop-filter .3s ease;
  backdrop-filter: none;
}
.site-header .nav-inner{
  position: relative;
  display:grid;
  grid-template-columns: auto 1fr auto;
  align-items:center;
  gap:48px;
  height:72px;
}
.brand img{ display:block; height:42px; width:auto; }

/* links */
.nav-list{ display:flex; gap:32px; list-style:none; margin:0; padding:0; justify-content:center; }
.nav-list a{
  color:#e9eeff;
  font-weight:700;
  text-decoration:none;
  padding:10px 4px;
  position:relative;
  transition: color .2s ease;
}
.nav-list a::after{
  content:""; position:absolute; left:0; right:0; bottom:6px; height:2px;
  background: linear-gradient(90deg, var(--brand), var(--violet));
  transform: scaleX(0); transform-origin: left;
  transition: transform .25s ease; opacity:.9;
}
.nav-list a:hover::after{ transform: scaleX(1); }


.nav-cta{ white-space:nowrap; }


.site-header.is-scrolled::before{
  background: rgba(255,255,255,.72);
  backdrop-filter: blur(10px) saturate(120%);
  border-color: rgba(15,23,42,.10);
}
.site-header.is-scrolled .nav-list a{ color:#0e1324; }
.site-header.is-scrolled .btn.primary{
  box-shadow: 0 8px 20px rgba(37,99,235,.22);
}

.nav-toggle{
  display:none;
  width:44px; height:36px;
  background:transparent; border:0; cursor:pointer;
  position:relative;
}
.nav-toggle span{
  position:absolute; left:8px; right:8px; height:2px; background:#e9eeff; border-radius:2px;
  transition: transform .25s ease, opacity .2s ease, background .25s ease;
}
.nav-toggle span:nth-child(1){ top:10px; }
.nav-toggle span:nth-child(2){ top:17px; }
.nav-toggle span:nth-child(3){ top:24px; }

@media (max-width: 980px){
  .nav-toggle{ display:block; }
  .primary-nav{
    position: fixed; left:0; right:0; top:72px;
    background: rgba(9,12,24,.95);
    transform: translateY(-120%);
    transition: transform .25s ease;
    border-bottom: 1px solid rgba(255,255,255,.06);
  }
  .site-header.is-scrolled .primary-nav{
    background: rgba(255,255,255,.96);
    border-color: rgba(15,23,42,.10);
  }
  .site-header.open .primary-nav{ transform: none; }

  .nav-list{ flex-direction:column; padding:14px 18px; gap:10px; }
  .nav-list a{ padding:12px 4px; }
  .site-header.is-scrolled .nav-list a{ color:#0e1324; }

  
  .site-header.open .nav-toggle span:nth-child(1){ transform: translateY(7px) rotate(45deg); }
  .site-header.open .nav-toggle span:nth-child(2){ opacity:0; }
  .site-header.open .nav-toggle span:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }

 
  .site-header.is-scrolled .nav-toggle span{ background:#0e1324; }
}

.logo-img{ height:36px; width:auto; display:block;
  image-rendering:-webkit-optimize-contrast; image-rendering:crisp-edges; }

.navbar{ position:fixed; top:0; left:0; right:0; z-index:1000; background:transparent; }
.navbar.scrolled::before{
  content:""; position:absolute; inset:0;
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  background: rgba(255,255,255,.6); z-index:-1;
}



.site-header{
  position: sticky; top:0; z-index: 1000;

  height: 72px;
  background: transparent;        
  transition: background .25s ease, box-shadow .25s ease;
}

.site-header .nav-inner{
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
  height: 100%;
  display: flex; align-items: center; gap: 36px;
}


.logo-img{ height: 28px; width: auto; display: block; image-rendering: -webkit-optimize-contrast; }
.logo-dark{ display: none; }   
.logo-light{ display: block; }


.primary-nav{ margin-left: 12px; }
.nav-list{
  display: flex; align-items: center; gap: 44px;
  list-style: none; margin: 0; padding: 0;
}
.nav-list a{
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  font-weight: 700;            
  letter-spacing: .2px;
  font-size: 16px;
  text-decoration: none;
  color: #e9eeff;
  position: relative;
  transition: color .2s ease, opacity .2s ease, transform .2s ease;
}

.nav-list a:hover{
  opacity: .9;
}
.nav-list a::after{
  content:""; position:absolute; left:0; right:0; bottom:-10px; height:2px;
  background: linear-gradient(90deg, #2b6cf6, #8b5cf6);
  transform: scaleX(0); transform-origin: center;
  transition: transform .25s ease;
}
.nav-list a:hover::after{ transform: scaleX(1); }


.nav-cta{ margin-left: auto; }    


.btn.primary.nav-cta{
  padding: 14px 24px;
  border-radius: 999px;
  font-weight: 800;
  box-shadow: 0 10px 28px rgba(37,99,235,.25);
}



.site-header.is-scrolled{
  background: rgba(255,255,255,.86);   /* barra blanca */
  box-shadow: 0 6px 30px rgba(10,17,31,.18);
  backdrop-filter: blur(12px);         /* blur del fondo */
}


.site-header.is-scrolled::after{
  content:""; position:absolute; left:0; right:0; top:100%;
  height: 60px; pointer-events: none;
  background: linear-gradient(180deg, rgba(10,15,31,.45), rgba(10,15,31,0));
}

.site-header.is-scrolled .nav-list a{ color:#0e1324; }
.site-header.is-scrolled .nav-list a::after{
  background: linear-gradient(90deg, #2b6cf6, #8b5cf6);
}
.site-header.is-scrolled .btn.primary.nav-cta{
  box-shadow: 0 10px 24px rgba(43,108,246,.25);
}


.site-header.is-scrolled .logo-light{ display: none; }
.site-header.is-scrolled .logo-dark{ display: block; }


.nav-toggle{ display:none; }


@media (max-width: 960px){
  .nav-toggle{ display:block; margin-left:auto; }
  .primary-nav{ margin-left: 0; }
  .nav-cta{ display:none; } 
}


.site-header{
  position: sticky;
  top: 0;
  z-index: 9999;

  background: transparent;
  transition: background .25s ease, box-shadow .25s ease;
}


.site-header .nav-inner{
  display: flex;
  align-items: center;
  gap: 32px;
  height: 76px;                 
}


.site-header .logo-img{
  height: 28px;                 
  width: auto;
  image-rendering: auto;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}


.primary-nav{ margin-left: 24px; }
.nav-list{
  display: flex;
  align-items: center;
  gap: 44px;                    
  margin: 0;
  padding: 0;
  list-style: none;
}
.nav-list a{
  display: inline-block;
  padding: 10px 0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  font-weight: 700;             
  font-size: 16px;
  letter-spacing: .1px;
  color: rgba(230,238,255,.88);
  text-decoration: none;
  transition: color .2s ease, transform .2s ease, box-shadow .2s ease;
}


.nav-list a:hover{
  color: #ffffff;
  text-shadow: 0 0 16px rgba(79,140,255,.25);
}


.nav-cta{
  margin-left: auto;           
}


.site-header .btn.primary:hover{
  box-shadow: 0 10px 28px rgba(37,99,235,.38);
  transform: translateY(-1px);
}


.site-header.is-scrolled{
  
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  background:
    linear-gradient(180deg,
      rgba(10,14,28,.86) 0%,
      rgba(10,14,28,.74) 55%,
      rgba(10,14,28,0) 100%);
  box-shadow: 0 1px 0 rgba(255,255,255,.06);  
}


.site-header.is-scrolled::after{
  content:"";
  position: absolute;
  left: 0; right: 0; bottom: -1px;
  height: 6px;
  pointer-events: none;
  background: radial-gradient(120% 14px at 50% 0,
              rgba(47,118,255,.22), transparent 70%);
}


@media (max-width: 1024px){
  .nav-cta{ display: none; }           
  .primary-nav{ margin-left: 0; }
  .nav-list{ gap: 24px; }
}




.primary-nav {
  margin-left: 56px; 
}


.nav-list a {
  font-weight: 600; 
  font-size: 16px;
  color: rgba(230,238,255,.88);
}
.nav-list a:hover {
  color: #fff;
  text-shadow: 0 0 14px rgba(79,140,255,.25);
}


.lang-btn {
  margin-left: auto;          
  margin-right: 8px;         
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px 10px;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  font-family: Inter, system-ui;
  font-size: 14px;
  font-weight: 600;
  color: #e6f0ff;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  text-decoration: none;
  transition: all .25s ease;
}
.lang-btn:hover {
  background: rgba(37,99,235,.12);
  border-color: rgba(37,99,235,.35);
  color: #fff;
  box-shadow: 0 0 12px rgba(37,99,235,.4);
}



.site-header .nav-inner{
  display: flex;
  align-items: center;
  justify-content: flex-start;           
  gap: 48px;
}


.site-header .logo{
  display: flex;
  align-items: center;
  flex: 0 0 auto;
}
.site-header .logo-img{
  height: 24px;                           
  width: auto !important;                 
  max-width: none !important;
  object-fit: contain;
}

/* Espacio entre logo y menú */
.site-header .primary-nav{
  flex: 1 1 auto;                         
  margin-left: clamp(48px, 6vw, 96px);   
}

/* Menú horizontal */
.site-header .nav-list{
  display: flex;
  align-items: center;
  gap: clamp(22px, 3.2vw, 44px);         
  margin: 0;
  padding: 0;
  list-style: none;
}

/* Texto menos grueso (forzado) */
.site-header .nav-list a{
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  font-weight: 600 !important;            
  font-size: 16px;
  line-height: 1;
  color: rgba(230,238,255,.92);
  text-decoration: none;
  padding: 14px 4px;
  transition: color .2s ease, text-shadow .2s ease, transform .2s ease;
}
.site-header .nav-list a:hover{
  color: #fff;
  text-shadow: 0 0 14px rgba(79,140,255,.25);
}


.lang-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 999px;
  font-family: Inter, system-ui;
  font-size: 14px;
  font-weight: 600;
  color: #e6f0ff;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  text-decoration: none;
  margin-right: 14px;                    
  transition: all .25s ease;
}
.lang-btn:hover{
  background: rgba(37,99,235,.12);
  border-color: rgba(37,99,235,.35);
  color: #fff;
  box-shadow: 0 0 12px rgba(37,99,235,.40);
}


.nav-cta{ margin-left: 0; }


.site-header{
  position: sticky;
  top: 0;
  z-index: 1000;
}
.site-header.is-scrolled .logo-img{
  height: 30px;                           
}


.site-header .nav-list a {
  font-size: 14px;            
  font-weight: 400 !important; 
  letter-spacing: 0.1px;     
  padding: 10px 2px;           
  color: rgba(230,238,255,.9);
}

.site-header .nav-list a:hover {
  color: #fff;
  text-shadow: 0 0 10px rgba(79,140,255,.25);
}

.site-header .nav-list {
  display: flex;
  gap: 32px; 
}

.site-header .nav-list li {
  white-space: nowrap; 
}

.site-header .nav-list a {
  font-size: 14px;
  font-weight: 400;
  text-decoration: none;
  white-space: nowrap; 
  display: inline-block;
}


:root{ --nav-h: 72px; }           


.site-header{
  position: fixed;  
  top: 0; left: 0; right: 0;
  z-index: 1000;
  height: var(--nav-h);
  display: grid; place-items: center;     
  background: transparent;                
  pointer-events: auto;
}


.site-header::before{
  content:"";
  position: absolute; inset: -6px 0 0 0;  
  background:
    linear-gradient(180deg,
      rgba(9,14,28,.92) 0%,
      rgba(12,18,40,.86) 40%,
      rgba(12,18,40,.00) 100%);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(255,255,255,.06);
  opacity: 0;                              
  transition: opacity .25s ease;
  pointer-events: none;
}


.site-header.is-scrolled::before{ opacity: 1; }


.site-header .nav-inner{
  width: 100%;
  max-width: var(--max, 1200px);
  margin-inline: auto;
  padding: 0 24px;
  display: grid;
  grid-template-columns: auto 1fr auto auto; 
  gap: clamp(24px, 4vw, 42px);
  align-items: center;
}

/* logo: no deformar jamás */
.logo-img{
  height: 36px;                
  width: auto;
  image-rendering: -webkit-optimize-contrast;
  -ms-interpolation-mode: nearest-neighbor;
}


.primary-nav .nav-list{
  display:flex; gap: clamp(28px, 4vw, 46px);
  align-items:center; margin:0; padding:0; list-style:none;
}
.primary-nav .nav-list a{
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  font-weight: 500;              
  font-size: 14px;              
  white-space: nowrap;          
  color: #dfe6ff;
  text-decoration: none;
  opacity:.92;
  transition: opacity .2s ease, transform .2s ease, color .2s ease;
}
.primary-nav .nav-list a:hover{
  opacity:1; transform: translateY(-1px);
}


.lang-switch{
  display:inline-flex; align-items:center; justify-content:center;
  padding: 6px 12px;            
  min-width: 38px;              
  border-radius: 999px;
  background: rgba(17,23,42,.65);
  border: 1px solid rgba(255,255,255,.10);
  color: #e8eeff; font-weight: 600; font-size: 12px; line-height: 1;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
  text-decoration: none;
}
.lang-switch:hover{
  transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(2,6,23,.35);
  background: rgba(17,23,42,.78);
  text-decoration: none;
}


.nav-cta.btn.primary{
  padding: 10px 18px;
  border-radius: 999px;
  font-weight: 700;
  box-shadow: 0 14px 28px rgba(37,99,235,.28);
}


body{ padding-top: var(--nav-h); }


@media (max-width: 1024px){
  .site-header .nav-inner{ grid-template-columns: auto 1fr auto; }
  .lang-switch{ display:none; text-decoration: none; } 
}
@media (max-width: 720px){
  .primary-nav{ display:none; } 
}




.case-study-banner {
  
  background-color: #eef3ff; 
  padding: 4rem 0; 
}


.case-study-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr; 
  gap: 3rem; 
  align-items: center; 
}


.case-study-copy {
  padding-right: 2rem; /
}

.case-study-copy .kicker {
  
  font-size: 0.8rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--color-primary, #dfe6ff); 
  font-weight: 600;
  margin-bottom: 0.5rem;
}

.case-study-title {
 
  font-family: var(--font-outfit, 'Outfit', sans-serif);
  font-size: clamp(1.8rem, 4vw, 2.5rem); 
  font-weight: 700;
  color: #0f183a; 
  line-height: 1.2;
  margin-bottom: 1.5rem;
}


.case-study-ill {
  margin: 0; 
  line-height: 0; 
  
  border-radius: 16px; 
  overflow: hidden; 
}

.case-study-ill img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover; 
}


@media (max-width: 992px) {
  .case-study-banner {
    padding: 3rem 0;
  }
  .case-study-grid {
    
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  .case-study-ill {
    
    order: 1; 
  }
  .case-study-copy {
    order: 2;
    padding-right: 0; 
  }
  .case-study-title {
    font-size: 2rem;
  }
}