/* ==============================================================
   BACKGROUND GLOBAL APLIKASI (GRADIEN BERGERAK)
============================================================== */

body { 
    font-size: 0.90rem; 
    background-image: linear-gradient(-45deg, #ff7eb3, #8a2387, #23a6d5, #23d5ab, #ff7eb3) !important; 
    background-size: 400% 400% !important; 
    animation: gBG 15s ease infinite !important;
    background-attachment: fixed !important; 
    min-height: 100vh;

    /* 👇 TAMBAHKAN 2 BARIS INI 👇 */
    display: flex !important;
    flex-direction: column !important;
    min-height: 100vh !important;
    margin: 0;
    padding: 0;
}

@keyframes gBG { 
    0% { background-position: 0% 50%; } 
    50% { background-position: 100% 50%; } 
    100% { background-position: 0% 50%; }
}


/* Menghilangkan celah atas dan memastikan background full */
.bg-landing, #viewLogin {
    flex: 1 0 auto;
    width: 100%;
    min-height: 100vh;
    margin-top: -20px !important; /* Sesuaikan dengan padding body */
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

/* Khusus Mobile agar tidak tertutup menu bawah */
@media (max-width: 768px) {
    .bg-landing, #viewLogin {
        margin-top: -58px !important;
    }
    .custom-footer {
        margin-bottom: 70px !important; /* Ruang untuk navbar HP */
    }
}

.hidden { display: none !important; }
tr.clickable td:not(.no-click) { cursor: pointer; }
tr.clickable:hover td:not(.no-click) { background-color: #e9ecef; }
.readonly-field { background-color: #e9ecef; font-weight: bold; cursor: not-allowed;}
.box-amprah { border: 1px solid #ddd; border-radius: 8px; padding: 15px; background: #fff; margin-bottom: 10px; }
.table-tpp th { font-size: 0.85rem; text-align: center; vertical-align: middle; }
.table-tpp td { font-size: 0.85rem; text-align: right; }
.flex-row-center { display: flex; justify-content: space-between; align-items: center; margin-bottom: 6px; }
.input-absen { width: 55px; text-align: center; font-weight: bold; margin: auto; }
.bg-soft-blue { background-color: #e3f2fd !important; }

/* Tombol Gradien Elegan untuk Landing Page */
.btn-masuk-landing {
  background: linear-gradient(135deg, #11998e 0%, #38ef7d 100%);
  color: white !important;
  border: none;
  transition: 0.3s ease-in-out;
}
.btn-masuk-landing:hover {
  background: linear-gradient(135deg, #0f8a80 0%, #32d670 100%);
  transform: scale(1.02);
}

/* Memastikan container aplikasi tetap bersih di atas background yang ramai */
#appContainer {
    background-color: rgba(255, 255, 255, 0.95) !important;
    backdrop-filter: blur(10px); /* Efek kaca buram agar lebih modern */
    border-radius: 10px;
    margin-top: 20px;
    margin-bottom: 5px;
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.3) !important;
}

@media print {
  body * { visibility: hidden; }
  #printArea, #printArea * { visibility: visible; }
  #printArea { position: absolute; left: 0; top: 0; width: 100%; }
  .no-print { display: none !important; }
  .table-bordered th, .table-bordered td { border: 1px solid black !important; }
}

.pdf-mode button, .pdf-mode .nav-pills { display: none !important; }
.pdf-mode .table-responsive { overflow: visible !important; }
.pdf-mode { height: auto !important; overflow: visible !important; padding-bottom: 20px; }

@keyframes floatAnim { 0% { transform: translateY(0px); } 50% { transform: translateY(-12px); } 100% { transform: translateY(0px); } }
.floating-logo { animation: floatAnim 3s ease-in-out infinite; filter: drop-shadow(0px 8px 6px rgba(0,0,0,0.2)); }
.floating-btn { animation: floatAnim 2.5s ease-in-out infinite; }

.glass-card { background: rgba(255, 255, 255, 0.85) !important; backdrop-filter: blur(15px); -webkit-backdrop-filter: blur(15px); border-radius: 24px; border: 1px solid rgba(255, 255, 255, 0.5); box-shadow: 0 8px 32px 0 rgba(31, 38, 135, 0.2) !important; }

.bg-landing {
    background-image: url('https://upload.wikimedia.org/wikipedia/commons/7/7c/Kantor-gubernur-2.jpg');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    
    flex-grow: 1; 
    width: 100%;
    /* 🔥 HAPUS min-height: 100vh; dari sini agar footer naik ke atas layar 🔥 */
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1040; 
}

#viewLogin {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding-top: 0 !important; 
}


.mobile-header { position: fixed; top: 0; left: 0; right: 0; background: rgba(255, 255, 255, 0.95); backdrop-filter: blur(10px); box-shadow: 0 2px 10px rgba(0,0,0,0.05); z-index: 1030; padding: 10px 15px; display: none; align-items: center; justify-content: space-between; }
.m-header-left { display: flex; align-items: center; gap: 10px; }
.m-header-logo { width: 38px; height: 38px; border-radius: 50%; object-fit: contain; }
.m-header-title { font-weight: 800; font-size: 1.1rem; color: #198754; margin: 0; line-height: 1; }
.m-header-subtitle { font-size: 0.75rem; color: #6c757d; margin: 0; font-weight: bold; }
.m-header-right { display: flex; gap: 15px; align-items: center; }
.m-header-icon { color: #495057; font-size: 1.3rem; cursor: pointer; transition: 0.2s; }
.m-header-icon:hover { color: #198754; }

.mobile-bottom-nav { position: fixed; bottom: 0; left: 0; right: 0; background: #ffffff; box-shadow: 0 -2px 15px rgba(0,0,0,0.08); z-index: 1030; display: none; justify-content: space-around; align-items: center; padding: 5px 0; height: 65px; border-radius: 20px 20px 0 0; }
.m-nav-item { display: flex; flex-direction: column; align-items: center; justify-content: center; color: #adb5bd; text-decoration: none; font-size: 0.65rem; width: 20%; font-weight: bold; transition: 0.3s; }
.m-nav-item i { font-size: 1.4rem; margin-bottom: 2px; }
.m-nav-item.active { color: #198754; }
.m-nav-item.active i { transform: translateY(-3px); }
.m-nav-center { position: relative; top: -20px; width: 60px; height: 60px; background: linear-gradient(135deg, #198754, #20c997); border-radius: 50%; display: flex; flex-direction: column; justify-content: center; align-items: center; color: white !important; box-shadow: 0 6px 15px rgba(25, 135, 84, 0.4); border: 5px solid #f4f6f9; }
.m-nav-center i { font-size: 1.8rem; margin: 0; }
.m-nav-center.disabled { background: #6c757d !important; box-shadow: none; opacity: 0.6; }

.scroll-to-top { position: fixed; bottom: 85px; right: 15px; width: 45px; height: 45px; background: rgba(13, 110, 253, 0.8); color: white; border-radius: 50%; display: none; justify-content: center; align-items: center; font-size: 1.5rem; z-index: 1020; cursor: pointer; box-shadow: 0 4px 10px rgba(0,0,0,0.2); transition: 0.3s; border: 2px solid white; }

/* Tombol Gradien Cetak Laporan (Ungu - Abu Gelap) */
.btn-cetak-gradien {
  background: linear-gradient(135deg, #6a11cb 0%, #4a4a4a 50%, #212529 100%);
  color: white !important;
  border: none;
  transition: all 0.3s ease;
}
.btn-cetak-gradien:hover {
  background: linear-gradient(135deg, #5b0eb0 0%, #3b3b3b 50%, #111417 100%);
  transform: translateY(-2px);
  box-shadow: 0 4px 10px rgba(0,0,0,0.3) !important;
}

@media (max-width: 768px) {
/* 🔥 Hapus position: fixed dan height: 100vh di sini 🔥 */
  .bg-landing, body.bg-gradient-login { 
      width: 100% !important; 
      flex-grow: 1;
  }
  #viewLanding h1 { font-size: 2.2rem !important; }
  #viewLanding > div { margin-top: -12vh !important; }
  #viewLogin > div { width: 90%; margin-top: -15vh !important; }
  .p-4.no-print { padding: 0 !important; }
  #viewPilihBulan { margin-top: 0 !important; }
  #viewPilihBulan .card { border-radius: 0 !important; border-left: none !important; border-right: none !important; box-shadow: none !important; }
  #viewPilihBulan .card-header { border-radius: 0 !important; padding: 10px !important; }
  #viewPilihBulan .card-body { padding: 10px !important; }
  #containerTombolPeriode { margin-bottom: 5px !important; }
  #viewPilihBulan .row.g-4 { gap: 0 !important; margin: 0 !important; }
  #viewPilihBulan .col-lg-8, #viewPilihBulan .col-lg-4 { padding: 0 !important; }
  .btn-periode-select { font-size: 0.70rem !important; padding: 6px 2px !important; }
  .box-aksi-periode { flex-direction: row !important; }
  .box-aksi-periode button { font-size: 0.70rem !important; padding: 8px 4px !important; width: 50% !important; margin-bottom: 0 !important; }
  #viewDaftarPegawai .alert-primary { font-size: 0.85rem !important; padding: 10px !important; margin-bottom: 10px !important; }
  #viewDaftarPegawai .alert-primary span.text-dark { font-size: 0.75rem !important; display: block; margin-top: 3px; }
  #warningLock { display: none !important; }
  #viewPilihBulan .card-body.text-center { padding: 15px 10px !important; }
  #displayBulanAktif { font-size: 1.1rem !important; margin-bottom: 10px !important; padding: 5px !important; }
  #btnPilihPNS, #btnPilihPPPK { font-size: 0.85rem !important; padding: 6px !important; }
  .btn-masuk-tpp { font-size: 0.95rem !important; padding: 12px !important; margin-top: 10px !important; }
 
  #mainNav { display: none !important; } 
  .mobile-header, .mobile-bottom-nav { display: flex; } 
  /* Rapatkan Kotak Aplikasi dengan Header HP */
  #appContainer { 
      min-height: calc(100vh - 140px); 
      margin-top: 0 !important; /* Hilangkan jarak atas */
      border-radius: 0 !important; /* Buat sudut menyatu tegak lurus dengan header */
      box-shadow: none !important; 
  }
  
  /* Hilangkan celah bawaan dari Lobby */
  #viewLobbySuperAdmin {
      margin-top: 0 !important; 
      padding-top: 15px; /* Ganti margin (bolong) dengan padding (berisi putih) */
  }
  
  .app-padding { 
      padding-top: 58px !important; /* Sesuaikan pas dengan tinggi header HP */
  }
  #tabelBodyPegawai td:nth-child(2), #tabelBodyPegawai td:nth-child(4) { min-width: 120px; max-width: 140px; white-space: normal !important; }
  #tabelBodyPegawai td:nth-child(2) b, #tabelBodyPegawai td:nth-child(4) { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis; word-break: break-word; }
  #tabelBodyPegawai td:nth-child(7) { white-space: nowrap !important;  }
  #viewManajemenASN .nav-pills { display: grid !important; grid-template-columns: 1fr 1fr; gap: 10px; padding-bottom: 10px; }
  #viewManajemenASN .nav-pills .nav-item { width: 100%; height: 100%; margin: 0 !important; display: flex; }
  #viewManajemenASN .nav-pills .nav-link { width: 100%; height: 100%; min-height: 60px; display: flex; align-items: center; justify-content: center; text-align: center; font-size: 0.75rem; padding: 5px !important; white-space: normal; line-height: 1.3; }
  .box-jml-bersih { flex-direction: column !important; align-items: stretch !important; text-align: center; padding: 15px !important; }
  .box-jml-bersih h4 { font-size: 0.95rem !important; margin-bottom: 10px !important; }
  .box-jml-bersih input { width: 100% !important; text-align: center !important; font-size: 1.5rem !important; }
  .action-left, .action-right { display: grid !important; grid-template-columns: 1fr 1fr; gap: 8px; width: 100%; }
  .action-left button, .action-right .btn-group, .action-right .btn-group button { width: 100% !important; margin: 0 !important; }
  .action-right .dropdown-menu { width: 100%; text-align: center; }


  /* Merapatkan Footer di HP */
  .custom-footer {
    margin-top: 0 !important;       /* Mepet dengan tabel/konten di atasnya */
    margin-bottom: 70px !important; /* Pas tepat di atas menu navigasi bawah HP */
    padding: 5px 0 !important;      /* Kurangi ruang kosong di sekitar teks */
  }
  
  .custom-footer p {
    font-size: 0.65rem !important; /* Perkecil teks di HP */
  }


  /* Merampingkan Kop OPD di Halaman Home (HP) */
  #boxKopHome {
    background-color: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin-bottom: 5px !important;
  }
  
  /* Sembunyikan kedua logo di HP */
  #logoInstansiHome, #logoOpdHome {
    display: none !important;
  }
  
  /* Hilangkan garis vertikal pembatas teks */
  #boxKopHome .border-start, 
  #boxKopHome .border-end {
    border: none !important;
    padding: 0 !important;
  }
  
  /* Sesuaikan ukuran teks agar seimbang dan rapi */
  #namaInstansiHome {
    font-size: 0.85rem !important;
    margin-bottom: 2px !important;
  }
  #namaOpdHome {
    font-size: 0.85rem !important; /* Ukuran disamakan dengan Instansi */
    margin-top: 0 !important;
  }

  /* ========================================================= */
  /* FIX UI: TABEL MASTER TPP (PERGUB) KHUSUS HP               */
  /* ========================================================= */

  /* 1. KUNCI KOLOM NAMA JABATAN (FROZEN/STICKY COLUMN) */
  #tabLobbyMasterTPP .table-responsive {
      overflow-x: auto !important;
      -webkit-overflow-scrolling: touch; 
      border-left: none !important;
  }
  
  /* Paksa kolom lain untuk memanjang lurus ke kanan */
  #tabLobbyMasterTPP table th, 
  #tabLobbyMasterTPP table td {
      white-space: nowrap !important;
      vertical-align: middle !important;
  }

  /* Kunci Header (Judul Kolom) Nama Jabatan */
  #tabLobbyMasterTPP table th:nth-child(1) {
      position: sticky !important;
      left: 0 !important;
      background-color: #212529 !important; /* Warna gelap header */
      z-index: 3 !important;
  }

  /* Kunci Isi Kolom Nama Jabatan & Buat Maksimal 2 Baris */
  #tabLobbyMasterTPP table td:nth-child(1) {
      position: sticky !important;
      left: 0 !important;
      background-color: #ffffff !important; 
      z-index: 2 !important;
      border-right: 2px solid #dee2e6 !important; 
      
      min-width: 140px !important;
      max-width: 150px !important;
      
      font-size: 0.75rem !important; /* Perkecil hurufnya */
      white-space: normal !important; /* Izinkan teks turun ke bawah */
      display: -webkit-box !important;
      -webkit-line-clamp: 2 !important; /* Batasi maksimal 2 baris */
      -webkit-box-orient: vertical !important;
      overflow: hidden !important;
      text-overflow: ellipsis !important;
  }

  /* 2. TOMBOL AKSI DI DALAM TABEL SEBARIS KE KANAN */
  #tabLobbyMasterTPP table td:last-child {
      display: flex !important;
      flex-direction: row !important;
      gap: 5px !important;
      justify-content: center !important;
      min-width: 80px !important;
  }
  #tabLobbyMasterTPP table td:last-child button {
      margin: 0 !important;
      font-size: 0.65rem !important; 
      padding: 4px 8px !important;
  }

  /* 3. TOMBOL ATAS (Import, Tambah, Hapus Semua) SEBARIS */
  #tabLobbyMasterTPP .text-md-end {
      display: flex !important;
      flex-direction: row !important;
      flex-wrap: nowrap !important;
      justify-content: space-between !important;
      gap: 5px !important;
      width: 100% !important;
      overflow-x: auto !important; 
  }
  
  #tabLobbyMasterTPP .text-md-end button {
      flex: 1 !important; 
      font-size: 0.65rem !important; 
      padding: 8px 2px !important;
      white-space: nowrap !important;
      margin: 0 !important;
  }
  
  #tabLobbyMasterTPP .text-md-end button i {
      font-size: 0.75rem !important; 
  }


  /* ========================================================= */
  /* FIX UI: HALAMAN DATA PEGAWAI KHUSUS HP                    */
  /* ========================================================= */

  /* 1. KUNCI KOLOM NIP (FROZEN/STICKY COLUMN) */
  #viewDaftarPegawai .table-responsive {
      overflow-x: auto !important;
      -webkit-overflow-scrolling: touch;
      border-left: none !important;
  }
  
  #viewDaftarPegawai table th {
      white-space: nowrap !important;
  }

  /* Kunci Header (Judul Kolom NIP) */
  #viewDaftarPegawai table th:nth-child(1) {
      position: sticky !important;
      left: 0 !important;
      background-color: #212529 !important; /* Warna gelap header */
      z-index: 3 !important;
  }

  /* Kunci Isi Kolom NIP */
  #viewDaftarPegawai table td:nth-child(1) {
      position: sticky !important;
      left: 0 !important;
      background-color: #ffffff !important; 
      z-index: 2 !important;
      border-right: 2px solid #dee2e6 !important; 
      font-weight: bold;
      white-space: nowrap !important;
  }

  /* 2. FIX CELAH KOSONG DI ATAS HALAMAN PEGAWAI */
  /* Membunuh jarak dorong (mt-3) bawaan HTML yang bikin background mengintip */
  #viewDaftarPegawai > .mt-3 {
      margin-top: 0 !important;
      padding-top: 15px !important;
  }

  /* 3. TOMBOL HALAMAN (PAGINATION) SEBARIS */
  #viewDaftarPegawai .mt-2.d-flex.justify-content-between {
      flex-direction: row !important;
      flex-wrap: nowrap !important; /* Paksa jangan turun baris */
      align-items: center !important;
      gap: 10px !important;
  }
  
  /* Kecilkan teks info "Menampilkan 1-15..." agar tombol tidak terdorong */
  #infoPagination {
      font-size: 0.65rem !important;
      line-height: 1.2 !important;
      white-space: normal !important; /* Teks infonya boleh jadi 2 baris ke bawah */
      min-width: 80px !important;
  }
  
  /* Paksa kumpulan tombol pagination menyusut dan berjejer */
  #btnPagination {
      display: flex !important;
      flex-wrap: nowrap !important;
  }
  
  /* Kecilkan ukuran tombol pagination */
  #btnPagination .btn {
      font-size: 0.65rem !important;
      padding: 4px 8px !important;
  }


  /* ========================================================= */
  /* FIX UI: HALAMAN KELOLA AKUN KHUSUS HP                     */
  /* ========================================================= */

  /* 1. KUNCI KOLOM USERNAME (FROZEN/STICKY COLUMN) */
  #viewManajemenAkun .table-responsive {
      overflow-x: auto !important;
      -webkit-overflow-scrolling: touch;
      border-left: none !important;
  }

  /* Paksa semua kolom memanjang lurus ke kanan */
  #viewManajemenAkun table th,
  #viewManajemenAkun table td {
      white-space: nowrap !important;
      vertical-align: middle !important;
  }

  /* Kunci Header (Judul Kolom Username) */
  #viewManajemenAkun table th:nth-child(1) {
      position: sticky !important;
      left: 0 !important;
      background-color: #212529 !important; /* Warna gelap header */
      z-index: 3 !important;
  }

  /* Kunci Isi Kolom Username */
  #viewManajemenAkun table td:nth-child(1) {
      position: sticky !important;
      left: 0 !important;
      background-color: #ffffff !important; 
      z-index: 2 !important;
      border-right: 2px solid #dee2e6 !important; 
      font-weight: bold;
  }

  /* 2. TOMBOL ATAS (Kembali, Import, Tambah) SEBARIS */
  #viewManajemenAkun .d-flex.flex-column > div:nth-child(2) {
      display: flex !important;
      flex-direction: row !important;
      flex-wrap: nowrap !important;
      justify-content: space-between !important;
      gap: 5px !important;
      width: 100% !important;
      overflow-x: auto !important;
  }
  #viewManajemenAkun .d-flex.flex-column > div:nth-child(2) button {
      flex: 1 !important;
      font-size: 0.65rem !important;
      padding: 8px 4px !important;
      margin: 0 !important;
      white-space: nowrap !important;
  }

  /* 3. TOMBOL HALAMAN (PAGINATION) SEBARIS */
  #viewManajemenAkun .mt-2.pb-4 {
      flex-direction: row !important;
      flex-wrap: nowrap !important;
      align-items: center !important;
      gap: 10px !important;
  }
  
  #infoPaginationAkun {
      font-size: 0.65rem !important;
      line-height: 1.2 !important;
      white-space: normal !important;
      min-width: 80px !important;
  }
  
  #btnPaginationAkun {
      display: flex !important;
      flex-wrap: nowrap !important;
  }
  
  #btnPaginationAkun .btn {
      font-size: 0.65rem !important;
      padding: 4px 8px !important;
  }

/* ========================================================= */
  /* MESIN COATING MOBILE APPS: FULL BLEED EDGE & HEADER CENTER */
  /* ========================================================= */

  /* 1. Sembunyikan Tombol Floating Music & Panel di HP */
  #btnToggleMusic, #musicPanel {
      display: none !important;
  }

  /* 2. Bongkar Margin & Padding Kontainer Biar Biru-nya Full Layar Menyentuh Tepi Screen */
  #viewPilihBulan, #viewDashboardPegawai {
      padding-left: 0 !important;
      padding-right: 0 !important;
  }
  #viewPilihBulan .row:first-child, #viewDashboardPegawai .row:first-child {
      margin-left: 0 !important;
      margin-right: 0 !important;
  }
  #viewPilihBulan .col-12, #viewDashboardPegawai .col-12 {
      padding-left: 0 !important;
      padding-right: 0 !important;
  }
  
  /* Hilangkan lengkungan bulat (telur) dan bayangan agar kotak menyatu rata dengan frame HP */
  #viewPilihBulan .shadow.rounded-4, #viewDashboardPegawai .shadow.rounded-4 {
      border-radius: 0 !important; 
      box-shadow: none !important;
  }

  /* 3. Eliminasi Logo Lingkaran Besarnya & Garis Pembatas Samping */
  #viewPilihBulan .bg-white.rounded-circle, #viewDashboardPegawai .bg-white.rounded-circle {
      display: none !important;
  }
  #viewPilihBulan .border-end, #viewDashboardPegawai .border-end {
      border: none !important;
      padding-right: 0 !important;
      margin-bottom: 12px !important;
  }

  /* 4. Sentralisasi Text Hub: Paksa Semua Elemen Identitas Jatuh Tepat di Tengah */
  #viewPilihBulan .col-md-7, #viewDashboardPegawai .col-md-7 {
      display: flex !important;
      flex-direction: column !important;
      align-items: center !important;
      justify-content: center !important;
      text-align: center !important;
      width: 100% !important;
  }
  #viewPilihBulan .col-md-7 > div, #viewDashboardPegawai .col-md-7 > div {
      display: flex !important;
      flex-direction: column !important;
      align-items: center !important;
      text-align: center !important;
      width: 100% !important;
  }

  /* 5. Harmonisasi Skala Huruf Identitas */
  #viewPilihBulan #namaInstansiHome, #viewDashboardPegawai #namaInstansiPegawai {
      font-size: 0.7rem !important;
      margin-bottom: 3px !important;
      white-space: nowrap !important;
      overflow: hidden !important;
      text-overflow: ellipsis !important;
      text-align: center !important;
  }
  
  #viewPilihBulan #namaOpdHome, #viewDashboardPegawai #namaOpdPegawai {
      font-size: 1.1rem !important;
      margin-bottom: 6px !important;
      white-space: nowrap !important;
      overflow: hidden !important;
      text-overflow: ellipsis !important;
      text-align: center !important;
  }

  /* Pusatkan Posisi Kapsul Badge Role */
  #viewPilihBulan #badgeRoleKop, #viewDashboardPegawai .badge.bg-light {
      font-size: 0.7rem !important;
      padding: 5px 12px !important;
      display: inline-block !important;
      margin: 0 auto !important;
  }

  /* 6. Optimasi Sub-Panel Sapaan Bawah Agar Tetap Elegan & Tipis */
  #viewPilihBulan #kopIconWaktu, #viewDashboardPegawai #kopIconWaktuPegawai {
      font-size: 1.4rem !important;
      margin-right: 8px !important;
  }
  #viewPilihBulan #kopSapaanTeks, #viewDashboardPegawai #kopSapaanTeksPegawai {
      font-size: 0.95rem !important;
      margin-bottom: 2px !important;
  }
  #viewPilihBulan #kopSapaanTeks + p, #viewDashboardPegawai #kopSapaanTeksPegawai + p {
      font-size: 0.75rem !important;
      line-height: 1.2 !important;
  }
  
  /* 5. Terapkan juga untuk Dashboard Pegawai (Slip Gaji) */
  #viewDashboardPegawai .bg-white.rounded-circle { display: none !important; }
  #viewDashboardPegawai .border-end { border: none !important; padding-right: 0 !important; margin-bottom: 10px !important; }
  #viewDashboardPegawai #namaInstansiPegawai { font-size: 0.65rem !important; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  #viewDashboardPegawai #namaOpdPegawai { font-size: 1rem !important; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  #viewDashboardPegawai #kopIconWaktuPegawai { font-size: 1.5rem !important; margin-right: 10px !important; }
  #viewDashboardPegawai #kopSapaanTeksPegawai { font-size: 0.95rem !important; }
  #viewDashboardPegawai #kopSapaanTeksPegawai + p { font-size: 0.75rem !important; line-height: 1.2 !important; }
  
}

@media (min-width: 769px) {
  .app-padding { padding-top: 20px; }
  .action-left, .action-right { display: flex !important; width: auto !important; }
  .action-left button, .action-right .btn-group, .action-right .btn-group button { width: auto !important; flex: none !important; }
  #tabelBodyPegawai td:nth-child(2) b { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis; white-space: normal !important; max-width: 25ch; }
  .clamp-unit { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis; white-space: normal !important; max-width: 35ch;  }
  #tabelBodyPegawai td:nth-child(7) { white-space: nowrap !important; width: 1%; }
}

.autocomplete-wrapper { position: relative; display: block; width: 100%; }
.autocomplete-items { position: absolute; border: 1px solid #ced4da; border-bottom: none; border-top: none; z-index: 9999; top: 100%; left: 0; right: 0; max-height: 220px; overflow-y: auto; background-color: #fff; box-shadow: 0px 8px 16px rgba(0,0,0,0.15); border-radius: 0 0 8px 8px; }
.autocomplete-items div { padding: 10px 15px; cursor: pointer; background-color: #fff; border-bottom: 1px solid #ced4da; font-size: 0.85rem; line-height: 1.4; transition: 0.2s; }
.autocomplete-items div:hover { background-color: #e9ecef; color: #0d6efd; font-weight: bold; }
.tab-pane:not(.active) { display: none !important; }

.nav-pills-custom { display: flex; gap: 10px; width: 100%; }
.nav-pills-custom .nav-item { flex: 1; }
.btn-tab-custom { width: 100%; background-color: #f8f9fa; color: #6c757d !important; border: 2px solid rgba(106, 17, 203, 0.4);  border-radius: 12px !important; transition: all 0.3s ease-in-out; box-shadow: 0 2px 5px rgba(0,0,0,0.02); display: flex; align-items: center; justify-content: center; padding: 12px 10px !important; }
.btn-tab-custom:hover { background-color: #e2e6ea; color: #495057 !important; transform: translateY(-2px); }
.btn-tab-custom.active { background: linear-gradient(135deg, #6a11cb 0%, #2575fc 100%) !important; color: #ffffff !important; border: 2px solid transparent; box-shadow: 0 8px 20px rgba(37, 117, 252, 0.4) !important; transform: translateY(-3px); }

#navAbsen:not(.active) { background-color: #fff3cd !important; border: 2px solid #ffc107 !important; color: #856404 !important; box-shadow: 0 4px 10px rgba(255, 193, 7, 0.25) !important; }
#navAbsen:not(.active):hover { background-color: #ffeeba !important; transform: translateY(-2px); }
.btn-absen-fixed { min-width: 100px; display: inline-flex; align-items: center; justify-content: center; }
.icon-final { font-size: 0.85rem; }

/* ==============================================================
   FOOTER MENYESUAIKAN KOTAK HALAMAN (TIDAK FIXED DI LAPTOP)
============================================================== */
.custom-footer {
  position: relative !important; /* Melepas sifat fixed */
  max-width: 1320px; /* Sesuai dengan ukuran maksimal container bootstrap */
  margin: 10px auto 0 auto; /* Tengah secara otomatis */
  background-color: transparent !important; 
  padding: 15px 0;
  border-top: none;
  z-index: 1010;
}

/* ========================================================= */
/* MODERN CHIP BUTTONS UNTUK PERIODE BULAN */
/* ========================================================= */
.btn-periode-chip {
    background-color: #f8f9fa;
    color: #0d6efd;
    border: 1px solid #cfe2f3;
    border-radius: 25px !important;
    padding: 8px 18px !important;
    font-size: 0.75rem !important;
    font-weight: 700;
    transition: all 0.3s ease;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.btn-periode-chip:hover {
    background-color: #e6f2ff;
    transform: translateY(-2px);
    box-shadow: 0 4px 8px rgba(13, 110, 253, 0.2) !important;
}
.btn-periode-chip.active {
    background: linear-gradient(135deg, #0d6efd, #0a58ca);
    color: white !important;
    border-color: transparent;
    box-shadow: 0 4px 10px rgba(13, 110, 253, 0.4) !important;
}

.btn-locked-chip {
    background-color: #f1f3f5;
    color: #6c757d;
    border: 1px solid #dee2e6;
    border-radius: 25px !important;
    padding: 8px 18px !important;
    font-size: 0.75rem !important;
    font-weight: 700;
    transition: all 0.3s ease;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.btn-locked-chip:hover {
    background-color: #e9ecef;
    transform: translateY(-2px);
}
.btn-locked-chip.active {
    background: linear-gradient(135deg, #6c757d, #495057);
    color: white !important;
    border-color: transparent;
    box-shadow: 0 4px 10px rgba(108, 117, 125, 0.3) !important;
}

/* ========================================================= */
/* FIX: DOUBLE SCROLLBAR & OVERLAP PADA MODAL FULLSCREEN     */
/* ========================================================= */

/* Mengunci scroll halaman utama secara paksa saat modal terbuka */
body.modal-open {
  overflow: hidden !important;
}

/* Memastikan konten di dalam modal fullscreen tidak menabrak scrollbar */
.modal-fullscreen .modal-header {
  padding-right: 1.5rem !important;
}

/* Memberi jarak aman untuk tombol close di modal fullscreen */
.modal-fullscreen .btn-close {
  margin-right: 0.5rem !important;
}

.modal {
    overflow-y: auto !important;
    padding-right: 0 !important;
}

/* Memastikan konten di dalam modal tidak terpotong */
.modal-dialog {
    margin-bottom: 50px;
}

/* ========================================================= */
/* FIX UI: FOOTER MENGAPUNG & ANTI OVERLAP                   */
/* ========================================================= */

/* FIX TATA LETAK GLOBAL */
body { 
    font-size: 0.90rem; 
    background-image: linear-gradient(-45deg, #ff7eb3, #8a2387, #23a6d5, #23d5ab, #ff7eb3) !important; 
    background-size: 400% 400% !important; 
    animation: gBG 15s ease infinite !important;
    background-attachment: fixed !important; 
    
    /* Gunakan Flexbox untuk mendorong footer ke bawah */
    display: flex !important;
    flex-direction: column !important;
    min-height: 100vh !important; 
    margin: 0;
    padding: 0;
}

#appContainer {
    flex: 1 0 auto; /* Memaksa kontainer mengisi ruang kosong agar footer terdorong ke bawah */
    width: 100%;
    background-color: rgba(255, 255, 255, 0.95) !important;
    backdrop-filter: blur(10px);
    display: flex;
    flex-direction: column;
}



#devSignature {
    color: #0d6efd;
    font-weight: bold;
    font-size: 0.75rem;
    display: block !important;
}


/* ==============================================================
   CSS FOOTER & LAYOUT PRESISI (ANTI-SCROLL & NO-GAP)
============================================================== */

/* Reset Dasar untuk mematikan celah */
#appContainer {
    transition: margin 0.3s ease;
}

/* --- TAMPILAN LAPTOP (992px ke atas) --- */
@media (min-width: 992px) {
    /* 1. Paksa 1 Halaman Tanpa Scroll & Tanpa Jeda Atas */
    body:has(#viewLanding:not(.hidden)), 
    body:has(#viewLogin:not(.hidden)) {
        height: 100vh !important;
        overflow: hidden !important; /* Matikan Scroll */
        display: flex;
        flex-direction: column;
    }

   /* Hilangkan Jeda Atas agar gradient tidak mengintip */
    body:has(#viewLanding:not(.hidden)) #appContainer,
    body:has(#viewLogin:not(.hidden)) #appContainer {
        margin-top: 0 !important;
        border-radius: 0 !important;
        flex: 1 !important; /* Biarkan container menyesuaikan sisa ruang */
        height: auto !important; /* Hapus 100% agar footer tidak terdorong ke luar layar */
    }

    /* 2. Footer Tipis (Sekitar 1cm) & 3 Kolom Sebaris */
    #appFooterPermanen {
        height: 40px !important; /* Tinggi fix agar presisi 1cm */
        padding: 0 20px !important;
        display: flex;
        align-items: center;
        background: transparent !important;
        margin-top: auto !important;
    }

    .footer-grid {
        display: grid;
        grid-template-columns: 1fr 1fr 1fr; /* Bagi 3 kolom sama rata */
        width: 100%;
        align-items: center;
    }

    .f-item { font-size: 0.75rem; color: #212529; }
    .f-left { text-align: left; }
    
    /* Ukuran tengah diperbesar jadi 0.9rem */
    .f-center { text-align: center; font-weight: bold; font-size: 0.9rem !important; } 
    
    /* Ukuran kanan diperkecil jadi 0.65rem */
    .f-right { text-align: right; color: #0d6efd; font-weight: bold; font-size: 0.65rem !important; }
}

/* --- TAMPILAN HP (Dibawah 992px) --- */
@media (max-width: 991px) {
    /* MATIKAN PADDING BAWAAN AGAR TIDAK ADA JEDA KOSONG LEBAR */
    body { padding-bottom: 0 !important; }

    #appFooterPermanen {
        padding: 10px 0 !important;
        background: transparent !important;
    }

    .footer-grid {
        display: flex;
        flex-direction: column;
        gap: 2px;
        text-align: center;
    }

    .f-item { font-size: 0.7rem; }
    
    /* Ukuran tengah HP agak dibesarkan */
    .f-center { font-size: 0.8rem !important; } 
    
    /* Ukuran kanan HP dikecilkan */
    .f-right { font-size: 0.6rem !important; }
    
    body:has(#viewLogin.hidden) #appFooterPermanen {
        margin-bottom: 70px !important;
    }
}

/* ==============================================================
   FIX LAPTOP: MENCEGAH FOOTER TERDORONG KELUAR LAYAR SAAT LANDING
============================================================== */
@media (min-width: 992px) {
    /* Matikan min-height 100vh bawaan agar halaman mengalah memberi ruang untuk Footer */
    .bg-landing, #viewLogin {
        min-height: 0 !important;
        height: 100% !important;
    }
}

/* ========================================================= */
  /* EFEK STICKY FREEZE KHUSUS TABEL HP                        */
  /* ========================================================= */
  @media (max-width: 768px) {
      .freeze-col-hp {
          position: sticky !important;
          left: 0 !important;
          z-index: 2 !important;
          box-shadow: 2px 0 4px rgba(0,0,0,0.08) !important;
      }
  }

  /* ========================================================= */
/* PERBAIKAN TOMBOL PAGU TPP PNS & PPPK DI HP                */
/* ========================================================= */
@media (max-width: 768px) {
    #btnTppPNS, #btnTppPPPK {
        font-size: 0.85rem !important;
        padding: 8px 5px !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }
    
    /* Supaya ukuran ikon ikut menyesuaikan */
    #btnTppPNS i, #btnTppPPPK i {
        font-size: 0.9rem !important;
    }
}

/* ========================================================= */
  /* PERBAIKAN TAMPILAN PANEL DETAIL (MENU & GAJI) DI HP       */
  /* ========================================================= */
  @media (max-width: 768px) {
      /* 1. Mengubah 4 Tab Navigasi Menu Menjadi Grid 2x2 */
      #pills-tab {
          display: grid !important;
          grid-template-columns: 1fr 1fr !important;
          gap: 8px !important;
          margin-bottom: 15px !important;
      }
      #pills-tab .nav-item {
          width: 100% !important;
          margin: 0 !important;
      }
      #pills-tab .nav-link {
          font-size: 0.75rem !important;
          padding: 10px 5px !important;
          text-align: center !important;
          white-space: normal !important;
          line-height: 1.2 !important;
          height: 100% !important;
          display: flex !important;
          align-items: center !important;
          justify-content: center !important;
          border-radius: 6px !important;
      }
      #pills-tab .nav-link i {
          margin-right: 4px !important;
      }

      /* 2. Rincian Gaji & Potongan (Tumpuk Vertikal: Label di Atas, Input 1 Baris) */
      .box-amprah .flex-row-center {
          display: flex !important;
          flex-direction: column !important;
          align-items: flex-start !important;
          margin-bottom: 12px !important;
          width: 100% !important;
      }
      .box-amprah .flex-row-center span {
          font-size: 0.75rem !important; 
          font-weight: 600 !important;
          margin-bottom: 4px !important;
          color: #555 !important;
          width: 100% !important;
      }
      .box-amprah .flex-row-center input {
          width: 100% !important; /* Menimpa class w-50 bawaan */
          font-size: 0.85rem !important;
          padding: 8px 10px !important;
          background-color: #f8f9fa !important;
          text-align: right !important; /* Angka rata kanan agar rapi */
      }

      /* 3. Sorotan Khusus (Highlight) Untuk Total / Jumlah */
      
      /* Baris: Jumlah Keluarga */
      .box-amprah .flex-row-center.text-primary span {
          color: #0d6efd !important;
          font-weight: 800 !important;
          font-size: 0.8rem !important;
      }
      .box-amprah .flex-row-center.text-primary input {
          border: 1px solid #0d6efd !important;
          background-color: #e9f2ff !important;
          color: #0d6efd !important;
          font-weight: bold !important;
      }

      /* Baris: Gaji Kotor */
      .box-amprah .flex-row-center:has(#aJmlKotor) span {
          color: #198754 !important; 
          font-size: 0.85rem !important;
          font-weight: 900 !important;
      }
      #aJmlKotor {
          font-size: 1.1rem !important;
          font-weight: 900 !important;
          color: #fff !important;
          background-color: #198754 !important;
          border: 1px solid #146c43 !important;
      }

      /* Baris: Total Potongan */
      .box-amprah .flex-row-center:has(#aJmlPotongan) span {
          color: #dc3545 !important; 
          font-size: 0.85rem !important;
          font-weight: 900 !important;
      }
      #aJmlPotongan {
          font-size: 1.1rem !important;
          font-weight: 900 !important;
          color: #fff !important;
          background-color: #dc3545 !important;
          border: 1px solid #b02a37 !important;
      }

      /* Baris: Gaji Bersih Paling Bawah */
      .box-jml-bersih {
          flex-direction: column !important;
          align-items: flex-start !important;
          padding: 15px !important;
      }
      .box-jml-bersih h4 {
          font-size: 0.95rem !important;
          margin-bottom: 8px !important;
          width: 100% !important;
      }
      #aJmlBersih {
          width: 100% !important;
          font-size: 1.3rem !important;
          padding: 10px !important;
          text-align: right !important;
          border: 2px solid #198754 !important;
      }
  }