/* ============================================
   Clear Haven — Responsive Breakpoints
   ============================================ */

/* Tablet: 768px - 1024px */
@media (max-width: 1024px) {
  .grid-3 {
    grid-template-columns: repeat(2, 1fr);
  }

  .form-row-3 {
    grid-template-columns: 1fr 1fr;
  }

  .stats-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .page-body {
    padding: var(--space-6);
  }

  .page-header {
    padding: var(--space-4) var(--space-6);
  }
}

/* Mobile: below 768px */
@media (max-width: 768px) {
  :root {
    --sidebar-width: 280px;
  }

  .sidebar {
    transform: translateX(-100%);
  }

  .sidebar.open {
    transform: translateX(0);
  }

  .sidebar-overlay.active {
    display: block;
  }

  .sidebar-toggle {
    display: flex;
  }

  .main-content {
    margin-left: 0;
  }

  .page-header {
    padding: var(--space-3) var(--space-4);
  }

  .page-header-left h1 {
    font-size: var(--text-xl);
  }

  .page-body {
    padding: var(--space-4);
  }

  .tabs {
    padding: 0 var(--space-4);
    overflow-x: auto;
  }

  .grid-2,
  .grid-3,
  .grid-auto {
    grid-template-columns: 1fr;
  }

  .form-row,
  .form-row-3 {
    grid-template-columns: 1fr;
  }

  .stats-grid {
    grid-template-columns: 1fr 1fr;
  }

  .modal {
    margin: var(--space-4);
    max-height: calc(100vh - 2rem);
  }

  .modal-lg,
  .modal-xl {
    max-width: 100%;
  }

  .data-table {
    display: block;
    overflow-x: auto;
  }

  .transaction-card-meta {
    flex-wrap: wrap;
  }

  .checklist-item {
    flex-wrap: wrap;
  }

  .checklist-item-meta {
    width: 100%;
    margin-top: var(--space-2);
    justify-content: flex-end;
  }

  .page-header-right {
    flex-wrap: wrap;
  }

  .toast-container {
    left: var(--space-4);
    right: var(--space-4);
  }

  .toast {
    min-width: auto;
  }
}

/* Status flow responsive */
@media (max-width: 768px) {
  .status-flow {
    flex-wrap: wrap;
    gap: var(--space-2);
  }

  .status-flow-node {
    min-width: calc(50% - var(--space-2));
    max-width: none;
  }

  .status-flow-arrow {
    display: none;
  }
}

/* Small mobile: below 480px */
@media (max-width: 480px) {
  .stats-grid {
    grid-template-columns: 1fr;
  }

  .page-header {
    flex-direction: column;
    align-items: flex-start;
  }

  .page-header-right {
    width: 100%;
  }

  .btn-lg {
    width: 100%;
  }
}
