:root{--bg0:#050814;--bg1:#070b1d;--ink:#eaf0ff;--muted:rgba(234,240,255,.72);--muter:rgba(234,240,255,.55);
--line:rgba(255,255,255,.10);--glass:rgba(255,255,255,.06);--shadow:0 18px 60px rgba(0,0,0,.55);--r:18px;
--brand:#38bdf8;--brand2:#a78bfa;--ok:#34d399;--max:1180px}
*{box-sizing:border-box}html,body{height:100%}
body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;color:var(--ink);
background:radial-gradient(1200px 900px at 15% 10%,rgba(56,189,248,.18),transparent 55%),
radial-gradient(1200px 900px at 85% 20%,rgba(167,139,250,.14),transparent 55%),
linear-gradient(180deg,var(--bg0),var(--bg1));overflow-x:hidden}
a{color:inherit}.container{max-width:var(--max);margin:0 auto;padding:0 22px}
header{position:sticky;top:0;z-index:50;backdrop-filter:blur(12px);
background:linear-gradient(180deg,rgba(5,8,20,.78),rgba(5,8,20,.35));border-bottom:1px solid rgba(255,255,255,.08)}
.nav{display:flex;align-items:center;justify-content:space-between;min-height:64px;gap:16px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.mark{width:34px;height:34px;border-radius:12px;background:radial-gradient(10px 10px at 30% 25%,rgba(255,255,255,.45),transparent 55%),
linear-gradient(135deg,rgba(56,189,248,.95),rgba(167,139,250,.95));box-shadow:0 10px 26px rgba(56,189,248,.14)}
.brand strong{letter-spacing:.4px}.brand small{display:block;color:var(--muter);letter-spacing:.18em;font-size:11px;margin-top:2px}
.navlinks{display:flex;gap:18px;align-items:center}
.navlinks a{text-decoration:none;color:var(--muted);font-size:14px;padding:10px 10px;border-radius:12px}
.navlinks a:hover{background:rgba(255,255,255,.05);color:var(--ink)}
.nav-cta{display:flex;gap:10px;align-items:center}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:14px;
border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.06);color:var(--ink);text-decoration:none;
gap:10px;font-weight:700;font-size:14px;box-shadow:0 10px 28px rgba(0,0,0,.25);cursor:pointer}
.btn:hover{background:rgba(255,255,255,.09);transform:translateY(-1px)}
.btn.primary{border:1px solid rgba(56,189,248,.45);background:linear-gradient(135deg,rgba(56,189,248,.95),rgba(167,139,250,.75))}
.pill{display:inline-flex;gap:10px;align-items:center;padding:8px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.12);
background:rgba(255,255,255,.05);color:var(--muted);font-size:13px}
.dot{width:8px;height:8px;border-radius:99px;background:var(--ok);box-shadow:0 0 0 6px rgba(52,211,153,.13)}
.lang{display:inline-flex;border:1px solid rgba(255,255,255,.12);border-radius:999px;overflow:hidden;background:rgba(255,255,255,.05)}
.lang button{border:0;background:transparent;color:var(--muted);padding:8px 10px;font-weight:800;cursor:pointer}
.lang button[aria-pressed="true"]{background:rgba(255,255,255,.10);color:var(--ink)}
.hero{position:relative;padding:64px 0 34px;overflow:hidden}
.heroGrid{display:grid;grid-template-columns:1.25fr .75fr;gap:26px;align-items:stretch}
@media(max-width:980px){.heroGrid{grid-template-columns:1fr;gap:18px}.navlinks{display:none}}
.heroVideo{position:absolute;inset:0;z-index:-2;overflow:hidden}
.heroVideo video{width:100%;height:100%;object-fit:cover;filter:saturate(1.15) contrast(1.1) brightness(.55);transform:scale(1.03)}
.heroOverlay{position:absolute;inset:0;z-index:-1;background:radial-gradient(1000px 650px at 20% 20%,rgba(56,189,248,.16),transparent 55%),
radial-gradient(1000px 650px at 85% 15%,rgba(167,139,250,.14),transparent 55%),linear-gradient(180deg,rgba(5,8,20,.72),rgba(5,8,20,.95))}
.glow{position:absolute;inset:-120px -120px auto auto;width:560px;height:560px;border-radius:50%;
background:radial-gradient(circle at 30% 30%,rgba(56,189,248,.25),transparent 55%),radial-gradient(circle at 70% 70%,rgba(167,139,250,.20),transparent 55%);
filter:blur(18px);animation:floaty 9s ease-in-out infinite;pointer-events:none;z-index:-1}
@keyframes floaty{0%,100%{transform:translate(0,0)}50%{transform:translate(-18px,12px)}}
h1{font-size:54px;line-height:1.02;margin:16px 0 12px;letter-spacing:-.03em}
@media(max-width:560px){h1{font-size:40px}}
.lead{color:var(--muted);font-size:16px;line-height:1.55;max-width:62ch;margin:0 0 18px}
.ctaRow{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.kpis{margin-top:18px;display:flex;gap:16px;flex-wrap:wrap}
.kpi{padding:12px 14px;border-radius:16px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);min-width:170px}
.kpi b{display:block;font-size:14px}.kpi span{color:var(--muter);font-size:12px}
.card{border:1px solid rgba(255,255,255,.12);background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.04));
border-radius:var(--r);box-shadow:var(--shadow)}
.panel{padding:18px}.panel h3{margin:0 0 6px;font-size:14px}.panel p{margin:0;color:var(--muter);font-size:13px;line-height:1.5}
.outcomes{padding:18px}.outcomes h3{margin:0 0 10px}
.outList{display:grid;gap:10px;margin-top:10px}
.row{display:flex;align-items:center;justify-content:space-between;padding:12px 12px;border-radius:14px;border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.15)}
.row small{color:var(--muter)}.row b{font-size:14px}
section{padding:44px 0}
.sectionTitle{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:18px}
.sectionTitle h2{margin:0;font-size:26px;letter-spacing:-.02em}
.sectionTitle p{margin:0;color:var(--muted);max-width:72ch}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:980px){.grid3{grid-template-columns:1fr}}
.feature{padding:18px;position:relative;overflow:hidden}
.feature::before{content:"";position:absolute;inset:-2px;background:radial-gradient(500px 200px at 20% 10%,rgba(56,189,248,.18),transparent 55%),
radial-gradient(500px 220px at 80% 20%,rgba(167,139,250,.16),transparent 55%);opacity:.6}
.feature>*{position:relative}
.icon{width:40px;height:40px;border-radius:14px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);
display:flex;align-items:center;justify-content:center;margin-bottom:10px}
.icon svg{width:20px;height:20px}.feature h3{margin:0 0 8px}.feature p{margin:0;color:var(--muter);line-height:1.55}
.split{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:980px){.split{grid-template-columns:1fr}}
.mediaCard{overflow:hidden;position:relative}.media{height:320px;background:center/cover no-repeat;filter:saturate(1.05) contrast(1.05) brightness(.8)}
.media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent,rgba(5,8,20,.85))}
.mediaCard .panel{position:absolute;inset:auto 0 0 0;padding:18px}
.footer{padding:26px 0 46px;border-top:1px solid rgba(255,255,255,.10);color:var(--muter)}
.footerGrid{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap}
.footer a{color:var(--muted);text-decoration:none}.footer a:hover{text-decoration:underline}
.formWrap{max-width:720px}
.field{display:grid;gap:8px;margin:12px 0}
label{font-size:13px;color:var(--muted)}
input,textarea{width:100%;padding:12px 12px;border-radius:14px;border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.22);color:var(--ink);outline:none}
textarea{min-height:140px;resize:vertical}
.hint{font-size:12px;color:var(--muter)}
.notice{margin-top:12px;padding:12px 12px;border-radius:14px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);color:var(--muted)}
.notice.ok{border-color:rgba(52,211,153,.30)}.notice.bad{border-color:rgba(251,113,133,.35)}

/* ===== People / Delivery photos ===== */
.photoRow{
  margin-top:18px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:16px;
}
.photo{
  position:relative;
  overflow:hidden;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(15,23,42,.35);
  box-shadow: 0 20px 60px rgba(0,0,0,.35);
  transform: translateZ(0);
}
.photo img{
  width:100%;
  height:240px;
  object-fit:cover;
  display:block;
  filter:saturate(1.05) contrast(1.05);
  transform: scale(1.03);
  transition: transform .6s ease, filter .6s ease;
}
.photo::after{
  content:"";
  position:absolute; inset:0;
  background: radial-gradient(800px 240px at 20% 10%, rgba(56,189,248,.20), transparent 60%),
              radial-gradient(700px 260px at 80% 30%, rgba(167,139,250,.16), transparent 55%),
              linear-gradient(to top, rgba(2,6,23,.80), rgba(2,6,23,.05) 60%);
  pointer-events:none;
}
.photo figcaption{
  position:absolute;
  left:14px; right:14px; bottom:12px;
  font-size:13px;
  line-height:1.35;
  color: rgba(226,232,240,.92);
  letter-spacing:.2px;
}
.photo:hover img{
  transform: scale(1.08);
  filter:saturate(1.15) contrast(1.1);
}
@media (max-width: 900px){
  .photoRow{ grid-template-columns: 1fr; }
  .photo img{ height:220px; }
}

/* ===== People photos grid (fix oversized images) ===== */
.photoRow{
  margin-top:32px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:22px;
}

.photo{
  position:relative;
  overflow:hidden;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.08);
  background:#0f172a;
  transition: transform .35s ease, box-shadow .35s ease;
}

.photo img{
  width:100%;
  height:200px;
  object-fit:cover;
  display:block;
  transition: transform .6s ease;
}

.photo:hover{ transform: translateY(-6px); box-shadow: 0 20px 60px rgba(0,0,0,.4); }
.photo:hover img{ transform: scale(1.08); }

.photo figcaption{
  padding:14px 16px;
  font-size:13px;
  color: rgba(226,232,240,.85);
  background: rgba(15,23,42,.6);
}

@media (max-width:1100px){ .photoRow{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width:700px){ .photoRow{ grid-template-columns: 1fr; } }


/* ===== OVERRIDE HARD: force people grid + image sizing ===== */
.photoRow{
  display:grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap:22px !important;
  align-items:stretch !important;
}

.photoRow .photo{
  width:100% !important;
  max-width:100% !important;
  overflow:hidden !important;
  border-radius:16px !important;
}

.photoRow .photo img{
  width:100% !important;
  max-width:100% !important;
  height:220px !important;
  object-fit:cover !important;
  display:block !important;
}

/* Si el CSS viejo te “rompe” el caption (lo pone absoluto), lo neutralizamos */
.photoRow .photo figcaption{
  position:static !important;
  padding:14px 16px !important;
  background: rgba(15,23,42,.55) !important;
}

/* Responsive */
@media (max-width:1100px){
  .photoRow{ grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}
@media (max-width:700px){
  .photoRow{ grid-template-columns: 1fr !important; }
}


/* ===== TRUST_AND_STATS ===== */
.trust{
  padding:18px 0;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
  background:rgba(2,6,23,.35)
}
.trustRow{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
  opacity:.9;
  font-size:12.5px;
  letter-spacing:.35px
}
.trustRow span{
  padding:8px 12px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:999px;
  background:rgba(15,23,42,.35);
  backdrop-filter: blur(8px)
}

.statsGrid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
  margin-top:6px
}
.stat{
  padding:18px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  background:rgba(15,23,42,.35);
  backdrop-filter: blur(10px)
}
.stat b{
  font-size:34px;
  display:block;
  letter-spacing:-.5px
}
.stat span{
  opacity:.75;
  font-size:13px
}
@media(max-width:900px){
  .statsGrid{grid-template-columns:repeat(2,1fr)}
}

/* micro-improvement: ensure the 3 photos behave */
.photo{transform-style:preserve-3d}
.photo img{will-change:transform}

/* ===== CASE_FILTERS_V1 ===== */
.hero.mini{padding:70px 0 40px}
.hero.mini h1{font-size:44px;margin:0 0 10px}
.hero.mini .lead{max-width:760px}

.filters{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin:16px 0 22px;
}
.chip{
  border:1px solid rgba(255,255,255,.10);
  background:rgba(15,23,42,.35);
  color:rgba(226,232,240,.92);
  padding:10px 12px;
  border-radius:999px;
  font-weight:650;
  font-size:13px;
  cursor:pointer;
  backdrop-filter: blur(10px);
  transition: transform .2s ease, background .2s ease, border-color .2s ease;
}
.chip:hover{ transform: translateY(-1px); }
.chip.active{
  background: rgba(59,130,246,.25);
  border-color: rgba(59,130,246,.45);
}

.caseGrid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:18px;
  margin-top:8px;
}
@media(max-width:1100px){ .caseGrid{grid-template-columns:repeat(2,1fr)} }
@media(max-width:700px){ .caseGrid{grid-template-columns:1fr} }

.case{ position:relative; }
.case .caseTop{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:10px;
  gap:10px;
}
.badge{
  font-size:12px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(2,6,23,.35);
}
.tags{ font-size:12px; opacity:.75 }
.bullets{
  margin:12px 0 0;
  padding-left:18px;
  opacity:.9
}
.bullets li{ margin:6px 0; }

.case.is-hidden{ display:none; }

.callout{
  margin-top:28px;
  padding:22px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background: radial-gradient(800px 220px at 20% 10%, rgba(56,189,248,.18), transparent 60%),
              radial-gradient(700px 260px at 80% 30%, rgba(167,139,250,.16), transparent 55%),
              rgba(15,23,42,.35);
}

/* ===== TESTIMONIALS ===== */
.testimonials .tGrid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:16px;
  margin-top:14px;
}
@media(max-width:1100px){ .testimonials .tGrid{grid-template-columns:repeat(2,1fr)} }
@media(max-width:700px){ .testimonials .tGrid{grid-template-columns:1fr} }
.tCard blockquote{
  margin:0;
  font-size:15px;
  line-height:1.65;
  color: rgba(226,232,240,.92);
}
.tCard figcaption{
  margin-top:14px;
  font-size:12.5px;
  opacity:.75;
}

/* ===== STICKY CTA ===== */
.stickyCta{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:9999;
  padding:12px 14px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(59,130,246,.88);
  color:white;
  font-weight:700;
  text-decoration:none;
  box-shadow: 0 18px 50px rgba(0,0,0,.45);
  backdrop-filter: blur(10px);
  transition: transform .2s ease, filter .2s ease, opacity .2s ease;
}
.stickyCta:hover{ transform: translateY(-2px); filter: brightness(1.05); }

/* =========================
   MOBILE RESPONSIVE PACK v1
   ========================= */

:root{ --pad: 24px; }
@media (max-width: 900px){ :root{ --pad: 18px; } }
@media (max-width: 560px){ :root{ --pad: 16px; } }

.container{
  padding-left: var(--pad) !important;
  padding-right: var(--pad) !important;
}

h1{ font-size: clamp(32px, 7vw, 56px) !important; line-height: 1.05; }
h2{ font-size: clamp(22px, 5vw, 34px) !important; }
.lead{ font-size: clamp(15px, 3.6vw, 18px) !important; }

.hero{ padding: 56px 0 !important; }
@media (max-width: 900px){
  .heroGrid{
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 18px !important;
  }
  .outcomes{ order: 2; }
}

.kpis{
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 10px !important;
}
@media (max-width: 900px){
  .kpis{ grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 560px){
  .kpis{ grid-template-columns: 1fr !important; }
}

.grid3{
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 16px !important;
}
@media (max-width: 1000px){
  .grid3{ grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 640px){
  .grid3{ grid-template-columns: 1fr !important; }
}

/* People photos grid: tamaño consistente */
.photoRow{
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 14px !important;
}
.photo img{
  width: 100% !important;
  height: 180px !important;
  object-fit: cover !important;
  display: block !important;
}
@media (max-width: 900px){
  .photoRow{ grid-template-columns: repeat(2, 1fr) !important; }
  .photo img{ height: 170px !important; }
}
@media (max-width: 560px){
  .photoRow{ grid-template-columns: 1fr !important; }
  .photo img{ height: 220px !important; }
}

/* Navbar compacta + botón hamburguesa */
.nav{ gap: 12px !important; }
.navlinks{ gap: 14px !important; flex-wrap: wrap; }

.burger{
  display:none;
  width:44px;height:44px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(2,6,23,.35);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  color: rgba(226,232,240,.95);
  align-items:center; justify-content:center;
  cursor:pointer;
}
.burger svg{ width:22px; height:22px; }

@media (max-width: 900px){
  .burger{ display:inline-flex !important; }
  .navlinks{
    display:none !important;
    position:absolute;
    left: var(--pad);
    right: var(--pad);
    top: 74px;
    padding: 14px;
    border-radius: 16px;
    border:1px solid rgba(255,255,255,.10);
    background: rgba(2,6,23,.75);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    box-shadow: 0 30px 80px rgba(0,0,0,.45);
    flex-direction: column;
    gap: 10px;
    z-index: 50;
  }
  .navlinks.is-open{ display:flex !important; }
  .nav{ position:relative; }
  .nav-cta .btn.primary{ padding:10px 12px !important; font-size:14px !important; }
}

/* Vídeo hero más suave en móvil */
@media (max-width: 900px){
  .heroVideo video{
    filter: blur(6px) saturate(.9) !important;
    transform: scale(1.08) !important;
  }
}
@media (prefers-reduced-motion: reduce){
  .heroVideo video{ display:none !important; }
}

/* Botones full-width en móvil */
@media (max-width: 560px){
  .ctaRow{
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }
  .btn{ width:100%; text-align:center; }
}

