/* ══════════════════════════════════════════════════ */
/* 📱 MOBILE RESPONSIVE OVERRIDE                      */
/* ══════════════════════════════════════════════════ */

/* ── TABLET / LARGE PHONE (≤1024px) ── */
@media (max-width: 1024px) {
  .content-area { padding: 16px; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .stat-card { padding: 18px; }
  .stat-value { font-size: 26px; }
  .table-header { flex-direction: column; align-items: flex-start; gap: 12px; }
  .table-header .d-flex { width: 100%; flex-wrap: wrap; }
  .search-input { width: 100% !important; flex: 1; }
}

/* ── MOBILE (≤768px) ── */
@media (max-width: 768px) {
  /* Sidebar & Overlay */
  .sidebar {
    transform: translateX(-100%);
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 4px 0 24px rgba(0,0,0,0.2);
  }
  .sidebar.show { transform: translateX(0); }
  .sidebar-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.5);
    backdrop-filter: blur(2px);
    z-index: 99;
  }
  .sidebar-overlay.show { display: block; }

  /* Main Layout */
  .main-content { margin-left: 0 !important; }
  .content-area { padding: 12px; }

  /* Navbar */
  .navbar { padding: 10px 14px; gap: 10px; }
  .navbar-left { flex: 1; min-width: 0; }
  .page-title {
    font-size: 16px !important;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 140px;
  }
  .navbar-right { gap: 6px; }
  .user-info { display: none; }
  .user-menu { padding: 4px 6px; }
  .user-avatar { width: 34px; height: 34px; font-size: 13px; }

  /* Stats Cards */
  .stats-grid { grid-template-columns: 1fr; gap: 10px; }
  .stat-card { padding: 16px; }
  .stat-header { flex-direction: column; align-items: flex-start; gap: 8px; }
  .stat-icon { display: none; }
  .stat-value { font-size: 22px; }
  .stat-label { font-size: 12px; }

  /* Tables: Horizontal Scroll */
  .table-container {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border-radius: 12px;
    margin: 0 -12px;
    padding: 0 12px;
  }
  .data-table { min-width: 680px; }
  .data-table th, .data-table td { padding: 10px 12px; font-size: 13px; }

  /* Pagination */
  .pagination-custom {
    flex-direction: column;
    gap: 10px;
    padding: 12px 0;
  }
  .pagination-info { font-size: 12px; text-align: center; }
  .pagination-buttons { justify-content: center; }

  /* Forms & Inputs */
  .form-group { margin-bottom: 14px; }
  .form-control-custom, .select-custom {
    font-size: 16px !important; /* Prevents iOS auto-zoom */
    padding: 12px 14px;
  }
  .btn-primary-custom, .btn-secondary-custom, .btn-success-custom, .btn-danger-custom, .btn-warning-custom, .btn-info-custom {
    /* width: 100%; */
    padding: 12px;
    font-size: 14px;
    margin-bottom: 8px;
  }
  .btn-primary-custom + .btn-secondary-custom { margin-bottom: 0; }
  .file-upload-area { padding: 16px; }
  .file-upload-area p { font-size: 12px; }

  /* Modals */
  .modal-content {
    max-width: 96vw;
    margin: 12px;
    border-radius: 14px;
    max-height: 85vh;
  }
  .modal-header, .modal-body, .modal-footer { padding: 16px; }
  .modal-title { font-size: 16px !important; }

  /* Notification Dropdown */
  .notification-dropdown {
    width: calc(100vw - 24px);
    right: -60px;
    top: 48px;
    max-height: 60vh;
    overflow-y: auto;
  }
  .dropdown-menu-custom {
    width: calc(100vw - 24px);
    right: 0;
  }
}

/* ── SMALL MOBILE (≤480px) ── */
@media (max-width: 480px) {
  .content-area { padding: 10px; }
  .navbar { padding: 8px 12px; }
  .page-title { font-size: 15px !important; max-width: 110px; }
  .notification-btn { width: 36px; height: 36px; }
  .notification-btn i { font-size: 16px !important; }
  .user-avatar { width: 32px; height: 32px; font-size: 12px; }
  .stat-value { font-size: 20px; }
  .table-container { margin: 0 -10px; padding: 0 10px; }
  .data-table th, .data-table td { padding: 8px 10px; font-size: 12px; }
  .modal-content { max-width: 100vw; margin: 0; border-radius: 12px 12px 0 0; }
  .modal-overlay { align-items: flex-end; }
  .modal-overlay.show .modal-content { transform: translateY(0); }
}

/* ── TOUCH TARGETS & ACCESSIBILITY ── */
@media (pointer: coarse) {
  .btn-icon { width: 40px !important; height: 40px !important; }
  .nav-item { min-height: 44px; padding: 12px; }
  .page-btn { min-width: 36px; min-height: 36px; }
  .toggle-switch { width: 48px; height: 26px; }
  .toggle-slider::before { width: 20px; height: 20px; top: 3px; left: 3px; }
  .toggle-switch input:checked + .toggle-slider::before { transform: translateX(22px); }
}

/* ══════════════════════════════════════════════════ */
/* 📱 MOBILE PERFECT FIX: Navbar Offset, Side Margin,  */
/*              Table Scroll X Tight                 */
/* ══════════════════════════════════════════════════ */
@media (max-width: 768px) {
  /* ── LAYOUT UTAMA: App-Like Scroll ── */
  html, body, .app-layout {
    height: 100% !important;
    min-height: 100% !important;
    overflow: hidden !important;
    margin: 0 !important;
    padding: 0 !important;
  }
  .main-content {
    margin-left: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    height: 100% !important;
    overflow: hidden !important;
  }

  /* ── NAVBAR FIXED ── */
  .navbar {
    position: fixed !important;
    top: 0; left: 0; right: 0;
    height: 56px !important;
    z-index: 1000 !important;
    padding: 0 12px !important;
    border-bottom: 1px solid rgba(255,255,255,0.08) !important;
  }
  .page-title {
    font-size: 16px !important;
    max-width: 150px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .user-info { display: none !important; }
  .user-avatar { width: 34px; height: 34px; font-size: 13px; }

  /* ── CONTENT AREA: Offset Navbar + Side Margin ── */
  .content-area {
    flex: 1 !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
    padding: 66px 14px 24px 14px !important; /* 66px = navbar(56) + gap(10) */
    background: #f5f7fa !important;
  }

  /* ── STATS CARD COMPACT ── */
  .stats-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
    margin-bottom: 12px !important;
  }
  .stat-card {
    padding: 14px !important;
    margin-bottom: 0 !important;
    border-radius: 12px !important;
  }
  .stat-value { font-size: 22px !important; }
  .stat-label { font-size: 11px !important; }
  .stat-card > div:last-child { font-size: 10px !important; }

  /* ── TABEL: SCROLL X OPTIMAL & TIGHT ── */
  .table-container {
    margin: 0 !important;          /* Hilangkan negative margin penyebab whitespace */
    padding: 0 !important;
    overflow-x: auto !important;   /* Scroll aktif di container */
    -webkit-overflow-scrolling: touch;
    width: 100% !important;
    border-radius: 12px !important;
    background: #ffffff !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.04) !important;
    margin-bottom: 12px !important;
  }
  .data-table {
    min-width: 660px !important;   /* Paksa scrollbar muncul */
    width: 100% !important;
    border-collapse: collapse !important;
    margin-bottom: 0 !important;
  }
  .data-table th, .data-table td {
    padding: 10px 12px !important;
    font-size: 13px !important;
    white-space: nowrap !important; /* Cegah pecah, jaga lebar kolom */
    border-bottom: 1px solid #f1f5f9 !important;
  }
  .table-header {
    padding: 14px !important;
    border-bottom: 1px solid #f1f5f9 !important;
    margin-bottom: 0 !important;
  }
  .pagination-custom {
    padding: 10px 14px !important;
    margin-bottom: 0 !important;
  }

  /* Custom Scrollbar (Table & Content) */
  .table-container::-webkit-scrollbar,
  .content-area::-webkit-scrollbar { height: 4px; width: 4px; }
  .table-container::-webkit-scrollbar-track,
  .content-area::-webkit-scrollbar-track { background: transparent; }
  .table-container::-webkit-scrollbar-thumb,
  .content-area::-webkit-scrollbar-thumb { background: #cbd5e1; border-radius: 4px; }

  /* ── FORM & BUTTONS ── */
  .form-group { margin-bottom: 10px !important; }
  .btn-primary-custom {
    width: 100% !important;
    padding: 13px !important;
    border-radius: 10px !important;
  }
  .file-upload-area { padding: 14px !important; }

  /* ── DROPDOWNS & MODALS ── */
  .notification-dropdown, .dropdown-menu-custom {
    top: 62px !important;
    right: 14px !important;
    left: 14px !important;
    width: auto !important;
    max-height: 60vh !important;
    overflow-y: auto !important;
  }
  .modal-content {
    max-width: 96vw !important;
    margin: 20px auto !important;
    border-radius: 14px !important;
  }
}

/* ══════════════════════════════════════════════════ */
/* 📱 MOBILE FINAL: STICKY TABLE HEADER (JUDUL & TOMBOL) */
/* ══════════════════════════════════════════════════ */
@media (max-width: 768px) {
  /* 1. Container Tabel: Jadikan Area Scroll Independen */
  .table-container {
    display: flex;
    flex-direction: column;
    /* Batasi tinggi container agar muncul scrollbar jika data banyak */
    max-height: 75vh !important; 
    overflow-y: auto !important; /* Scroll terjadi di dalam kotak ini */
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    border-radius: 12px !important;
    background: #ffffff !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.04) !important;
  }

  /* 2. Table Header (Judul + Tombol): Tetap Menempel di Atas */
  .table-header {
    position: sticky !important;
    top: 0 !important;
    z-index: 50 !important; /* Di atas baris tabel */
    background: #ffffff !important;
    border-bottom: 1px solid #f1f5f9 !important;
    padding: 14px !important;
    flex-shrink: 0; /* Agar tidak gepeng */
  }

  /* 3. Table Body (Kolom NO, NASABAH, dst): Sticky di Bawah Header */
  .data-table thead {
    position: sticky !important;
    top: 62px !important; /* Sesuaikan jika tinggi header berubah (50px header + 12px gap) */
    z-index: 40 !important; /* Di bawah header, tapi di atas isi */
    background: #f8fafc !important;
    flex-shrink: 0;
  }

  /* 4. Isi Tabel */
  .data-table tbody {
    flex-shrink: 0;
  }
  .data-table th, .data-table td {
    padding: 10px 12px !important;
    font-size: 13px !important;
    white-space: nowrap !important;
    border-bottom: 1px solid #f1f5f9 !important;
  }

  /* 5. Pagination: Sticky di Bawah Container */
  .pagination-custom {
    position: sticky !important;
    bottom: 0 !important;
    z-index: 50 !important;
    background: #ffffff !important;
    border-top: 1px solid #e2e8f0 !important;
    padding: 12px !important;
    flex-shrink: 0;
    margin-top: auto !important;
  }

  /* 6. Perbaikan Scrollbar (Opsional - Agar Lebih Tipis) */
  .table-container::-webkit-scrollbar { width: 4px; height: 4px; }
  .table-container::-webkit-scrollbar-track { background: transparent; }
  .table-container::-webkit-scrollbar-thumb { background: #cbd5e1; border-radius: 4px; }
}

/* ══════════════════════════════════════════════════ */
/* 📱 FIX: Dropdown User Menu tidak terpotong di kanan */
/* ══════════════════════════════════════════════════ */
@media (max-width: 768px) {
  /* Gunakan position: fixed agar dropdown selalu dalam batas viewport,
     tidak bergantung pada posisi parent yang bisa dekat tepi kiri */
  .notification-dropdown {
    position: fixed !important;
    top: 62px !important;
    right: 12px !important;
    left: auto !important;
    width: auto !important;
    min-width: 300px !important;
    max-width: calc(100vw - 24px) !important;
  }
  .dropdown-menu-custom {
    position: fixed !important;
    top: 62px !important;
    right: 12px !important;
    left: auto !important;
    width: auto !important;
    min-width: 200px !important;
    max-width: calc(100vw - 24px) !important;
  }

  .login-card {
    margin: 0 20px;
  }
}