@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap");

:root {
  --primary: #3f5f7f;
  --primary-hover: #344f6a;
  --primary-soft: #edf3f8;
  --primary-border: #cfdce8;

  --success: #4f7f68;
  --success-hover: #426b58;
  --success-soft: #eef6f2;

  --danger: #9b4d4d;
  --danger-hover: #843f3f;
  --danger-soft: #f8eeee;

  --warning: #9a7442;
  --warning-hover: #806036;
  --warning-soft: #f8f3ea;

  --info: #4f6f86;
  --info-soft: #edf4f8;

  --text: #263238;
  --text-secondary: #5f6f7a;
  --text-muted: #8a979f;

  --bg: #f4f6f7;
  --surface: #ffffff;
  --surface-soft: #f8fafb;
  --surface-hover: #eef2f4;

  --border: #d9e0e4;
  --border-soft: #edf1f3;

  --shadow-xs: 0 1px 2px rgba(38, 50, 56, 0.05);
  --shadow-sm: 0 3px 10px rgba(38, 50, 56, 0.07);
  --shadow-md: 0 10px 25px rgba(38, 50, 56, 0.08);
  --shadow-lg: 0 18px 45px rgba(38, 50, 56, 0.12);

  --radius-sm: 7px;
  --radius-md: 10px;
  --radius-lg: 14px;
  --radius-xl: 18px;
  --transition: 180ms ease;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}
html {
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
}
body {
  margin: 0;
  font-family:
    "Inter",
    -apple-system,
    BlinkMacSystemFont,
    "Segoe UI",
    sans-serif;
  font-size: 14px;
  line-height: 1.55;
  color: var(--text);
  background:
    radial-gradient(
      circle at top left,
      rgba(63, 95, 127, 0.08),
      transparent 34%
    ),
    linear-gradient(180deg, #f7f9fa 0%, var(--bg) 100%);
  min-height: 100vh;
}

a {
  color: var(--primary);
  transition: var(--transition);
}
a:hover {
  color: var(--primary-hover);
  text-decoration: none;
}

::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}
::-webkit-scrollbar-track {
  background: transparent;
}
::-webkit-scrollbar-thumb {
  background: #c4cdd3;
  border-radius: 999px;
}
::-webkit-scrollbar-thumb:hover {
  background: #9facb5;
}

.main-content,
.container-fluid {
  max-width: 1320px;
}
.main-content {
  margin: 0 auto;
  padding: 28px;
}

/* ================= NAVBAR ================= */
.navbar,
.navbar.navbar-dark,
nav.navbar[style] {
  background: rgba(255, 255, 255, 0.92) !important;
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
  box-shadow: var(--shadow-xs);
  min-height: 62px;
  padding: 0 22px;
  position: sticky;
  top: 0;
  z-index: 1000;
}
.navbar-brand,
.navbar-brand[style] {
  color: var(--text) !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em;
}
.navbar-brand i,
.navbar-brand i[style] {
  color: var(--primary) !important;
}
.navbar .nav-link,
.navbar .nav-link[style] {
  color: var(--text-secondary) !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  border-radius: var(--radius-md) !important;
  padding: 8px 14px !important;
}
.navbar .nav-link:hover {
  color: var(--text) !important;
  background: var(--surface-hover) !important;
}
.nav-link.dropdown-toggle,
.nav-link.dropdown-toggle[style] {
  background: var(--surface-soft) !important;
  color: var(--text) !important;
  border: 1px solid var(--border) !important;
  box-shadow: var(--shadow-xs);
}
.navbar-toggler {
  border-color: var(--border) !important;
  background: var(--surface-soft);
}
.navbar-toggler-icon {
  filter: invert(1);
  opacity: 0.62;
}

.dropdown-menu,
.dropdown-menu[style] {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-lg) !important;
  padding: 8px;
}
.dropdown-item {
  color: var(--text) !important;
  font-size: 13px;
  font-weight: 500;
  border-radius: var(--radius-sm);
  padding: 9px 12px;
}
.dropdown-item:hover {
  background: var(--surface-hover);
  color: var(--text) !important;
}
.dropdown-item i {
  width: 19px;
  color: var(--text-secondary);
  margin-right: 8px;
}
.dropdown-divider {
  border-color: var(--border-soft);
}

/* ================= BUTTONS ================= */
.btn,
.btn-add,
.btn-filter,
.btn-reset,
.btn-submit,
.btn-cancel,
.btn-aksi {
  border-radius: var(--radius-md) !important;
  font-weight: 600;
  font-size: 13px;
  letter-spacing: -0.01em;
  transition:
    transform var(--transition),
    box-shadow var(--transition),
    background var(--transition),
    border-color var(--transition);
}
.btn:hover,
.btn-add:hover,
.btn-filter:hover,
.btn-submit:hover,
.btn-cancel:hover {
  transform: translateY(-1px);
}
.btn-primary,
.btn-add,
.btn-submit {
  background: var(--primary) !important;
  border-color: var(--primary) !important;
  color: #fff !important;
  box-shadow: 0 8px 18px rgba(63, 95, 127, 0.18);
}
.btn-primary:hover,
.btn-add:hover,
.btn-submit:hover {
  background: var(--primary-hover) !important;
  border-color: var(--primary-hover) !important;
  color: #fff !important;
}
.btn-success {
  background: var(--success) !important;
  border-color: var(--success) !important;
  color: #fff !important;
}
.btn-success:hover {
  background: var(--success-hover) !important;
  border-color: var(--success-hover) !important;
}
.btn-danger {
  background: var(--danger) !important;
  border-color: var(--danger) !important;
  color: #fff !important;
}
.btn-danger:hover {
  background: var(--danger-hover) !important;
  border-color: var(--danger-hover) !important;
}
.btn-outline,
.btn-filter,
.btn-cancel {
  background: var(--surface) !important;
  color: var(--text) !important;
  border: 1px solid var(--border) !important;
  box-shadow: var(--shadow-xs);
}
.btn-outline:hover,
.btn-filter:hover,
.btn-cancel:hover {
  background: var(--surface-hover) !important;
  border-color: #c8d2d8 !important;
}
.btn-reset {
  background: transparent !important;
  color: var(--text-secondary) !important;
  border: 0 !important;
}
.btn-reset:hover {
  color: var(--text) !important;
  background: var(--surface-hover) !important;
}

/* ================= PAGE HEADER & CARDS ================= */
.page-header,
.search-filter-card,
.table-card,
.form-card,
.section-card,
.auto-card,
.stat-card-mini,
.total-jk-card,
.monitor-stat-card {
  background: rgba(255, 255, 255, 0.96) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-xl) !important;
  box-shadow: var(--shadow-sm) !important;
}
.page-header {
  padding: 24px 26px;
  margin-bottom: 22px;
}
.page-header h1,
.page-header h2,
.page-header h3,
.card-header h3,
.section-header h3 {
  color: var(--text) !important;
  font-weight: 800;
  letter-spacing: -0.035em;
  margin-bottom: 6px;
}
.page-header p,
.card-header p,
.section-header p {
  color: var(--text-secondary) !important;
  margin-bottom: 0;
}
.card-header,
.section-header,
.filter-header,
.modal-header {
  background: linear-gradient(
    180deg,
    var(--surface) 0%,
    var(--surface-soft) 100%
  ) !important;
  border-bottom: 1px solid var(--border-soft) !important;
  border-radius: var(--radius-xl) var(--radius-xl) 0 0 !important;
  padding: 20px 24px;
}
.card-header i,
.section-header i,
.filter-header i {
  color: var(--primary) !important;
}
.card-body,
.section-body,
.filter-body,
.modal-body {
  padding: 24px;
}

/* ================= STATS ================= */
.stats-grid,
.auto-grid,
.monitor-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 16px;
}
.stat-card-mini,
.monitor-stat-card,
.stats-bar {
  padding: 18px;
  display: flex;
  align-items: center;
  gap: 14px;
}
.stat-icon,
.monitor-stat-icon {
  width: 46px;
  height: 46px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--primary) !important;
  background: var(--primary-soft) !important;
}
.monitor-stat-icon.green,
.stat-icon.green {
  background: var(--success-soft) !important;
  color: var(--success) !important;
}
.monitor-stat-icon.red,
.stat-icon.red {
  background: var(--danger-soft) !important;
  color: var(--danger) !important;
}
.monitor-stat-icon.blue,
.stat-icon.blue {
  background: var(--primary-soft) !important;
  color: var(--primary) !important;
}
.stat-info h3,
.monitor-stat-info h3 {
  color: var(--text) !important;
  font-weight: 800;
  margin: 0;
}
.stat-info p,
.monitor-stat-info p {
  color: var(--text-secondary) !important;
  margin: 2px 0 0;
}

/* ================= FORMS & FILTERS ================= */
.form-container {
  max-width: 980px;
  margin: 0 auto;
  padding: 28px;
}
.form-group label {
  color: var(--text-secondary) !important;
  font-weight: 700;
  font-size: 12px;
  text-transform: none;
  letter-spacing: 0.01em;
  margin-bottom: 7px;
}
.form-control,
.custom-select,
.dataTables_length select,
.dataTables_filter input,
select,
textarea,
input[type="text"],
input[type="date"],
input[type="password"],
input[type="number"],
input[type="email"] {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-md) !important;
  color: var(--text) !important;
  font-size: 13px !important;
  min-height: 42px;
  box-shadow: none !important;
  transition:
    border-color var(--transition),
    box-shadow var(--transition),
    background var(--transition);
}
.form-control:focus,
.custom-select:focus,
.dataTables_filter input:focus,
select:focus,
textarea:focus,
input:focus {
  border-color: var(--primary) !important;
  box-shadow: 0 0 0 4px rgba(63, 95, 127, 0.13) !important;
  outline: none !important;
}
.form-control::placeholder {
  color: var(--text-muted) !important;
}
.input-group {
  border-radius: var(--radius-md) !important;
}
.input-group-text {
  background: var(--surface-soft) !important;
  border: 1px solid var(--border) !important;
  color: var(--text-muted) !important;
}
.form-text {
  color: var(--text-muted) !important;
}
.form-section {
  border-top: 1px solid var(--border-soft);
  padding-top: 20px;
  margin-top: 20px;
}
.form-section-title {
  color: var(--text) !important;
  font-weight: 800;
  margin-bottom: 16px;
}
.search-filter-card {
  padding: 0;
  margin-bottom: 20px;
  overflow: visible !important;
}
.search-section {
  padding: 20px 22px;
}
.search-container {
  position: relative;
}
.search-icon-left {
  color: var(--text-muted) !important;
}
.clear-search {
  color: var(--text-muted) !important;
}
.clear-search:hover {
  color: var(--danger) !important;
}
.filter-info,
.filter-badge {
  background: var(--primary-soft) !important;
  color: var(--primary) !important;
  border: 1px solid var(--primary-border) !important;
  border-radius: 999px;
}

/* ================= TABLE ================= */
.table-card {
  overflow: hidden;
}
.table {
  margin-bottom: 0;
  color: var(--text);
  background: var(--surface);
}
.table thead th {
  background: var(--surface-soft) !important;
  color: var(--text-secondary) !important;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.045em;
  border-top: 0 !important;
  border-bottom: 1px solid var(--border) !important;
  padding: 13px 14px;
  white-space: nowrap;
}
.table tbody td {
  border-top: 1px solid var(--border-soft) !important;
  padding: 13px 14px;
  vertical-align: middle;
  color: var(--text);
}
.table tbody tr {
  transition: background var(--transition);
}
.table tbody tr:hover {
  background: #f8fbfc !important;
}
.table-responsive {
  border-radius: var(--radius-lg);
}
.footer-stats {
  background: var(--surface-soft);
  border-top: 1px solid var(--border-soft);
  color: var(--text-secondary);
  padding: 14px 18px;
}

.btn-aksi,
.btn-aksi-edit,
.btn-aksi-hapus,
.btn-aksi-reset {
  width: 34px;
  height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 !important;
  border-radius: 9px !important;
  border: 1px solid var(--border) !important;
  background: var(--surface) !important;
}
.btn-aksi-edit {
  color: var(--warning) !important;
}
.btn-aksi-edit:hover {
  background: var(--warning-soft) !important;
  border-color: #ead8bb !important;
}
.btn-aksi-hapus {
  color: var(--danger) !important;
}
.btn-aksi-hapus:hover {
  background: var(--danger-soft) !important;
  border-color: #efcaca !important;
}
.btn-aksi-reset {
  color: var(--primary) !important;
}
.btn-aksi-reset:hover {
  background: var(--primary-soft) !important;
}

/* ================= BADGES & ALERTS ================= */
.badge,
.role-badge-admin,
.role-badge-rt,
.role-badge-warga {
  border-radius: 999px !important;
  padding: 4px 9px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
}
.badge-primary {
  background: var(--primary-soft) !important;
  color: var(--primary) !important;
}
.badge-success,
.role-badge-warga {
  background: var(--success-soft) !important;
  color: var(--success) !important;
}
.badge-danger,
.role-badge-admin {
  background: var(--danger-soft) !important;
  color: var(--danger) !important;
}
.badge-warning,
.role-badge-rt {
  background: var(--warning-soft) !important;
  color: var(--warning) !important;
}
.badge-info {
  background: var(--info-soft) !important;
  color: var(--info) !important;
}
.badge-secondary {
  background: #eef1f3 !important;
  color: var(--text-secondary) !important;
}
.alert {
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-xs);
}
.alert-success {
  background: var(--success-soft) !important;
  color: var(--success) !important;
  border-color: #cfe5da !important;
}
.alert-danger {
  background: var(--danger-soft) !important;
  color: var(--danger) !important;
  border-color: #edcccc !important;
}
.alert-warning {
  background: var(--warning-soft) !important;
  color: var(--warning) !important;
  border-color: #ead8bb !important;
}
.alert-info {
  background: var(--info-soft) !important;
  color: var(--info) !important;
  border-color: #cddde7 !important;
}

/* ================= BREADCRUMB, TABS, MODAL ================= */
.breadcrumb {
  background: transparent !important;
  color: var(--text-secondary);
  padding: 0;
  margin-bottom: 16px;
  font-size: 13px;
}
.breadcrumb a {
  color: var(--text-secondary);
  font-weight: 600;
}
.breadcrumb .active {
  color: var(--text);
  font-weight: 700;
}
.nav-tabs-custom {
  border-bottom: 1px solid var(--border);
  gap: 6px;
}
.nav-tabs-custom .nav-link {
  border: 0 !important;
  color: var(--text-secondary) !important;
  border-radius: var(--radius-md) var(--radius-md) 0 0 !important;
  font-weight: 700;
}
.nav-tabs-custom .nav-link.active,
.nav-tabs .nav-link.active {
  background: var(--surface) !important;
  color: var(--primary) !important;
  border-bottom: 2px solid var(--primary) !important;
}
.modal-content {
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}
.modal-title {
  color: var(--text);
  font-weight: 800;
}
.modal-footer {
  background: var(--surface-soft);
  border-top: 1px solid var(--border-soft);
}

/* ================= CONTEXT MENU & LOGIN SUPPORT ================= */
#contextMenu {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-lg) !important;
  overflow: hidden;
}
#contextMenu .ctx-item {
  color: var(--text) !important;
}
#contextMenu .ctx-item:hover {
  background: var(--surface-hover) !important;
}
#contextMenu .ctx-item.ctx-danger {
  color: var(--danger) !important;
}
#contextMenu .ctx-item.ctx-danger:hover {
  background: var(--danger-soft) !important;
}
#contextMenu .ctx-divider {
  background: var(--border-soft) !important;
}
#tabelRumah tbody tr.ctx-active {
  background: var(--primary-soft) !important;
}

.login-card,
.brand-icon,
.input-group,
.password-toggle,
.login-btn {
  transition: var(--transition);
}
.login-card {
  border-color: var(--border) !important;
  box-shadow: var(--shadow-md) !important;
}
.brand-icon {
  background: var(--primary) !important;
  border-radius: 16px !important;
}
.login-btn {
  background: var(--primary) !important;
  border-color: var(--primary) !important;
}
.login-btn:hover {
  background: var(--primary-hover) !important;
  border-color: var(--primary-hover) !important;
  transform: translateY(-1px);
}

/* ================= DATATABLES ================= */
.dataTables_wrapper .dataTables_info {
  color: var(--text-secondary) !important;
  font-size: 13px;
}
.page-link {
  color: var(--primary);
  border-color: var(--border);
}
.page-item.active .page-link {
  background: var(--primary);
  border-color: var(--primary);
}
.page-link:hover {
  color: var(--primary-hover);
  background: var(--surface-hover);
  border-color: var(--border);
}

/* ================= RESPONSIVE ================= */
@media (max-width: 992px) {
  .main-content,
  .form-container {
    padding: 20px;
  }
  .navbar {
    padding: 8px 16px;
  }
}
@media (max-width: 768px) {
  body {
    font-size: 13px;
  }
  .main-content,
  .form-container {
    padding: 16px;
  }
  .page-header,
  .card-body,
  .section-body,
  .filter-body {
    padding: 18px;
  }
  .stats-grid,
  .auto-grid,
  .monitor-stats {
    grid-template-columns: 1fr;
  }
  .table thead th,
  .table tbody td {
    padding: 11px 12px;
  }
  .btn,
  .btn-add,
  .btn-filter,
  .btn-submit,
  .btn-cancel {
    width: 100%;
    justify-content: center;
    margin-bottom: 8px;
  }
}
@media (max-width: 576px) {
  .navbar-brand {
    font-size: 14px !important;
  }
  .page-header h1,
  .page-header h2,
  .card-header h3 {
    font-size: 20px;
  }
  .form-card,
  .table-card,
  .search-filter-card {
    border-radius: var(--radius-lg) !important;
  }
}

/* ============================================================
   TABLE SCROLL FIX - hilangkan efek goyang saat tabel discroll
   ============================================================ */
.table-card,
.table-responsive,
.dataTables_wrapper,
.dataTables_scroll,
.dataTables_scrollBody {
  transform: none !important;
  animation: none !important;
  will-change: auto !important;
  backface-visibility: visible !important;
  perspective: none !important;
}

.table-responsive,
.dataTables_scrollBody {
  overflow-x: auto !important;
  overflow-y: visible !important;
  -webkit-overflow-scrolling: auto !important;
  scroll-behavior: auto !important;
}

.table,
.table thead,
.table tbody,
.table tr,
.table th,
.table td {
  transform: none !important;
  animation: none !important;
  transition: none !important;
}

.table tbody tr:hover,
#tabelRumah tbody tr:hover,
#tabelPenduduk tbody tr:hover {
  transform: none !important;
  box-shadow: none !important;
  background: #f8fbfc !important;
}

.table .btn,
.table .btn:hover,
.table .btn-aksi,
.table .btn-aksi:hover,
.table .btn-aksi-edit,
.table .btn-aksi-edit:hover,
.table .btn-aksi-hapus,
.table .btn-aksi-hapus:hover,
.table .btn-aksi-reset,
.table .btn-aksi-reset:hover {
  transform: none !important;
  transition:
    background-color 120ms ease,
    border-color 120ms ease,
    color 120ms ease !important;
}

/* ============================================================
   PATCH HALAMAN KHUSUS: GENERATE USER, MONITORING, STATISTIK
   Menyamakan tampilan halaman yang masih memakai style inline/lokal.
   Letakkan file ini sebagai style.css agar override berjalan.
   ============================================================ */

/* Paksa navbar halaman monitoring/statistik/generate agar sama dengan dashboard */
.navbar.navbar-dark,
nav.navbar[style] {
  background: var(--surface) !important;
  border-bottom: 1px solid var(--border) !important;
  box-shadow: var(--shadow-sm) !important;
  min-height: 60px;
}
.navbar.navbar-dark .navbar-brand,
.navbar.navbar-dark .nav-link,
nav.navbar[style] .navbar-brand,
nav.navbar[style] .nav-link {
  color: var(--text) !important;
}
.navbar.navbar-dark .navbar-brand i,
nav.navbar[style] .navbar-brand i {
  color: var(--primary) !important;
}
.navbar.navbar-dark .navbar-toggler,
nav.navbar[style] .navbar-toggler {
  background: var(--primary) !important;
  border: 0 !important;
  border-radius: var(--radius-md) !important;
  padding: 6px 9px;
}
.navbar.navbar-dark .nav-link.dropdown-toggle,
nav.navbar[style] .nav-link.dropdown-toggle,
.nav-link.dropdown-toggle[style] {
  background: var(--surface-soft) !important;
  color: var(--text) !important;
  border: 1px solid var(--border) !important;
  border-radius: 999px !important;
  padding: 7px 16px !important;
  box-shadow: none !important;
}
.navbar.navbar-dark .nav-link.dropdown-toggle:hover,
nav.navbar[style] .nav-link.dropdown-toggle:hover {
  background: var(--surface-hover) !important;
}
.navbar .dropdown-menu[style],
.dropdown-menu.dropdown-menu-right[style] {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-lg) !important;
}

/* Header halaman agar konsisten */
.page-header,
.search-filter-card > div:first-child {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-xl) !important;
  box-shadow: var(--shadow-sm) !important;
}
.search-filter-card > div:first-child {
  padding: 20px 22px !important;
}
.page-header h5,
.search-filter-card h5 {
  color: var(--text) !important;
  font-size: 20px !important;
  font-weight: 800 !important;
  letter-spacing: -0.3px;
}
.page-header p,
.search-filter-card p {
  color: var(--text-secondary) !important;
  margin-top: 4px;
}

/* MONITORING */
.monitor-stats,
.stats-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 18px !important;
  margin-bottom: 24px !important;
}
.monitor-stat-card,
.stat-card,
.stats-grid > div,
.total-jk-card {
  background: var(--surface) !important;
  color: var(--text) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-xl) !important;
  box-shadow: var(--shadow-sm) !important;
  padding: 20px !important;
  transition: none !important;
  transform: none !important;
}
.monitor-stat-card {
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
}
.monitor-stat-icon,
.stat-icon {
  width: 48px !important;
  height: 48px !important;
  border-radius: 14px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 20px !important;
}
.monitor-stat-icon.blue,
.stat-icon.blue {
  background: var(--primary-soft) !important;
  color: var(--primary) !important;
}
.monitor-stat-icon.green,
.stat-icon.green {
  background: var(--success-soft) !important;
  color: var(--success) !important;
}
.monitor-stat-icon.red,
.stat-icon.red {
  background: var(--danger-soft) !important;
  color: var(--danger) !important;
}
.monitor-stat-info h3,
.stat-card h3,
.total-jk-card .number {
  color: var(--text) !important;
  font-size: 28px !important;
  font-weight: 800 !important;
  margin: 0 !important;
  line-height: 1.15 !important;
}
.monitor-stat-info p,
.stat-card p,
.total-jk-card small,
.total-jk-card .label {
  color: var(--text-secondary) !important;
  margin: 4px 0 0 !important;
  font-size: 13px !important;
}
.pwd-code {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  padding: 4px 10px;
  background: var(--surface-soft);
  border: 1px solid var(--border);
  border-radius: 999px;
  color: var(--text);
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 12px;
}
.footer-stats {
  color: var(--text-secondary) !important;
  font-size: 13px;
}

/* STATISTIK */
.stat-card-custom {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-xl) !important;
  box-shadow: var(--shadow-sm) !important;
  overflow: hidden !important;
  margin-bottom: 24px !important;
}
.stat-card-custom .card-header-custom,
.card-header-custom {
  background: var(--surface-soft) !important;
  color: var(--text) !important;
  border-bottom: 1px solid var(--border) !important;
  padding: 16px 20px !important;
  font-weight: 800 !important;
  font-size: 16px !important;
}
.stat-card-custom .card-body-custom,
.card-body-custom {
  padding: 20px !important;
  background: var(--surface) !important;
  overflow-x: auto !important;
}
.stats-table {
  width: 100% !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
  color: var(--text) !important;
  font-size: 13px !important;
}
.stats-table th,
.stats-table td {
  border: 0 !important;
  border-bottom: 1px solid var(--border-soft) !important;
  padding: 12px 14px !important;
  vertical-align: middle !important;
}
.stats-table th {
  background: var(--surface-soft) !important;
  color: var(--text-secondary) !important;
  font-weight: 800 !important;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  font-size: 11px !important;
}
.stats-table td:first-child {
  color: var(--text) !important;
  font-weight: 700 !important;
}
.stats-table .total-row,
.total-row {
  background: var(--primary-soft) !important;
  color: var(--text) !important;
  font-weight: 800 !important;
}
.nav-tabs-custom {
  border-bottom: 1px solid var(--border) !important;
  gap: 4px;
  margin-bottom: 22px !important;
}
.nav-tabs-custom .nav-link {
  color: var(--text-secondary) !important;
  border: 0 !important;
  border-radius: var(--radius-md) var(--radius-md) 0 0 !important;
  padding: 10px 16px !important;
  font-weight: 700 !important;
  background: transparent !important;
}
.nav-tabs-custom .nav-link:hover {
  background: var(--surface-hover) !important;
  color: var(--text) !important;
}
.nav-tabs-custom .nav-link.active {
  background: var(--surface) !important;
  color: var(--primary) !important;
  border-bottom: 3px solid var(--primary) !important;
}
.btn-export-tab {
  background: var(--success) !important;
  color: #fff !important;
  border: 1px solid var(--success) !important;
  border-radius: 999px !important;
  padding: 7px 15px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  box-shadow: none !important;
  transform: none !important;
}
.btn-export-tab:hover {
  background: var(--success-hover) !important;
  border-color: var(--success-hover) !important;
  color: #fff !important;
  transform: none !important;
  text-decoration: none !important;
}

/* GENERATE USER - dukungan class umum yang biasanya dipakai */
.generate-card,
.generator-card,
.user-generate-card,
.account-card,
.info-card,
.result-card,
.generated-user-card {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-xl) !important;
  box-shadow: var(--shadow-sm) !important;
  padding: 20px !important;
}
.generate-card .card-header,
.generator-card .card-header,
.user-generate-card .card-header,
.account-card .card-header,
.result-card .card-header {
  background: var(--surface-soft) !important;
  border-bottom: 1px solid var(--border) !important;
  color: var(--text) !important;
  font-weight: 800 !important;
}
.generate-list,
.user-list,
.account-list {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-lg) !important;
  overflow: hidden;
}
.generate-list .list-group-item,
.user-list .list-group-item,
.account-list .list-group-item {
  border-color: var(--border-soft) !important;
  color: var(--text) !important;
}
.generated-username,
.generated-password,
.username-code,
.password-code {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  background: var(--surface-soft) !important;
  border: 1px solid var(--border) !important;
  border-radius: 999px !important;
  color: var(--text) !important;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 12px;
}

/* Badge lebih soft dan seragam */
.badge,
.role-badge-admin,
.role-badge-rt,
.role-badge-warga {
  border-radius: 999px !important;
  padding: 5px 10px !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  letter-spacing: 0.01em;
}
.badge-info {
  background: var(--info-soft) !important;
  color: var(--info) !important;
}
.badge-success,
.role-badge-warga {
  background: var(--success-soft) !important;
  color: var(--success) !important;
}
.badge-danger,
.role-badge-admin {
  background: var(--danger-soft) !important;
  color: var(--danger) !important;
}
.badge-warning,
.role-badge-rt {
  background: var(--warning-soft) !important;
  color: var(--warning) !important;
}
.badge-secondary {
  background: var(--surface-hover) !important;
  color: var(--text-secondary) !important;
}

/* Rapikan DataTables di monitoring/generate */
.dataTables_wrapper .row {
  align-items: center;
}
.dataTables_wrapper .dataTables_length label,
.dataTables_wrapper .dataTables_filter label {
  color: var(--text-secondary) !important;
  font-size: 13px !important;
  font-weight: 600 !important;
}
.dataTables_wrapper .dataTables_filter input,
.dataTables_wrapper .dataTables_length select {
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-md) !important;
  background: var(--surface) !important;
  color: var(--text) !important;
  padding: 7px 10px !important;
  min-height: 36px;
}
.dataTables_wrapper .dataTables_filter input:focus,
.dataTables_wrapper .dataTables_length select:focus {
  border-color: var(--primary) !important;
  box-shadow: 0 0 0 3px var(--primary-soft) !important;
  outline: none !important;
}

@media (max-width: 991px) {
  .navbar-collapse {
    background: var(--surface) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius-lg) !important;
    padding: 12px !important;
    margin-top: 10px !important;
    box-shadow: var(--shadow-md) !important;
  }
}
@media (max-width: 768px) {
  .monitor-stats,
  .stats-grid {
    grid-template-columns: 1fr !important;
  }
  .nav-tabs-custom .nav-link {
    padding: 8px 12px !important;
    font-size: 12px !important;
  }
  .stats-table th,
  .stats-table td {
    padding: 9px 10px !important;
    font-size: 12px !important;
  }
}
/* Biodata tidak punya wrapper .main-content, jadi blok utamanya dianimasikan halus */
body > .search-filter-card,
body > .stats-grid,
body > .table-card,
body > .chart-card,
body > .section-card,
body > .data-card,
body > .card,
.search-filter-card,
.table-card,
.stats-charts-container

/* Delay tipis agar masuknya natural, bukan goyang */
.search-filter-card {
  animation-delay: 40ms;
}
.stats-grid,
.monitor-stats,
.stats-charts-container {
  animation-delay: 80ms;
}
.table-card,
.dataTables_wrapper {
  animation-delay: 120ms;
}

/* Pastikan tabel tetap stabil saat scroll; animasi hanya container awal */
.table,
.table thead,
.table tbody,
.table tr,
.table th,
.table td,
.table-responsive,
.dataTables_scrollBody {
  animation: none !important;
  transform: none !important;
}

/* Hormati setting pengguna yang mematikan animasi */
@media (prefers-reduced-motion: reduce) {
  .animate-fadeInUp,
  .main-content,
  .search-filter-card,
  .table-card,
  .stats-grid,
  .monitor-stats,
  .stats-charts-container,
  .stat-chart-container {
    animation: none !important;
  }
}
/* ===================================================== */
/* STANDARD BUTTON SYSTEM */
/* ===================================================== */

.btn-action {
  min-width: 120px;
  height: 40px;
  padding: 0 18px;
  border: none;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 600;
  text-decoration: none !important;
  transition: all 0.2s ease;
  cursor: pointer;
  margin: 4px;
}

/* PRIMARY */
.btn-primary-custom {
  background: #2563eb;
  color: #fff;
}

.btn-primary-custom:hover {
  background: #1d4ed8;
  color: #fff;
}

/* DANGER */
.btn-danger-custom {
  background: #dc2626;
  color: #fff;
}

.btn-danger-custom:hover {
  background: #b91c1c;
  color: #fff;
}

/* SECONDARY */
.btn-secondary-custom {
  background: #e5e7eb;
  color: #374151;
}

.btn-secondary-custom:hover {
  background: #d1d5db;
  color: #111827;
}
/* ===================================================== */
/* BUTTON CONSISTENT SYSTEM */
/* ===================================================== */

.btn-save,
.btn-export-excel,
.btn-generate-single,
.btn-generate-all {
  height: 40px !important;
  border: none !important;
  border-radius: 12px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 6px;
  transition: all 0.2s ease;
  text-decoration: none !important;
}

/* BUTTON PRIMARY */
.btn-save,
.btn-generate-single,
.btn-generate-all,
.btn-export-excel {
  background: linear-gradient(135deg, #1e293b, #0f172a) !important;
  color: #fff !important;
}

.btn-save:hover,
.btn-generate-single:hover,
.btn-generate-all:hover,
.btn-export-excel:hover {
  background: linear-gradient(135deg, #0f172a, #020617) !important;
  transform: none !important;
  box-shadow: none !important;
}

/* AKSI TABLE */
.btn-aksi {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none !important;
  transition: all 0.2s ease;
  border: none;
  font-size: 13px;
}

/* RESET */
.btn-aksi-reset {
  background: #e0f2fe;
  color: #0369a1;
}

.btn-aksi-reset:hover {
  background: #bae6fd;
  color: #075985;
}

/* AKTIF */
.btn-aksi-aktif {
  background: #dcfce7;
  color: #166534;
}

.btn-aksi-aktif:hover {
  background: #bbf7d0;
  color: #14532d;
}

/* NONAKTIF */
.btn-aksi-nonaktif {
  background: #fef3c7;
  color: #92400e;
}

.btn-aksi-nonaktif:hover {
  background: #fde68a;
  color: #78350f;
}

/* HAPUS */
.btn-aksi-hapus {
  background: #fee2e2;
  color: #b91c1c;
}

.btn-aksi-hapus:hover {
  background: #fecaca;
  color: #991b1b;
}

/* DISABLED */
.btn-aksi-disabled {
  background: #e5e7eb;
  color: #9ca3af;
  cursor: not-allowed;
}

/* DATATABLE BUTTON SPACE */
.dataTables_wrapper .dataTables_paginate .paginate_button {
  border-radius: 8px !important;
}
/* FIX MENU GOYANG SAAT SCROLL */
html {
  scroll-behavior: auto !important;
}

.navbar,
.navbar *,
.dropdown-menu,
.dropdown-item {
  transform: none !important;
  transition:
    background 0.15s ease,
    color 0.15s ease !important;
}

.dropdown-item:hover {
  padding-left: 20px !important;
}

/* HAPUS FLASH / ANIMASI FILTER & JUMLAH DATA */
.filter-header,
.filter-body,
.filter-info,
.filter-badge,
.search-filter-card {
  animation: none !important;
  transition: none !important;
}

/* TABLE LEBIH STABIL */
.table-responsive {
  overflow-x: auto;
  -webkit-overflow-scrolling: auto;
}

.table {
  table-layout: auto;
  white-space: nowrap;
}

.table th,
.table td {
  vertical-align: middle !important;
}

/* UKURAN KOLOM BIODATA */
#tabelBiodata th:nth-child(1),
#tabelBiodata td:nth-child(1) {
  width: 45px;
}

#tabelBiodata th:nth-child(2),
#tabelBiodata td:nth-child(2) {
  width: 90px;
}

#tabelBiodata th:nth-child(4),
#tabelBiodata td:nth-child(4) {
  min-width: 180px;
  white-space: normal;
}

#tabelBiodata th:nth-child(5),
#tabelBiodata td:nth-child(5) {
  width: 110px;
}

#tabelBiodata th:nth-child(7),
#tabelBiodata td:nth-child(7) {
  width: 120px;
}

#tabelBiodata th:nth-child(8),
#tabelBiodata td:nth-child(8) {
  width: 110px;
}

#tabelBiodata th:nth-child(9),
#tabelBiodata td:nth-child(9) {
  width: 130px;
}

/* KOLOM ALAMAT BOLEH PANJANG */
#tabelBiodata td.alamat-cell,
#tabelRumah td.alamat-cell {
  min-width: 220px;
  max-width: 320px;
  white-space: normal;
}
/* FIX UKURAN KOLOM BIODATA SESUAI ISI DATA */
#tabelBiodata th:nth-child(6),
#tabelBiodata td:nth-child(6) {
  width: 90px;
  min-width: 90px;
  max-width: 90px;
}

#tabelBiodata th:nth-child(8),
#tabelBiodata td:nth-child(8) {
  width: 115px;
  min-width: 115px;
  max-width: 115px;
}

#tabelBiodata th:nth-child(10),
#tabelBiodata td:nth-child(10) {
  width: 110px;
  min-width: 110px;
  max-width: 110px;
}

#tabelBiodata th:nth-child(11),
#tabelBiodata td:nth-child(11) {
  width: 120px;
  min-width: 120px;
  max-width: 120px;
}

#tabelBiodata th:nth-child(22),
#tabelBiodata td:nth-child(22) {
  min-width: 220px;
  max-width: 320px;
  white-space: normal;
}
/* GENERATE USER - CONSISTENT UI */
.page-header,
.stats-bar,
.section-card,
.auto-card {
  border: 1px solid #e2e8f0 !important;
  border-radius: 20px !important;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.04) !important;
}

.section-header {
  background: #f8fafc !important;
  color: #1e293b !important;
  border-bottom: 1px solid #e2e8f0 !important;
}

.btn-save,
.btn-export-excel,
.btn-generate-single,
.btn-generate-all {
  background: linear-gradient(135deg, #1e293b, #0f172a) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 12px !important;
  height: 40px !important;
  padding: 0 18px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 6px;
  box-shadow: none !important;
  transform: none !important;
}

.btn-save:hover,
.btn-export-excel:hover,
.btn-generate-single:hover,
.btn-generate-all:hover {
  background: linear-gradient(135deg, #0f172a, #020617) !important;
  color: #fff !important;
  transform: none !important;
  box-shadow: none !important;
}

.auto-icon.blue,
.auto-icon.green {
  background: #f1f5f9 !important;
  color: #1e293b !important;
}

.badge-pill-count.orange,
.badge-pill-count.blue {
  background: #f8fafc !important;
  color: #334155 !important;
  border: 1px solid #e2e8f0 !important;
}

.btn-aksi {
  width: 34px !important;
  height: 34px !important;
  border-radius: 10px !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  text-decoration: none !important;
  font-size: 13px !important;
}

.btn-aksi-reset {
  background: #e0f2fe !important;
  color: #0369a1 !important;
}

.btn-aksi-aktif {
  background: #dcfce7 !important;
  color: #166534 !important;
}

.btn-aksi-nonaktif {
  background: #fef3c7 !important;
  color: #92400e !important;
}

.btn-aksi-hapus {
  background: #fee2e2 !important;
  color: #b91c1c !important;
}

#tabelBiodata {
  table-layout: auto;
}

#tabelBiodata th,
#tabelBiodata td {
  vertical-align: middle !important;
}

/* No */
#tabelBiodata th:nth-child(1),
#tabelBiodata td:nth-child(1) {
  width: 45px;
  min-width: 45px;
}

/* No Rumah */
#tabelBiodata th:nth-child(2),
#tabelBiodata td:nth-child(2) {
  width: 85px;
  min-width: 85px;
}

/* NIK */
#tabelBiodata th:nth-child(3),
#tabelBiodata td:nth-child(3) {
  width: 145px;
  min-width: 145px;
}

/* Nama */
#tabelBiodata th:nth-child(4),
#tabelBiodata td:nth-child(4) {
  min-width: 180px;
  max-width: 240px;
  white-space: normal;
}

/* Jenis Kelamin */
#tabelBiodata th:nth-child(5),
#tabelBiodata td:nth-child(5) {
  width: 110px;
  min-width: 110px;
  max-width: 110px;
}

/* Tempat Lahir */
#tabelBiodata th:nth-child(6),
#tabelBiodata td:nth-child(6) {
  width: 130px;
  min-width: 130px;
  max-width: 150px;
}

/* Tanggal Lahir */
#tabelBiodata th:nth-child(7),
#tabelBiodata td:nth-child(7) {
  width: 115px;
  min-width: 115px;
  max-width: 115px;
}

/* Usia */
#tabelBiodata th:nth-child(8),
#tabelBiodata td:nth-child(8) {
  width: 105px;
  min-width: 105px;
  max-width: 120px;
}

/* Agama */
#tabelBiodata th:nth-child(9),
#tabelBiodata td:nth-child(9) {
  width: 120px;
  min-width: 120px;
  max-width: 140px;
}

/* Pendidikan */
#tabelBiodata th:nth-child(10),
#tabelBiodata td:nth-child(10) {
  width: 115px;
  min-width: 115px;
  max-width: 130px;
}

/* Pekerjaan */
#tabelBiodata th:nth-child(11),
#tabelBiodata td:nth-child(11) {
  width: 150px;
  min-width: 150px;
  max-width: 180px;
  white-space: normal;
}

/* Golongan Darah */
#tabelBiodata th:nth-child(12),
#tabelBiodata td:nth-child(12) {
  width: 95px;
  min-width: 95px;
  max-width: 95px;
}

/* Status Kawin */
#tabelBiodata th:nth-child(13),
#tabelBiodata td:nth-child(13) {
  width: 120px;
  min-width: 120px;
  max-width: 140px;
}

/* Hubungan Keluarga */
#tabelBiodata th:nth-child(14),
#tabelBiodata td:nth-child(14) {
  width: 150px;
  min-width: 150px;
  max-width: 170px;
  white-space: normal;
}

/* Warga Negara */
#tabelBiodata th:nth-child(15),
#tabelBiodata td:nth-child(15) {
  width: 95px;
  min-width: 95px;
  max-width: 95px;
}

/* Alamat */
#tabelBiodata th:nth-child(16),
#tabelBiodata td:nth-child(16) {
  min-width: 220px;
  max-width: 320px;
  white-space: normal;
}

/* RT dan RW */
#tabelBiodata th:nth-child(17),
#tabelBiodata td:nth-child(17),
#tabelBiodata th:nth-child(18),
#tabelBiodata td:nth-child(18) {
  width: 60px;
  min-width: 60px;
  max-width: 60px;
}

/* Kelurahan, Kecamatan, Kabupaten, Provinsi */
#tabelBiodata th:nth-child(19),
#tabelBiodata td:nth-child(19),
#tabelBiodata th:nth-child(20),
#tabelBiodata td:nth-child(20),
#tabelBiodata th:nth-child(21),
#tabelBiodata td:nth-child(21),
#tabelBiodata th:nth-child(22),
#tabelBiodata td:nth-child(22) {
  width: 140px;
  min-width: 140px;
  max-width: 170px;
  white-space: normal;
}

/* Kodepos */
#tabelBiodata th:nth-child(23),
#tabelBiodata td:nth-child(23) {
  width: 90px;
  min-width: 90px;
  max-width: 90px;
}

/* Status */
#tabelBiodata th:nth-child(24),
#tabelBiodata td:nth-child(24) {
  width: 95px;
  min-width: 95px;
  max-width: 95px;
}

/* Aksi */
#tabelBiodata th:last-child,
#tabelBiodata td:last-child {
  width: 120px;
  min-width: 120px;
  max-width: 120px;
}
/* MATIKAN SEMUA ANIMASI */
* {
  animation: none !important;
  transition: none !important;
  scroll-behavior: auto !important;
}

/* MENU TIDAK GOYANG */
.dropdown-item:hover {
  padding-left: 20px !important;
  transform: none !important;
}

/* HAPUS EFEK MASUK HALAMAN */
.animate-fadeInUp,
.animate-scaleIn,
.animate-pulse {
  animation: none !important;
  transform: none !important;
}

/* FILTER TANPA FLASH */
.filter-header,
.filter-body,
.filter-info,
.filter-badge,
.search-filter-card {
  animation: none !important;
  transition: none !important;
  transform: none !important;
}

/* TABLE STABIL */
.table,
.table th,
.table td {
  transition: none !important;
  animation: none !important;
}

/* KOLOM BIODATA SESUAI PANJANG DATA */
#tabelBiodata {
  table-layout: auto;
}

#tabelBiodata th:nth-child(5),
#tabelBiodata td:nth-child(5) {
  width: 110px;
}

#tabelBiodata th:nth-child(7),
#tabelBiodata td:nth-child(7) {
  width: 120px;
}

#tabelBiodata th:nth-child(9),
#tabelBiodata td:nth-child(9) {
  width: 110px;
}

#tabelBiodata th:nth-child(10),
#tabelBiodata td:nth-child(10) {
  width: 120px;
}
#tabelBiodata {
  table-layout: auto !important;
  width: 100% !important;
}

#tabelBiodata th,
#tabelBiodata td {
  padding: 5px 6px !important;
  font-size: 10.8px !important;
  line-height: 1.25 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  vertical-align: middle !important;
}

/* 1 No */
#tabelBiodata th:nth-child(1),
#tabelBiodata td:nth-child(1) {
  min-width: 38px !important;
  max-width: 38px !important;
  text-align: center !important;
}

/* 2 No Rumah */
#tabelBiodata th:nth-child(2),
#tabelBiodata td:nth-child(2) {
  min-width: 58px !important;
  max-width: 58px !important;
  text-align: center !important;
}

/* 3 Status Tempat Tinggal */
#tabelBiodata th:nth-child(3),
#tabelBiodata td:nth-child(3) {
  min-width: 88px !important;
  max-width: 88px !important;
}

/* 4 NIK */
#tabelBiodata th:nth-child(4),
#tabelBiodata td:nth-child(4) {
  min-width: 120px !important;
  max-width: 120px !important;
}

/* 5 Nama */
#tabelBiodata th:nth-child(5),
#tabelBiodata td:nth-child(5) {
  min-width: 125px !important;
  max-width: 125px !important;
}

/* 6 JK */
#tabelBiodata th:nth-child(6),
#tabelBiodata td:nth-child(6) {
  min-width: 42px !important;
  max-width: 42px !important;
  text-align: center !important;
}

/* 7 Tempat Lahir */
#tabelBiodata th:nth-child(7),
#tabelBiodata td:nth-child(7) {
  min-width: 85px !important;
  max-width: 85px !important;
}

/* 8 Tgl Lahir */
#tabelBiodata th:nth-child(8),
#tabelBiodata td:nth-child(8) {
  min-width: 78px !important;
  max-width: 78px !important;
  text-align: center !important;
}

/* 9 Usia */
#tabelBiodata th:nth-child(9),
#tabelBiodata td:nth-child(9) {
  min-width: 70px !important;
  max-width: 70px !important;
  text-align: center !important;
}

/* 10 Agama */
#tabelBiodata th:nth-child(10),
#tabelBiodata td:nth-child(10) {
  min-width: 65px !important;
  max-width: 65px !important;
  text-align: center !important;
}

/* 11 Pendidikan */
#tabelBiodata th:nth-child(11),
#tabelBiodata td:nth-child(11) {
  min-width: 75px !important;
  max-width: 75px !important;
}

/* 12 Pekerjaan */
#tabelBiodata th:nth-child(12),
#tabelBiodata td:nth-child(12) {
  min-width: 90px !important;
  max-width: 90px !important;
}

/* 13 Gol Darah */
#tabelBiodata th:nth-child(13),
#tabelBiodata td:nth-child(13) {
  min-width: 45px !important;
  max-width: 45px !important;
  text-align: center !important;
}

/* 14 Status Kawin */
#tabelBiodata th:nth-child(14),
#tabelBiodata td:nth-child(14) {
  min-width: 82px !important;
  max-width: 82px !important;
}

/* 15 Tgl Kawin */
#tabelBiodata th:nth-child(15),
#tabelBiodata td:nth-child(15) {
  min-width: 75px !important;
  max-width: 75px !important;
  text-align: center !important;
}

/* 16 Hubungan Keluarga */
#tabelBiodata th:nth-child(16),
#tabelBiodata td:nth-child(16) {
  min-width: 90px !important;
  max-width: 90px !important;
}

/* 17 WN */
#tabelBiodata th:nth-child(17),
#tabelBiodata td:nth-child(17) {
  min-width: 55px !important;
  max-width: 55px !important;
  text-align: center !important;
}

/* 18 No Paspor */
#tabelBiodata th:nth-child(18),
#tabelBiodata td:nth-child(18) {
  min-width: 72px !important;
  max-width: 72px !important;
}

/* 19 No KITAP */
#tabelBiodata th:nth-child(19),
#tabelBiodata td:nth-child(19) {
  min-width: 72px !important;
  max-width: 72px !important;
}

/* 20 Ayah */
#tabelBiodata th:nth-child(20),
#tabelBiodata td:nth-child(20) {
  min-width: 95px !important;
  max-width: 95px !important;
}

/* 21 Ibu */
#tabelBiodata th:nth-child(21),
#tabelBiodata td:nth-child(21) {
  min-width: 95px !important;
  max-width: 95px !important;
}

/* 22 Alamat */
#tabelBiodata th:nth-child(22),
#tabelBiodata td:nth-child(22) {
  min-width: 145px !important;
  max-width: 145px !important;
}

/* 23 RT */
#tabelBiodata th:nth-child(23),
#tabelBiodata td:nth-child(23) {
  min-width: 35px !important;
  max-width: 35px !important;
  text-align: center !important;
}

/* 24 RW */
#tabelBiodata th:nth-child(24),
#tabelBiodata td:nth-child(24) {
  min-width: 35px !important;
  max-width: 35px !important;
  text-align: center !important;
}

/* 25-28 Wilayah */
#tabelBiodata th:nth-child(25),
#tabelBiodata td:nth-child(25),
#tabelBiodata th:nth-child(26),
#tabelBiodata td:nth-child(26),
#tabelBiodata th:nth-child(27),
#tabelBiodata td:nth-child(27),
#tabelBiodata th:nth-child(28),
#tabelBiodata td:nth-child(28) {
  min-width: 85px !important;
  max-width: 85px !important;
}

/* 29 Kodepos */
#tabelBiodata th:nth-child(29),
#tabelBiodata td:nth-child(29) {
  min-width: 60px !important;
  max-width: 60px !important;
  text-align: center !important;
}

/* 30-31 Tanggal */
#tabelBiodata th:nth-child(30),
#tabelBiodata td:nth-child(30),
#tabelBiodata th:nth-child(31),
#tabelBiodata td:nth-child(31) {
  min-width: 75px !important;
  max-width: 75px !important;
  text-align: center !important;
}

/* 32 Status */
#tabelBiodata th:nth-child(32),
#tabelBiodata td:nth-child(32) {
  min-width: 35px !important;
  max-width: 35px !important;
  text-align: center !important;
}

/* 33 Keterangan */
#tabelBiodata th:nth-child(33),
#tabelBiodata td:nth-child(33) {
  min-width: 110px !important;
  max-width: 110px !important;
}

/* Biar DataTables scroll tetap aman */
.dataTables_scrollBody {
  overflow-x: auto !important;
}
.form-page-card {
  background: #ffffff;
  border: 1px solid #e2e8f0;
  border-radius: 20px;
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.05);
  overflow: hidden;
}

.form-page-header {
  padding: 20px 24px;
  background: #f8fafc;
  border-bottom: 1px solid #e2e8f0;
}

.form-page-header h5 {
  margin: 0;
  font-size: 16px;
  font-weight: 700;
  color: #0f172a;
}

.form-page-header p {
  margin: 4px 0 0;
  font-size: 13px;
  color: #64748b;
}

.form-page-body {
  padding: 24px;
}

.form-section-title {
  font-size: 14px;
  font-weight: 700;
  color: #0f172a;
  margin: 4px 0 16px;
  padding-bottom: 10px;
  border-bottom: 1px solid #e2e8f0;
}

.form-grid-2 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px 18px;
}

.form-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px 18px;
}

.form-group {
  margin-bottom: 0;
}

.form-group label {
  font-size: 12px;
  font-weight: 600;
  color: #334155;
  margin-bottom: 6px;
}

.form-control {
  height: 40px;
  border-radius: 10px;
  border: 1px solid #dbe2ea;
  padding: 8px 12px;
  font-size: 13px;
  color: #0f172a;
  box-shadow: none !important;
}

textarea.form-control {
  min-height: 84px;
  height: auto;
  resize: vertical;
}

.form-control:focus {
  border-color: #334155;
  box-shadow: 0 0 0 4px rgba(30, 41, 59, 0.08) !important;
}

.form-action-row {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 22px;
  padding-top: 18px;
  border-top: 1px solid #e2e8f0;
}

.btn-form-primary,
.btn-form-secondary {
  height: 38px;
  padding: 0 18px;
  border-radius: 10px;
  border: none;
  font-size: 13px;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  text-decoration: none !important;
}

.btn-form-primary {
  background: linear-gradient(135deg, #1e293b, #0f172a);
  color: #fff !important;
}

.btn-form-secondary {
  background: #f1f5f9;
  color: #334155 !important;
  border: 1px solid #e2e8f0;
}

.btn-form-primary:hover {
  background: linear-gradient(135deg, #0f172a, #020617);
}

.btn-form-secondary:hover {
  background: #e2e8f0;
}

@media (max-width: 768px) {
  .form-grid-2,
  .form-grid-3 {
    grid-template-columns: 1fr;
  }

  .form-page-body {
    padding: 18px;
  }

  .form-action-row {
    flex-direction: column;
  }

  .btn-form-primary,
  .btn-form-secondary {
    width: 100%;
  }
}

/* PASSWORD MONITORING LEBIH JELAS */
.pwd-code {
  font-size: 16px !important;
  font-weight: 800 !important;
  letter-spacing: 0.7px;
  color: #0f172a !important;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  padding: 5px 10px;
  border-radius: 8px;
  display: inline-block;
}

/* SEARCH USER MONITORING */
.monitor-search-box {
  background: #ffffff;
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  padding: 16px;
  margin-bottom: 18px;
}

.monitor-search-box label {
  font-size: 13px;
  font-weight: 700;
  color: #1e293b;
  margin-bottom: 8px;
  display: block;
}

#userSearch {
  height: 40px;
  border-radius: 10px;
}
html,
body,
*,
*::before,
*::after {
  animation: none !important;
  transition: none !important;
  transform: none !important;
  scroll-behavior: auto !important;
}

/* NAVBAR & MENU */
.navbar,
.navbar *,
.dropdown-menu,
.dropdown-item,
.dropdown-item:hover,
.nav-link,
.nav-link:hover {
  animation: none !important;
  transition: none !important;
  transform: none !important;
}

.dropdown-item:hover {
  padding-left: 12px !important;
  background: #f8fafc !important;
}

/* CARD */
.page-header,
.search-filter-card,
.table-card,
.form-card,
.section-card,
.auto-card,
.monitor-stat-card,
.stat-card-mini {
  animation: none !important;
  transition: none !important;
  transform: none !important;
}

/* TABLE */
.table,
.table *,
.table-responsive,
.dataTables_wrapper,
.dataTables_scroll,
.dataTables_scrollBody {
  animation: none !important;
  transition: none !important;
  transform: none !important;
  scroll-behavior: auto !important;
}

.table tbody tr:hover {
  transform: none !important;
  box-shadow: none !important;
}

/* BUTTON */
.btn,
.btn:hover,
.btn-add,
.btn-add:hover,
.btn-save,
.btn-save:hover,
.btn-aksi,
.btn-aksi:hover {
  animation: none !important;
  transition: none !important;
  transform: none !important;
}

/* FILTER */
.filter-header,
.filter-body,
.filter-info,
.filter-badge,
.search-filter-card {
  animation: none !important;
  transition: none !important;
  transform: none !important;
}

/* DATATABLE */
.dataTables_wrapper *,
.dataTables_paginate *,
.dataTables_filter *,
.dataTables_length * {
  animation: none !important;
  transition: none !important;
  transform: none !important;
}

/* HAPUS ANIMASI MASUK HALAMAN */
.animate-fadeInUp,
.animate-scaleIn,
.animate-pulse,
.main-content {
  animation: none !important;
  transform: none !important;
}

/* FIX SCROLL */
.table-responsive {
  -webkit-overflow-scrolling: auto !important;
}
.table-responsive {
  width: 100%;
  overflow-x: auto !important;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
}

.table {
  width: 100% !important;
  table-layout: fixed !important;
  font-size: 12px !important;
}

.table th,
.table td {
  padding: 8px 10px !important;
  vertical-align: middle !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

/* Kolom panjang boleh turun baris */
#tabelRumah td:nth-child(4),
#tabelBiodata td:nth-child(5),
#tabelBiodata td:nth-child(22),
#tabelBiodata td:nth-child(33) {
  white-space: normal !important;
  word-break: break-word !important;
}

/* Data Rumah - kolom lebih proporsional */
#tabelRumah th:nth-child(1),
#tabelRumah td:nth-child(1) {
  width: 45px;
}

#tabelRumah th:nth-child(2),
#tabelRumah td:nth-child(2) {
  width: 85px;
}

#tabelRumah th:nth-child(3),
#tabelRumah td:nth-child(3) {
  width: 120px;
}

#tabelRumah th:nth-child(4),
#tabelRumah td:nth-child(4) {
  width: 220px;
}

#tabelRumah th:nth-child(5),
#tabelRumah td:nth-child(5),
#tabelRumah th:nth-child(6),
#tabelRumah td:nth-child(6) {
  width: 55px;
}

#tabelRumah th:last-child,
#tabelRumah td:last-child {
  width: 110px;
}

/* Data Penduduk - kolom lebih kecil */
#tabelBiodata th,
#tabelBiodata td {
  font-size: 11.5px !important;
}

#tabelBiodata th:nth-child(1),
#tabelBiodata td:nth-child(1) {
  width: 42px;
}

#tabelBiodata th:nth-child(2),
#tabelBiodata td:nth-child(2) {
  width: 75px;
}

#tabelBiodata th:nth-child(3),
#tabelBiodata td:nth-child(3) {
  width: 120px;
}

#tabelBiodata th:nth-child(4),
#tabelBiodata td:nth-child(4) {
  width: 135px;
}

#tabelBiodata th:nth-child(5),
#tabelBiodata td:nth-child(5) {
  width: 160px;
}

#tabelBiodata th:nth-child(6),
#tabelBiodata td:nth-child(6) {
  width: 70px;
}

#tabelBiodata th:nth-child(8),
#tabelBiodata td:nth-child(8) {
  width: 100px;
}

#tabelBiodata th:nth-child(9),
#tabelBiodata td:nth-child(9) {
  width: 95px;
}

#tabelBiodata th:nth-child(10),
#tabelBiodata td:nth-child(10) {
  width: 95px;
}

#tabelBiodata th:nth-child(11),
#tabelBiodata td:nth-child(11) {
  width: 105px;
}

#tabelBiodata th:nth-child(22),
#tabelBiodata td:nth-child(22) {
  width: 210px;
}

/* Mobile responsive */
@media (max-width: 768px) {
  .main-content,
  .form-container {
    padding: 12px !important;
    max-width: 100% !important;
  }

  .page-header,
  .search-filter-card,
  .table-card,
  .section-card,
  .form-card {
    border-radius: 14px !important;
  }

  .page-header {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 10px;
  }

  .stats-grid,
  .monitor-stats,
  .auto-grid,
  .form-grid-2,
  .form-grid-3 {
    grid-template-columns: 1fr !important;
  }

  .table {
    min-width: 1100px !important;
  }

  #tabelBiodata {
    min-width: 2600px !important;
  }

  #tabelRumah {
    min-width: 1200px !important;
  }

  .btn,
  .btn-add,
  .btn-save,
  .btn-filter,
  .btn-reset {
    width: auto !important;
    max-width: 100%;
  }

  .navbar-collapse {
    max-height: 80vh;
    overflow-y: auto;
  }
}
#tabelBiodata {
  table-layout: fixed !important;
}

/* Pendidikan */
#tabelBiodata th:nth-child(10),
#tabelBiodata td:nth-child(10) {
  width: 95px !important;
  max-width: 95px !important;
}

/* Golongan darah */
#tabelBiodata th:nth-child(17),
#tabelBiodata td:nth-child(17) {
  width: 65px !important;
  max-width: 65px !important;
  text-align: center;
}

/* Status kawin */
#tabelBiodata th:nth-child(12),
#tabelBiodata td:nth-child(12) {
  width: 90px !important;
  max-width: 90px !important;
}

/* Hubungan keluarga */
#tabelBiodata th:nth-child(15),
#tabelBiodata td:nth-child(15) {
  width: 105px !important;
  max-width: 105px !important;
}

/* No Paspor */
#tabelBiodata th:nth-child(27),
#tabelBiodata td:nth-child(27) {
  width: 110px !important;
  max-width: 110px !important;
}

/* No KITAP */
#tabelBiodata th:nth-child(28),
#tabelBiodata td:nth-child(28) {
  width: 110px !important;
  max-width: 110px !important;
}

/* Nama Ayah */
#tabelBiodata th:nth-child(31),
#tabelBiodata td:nth-child(31) {
  width: 130px !important;
  max-width: 130px !important;
}

/* Nama Ibu */
#tabelBiodata th:nth-child(32),
#tabelBiodata td:nth-child(32) {
  width: 130px !important;
  max-width: 130px !important;
}

/* RT */
#tabelBiodata th:nth-child(34),
#tabelBiodata td:nth-child(34) {
  width: 50px !important;
  max-width: 50px !important;
  text-align: center;
}

/* RW */
#tabelBiodata th:nth-child(35),
#tabelBiodata td:nth-child(35) {
  width: 50px !important;
  max-width: 50px !important;
  text-align: center;
}

/* Semua teks panjang dibuat rapi */
#tabelBiodata td {
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

/* Hover tetap normal */
#tabelBiodata tbody tr:hover {
  background: #f8fafc !important;
}
@media (max-width: 768px) {
  .navbar {
    padding: 10px 14px !important;
  }

  .navbar .container-fluid {
    display: grid !important;
    grid-template-columns: 1fr auto !important;
    grid-template-areas:
      "brand menu"
      "user menu";
    align-items: center !important;
    gap: 2px 10px !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .navbar-brand {
    grid-area: brand !important;
    margin: 0 !important;
    padding: 0 !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    white-space: nowrap !important;
  }

  .navbar-toggler {
    display: none !important;
  }

  .navbar-collapse {
    grid-area: menu !important;
    display: block !important;
    width: auto !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  .navbar-nav {
    display: contents !important;
  }

  .navbar-nav .dropdown {
    grid-area: menu !important;
    justify-self: end !important;
    margin: 0 !important;
  }

  .navbar-nav .dropdown > .nav-link {
    background: rgba(255, 255, 255, 0.16) !important;
    border: 1px solid rgba(255, 255, 255, 0.18) !important;
    border-radius: 999px !important;
    padding: 6px 12px !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    color: #ffffff !important;
    white-space: nowrap !important;
  }

  .navbar-nav .dropdown > .nav-link::after {
    display: none !important;
  }

  .nav-user-info {
    grid-area: user !important;
    margin-left: 0 !important;
    margin-top: 2px !important;
    width: 100% !important;
  }

  .nav-user-info .nav-link {
    padding: 0 !important;
    font-size: 12px !important;
    line-height: 1.2 !important;
    color: rgba(255, 255, 255, 0.85) !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    white-space: nowrap !important;
  }

  .nav-user-info .role-badge-admin,
  .nav-user-info .role-badge-rt,
  .nav-user-info .role-badge-warga {
    font-size: 10px !important;
    padding: 2px 7px !important;
  }

  .dropdown-menu.dropdown-menu-right {
    position: absolute !important;
    top: 100% !important;
    right: 0 !important;
    left: auto !important;
    margin-top: 8px !important;
    min-width: 205px !important;
    width: 205px !important;
    border-radius: 12px !important;
    z-index: 9999 !important;
  }
}
/* NAVBAR FINAL - DESKTOP NORMAL, MOBILE RAPI */
.navbar-final{
    background: linear-gradient(135deg, #1e293b, #0f172a) !important;
    padding: 10px 18px !important;
}

.navbar-final-wrap{
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    width: 100% !important;
}

.navbar-left-final{
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
}

.navbar-title-final{
    color: #ffffff !important;
    font-size: 1.1rem !important;
    font-weight: 700 !important;
    margin: 0 !important;
    padding: 0 !important;
}

.navbar-title-final i{
    margin-right: 6px !important;
}

.navbar-user-final{
    color: rgba(255,255,255,.85) !important;
    font-size: 13px !important;
    display: flex !important;
    align-items: center !important;
    gap: 5px !important;
}

.navbar-menu-btn-final{
    background: rgba(255,255,255,.14) !important;
    color: #ffffff !important;
    border-radius: 999px !important;
    padding: 7px 16px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
}

.navbar-menu-btn-final:hover,
.navbar-menu-btn-final:focus{
    background: rgba(255,255,255,.22) !important;
    color: #ffffff !important;
}

.navbar-menu-final .dropdown-menu{
    right: 0 !important;
    left: auto !important;
    border-radius: 12px !important;
    padding: 8px !important;
    min-width: 210px !important;
}

/* MOBILE */
@media(max-width:768px){
    .navbar-final{
        padding: 11px 14px !important;
    }

    .navbar-final-wrap{
        display: grid !important;
        grid-template-columns: 1fr auto !important;
        grid-template-areas:
            "title menu"
            "user menu" !important;
        align-items: center !important;
        gap: 3px 10px !important;
    }

    .navbar-left-final{
        display: contents !important;
    }

    .navbar-title-final{
        grid-area: title !important;
        font-size: 15px !important;
        line-height: 1.2 !important;
        white-space: nowrap !important;
    }

    .navbar-user-final{
        grid-area: user !important;
        font-size: 12px !important;
        line-height: 1.2 !important;
        white-space: nowrap !important;
    }

    .navbar-menu-final{
        grid-area: menu !important;
        justify-self: end !important;
    }

    .navbar-menu-btn-final{
        padding: 6px 12px !important;
        font-size: 12px !important;
        border-radius: 999px !important;
    }

    .navbar-menu-btn-final::after{
        display: none !important;
    }

    .navbar-menu-final .dropdown-menu{
        position: absolute !important;
        top: 100% !important;
        right: 0 !important;
        left: auto !important;
        margin-top: 8px !important;
        width: 205px !important;
        min-width: 205px !important;
    }
}
