/* =====================================================================
   BBJ · refresh.css
   Capa de modernización NO destructiva. No cambia la maquetación ni la
   posición de imágenes: solo afina tipografía, color de elementos
   interactivos, foco accesible, sombras suaves y micro-interacciones.
   Se carga DESPUÉS de estilos.css para poder realzar sin reescribir.
   Paleta heredada del sitio: azul #0061a9 / #03406e, acento #ff5050.
   ===================================================================== */

:root {
  /* Marca (heredada, identidad preservada) */
  --bbj-azul: #0061a9;
  --bbj-azul-oscuro: #03406e;
  --bbj-azul-claro: #e8f1f9;
  --bbj-rojo: #e23b3b;        /* acento, versión con mejor contraste que #ff5050 */
  --bbj-tinta: #1d2125;        /* texto principal (AA sobre blanco) */
  --bbj-gris: #5b6168;         /* texto secundario */
  --bbj-linea: #e3e7ec;        /* bordes sutiles */
  --bbj-blanco: #ffffff;

  /* Sombras (suaves, no "ghost-card") */
  --sombra-sm: 0 1px 2px rgba(3, 64, 110, .06);
  --sombra-md: 0 6px 18px rgba(3, 64, 110, .10);
  --sombra-lg: 0 14px 34px rgba(3, 64, 110, .16);

  /* Radios moderados (cards 12-14px máx.) */
  --radio: 12px;
  --radio-sm: 8px;

  /* Curvas de salida (sin bounce) */
  --ease: cubic-bezier(.22, 1, .36, 1);
  --t-rapido: .18s var(--ease);
  --t-medio: .32s var(--ease);
}

/* ----------------------------------------------------------------
   Base: render tipográfico más limpio (sin tocar tamaños/layout)
   ---------------------------------------------------------------- */
html { scroll-behavior: smooth; }

body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

/* Títulos de sección: equilibra los saltos de línea (no cambia tamaño) */
h1, h2, h3 { text-wrap: balance; }
p { text-wrap: pretty; }

/* Imágenes: evita huecos por baseline y mejora el escalado */
img { image-rendering: auto; }

/* ----------------------------------------------------------------
   Foco accesible (el sitio no tenía estados de foco visibles)
   ---------------------------------------------------------------- */
a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible,
.btn:focus-visible {
  outline: 3px solid var(--bbj-azul);
  outline-offset: 2px;
  border-radius: 4px;
}

/* ----------------------------------------------------------------
   Navegación: subrayado animado en hover/activo (sin mover nada)
   ---------------------------------------------------------------- */
.navbar-light .navbar-nav .nav-link {
  position: relative;
  transition: color var(--t-rapido);
}
.navbar-light .navbar-nav .nav-link::after {
  content: "";
  position: absolute;
  left: .75rem;
  right: .75rem;
  bottom: 2px;
  height: 2px;
  background: var(--bbj-azul);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform var(--t-medio);
}
.navbar-light .navbar-nav .nav-link:hover::after,
.navbar-light .navbar-nav .nav-link:focus::after,
.navbar-light .navbar-nav .nav-link.active::after {
  transform: scaleX(1);
}

/* Redes sociales del menú: realce sutil */
.redes-sociales a,
.redes-sociales2 a {
  transition: transform var(--t-rapido), color var(--t-rapido);
  display: inline-block;
}
.redes-sociales a:hover,
.redes-sociales2 a:hover {
  transform: translateY(-2px);
  color: var(--bbj-azul);
}

/* ----------------------------------------------------------------
   Tarjetas de catálogo / marcas: elevación suave en hover
   (no cambia tamaño base, solo transform + sombra)
   ---------------------------------------------------------------- */
#catalaogos a,
#cla_dec a {
  display: inline-block;
  border-radius: var(--radio);
  overflow: hidden;
  transition: transform var(--t-medio), box-shadow var(--t-medio);
}
#catalaogos a img,
#cla_dec a img {
  border-radius: var(--radio);
  display: block;
  /* Evita desbordamiento si la columna es más angosta que el ancho fijo */
  max-width: 100%;
  height: auto;
}
#catalaogos a:hover,
#catalaogos a:focus-visible,
#cla_dec a:hover,
#cla_dec a:focus-visible {
  transform: translateY(-6px);
  box-shadow: var(--sombra-lg);
}

/* ----------------------------------------------------------------
   Botones: transición y elevación coherentes (respeta colores)
   ---------------------------------------------------------------- */
.btn,
.btn-send,
.btn_color .btn,
input[type="submit"] {
  transition: transform var(--t-rapido), box-shadow var(--t-rapido),
              background-color var(--t-rapido), filter var(--t-rapido);
  border-radius: var(--radio-sm);
}
.btn:hover,
.btn-send:hover,
input[type="submit"]:hover {
  transform: translateY(-2px);
  box-shadow: var(--sombra-md);
  filter: saturate(1.05);
}
.btn:active,
.btn-send:active { transform: translateY(0); }

/* ----------------------------------------------------------------
   Formularios: foco azul de marca, transición y placeholder legible
   ---------------------------------------------------------------- */
.form-control {
  transition: border-color var(--t-rapido), box-shadow var(--t-rapido);
}
.form-control:focus {
  border-color: var(--bbj-azul);
  box-shadow: 0 0 0 .2rem rgba(0, 97, 169, .18);
}
.form-control::placeholder { color: #8a9099; opacity: 1; }

/* ----------------------------------------------------------------
   Footer: enlaces con transición y subrayado en hover (legible)
   ---------------------------------------------------------------- */
footer .contact-link {
  transition: color var(--t-rapido), opacity var(--t-rapido);
}
footer .contact-link:hover {
  color: #fff;
  opacity: .82;
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* ----------------------------------------------------------------
   Botón flotante de WhatsApp: pulso sutil de atención
   ---------------------------------------------------------------- */
.whatsapp {
  transition: transform var(--t-rapido), box-shadow var(--t-rapido);
  box-shadow: var(--sombra-md);
}
.whatsapp:hover { transform: scale(1.08); box-shadow: var(--sombra-lg); }

@keyframes bbj-pulso {
  0%   { box-shadow: 0 0 0 0 rgba(37, 211, 102, .45); }
  70%  { box-shadow: 0 0 0 14px rgba(37, 211, 102, 0); }
  100% { box-shadow: 0 0 0 0 rgba(37, 211, 102, 0); }
}
.whatsapp { animation: bbj-pulso 2.6s var(--ease) infinite; }

/* ----------------------------------------------------------------
   Controles del carrusel: un poco más visibles y suaves
   ---------------------------------------------------------------- */
.carousel-control-prev,
.carousel-control-next { transition: opacity var(--t-rapido); }

/* Indicadores del carrusel con la marca */
.carousel-indicators li { transition: opacity var(--t-rapido); }

/* ----------------------------------------------------------------
   Botón "volver arriba" opcional (si se añade .bbj-top en el HTML)
   ---------------------------------------------------------------- */
.bbj-top {
  position: fixed;
  right: 22px;
  bottom: 92px;
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  background: var(--bbj-azul);
  color: #fff;
  border-radius: 50%;
  box-shadow: var(--sombra-md);
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity var(--t-medio), transform var(--t-medio), visibility var(--t-medio);
  z-index: 1030;
  text-decoration: none;
}
.bbj-top.is-visible { opacity: 1; visibility: visible; transform: translateY(0); }
.bbj-top:hover { background: var(--bbj-azul-oscuro); color: #fff; }

/* ----------------------------------------------------------------
   Selección de texto con la marca
   ---------------------------------------------------------------- */
::selection { background: rgba(0, 97, 169, .18); color: var(--bbj-tinta); }

/* ----------------------------------------------------------------
   Accesibilidad: respetar reducción de movimiento
   ---------------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *,
  *::before,
  *::after {
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .001ms !important;
  }
  .whatsapp { animation: none; }
}
