
    /* ——— NEO‑BRUTALISTA: alto contraste, bordes gruesos, sombras desplazadas ——— */
    :root{
      --bg:#e3f2fd;             /* crema */
      --surface:#ffffff;         /* tarjetas */
      --ink:#0f172a;             /* negro azuloso */
      --muted:#334155;           /* texto secundario */
      --brand:#06b6d4;           /* cian */
      --accent:#06b6d4;          /* ámbar */
      --border:#0f172a;          /* bordes fuertes */
      --radius:10px;
      --shadow:6px 6px 0 var(--border); /* sombra dura desplazada */
    }

    *{box-sizing:border-box}
    html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:"Inter", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif}
    a{color:inherit;text-decoration:none}
    img{max-width:100%;display:block;border-radius:8px;border:2px solid var(--border)}
    .container{max-width:1200px;margin:0 auto;padding:0 24px}

    /* Header con barra gruesa */
    .brand-logo {
    height: 45px; /* ajusta el tamaño del logo */
    margin-right: 8px; /* espacio entre logo y texto */
    vertical-align: middle;
    border: none;
    }
    header{position:sticky;top:0;z-index:20;background:var(--surface);border-bottom:3px solid var(--border)}
    .nav{display:flex;align-items:center;justify-content:space-between;padding:16px 0}
    .brand{display:flex;align-items:center;gap:12px;font-weight:900;color:var(--ink);font-size:18px}
    .brand-badge{width:40px;height:40px;border-radius:10px;background:var(--accent);display:grid;place-items:center;color:#fff;font-weight:900;border:2px solid var(--border);box-shadow:var(--shadow)}
    .menu{display:flex;gap:22px;align-items:center}
    .menu a{color:var(--ink);font-weight:800;padding:8px 10px;border:2px solid transparent;border-radius:8px}
    .menu a:hover{border-color:var(--border);background:#fff}
    .cta-top{padding:10px 16px;border:2px solid var(--border);background:var(--brand);color:#03242b;border-radius:10px;font-weight:900;box-shadow:var(--shadow)}
    .cta-top:hover{transform:translate(-2px,-2px)}

    /* Etiquetas de sección */
    .eyebrow{display:inline-block;margin-bottom:10px;padding:6px 10px;border:2px solid var(--border);border-radius:999px;background:#e6fffb;font-weight:900;letter-spacing:.06em;text-transform:uppercase;color:#064e58}

    /* Hero con layout invertido y bloques contundentes */
    .hero{padding:56px 0}
    .hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:center}
    .title-xl{font-size:clamp(38px,5.2vw,64px);line-height:1.02;margin:8px 0 12px;font-weight:1000}
    .lead{color:var(--muted);font-size:18px;max-width:60ch}
    .cta-row{display:flex;gap:12px;margin-top:20px;flex-wrap:wrap}
    .btn{display:inline-flex;align-items:center;gap:.6rem;background:var(--brand);color:#051923;padding:14px 20px;border-radius:12px;border:2px solid var(--border);font-weight:900;box-shadow:var(--shadow)}
    .btn:hover{transform:translate(-2px,-2px)}
    .btn--ghost{background:#fff;color:var(--ink)}

    .carousel {
  position: relative;
  overflow: hidden;
  width: 100%;
  max-width: 800px; /* Ajusta el tamaño máximo del carrusel */
  margin: 0 auto;
  border-radius: 12px;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

/* Contenedor para las imágenes */
.carousel-track-container {
  display: flex;
  transition: transform 0.5s ease-in-out; /* Animación suave para el movimiento */
}

.carousel-track img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

/* Estilo de los botones de navegación */
.carousel-button {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background-color: rgba(0, 0, 0, 0.5);
  color: white;
  border: none;
  padding: 10px;
  cursor: pointer;
  font-size: 24px;
  border-radius: 50%;
  z-index: 10;
}

.carousel-button.prev {
  left: 10px;
}

.carousel-button.next {
  right: 10px;
}

/* Estilo de los indicadores de los puntos */
.dots {
  display: flex;
  justify-content: center;
  margin-top: 10px;
}

.dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background-color: #dbe3ef;
  margin: 0 5px;
  cursor: pointer;
}

.dot.active {
  background-color: var(--brand); /* Resalta el punto activo */
}

    /* Títulos de sección con subrayado grueso */
    section{padding:60px 0}
    .section-title{font-size:clamp(26px,3.2vw,40px);margin:0 0 6px;font-weight:1000;border-bottom:4px solid var(--border);display:inline-block}
    .section-sub{color:var(--muted);margin:10px 0 24px}

    /* Grids / tarjetas con bordes y sombra dura */
    .grid{display:grid;gap:22px}
    .grid-3{grid-template-columns:repeat(3,1fr)}
    .grid-4{grid-template-columns:repeat(4,1fr)}
    .card{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
    .card h3{margin:12px 0 6px;font-weight:900}

    /* About con lista de insignias rectangulares */
    .about{display:grid;grid-template-columns:.9fr 1.1fr;gap:28px;align-items:center}
    .about .panel{background:var(--surface);border:2px solid var(--border);border-radius:12px;padding:22px;box-shadow:var(--shadow)}
    .keypoints{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}
    .keypoints li{list-style:none;border:2px solid var(--border);border-radius:8px;padding:8px 10px;background:#fff}

    /* Testimonios rectangulares */
    .testis{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
    .testi{background:#fff;border:2px solid var(--border);border-radius:10px;padding:18px;box-shadow:var(--shadow)}
    .quote{color:var(--muted);font-style:italic}

    /* Carrusel con marco y botones grandes */
    .carousel{position:relative;overflow:hidden;border-radius:12px;border:2px solid var(--border);box-shadow:var(--shadow)}
    .carousel-track{display:flex;transition:transform .5s cubic-bezier(.2,.9,.3,1)}
    .carousel img{width:100%;max-height:440px;object-fit:cover;border-radius:0;border:none}
    .carousel .nav{position:absolute;inset:0;display:flex;align-items:center;justify-content:space-between;padding:0 8px}
    .carousel button{background:var(--accent);border:2px solid var(--border);color:#231a00;width:48px;height:48px;border-radius:12px;cursor:pointer;font-weight:1000;box-shadow:var(--shadow)}
    .dots{display:flex;gap:8px;justify-content:center;margin-top:12px}
    .dot{width:10px;height:10px;border-radius:2px;background:#dbe3ef;border:2px solid var(--border)}
    .dot.active{background:var(--brand)}

    /* FAQ brusco */
    .faq{max-width:900px;margin:0 auto}
    .faq-item{border:2px solid var(--border);border-radius:12px;background:#fff;margin-bottom:12px;overflow:hidden;box-shadow:var(--shadow)}
    .faq-q{display:flex;justify-content:space-between;align-items:center;padding:16px 18px;cursor:pointer;font-weight:900}
    .faq-a{display:none;padding:0 18px 16px;color:var(--muted)}

    /* Contacto contundente */
    .contact .wrap{max-width:820px;margin:0 auto;background:#fff;border:2px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:24px}
    form{display:grid;gap:12px}
    input, textarea, select{width:100%;padding:12px 14px;border:2px solid var(--border);border-radius:10px;background:#fff;font:inherit}
    textarea{min-height:120px}

    .contact-wrap {
      display: flex;
      justify-content: space-between; /* Espacio entre las columnas */
      gap: 30px;  /* Espacio entre el formulario y la información */
    }

    /* Estilo para el formulario */
    .contact-form {
      flex: 1;  /* El formulario ocupa el 50% del espacio */
    }

    /* Estilo para la información de contacto */
    .contact-info {
      flex: 1;  /* La información de contacto ocupa el 50% del espacio */
      max-width: 500px;  /* Limita el ancho máximo de la columna de información */
    }

    /* Responsividad para pantallas pequeñas */
    @media (max-width: 768px) {
      .contact-wrap {
        flex-direction: column;  /* En pantallas pequeñas, las columnas se apilan */
        gap: 20px;
      }
    }
    footer{border-top:3px solid var(--border);background:#fff;color:var(--muted);padding:24px 0}

    /* Responsive */
    @media (max-width: 1100px){.grid-4{grid-template-columns:repeat(2,1fr)}}
    @media (max-width: 980px){
      .hero-grid,.about{grid-template-columns:1fr}
      .grid-3,.testis{grid-template-columns:1fr 1fr}
    }
    @media (max-width: 640px){
      .menu{display:none}
      .grid-3,.testis,.grid-4{grid-template-columns:1fr}
    }
  </style>