/* ============================================================
   INGNOVA — ingnovacr.com · Landing
   Moderna, audaz, responsive
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Rokkitt:wght@400;500;600;700;800;900&family=Source+Serif+4:ital,opsz,wght@0,8..60,400;0,8..60,500;0,8..60,600;1,8..60,400&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

:root{
  --navy:#0C1B4E; --navy-800:#0A1640; --navy-900:#070F2B; --navy-950:#050A1E;
  --azure:#1E88C7; --azure-bright:#39A7E0; --azure-deep:#0E5C8C;
  --steel:#4A5160; --steel-2:#727A88; --fog:#F1F2F4; --fog-2:#E7E9ED; --line:#D7DAE0;
  --paper:#FBFBFC; --ink:#14171D; --white:#FFFFFF;
  --display:'Rokkitt',Georgia,serif;
  --serif:'Source Serif 4',Georgia,serif;
  --mono:'IBM Plex Mono',ui-monospace,monospace;
  --maxw:1240px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
body{font-family:var(--serif);color:var(--ink);background:var(--paper);line-height:1.6;overflow-x:hidden;}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
::selection{background:var(--azure);color:#fff;}

/* lang toggle visibility */
body[data-lang="es"] .en{display:none;}
body[data-lang="en"] .es{display:none;}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,56px);}
.eyebrow{font-family:var(--mono);font-size:clamp(11px,1.1vw,13px);letter-spacing:.28em;text-transform:uppercase;color:var(--azure-deep);font-weight:500;}
.section{padding:clamp(72px,10vw,140px) 0;}
.section-head{max-width:760px;margin-bottom:clamp(36px,5vw,64px);}
.section-head h2{font-family:var(--display);font-weight:800;font-size:clamp(30px,5vw,52px);line-height:1.05;color:var(--navy);letter-spacing:-.01em;margin-top:14px;}
.section-head p{font-size:clamp(15px,1.6vw,19px);color:var(--steel);margin-top:18px;line-height:1.6;}
.accent-line{width:54px;height:4px;background:var(--azure);border-radius:3px;}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:13px;letter-spacing:.08em;text-transform:uppercase;font-weight:500;padding:15px 26px;border-radius:8px;border:1.5px solid transparent;cursor:pointer;transition:transform .25s var(--ease),background .25s,border-color .25s,color .25s;white-space:nowrap;}
.btn:active{transform:translateY(1px);}
.btn-primary{background:var(--azure);color:#fff;}
.btn-primary:hover{background:var(--azure-bright);transform:translateY(-2px);box-shadow:0 10px 30px -8px rgba(30,136,199,.6);}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.35);}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08);transform:translateY(-2px);}
.btn-dark{background:var(--navy);color:#fff;}
.btn-dark:hover{background:var(--navy-800);transform:translateY(-2px);box-shadow:0 10px 30px -8px rgba(12,27,78,.5);}
.btn-wa{background:#25D366;color:#06351a;}
.btn-wa:hover{background:#2bdd6f;transform:translateY(-2px);box-shadow:0 10px 30px -8px rgba(37,211,102,.5);}

/* ---------- HEADER ---------- */
header{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .35s,box-shadow .35s,padding .35s;padding:18px 0;}
header.scrolled{background:rgba(7,15,43,.86);backdrop-filter:blur(14px);box-shadow:0 1px 0 rgba(255,255,255,.08);padding:11px 0;}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px;}
.nav .logo{height:34px;width:auto;transition:height .35s;}
header.scrolled .nav .logo{height:30px;}
.nav-links{display:flex;align-items:center;gap:34px;}
.nav-links a{font-family:var(--mono);font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.8);transition:color .2s;position:relative;white-space:nowrap;}
.nav-links a::after{content:'';position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--azure);transition:width .25s var(--ease);}
.nav-links a:hover{color:#fff;}
.nav-links a:hover::after{width:100%;}
.nav-right{display:flex;align-items:center;gap:16px;}
.lang{display:flex;align-items:center;gap:2px;font-family:var(--mono);font-size:12px;border:1px solid rgba(255,255,255,.25);border-radius:7px;overflow:hidden;}
.lang button{background:transparent;border:0;color:rgba(255,255,255,.6);padding:7px 11px;cursor:pointer;font-family:var(--mono);font-size:12px;letter-spacing:.05em;transition:background .2s,color .2s;}
.lang button.active{background:var(--azure);color:#fff;}
.menu-btn{display:none;background:transparent;border:0;cursor:pointer;flex-direction:column;gap:5px;padding:6px;}
.menu-btn span{width:24px;height:2px;background:#fff;border-radius:2px;transition:.3s;}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;color:#fff;overflow:hidden;}
.hero-bg{position:absolute;inset:0;z-index:0;}
.hero-bg img{width:100%;height:100%;object-fit:cover;}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(100deg,var(--navy-950) 0%,rgba(7,15,43,.92) 38%,rgba(7,15,43,.6) 66%,rgba(7,15,43,.3) 100%);}
.hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(100deg,var(--navy-950) 0%,rgba(7,15,43,.9) 40%,rgba(7,15,43,.55) 68%,rgba(7,15,43,.25) 100%),linear-gradient(0deg,rgba(5,10,30,.6) 0%,transparent 30%);}
.hero-grid{position:absolute;inset:0;z-index:1;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:64px 64px;opacity:.7;}
.hero .wrap{position:relative;z-index:2;padding-top:120px;padding-bottom:80px;width:100%;}
.hero-inner{max-width:880px;}
.hero h1{font-family:var(--display);font-weight:800;font-size:clamp(40px,7.2vw,86px);line-height:1.02;letter-spacing:-.02em;margin:22px 0 0;}
.hero h1 .hl{color:var(--azure-bright);}
.hero p.lead{font-size:clamp(16px,2vw,22px);color:#C2C9DB;max-width:620px;margin-top:26px;line-height:1.55;}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;margin-top:38px;}
.hero-trust{display:flex;gap:28px;flex-wrap:wrap;margin-top:46px;padding-top:28px;border-top:1px solid rgba(255,255,255,.14);}
.hero-trust .t{display:flex;flex-direction:column;gap:3px;}
.hero-trust .t b{font-family:var(--display);font-weight:700;font-size:clamp(22px,3vw,32px);color:#fff;line-height:1;}
.hero-trust .t span{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--steel-2);}
.scroll-ind{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:2;font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.5);display:flex;flex-direction:column;align-items:center;gap:8px;}
.scroll-ind .dot{width:5px;height:5px;border-radius:50%;background:var(--azure-bright);animation:sdrop 1.8s var(--ease) infinite;}
@keyframes sdrop{0%{transform:translateY(0);opacity:0;}30%{opacity:1;}100%{transform:translateY(14px);opacity:0;}}

/* ---------- SERVICES ---------- */
.services{background:var(--white);}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:16px;overflow:hidden;}
.svc{background:var(--white);padding:clamp(28px,3.4vw,42px);transition:background .3s;position:relative;}
.svc:hover{background:var(--fog);}
.svc .ic{width:46px;height:46px;margin-bottom:22px;color:var(--azure);}
.svc .ic svg{width:100%;height:100%;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;}
.svc h3{font-family:var(--display);font-weight:700;font-size:clamp(19px,2vw,23px);color:var(--navy);}
.svc p{font-size:15px;color:var(--steel);margin-top:10px;line-height:1.55;}
.svc .no{position:absolute;top:24px;right:28px;font-family:var(--mono);font-size:12px;color:var(--line);}

/* ---------- PROJECTS ---------- */
.projects{background:var(--navy-950);color:#fff;position:relative;overflow:hidden;}
.projects .section-head h2{color:#fff;}
.projects .section-head p{color:#AEB6CC;}
.proj-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(14px,1.8vw,22px);}
.proj{position:relative;border-radius:14px;overflow:hidden;background:var(--navy-900);min-height:230px;}
.proj img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;transition:transform .9s var(--ease);}
.proj:hover img{transform:scale(1.06);}
.proj::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(5,10,30,.92) 0%,rgba(5,10,30,.15) 55%,transparent 100%);}
.proj .cap{position:absolute;left:0;right:0;bottom:0;padding:22px 24px;z-index:2;}
.proj .cap .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--azure-bright);}
.proj .cap .t{font-family:var(--display);font-weight:700;font-size:clamp(17px,1.7vw,21px);margin-top:4px;}
.proj.big{grid-column:span 6;min-height:clamp(300px,38vw,470px);}
.proj.med{grid-column:span 6;}
.proj.third{grid-column:span 4;}
@media(min-width:781px){.proj.med{grid-column:span 3;}}

/* ---------- ABOUT ---------- */
.about{background:var(--white);}
.about-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,5vw,80px);align-items:center;}
.about-media{position:relative;border-radius:18px;overflow:hidden;aspect-ratio:4/5;}
.about-media img{width:100%;height:100%;object-fit:cover;}
.about-media .badge{position:absolute;left:22px;bottom:22px;background:rgba(7,15,43,.82);backdrop-filter:blur(8px);border-radius:12px;padding:16px 20px;color:#fff;}
.about-media .badge b{font-family:var(--display);font-weight:800;font-size:30px;line-height:1;display:block;}
.about-media .badge span{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--azure-bright);}
.about h2{font-family:var(--display);font-weight:800;font-size:clamp(28px,4vw,46px);line-height:1.06;color:var(--navy);margin-top:14px;letter-spacing:-.01em;}
.about p{font-size:clamp(15px,1.5vw,17.5px);color:var(--steel);margin-top:20px;line-height:1.65;}
.vals{display:grid;grid-template-columns:1fr 1fr;gap:22px 26px;margin-top:34px;}
.vals .v .h{display:flex;align-items:center;gap:9px;font-family:var(--display);font-weight:700;font-size:17px;color:var(--navy);}
.vals .v .h .dot{width:8px;height:8px;border-radius:50%;background:var(--azure);}
.vals .v p{font-size:14px;color:var(--steel);margin-top:6px;}

/* ---------- WHY ---------- */
.why{background:var(--navy);color:#fff;position:relative;overflow:hidden;}
.why .mapwm{position:absolute;right:-6%;top:50%;transform:translateY(-50%);height:120%;opacity:.06;pointer-events:none;}
.why .wrap{position:relative;z-index:2;}
.why .section-head h2{color:#fff;}
.why .section-head p{color:#AEB6CC;}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,2.4vw,34px);}
.why-item{padding-top:26px;border-top:2px solid rgba(255,255,255,.16);transition:border-color .3s;}
.why-item:hover{border-color:var(--azure);}
.why-item .n{font-family:var(--mono);font-size:12px;color:var(--azure-bright);letter-spacing:.1em;}
.why-item h3{font-family:var(--display);font-weight:700;font-size:clamp(19px,2vw,24px);margin-top:14px;}
.why-item p{font-size:14.5px;color:#AEB6CC;margin-top:10px;line-height:1.55;}

/* ---------- CONTACT ---------- */
.contact{background:var(--fog);}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,72px);align-items:start;}
.contact h2{font-family:var(--display);font-weight:800;font-size:clamp(30px,4.6vw,52px);line-height:1.04;color:var(--navy);margin-top:14px;letter-spacing:-.01em;}
.contact .lead{font-size:clamp(15px,1.6vw,18px);color:var(--steel);margin-top:18px;}
.contact-cards{display:flex;flex-direction:column;gap:14px;margin-top:34px;}
.cc{display:flex;gap:16px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px 20px;transition:transform .25s var(--ease),box-shadow .25s;}
.cc:hover{transform:translateY(-2px);box-shadow:0 12px 30px -14px rgba(12,27,78,.3);}
.cc .ci{width:42px;height:42px;flex:0 0 42px;border-radius:10px;background:var(--navy);display:flex;align-items:center;justify-content:center;color:#fff;}
.cc .ci svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;}
.cc .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--steel-2);}
.cc .v{font-family:var(--display);font-weight:600;font-size:16px;color:var(--navy);margin-top:2px;}
form.cform{background:#fff;border:1px solid var(--line);border-radius:18px;padding:clamp(26px,3vw,38px);}
.field{margin-bottom:18px;}
.field label{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--steel-2);margin-bottom:8px;}
.field input,.field textarea{width:100%;font-family:var(--serif);font-size:15.5px;color:var(--ink);background:var(--fog);border:1.5px solid transparent;border-radius:10px;padding:13px 15px;transition:border-color .2s,background .2s;}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--azure);background:#fff;}
.field textarea{resize:vertical;min-height:120px;}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.cform .actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:8px;}

/* ---------- FOOTER ---------- */
footer{background:var(--navy-950);color:#fff;padding:clamp(54px,7vw,84px) 0 34px;}
.foot-top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.12);}
.foot-brand img{height:42px;margin-bottom:18px;}
.foot-brand p{color:#8C96B4;font-size:14px;max-width:300px;}
.foot-cols{display:flex;gap:clamp(40px,6vw,90px);flex-wrap:wrap;}
.foot-col h4{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--azure-bright);margin-bottom:16px;}
.foot-col a,.foot-col span{display:block;color:#AEB6CC;font-size:14.5px;margin-bottom:11px;transition:color .2s;}
.foot-col a:hover{color:#fff;}
.foot-bottom{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;padding-top:26px;font-family:var(--mono);font-size:11.5px;letter-spacing:.08em;color:var(--steel-2);text-transform:uppercase;}
.foot-bottom a{color:var(--azure-bright);}

/* ---------- SCROLL REVEAL ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease);}
.reveal.in{opacity:1;transform:none;}
.reveal[data-d="1"]{transition-delay:.08s;}
.reveal[data-d="2"]{transition-delay:.16s;}
.reveal[data-d="3"]{transition-delay:.24s;}
.reveal[data-d="4"]{transition-delay:.32s;}
.reveal[data-d="5"]{transition-delay:.4s;}

/* ---------- RESPONSIVE ---------- */
@media(max-width:980px){
  .svc-grid{grid-template-columns:repeat(2,1fr);}
  .why-grid{grid-template-columns:repeat(2,1fr);}
  .about-grid{grid-template-columns:1fr;}
  .about-media{aspect-ratio:16/10;max-height:440px;}
  .contact-grid{grid-template-columns:1fr;}
  .proj.big{grid-column:span 12;}
  .proj.med{grid-column:span 6;}
  .proj.third{grid-column:span 6;}
}
@media(max-width:780px){
  .nav-links{position:fixed;inset:0 0 auto 0;top:0;flex-direction:column;align-items:flex-start;gap:0;background:var(--navy-950);padding:90px 32px 32px;transform:translateY(-100%);transition:transform .4s var(--ease);height:100vh;justify-content:center;}
  .nav-links.open{transform:translateY(0);}
  .nav-links a{font-size:20px;padding:16px 0;}
  .nav-links a::after{display:none;}
  .menu-btn{display:flex;}
  .menu-btn.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
  .menu-btn.open span:nth-child(2){opacity:0;}
  .menu-btn.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
  .nav .desk-cta{display:none;}
  .row2{grid-template-columns:1fr;}
  .vals{grid-template-columns:1fr;}
}
@media(max-width:520px){
  .svc-grid{grid-template-columns:1fr;}
  .why-grid{grid-template-columns:1fr;}
  .proj.med,.proj.third{grid-column:span 12;}
  .hero-trust{gap:20px;}
}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none;}
  .scroll-ind .dot{animation:none;}
  html{scroll-behavior:auto;}
}
