/* ─── Mobile ─── */

@media (max-width: 768px) {
  .tasks-body {
    flex-direction: column;
  }
  .tasks-column {
    flex: none;
  }
  .carousel-wrap {
    border-left: none;
    padding-left: 0;
    padding-top: 0.75rem;
    border-top: 1px solid var(--border);
  }
  .news-body {
    flex-direction: column;
  }
  .news-img-wrap {
    width: 100%;
    height: 160px;
  }
}
@media (max-width: 640px) {
  .container { padding: 0.75rem; }

  header { flex-direction: column; gap: 0.75rem; }

  .brand { gap: 0.6rem; }
  .logo { height: 32px; }
  .greeting h1 { font-size: 1.2rem; }
  .subtitle { font-size: 0.8rem; }

  .stats-card { flex-direction: column; gap: 0.5rem; padding: 0.9rem 1rem; }
  .stat { min-width: auto; }
  .stat-value { font-size: 1.2rem; }
  .stat-breakdown { gap: 0.4rem; }

  .search-input { font-size: 16px; padding: 0.65rem 1rem 0.65rem 2.5rem; }
  .search-icon { left: 10px; }
  .search-icon svg { width: 14px; height: 14px; }

  .toolbar { flex-direction: column; align-items: stretch; padding: 0.6rem 0.75rem; gap: 0.5rem; }
  .toolbar-group { flex-wrap: wrap; }
  .toolbar-divider { display: none; }
  .toolbar-label { font-size: 0.7rem; min-width: 50px; }
  .toolbar-select { flex: 1; font-size: 16px; padding: 0.5rem 2rem 0.5rem 0.6rem; min-height: 40px; }
  .sort-btn { min-height: 40px; padding: 0.5rem 0.75rem; }

  .actions { flex-direction: column; gap: 0.5rem; margin-bottom: 1rem; }
  .btn { width: 100%; justify-content: center; padding: 0.75rem 1rem; min-height: 44px; font-size: 0.95rem; }

  .preview-header { padding: 0.7rem 1rem; }
  .preview-header h2 { font-size: 0.9rem; }

  thead th { padding: 0.5rem 0.6rem; font-size: 0.65rem; }
  tbody td { padding: 0.5rem 0.6rem; font-size: 0.8rem; }

  .th-check { width: 36px !important; padding: 0.5rem 0.3rem !important; }
  .cell-check { width: 36px !important; padding: 0.5rem 0.3rem !important; }
  .cell-check input[type="checkbox"] { width: 18px; height: 18px; }
  #select-all { width: 18px; height: 18px; }

  .status-select { font-size: 0.7rem; padding: 0.2rem 1.4rem 0.2rem 0.4rem; min-height: 28px; }
  .source-select { font-size: 0.7rem; padding: 0.2rem 1.4rem 0.2rem 0.4rem; min-height: 28px; }

  .pagination { flex-direction: column; align-items: stretch; text-align: center; padding: 0.6rem 1rem; gap: 0.5rem; }
  .pagination-info { font-size: 0.75rem; }
  .pagination-controls { justify-content: center; flex-wrap: wrap; gap: 0.3rem; }
  .pagination-btn { min-width: 40px; height: 40px; font-size: 0.85rem; padding: 0 0.6rem; }
  .pagination-ellipsis { height: 40px; }

  .hide-mobile { display: none; }
  .modal-card { padding: 1.25rem; margin: 0.5rem; }
  .modal-card input, .modal-card select { font-size: 16px; padding: 0.7rem 0.85rem; }

  .header-avatar { width: 30px; height: 30px; font-size: 0.8rem; }
  .tasks-card { padding: 1rem; }
  .tasks-title { font-size: 0.85rem; }
  .task-row { padding: 0.4rem 0; gap: 0.5rem; }
  .task-row .task-icon { font-size: 1.35rem; width: 30px; }
  .task-row .task-label { font-size: 1.1rem; }
  .task-row .task-check { width: 22px; height: 22px; }
  .add-task-btn { font-size: 1rem; padding: 0.35rem; margin-top: 0.25rem; }

  footer { padding: 1.5rem 0 0; font-size: 0.7rem; }
}

@media (min-width: 641px) {
  .hide-desktop {
    display: none;
  }
}
/* ─── Property Responsive ─── */
@media (max-width: 900px) {
  .property-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .property-grid { grid-template-columns: 1fr; }
  .property-card-img { height: 200px; }
  .detail-hero img { max-height: 280px; }
}
@media (max-width: 640px) {
  .tasks-widget { top: 70px; }
  .tw-panel {
    width: calc(100vw - 12px);
    max-height: calc(100vh - 80px);
  }
  .tw-bar { width: 24px; min-height: 90px; padding: 6px 0; }
  .tw-toggle { width: 24px; height: 18px; }
  .tw-badge { font-size: 0.65rem; min-width: 16px; line-height: 16px; }
  .tw-row { padding: 0.45rem 0.75rem; min-height: 42px; }
  .tw-inp { font-size: 0.9rem; }
}
