/* =========================================================
   REVOK TEKHNOLOGII — Sitio Web Corporativo
   Paleta: Navy profundo · Turquesa eléctrico · Blanco roto
   Tipografía: Sora (display) + Space Grotesk (body) + JetBrains Mono
   ========================================================= */

:root{
  --navy-950:#05081a;
  --navy-900:#0a1230;
  --navy-800:#121a47;
  --navy-700:#1b2766;
  --navy-600:#2a3891;
  --violet:#3b3fd4;
  --teal-500:#17c8c4;
  --teal-400:#2ee6e0;
  --teal-300:#7af7f3;
  --cream:#f5f7fb;
  --white:#ffffff;
  --muted:#8a94b8;
  --ink:#0a1230;
  --radius:18px;
  --radius-lg:28px;
  --maxw:1240px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Space Grotesk', system-ui, sans-serif;
  background:var(--cream);
  color:var(--ink);
  line-height:1.55;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

.container{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,4vw,40px)}

.grad{
  background:linear-gradient(90deg,var(--teal-400) 0%,var(--teal-300) 50%, #b5fffd 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* ============ NAVBAR ============ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:18px 0;
  transition:all .3s ease;
}
.nav--scrolled{
  background:rgba(5,8,26,.85);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  padding:12px 0;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.nav__inner{
  max-width:var(--maxw);margin:0 auto;
  padding:0 clamp(20px,4vw,40px);
  display:flex;align-items:center;justify-content:space-between;gap:30px;
}
.brand{
  display:flex;align-items:center;gap:14px;color:#fff;
  transition:transform .3s;
}
.brand:hover{transform:scale(1.02)}
.brand__mark{
  width:52px;height:52px;
  border-radius:12px;
  overflow:hidden;
  background:#fff;
  display:grid;place-items:center;
  padding:4px;
  box-shadow:
    0 0 0 1px rgba(46,230,224,.3),
    0 8px 24px -8px rgba(46,230,224,.4);
  flex-shrink:0;
}
.brand__mark img{
  width:100%;height:100%;
  object-fit:contain;
  display:block;
}
.brand__text{display:flex;flex-direction:column;line-height:1}
.brand__name{
  font-family:'Sora',sans-serif;font-weight:800;
  font-size:18px;letter-spacing:.14em;color:#fff;
}
.brand__sub{
  font-family:'JetBrains Mono',monospace;font-size:10px;
  color:var(--teal-400);letter-spacing:.3em;margin-top:3px;
}
.brand--light .brand__name,.brand--light .brand__sub{color:#fff}

.nav__menu{display:flex;align-items:center;gap:32px}
.nav__menu a{
  color:rgba(255,255,255,.8);
  font-size:14px;font-weight:500;
  transition:color .2s;
  position:relative;
}
.nav__menu a:not(.nav__cta):hover{color:var(--teal-400)}
.nav__menu a:not(.nav__cta)::after{
  content:"";position:absolute;left:0;bottom:-6px;height:1px;width:0;
  background:var(--teal-400);transition:width .3s;
}
.nav__menu a:not(.nav__cta):hover::after{width:100%}

.nav__cta{
  background:var(--teal-400);
  color:var(--navy-900)!important;
  padding:10px 20px;border-radius:100px;
  font-weight:700;
  transition:all .25s;
}
.nav__cta:hover{
  background:#fff;
  transform:translateY(-2px);
  box-shadow:0 10px 25px -5px rgba(46,230,224,.6);
}

.nav__burger{display:none;flex-direction:column;gap:5px;width:28px}
.nav__burger span{display:block;height:2px;background:#fff;border-radius:2px;transition:all .3s}
.nav__burger--open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__burger--open span:nth-child(2){opacity:0}
.nav__burger--open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ============ HERO ============ */
.hero{
  position:relative;
  min-height:100vh;
  padding:160px 0 120px;
  background:
    radial-gradient(ellipse at 20% 20%, rgba(59,63,212,.35) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 80%, rgba(23,200,196,.25) 0%, transparent 50%),
    linear-gradient(135deg,var(--navy-950) 0%, var(--navy-900) 60%, var(--navy-800) 100%);
  color:#fff;
  overflow:hidden;
  display:flex;flex-direction:column;justify-content:center;
}
.hero__grid-bg{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 60px 60px;
  mask-image: radial-gradient(ellipse at center, black 40%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse at center, black 40%, transparent 80%);
}
.hero__glow{
  position:absolute;
  top:20%;right:-10%;
  width:600px;height:600px;
  background:radial-gradient(circle, rgba(46,230,224,.4) 0%, transparent 70%);
  filter:blur(60px);
  animation: float 8s ease-in-out infinite;
}
@keyframes float{
  0%,100%{transform:translate(0,0)}
  50%{transform:translate(-40px,30px)}
}

.hero__inner{
  position:relative;z-index:2;
  max-width:var(--maxw);margin:0 auto;
  padding:0 clamp(20px,4vw,40px);
  width:100%;
  display:grid;
  grid-template-columns: 1.1fr 1fr;
  gap:clamp(30px,5vw,70px);
  align-items:center;
}
.hero__content{
  grid-column: 1;
}
.hero__visual{
  position:relative;
  grid-column: 2;
  grid-row: 1;
  animation: fadeUp 1s .3s both;
}
.hero__visual-frame{
  position:relative;
  border-radius: 24px;
  overflow:hidden;
  border:1px solid rgba(46,230,224,.2);
  box-shadow:
    0 40px 80px -30px rgba(46,230,224,.35),
    0 0 0 1px rgba(255,255,255,.04);
  background:linear-gradient(135deg, rgba(46,230,224,.08), rgba(59,63,212,.05));
  aspect-ratio: 1 / 1;
}
.hero__visual-frame img{
  width:100%;height:100%;display:block;
  animation: breathe 8s ease-in-out infinite;
}
@keyframes breathe{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.03)}
}

.hero__badge{
  position:absolute;
  background: rgba(5,8,26,.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border:1px solid rgba(46,230,224,.3);
  padding:10px 14px;
  border-radius:14px;
  font-family:'JetBrains Mono',monospace;
  font-size:11px;color:var(--teal-300);
  letter-spacing:.1em;
  display:flex;align-items:center;gap:8px;
  box-shadow:0 10px 30px -10px rgba(0,0,0,.5);
  animation: floatBadge 4s ease-in-out infinite;
}
.hero__badge strong{
  font-family:'Sora',sans-serif;
  font-size:18px;color:#fff;
  font-weight:700;letter-spacing:-.01em;
}
.hero__badge-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--teal-400);
  box-shadow:0 0 8px var(--teal-400);
}
.hero__badge--1{top:8%;left:-10%;animation-delay:0s}
.hero__badge--2{top:40%;right:-14%;animation-delay:1.5s;padding:12px 16px}
.hero__badge--3{bottom:10%;left:-5%;animation-delay:3s}
@keyframes floatBadge{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-8px)}
}

.hero__stats{
  grid-column: 1 / -1;
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:24px;
  padding-top:40px;
  margin-top:30px;
  border-top:1px solid rgba(255,255,255,.1);
  animation: fadeUp .9s .55s both;
}
.hero__tag{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 16px;
  border:1px solid rgba(46,230,224,.4);
  background:rgba(46,230,224,.08);
  border-radius:100px;
  font-family:'JetBrains Mono',monospace;
  font-size:12px;color:var(--teal-300);
  letter-spacing:.1em;
  margin-bottom:32px;
  animation: fadeUp .8s both;
}
.hero__tag .dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--teal-400);
  box-shadow:0 0 12px var(--teal-400);
  animation: pulse 2s infinite;
}
@keyframes pulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.4;transform:scale(.8)}
}

.hero__title{
  font-family:'Sora',sans-serif;
  font-size:clamp(40px, 7vw, 92px);
  font-weight:800;
  line-height:1;
  letter-spacing:-.03em;
  margin-bottom:28px;
  animation: fadeUp .9s .1s both;
}
.hero__title em{
  font-style:italic;font-weight:300;
  color:var(--teal-300);
}
.hero__lead{
  max-width:620px;
  font-size:clamp(16px,1.5vw,19px);
  color:rgba(255,255,255,.75);
  margin-bottom:40px;
  animation: fadeUp .9s .25s both;
}
.hero__lead strong{color:#fff;font-weight:600}

.hero__actions{
  display:flex;gap:16px;flex-wrap:wrap;
  margin-bottom:40px;
  animation: fadeUp .9s .4s both;
}

.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 28px;border-radius:100px;
  font-weight:600;font-size:15px;
  transition:all .3s;
  cursor:pointer;
  border:1px solid transparent;
}
.btn svg{width:18px;height:18px;transition:transform .3s}
.btn:hover svg{transform:translateX(4px)}
.btn--primary{
  background:var(--teal-400);
  color:var(--navy-900);
}
.btn--primary:hover{
  background:#fff;
  box-shadow:0 15px 40px -10px rgba(46,230,224,.6);
  transform:translateY(-3px);
}
.btn--ghost{
  background:transparent;
  color:#fff;
  border-color:rgba(255,255,255,.25);
}
.btn--ghost:hover{
  background:rgba(255,255,255,.08);
  border-color:#fff;
}
.btn--block{width:100%;justify-content:center}

.stat__num{
  font-family:'Sora',sans-serif;
  font-size:clamp(36px,4vw,56px);
  font-weight:800;color:var(--teal-400);
  line-height:1;margin-bottom:8px;
  letter-spacing:-.03em;
}
.stat__lbl{
  font-size:13px;color:rgba(255,255,255,.6);
  line-height:1.4;
}

.hero__scroll{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:10px;
  font-family:'JetBrains Mono',monospace;
  font-size:11px;color:rgba(255,255,255,.5);
  letter-spacing:.2em;
}
.hero__scroll-line{
  width:1px;height:50px;
  background:linear-gradient(to bottom, var(--teal-400), transparent);
  animation: scrollLine 2s infinite;
}
@keyframes scrollLine{
  0%{transform:scaleY(0);transform-origin:top}
  50%{transform:scaleY(1);transform-origin:top}
  51%{transform-origin:bottom}
  100%{transform:scaleY(0);transform-origin:bottom}
}
@keyframes fadeUp{
  from{opacity:0;transform:translateY(30px)}
  to{opacity:1;transform:translateY(0)}
}

/* ============ MARQUEE ============ */
.marquee{
  background:var(--navy-900);
  padding:22px 0;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
  overflow:hidden;
}
.marquee__track{
  display:flex;gap:40px;align-items:center;
  animation: scroll 40s linear infinite;
  white-space:nowrap;
  width:max-content;
}
.marquee__track span{
  font-family:'Sora',sans-serif;
  font-weight:700;font-size:clamp(20px,2.4vw,30px);
  color:rgba(255,255,255,.15);
  letter-spacing:.02em;
}
.marquee__track span:nth-child(even){
  color:var(--teal-400);font-size:14px;
}
@keyframes scroll{
  to{transform:translateX(-50%)}
}

/* ============ SECTION LABELS ============ */
.section__label{
  display:inline-block;
  font-family:'JetBrains Mono',monospace;
  font-size:12px;letter-spacing:.25em;
  color:var(--violet);
  text-transform:uppercase;
  margin-bottom:20px;
  padding-bottom:8px;
  border-bottom:1px solid currentColor;
}
.section__label.light{color:var(--teal-400)}
.section__title{
  font-family:'Sora',sans-serif;
  font-size:clamp(32px,5vw,64px);
  font-weight:800;line-height:1.05;
  letter-spacing:-.025em;
  margin-bottom:24px;
  color:var(--navy-900);
}
.section__title.light{color:#fff}
.section__p{
  font-size:clamp(15px,1.3vw,17px);
  max-width:620px;
  color:var(--muted);
  margin-bottom:16px;
}
.section__p.light{color:rgba(255,255,255,.7)}

/* ============ ABOUT ============ */
.about{padding:clamp(80px,10vw,140px) 0}
.about__grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(40px,6vw,80px);align-items:start;
}
.about__right{display:flex;flex-direction:column;gap:20px}

.card{
  background:#fff;
  padding:40px;
  border-radius:var(--radius-lg);
  position:relative;
  border:1px solid rgba(10,18,48,.08);
  transition:all .4s;
}
.card:hover{
  transform:translateY(-6px);
  box-shadow:0 25px 50px -20px rgba(10,18,48,.25);
  border-color:var(--teal-400);
}
.card--mv h3{
  font-family:'Sora',sans-serif;
  font-size:28px;font-weight:700;
  margin-bottom:14px;
  color:var(--navy-900);
}
.card__badge{
  position:absolute;top:-20px;left:40px;
  width:50px;height:50px;border-radius:50%;
  background:var(--navy-900);color:var(--teal-400);
  display:grid;place-items:center;
  font-family:'Sora',sans-serif;font-weight:800;font-size:24px;
  box-shadow:0 10px 30px -8px rgba(10,18,48,.4);
}
.card--accent{
  background:linear-gradient(135deg,var(--navy-900),var(--navy-700));
  color:#fff;
}
.card--accent h3{color:#fff}
.card--accent .card__badge{background:var(--teal-400);color:var(--navy-900)}
.card--accent p{color:rgba(255,255,255,.8)}
.card--accent strong{color:var(--teal-400)}
.card p{color:var(--muted);line-height:1.7}
.card--accent p{color:rgba(255,255,255,.82)}

/* ============ SERVICES ============ */
.services{
  padding:clamp(80px,10vw,140px) 0;
  background:
    radial-gradient(ellipse at top right, rgba(59,63,212,.3) 0%, transparent 50%),
    radial-gradient(ellipse at bottom left, rgba(23,200,196,.2) 0%, transparent 50%),
    var(--navy-950);
  color:#fff;
  position:relative;
  overflow:hidden;
}
.services::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: radial-gradient(ellipse at center, black 20%, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse at center, black 20%, transparent 70%);
  pointer-events:none;
}
.services > *{position:relative;z-index:2}
.services__head{max-width:780px;margin-bottom:70px}
.services__grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:24px;
}

.svc{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  padding:40px;
  border-radius:var(--radius-lg);
  position:relative;
  overflow:hidden;
  transition:all .4s;
  backdrop-filter: blur(10px);
}
.svc__img{
  margin:-40px -40px 30px;
  aspect-ratio: 16/9;
  overflow:hidden;
  position:relative;
  border-bottom:1px solid rgba(46,230,224,.15);
}
.svc__img img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  transition:transform .6s ease;
}
.svc:hover .svc__img img{
  transform:scale(1.05);
}
.svc__img::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 60%, rgba(5,8,26,.6));
  pointer-events:none;
}
.svc::before{
  content:"";
  position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent, var(--teal-400), transparent);
  transform:scaleX(0);transform-origin:left;
  transition:transform .5s;
}
.svc:hover{
  background:rgba(255,255,255,.05);
  border-color:var(--teal-400);
  transform:translateY(-8px);
}
.svc:hover::before{transform:scaleX(1)}
.svc__num{
  font-family:'JetBrains Mono',monospace;
  font-size:12px;color:var(--teal-400);
  letter-spacing:.2em;
  margin-bottom:20px;
}
.svc__icon{
  width:60px;height:60px;
  border-radius:16px;
  background:linear-gradient(135deg,var(--teal-500),var(--teal-400));
  color:var(--navy-900);
  display:grid;place-items:center;
  margin-bottom:24px;
  box-shadow:0 15px 40px -10px rgba(46,230,224,.5);
}
.svc__icon svg{width:30px;height:30px}
.svc h3{
  font-family:'Sora',sans-serif;
  font-size:26px;font-weight:700;
  margin-bottom:14px;color:#fff;
  line-height:1.2;
}
.svc__desc{
  color:rgba(255,255,255,.65);
  margin-bottom:22px;
  font-size:15px;
}
.svc__list{
  list-style:none;display:flex;flex-direction:column;gap:10px;
}
.svc__list li{
  padding-left:22px;position:relative;
  font-size:14px;color:rgba(255,255,255,.85);
  line-height:1.5;
}
.svc__list li::before{
  content:"";position:absolute;left:0;top:8px;
  width:10px;height:2px;background:var(--teal-400);
}
.svc__list strong{color:var(--teal-300);font-weight:600}

/* ============ CLIENTS ============ */
.clients{padding:clamp(80px,10vw,140px) 0;background:var(--cream)}
.clients__grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:20px;margin-top:60px;
}
.client{
  background:#fff;
  padding:30px;
  border-radius:var(--radius);
  border:1px solid rgba(10,18,48,.08);
  transition:all .4s;
  display:flex;flex-direction:column;gap:14px;
  position:relative;
  overflow:hidden;
}
.client::after{
  content:"";
  position:absolute;top:0;right:0;
  width:0;height:0;
  border-top:40px solid transparent;
  border-right:40px solid var(--teal-400);
  opacity:0;transition:opacity .3s;
}
.client:hover{
  transform:translateY(-6px);
  box-shadow:0 25px 40px -20px rgba(10,18,48,.2);
  border-color:var(--violet);
}
.client:hover::after{opacity:1}
.client__logo{
  font-family:'Sora',sans-serif;
  font-weight:800;font-size:18px;
  color:var(--navy-900);
  letter-spacing:.05em;
  line-height:1.2;
}
.client__country{
  font-family:'JetBrains Mono',monospace;
  font-size:11px;color:var(--violet);
  letter-spacing:.15em;
}
.client p{
  font-size:14px;color:var(--muted);line-height:1.55;
  margin-top:auto;
}
.client strong{color:var(--navy-900);font-weight:600}
.client--hl{
  background:linear-gradient(135deg,var(--navy-900),var(--navy-700));
  color:#fff;
  border-color:transparent;
}
.client--hl .client__logo{color:#fff}
.client--hl .client__country{color:var(--teal-400)}
.client--hl p{color:rgba(255,255,255,.8)}
.client--hl strong{color:var(--teal-300)}

/* ============ GOALS ============ */
.goals{
  padding:clamp(80px,10vw,140px) 0;
  background:
    radial-gradient(ellipse at top, rgba(59,63,212,.25), transparent 60%),
    linear-gradient(180deg,var(--navy-950),var(--navy-900));
  color:#fff;
}
.goals__head{max-width:720px;margin-bottom:70px}
.goals__grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:20px;
}
.goal{
  grid-column:span 2;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  padding:40px;
  border-radius:var(--radius-lg);
  transition:all .4s;
  position:relative;
}
.goal--wide{grid-column:1/-1}
.goal:hover{
  background:rgba(46,230,224,.06);
  border-color:var(--teal-400);
}
.goal__num{
  font-family:'Sora',sans-serif;
  font-weight:800;
  font-size:clamp(48px,5vw,72px);
  color:transparent;
  -webkit-text-stroke:1.5px var(--teal-400);
  line-height:1;
  display:block;
  margin-bottom:20px;
  letter-spacing:-.03em;
}
.goal h3{
  font-family:'Sora',sans-serif;
  font-size:clamp(20px,2vw,26px);
  font-weight:700;
  margin-bottom:14px;
  line-height:1.2;
}
.goal p{color:rgba(255,255,255,.7);font-size:15px;line-height:1.65}

/* ============ CTA ============ */
.cta{
  position:relative;
  padding:clamp(80px,10vw,140px) 0;
  background:var(--cream);
  overflow:hidden;
}
.cta__bg{
  position:absolute;inset:0;
  background:
    radial-gradient(circle at 15% 40%, rgba(59,63,212,.15), transparent 40%),
    radial-gradient(circle at 85% 70%, rgba(23,200,196,.18), transparent 40%);
  pointer-events:none;
}
.cta__inner{position:relative;z-index:2;max-width:860px}
.cta__label{
  display:inline-block;
  font-family:'JetBrains Mono',monospace;
  font-size:12px;letter-spacing:.25em;
  color:var(--violet);
  text-transform:uppercase;
  margin-bottom:20px;
  padding-bottom:8px;
  border-bottom:1px solid currentColor;
}
.cta__title{
  font-family:'Sora',sans-serif;
  font-size:clamp(32px,5vw,58px);
  font-weight:800;line-height:1.05;
  letter-spacing:-.025em;
  color:var(--navy-900);
  margin-bottom:20px;
}
.cta__p{
  color:var(--muted);
  font-size:17px;
  max-width:560px;
  margin-bottom:50px;
}
.cta__form{
  display:grid;grid-template-columns:1fr 1fr;
  gap:20px;
  background:#fff;
  padding:44px;
  border-radius:var(--radius-lg);
  box-shadow:0 30px 60px -30px rgba(10,18,48,.2);
  border:1px solid rgba(10,18,48,.06);
}
.field{display:flex;flex-direction:column;gap:8px}
.field:nth-child(3),.field:nth-child(4){grid-column:1/-1}
.field label{
  font-size:12px;
  font-family:'JetBrains Mono',monospace;
  letter-spacing:.12em;
  color:var(--navy-900);
  text-transform:uppercase;
}
.field input, .field textarea{
  padding:14px 16px;
  border:1px solid rgba(10,18,48,.12);
  border-radius:12px;
  font-family:inherit;
  font-size:15px;
  color:var(--ink);
  background:var(--cream);
  transition:all .2s;
  outline:none;
  resize:vertical;
}
.field input:focus, .field textarea:focus{
  border-color:var(--teal-500);
  background:#fff;
  box-shadow:0 0 0 4px rgba(23,200,196,.15);
}
.cta__form .btn{grid-column:1/-1}
.cta__ok{
  grid-column:1/-1;
  padding:14px;
  background:rgba(23,200,196,.1);
  color:var(--teal-500);
  border-radius:12px;
  font-weight:600;text-align:center;
  border:1px solid var(--teal-400);
}

.cta__info{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:24px;margin-top:50px;
  padding-top:40px;
  border-top:1px solid rgba(10,18,48,.1);
}
.info__k{
  font-family:'JetBrains Mono',monospace;
  font-size:11px;letter-spacing:.2em;
  color:var(--violet);
  text-transform:uppercase;
  margin-bottom:6px;
}
.info__v{
  font-weight:600;color:var(--navy-900);
  font-size:15px;
}

/* ============ FOOTER ============ */
.footer{
  background:var(--navy-950);color:#fff;
  padding:80px 0 30px;
}
.footer__grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
  gap:50px;
  padding-bottom:50px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.footer__brand p{
  margin-top:20px;color:rgba(255,255,255,.6);
  max-width:320px;font-size:14px;
}
.footer__col h4{
  font-family:'Sora',sans-serif;
  font-size:14px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--teal-400);
  margin-bottom:18px;
}
.footer__col a{
  display:block;
  color:rgba(255,255,255,.7);
  font-size:14px;
  margin-bottom:12px;
  transition:color .2s;
}
.footer__col a:hover{color:var(--teal-400)}
.footer__base{
  max-width:var(--maxw);margin:0 auto;
  padding:25px clamp(20px,4vw,40px) 0;
  display:flex;justify-content:space-between;gap:20px;
  font-size:12px;color:rgba(255,255,255,.4);
  flex-wrap:wrap;
}
.footer__mono{
  font-family:'JetBrains Mono',monospace;
  letter-spacing:.15em;
  color:var(--teal-400);
}

/* ============ ABOUT VISUAL ============ */
.about__visual{
  margin-top:40px;
  position:relative;
  border-radius:var(--radius-lg);
  overflow:hidden;
  background:linear-gradient(135deg, var(--navy-900), var(--navy-700));
  border:1px solid rgba(46,230,224,.2);
  box-shadow:0 30px 60px -30px rgba(10,18,48,.4);
  aspect-ratio: 1 / 1;
  max-width:380px;
}
.about__visual img{
  width:100%;height:100%;
  display:block;
  object-fit:cover;
}
.about__visual-tag{
  position:absolute;
  bottom:16px;left:16px;right:16px;
  background:rgba(5,8,26,.85);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  padding:10px 14px;
  border-radius:12px;
  font-family:'JetBrains Mono',monospace;
  font-size:11px;
  color:var(--teal-300);
  letter-spacing:.05em;
  display:flex;align-items:center;gap:10px;
  border:1px solid rgba(46,230,224,.2);
}
.about__visual-tag span{
  width:8px;height:8px;border-radius:50%;
  background:var(--teal-400);
  box-shadow:0 0 10px var(--teal-400);
  flex-shrink:0;
}

/* ============ POR QUÉ ELEGIRNOS ============ */
.why{
  padding:clamp(80px,10vw,140px) 0;
  background:var(--cream);
  position:relative;
}
.why__grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-top:60px;
}
.why__card{
  background:#fff;
  padding:36px 32px;
  border-radius:var(--radius-lg);
  border:1px solid rgba(10,18,48,.08);
  transition:all .4s;
  position:relative;
  overflow:hidden;
}
.why__card::before{
  content:"";
  position:absolute;top:0;left:0;
  width:100%;height:3px;
  background:linear-gradient(90deg, var(--teal-400), var(--violet));
  transform:scaleX(0);transform-origin:left;
  transition:transform .5s ease;
}
.why__card:hover{
  transform:translateY(-6px);
  box-shadow:0 25px 50px -20px rgba(10,18,48,.2);
  border-color:var(--teal-400);
}
.why__card:hover::before{transform:scaleX(1)}
.why__icon{
  width:56px;height:56px;
  border-radius:14px;
  background:linear-gradient(135deg, var(--navy-900), var(--navy-700));
  color:var(--teal-400);
  display:grid;place-items:center;
  margin-bottom:22px;
  box-shadow:0 10px 25px -8px rgba(10,18,48,.3);
}
.why__icon svg{width:28px;height:28px}
.why__card h3{
  font-family:'Sora',sans-serif;
  font-size:20px;font-weight:700;
  margin-bottom:12px;
  color:var(--navy-900);
  line-height:1.2;
}
.why__card p{
  color:var(--muted);
  font-size:14.5px;
  line-height:1.65;
}

/* ============ TESTIMONIOS ============ */
.testimonials{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-top:60px;
  padding-top:60px;
  border-top:1px solid rgba(10,18,48,.1);
}
.testimonial{
  background:linear-gradient(135deg, var(--navy-900), var(--navy-700));
  color:#fff;
  padding:36px;
  border-radius:var(--radius-lg);
  position:relative;
  overflow:hidden;
  transition:transform .4s;
}
.testimonial::before{
  content:"";
  position:absolute;top:0;right:0;
  width:120px;height:120px;
  background:radial-gradient(circle, rgba(46,230,224,.25), transparent 70%);
  pointer-events:none;
}
.testimonial:hover{transform:translateY(-6px)}
.testimonial__quote{
  width:32px;height:32px;
  color:var(--teal-400);
  margin-bottom:20px;
  opacity:.7;
}
.testimonial p{
  font-size:15px;
  line-height:1.7;
  color:rgba(255,255,255,.88);
  margin-bottom:26px;
  font-style:italic;
}
.testimonial__author{
  display:flex;align-items:center;gap:14px;
  padding-top:22px;
  border-top:1px solid rgba(255,255,255,.12);
}
.testimonial__avatar{
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg, var(--teal-500), var(--teal-400));
  color:var(--navy-900);
  display:grid;place-items:center;
  font-family:'Sora',sans-serif;
  font-weight:800;font-size:18px;
  flex-shrink:0;
}
.testimonial__author strong{
  display:block;
  font-family:'Sora',sans-serif;
  font-size:15px;font-weight:700;
  color:#fff;
  margin-bottom:2px;
}
.testimonial__author span{
  font-size:12px;
  color:var(--teal-300);
  font-family:'JetBrains Mono',monospace;
  letter-spacing:.05em;
}

/* ============ FLOATING ELEMENTS ============ */
.floating-wa{
  position:fixed;
  bottom:24px;right:24px;
  width:60px;height:60px;
  border-radius:50%;
  background:#25D366;
  color:#fff;
  display:grid;place-items:center;
  z-index:99;
  box-shadow:
    0 10px 30px -5px rgba(37,211,102,.5),
    0 0 0 0 rgba(37,211,102,.7);
  transition:all .3s;
  animation: waPulse 2s infinite;
}
.floating-wa svg{width:32px;height:32px}
.floating-wa:hover{
  transform:scale(1.1);
  animation:none;
}
.floating-wa__tooltip{
  position:absolute;
  right:72px;
  background:var(--navy-900);
  color:#fff;
  padding:8px 14px;
  border-radius:8px;
  font-size:13px;font-weight:600;
  white-space:nowrap;
  opacity:0;
  pointer-events:none;
  transform:translateX(10px);
  transition:all .3s;
}
.floating-wa__tooltip::after{
  content:"";
  position:absolute;
  right:-6px;top:50%;
  transform:translateY(-50%);
  border:6px solid transparent;
  border-left-color:var(--navy-900);
}
.floating-wa:hover .floating-wa__tooltip{
  opacity:1;
  transform:translateX(0);
}
@keyframes waPulse{
  0%{box-shadow:0 10px 30px -5px rgba(37,211,102,.5), 0 0 0 0 rgba(37,211,102,.7)}
  70%{box-shadow:0 10px 30px -5px rgba(37,211,102,.5), 0 0 0 15px rgba(37,211,102,0)}
  100%{box-shadow:0 10px 30px -5px rgba(37,211,102,.5), 0 0 0 0 rgba(37,211,102,0)}
}

.floating-top{
  position:fixed;
  bottom:100px;right:24px;
  width:48px;height:48px;
  border-radius:50%;
  background:var(--navy-900);
  color:var(--teal-400);
  display:grid;place-items:center;
  z-index:98;
  box-shadow:0 10px 25px -5px rgba(10,18,48,.4);
  opacity:0;
  pointer-events:none;
  transform:translateY(20px);
  transition:all .3s;
  border:1px solid rgba(46,230,224,.3);
}
.floating-top svg{width:20px;height:20px}
.floating-top--show{
  opacity:1;
  pointer-events:auto;
  transform:translateY(0);
}
.floating-top:hover{
  background:var(--teal-400);
  color:var(--navy-900);
  transform:translateY(-4px);
}

/* ============ REVEAL ANIMATIONS ============ */
.reveal{
  opacity:0;transform:translateY(30px);
  transition:opacity .8s ease, transform .8s ease;
}
.reveal.is-in{opacity:1;transform:translateY(0)}

/* ============ RESPONSIVE ============ */
@media (max-width:1000px){
  .hero__inner{
    grid-template-columns: 1fr;
    gap:50px;
  }
  .hero__visual{
    grid-column: 1;
    grid-row: 2;
    max-width:460px;
    margin:0 auto;
    width:100%;
  }
  .hero__content{grid-column: 1; grid-row: 1}
  .hero__stats{grid-row: 3}
  .hero__badge--1{left:4%}
  .hero__badge--2{right:4%}
  .hero__badge--3{left:8%}
  .about__visual{max-width:100%}
  .services__grid{grid-template-columns:1fr}
  .clients__grid{grid-template-columns:repeat(2,1fr)}
  .goals__grid{grid-template-columns:1fr 1fr}
  .goal{grid-column:1/-1}
  .why__grid{grid-template-columns:repeat(2,1fr)}
  .testimonials{grid-template-columns:1fr;gap:20px}
  .footer__grid{grid-template-columns:1fr 1fr;gap:40px}
  .about__grid{grid-template-columns:1fr;gap:50px}
}
@media (max-width:760px){
  .nav__menu{
    position:fixed;top:70px;left:0;right:0;
    flex-direction:column;gap:0;
    background:rgba(5,8,26,.95);
    backdrop-filter:blur(20px);
    padding:20px;
    transform:translateY(-20px);opacity:0;
    pointer-events:none;
    transition:all .3s;
    border-bottom:1px solid rgba(255,255,255,.08);
  }
  .nav__menu--open{transform:translateY(0);opacity:1;pointer-events:auto}
  .nav__menu a{
    width:100%;padding:16px 0;
    border-bottom:1px solid rgba(255,255,255,.05);
  }
  .nav__menu a:last-child{border-bottom:none}
  .nav__cta{text-align:center;margin-top:10px;width:100%}
  .nav__burger{display:flex}
  .hero{padding:140px 0 80px;min-height:auto}
  .hero__stats{grid-template-columns:repeat(2,1fr);gap:20px}
  .hero__actions{flex-direction:column;align-items:stretch}
  .hero__actions .btn{justify-content:center}
  .clients__grid{grid-template-columns:1fr}
  .goals__grid{grid-template-columns:1fr}
  .cta__form{grid-template-columns:1fr;padding:30px}
  .field:nth-child(3),.field:nth-child(4){grid-column:auto}
  .cta__info{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr;gap:30px}
  .card{padding:30px}
  .svc{padding:30px}
  .svc__img{margin:-30px -30px 24px}
  .goal{padding:30px}
  .hero__badge{padding:8px 12px;font-size:10px}
  .hero__badge strong{font-size:16px}
  .why__grid{grid-template-columns:1fr}
  .why__card{padding:28px 24px}
  .testimonial{padding:28px}
  .floating-wa{width:54px;height:54px;bottom:18px;right:18px}
  .floating-wa svg{width:28px;height:28px}
  .floating-wa__tooltip{display:none}
  .floating-top{width:42px;height:42px;bottom:84px;right:18px}
}
@media (max-width:420px){
  .brand__name{font-size:16px}
  .brand__sub{font-size:9px}
  .hero__tag{font-size:11px}
}
