/* ============================================
   AL-HIRA PUBLIC SCHOOL — Responsive Design
   Desktop > Tablet > Mobile
   ============================================ */

/* === Large Desktop (1440px+) === */
@media (min-width: 1440px) {
  .main-content {
    padding: var(--space-10);
  }

  .grid-cols-6 {
    grid-template-columns: repeat(6, 1fr);
  }
}

/* === Desktop (1024px - 1439px) === */
@media (max-width: 1439px) {
  .grid-cols-6 {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* === Tablet (768px - 1023px) === */
@media (max-width: 1023px) {
  .sidebar {
    transform: translateX(-100%);
    z-index: var(--z-sidebar);
  }

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

  .app-layout {
    grid-template-columns: 1fr;
    grid-template-areas:
      "topbar"
      "content";
  }

  .topbar {
    margin-left: 0;
    padding: 0 var(--space-5);
  }

  .topbar-menu-btn {
    display: flex;
  }

  .topbar-search-btn {
    min-width: auto;
    padding: var(--space-2);
    width: 38px;
    height: 38px;
    border-radius: var(--radius-lg);
    justify-content: center;
  }

  .topbar-search-btn span,
  .topbar-search-shortcut {
    display: none;
  }

  .main-content {
    margin-left: 0;
    padding: var(--space-5);
  }

  .grid-cols-4 {
    grid-template-columns: repeat(2, 1fr);
  }

  .grid-cols-3 {
    grid-template-columns: repeat(2, 1fr);
  }

  .grid-cols-6 {
    grid-template-columns: repeat(3, 1fr);
  }

  .page-header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-4);
  }

  .page-header-right {
    width: 100%;
    flex-wrap: wrap;
  }

  .data-table-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .data-table-toolbar-left {
    flex-wrap: wrap;
  }

  .data-table-search {
    min-width: 100%;
  }
}

/* === Mobile (< 768px) === */
@media (max-width: 767px) {
  :root {
    --topbar-height: 56px;
  }

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

  .topbar-title h1 {
    font-size: var(--text-lg);
  }

  .topbar-breadcrumb {
    display: none;
  }

  .main-content {
    padding: var(--space-4);
    padding-bottom: calc(var(--mobile-nav-height) + var(--space-6));
  }

  /* Show mobile nav */
  .mobile-nav {
    display: block;
  }

  /* Grid adjustments */
  .grid {
    gap: var(--space-4);
  }

  .grid-cols-2,
  .grid-cols-3,
  .grid-cols-4 {
    grid-template-columns: 1fr;
  }

  .grid-cols-6 {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Stats cards */
  .stats-card {
    padding: var(--space-4);
  }

  .stats-card-value {
    font-size: var(--text-xl);
  }

  /* Page header */
  .page-header {
    margin-bottom: var(--space-5);
  }

  .page-header-left h2 {
    font-size: var(--text-xl);
  }

  .page-header-right {
    width: 100%;
  }

  .page-header-right .btn {
    flex: 1;
  }

  /* Cards */
  .card-body {
    padding: var(--space-4);
  }

  .card-header {
    padding: var(--space-3) var(--space-4);
  }

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

  /* Modal */
  .modal-overlay {
    padding: var(--space-3);
    align-items: flex-end;
  }

  .modal {
    border-radius: var(--radius-2xl) var(--radius-2xl) 0 0;
    max-height: 92vh;
  }

  .modal-sm,
  .modal-md,
  .modal-lg,
  .modal-xl {
    max-width: 100%;
  }

  .modal-header {
    padding: var(--space-4) var(--space-5);
  }

  .modal-body {
    padding: var(--space-4) var(--space-5);
  }

  .modal-footer {
    padding: var(--space-3) var(--space-5);
    flex-direction: column;
  }

  .modal-footer .btn {
    width: 100%;
  }

  /* Toast */
  .toast-container {
    left: var(--space-4);
    right: var(--space-4);
    max-width: none;
    top: var(--space-4);
  }

  /* Data Table */
  .data-table-container {
    border-radius: var(--radius-lg);
  }

  .data-table-toolbar {
    padding: var(--space-3) var(--space-4);
  }

  .data-table-toolbar-right {
    width: 100%;
    justify-content: flex-end;
  }

  .data-table th,
  .data-table td {
    padding: var(--space-2) var(--space-3);
    font-size: var(--text-xs);
  }

  .data-table-footer {
    padding: var(--space-3) var(--space-4);
    flex-direction: column;
    gap: var(--space-3);
    text-align: center;
  }

  /* Search overlay */
  .search-modal {
    max-width: 100%;
    margin: 0 var(--space-3);
  }

  /* Quick actions */
  .quick-action {
    padding: var(--space-4);
  }

  .quick-action-icon {
    width: 40px;
    height: 40px;
  }

  /* Tabs */
  .tabs {
    gap: 0;
  }

  .tab {
    padding: var(--space-3) var(--space-3);
    font-size: var(--text-xs);
  }

  /* Login */
  .login-card {
    padding: var(--space-8) var(--space-6);
  }

  .login-logo img {
    width: 56px;
    height: 56px;
  }

  .login-logo h2 {
    font-size: var(--text-lg);
  }

  /* Timeline */
  .timeline {
    padding-left: var(--space-5);
  }
}

/* === Very Small Screens (<= 375px) === */
@media (max-width: 375px) {
  .main-content {
    padding: var(--space-3);
    padding-bottom: calc(var(--mobile-nav-height) + var(--space-4));
  }

  .grid-cols-6 {
    grid-template-columns: repeat(2, 1fr);
  }

  .stats-card {
    flex-direction: column;
    text-align: center;
    align-items: center;
  }

  .page-header-left h2 {
    font-size: var(--text-lg);
  }

  .login-card {
    padding: var(--space-6) var(--space-4);
  }
}

/* === Print Styles === */
@media print {
  .sidebar,
  .topbar,
  .mobile-nav,
  .toast-container,
  .modal-overlay,
  .search-overlay,
  .page-loader,
  .btn,
  .data-table-toolbar,
  .data-table-footer {
    display: none !important;
  }

  .main-content {
    margin-left: 0 !important;
    padding: 0 !important;
  }

  body {
    background: #fff;
    color: #000;
  }

  .card {
    box-shadow: none;
    border: 1px solid #ddd;
  }

  .data-table th,
  .data-table td {
    border: 1px solid #ddd;
  }
}
