/* ============================================================
   FUENTE "NEW ORDER" (Newlyn foundry — Miles Newlyn / Rutherford Craze)
   Es una fuente de pago, no está en Google Fonts ni puede
   cargarse desde un CDN público. Para usarla en serio:
   1) Comprá la licencia web en https://newlyn.com (o vía Adobe Fonts
      si tenés Creative Cloud, que la incluye para sync+web).
   2) Si la conseguís en archivos .woff2, descomentá el @font-face
      de abajo y subí los archivos junto al sitio.
   3) Si la activás por Adobe Fonts (CDN con <link> de tu kit),
      borrá este @font-face y usá el font-family que te da Adobe.
   Mientras tanto, el sitio cae a Bricolage Grotesque como fallback
   para que el prototipo se vea completo.
   ============================================================ */
/*
@font-face{
  font-family:'New Order';
  src:url('fonts/NewOrder-Regular.woff2') format('woff2');
  font-weight:400; font-style:normal; font-display:swap;
}
@font-face{
  font-family:'New Order';
  src:url('fonts/NewOrder-Bold.woff2') format('woff2');
  font-weight:700; font-style:normal; font-display:swap;
}
*/
:root{
  --bg:#0b0b0e;
  --bg-soft:#13131a;
  --bg-card:#15151d;
  --fg:#f4f2ed;
  --fg-muted:#92929b;
  --fg-dim:#54545e;
  --accent:#2b5fff;
  --accent-soft:rgba(43,95,255,.14);
  --accent-2:#f4f2ed;
  --line:#24242c;
  --r-display: 'New Order', 'Bricolage Grotesque', sans-serif;
  --r-body: 'Manrope', sans-serif;
  --r-mono: 'Space Mono', monospace;
  --container: 1320px;
  --gutter: clamp(20px, 5vw, 64px);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:auto;}
body{
  background:var(--bg);
  color:var(--fg);
  font-family:var(--r-body);
  overflow-x:hidden;
  cursor:none;
}
::selection{background:var(--accent);color:#fff;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
.wrap{max-width:var(--container);margin:0 auto;padding:0 var(--gutter);}
.eyebrow{
  font-family:var(--r-mono);
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--fg-muted);
  display:flex;align-items:center;gap:10px;
}
.eyebrow::before{content:'';width:18px;height:1px;background:var(--accent);display:inline-block;}

/* CUSTOM CURSOR */
.cursor-dot, .cursor-ring{
  position:fixed;top:0;left:0;pointer-events:none;z-index:999;
  border-radius:50%;
  transform:translate(-50%,-50%);
}
.cursor-dot{width:6px;height:6px;background:var(--fg);}
.cursor-ring{width:34px;height:34px;border:1px solid rgba(244,242,237,.35);transition:width .25s,height .25s,border-color .25s,background .25s;}
.cursor-ring.is-active{width:64px;height:64px;background:var(--accent-soft);border-color:var(--accent);}
@media(max-width:900px){.cursor-dot,.cursor-ring{display:none;}body{cursor:auto;}}

/* LOADER */
#loader{
  position:fixed;inset:0;background:var(--bg);z-index:1000;
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:18px;
}
#loader .r-mark{font-family:var(--r-display);font-weight:700;font-size:clamp(40px, 9vw, 130px);line-height:.8;color:transparent;
  -webkit-text-stroke:1px var(--fg);letter-spacing:.01em;white-space:nowrap;}
#loader .pct{font-family:var(--r-mono);font-size:13px;color:var(--fg-muted);letter-spacing:.1em;}

/* NAV */
header.nav{
  position:fixed;top:0;left:0;right:0;z-index:80;
  display:flex;align-items:center;justify-content:space-between;
  padding:26px var(--gutter);
  mix-blend-mode:normal;
}
.logo{display:flex;align-items:center;}
.logo svg{height:28px;width:auto;display:block;}
.foot-logo svg{height:38px;width:auto;display:block;margin-bottom:18px;}
.nav-links{display:flex;gap:36px;font-size:14px;color:var(--fg-muted);}
.nav-links a{position:relative;padding:4px 0;}
.nav-links a::after{content:'';position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--accent);transition:width .3s;}
.nav-links a:hover{color:var(--fg);}
.nav-links a:hover::after{width:100%;}
.nav-cta{
  font-family:var(--r-mono);font-size:12px;letter-spacing:.06em;
  border:1px solid var(--line);padding:10px 18px;border-radius:30px;
  display:flex;align-items:center;gap:8px;
}
.nav-cta:hover{border-color:var(--accent);}


/* HAMBURGER + MOBILE MENU */
.hamburger{
  display:none;
  position:relative;z-index:120;
  width:40px;height:40px;
  align-items:center;justify-content:center;
  background:none;border:none;cursor:pointer;padding:0;
}
.hamburger span{
  display:block;position:absolute;width:22px;height:1.5px;background:var(--fg);
  transition:transform .35s ease, opacity .25s ease, top .35s ease;
}
.hamburger span:nth-child(1){top:15px;}
.hamburger span:nth-child(2){top:50%;transform:translateY(-50%);}
.hamburger span:nth-child(3){bottom:15px;}
.hamburger.open span:nth-child(1){top:50%;transform:translateY(-50%) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){bottom:auto;top:50%;transform:translateY(-50%) rotate(-45deg);}

.mobile-menu{
  position:fixed;inset:0;z-index:110;
  background:var(--bg);
  display:flex;flex-direction:column;justify-content:center;
  padding:0 var(--gutter);
  opacity:0;pointer-events:none;
  transform:translateY(-12px);
  transition:opacity .35s ease, transform .35s ease;
}
.mobile-menu.open{opacity:1;pointer-events:auto;transform:translateY(0);}
.mobile-menu nav{display:flex;flex-direction:column;gap:4px;}
.mobile-menu .mm-link{
  font-family:var(--r-display);font-weight:600;font-size:18px;
  color:var(--fg);padding:14px 0;border-bottom:1px solid var(--line);
}
.mobile-menu .mm-cta{
  margin-top:28px;align-self:flex-start;
}

/* Hamburguesa visible solo en mobile/tablet */
@media(max-width:900px){
  .hamburger{ display:flex; }
  .nav-cta{ display:none; }
  .nav-links{ display:none; }
}
@media(min-width:901px){
  .mobile-menu{ display:none; }
}


/* HERO */
section.hero{
  position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:center;
  padding:140px var(--gutter) 80px;overflow:hidden;
}
.hero-video{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;
  filter:grayscale(.25) brightness(.55) contrast(1.05);
}
.hero-video-overlay{
  position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg, rgba(11,11,14,.5) 0%, rgba(11,11,14,.35) 40%, var(--bg) 96%),
    linear-gradient(90deg, rgba(11,11,14,.75) 0%, rgba(11,11,14,.15) 55%);
}
.hero-r-bg{
  position:absolute;right:-2vw;top:50%;transform:translateY(-50%);
  font-family:var(--r-display);font-weight:700;font-size:21vw;line-height:1;letter-spacing:.01em;
  color:transparent;-webkit-text-stroke:1px var(--line);white-space:nowrap;
  z-index:2;pointer-events:none;user-select:none;
}
.hero-content{position:relative;z-index:3;max-width:980px;}
.hero h1{
  font-family:var(--r-display);
  font-weight:600;
  font-size:clamp(48px, 8.6vw, 118px);
  line-height:.97;
  letter-spacing:-.01em;
  margin-top:24px;
}
.hero h1 .accent{color:var(--accent);font-style:italic;font-weight:500;}
.hero .sub{
  margin-top:28px;max-width:520px;font-size:clamp(16px,1.6vw,19px);color:var(--fg-muted);line-height:1.6;
}
.hero-cta-row{display:flex;align-items:center;gap:22px;margin-top:48px;flex-wrap:wrap;}
.btn-primary{
  font-family:var(--r-mono);font-size:13px;letter-spacing:.04em;
  background:var(--fg);color:var(--bg);
  padding:18px 30px;border-radius:40px;
  display:inline-flex;align-items:center;gap:10px;
  transition:background .3s, color .3s, transform .3s;
}
.btn-primary:hover{background:var(--accent);color:#fff;transform:translateY(-2px);}
.btn-ghost{
  font-family:var(--r-mono);font-size:13px;letter-spacing:.04em;color:var(--fg-muted);
  display:inline-flex;align-items:center;gap:10px;border-bottom:1px solid var(--line);padding-bottom:6px;
  transition:color .3s,border-color .3s;
}
.btn-ghost:hover{color:var(--fg);border-color:var(--fg);}
.hero-scroll{
  position:absolute;bottom:40px;left:var(--gutter);z-index:3;
  display:flex;align-items:center;gap:10px;color:var(--fg-dim);
  font-family:var(--r-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
}
.hero-scroll .line{width:1px;height:40px;background:var(--fg-dim);position:relative;overflow:hidden;}
.hero-scroll .line::after{content:'';position:absolute;top:0;left:0;width:100%;height:14px;background:var(--accent);animation:scrollline 1.8s ease-in-out infinite;}
@keyframes scrollline{0%{transform:translateY(-14px);}100%{transform:translateY(40px);}}

/* SECTION GENERIC */
section{position:relative;padding:160px var(--gutter);}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;margin-bottom:80px;flex-wrap:wrap;}
.section-head h2{
  font-family:var(--r-display);font-weight:600;font-size:clamp(34px,5vw,64px);line-height:1.04;letter-spacing:-.01em;margin-top:18px;max-width:680px;
}
.section-head p{max-width:340px;color:var(--fg-muted);font-size:15px;line-height:1.7;}

/* QUIENES SOMOS */
.about{background:var(--bg-soft);}
.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:start;}
.def-card{
  border:1px solid var(--line);border-radius:24px;padding:48px;background:var(--bg-card);
}
.def-card .word{font-family:var(--r-display);font-size:clamp(36px,4.2vw,54px);font-style:italic;color:var(--accent);}
.def-card .pos{font-family:var(--r-mono);font-size:12px;color:var(--fg-dim);margin-left:8px;}
.def-card ol{margin-top:22px;padding-left:22px;color:var(--fg-muted);font-size:16px;line-height:1.8;}
.def-card ol li{margin-bottom:10px;}
.def-card ol li::marker{color:var(--accent);font-family:var(--r-mono);font-size:14px;}
.about-lines{display:flex;flex-direction:column;gap:36px;justify-content:center;height:100%;}
.about-lines p{font-family:var(--r-display);font-weight:500;font-size:clamp(20px,2.6vw,28px);line-height:1.4;}
.about-lines p span{color:var(--fg-dim);font-weight:400;}
.about-stats{display:flex;gap:50px;margin-top:50px;flex-wrap:wrap;}
.stat b{font-family:var(--r-display);font-size:38px;display:block;}
.stat span{font-family:var(--r-mono);font-size:11px;letter-spacing:.1em;color:var(--fg-muted);text-transform:uppercase;}


/* SERVICIOS */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:20px;overflow:hidden;}
.s-card{
  background:var(--bg);padding:40px 32px;min-height:220px;
  display:flex;flex-direction:column;justify-content:space-between;
  position:relative;overflow:hidden;transition:background .35s;
}
.s-card::before{
  content:'';position:absolute;inset:0;background:var(--accent);transform:translateY(101%);transition:transform .45s cubic-bezier(.7,0,.2,1);z-index:0;
}
.s-card:hover::before{transform:translateY(0);}
.s-card .num{font-family:var(--r-mono);font-size:12px;color:var(--fg-dim);position:relative;z-index:1;transition:color .35s;}
.s-card:hover .num{color:rgba(255,255,255,.7);}
.s-card h3{font-family:var(--r-display);font-weight:600;font-size:23px;margin-top:auto;position:relative;z-index:1;transition:color .35s;}
.s-card:hover h3{color:#fff;}
.s-card p{font-size:13.5px;color:var(--fg-muted);margin-top:10px;position:relative;z-index:1;transition:color .35s;line-height:1.5;}
.s-card:hover p{color:rgba(255,255,255,.85);}



/* PROCESO */
.process{background:var(--bg-soft);}
.process-track{position:relative;}
.process-svg{position:absolute;left:0;top:0;width:100%;height:100%;z-index:0;}
.process-list{display:flex;flex-direction:column;gap:0;position:relative;z-index:1;}
.p-step{display:grid;grid-template-columns:90px 1fr 1fr;gap:24px;padding:38px 0;border-top:1px solid var(--line);align-items:center;}
.p-step:last-child{border-bottom:1px solid var(--line);}
.p-step .pnum{font-family:var(--r-mono);font-size:13px;color:var(--accent);}
.p-step h4{font-family:var(--r-display);font-weight:600;font-size:26px;}
.p-step p{color:var(--fg-muted);font-size:14.5px;line-height:1.6;max-width:380px;}


/* TRABAJOS desktop: pin GSAP activo solo >900px (ver JS) */
.work-pin{height:100vh;display:flex;flex-direction:column;justify-content:center;padding:0;overflow:hidden;}
.work-head{padding:0 var(--gutter);margin-bottom:50px;}
.work-track{display:flex;gap:28px;padding-left:var(--gutter);width:max-content;}
.work-swipe-hint{display:none;}
.work-card{width:min(560px,80vw);flex-shrink:0;border-radius:20px;overflow:hidden;position:relative;border:1px solid var(--line);background:var(--bg-card);}
.work-card .ph{aspect-ratio:4/3;background:linear-gradient(135deg,#1a1a22,#0d0d12);position:relative;overflow:hidden;}
.work-card .ph::after{content:attr(data-tag);position:absolute;bottom:16px;left:16px;font-family:var(--r-mono);font-size:11px;letter-spacing:.08em;color:var(--fg-dim);text-transform:uppercase;}
.work-card .ph .glow{position:absolute;width:160%;height:160%;top:-30%;left:-30%;background:radial-gradient(circle at 30% 30%,var(--accent-soft),transparent 60%);transition:transform .6s;}
.work-card:hover .glow{transform:scale(1.15) rotate(10deg);}
.work-info{padding:24px 26px;display:flex;justify-content:space-between;align-items:flex-start;}
.work-info h4{font-family:var(--r-display);font-size:21px;font-weight:600;}
.work-info span{font-family:var(--r-mono);font-size:11px;color:var(--fg-muted);}

/* TRABAJOS ≤900px: scroll táctil nativo, sin pin */
@media(max-width:900px){
  .work-pin{
    height:auto !important;
    overflow:visible;
    padding:80px 0;
    display:block;
  }
  .work-head{margin-bottom:24px;}
  .work-head h2{font-size:clamp(22px,7vw,36px);}
  .work-swipe-hint{display:block;margin-top:10px;font-family:var(--r-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-dim);}
  .work-track{
    display:flex !important;
    width:100% !important;
    max-width:100vw !important;
    overflow-x:scroll !important;
    overflow-y:visible;
    -webkit-overflow-scrolling:touch;
    scroll-snap-type:x mandatory;
    padding:4px var(--gutter) 16px;
    gap:14px;
    scrollbar-width:none;
    /* cancelar transform de GSAP si quedara alguno */
    transform:none !important;
  }
  .work-track::-webkit-scrollbar{display:none;}
  .work-card{
    min-width:min(280px,72vw) !important;
    width:min(280px,72vw) !important;
    flex-shrink:0;
    scroll-snap-align:start;
  }
  .work-info{padding:14px 16px;flex-direction:column;gap:4px;}
  .work-info h4{font-size:15px;}
  .work-info span{font-size:10px;}
}

/* POR QUE ELEGIRNOS */
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;}
.why-item{border-top:1px solid var(--line);border-right:1px solid var(--line);padding:48px 40px;display:flex;gap:28px;align-items:flex-start;}
.why-item:nth-child(2n){border-right:none;}
.why-mark{width:46px;height:46px;flex-shrink:0;}
.why-item h4{font-family:var(--r-display);font-size:21px;font-weight:600;margin-bottom:10px;}
.why-item p{color:var(--fg-muted);font-size:14.5px;line-height:1.6;}
.why-item{border-right:none;}

/* TESTIMONIOS */
.testi{background:var(--bg-soft);}
.testi-quote{font-family:var(--r-display);font-weight:500;font-size:clamp(26px,3.6vw,44px);line-height:1.3;max-width:920px;}
.testi-quote .mark{color:var(--accent);font-style:italic;}
.testi-meta{display:flex;align-items:center;gap:16px;margin-top:36px;}
.testi-meta .av{width:46px;height:46px;border-radius:50%;background:var(--accent-soft);border:1px solid var(--accent);}
.testi-meta b{font-size:14px;}
.testi-meta span{font-family:var(--r-mono);font-size:12px;color:var(--fg-muted);}
.testi-dots{display:flex;gap:10px;margin-top:50px;}
.testi-dots span{width:8px;height:8px;border-radius:50%;background:var(--line);cursor:pointer;}
.testi-dots span.active{background:var(--accent);}

/* CLIENTES marquee */
.clients{padding:100px var(--gutter);border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;}
.marquee{display:flex;gap:90px;width:max-content;animation:scrollx 26s linear infinite;}
@keyframes scrollx{from{transform:translateX(0);}to{transform:translateX(-50%);}}
.marquee span{font-family:var(--r-display);font-weight:700;font-size:30px;color:var(--fg-dim);transition:color .3s;white-space:nowrap;}
.marquee span:hover{color:var(--fg);}

/* CTA GIGANTE */
.big-cta{padding-top:160px;padding-bottom:0;display:flex;flex-direction:column;align-items:center;text-align:center;position:relative;}
.big-cta h2{
  font-family:var(--r-display);font-weight:600;font-size:clamp(54px,11vw,150px);line-height:.92;letter-spacing:-.01em;
}
.big-cta h2 i{color:var(--accent);font-style:italic;font-weight:500;}
.big-cta p{margin-top:26px;color:var(--fg-muted);font-size:17px;}

/* FORMULARIO DE CONTACTO */
.contact-form{
  width:100%;max-width:640px;margin:64px auto 0;text-align:left;
}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:0 40px;}
.cf-field{position:relative;margin-bottom:38px;}
.cf-field.full{grid-column:1 / -1;}
.cf-field input,
.cf-field textarea{
  width:100%;background:transparent;border:none;border-bottom:1px solid var(--line);
  color:var(--fg);font-family:var(--r-body);font-size:17px;padding:10px 0 12px;
  outline:none;transition:border-color .3s;resize:none;
}
.cf-field textarea{min-height:64px;}
.cf-field input:focus,
.cf-field textarea:focus{border-color:var(--accent);}
.cf-field label{
  position:absolute;left:0;top:10px;
  font-family:var(--r-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--fg-dim);pointer-events:none;transition:transform .25s ease, color .25s ease;
  transform-origin:left top;
}
.cf-field input:focus + label,
.cf-field input:not(:placeholder-shown) + label,
.cf-field textarea:focus + label,
.cf-field textarea:not(:placeholder-shown) + label{
  transform:translateY(-22px) scale(.86);color:var(--accent);
}
.cf-submit{
  margin-top:8px;border:none;cursor:pointer;
  font-family:var(--r-mono);font-size:13px;letter-spacing:.04em;
  background:var(--fg);color:var(--bg);
  padding:18px 30px;border-radius:40px;
  display:inline-flex;align-items:center;gap:10px;
  transition:background .3s, color .3s, transform .3s;
}
.cf-submit:hover{background:var(--accent);color:#fff;transform:translateY(-2px);}
.cf-note{margin-top:18px;font-family:var(--r-mono);font-size:11px;color:var(--fg-dim);letter-spacing:.02em;}
.cf-status{margin-top:16px;font-size:14px;color:var(--fg-muted);display:none;}
.cf-status.show{display:block;}
.cf-status.ok{color:var(--accent);}

/* FOOTER */
footer{position:relative;padding:90px var(--gutter) 40px;overflow:hidden;border-top:1px solid var(--line);}
.foot-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:40px;position:relative;z-index:1;}
.foot-col h5{font-family:var(--r-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-dim);margin-bottom:18px;}
.foot-col a, .foot-col p{display:block;color:var(--fg-muted);font-size:14.5px;margin-bottom:10px;}
.foot-col a:hover{color:var(--fg);}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:90px;padding-top:24px;border-top:1px solid var(--line);font-family:var(--r-mono);font-size:11px;color:var(--fg-dim);position:relative;z-index:1;flex-wrap:wrap;gap:12px;}
.foot-r{
  position:absolute;bottom:-6vw;left:50%;transform:translateX(-50%);
  font-family:var(--r-display);font-weight:700;font-size:13vw;line-height:1;letter-spacing:.01em;
  color:transparent;-webkit-text-stroke:1px var(--line);white-space:nowrap;z-index:0;pointer-events:none;user-select:none;
}

/* El texto es visible por defecto SIEMPRE (sin depender de que JS/GSAP carguen).
   La animación de scroll-reveal se aplica solo si GSAP confirma estar disponible
   (ver script al final del documento), nunca al revés. */
.reveal{opacity:1;}

/* ============================================================
   RESPONSIVE MOBILE — 480px y menos
   Todas las secciones se apilan verticalmente, textos escalados,
   grids colapsados, espaciados reducidos.
   ============================================================ */
@media(max-width:480px){

  /* VARIABLES MOBILE */
  :root{
    --gutter: 20px;
  }

  /* NAV */
  header.nav{
    padding: 18px var(--gutter);
  }
  .nav-cta{
    display: none;
  }
  .logo svg{
    height: 22px;
  }

  /* LOADER */
  #loader .r-mark{
    font-size: clamp(32px, 14vw, 52px);
  }

  /* HERO */
  section.hero{
    padding: 110px var(--gutter) 70px;
    min-height: 100svh;
  }
  .hero h1{
    font-size: clamp(38px, 11vw, 52px);
    line-height: 1.05;
  }
  .hero .sub{
    font-size: 15px;
    margin-top: 18px;
  }
  .hero-cta-row{
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
    margin-top: 32px;
  }
  .btn-primary{
    width: 100%;
    justify-content: center;
    padding: 16px 24px;
  }
  .hero-r-bg{
    font-size: 52vw;
    right: -8vw;
    opacity: .5;
  }
  .hero-scroll{ bottom: 24px; }

  /* SECCIONES — padding general */
  section{
    padding: 80px var(--gutter);
  }

  /* SECTION HEAD */
  .section-head{
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
    margin-bottom: 40px;
  }
  .section-head h2{
    font-size: clamp(26px, 8vw, 38px);
    margin-top: 12px;
  }
  .section-head p{
    max-width: 100%;
    font-size: 14px;
  }

  /* QUIÉNES SOMOS */
  .about-grid{
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .def-card{
    padding: 28px 22px;
  }
  .def-card .word{
    font-size: 32px;
  }
  .def-card ol{
    font-size: 14px;
  }
  .about-lines p{
    font-size: 18px;
  }
  .about-stats{
    gap: 28px;
    margin-top: 32px;
    flex-wrap: wrap;
  }
  .stat b{
    font-size: 28px;
  }
  .stat span{
    font-size: 10px;
  }

  /* SERVICIOS */
  .services-grid{
    grid-template-columns: 1fr;
    border-radius: 16px;
  }
  .s-card{
    padding: 28px 22px;
    min-height: 140px;
  }
  .s-card h3{
    font-size: 19px;
  }
  .s-card p{
    font-size: 13px;
  }

  /* PROCESO */
  .process-list{
    gap: 0;
  }
  .p-step{
    grid-template-columns: 1fr;
    gap: 6px;
    padding: 24px 0;
  }
  .p-step h4{
    font-size: 20px;
  }
  .p-step p{
    font-size: 13.5px;
    max-width: 100%;
  }
  .p-step .pnum{
    font-size: 11px;
  }

  /* POR QUÉ ERRE */
  .why-grid{
    grid-template-columns: 1fr;
  }
  .why-item{
    border-right: none;
    padding: 28px 0;
    gap: 18px;
    flex-direction: row;
    align-items: flex-start;
  }
  .why-item h4{
    font-size: 17px;
  }
  .why-item p{
    font-size: 13.5px;
  }
  .why-mark{
    width: 36px;
    height: 36px;
    flex-shrink: 0;
    margin-top: 2px;
  }

  /* TESTIMONIOS */
  .testi-quote{
    font-size: clamp(18px, 5.5vw, 26px);
    line-height: 1.45;
  }
  .testi-meta{
    margin-top: 24px;
    gap: 12px;
  }
  .testi-meta b{
    font-size: 13px;
  }
  .testi-dots{
    margin-top: 32px;
  }

  /* CLIENTES MARQUEE */
  .clients{
    padding: 60px 0;
  }
  .marquee span{
    font-size: 20px;
  }
  .marquee{
    gap: 50px;
  }

  /* CTA GIGANTE */
  .big-cta{
    padding-top: 80px;
    padding-left: var(--gutter);
    padding-right: var(--gutter);
    text-align: left;
    align-items: flex-start;
  }
  .big-cta .eyebrow{
    justify-content: flex-start;
  }
  .big-cta h2{
    font-size: clamp(36px, 11vw, 54px);
    line-height: .98;
  }
  .big-cta p{
    font-size: 14px;
    margin-top: 16px;
  }

  /* FORMULARIO */
  .contact-form{
    margin-top: 40px;
  }
  .cf-row{
    grid-template-columns: 1fr;
    gap: 0;
  }
  .cf-field.full{
    grid-column: 1;
  }
  .cf-field input,
  .cf-field textarea{
    font-size: 15px;
  }
  .cf-submit{
    width: 100%;
    justify-content: center;
  }

  /* FOOTER */
  footer{
    padding: 60px var(--gutter) 32px;
    overflow: hidden;
  }
  .foot-grid{
    grid-template-columns: 1fr 1fr;
    gap: 32px 20px;
  }
  .foot-logo svg{
    height: 26px;
  }
  .foot-col h5{
    font-size: 10px;
  }
  .foot-col a,
  .foot-col p{
    font-size: 13px;
  }
  .foot-bottom{
    margin-top: 48px;
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
    font-size: 10px;
  }
  .foot-r{
    font-size: 38vw;
    bottom: -8vw;
    letter-spacing: .01em;
    white-space: nowrap;
  }

  /* MENÚ MOBILE */
  .mobile-menu{
    padding: 0 var(--gutter);
    justify-content: center;
  }
  .mobile-menu .mm-link{
    font-size: 18px;
    padding: 16px 0;
  }
  .mobile-menu .mm-cta{
    margin-top: 24px;
    padding: 16px 28px;
    width: 100%;
    justify-content: center;
    font-size: 13px;
  }

}

/* TABLET — 481px a 768px */
@media(min-width:481px) and (max-width:768px){
  :root{ --gutter: 28px; }

  section{ padding: 100px var(--gutter); }

  .section-head h2{ font-size: clamp(30px, 6vw, 44px); }

  .hero h1{ font-size: clamp(42px, 10vw, 64px); }
  .hero-cta-row{ gap: 18px; }

  .about-grid{ grid-template-columns: 1fr; gap: 40px; }
  .about-lines p{ font-size: 20px; }

  .services-grid{ grid-template-columns: repeat(2, 1fr); }

  .p-step{ grid-template-columns: 80px 1fr; }
  .p-step p{ display: none; }

  .why-grid{ grid-template-columns: 1fr; }
  .why-item{ border-right: none; }

  .foot-grid{ grid-template-columns: 1fr 1fr; gap: 36px 24px; }

  .cf-row{ grid-template-columns: 1fr; }
  .cf-submit{ width: 100%; justify-content: center; }

  .big-cta h2{ font-size: clamp(40px, 9vw, 64px); }

	.work-card .ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;}
.work-card .ph .glow{z-index:1;mix-blend-mode:screen;opacity:.55;}
.work-card .ph::after{z-index:2;}
}
