/**
 * ILERCO App SPA — mejoras responsive (PC, tablet, móvil)
 * Carga después de admin.css, layout.css, etc.
 */

html,
body {
  overflow-x: hidden;
}

#app-container {
  max-width: 100%;
  overflow-x: hidden;
}

#app-container > .container,
#app-container main.container {
  max-width: 100%;
  padding-left: clamp(8px, 2vw, 15px);
  padding-right: clamp(8px, 2vw, 15px);
}

@media (max-width: 991px) {
  .admin-layout,
  .student-layout,
  .prof-layout {
    min-height: auto;
  }

  .admin-main,
  .student-main,
  .prof-main {
    width: 100%;
    min-width: 0;
  }

  .admin-header,
  .student-header,
  .prof-header {
    flex-wrap: wrap;
    gap: 10px;
  }

  .property-publish-wrap > .d-flex,
  .blog-publish-wrap > .d-flex,
  .property-publish-wrap .d-flex.justify-content-between,
  .blog-publish-wrap .d-flex.justify-content-between {
    flex-direction: column;
    align-items: flex-start !important;
    gap: 12px;
  }

  .admin-content .row > [class*="col-lg-"],
  .admin-content .row > [class*="col-md-"],
  .student-content .row > [class*="col-lg-"],
  .student-content .row > [class*="col-md-"] {
    flex: 0 0 100%;
    max-width: 100%;
  }

  .admin-sidebar,
  .student-sidebar,
  .prof-sidebar {
    scrollbar-width: thin;
  }

  .admin-sidebar::after,
  .student-sidebar::after {
    content: '';
    position: sticky;
    right: 0;
    top: 0;
    width: 24px;
    height: 100%;
    pointer-events: none;
    background: linear-gradient(to left, rgba(26, 26, 26, 0.12), transparent);
    flex-shrink: 0;
  }
}

@media (max-width: 767px) {
  #app-container main.container {
    margin-top: 12px !important;
    margin-bottom: 12px !important;
  }

  .admin-content,
  .student-content,
  .prof-content {
    padding: 12px !important;
  }

  .admin-content .card-body,
  .student-content .card-body {
    padding: 16px;
  }

  .admin-header h4,
  .student-header h4 {
    font-size: 1.15rem;
  }

  .property-section-card .card-header h6,
  .blog-publish-wrap .property-section-card .card-header h6 {
    font-size: 0.95rem;
  }

  .property-publish-wrap .form-check-inline,
  .blog-publish-wrap .form-check-inline {
    display: flex;
    width: 100%;
    margin-right: 0;
    margin-bottom: 8px;
  }

  .property-card--panel .property-card-qr > div[style*="grid-template-columns"] {
    grid-template-columns: 1fr !important;
  }

  .property-card--panel .property-card-qr__btn,
  .property-card--panel .property-card-qr a[style*="inline-flex"] {
    white-space: normal !important;
    min-height: 38px;
  }

  .students-table-wrapper {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
    border-radius: 8px;
    border: 1px solid rgba(26, 26, 26, 0.08);
  }

  .students-table {
    min-width: 680px;
  }

  #notificationsList {
    max-width: calc(100vw - 24px) !important;
    min-width: 0 !important;
    width: calc(100vw - 24px) !important;
  }

  .notification-item .dropdown-item {
    padding: 1rem;
  }

  .blog-admin-grid {
    grid-template-columns: 1fr;
  }

  .blog-admin-card {
    flex-direction: column;
  }

  .blog-admin-card__image,
  .blog-admin-card__image img {
    width: 100%;
    min-height: 160px;
  }

  .blog-admin-card__body {
    padding: 16px;
  }

  .admin-stat-card .card-title {
    font-size: 1.45rem;
  }

  .admin-stat-icon {
    font-size: 1.75rem;
  }

  .modal-dialog {
    margin: 10px auto;
    max-width: calc(100% - 20px);
  }

  .credentials-modal__dialog {
    max-width: calc(100vw - 16px);
    margin: 8px auto;
  }

  .table-responsive {
    border-radius: 8px;
  }

  .d-flex.flex-wrap.gap-2.justify-content-center,
  .d-flex.justify-content-end.mb-4.gap-2 {
    flex-direction: column;
    align-items: stretch !important;
    width: 100%;
  }

  .d-flex.flex-wrap.gap-2.justify-content-center .btn,
  .d-flex.justify-content-end.mb-4.gap-2 .btn {
    width: 100%;
  }

  .property-publish-wrap .d-flex.flex-wrap.gap-2 .btn,
  .blog-publish-wrap .d-flex.flex-wrap.gap-2 .btn {
    width: auto;
    flex: 1 1 auto;
  }

  .property-publish-wrap .d-flex.flex-wrap.gap-2,
  .blog-publish-wrap .d-flex.flex-wrap.gap-2 {
    flex-direction: row;
    flex-wrap: wrap;
  }
}

@media (max-width: 576px) {
  .admin-sidebar .sidebar-menu .nav-link,
  .student-sidebar .sidebar-menu .nav-link,
  .prof-sidebar .sidebar-menu .nav-link {
    font-size: 12px;
    padding: 8px 12px;
  }

  .property-grid--panel {
    grid-template-columns: 1fr !important;
  }

  .property-card--panel .img-wrap img {
    height: 150px;
  }

  .admin-content .btn-group {
    flex-direction: column;
    width: 100%;
  }

  .admin-content .btn-group .btn {
    width: 100%;
    border-radius: 6px !important;
    margin-bottom: 6px;
  }

  .form-control,
  .form-select,
  textarea.form-control {
    font-size: 16px;
  }
}

@media (max-width: 991px) and (orientation: landscape) {
  .admin-sidebar .sidebar-logo,
  .student-sidebar .sidebar-logo {
    display: none;
  }

  .hero-content-wrap {
    padding-top: 100px;
  }
}
