/* assets/css/home.css — estilos específicos de la página de inicio (index) */

:root {
  --mh-font: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --mh-radius: 0.85rem;
  --mh-radius-sm: 0.5rem;
  --mh-card-shadow: 0 2px 16px rgba(13, 110, 253, 0.07);
  --mh-card-shadow-hover: 0 14px 36px rgba(13, 110, 253, 0.14);
  --mh-section-max: 42rem;
  --mh-transition: 0.22s ease;
}

#app main {
  font-family: var(--mh-font);
}

/* —— Sección presentación —— */
#nosotros {
  border-bottom: 1px solid rgba(13, 110, 253, 0.08);
}

#nosotros .lead {
  max-width: 48rem;
  margin-left: auto;
  margin-right: auto;
}

#nosotros h1 {
  letter-spacing: -0.02em;
  line-height: 1.2;
}

#nosotros h2.text-secondary {
  font-weight: 500;
  font-size: clamp(1.1rem, 2.5vw, 1.35rem);
}

/* —— Video —— */
section.py-4 video {
  border-radius: var(--mh-radius);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
}

/* —— Catálogo de equipos —— */
#equipos {
  background: linear-gradient(180deg, rgba(13, 110, 253, 0.03) 0%, transparent 28%);
}

#equipos #equipos-titulo {
  font-weight: 700;
  letter-spacing: -0.02em;
}

#equipos > .container > p.text-center {
  max-width: var(--mh-section-max);
  margin-left: auto;
  margin-right: auto;
  color: #495057;
}

#equipos .card {
  border: 1px solid rgba(0, 0, 0, 0.06);
  border-radius: var(--mh-radius);
  box-shadow: var(--mh-card-shadow);
  transition: box-shadow var(--mh-transition), transform var(--mh-transition), border-color var(--mh-transition);
  overflow: hidden;
}

#equipos .card:hover {
  box-shadow: var(--mh-card-shadow-hover);
  transform: translateY(-3px);
  border-color: rgba(13, 110, 253, 0.2);
}

#equipos .card-title {
  font-weight: 600;
  letter-spacing: -0.01em;
}

#equipos .card .carousel {
  border-radius: var(--mh-radius) var(--mh-radius) 0 0;
  overflow: hidden;
}

#equipos article.no-result {
  opacity: 0.35;
  pointer-events: none;
}

/* —— Contacto —— */
#contacto .lead {
  max-width: 40rem;
  margin-left: auto;
  margin-right: auto;
}

#contacto .btn-lg {
  border-radius: 999px;
  padding-left: 1.75rem;
  padding-right: 1.75rem;
  font-weight: 600;
  box-shadow: 0 4px 14px rgba(25, 135, 84, 0.35);
}

#contacto .btn-lg:hover {
  box-shadow: 0 6px 20px rgba(25, 135, 84, 0.45);
}

#contacto .card.shadow-sm {
  border-radius: var(--mh-radius);
  overflow: hidden;
  border: 1px solid rgba(0, 0, 0, 0.06);
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.08) !important;
}

#contacto .card-header {
  border-bottom: none;
  padding-top: 1rem;
  padding-bottom: 1rem;
}

#master-map {
  min-height: 280px;
}

#contacto .card-footer .btn {
  border-radius: 999px;
}

/* —— Buscador (header inyectado; bordes ya en header.css) —— */
#buscadorHerramientas:focus {
  box-shadow: 0 0 0 3px rgba(13, 110, 253, 0.25);
}

/* —— FAQ (SEO + legibilidad) —— */
#preguntas-frecuentes .accordion-button {
  font-weight: 600;
  font-size: 0.95rem;
}

#preguntas-frecuentes .accordion-body {
  color: #495057;
  line-height: 1.55;
}

[data-theme="dark"] #preguntas-frecuentes .accordion-body {
  color: #ced4da;
}

[data-theme="dark"] #preguntas-frecuentes .accordion-button {
  background-color: var(--card-dark, #2d2d2d);
  color: var(--text-dark, #e9ecef);
}

[data-theme="dark"] #preguntas-frecuentes .accordion-item {
  background-color: var(--card-dark, #2d2d2d);
  border-color: var(--border-dark, #495057);
}

/* —— Modo oscuro —— */
[data-theme="dark"] #equipos {
  background: linear-gradient(180deg, rgba(77, 171, 247, 0.06) 0%, transparent 28%);
}

[data-theme="dark"] #equipos > .container > p.text-center {
  color: #adb5bd;
}

[data-theme="dark"] #equipos .card {
  border-color: var(--border-dark, #495057);
}

[data-theme="dark"] #equipos .card:hover {
  box-shadow: 0 14px 40px rgba(0, 0, 0, 0.45);
  border-color: rgba(77, 171, 247, 0.35);
}

[data-theme="dark"] #contacto .card.shadow-sm {
  border-color: var(--border-dark, #495057);
}

[data-theme="dark"] section.py-4 video {
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4);
}

@media (prefers-reduced-motion: reduce) {
  #equipos .card {
    transition: none;
  }

  #equipos .card:hover {
    transform: none;
  }
}
