/* =========================================================
   Andrade Turismo — sitio · estilos responsive
   (los tamaños fluidos viven en styles.css vía clamp();
    aquí van los cambios de layout por breakpoint)
   ========================================================= */

/* ---- Desktop chico / tablet horizontal ---- */
@media (max-width: 900px) {
  .hero__card { aspect-ratio: auto; height: 600px; min-height: 600px; }
  .hero__desc { max-width: 100%; }
}

/* ---- Tablet vertical ---- */
@media (max-width: 720px) {
  .footer__grid { grid-template-columns: 1fr; row-gap: 34px; }

  /* CTA final: QR y WhatsApp como 2 columnas cuadradas iguales — el QR
     es el protagonista en mobile, no un botón secundario apilado.
     El texto del QR se oculta visualmente (queda accesible para lectores
     de pantalla); el de WhatsApp se mantiene visible, ícono + label. */
  .cta__actions { display: grid; grid-template-columns: 1fr 1fr; align-items: stretch; }
  .cta__whats,
  .cta__qr { aspect-ratio: 1 / 1; height: auto; padding: 10px; }
  .cta__whats svg { width: 40px; height: 40px; }
  .cta__whats-title { font-size: 13px; }
  .cta__qr-text {
    position: absolute;
    width: 1px; height: 1px;
    margin: -1px; padding: 0;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }
  .cta__qr { flex-direction: column; justify-content: center; align-items: center; gap: 0; }
  .cta__qr-img { width: 76%; height: 76%; margin: 0 auto; }
}

/* ---- Sellos: 1 columna, mismo ancho que la card do logo (.experience__mark) ---- */
@media (max-width: 680px) {
  .seals__grid { grid-template-columns: 1fr; gap: 10px; max-width: 300px; margin: 0 auto; }
  .seal { column-gap: 18px; row-gap: 8px; padding: 14px 16px; }
  .seal__title { font-size: 1.02rem; }
  .seal__text { font-size: .82rem; }
}

/* ---- Experiência (selos + cta fundidos): compacta el bloque en mobile ---- */
@media (max-width: 680px) {
  .experience { padding: clamp(36px, 10vw, 64px) 20px; }
  .experience__divider { margin: 20px auto; }
  .cta__actions { max-width: 420px; margin-top: 8px; }
}

/* ---- Móvil grande ---- */
@media (max-width: 640px) {
  .hero { padding: 12px; }
  .hero__card { height: 92vh; min-height: 92vh; border-radius: 20px; }
  .hero__content { padding: 22px 22px 24px; }
  .hero__menu { gap: 14px; }
  .hero__logo img { height: 42px; }
  .hero__main { align-items: center; }
  .hero__copy { max-width: 100%; }
  .hero__title { line-height: 1.04; }
  .hero__actions { gap: 12px; }
  .btn--primary,
  .btn--ghost { flex: 1 1 auto; justify-content: center; }
}

/* ---- Footer: apila copyright + crédito ---- */
@media (max-width: 560px) {
  .footer__bottom { flex-direction: column; gap: 8px; text-align: center; align-items: center; }
}

/* ---- Footer: todo el contenido centrado (logo, contato, redes, copyright) ---- */
@media (max-width: 500px) {
  .footer__grid { text-align: center; }
  .footer__brand { align-items: center; }
  .footer__about { margin-left: auto; margin-right: auto; }
  .footer__col { align-items: center; }
  .footer__link,
  .footer__item { justify-content: center; }
}

/* ---- Features: cuadrícula 2 x 2 ---- */
@media (max-width: 500px) {
  .features__card { grid-template-columns: repeat(2, 1fr); row-gap: 28px; }
  .feature { border-right: none; padding-left: 8px; padding-right: 8px; }
  .feature:nth-child(odd) { border-right: 1px solid rgba(20, 58, 64, .12); }
}

/* ---- Móvil chico ---- */
@media (max-width: 460px) {
  .progress { display: none; }
  .hero__footer-left { gap: 16px; }
  .hero__menu .nav-link:not(.nav-link--cta) { display: none; } /* deja logo + Contato */
  .hero__title-main { font-size: clamp(46px, 16vw, 72px); }
}
