/* ===== RESPONSIVE DESIGN PARA MÓVILES ===== */

/* MÓVILES: max-width 768px */
@media (max-width: 768px) {

  * {
    box-sizing: border-box;
  }

  body {
    overflow-x: hidden !important;
    width: 100vw !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  /* === NAVBAR === */
  nav {
    flex-direction: column !important;
    gap: 0.75rem !important;
    padding: 1rem !important;
    width: 100% !important;
    overflow-x: hidden !important;
  }

  nav h1,
  nav a[class*="text-2xl"] {
    font-size: 1.5rem !important;
    text-align: center;
    width: 100%;
  }

  /* Usando el nuevo ID userArea si existe, si no fallback a estructura */
  nav #userArea,
  nav .flex.items-center.gap-6 {
    flex-direction: column !important;
    width: 100% !important;
    gap: 0.5rem !important;
  }

  nav #userArea>a,
  nav #userArea>button,
  nav .flex.items-center.gap-6>a,
  nav .flex.items-center.gap-6>button {
    width: 100% !important;
    text-align: center !important;
    font-size: 0.875rem !important;
    padding: 0.5rem 1rem !important;
    word-wrap: break-word !important;
  }

  /* === MAIN CONTAINER === */
  main {
    width: 100% !important;
    overflow-x: hidden !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  .container {
    width: 100% !important;
    padding: 1rem !important;
    margin: 0 !important;
    overflow-x: hidden !important;
  }

  /* === FILTROS EN FEED === */
  #filterContainer {
    flex-direction: column !important;
    gap: 0.75rem !important;
    width: 100% !important;
  }

  #filterCategory,
  #filterSort {
    width: 100% !important;
    font-size: 14px !important;
    padding: 0.75rem !important;
    box-sizing: border-box !important;
  }

  /* === GRIDS & CONTAINERS === */
  #feedContainer {
    grid-template-columns: 1fr !important;
    padding: 0 !important;
    width: 100% !important;
    gap: 1rem !important;
  }

  /* === MODALES === */
  #modalReseña,
  #modalComentarios {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100% !important;
    height: 100% !important;
    overflow-y: auto !important;
    padding: 0 !important;
  }

  #modalReseña>div,
  #modalComentarios>div {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    max-height: 95vh !important;
    padding: 1.5rem 1rem !important;
    overflow-y: auto !important;
    border-radius: 1.5rem 1.5rem 0 0 !important;
    box-sizing: border-box !important;
  }

  /* Modal header */
  #modalComentarios h2,
  #modalReseña h2,
  #modalComentarios h3,
  #modalReseña h3 {
    font-size: 1.25rem !important;
    margin-bottom: 0.75rem !important;
    word-wrap: break-word !important;
  }

  /* Form inputs */
  #nuevoComentarioForm,
  #formCrearReseña {
    width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 0.75rem !important;
  }

  /* Input de comentarios */
  #inputComentario {
    font-size: 16px !important;
    padding: 0.75rem !important;
    min-height: 80px !important;
    width: 100% !important;
    box-sizing: border-box !important;
    resize: vertical !important;
  }

  /* Botón enviar comentario móvil */
  #btnEnviarComentario,
  #btnGuardarReseña {
    width: 100% !important;
    padding: 0.75rem !important;
    margin-top: 0.5rem !important;
    box-sizing: border-box !important;
  }

  /* === TARJETAS DE RESEÑAS === */
  .review-card {
    margin-bottom: 1.25rem !important;
    padding: 1rem !important;
    width: 100% !important;
    box-sizing: border-box !important;
    word-wrap: break-word !important;
    overflow-wrap: break-word !important;
  }

  .review-card h3 {
    font-size: 1.25rem !important;
    margin-bottom: 0.5rem !important;
    word-wrap: break-word !important;
  }

  .review-card img {
    max-height: 200px !important;
    width: 100% !important;
    object-fit: cover !important;
    border-radius: 0.5rem !important;
  }

  /* Botones de acción en tarjetas (responsive grid) */
  .review-card .flex.items-center.gap-4 {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 0.75rem !important;
    width: 100% !important;
  }

  .review-card .btn-like,
  .review-card .btn-comment {
    width: 100% !important;
    justify-content: center !important;
    padding: 0.5rem !important;
    font-size: 0.875rem !important;
    word-wrap: break-word !important;
  }

  /* === COMENTARIOS ITEM === */
  .comment-item {
    flex-direction: column !important;
    gap: 0.5rem !important;
    width: 100% !important;
    word-wrap: break-word !important;
    overflow-wrap: break-word !important;
  }

  .comment-item>div:first-child {
    display: none;
  }

  /* === GENERAL === */
  h1 {
    font-size: 1.75rem !important;
    word-wrap: break-word !important;
  }

  h2 {
    font-size: 1.5rem !important;
    word-wrap: break-word !important;
  }

  p,
  span,
  a,
  button {
    word-wrap: break-word !important;
    overflow-wrap: break-word !important;
  }

}

/* MÓVILES PEQUEÑOS: max-width 480px */
@media (max-width: 480px) {

  body {
    width: 100vw !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow-x: hidden !important;
  }

  .review-card {
    padding: 0.75rem !important;
    margin-bottom: 1rem !important;
  }

  .review-card .btn-like,
  .review-card .btn-comment {
    padding: 0.5rem !important;
    font-size: 0.75rem !important;
    width: 100% !important;
  }

  #modalReseña>div,
  #modalComentarios>div {
    padding: 1rem !important;
    margin-top: 2rem !important;
  }

  nav {
    padding: 0.75rem !important;
  }

  .container {
    padding: 0.75rem !important;
  }

  /* === INDEX.HTML FIXES === */
  header {
    padding: 1rem 0.75rem !important;
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
  }

  header h2 {
    font-size: 2rem !important;
    line-height: 1.2 !important;
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
  }

  header h3 {
    font-size: 1.5rem !important;
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
  }

  header p {
    font-size: 0.875rem !important;
    padding: 0 0.5rem !important;
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
  }

  section {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
  }

  /* Grid de tarjetas - max-width ancho */
  .grid.gap-8.sm\\:grid-cols-2,
  .grid.gap-8.sm\\:grid-cols-3,
  .grid.gap-6.sm\\:grid-cols-2.lg\\:grid-cols-3 {
    grid-template-columns: 1fr !important;
    gap: 1rem !important;
    padding: 0.75rem !important;
    display: grid !important;
    visibility: visible !important;
    opacity: 1 !important;
  }

  /* Tarjetas de comunidad */
  .p-6.bg-white\/10.rounded-xl.w-64 {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0.5rem auto !important;
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
  }

  /* Sección de efemérides */
  .max-w-7xl {
    width: 100% !important;
    padding: 0.75rem !important;
    margin: 0 !important;
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
  }

  #efemerideContent {
    padding: 1rem !important;
    min-height: 250px !important;
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
  }

  /* Max-width genérico */
  .max-w-6xl {
    width: 100% !important;
    padding: 0 0.75rem !important;
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
  }

  .max-w-3xl {
    width: 100% !important;
    padding: 0 0.75rem !important;
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
  }

  /* Flex wrap para garantizar que los elementos se ajusten */
  .flex.justify-center.gap-6.flex-wrap {
    flex-direction: column !important;
    align-items: center !important;
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
  }

  .flex.flex-wrap {
    flex-direction: column !important;
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
  }

  /* Fade-up, fade-in, scale-in animations */
  .fade-up,
  .fade-in,
  .scale-in {
    animation: none !important;
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
  }

}