/* List perangkat desa — diseragamkan (meniru data_penduduk/list.html) */

.perangkat-dashboard .action-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-bottom: 1rem;
}

.perangkat-dashboard .search-filter form {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.perangkat-dashboard .dp-header-wrap,
.perangkat-dashboard .dp-filter-card,
.perangkat-dashboard .dp-table-wrap,
.perangkat-dashboard .dp-card {
  box-sizing: border-box;
}

/* Header list */
.perangkat-dashboard .dp-header-wrap {
  background: linear-gradient(135deg, #0f766e 0%, #0d5c42 50%, #064e3b 100%);
  border-radius: 16px;
  padding: 1.5rem 1.75rem;
  margin-bottom: 1.5rem;
  box-shadow: 0 10px 40px rgba(13, 92, 66, 0.25);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
}
.perangkat-dashboard .dp-header-left { flex: 1; min-width: 0; }
.perangkat-dashboard .dp-header-title {
  font-size: 1.1rem;
  font-weight: 700;
  color: rgba(255,255,255,0.95);
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.75rem;
}
.perangkat-dashboard .dp-header-title i { opacity: 0.9; }

/* Tombol header list */
.perangkat-dashboard .dp-header-wrap .btn-tambah,
.perangkat-dashboard .dp-header-actions .btn-tambah {
  background: rgba(255,255,255,0.95);
  color: #0d5c42;
  font-weight: 600;
  padding: 0.5rem 1rem;
  border-radius: 10px;
  font-size: 0.9rem;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  box-shadow: 0 2px 8px rgba(0,0,0,0.12);
}
.perangkat-dashboard .dp-header-wrap .btn-tambah:hover,
.perangkat-dashboard .dp-header-actions .btn-tambah:hover {
  background: #fff;
  color: #064e3b;
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(0,0,0,0.18);
}

/* Filter card */
.perangkat-dashboard .dp-filter-card {
  background: #f9fafb;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: 1.25rem;
  margin-bottom: 1.25rem;
}
.perangkat-dashboard .dp-filter-card .title {
  font-size: 0.9rem;
  font-weight: 700;
  color: #374151;
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.perangkat-dashboard .dp-filter-row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 0.75rem;
}
/* Override rule .card form { flex-direction: column } dari perangkat_dashboard.css */
.perangkat-dashboard .card form.dp-filter-row {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 0.75rem;
}
.perangkat-dashboard .dp-filter-row .field {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  min-width: 160px;
}
.perangkat-dashboard .dp-filter-row .field label {
  font-size: 0.8rem;
  font-weight: 600;
  color: #4b5563;
}
.perangkat-dashboard .dp-filter-row input[type="text"],
.perangkat-dashboard .dp-filter-row input[type="number"],
.perangkat-dashboard .dp-filter-row input[type="date"],
.perangkat-dashboard .dp-filter-row select {
  padding: 0.5rem 0.75rem;
  border: 1px solid #d1d5db;
  border-radius: 8px;
  font-size: 0.9rem;
  background: #fff;
  min-width: 160px;
}
.perangkat-dashboard .dp-filter-row .field.field-wide { min-width: 240px; }
.perangkat-dashboard .dp-filter-row .field.field-narrow { min-width: 120px; }
.perangkat-dashboard .dp-filter-row .field.field-narrow input { width: 120px; }

.perangkat-dashboard .dp-filter-row .btn {
  padding: 0.5rem 1rem;
  border-radius: 8px;
  font-size: 0.9rem;
}

/* Table card */
.perangkat-dashboard .dp-table-wrap { overflow-x: auto; }
.perangkat-dashboard .dp-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}
.perangkat-dashboard .dp-table th {
  text-align: left;
  padding: 0.75rem 1rem;
  font-weight: 600;
  color: #374151;
  background: #f3f4f6;
  border-bottom: 2px solid #e5e7eb;
}
.perangkat-dashboard .dp-table td {
  padding: 0.75rem 1rem;
  border-bottom: 1px solid #e5e7eb;
  vertical-align: middle;
}
.perangkat-dashboard .dp-table tbody tr:nth-child(even) { background: #fafafa; }
.perangkat-dashboard .dp-table tbody tr:hover { background: #f3f4f6; }
.perangkat-dashboard .dp-table .aksi-cell { white-space: nowrap; }
.perangkat-dashboard .dp-empty {
  text-align: center;
  padding: 3rem 1rem !important;
  color: #6b7280;
}
.perangkat-dashboard .dp-empty i { font-size: 2.5rem; display: block; margin-bottom: 0.5rem; opacity: 0.5; }
.perangkat-dashboard .dp-empty p { margin: 0; font-size: 0.9rem; }

/* Tombol aksi kecil */
.perangkat-dashboard .dp-table .aksi-cell .btn { padding: 0.35rem 0.6rem; font-size: 0.8rem; margin: 0 2px; }

/* Pagination — universal */
.perangkat-dashboard .pagination {
  padding: 1rem 1.25rem;
  border-top: 1px solid #e5e7eb;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.9rem;
}
.perangkat-dashboard .pagination a {
  padding: 0.35rem 0.75rem;
  border-radius: 6px;
  background: #f3f4f6;
  color: #374151;
  text-decoration: none;
}
.perangkat-dashboard .pagination a:hover { background: #e5e7eb; }
.perangkat-dashboard .pagination .current {
  padding: 0 0.5rem;
  color: #6b7280;
  font-weight: 500;
}

/* Empty state jika template pakai class empty-state */
.perangkat-dashboard .card .empty-state {
  text-align: center;
  padding: 3rem 1rem !important;
  color: #6b7280;
}
.perangkat-dashboard .card .empty-state i { font-size: 2.5rem; display: block; margin-bottom: 0.5rem; opacity: 0.5; }
.perangkat-dashboard .card .empty-state p { margin: 0; font-size: 0.9rem; }

/* ===== Styling universal untuk table list =====
   Supaya halaman list yang belum kita ubah HTML-nya tetap tampil seragam.
*/
.perangkat-dashboard .card .table-container table,
.perangkat-dashboard .card table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}

.perangkat-dashboard .card .table-container thead th,
.perangkat-dashboard .card table thead th {
  text-align: left;
  padding: 0.75rem 1rem;
  font-weight: 600;
  color: #374151;
  background: #f3f4f6;
  border-bottom: 2px solid #e5e7eb;
}

.perangkat-dashboard .card .table-container td,
.perangkat-dashboard .card .table-container th,
.perangkat-dashboard .card table td,
.perangkat-dashboard .card table th {
  padding: 0.75rem 1rem;
  vertical-align: middle;
}

.perangkat-dashboard .card table tbody td {
  border-bottom: 1px solid #e5e7eb;
}

.perangkat-dashboard .card table tbody tr:nth-child(even) { background: #fafafa; }
.perangkat-dashboard .card table tbody tr:hover { background: #f3f4f6; }

.perangkat-dashboard .card table td:last-child { white-space: nowrap; }

/* ============================================
   DARK MODE OVERRIDES
   ============================================ */
body.theme-dark .dp-filter-card {
  background: var(--pd-bg-subtle) !important;
  border-color: var(--pd-border) !important;
}

body.theme-dark .dp-filter-card .title,
body.theme-dark .dp-filter-row .field label {
  color: var(--pd-text) !important;
}

body.theme-dark .dp-filter-row input[type="text"],
body.theme-dark .dp-filter-row input[type="number"],
body.theme-dark .dp-filter-row input[type="date"],
body.theme-dark .dp-filter-row select {
  background: var(--pd-surface) !important;
  border-color: var(--pd-border) !important;
  color: var(--pd-text) !important;
}

body.theme-dark .dp-table th,
body.theme-dark .card .table-container thead th,
body.theme-dark .card table thead th {
  background: var(--pd-bg-subtle) !important;
  color: var(--pd-text) !important;
  border-bottom-color: var(--pd-border-strong) !important;
}

body.theme-dark .dp-table td,
body.theme-dark .card .table-container td,
body.theme-dark .card .table-container th,
body.theme-dark .card table td,
body.theme-dark .card table th {
  border-bottom-color: var(--pd-border) !important;
  color: var(--pd-text) !important;
}

body.theme-dark .dp-table tbody tr:nth-child(even),
body.theme-dark .card table tbody tr:nth-child(even) {
  background: rgba(255, 255, 255, 0.02) !important;
}

body.theme-dark .dp-table tbody tr:hover,
body.theme-dark .card table tbody tr:hover {
  background: rgba(255, 255, 255, 0.04) !important;
}

body.theme-dark .dp-empty,
body.theme-dark .card .empty-state {
  color: var(--pd-text-muted) !important;
}

body.theme-dark .pagination {
  border-top-color: var(--pd-border) !important;
}

body.theme-dark .pagination a {
  background: var(--pd-bg-subtle) !important;
  color: var(--pd-text) !important;
}

body.theme-dark .pagination a:hover {
  background: rgba(255, 255, 255, 0.1) !important;
}

body.theme-dark .pagination .current {
  color: var(--pd-text-muted) !important;
}
