/* ==========================================================
   RESPONSIVO — mobile-first priority
   Breakpoints: 1200 · 1024 · 900 · 768 · 640 · 480 · 420
   ========================================================== */

/* ========= 1200 ========= */
@media (max-width: 1200px) {
  :root { --header-h: 96px; }
  .container { padding: 0 var(--space-5); }
  .hero-grid { gap: var(--space-7); }
  .hero-card { left: -30px; width: 220px; }
  .brand-logo { height: 80px; }
  .footer-grid { grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr; gap: var(--space-5); }
}

/* ========= 1024 ========= */
@media (max-width: 1024px) {
  :root { --header-h: 88px; }
  section { padding: var(--space-8) 0; }

  .nav-primary { display: none; }
  .nav-contacts { display: none; }
  .nav-toggle { display: inline-flex; }
  .brand-logo { height: 72px; }

  .hero-grid { grid-template-columns: 1fr; gap: var(--space-7); }
  .hero-visual { max-width: 460px; margin: 0 auto; }
  .hero-stats { max-width: 100%; }
  .hero-card { left: auto; right: -20px; top: 6%; }

  .section-head { grid-template-columns: 1fr; gap: var(--space-5); }
  .feature-split { grid-template-columns: 1fr; gap: var(--space-7); }
  .feature-image { max-width: 520px; margin: 0 auto; }

  .quick-grid { grid-template-columns: repeat(2, 1fr); }
  .news-grid { grid-template-columns: repeat(2, 1fr); }
  .insti-grid { grid-template-columns: repeat(2, 1fr); }

  .footer-grid {
    grid-template-columns: 1fr 1fr 1fr;
    grid-template-areas:
      "brand brand brand"
      "contato nav insti"
      "contato apoiar apoiar";
  }
  .footer-brand-col { grid-area: brand; text-align: center; }
  .footer-brand-col .footer-logo img { margin: 0 auto var(--space-4); }
  .footer-brand-col .footer-tag { margin: 0 auto var(--space-5); }
  .footer-brand-col .footer-socials { justify-content: center; }
}

/* Hero carousel responsive */
@media (max-width: 1024px) {
  .hero-carousel { height: 70vh; min-height: 440px; }
  .hero-carousel-arrow { width: 44px; height: 44px; }
  .hero-carousel-arrow.prev { left: var(--space-4); }
  .hero-carousel-arrow.next { right: var(--space-4); }
}

/* ========= 900 ========= */
@media (max-width: 900px) {
  .liturgia-live { grid-template-columns: 1fr; gap: var(--space-5); }
  .footer-grid {
    grid-template-columns: 1fr 1fr;
    grid-template-areas:
      "brand brand"
      "contato nav"
      "insti apoiar";
    gap: var(--space-6);
  }
}

/* ========= 768 ========= */
@media (max-width: 768px) {
  :root { --header-h: 78px; }

  h1 { font-size: clamp(2.25rem, 9vw, 3rem); }
  h2 { font-size: clamp(1.85rem, 6.5vw, 2.4rem); }
  body { font-size: 16px; line-height: 1.6; }

  section { padding: var(--space-7) 0; }
  section.pad-lg { padding: var(--space-8) 0; }

  .brand-logo { height: 60px !important; }

  .hero { padding-top: calc(var(--header-h) + var(--space-7)); }
  .hero-title .years { font-size: clamp(4rem, 16vw, 6rem); }
  .hero-stats { grid-template-columns: 1fr; gap: var(--space-4); padding-top: var(--space-5); }
  .hero-stats .stat { display: flex; justify-content: space-between; align-items: baseline; border-bottom: 1px dashed var(--border-subtle); padding-bottom: var(--space-3); }

  .hero-cta-row { flex-direction: column; align-items: stretch; }
  .hero-cta-row .btn { width: 100%; }

  .hero-card { display: none; }
  .hero-visual { aspect-ratio: 3/4; max-width: 100%; }

  .quick-grid { grid-template-columns: 1fr; gap: var(--space-4); }
  .quick-card { min-height: 260px; padding: var(--space-6); }
  .quick-card .icon { width: 56px; height: 56px; }
  .quick-card .icon svg { width: 26px; height: 26px; }
  .quick-card h3 { font-size: 1.5rem; }
  .quick-card p { font-size: 1rem; }

  .news-grid { grid-template-columns: 1fr; }
  .insti-grid { grid-template-columns: 1fr; }
  .transport-list { grid-template-columns: 1fr; }

  .schedule-card { padding: var(--space-6); }
  .schedule-grid { grid-template-columns: 1fr; gap: var(--space-6); }

  .gallery-grid { grid-template-columns: 1fr; }
  .gallery-grid .tile { grid-column: span 1 !important; aspect-ratio: 4/3; }

  .footer-grid {
    grid-template-columns: 1fr;
    grid-template-areas:
      "brand"
      "contato"
      "nav"
      "insti"
      "apoiar";
    gap: var(--space-6);
    text-align: left;
  }
  .footer-col { text-align: center; }
  .footer-col h6 { margin-bottom: var(--space-3); }
  .footer-col .footer-list { justify-items: center; }
  .footer-col .footer-contact-line { justify-content: center; text-align: center; }

  .form-row { grid-template-columns: 1fr; }

  .page-header { padding-top: calc(var(--header-h) + var(--space-7)); }
  .page-header h1 { font-size: clamp(2rem, 8vw, 3rem); }

  .timeline { padding-left: var(--space-4); }
  .timeline::before { left: 4px; }

  .carousel-slide .cs-caption { padding: var(--space-5) var(--space-4) var(--space-4); }
  .carousel-slide .cs-caption .cs-ttl { font-size: 1.2rem; }
  .carousel-btn { width: 40px; height: 40px; }
  .carousel-btn.prev { left: var(--space-3); }
  .carousel-btn.next { right: var(--space-3); }

  .lightbox-thumbs .lb-thumb { width: 64px; }
  .lightbox-nav { width: 42px; height: 42px; }

  /* Video modal mobile */
  .video-modal { padding: var(--space-3); }
  .video-modal .vm-close { top: -46px; }

  /* News/Obras card tidy */
  .insti-card .insti-media,
  .news-media { aspect-ratio: 16/10; }
  .insti-body { padding: var(--space-4); }
  .insti-footer img { max-height: 40px; }
}

/* ========= 640 ========= */
@media (max-width: 640px) {
  .hero-carousel { height: 58vh; min-height: 380px; }
  .hero-carousel-arrow { display: none; }
  .audio-player { right: var(--space-3); bottom: var(--space-3); left: var(--space-3); max-width: none; }
  .carousel-vertical { max-width: 320px; aspect-ratio: 3/4; border-radius: 130px 130px 14px 14px; }
  .medalha-duo { grid-template-columns: 1fr; max-width: 340px; }

  /* Section heads text centered on mobile feels cleaner */
  .section-head .lead { font-size: 1.85rem; }
  .section-head > p.muted { font-size: 1rem; }

  /* Prose drop-cap smaller */
  .prose p:first-of-type::first-letter { font-size: 3.4rem; margin-top: 2px; }

  /* Mobile menu socials */
  .mm-socials {
    display: flex; gap: var(--space-4); align-items: center; justify-content: flex-start;
    padding-top: var(--space-6);
    border-top: 1px solid rgba(243, 238, 227, 0.08);
    margin-top: var(--space-4);
  }
  .mm-socials a {
    display: inline-flex; align-items: center; gap: 10px;
    color: rgba(243, 238, 227, 0.75);
    font-size: 0.95rem;
  }
  .mm-socials a:hover { color: var(--color-ochre); }
}

/* ========= 480 ========= */
@media (max-width: 480px) {
  .container { padding: 0 var(--space-4); }
  .brand-logo { height: 52px !important; }
  .nav-actions { gap: var(--space-3); }
  .btn-donate { padding: 8px 16px; font-size: 0.82rem; }

  .hero-title { font-size: clamp(2.25rem, 10vw, 3rem); }
  .btn { padding: 12px 22px; font-size: 0.95rem; }
  .btn-lg { padding: 14px 24px; font-size: 1rem; }

  blockquote.quote { font-size: 1.15rem; padding-left: var(--space-4); }
  .contact-card { padding: var(--space-5); }

  .quick-card { padding: var(--space-5); min-height: 240px; }
  .quick-card h3 { font-size: 1.35rem; }

  /* Captcha compact */
  .captcha-box { max-width: 100%; padding: var(--space-3) var(--space-4); }

  /* Cronologia linear */
  .ts-item.with-image .ts-card { grid-template-columns: 1fr; }
  .ts-item.with-image .ts-image { display: none; }

  /* CTA band */
  .cta-band { padding: var(--space-5) var(--space-5); }
  .cta-band h2 { font-size: 1.4rem; }
}

/* Default mm-socials desktop hidden */
@media (min-width: 641px) {
  .mm-socials { display: none; }
}

/* ========= prefers-reduced-motion fallback for carousel === */
@media (prefers-reduced-motion: reduce) {
  .hero-carousel-track,
  .carousel-track,
  .carousel-vertical .cv-track { transition: none !important; }
  .hero-carousel-slide img { transform: none !important; transition: none !important; }
}

/* ========= HEADER DESKTOP — caber sem sobrepor o botão Doações =========
   Acima de 1024px o menu completo aparece. Com a logo alta + 6 itens +
   contatos, o nav comprimia (min-width:0) e os links transbordavam por baixo
   do botão "Doações". Aqui o nav passa a ter largura natural (flex-shrink:0),
   centralizado, com tipografia/espaçamentos um pouco menores pra caber até
   ~1280px. O telefone some na faixa apertada (1025–1400) e volta acima disso. */
@media (min-width: 1025px) {
  .site-header .bar { gap: 16px; }
  .nav-primary { flex-shrink: 0; min-width: auto; margin: 0 auto; gap: 14px; }
  .nav-actions { margin-left: 0; }
  .nav-primary a.nav-link { padding: 8px 6px; font-size: 0.85rem; letter-spacing: 0.03em; }
  .brand-logo { height: 76px; }
}
@media (min-width: 1025px) and (max-width: 1400px) {
  .nav-phone-text { display: none; }
}
