/* =========================
   VARIABLES / BASE
   ========================= */
:root{
  --ink:#1d1d1f;
  --muted:#6e6e73;
  --line:#d2d2d7;
  --chip:#f5f5f7;
  --bg:#ffffff;

  --max:1120px;
  --r:22px;

  --rosa:#ff0080;
  --rosa-claro:#ff66a3;
  --rosa-oscuro:#99004d;
}

*{ box-sizing:border-box; }
html,body{ height:100%; margin:0; padding:0; }
body{
  background:var(--bg);
  color:var(--ink);
  font:16px/1.6 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
hr{ border:0; border-top:1px solid var(--line); margin:0; }

.container{ max-width:var(--max); margin:0 auto; padding:0 24px; }
.center{ text-align:center; }
.small{ font-size:14px; color:var(--muted); }

/* =========================
   TIPOGRAFÍA
   ========================= */
.h1{ font-weight:800; letter-spacing:-.02em; font-size:clamp(34px,6vw,72px); line-height:1.05; }
.h2,.section-title{ font-weight:800; letter-spacing:-.01em; font-size:clamp(26px,4.2vw,44px); line-height:1.15; margin:0 0 12px; color:var(--ink); }
.h3{ font-weight:700; font-size:22px; }
.copy{ color:var(--muted); font-size:18px; max-width:72ch; margin-left:auto; margin-right:auto; }

.gradient-text{
  background: linear-gradient(to right, var(--rosa), var(--rosa-oscuro));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text; color:transparent;
}

/* =========================
   SECCIONES / CHIPS / BOTONES
   ========================= */
.section{ padding:96px 0; } /* respiración como la original */
.section.hero{ padding:84px 0 28px; } /* un poco más pegada a la foto */

.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:12px 18px; border-radius:999px; border:1px solid var(--line);
  font-weight:700; color:var(--ink);
  background: rgba(255,255,255,0.8);
  backdrop-filter: saturate(180%) blur(15px);
  -webkit-backdrop-filter: saturate(180%) blur(15px);
  transition: border-color .25s ease, background .25s ease;
}
.btn:hover{ border-color:#000; background: rgba(255,255,255,0.95); }
.btn.primary{ background:var(--rosa); color:#fff; border-color:var(--rosa); }
.btn.primary:hover{ background:#e50075; border-color:#e50075; }

.chip{
  display:inline-flex; align-items:center; gap:8px;
  background:var(--chip); border:1px solid var(--line);
  border-radius:999px; padding:6px 12px;
  color:var(--muted); font-weight:700; font-size:12px;
}

/* =========================
   NAV
   ========================= */
/* NAV siempre visible (fixed) */
:root{ --nav-h:60px; }

.nav{
  position: fixed;            /* antes: sticky */
  top: 0; left: 0; right: 0;
  z-index: 1000;
  background: rgba(255,255,255,0.72);
  backdrop-filter: saturate(180%) blur(20px);
  -webkit-backdrop-filter: saturate(180%) blur(20px);
  border-bottom: 1px solid rgba(210,210,215,0.6);
  padding-top: env(safe-area-inset-top); /* notch iOS */
}

.nav .row{
  height: var(--nav-h);
  display:flex; align-items:center; justify-content:space-between; gap:16px;
}
.nav .links{ display:none; gap:28px; color:var(--muted); font-weight:600; }
@media(min-width:960px){ .nav .links{ display:flex; } }
.nav .links a{ transition:color .25s ease; }
.nav .links a:hover{ color:#1d1d1f; }

.brand{ display:inline-flex; align-items:baseline; gap:10px; }
.brand-eureka{ color:var(--rosa); font-weight:900; font-size: clamp(22px, 2.6vw, 28px); letter-spacing:-0.01em; }
.brand-dynamic{ display:inline-flex; align-items:center; gap:6px; font-weight:400; font-size: clamp(22px, 2.6vw, 28px); color:#6e6e73; min-width:140px; }
.brand-rotating{ color:#6e6e73; text-transform:capitalize; white-space:nowrap; }

/* =========================
   STORY HERO (foto grande) + filtros
   ========================= */
.story-hero{ position: relative; margin-top:8px; }
.story-wrap{ max-width: min(1400px, 96vw); margin: 0 auto; padding: 0 16px; }
.story-media{
  position: relative; border-radius: 22px; overflow: hidden; border: 1px solid var(--line);
  background:#000; min-height: clamp(340px, 48vw, 640px);
}
.story-media > img{ width:100%; height:100%; object-fit:cover; object-position: var(--focus-x,50%) var(--focus-y,50%); }
.story-caption{ position:absolute; inset:auto 24px 24px 24px; color:#fff; z-index:2; max-width:880px; }
.story-kicker{ display:inline-block; font-size:12px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:#e6e6ea; margin-bottom:8px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.16); padding:6px 10px; border-radius:999px; }
.story-title{ margin:0; font-weight:900; letter-spacing:-.01em; font-size: clamp(22px, 4.6vw, 48px); line-height:1.08; text-shadow:0 2px 18px rgba(0,0,0,.35); }
.story-media.rosa::before{ content:""; position:absolute; inset:0; background: rgba(255,0,128,.22); mix-blend-mode:multiply; z-index:1; }
.story-media.gris::before{ content:""; position:absolute; inset:0; background: rgba(40,40,40,.28); mix-blend-mode:multiply; z-index:1; }
.story-media.bn > img{ filter: grayscale(100%) contrast(1.05); }
.story-media.hl > img{ filter: brightness(1.1) contrast(1.05) saturate(1.2); }
@media (max-width: 560px){ .story-wrap{ padding:0 12px; } .story-caption{ inset:auto 14px 14px 14px; } .story-title{ font-size: clamp(20px, 6vw, 28px); } }

/* =========================
   LOGO STRIP
   ========================= */
.logo-strip.clean{
  --slide-w: 180px; --logo-h:48px; --speed:50s;
  overflow:hidden; padding:32px 0; background:#fff;
  border-top:1px solid rgba(0,0,0,.06); border-bottom:1px solid rgba(0,0,0,.06);
}
.logo-strip.clean .logo-track{ display:flex; width: calc(var(--slide-w) * 32); animation: logos-scroll var(--speed) linear infinite; }
.logo-strip.clean .logo{ flex:0 0 var(--slide-w); display:flex; align-items:center; justify-content:center; padding:0 16px; }
.logo-strip.clean .logo img{ height:var(--logo-h); object-fit:contain; filter:grayscale(100%) brightness(0.2) contrast(100%); opacity:.8; transition:opacity .25s ease, filter .25s ease; }
.logo-strip.clean .logo img:hover{ filter:grayscale(100%) brightness(0) contrast(120%); opacity:1; }
@keyframes logos-scroll{ 0%{ transform:translateX(0); } 100%{ transform:translateX(-50%); } }
.logo-strip.clean:hover .logo-track{ animation-play-state: paused; }
@media (prefers-reduced-motion: reduce){ .logo-strip.clean .logo-track{ animation:none; flex-wrap:wrap; width:100%; gap:24px; justify-content:center; } .logo-strip.clean .logo{ flex:0 1 140px; } }

/* =========================
   RIEL DE SERVICIOS (sin cortes)
   ========================= */
.service-rail{ background:#fff; padding: 40px 0 56px; }
.rail-viewport{ position:relative; overflow:hidden; padding-inline: clamp(16px, 6vw, 64px); padding-block: 12px; }
.rail-track{ display:flex; gap: clamp(16px, 2vw, 24px); }

.card-tall{
  flex: 0 0 clamp(300px, 28vw, 380px);
  height: clamp(440px, 56vw, 580px);
  background:#f5f5f7; border:1px solid #e6e6ea; border-radius:18px; padding:22px;
  display:flex; flex-direction:column; overflow:hidden;
  box-shadow:0 10px 24px rgba(0,0,0,.04);
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
  will-change: transform;
}
.card-ico{ width:44px; height:44px; }
.card-ico svg{ width:100%; height:100%; fill:none; stroke:var(--rosa); stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round; }
.push{ margin-top:auto; } /* texto abajo */
.card-tall:hover{ border-color:var(--rosa); transform: translateY(-3px); box-shadow:0 14px 36px rgba(0,0,0,.08); }
.card-tall h3{ margin:16px 0 8px; font-size:clamp(20px,2.2vw,28px); letter-spacing:-0.01em; }
.card-tall p{ margin:0; font-size:15.5px; line-height:1.6; color:#3a3a3c; }

.card-tall.cta{ position:relative; background:#ececf1; border-color:#dedee4; align-items:flex-start; }
.card-tall.cta .cta-kicker{ font-size:12px; color:#6e6e73; margin-bottom:8px; }
.card-tall.cta h3{ margin-top:6px; }
.card-tall.cta .cta-btn{ margin-top:auto; display:inline-flex; align-items:center; justify-content:center; padding:10px 14px; border-radius:999px; background:var(--rosa); color:#fff; font-weight:700; border:1px solid var(--rosa); }
.card-tall.cta .cta-btn:hover{ background:#e50075; border-color:#e50075; }
.card-tall.cta .cta-img{ position:absolute; bottom:-6px; right:-6px; width:clamp(160px,22vw,220px); opacity:.95; pointer-events:none; }

@media (max-width: 900px){
  .rail-viewport{ overflow-x:auto; -webkit-overflow-scrolling:touch; }
  .rail-viewport::-webkit-scrollbar{ display:none; }
  .card-tall{ flex-basis:78vw; height:420px; } /* móvil compacto bonito */
}

/* =========================
   STACKED GALLERY
   ========================= */
.stacked-gallery{ --count:4; position:relative; width:100%; height: calc(100svh * var(--count)); background:#000; }
.frame{ position:sticky; top:0; height:100svh; width:100%; overflow:hidden; display:grid; place-items:center; isolation:isolate; z-index:var(--z,1); background:#000; }
.frame > img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position: var(--fx,50%) var(--fy,40%); transform:scale(1.06); filter:saturate(102%); transition: transform .9s ease, opacity .9s ease, object-position .3s ease; }
.frame::before,.frame::after{ content:""; position:absolute; left:0; right:0; height:30vh; pointer-events:none; z-index:1; }
.frame::before{ top:0;    background: linear-gradient(to bottom, rgba(0,0,0,.28), rgba(0,0,0,0)); }
.frame::after { bottom:0; background: linear-gradient(to top,   rgba(0,0,0,.35), rgba(0,0,0,0)); }
.caption{ position:relative; z-index:2; text-align:center; padding:0 24px; max-width:min(92vw,960px); }
.caption h2{ margin:0 0 10px; font-size: clamp(28px, 6vw, 64px); line-height:1.06; font-weight:800; letter-spacing:-0.01em; background: linear-gradient(90deg, #cfcfd3 0%, var(--rosa-claro) 55%, var(--rosa-oscuro) 100%); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; color:transparent; }
.caption p{ margin:0; font-size: clamp(16px, 2.4vw, 20px); color: rgba(255,255,255,.9); text-shadow: 0 1px 12px rgba(0,0,0,.25); }
.frame .caption{ transform: translateY(16px); opacity:0; transition: transform .6s ease, opacity .6s ease; }
.frame.is-visible > img{ transform: scale(1.0); opacity:1; }
.frame.is-visible .caption{ transform: translateY(0); opacity:1; }
@media (max-width: 768px){ .stacked-gallery{ height: calc(40svh * var(--count)); } .frame{ height:40svh; } .frame > img{ transform:none; object-position: var(--fx, 20%) var(--fy, 30%); } }
@media (max-width: 380px){ .stacked-gallery{ height: calc(38svh * var(--count)); } .frame{ height:38svh; } }

/* =========================
   GRIDS / TILES (secciones ya existentes)
   ========================= */
.grid3{ display:grid; gap:24px; margin-top:28px; }
@media(min-width:900px){ .grid3{ grid-template-columns:repeat(3,1fr); } }
.tile{ border:1px solid var(--line); border-radius:18px; padding:22px; }
.visual{ border:1px solid var(--line); border-radius:var(--r); overflow:hidden; background:var(--chip); }
.visual img{ width:100%; height:auto; }

/* =========================
   CONTADORES
   ========================= */
.counter-strip{ background:#f5f5f7; padding:60px 0; border-top:1px solid rgba(0,0,0,.05); border-bottom:1px solid rgba(0,0,0,.05); }
.counter-grid{ display:grid; grid-template-columns: repeat(4,1fr); gap:32px; text-align:center; }
@media(max-width:900px){ .counter-grid{ grid-template-columns:repeat(2,1fr); gap:24px; } }
@media(max-width:480px){ .counter-grid{ grid-template-columns:1fr; } }
.counter-number{ font-size:clamp(28px,5vw,48px); font-weight:900; color:var(--rosa); line-height:1; margin-bottom:0; }
.counter-label{ font-size:clamp(14px,2vw,16px); font-weight:600; color:#000; text-transform:uppercase; letter-spacing:.02em; line-height:1.1; margin-top:2px; }

/* =========================
   CONTACT CARD (95% centrada, fondo blanco)
   ========================= */
.contact-card-wrap{ background:#fff; padding: 64px 0; }
.contact-card{
  width:95%; max-width:1280px; margin:0 auto;
  background:#0f0f11; border:1px solid #252527; border-radius:24px;
  padding: clamp(20px, 3.6vw, 32px); color:#e6e6ea;
  box-shadow: 0 18px 60px rgba(0,0,0,.18);
}
.contact-grid{ display:grid; grid-template-columns: 1.1fr 1fr; gap: clamp(20px, 3vw, 28px); align-items:start; }
@media (max-width: 900px){ .contact-grid{ grid-template-columns: 1fr; } }

.kicker{ font-size:12px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:#a1a1a6; margin-bottom:10px; }
.contact-title{ margin:0; font-weight:900; font-size: clamp(40px, 7vw, 72px); letter-spacing:-.02em; line-height:1.04; color:#fff; }

.newsletter{ display:flex; gap:10px; align-items:center; background:#151517; border:1px solid #2a2a2d; border-radius:14px; padding: 8px 8px 8px 12px; width:100%; }
.newsletter input{ flex:1; background:transparent; border:0; color:#fff; outline:none; font-size:15px; padding:10px 6px; }
.newsletter button{ width:44px; height:44px; border-radius:999px; border:1px solid var(--rosa); background:var(--rosa); color:#fff; font-weight:700; cursor:pointer; }
.newsletter button:hover{ background:#e50075; border-color:#e50075; }

.contact-sep{ border-top:1px solid #2a2a2d; margin:16px 0; }
.links-grid{ display:grid; grid-template-columns: 1fr 1fr 1.2fr; gap:16px; }
.links-grid ul{ list-style:none; padding:0; margin:0; display:grid; gap:10px; }
.links-grid a{ color:#fff; text-decoration:none; }
.links-grid a:hover{ color:var(--rosa-claro); }

.office-title{ font-weight:700; margin-bottom:6px; color:#fff; }
.office p{ margin:0 0 8px; color:#c2c2c6; }

.contact-bottom{ display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; border-top:1px solid #252527; margin-top:20px; padding-top:16px; }
.copyr{ color:#a1a1a6; font-size:14px; }
.socials{ display:flex; align-items:center; gap:12px; }
.socials a{ color:#fff; }
.socials a:hover{ color:var(--rosa-claro); }
.to-top{ margin-left:auto; display:inline-flex; width:40px; height:40px; align-items:center; justify-content:center; border-radius:999px; border:1px solid #2a2a2d; color:#fff; background:#151517; text-decoration:none; }
.to-top:hover{ border-color:#3a3a3c; }

@media (max-width: 600px){
  .links-grid{ grid-template-columns: 1fr 1fr; }
  .office{ grid-column: 1 / -1; }
}
/* === Trust avatars (BeTheme-style) === */
.trust-row {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
  margin-top: 20px;
  flex-wrap: wrap;
}

.trust-avatars {
  display: flex;
  list-style: none;
  padding: 0;
  margin: 0;
}

.trust-avatars li {
  margin-left: -8px; /* efecto de solapado */
}

.trust-avatars li:first-child {
  margin-left: 0;
}

.trust-avatars img {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid #fff;
  box-shadow: 0 2px 6px rgba(0,0,0,0.1);
}

.trust-text {
  font-size: 0.95rem;
  color: #555;
}

/* Hover sutil (desktop) */
@media (hover:hover){
  .trust-avatars li:hover{ transform: translateY(-2px); }
}

/* Responsive: en móvil, avatares un poco más chicos y sin overlap agresivo */
@media (max-width:600px){
  .trust-avatars li{ width:38px; height:38px; }
  .trust-avatars li + li{ margin-left:-10px; }
  .trust-text{ font-size:13px; }
}
.avatar-logos {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: -8px; /* para que se encimen un poco */
}

.avatar-logos img {
  width: 48px;       /* tamaño del logo */
  height: 48px;
  border-radius: 50%;  /* hace el círculo */
  object-fit: cover;   /* asegura que se recorte y no se deforme */
  border: 2px solid #fff; /* borde blanco como en tu ejemplo */
  box-shadow: 0 2px 6px rgba(0,0,0,0.1);
}

/* Imagen animada tipo video */
.ambient-figure {
  margin: 24px auto 0;
  max-width: min(1120px, 94vw);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(0,0,0,.15);
}

.ambient-video {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;      /* ajusta si el clip no es 16:9 */
  object-fit: cover;
  pointer-events: none;      /* evita clics o pausas */
  user-select: none;
}

/* Video incrustado, sin sombra ni borde */
.video-plain video {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
  border: none;
  outline: none;
  box-shadow: none;
  background: transparent;
}

/* HERO: estructura nueva */
.hero{ padding:0; }

/* Chip en blanco arriba */
.hero-chip-wrap{
  padding: 84px 0 16px; /* respira como antes pero pegado a la foto */
  background:#fff;
}

/* Bloque con imagen de fondo + overlay negro */
.hero-bg{
  position: relative;
  background: #000;
  min-height: clamp(440px, 56vw, 720px);
  display: block;
  isolation: isolate;
}
.hero-bg::before{
  content:"";
  position:absolute; inset:0;
  background-image: var(--hero-img);
  background-size: cover;
  background-position: center;
  z-index: 0;
}
.hero-bg::after{
  content:"";
  position:absolute; inset:0;
  background: rgba(0,0,0,.75); /* máscara negra opaca */
  z-index: 0;
}

/* Contenido sobre la imagen */
.hero-content{
  position: relative;
  z-index: 1;
  padding: clamp(36px, 7vw, 92px) 0;
  color: #fff;
  text-align: center;
}
.hero-title{ color:#fff; margin:0; }
.hero-copy{ color:#e9e9ec; }

/* “enamoren” rosa sólido con outline negro (no degradado) */
.enamoren{
  color: var(--rosa);
  -webkit-text-stroke: 0px #000;      /* outline principal */
  text-shadow:
    0 0px 0 #000, 0px 0 0 #000,       /* fallback pequeño para navegadores sin stroke */
    0px 0 0 #000, 0 0px 0 #000;
}

/* Ajustes de la fila de confianza cuando está sobre fondo oscuro */
.hero .trust-avatars img{
  border-color:#fff; /* ya lo tenías, reafirmo para el fondo oscuro */
}
.hero .trust-text{
  color:#e6e6ea;
}

/* Responsive fino del bloque con imagen */
@media (max-width:560px){
  .hero-chip-wrap{ padding: 72px 0 12px; }
  .hero-content{ padding: 28px 0 44px; }
}
/* === CONSULTORÍA sección con fondo === */
.consultoria-section{ padding:0; }

/* Chip sobre fondo blanco */
.consultoria-chip-wrap{
  padding: 80px 0 16px;
  background:#fff;
}

/* Imagen de fondo + overlay oscuro */
.consultoria-bg{
  position:relative;
  background:#000;
  min-height: clamp(420px, 54vw, 680px);
  display:block;
  isolation:isolate;
}
.consultoria-bg::before{
  content:"";
  position:absolute; inset:0;
  background-image: var(--consultoria-img);
  background-size: cover;
  background-position:center;
  z-index:0;
}
.consultoria-bg::after{
  content:"";
  position:absolute; inset:0;
  background:rgba(0,0,0,.55); /* máscara negra */
  z-index:0;
}

/* Contenido centrado sobre la imagen */
.consultoria-content{
  position:relative;
  z-index:1;
  padding: clamp(36px,7vw,92px) 0;
  color:#fff;
  text-align:center;
}
.consultoria-title{ color:#fff; margin:0; }
.consultoria-copy{ color:#e9e9ec; }

/* Palabra “metodología” rosa sólido con contorno negro */
.metodologia{
  color: var(--rosa);
  -webkit-text-stroke: 0px #000;
  text-shadow:
    0 0px 0 #000, 0px 0 0 #000,
    0px 0 0 #000, 0 0px 0 #000;
}

/* Ajustes responsive */
@media (max-width:560px){
  .consultoria-chip-wrap{ padding:72px 0 12px; }
  .consultoria-content{ padding:28px 0 44px; }
}
/* === HERO con fondo === */
.hero-bg,
.consultoria-bg {
  position: relative;
  background: #000;
  min-height: clamp(420px, 54vw, 680px);
  display: flex;                      /* 👈 permite centrar */
  align-items: center;                /* 👈 centra verticalmente */
  justify-content: center;            /* 👈 centra horizontalmente */
  isolation: isolate;
  text-align: center;
}
.hero-bg::before,
.consultoria-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--hero-img, none);
  background-size: cover;
  background-position: center;
  z-index: 0;
}
.consultoria-bg::before {
  background-image: var(--consultoria-img);
}
.hero-bg::after,
.consultoria-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  z-index: 0;
}

/* Contenido centrado */
.hero-content,
.consultoria-content {
  position: relative;
  z-index: 1;
  color: #fff;
  max-width: var(--max);
  padding: 0 24px;

  
}
/* Deja espacio para el header fixed */
body{
  padding-top: calc(var(--nav-h) + env(safe-area-inset-top));
}
/* ===== Contact kicker en rosa ===== */
.contact-card .kicker {
  color: var(--rosa);
}