:root{
  --primary:#0C2A4D;
  --secondary:#1F4678;
  --accent:#4C7CB7;
  --white:#FFFFFF;
  --text:#1B2430;
  --muted:#6D6D6D;
  --bg:#FFFFFF; /* 70% white */
  --radius:16px;
  --shadow:0 10px 30px rgba(12,42,77,.08);
}

*{
  box-sizing:border-box;
}

html, body{
  margin:0;
  padding:0;
  background:var(--bg);
  color:var(--text);
  font-family:"Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  overflow-x: clip;
  overflow-y: visible;
}

.container{
  width:min(1180px,92%);
  margin:0 auto;
}

a{
  color:var(--secondary);
  text-decoration:none;
}

img{
  max-width:100%;
  display:block;
}

/* HEADER */

.header{
  position: sticky;
  top: 0;
  background: rgba(255,255,255,.96);
  backdrop-filter: saturate(180%) blur(6px);
  border-bottom: 1px solid #eef2f6;
  z-index: 9999;
}

.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 0;
  position:relative;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
}

.brand-logo{
  height:80px;
  display:flex;
  align-items:center;
}

.brand-logo img{
  height:100%;
  width:auto;
}

/* NAV */

.nav{
  display:flex;
  gap:22px;
  align-items:center;
}

.nav a{
  font-weight:500;
  font-size:14px;
  color:#20334a;
}

.nav a.cta {
  color: #ffffff !important;
}


.nav a:hover{
  color:var(--secondary);
}

.cta{
  background:var(--primary);
  color:var(--white);
  padding:10px 16px;
  border-radius:12px;
  font-weight:600;
  font-size:14px;
}
/* Toggle mobile */

.nav-toggle{
  display:none;
}

.nav-toggle-label{
  display:none;
  width:36px;
  height:36px;
  border-radius:999px;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}

.nav-toggle-label span,
.nav-toggle-label span::before,
.nav-toggle-label span::after{
  display:block;
  width:20px;
  height:2px;
  background:#20334a;
  border-radius:2px;
  position:relative;
  transition:.2s ease;
}

.nav-toggle-label span::before,
.nav-toggle-label span::after{
  content:"";
  position:absolute;
  left:0;
}

.nav-toggle-label span::before{
  top:-6px;
}

.nav-toggle-label span::after{
  top:6px;
}

/* HERO */

.hero-grid{
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 40px;
  align-items: center;
}

.hero-text{
  grid-column: span 6;
}

.hero-visual{
  grid-column: span 6;
}

h1{
  font-weight:700;
  letter-spacing:-.3px;
  color:#0C2A4D;
  margin:.6em 0 12px;
  font-size:48px;
  line-height:1.2;
}

.lead{
  color:var(--muted);
  font-size:18px;
  line-height:1.7;
  margin:0 0 18px;
}

.btns{
  display:flex;
  gap:12px;
  margin-top:8px;
}

.btn{
  padding:14px 18px;
  border-radius:14px;
  font-weight:600;
  font-size:14px;
  border:2px solid transparent;
}

.btn-primary{
  background:var(--secondary);
  color:#fff;
  cursor: pointer;
}

.btn-ghost{
  background:#f3f7fc;
  border-color:#e2eaf5;
  color:#0C2A4D;
}

.hero-visual{
  border-radius:18px;
  box-shadow:var(--shadow);
  overflow:hidden;
  background:linear-gradient(135deg,#e9f0fb,#dfe8f6);
}

/* ===== SLIDER HERO ESTABLE ===== */
.hero-text,
.hero-visual {
  min-width: 0;   /* 🔥 permite que el contenido se encoja */
}

.slider{
  position: relative;
  width: 100%;
  aspect-ratio: 1200 / 768;
  border-radius: 24px;
  overflow: hidden;
  background: #ffffff; /* evita franja azul */
}

.slider .slides{
  display: flex;
  height: 100%;
  transition: transform 1s ease-in-out;
}

.slider .slide{
  flex: 0 0 100%;
  height: 100%;
}

.slider .slide img{
  width: 100%;
  height: 100%;
  object-fit: contain; /* desktop */
  object-position: center;
  display: block;
}

@media (max-width: 1024px){
  .slider .slide img{
    object-fit: cover;
  }
}

@media (max-width: 560px){
  .slider .slide img{
    object-fit: cover;
  }
}




/* SECCIONES */

.section{
  padding:72px 0;
}

.section h2{
  color:#0C2A4D;
  font-weight:700;
  font-size:36px;
  letter-spacing:-.2px;
  margin:0 0 22px;
}

/* CARDS SERVICIOS */
.service-icon{
  font-size: 44px;
  color: var(--secondary);
  margin-bottom: 12px;
}

.card .go i{
  margin-left: 6px;
  transition: transform .2s ease;
}

.card .go:hover i{
  transform: translateX(4px);
}

.cards{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}

.card{
  background:#fff;
  border:1px solid #eaf0f6;
  border-radius:16px;
  box-shadow:var(--shadow);
  padding:18px;
}

.card h3{
  margin:6px 0 8px;
  font-size:22px;
  color:#1b2a3a;
  font-weight:700;
}

.card p{
  margin:0;
  color:#4b5563;
  line-height:1.6;
}

.card .go{
  margin-top:10px;
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-weight:700;
  color:#1F4678;
}

/* DIFERENCIALES */

.pills{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}

.pill{
  background:#0C2A4D;
  color:#dfeaff;
  padding:20px;
  border-radius:16px;
  box-shadow:var(--shadow);
}

.pill b{
  display:block;
  margin-bottom:6px;
  color:#fff;
}

/* ========= SLIDER CLIENTES (CAJA + SOMBRA) ========= */
.logo-slider-2-rows{
  width:100%;
  overflow:hidden;
  border:1px solid #eaf0f6;
  border-radius:16px;
  background:#fff;
  box-shadow:var(--shadow);
  padding:20px 0;
  display:flex;
  flex-direction:column;
  gap:26px;
  margin-top:8px;
}


.logo-track{
  display:flex;
  gap:34px;
  width:max-content;
  align-items:center;
  will-change: transform;
}

.logo-item img{
  height:52px;
  width:auto;
  object-fit:contain;
  filter:grayscale(100%);
  opacity:.9;
  transition:.2s ease;
}

.logo-item:hover img{
  filter:none;
  opacity:1;
  transform: scale(1.06);
}

@keyframes scrollTrack {
  0% { transform: translateX(0); }
  100% { transform: translateX(calc(-1 * var(--track-width))); }
}


/* ========= SLIDER SECTORES ========= */
.sector-slider{
  width:100%;
  overflow:hidden;
  border:1px solid #eaf0f6;
  border-radius:16px;
  background:#fff;
  box-shadow:var(--shadow);
  padding:12px 0;
  margin-top:12px;
}

.sector-track{
  display:flex;
  gap:16px;
  align-items:center;
  width:max-content;
  animation: scroll-sectors 22s linear infinite;
}

.sector-item{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border:1px solid #eef2f6;
  background:#f8fbff;
  border-radius:999px;
  font-weight:700;
  color:#0C2A4D;
  white-space:nowrap;
}

.sector-item i{
  color: var(--secondary);
  font-size:18px;
}

@keyframes scroll-sectors{
  0%{ transform: translateX(0); }
  100%{ transform: translateX(-50%); }
}

/* Pausa al pasar mouse (UX) */
.logo-slider-2-rows:hover .logo-track,
.sector-slider:hover .sector-track{
  animation-play-state: paused;
}


/* Responsive */
@media (max-width: 768px){
  .logo-item img{ height:44px; max-width:120px; }
  .logo-track{ gap:22px; animation-duration:22s; }
  .sector-track{ animation-duration:18s; }
}


/* CONTACTO */

.split{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:22px;
  align-items:start;
}

.panel{
  background:#fff;
  border:1px solid #eaf0f6;
  border-radius:16px;
  box-shadow:var(--shadow);
  padding:22px;
}

label{
  display:block;
  margin:10px 0 6px;
  color:#334155;
  font-weight:600;
}

input,
textarea{
  width:100%;
  padding:12px 14px;
  border:1px solid #d7deea;
  border-radius:10px;
  background:#fbfdff;
  font-size:16px;
}

.form-actions{
  margin-top:10px;
}

/* FOOTER */
/* ===========================
   FOOTER GENERAL
=========================== */
.footer{
  background:#0C2A4D;
  color:#d8e6ff;
  padding:42px 0 0;
  margin-top:24px;
}

/* 4 columnas dentro de .container, igual que el resto de la web */
.footer-grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr)); /* 4 columnas iguales y cada una puede encoger */
  gap:24px;
}

.footer-clients{
  min-width: 0;  /* 🔥 clave: permite que la columna 4 se adapte al grid sin romperlo */
}

.footer h4{
  margin:0 0 10px;
  color:#fff;
  font-size:16px;
}

/* ===========================
   COL 1: Marca + descripción + redes
=========================== */
.footer-brand p{
  max-width:420px;
  font-size:14px;
  line-height:1.6;
}

.footer-logo img{
  max-width:180px;
  height:auto;
  margin-bottom:10px;
}

/* Redes */
.footer-social{
  display:flex;
  gap:10px;
  margin-top:12px;
}

.footer-social a{
  width:32px;
  height:32px;
  border-radius:999px;
  border:1px solid rgba(216,230,255,.5);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#d8e6ff;
  font-size:14px;
  transition:.2s ease;
}

.footer-social a:hover{
  background:#d8e6ff;
  color:#0C2A4D;
}

/* ===========================
   COL 2 y 3: Informes + links
=========================== */
.footer-info ul,
.footer-links ul{
  list-style:none;
  padding:0;
  margin:0 0 12px;
}

.footer-info li{
  display:flex;
  align-items:flex-start;
  gap:8px;
  margin-bottom:6px;
  font-size:14px;
}

.footer-info i{
  margin-top:3px;
  font-size:14px;
}

.footer-links ul li a{
  font-size:14px;
  color:#d8e6ff;
}

.footer-links ul li a:hover{
  text-decoration:underline;
}

/* ===========================
   COL 4: Slider de clientes
   (usa .logo-track y .logo-item que ya tienes)
=========================== */

/* caja del slider dentro de la 4ª columna */
.footer-logo-slider{
  width:100%;
  max-width:100%;
  min-width:0;
  overflow:hidden;         /* lo que sobre se oculta dentro de la caja */
  border:1px solid #eaf0f6;
  border-radius:16px;
  background:#fff;
  box-shadow:var(--shadow);
  padding:12px 10px;
  margin-top:10px;
  display:flex;
  flex-direction:column;
  gap:14px;
}

/* tracks del footer (usan mismo JS que el slider grande) */
.footer-logo-slider .logo-track{
  display:flex;
  align-items:center;
  gap:22px;
  /* NO usar width:max-content aquí, deja que el overflow lo recorte */
  will-change: transform;
  animation: scrollTrackFooter 24s linear infinite;
}

/* logos dentro del footer */
.footer-logo-slider .logo-item img{
  height:34px;
  width:auto;
  object-fit:contain;
  filter:grayscale(100%);
  opacity:.9;
  transition:.2s ease;
}

.footer-logo-slider .logo-item img:hover{
  filter:none;
  opacity:1;
  transform:scale(1.05);
}

/* animación específica para el footer (no toca el slider de arriba) */
@keyframes scrollTrackFooter{
  0%{ transform:translateX(0); }
  100%{ transform:translateX(-50%); }
}

/* pausa al pasar mouse */
.footer-logo-slider:hover .logo-track{
  animation-play-state:paused;
}

/* ===========================
   BARRA INFERIOR
=========================== */
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.12);
  margin-top:28px;
  padding:14px 0;
}

.footer-bottom-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  font-size:13px;
  color:#b9c9f0;
}

.footer-dev{
  opacity:.9;
}

/* ===========================
   BOTONES WHATSAPP FLOTANTES
=========================== */
.wa-btn{
  position:fixed;
  right:18px;
  z-index:9999;
  display:flex;
  align-items:center;
  gap:8px;
  padding:10px 14px;
  border-radius:999px;
  background:#25D366;
  color:#fff;
  font-weight:600;
  font-size:13px;
  box-shadow:0 10px 25px rgba(0,0,0,.25);
  text-decoration:none;
}

.wa-btn i{
  font-size:18px;
}

.wa-btn-quote{
  bottom:92px;
}

.wa-btn-support{
  bottom:40px;
}

/* ===========================
   RESPONSIVE
=========================== */
@media (max-width: 900px){
  .footer-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .footer-logo-slider .logo-item img{
    height:30px;
  }
}

@media (max-width: 640px){
  .footer-grid{
    grid-template-columns:1fr;
  }

  .footer-bottom-inner{
    flex-direction:column;
    align-items:flex-start;
  }

  .wa-btn span{
    display:none;
  }

  .footer-logo-slider{
    padding:10px;
    gap:12px;
  }

  .footer-logo-slider .logo-track{
    gap:16px;
    animation-duration:20s;
  }

  .footer-logo-slider .logo-item img{
    height:26px;
  }
}
/* BREAKPOINTS */

/* Tablet (<= 1024px o <= 768px según tu diseño) */
@media (max-width: 1024px){
   .slider .slide img{
    object-fit: cover;
  }
  .hero-grid{
    grid-template-columns: repeat(12, 1fr); /* puedes dejarlo igual */
  }
  .hero-text,
  .hero-visual{
    grid-column: span 12; /* ahora bajan uno debajo del otro */
  }

  .slider{ aspect-ratio: 16/12; }

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

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

  .grid-logos{
    grid-template-columns:repeat(3,1fr);
  }

  .split{
    grid-template-columns:1fr;
  }

  .footer .cols{
    grid-template-columns:1fr 1fr;
  }
}


/* Móvil grande (<= 768px) */
@media (max-width: 768px){
  .hero-text,
  .hero-visual{
    grid-column: span 12;
  }

  .hero-grid{
    gap: 20px; /* reduce espacio para evitar empujes */
  }
  .hero-text,
  .hero-visual{
    grid-column: span 12;
  }

  .header-inner{
    padding:10px 0;
  }

  .nav{
    position:absolute;
    top:100%;
    left:0;
    right:0;
    background:#ffffff;
    flex-direction:column;
    align-items:flex-start;
    padding:16px 24px 24px;
    gap:12px;
    border-bottom:1px solid #e5eaf3;
    box-shadow:0 12px 30px rgba(12,42,77,.08);
    display:none;
  }

  .nav a{
    font-size:15px;
  }

  .cta{
    width:100%;
    text-align:center;
  }

  .nav-toggle-label{
    display:flex;
  }

  .nav-toggle:checked ~ .nav{
    display:flex;
  }
}


/* Móvil chico (<= 560px) */
@media (max-width: 560px){
   .slider .slide img{
    object-fit: cover;
  }
  .hero-visual{
    margin-top: 12px; /* un poco de aire */
  }

  .slider{ aspect-ratio: 4/3; }

  h1{
    font-size:36px;
  }

  .cards{
    grid-template-columns:1fr;
  }

  .pills{
    grid-template-columns:1fr;
  }

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

  .footer .cols{
    grid-template-columns:1fr;
  }
}

