/* ============================================================
   RESPONSIVE — DDE ATLACOMULCO
   Mobile-first breakpoints
   ============================================================ */

/* ── Tablet ≤ 1024px ── */
@media (max-width: 1024px) {
  :root { --nav-h: 66px; }

  .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .footer__grid { grid-template-columns: 1fr 1fr; gap: var(--gap-lg) var(--gap-md); }

  /* Hero slider ajuste */
  .hero__content { max-width: 540px; }

  /* Navbar: ocultar nav links, mostrar hamburger */
  .navbar__nav,
  .navbar__actions .btn { display: none; }
  .navbar__hamburger { display: flex; }

  /* Menú móvil */
  .mobile-menu {
    position: fixed;
    top: var(--nav-h);
    left: 0; right: 0;
    background: #fff;
    box-shadow: var(--sombra-lg);
    padding: var(--gap-md);
    z-index: 850;
    max-height: calc(100vh - var(--nav-h));
    overflow-y: auto;
    transform: translateY(-110%);
    transition: transform var(--t-mid);
  }
  .mobile-menu.open { transform: translateY(0); }

  .mobile-menu .nav-link {
    display: block;
    padding: .75rem 1rem;
    border-bottom: 1px solid var(--gris-200);
    font-size: 1rem;
  }
  .mobile-menu .dropdown {
    position: static;
    transform: none;
    box-shadow: none;
    border: none;
    background: var(--gris-100);
    border-radius: var(--r-sm);
    margin: .25rem 0;
    opacity: 1;
    pointer-events: all;
    display: none;
    padding: 0;
  }
  .mobile-menu .nav-item.open .dropdown { display: block; }
  .mobile-menu .dropdown__link { padding: .55rem 1.5rem; }
  .mobile-menu__actions {
    display: flex;
    gap: var(--gap-sm);
    margin-top: var(--gap-md);
    flex-wrap: wrap;
  }

  /* Búsqueda en navbar abierta siempre */
  .navbar__search-input { width: 160px; opacity: 1; pointer-events: all; }
  .navbar__search.open .navbar__search-input { width: 160px; }

  /* Servicios */
  .servicios-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ── Mobile ≤ 768px ── */
@media (max-width: 768px) {
  :root {
    --gap-xl: 4rem;
    --gap-lg: 2.4rem;
  }

  .topbar { display: none; }
  .acc-bar { font-size: .72rem; }

  .grid-2,
  .grid-3 { grid-template-columns: 1fr; }

  .footer__grid { grid-template-columns: 1fr; gap: var(--gap-lg); }
  .footer__bottom { flex-direction: column; text-align: center; gap: .4rem; }

  /* Hero */
  .hero { min-height: 480px; }
  .hero__content { padding: var(--gap-lg) 0; }
  .hero__buttons { flex-direction: column; gap: .75rem; }
  .hero__buttons .btn { justify-content: center; }

  /* Slider dots */
  .slider__dots { bottom: 1rem; }

  /* Acceso rápido */
  .acceso-grid { grid-template-columns: repeat(2, 1fr); gap: var(--gap-sm); }
  .acceso-card__icon { font-size: 1.8rem; }

  /* Noticias */
  .noticias-grid { grid-template-columns: 1fr; }

  /* Stats */
  .stats-grid { grid-template-columns: repeat(2, 1fr); gap: var(--gap-md); }

  /* Servicios */
  .servicios-grid { grid-template-columns: 1fr; }

  /* Newsletter */
  .newsletter__form { flex-direction: column; }
  .newsletter__input { border-radius: var(--r-sm) !important; }
  .newsletter__btn   { border-radius: var(--r-sm) !important; }

  /* WhatsApp */
  .wa-float { bottom: 1.2rem; right: 1.2rem; }
  .wa-float__btn { width: 48px; height: 48px; font-size: 1.4rem; }
}

/* ── Pequeño móvil ≤ 480px ── */
@media (max-width: 480px) {
  :root { --gap-xl: 3.2rem; }

  .acceso-grid { grid-template-columns: 1fr; }
  .stats-grid  { grid-template-columns: 1fr; }

  .btn--lg { padding: .85rem 1.6rem; font-size: 1rem; }

  .section__eyebrow { font-size: .7rem; }

  .hero__title { font-size: clamp(1.9rem, 8vw, 2.6rem); }
}

/* ── Preferencia de movimiento reducido ── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    transition-duration: .01ms !important;
  }
}

/* ── Print ── */
@media print {
  .navbar, .footer, .wa-float, .acc-bar, .topbar { display: none !important; }
  body { font-size: 12pt; }
}

/* ── Nuevos servicios — responsive global ── */
@media (max-width: 768px) {
  /* Grids de 2 columnas que colapsan a 1 en móvil */
  .grid-2col-responsive {
    grid-template-columns: 1fr !important;
  }

  /* Diagnóstico de microcréditos */
  .diag-opcion { font-size: .88rem; padding: .75rem .9rem; }

  /* Maquinaria — tarjetas de equipo */
  .maq-equipo-card { padding: .9rem; }
  .maq-equipo-card__icon { font-size: 2rem; }
  .maq-equipo-card__nombre { font-size: .82rem; }

  /* Certificado preview en oscuro — ocultar en móvil muy pequeño */
  #cert-preview-wrap { min-height: auto; }

  /* Feria virtual — categorías en wrap */
  .feria-cats { gap: .35rem; }
  .feria-cat  { font-size: .8rem; padding: .35rem .9rem; }

  /* Carta de presentación — mover preview debajo del form */
  #carta-preview-visual { min-height: 300px; }
}

@media (max-width: 480px) {
  /* Feria — grid forzado a 1 col en pantallas muy pequeñas */
  .feria-grid { grid-template-columns: 1fr !important; }
}

@media (max-width: 768px) {
  /* 3-col grids en nuevas secciones */
  .grid-3col-responsive,
  .maq-grid-equipos {
    grid-template-columns: 1fr 1fr !important;
  }
}

@media (max-width: 480px) {
  .grid-3col-responsive,
  .maq-grid-equipos {
    grid-template-columns: 1fr !important;
  }
}
