/* ======================================
   ASPROCOMUR - Responsive Styles
   BEM naming convention
   ====================================== */

/* Large tablet / Small desktop */
@media (max-width: 1024px) {
  :root {
    --font-size-7xl: 3.5rem;
    --font-size-6xl: 3rem;
    --font-size-5xl: 2.5rem;
  }

  /* Hero */
  .hero-container {
    grid-template-columns: 1fr;
    text-align: center;
    gap: var(--space-8);
  }

  .hero-subtitle {
    margin-left: auto;
    margin-right: auto;
  }

  .hero-actions {
    justify-content: center;
  }

  .hero-visual {
    max-width: 500px;
    margin: 0 auto;
  }

  .hero-float-card--1 {
    left: var(--space-2);
  }

  .hero-float-card--2 {
    right: var(--space-2);
  }

  /* Grids */
  .about-grid { grid-template-columns: 1fr; gap: var(--space-10); }
  .network-grid { grid-template-columns: repeat(2, 1fr); }
  .products-grid { grid-template-columns: repeat(2, 1fr); }
  .mission-layout { grid-template-columns: 1fr; gap: var(--space-10); padding: 0 var(--space-4); }
  .mission-visual { max-width: 280px; margin: 0 auto; }
  .mission-content { text-align: center; }
  .mission-pillars { align-items: center; }
  .trajectory-layout { grid-template-columns: 1fr; gap: var(--space-8); }
  .services-grid { grid-template-columns: repeat(2, 1fr); }
  .featured-grid { grid-template-columns: repeat(2, 1fr); }
  .experience-grid { grid-template-columns: repeat(2, 1fr); }
  .jubileo-grid { grid-template-columns: 1fr; gap: var(--space-8); }
  .comarca-grid { grid-template-columns: repeat(2, 1fr); }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .blog-grid { grid-template-columns: repeat(2, 1fr); }
  .blog-grid--3col { grid-template-columns: repeat(2, 1fr); }
  .activities-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-top { grid-template-columns: repeat(2, 1fr); gap: var(--space-8); }
  .contact-grid { grid-template-columns: 1fr; }
  .activity-layout { grid-template-columns: 1fr; }
  .municipality-grid { grid-template-columns: 1fr; }

  /* Header */
  .header-actions {
    display: none;
  }

  .mobile-toggle {
    display: block;
  }

  .main-nav {
    display: none;
  }
}

/* Tablet */
@media (max-width: 768px) {
  :root {
    --font-size-7xl: 2.5rem;
    --font-size-6xl: 2.25rem;
    --font-size-5xl: 2rem;
    --font-size-4xl: 1.75rem;
    --header-height: 70px;
  }

  .container { padding: 0 var(--space-4); }

  /* Hero */
  .section-hero { min-height: 90vh; }
  .hero-title { font-size: var(--font-size-5xl); }
  .hero-subtitle { font-size: var(--font-size-base); }
  .hero-actions { flex-direction: column; align-items: center; }
  .hero-actions .btn { width: 100%; max-width: 300px; }
  .hero-float-card { display: none; }

  /* Section headers */
  .section-title { font-size: var(--font-size-3xl); }
  .section-header { margin-bottom: var(--space-10); }

  /* Grids */
  .network-grid { grid-template-columns: repeat(2, 1fr); }
  .products-grid { grid-template-columns: repeat(2, 1fr); }
  .services-grid { grid-template-columns: 1fr; }
  .featured-grid { grid-template-columns: 1fr; }
  .experience-grid { grid-template-columns: repeat(2, 1fr); }
  .comarca-grid { grid-template-columns: repeat(2, 1fr); }
  .stats-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-4); }
  .blog-grid, .blog-grid--3col { grid-template-columns: 1fr; }
  .activities-grid { grid-template-columns: 1fr; }

  /* Solidarity */
  .solidarity-layout { flex-direction: column; text-align: center; align-items: center; }

  /* Jubileo */
  .jubileo-stats { gap: var(--space-4); }

  /* Footer */
  .footer-top { grid-template-columns: 1fr; gap: var(--space-8); }
  .footer-bottom { flex-direction: column; gap: var(--space-4); text-align: center; }
  .footer-bottom__right { justify-content: center; }

  /* Activity detail */
  .activity-hero__title { font-size: var(--font-size-3xl); }
  .activity-hero__info-grid { gap: var(--space-4); }
  .activity-info-bar { flex-direction: column; gap: var(--space-3); }

  /* Page header */
  .page-header__title { font-size: var(--font-size-3xl); }

  /* Post hero */
  .post-hero__title { font-size: var(--font-size-3xl); }
  .post-hero__meta { flex-direction: column; gap: var(--space-3); }

  /* Contact */
  .contact-grid { grid-template-columns: 1fr; }

  /* Forms */
  .form-row { flex-direction: column; }
  .form-row--2col { grid-template-columns: 1fr; }

  /* CTA */
  .cta-title { font-size: var(--font-size-3xl); }
  .cta-actions { flex-direction: column; align-items: center; }

  /* Stat items */
  .stat-item { padding: var(--space-4); }
  .stat-item__number { font-size: var(--font-size-4xl); }

  /* Cards */
  .card-service { padding: var(--space-6); }

  /* Blog post */
  .post-author-bio { flex-direction: column; text-align: center; }
  .post-share { flex-direction: column; align-items: flex-start; }

  /* Error page */
  .error-suggestions__list { flex-direction: column; align-items: center; }

  /* Municipality */
  .municipality-grid { grid-template-columns: 1fr; }

  /* Info banner */
  .info-banner { flex-direction: column; text-align: center; }

  /* Calendar */
  .calendar-legend { flex-wrap: wrap; justify-content: center; }
}

/* Small mobile */
@media (max-width: 480px) {
  :root {
    --font-size-7xl: 2rem;
    --font-size-5xl: 1.75rem;
  }

  .comarca-grid { grid-template-columns: 1fr; }
  .stats-grid { grid-template-columns: 1fr; }
  .network-grid { grid-template-columns: 1fr; }
  .products-grid { grid-template-columns: 1fr; }
  .experience-grid { grid-template-columns: 1fr; }
  .filter-pills { justify-content: center; }
  .jubileo-stats { flex-direction: column; align-items: center; }
  .hero-badge { font-size: var(--font-size-xs); }
}

/* Admin responsive - keep existing */
@media (max-width: 768px) {
  .admin-sidebar {
    transform: translateX(-100%);
    position: fixed;
    z-index: 1000;
    top: 0;
    left: 0;
    height: 100vh;
  }

  .admin-sidebar--open {
    transform: translateX(0);
  }

  .admin-main {
    margin-left: 0;
  }

  .admin-topbar__toggle {
    display: flex;
  }
}

/* Print */
@media print {
  .site-header, .site-footer, .scroll-top, .mobile-toggle,
  .hero-actions, .registration-card, .section-related, .section-cta,
  .flash-messages {
    display: none !important;
  }

  body { font-size: 12pt; }
  .card-activity, .card-post, .card-service, .card-comarca {
    box-shadow: none;
    border: 1px solid #ddd;
    break-inside: avoid;
  }
}
