:root{--bg:#ffffff;--text:#111317;--muted:#5b6270;--accent:#F58220;--border:#E6E8EC;--blue:#2F5FB8;--blue-dark:#234A8F}
*{box-sizing:border-box}
html,body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif}
img,video{max-width:100%;height:auto;display:block}
.wrap{max-width:1200px;margin:0 auto;padding:0 20px}

/* Header */
.site-header{position:sticky;top:0;z-index:80;border-bottom:1px solid var(--border);background:#fff}
.site-header.glass{backdrop-filter:saturate(1.2) blur(6px); background:rgba(255,255,255,.85)}
.header-inner{height:64px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:inherit}
.brand-name{font-weight:800;letter-spacing:-0.01em}
.logo{height:28px}

/* Desktop nav */
.nav{display:flex;gap:14px;align-items:center}
.nav a{text-decoration:none;font-weight:600;color:#1b2a4a}
.nav .btn.sm{padding:8px 12px;border-radius:10px;border:1px solid var(--blue-dark);color:#fff;background:var(--blue-dark)}

/* Hero (con transparencia) */
.hero-section-short{
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  height:450px;
  width:100%;
  position:relative;
}
.hero-overlay{position:relative;z-index:2;color:#fff;padding:40px 0}
.hero-section-short::before{content:"";position:absolute;inset:0;background:rgba(0,0,0,.40)}
.hero-copy h1{font-family:Poppins,Inter;font-size:clamp(32px,6vw,56px);line-height:1.06;margin:.2em 0 .4em}
.lead{color:#e8eaf0;font-size:clamp(16px,1.2vw,18px)}
.cta-row{display:flex;gap:12px;margin:16px 0 10px}
.btn{padding:12px 16px;border-radius:12px;border:1px solid var(--accent);background:var(--accent);color:#fff;font-weight:800;cursor:pointer;text-decoration:none;display:inline-block;box-shadow:0 2px 8px rgba(0,0,0,.06)}
.btn.lg{padding:14px 18px;border-radius:14px}
.btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(0,0,0,.10)}

/* Trust */
.trust{padding:10px 0 24px}
.trust-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
.trust-item{border:1px dashed var(--border);border-radius:12px;padding:10px;text-align:center;background:#fff;color:#1b2a4a}

/* Secciones y cards */
.slab{padding:34px 0;border-top:1px solid var(--border)}
.slab.alt{background:#fbfcff}
.slab h2{font-family:Poppins,Inter;font-size:clamp(22px,2.4vw,30px);margin:6px 0 18px}
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:16px}
.card h3{margin:0 0 6px;font-size:18px}



/* Evidencia (antiguo, mantenido por compatibilidad) */
.evidence{padding:40px 0}
.evidence h2{font-family:Poppins,Inter;margin:0 0 14px} /* FIX del selector */
.evidence-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.evidence-card{background:#fff;border:1px solid var(--border);border-radius:12px;overflow:hidden}
.evidence-card .media{display:block;width:100%;height:220px;object-fit:cover;background:#f6f7f9}
.evidence-card .caption{padding:12px;color:var(--muted)}

/* Proceso */
.process h2{font-family:Poppins,Inter}
.steps-line{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:14px;padding:0;margin:0}
.steps-line li{background:#fff;border:1px solid var(--border);border-radius:12px;padding:12px;position:relative}
.steps-line .dot{width:10px;height:10px;background:var(--accent);border-radius:50%;display:inline-block;margin-right:6px}

/* CTA */
.cta-bar{padding:18px 0;border-top:1px solid var(--border);background:linear-gradient(90deg,#fff,#fbfcff)}
.cta-flex{display:flex;align-items:center;justify-content:space-between;gap:14px}
.muted{color:var(--muted)}

/* FAQ */
.faq h2{font-family:Poppins,Inter}
.faq-list details{border:1px solid var(--border);border-radius:10px;padding:10px;background:#fff;margin:8px 0}

/* Contacto */
.contact{padding:40px 0;border-top:1px solid var(--border)}
.contact-card{display:grid;grid-template-columns:1fr 1fr;gap:18px;background:#fff;border:1px solid var(--border);border-radius:14px;padding:18px}
.contact-form label{display:block;margin-bottom:10px;font-weight:600}
.contact-form input,.contact-form textarea{width:100%;padding:10px;border-radius:10px;border:1px solid var(--border);font:inherit}

/* Footer */
.footer{border-top:1px solid var(--border);margin-top:40px}
.subfooter{padding:12px 0;color:var(--muted);font-size:14px}

/* ---------- Navegación móvil (hamburger + drawer) ---------- */
.hamburger{display:none;position:relative;width:38px;height:34px;border:1px solid var(--border);border-radius:10px;background:#fff;cursor:pointer;padding:6px}
.hamburger span{display:block;height:2px;background:#1b2a4a;margin:5px 0;transition:transform .2s, opacity .2s}
.mobile-drawer{display:none;position:fixed;top:64px;left:0;right:0;background:#fff;border-bottom:1px solid var(--border);padding:12px 20px;z-index:70}
.mobile-drawer a{display:block;padding:12px 4px;text-decoration:none;color:#1b2a4a;font-weight:600}
.lang-mobile{padding:8px 4px;color:#5b6270}
.desktop-only{display:flex}
body.mobile-open{overflow:hidden} /* bloquea scroll al abrir el drawer */

/* open state */
.mobile-open .mobile-drawer{display:block}
.mobile-open #navToggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.mobile-open #navToggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.mobile-open #navToggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Breakpoints */
@media(max-width:960px){
  .desktop-only{display:none}
  .hamburger{display:block}
  .cards-3{grid-template-columns:1fr}
  .evidence-grid{grid-template-columns:1fr}
  .steps-line{grid-template-columns:1fr}
  .contact-card{grid-template-columns:1fr}
  .trust-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:640px){
  .trust-grid{grid-template-columns:repeat(2,1fr)}
}

/* ---- Fix de contraste de textos ---- */
.lead{ color: var(--muted); }              /* color normal en todo el sitio */
.hero-overlay .lead{ color: #e8eaf0; }     /* solo en el hero va claro sobre la imagen */
p{ color: var(--text); }
.slab .lead{ color: var(--muted); }
h1,h2,h3,h4{ color: #0f1220; }

/* ---- Callout Panels ---- */
.callout{background:#fff;border:2px solid var(--blue-dark);border-radius:14px;padding:20px;margin:20px 0;box-shadow:0 2px 8px rgba(0,0,0,.05)}
.callout h3{margin-top:0;color:var(--accent);font-family:Poppins, Inter, sans-serif}
@media(max-width:768px){ .callout{ padding:14px } }

/* ---- Texto blanco en hero ---- */
.hero-overlay h1,
.hero-overlay .lead,
.hero-overlay p,
.hero-overlay a,
.hero-overlay li { color:#fff !important; text-shadow:0 2px 6px rgba(0,0,0,.4) }

/* ===== Evidencia: grid de tarjetas + modal (ligero y NUEVO) ===== */
.evi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
@media(max-width:960px){ .evi-grid{ grid-template-columns:1fr } }

.evi-card{
  position:relative;display:block;border:1px solid var(--border);border-radius:14px;overflow:hidden;
  background:#fff;text-decoration:none;color:inherit;cursor:pointer;outline:none;
}
.evi-card:focus-visible{box-shadow:0 0 0 3px rgba(47,95,184,.35)}
.evi-thumb{width:100%;aspect-ratio:16/9;object-fit:cover;display:block;background:#f4f6fa}
.evi-title{padding:10px 12px;font-weight:600}
.evi-play{position:absolute;right:12px;bottom:12px;width:46px;height:46px;border-radius:50%;background:rgba(0,0,0,.6);display:grid;place-items:center}
.evi-play::before{content:"";border:8px solid transparent;border-left-color:#fff;margin-left:2px}

/* Modal */
.modal{position:fixed;inset:0;background:rgba(10,14,20,.65);display:none;align-items:center;justify-content:center;z-index:120}
.modal.open{display:flex}
.modal-inner{width:min(1000px,92vw);background:#000;border-radius:12px;overflow:hidden;position:relative}
.modal video{width:100%;height:auto;display:block}
.modal-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;background:#fff;color:#111;font-weight:700;display:grid;place-items:center;cursor:pointer;border:none}


/* 0110 chatgpt start: grid tipo YouTube */
.evi-grid{display:grid;gap:12px}
@media (max-width:640px){ .evi-grid{grid-template-columns:repeat(2,1fr)} }
@media (min-width:641px) and (max-width:1023px){ .evi-grid{grid-template-columns:repeat(3,1fr)} }
@media (min-width:1024px){ .evi-grid{grid-template-columns:repeat(4,1fr);max-width:1280px;margin:0 auto} }

.evi-card{display:block;text-decoration:none;color:inherit}
.evi-thumb{width:100%;aspect-ratio:16/9;object-fit:cover;display:block;border-radius:10px;background:#0f172a}
.evi-meta{margin-top:6px}
.evi-title{
  font-size:14px;line-height:1.25;color:#e5e7eb;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;min-height:2.5em
}
/* 0110 chatgpt end */

/* 0110 chatgpt start: hero sizing */
.hero-section-short{position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;filter:brightness(.55)}
@media (max-width:640px){ .hero-section-short{min-height:60vh} }
@media (min-width:641px){ .hero-section-short{min-height:72vh} }
.hero-overlay{position:relative;z-index:2;padding:clamp(20px,4vw,48px) 0}
.hero-copy h1{font-size:clamp(24px,4vw,44px);margin:0 0 8px}
.hero-copy .lead{font-size:clamp(14px,2.2vw,18px);max-width:60ch}
.hero-copy .cta-row{margin-top:12px}
/* 0110 chatgpt end */



/* ========== 0110 chatgpt: NORMALIZACIÓN Y ARREGLOS FINALES ========== */

/* 1) HERO: anular alto fijo, mantener full-bleed y estabilizar hover/zoom */
#hero,
.hero-section-short{
  height:auto !important;               /* anula height:450px definido arriba */
  background-size:cover !important;
  background-position:center !important;
  transform:none !important;
  transition:none !important;
}
.hero-section-short{ position:relative; overflow:hidden; }
.hero-bg{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; object-position:center;
  filter:brightness(.55);
  transform:none !important; transition:none !important; pointer-events:none;
}
@media (max-width:640px){ .hero-section-short{ min-height:60vh } }
@media (min-width:641px){ .hero-section-short{ min-height:72vh } }

/* 2) EVIDENCIA tipo YouTube: forzar que gane esta malla (2/3/4 columnas) */
section.evidence .evi-grid{ display:grid; gap:12px; }
@media (max-width:640px){  section.evidence .evi-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:641px) and (max-width:1023px){ section.evidence .evi-grid{ grid-template-columns:repeat(3,1fr); } }
@media (min-width:1024px){ section.evidence .evi-grid{ grid-template-columns:repeat(4,1fr); max-width:1280px; margin:0 auto; } }

/* 3) EVIDENCIA: legibilidad del título y tarjetas clicables */
section.evidence .evi-card{
  display:block; text-decoration:none; color:inherit;
  border-radius:12px; overflow:hidden; background:#fff; border:1px solid var(--border);
}
section.evidence .evi-thumb{ width:100%; aspect-ratio:16/9; object-fit:cover; display:block; background:#f4f6fa; }
section.evidence .evi-meta{ margin-top:6px; }
section.evidence .evi-title{
  font-size:14px; line-height:1.25; color:var(--text);   /* <-- antes era #e5e7eb (bajo contraste) */
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; min-height:2.5em;
}

/* 4) Contrastes en HERO: mantener blanco solo dentro del overlay */
.hero-overlay h1,
.hero-overlay .lead,
.hero-overlay p,
.hero-overlay a,
.hero-overlay li {
  color:#fff !important;
  text-shadow:0 2px 6px rgba(0,0,0,.4);
}

/* 5) (Opcional) eliminar zoom por hover del hero si alguna regla global lo aplica */
#hero:hover, #hero:hover .hero-bg { transform:none !important; }

/* ========== /0110 chatgpt ========== */


/* ========== 0110 chatgpt: HERO con espacio correcto (PC y móvil) ========== */

/* 1) El hero toma alto de pantalla y NO se encoje ni con hover */
#hero,
.hero-section-short{
  height:auto !important;
  background-size:cover !important;
  background-position:center !important;
  transform:none !important;
  transition:none !important;
}

/* 2) El overlay ocupa el alto y distribuye el contenido sin <br> */
#hero .hero-overlay{
  position:relative; z-index:2;
  display:flex; flex-direction:column;
  justify-content:center;        /* centrado vertical en desktop */
  gap:12px;
  min-height:clamp(480px, 72vh, 880px);
  padding:clamp(24px,4vw,56px) 0; /* margen superior/inf */
}

/* 3) En móvil, baja el copy para que respire sobre la imagen */
@media (max-width:640px){
  #hero .hero-overlay{
    justify-content:flex-end;    /* abajo en móvil */
    min-height:70vh;
    padding:16px 0 28px;
  }
  #hero .hero-copy h1{ font-size:clamp(22px,7.2vw,34px); line-height:1.1; }
  #hero .hero-copy .lead{ font-size:14px; max-width:45ch; }
  #hero .cta-row{ margin-top:8px; }
  #hero .bullets{ margin:6px 0 0; padding-left:18px; }
  #hero .bullets li{ margin:4px 0; }
}

/* 4) Gradiente sutil para legibilidad del texto sobre la foto/video */
#hero.hero-section-short::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(to bottom,
              rgba(0,0,0,.15) 0%,
              rgba(0,0,0,.35) 45%,
              rgba(0,0,0,.55) 100%);
}

/* 5) Inmuniza contra reglas globales de zoom al pasar el mouse */
#hero:hover, #hero:hover .hero-bg{ transform:none !important; }


/* 0110 chatgpt: cajas translúcidas en el HERO */
#hero .lead{
  display:inline-block;
  max-width:65ch;
  background:rgba(17,24,39,.48);      /* gris oscuro translúcido */
  padding:8px 12px;
  border-radius:10px;
  box-shadow:0 8px 24px rgba(0,0,0,.18);
  backdrop-filter:saturate(1.1) blur(2px);
}

#hero .cta-row,
#hero .bullets{
  background:rgba(17,24,39,.38);      /* mismo tono, un poco más claro */
  padding:10px 12px;
  border-radius:12px;
  backdrop-filter:saturate(1.1) blur(2px);
}

#hero .cta-row{ display:inline-flex; gap:10px; align-items:center; }
#hero .bullets{ margin-top:8px; padding-left:22px; }
#hero .bullets li{ margin:4px 0; }



/* 0110 chatgpt start: styles SOLO para #process */
.flow-process{
  position:relative; padding:28px 0; border-top:1px solid var(--border);
  background:linear-gradient(180deg,#f7f9ff, #fff); overflow:hidden;
}
.flow-process h2{
  font-family:Poppins,Inter,sans-serif; margin:0 0 12px;
  font-size:clamp(22px,2.4vw,30px); color:#0f1220;
}

/* “>>>” gigante de fondo, en azules, con pulso sutil */
.flow-process::before{
  content: ">>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>";
  position:absolute; right:-6vw; top:50%;
  transform:translateY(-50%) rotate(-8deg);
  font: 800 clamp(72px,18vw,220px) Poppins,Inter,sans-serif;
  line-height:1; letter-spacing:-.06em; white-space:nowrap;
  color:rgba(35,74,143,.06); pointer-events:none; user-select:none;
  animation:pulseChev 6s ease-in-out infinite;
}
@keyframes pulseChev{
  0%,100%{ color:rgba(35,74,143,.06) }
  50%{    color:rgba(47,95,184,.12) }
}

/* Grid de pasos (3 cols desktop, 1 col móvil) */
.flow-steps{
  list-style:none; margin:14px 0 0; padding:0;
  display:grid; gap:16px; grid-template-columns:repeat(3,1fr);
}
@media (max-width:960px){ .flow-steps{ grid-template-columns:1fr } }

/* Card de paso */
.flow-step{
  position:relative; background:#fff; border:1px solid var(--border);
  border-radius:14px; padding:16px;
  box-shadow:0 2px 10px rgba(0,0,0,.04);
  transition:transform .15s ease, box-shadow .15s ease;
}
.flow-step:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(35,74,143,.08);
}

/* Badge de número */
.flow-badge{
  position:absolute; top:-12px; left:-12px;
  width:36px; height:36px; border-radius:50%;
  background:var(--blue-dark); color:#fff; font-weight:800;
  display:grid; place-items:center;
  box-shadow:0 6px 18px rgba(47,95,184,.20);
}

/* Títulos y copia */
.flow-step h4{ margin:6px 0 6px; font-size:18px; color:#0f1220 }
.flow-step p{ margin:0; color:var(--muted) }

/* ===== Cómo trabajamos — reveal estilo “cards que suben” ===== */
:root{
  --ink:#0a0b10;        /* fondo negro azulado */
  --muted:#aab1c5;
  --card:#111423;
  --bd:rgba(255,255,255,.08);
  --vio:#7a00ff; --blu:#00c2ff; --fux:#ff2a7a;
}

#process.acc-reveal{
  position:relative; overflow:hidden;
  padding:48px 0 24px; background:var(--ink);
}

/* glow suave al fondo */
#process .acc-reveal__bg{
  position:absolute; inset:-10% -30% auto -30%;
  height:46vh; pointer-events:none;
  background:
    radial-gradient(60% 70% at 30% 30%, rgba(122,0,255,.22), transparent 70%),
    radial-gradient(40% 55% at 70% 50%, rgba(0,194,255,.18), transparent 70%);
  filter: blur(18px);
}

#process .acc-reveal__inner{ position:relative; z-index:1 }
#process .acc-reveal__h{
  color:#fff; margin:0 0 4px;
  font-size:clamp(32px,6vw,72px);
  line-height:1.04; letter-spacing:-.01em;
  position:sticky; top:72px; /* queda fijo mientras aparecen las cards */
  z-index:2;
}
#process .acc-reveal__lead{
  color:var(--muted); margin:8px 0 18px; font-size:clamp(14px,1.4vw,16px);
}

/* Grid de tarjetas (no uniformes) */
#process .acc-reveal__grid{
  display:grid; gap:18px;
  grid-template-columns:repeat(12,1fr);
  grid-auto-flow:dense;
}
@media (max-width: 960px){
  #process .acc-reveal__grid{ grid-template-columns:repeat(6,1fr) }
}
@media (max-width: 640px){
  #process .acc-reveal__grid{ grid-template-columns:repeat(4,1fr) }
}

#process > h2{
  color:#fff;
  margin:0 0 16px;
  line-height:1.1;
}




/* ===============================
Pagina Process es todos esto 

Paleta (naranja + azul)
   =============================== */
:root{
  --ink: #0b0f14;          /* negro profundo */
  --card:#0f1420;          /* fondo tarjeta (glass oscuro) */
  --txt:#fff;

  --brand-orange:#ff7a18;       /* naranja marca */
  --brand-orange-700:#ed6600;
  --brand-blue:#0b66ff;         /* azul marca */
  --brand-blue-700:#0839bf;

  --stroke:255 255 255;
}

/* ===============================
   Sección: fondo azul “eléctrico/vidrio”
   =============================== */
#process{
  position: relative;
  isolation: isolate;                  /* ya lo tienes, pero lo dejamos claro */
  --bleed: max(0px, (100vw - 100%) / 2);
}

/* Fondo principal: 3 focos azules + base oscura */
#process::before{
  content:"";
  position:absolute; inset:-1px;
  border-radius:24px;
  background:
    radial-gradient(60% 75% at 12% 10%,
      color-mix(in oklch, var(--brand-blue) 78%, white 8%) 0 42%,
      transparent 62%),
    radial-gradient(68% 78% at 86% 18%,
      color-mix(in oklch, #29b6ff 64%, transparent) 0 38%,
      transparent 60%),
    radial-gradient(70% 75% at 50% 94%,
      color-mix(in oklch, var(--brand-blue-700) 70%, black 10%) 0 42%,
      transparent 66%),
    linear-gradient(180deg,#0a0f18 0%,#0a0f18 60%);
  filter:saturate(1.08) blur(18px);
  opacity:.95;
  z-index:-1;
}

/* Brillo sutil tipo vidrio (opcional pero bonito) */
#process::after{
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: calc(-1 * var(--bleed));
  right: calc(-1 * var(--bleed));
  background: #0a0d12;                 /* negro profundo (puedes usar #000 si prefieres) */
  z-index: -2;                          /* detrás del gradiente (::before) y de las cards */
}

#process::before{
  z-index: -1;                          /* asegúrate que esté por encima del ::after */
}

/* ===============================
   Lista / Tarjetas
   =============================== */
#process .steps-line{
  list-style:none;
  margin:16px 0 0;
  padding:0;
  display:grid;
  grid-template-columns:1fr;      /* móvil: 1 columna */
  gap:16px;
  position:relative;
  z-index:1;
}

#process .step{
  background:linear-gradient(180deg,
    color-mix(in oklch, var(--card) 92%, #000 8%),
    var(--card)
  );
  border:1px solid rgba(var(--stroke)/0.06);
  border-radius:18px;
  padding:20px 18px 18px;
  min-height:clamp(120px,30vw,180px); /* igual en móvil */
  display:flex; flex-direction:column; justify-content:flex-start;
  box-shadow:
    0 10px 30px rgba(0,0,0,.25),
    inset 0 1px 0 rgba(255,255,255,.04);
  backdrop-filter:blur(2px);

  /* Animación (con stagger) */
  opacity:0;
  transform:translateY(40px) scale(.98);
  transition:
    transform .70s cubic-bezier(.2,.7,.2,1),
    opacity .6s ease .1s,
    border-color .2s ease;
  transition-delay:var(--stagger,0ms);
}

/* Hover (desktop): borde un pelín más visible */
@media (hover:hover){
  #process .step:hover{
    border-color:rgba(var(--stroke)/0.12);
  }
}

#process .step.in{
  opacity:1;
  transform:translateY(0) scale(1);
}

#process .step h4{
  margin:0 0 8px;
  font-weight:800;
  letter-spacing:.01em;
}

#process .step p{
  margin:0;
  line-height:1.5;
  opacity:.95;
}

/* Badge con degradé marca (naranja + azul) */
#process .step .badge{
  display:inline-grid; place-items:center;
  width:42px; height:42px;
  border-radius:12px;
  font:600 14px/1.2 ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  color:#fff; margin-bottom:10px;
  background:
    radial-gradient(120% 120% at 24% 22%, var(--brand-orange) 0 35%, transparent 40%),
    radial-gradient(120% 120% at 80% 80%, var(--brand-blue) 0 42%, transparent 50%),
    linear-gradient(135deg, var(--brand-orange-700), var(--brand-blue-700));
  box-shadow:0 8px 24px rgba(0,0,0,.35), inset 0 0 0 1px rgba(255,255,255,.18);
}

/* ===============================
   Desktop (12 columnas, mejor uso ancho)
   =============================== */
@media (min-width:992px){
  #process .steps-line{
    grid-template-columns:repeat(12, minmax(0,1fr));
    gap:22px;
  }
  #process .step{ min-height:220px; }

  /* Ocupa más ancho total:
     1) 1 / span 7   (col 1 a 7)
     2) 8 / span 5   (col 8 a 12)
     3) 3 / span 7   (col 3 a 9)
  */
  #process .step:nth-child(1){ grid-column:1 / span 7; }
  #process .step:nth-child(2){ grid-column:8 / span 5; min-height:240px; }
  #process .step:nth-child(3){ grid-column:3 / span 7; }
}

/* Accesibilidad: sin animación si el usuario la reduce */
@media (prefers-reduced-motion:reduce){
  #process .step{ transition:none; transform:none; opacity:1; }
}



/* Explode entrance es del home efecto explote*/
.fx-explode{ position:relative; contain:content; }
.fx-explode .callout{
  opacity:0;
  transform:
    translate(var(--dx,0px), var(--dy,0px))
    scale(var(--scale0,.40))
    rotate(var(--rot,8deg));
  transition:
    transform .90s cubic-bezier(.2,.7,.2,1),
    opacity .45s ease;
  transition-delay: var(--delay,0ms);
  will-change: transform, opacity;
  transform-origin: center center;
  border-radius: 14px;
  overflow: hidden;
}
.fx-explode.in .callout{
  opacity:1;
  transform: translate(0,0) scale(1) rotate(0deg);
}
@media(hover:hover){
  .fx-explode.in .callout:hover{
    transform: translate(0,-4px) scale(1.01);
  }
}
@media(prefers-reduced-motion:reduce){
  .fx-explode .callout{
    opacity:1 !important;
    transform:none !important;
    transition:none !important;
  }
}



/* ===== Full-bleed ribbon (azules eléctricos oscuros) ===== */
.brand-ribbon{
  /* hace que la franja ocupe TODO el ancho de la pantalla, aunque estés dentro de .wrap */
  width: 100vw;
  margin-inline: calc(50% - 50vw);
  padding-block: clamp(28px, 7vw, 88px);
  position: relative;
  color: #fff;
  isolation: isolate;
  /* separa visualmente de lo que sigue/precede */
  box-shadow:
    0 -24px 38px -24px rgba(0,0,0,.45) inset,
    0 24px 38px -24px rgba(0,0,0,.45) inset;
}

/* Fondo: combinación de gradientes con movimiento suave */
.brand-ribbon::before{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(70% 90% at 12% 18%, rgba(64,140,255,.22), transparent 60%),
    radial-gradient(80% 80% at 88% 82%, rgba(0,90,255,.20), transparent 55%),
    linear-gradient(135deg, #080e1b 0%, #0b1730 38%, #102a64 70%, #0a4cff 100%);
  filter: saturate(115%);
  z-index: -1;
  /* brillo desplazándose MUY sutilmente */
  background-size: 140% 140%;
  animation: ribbonShift 18s ease-in-out infinite alternate;
}
@keyframes ribbonShift{
  0%{ background-position: 0% 40%; }
  100%{ background-position: 100% 60%; }
}

/* Tipografía grande, moderna (usa las que ya cargas: Poppins/Inter) */
.ribbon-inner{
  max-width: 1100px;
  margin-inline: auto;
  text-align: center;
  font-family: "Poppins", "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial;
  font-weight: 800;
  font-size: clamp(18px, 2.6vw, 32px);
  line-height: 1.25;
  letter-spacing: .01em;
  text-wrap: balance;
  /* micro-glow para contraste en azul oscuro */
  text-shadow:
    0 1px 0 rgba(0,0,0,.25),
    0 6px 18px rgba(10,80,255,.28);
}

.ribbon-item{ opacity:.98; }
.sep{
  opacity:.5;
  margin-inline: .6ch;
}

/* Respeta usuarios con menos movimiento */
@media (prefers-reduced-motion: reduce){
  .brand-ribbon::before{ animation:none; }
}




/* ===== RIBBON full-bleed ===== */
.brand-ribbon{
  width: 100vw;
  margin-inline: calc(50% - 50vw);
  padding-block: clamp(28px, 7vw, 88px);
  position: relative;
  color: #fff;
  isolation: isolate; /* para manejar z-index negativos de los pseudo */
  box-shadow:
    0 -24px 38px -24px rgba(0,0,0,.45) inset,
    0 24px 38px -24px rgba(0,0,0,.45) inset;
}

/* Fondo base con azules eléctricos oscuros + movimiento MUY sutil */
.brand-ribbon::before{
  content:"";
  position:absolute; inset:0;
  z-index:-2;
  background:
    radial-gradient(70% 90% at 12% 18%, rgba(64,140,255,.22), transparent 60%),
    radial-gradient(80% 80% at 88% 82%, rgba(0,90,255,.20), transparent 55%),
    linear-gradient(135deg, #080e1b 0%, #0b1730 38%, #102a64 70%, #0a4cff 100%);
  filter: saturate(115%);
  background-size: 140% 140%;
  animation: ribbonShift 18s ease-in-out infinite alternate;
}
@keyframes ribbonShift{
  0%{   background-position: 0% 40%; }
  100%{ background-position: 100% 60%; }
}

/* “Sheen” / brillo diagonal desplazándose encima (muy sutil) */
.brand-ribbon::after{
  content:"";
  position:absolute; inset:-2px;
  z-index:-1;
  background:
    linear-gradient(120deg,
      transparent 0%,
      rgba(255,255,255,.06) 20%,
      rgba(255,255,255,.16) 28%,
      rgba(255,255,255,.06) 36%,
      transparent 55%);
  background-size: 300% 100%;
  animation: sheen 12s linear infinite;
  mix-blend-mode: screen;  /* suma brillo sin lavar el azul */
  pointer-events: none;
}
@keyframes sheen{
  0%   { background-position: -200% 0; }
  100% { background-position:  200% 0; }
}

/* ===== Tipografía y separación legible en todo el ancho ===== */
.ribbon-inner{
  max-width: min(1320px, 92vw);
  margin-inline: auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: clamp(14px, 2.8vw, 40px); /* separación visible entre items */
  font-family: "Poppins","Inter",ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Arial;
  font-weight: 800;
  font-size: clamp(18px, 2.6vw, 32px);
  line-height: 1.25;
  letter-spacing: .01em;
  text-align: center;
  text-wrap: balance;
  text-shadow:
    0 1px 0 rgba(0,0,0,.25),
    0 6px 18px rgba(10,80,255,.28);
}

.ribbon-item{
  position: relative;
  white-space: nowrap; /* cada item es bloque compacto */
  opacity: .98;
}

/* separador visual automático entre items (no hace falta poner “•” en HTML) */
.ribbon-item + .ribbon-item::before{
  content: "•";
  position: relative;
  top: -0.02em;
  margin: 0 clamp(8px, 1.4vw, 18px);
  opacity: .65;
  font-weight: 800;
}

/* Menos movimiento si el usuario lo solicita */
@media (prefers-reduced-motion: reduce){
  .brand-ribbon::before,
  .brand-ribbon::after{ animation: none; }
}

/* Parte dropbox menu*/

.site-header .nav.desktop-only .nav-tools {
  position: relative;
  display: inline-block;   /* se alinea como otro link */
}

/* Enlace "Herramientas ▾" */
.site-header .nav.desktop-only .nav-tools-toggle {
  text-decoration: none;
  color: inherit;          /* mismo color que el resto del menú */
  padding: 0 0.5rem;
  cursor: pointer;
}

/* Caja del menú desplegable */


