/**
 * E-BK Responsive - Tampilan optimal di semua device
 * Mobile-first & tablet, desktop
 */

/* ========== Global ========== */
html {
  overflow-x: hidden;
  -webkit-text-size-adjust: 100%;
}

body {
  overflow-x: hidden;
  min-height: 100vh;
}

/* ========== Navbar ========== */
.navbar-brand {
  font-size: clamp(0.9rem, 4vw, 1.1rem);
}
.navbar-brand img {
  width: 32px !important;
  height: auto;
}
@media (min-width: 576px) {
  .navbar-brand img {
    width: 40px !important;
  }
}
.navbar-nav .nav-link {
  white-space: nowrap;
}
@media (max-width: 991.98px) {
  .navbar-collapse {
    max-height: 70vh;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 0.5rem;
  }
  .navbar-nav .nav-link span {
    display: inline;
  }
}

/* Notifikasi dropdown - tidak overflow di layar kecil */
.notif-dropdown {
  max-width: calc(100vw - 2rem) !important;
}
@media (min-width: 400px) {
  .notif-dropdown {
    min-width: 320px !important;
  }
}

/* Desktop: ikon notifikasi lebih jelas dan seimbang dengan profil */
@media (min-width: 992px) {
  .navbar-nav .nav-link.position-relative .notif-badge {
    font-size: 0.7rem;
    padding: 0.2em 0.5em;
  }
  .navbar-nav.d-none.d-lg-flex .nav-link[title="Notifikasi"]:hover {
    opacity: 0.9;
  }
}

/* Profil user di navbar - potong teks panjang di mobile */
.navbar-nav .dropdown-toggle span {
  max-width: 120px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  display: inline-block;
  vertical-align: bottom;
}
@media (min-width: 992px) {
  .navbar-nav .dropdown-toggle span {
    max-width: none;
  }
}

/* ========== Layout utama (sidebar + content) ========== */
/* Sidebar hanya tampil di desktop */
.col-lg-2.d-none.d-lg-block {
  min-height: calc(100vh - 56px);
}
/* Area content full width di mobile & tablet */
@media (max-width: 991.98px) {
  .col-lg-10.col-md-12 {
    flex: 0 0 100%;
    max-width: 100%;
    padding-left: 0.75rem;
    padding-right: 0.75rem;
  }
}

/* ========== Container & content ========== */
.container-fluid.px-4 {
  padding-left: 0.75rem !important;
  padding-right: 0.75rem !important;
}
@media (min-width: 576px) {
  .container-fluid.px-4 {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
}
@media (min-width: 992px) {
  .container-fluid.px-4 {
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
  }
}

.container.pb-5,
div.container {
  padding-left: 0.75rem;
  padding-right: 0.75rem;
  max-width: 100%;
}
@media (min-width: 576px) {
  .container.pb-5,
  div.container {
    padding-left: 1rem;
    padding-right: 1rem;
  }
}

/* ========== Tabel responsif ========== */
.table-responsive {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin-bottom: 1rem;
}
.table-responsive .table {
  min-width: 600px; /* biar tidak remuk, scroll horizontal */
}
@media (max-width: 767.98px) {
  .table-responsive .table {
    font-size: 0.875rem;
  }
  .table-responsive .table th,
  .table-responsive .table td {
    padding: 0.5rem;
    vertical-align: middle !important;
  }
}

/* DataTables - tombol & info di mobile */
.dataTables_wrapper .row:first-child {
  flex-wrap: wrap;
  gap: 0.5rem;
}
.dataTables_wrapper .dataTables_length,
.dataTables_wrapper .dataTables_filter {
  margin-bottom: 0.5rem;
}
.dataTables_wrapper .dataTables_filter input {
  max-width: 100%;
  min-width: 120px;
}
@media (max-width: 575.98px) {
  .dataTables_wrapper .dataTables_info,
  .dataTables_wrapper .dataTables_paginate {
    font-size: 0.8rem;
    text-align: center;
  }
  .dataTables_wrapper .dataTables_paginate .paginate_button {
    padding: 0.25rem 0.5rem;
    margin: 1px;
  }
}

/* ========== Card ========== */
.card {
  margin-bottom: 1rem;
}
.card-header.d-flex {
  flex-wrap: wrap;
  gap: 0.5rem;
}
.card-header .btn {
  flex-shrink: 0;
}
.card-title {
  word-break: break-word;
}

/* Dashboard stat cards */
@media (max-width: 575.98px) {
  .card-stat .display-6,
  .card-stat h2 {
    font-size: 1.5rem !important;
  }
  .card-stat .bg-icon {
    font-size: 3rem !important;
  }
}

/* ========== Form ========== */
.form-control,
.form-select {
  max-width: 100%;
}
.d-flex.gap-2,
.d-flex.justify-content-between {
  flex-wrap: wrap;
}
.btn-group .btn {
  flex-wrap: nowrap;
}
@media (max-width: 575.98px) {
  .btn-group {
    flex-direction: column;
    width: 100%;
  }
  .btn-group .btn {
    width: 100%;
    border-radius: 0.375rem !important;
  }
}

/* ========== Page header (judul h1/h2) ========== */
.d-flex.flex-wrap.flex-md-nowrap.align-items-center.pt-3.pb-2.mb-4,
.my-4.border-bottom.pb-2 {
  flex-wrap: wrap;
}
h1.h2.fw-bold,
h2.fw-bold {
  font-size: clamp(1.25rem, 5vw, 1.75rem);
  word-break: break-word;
}
@media (max-width: 575.98px) {
  .d-flex.justify-content-between.align-items-center .btn {
    width: 100%;
    margin-top: 0.5rem;
  }
}

/* ========== Login page ========== */
@media (max-width: 575.98px) {
  body .bg-overlay .container {
    padding-left: 0.75rem;
    padding-right: 0.75rem;
  }
  .card-login {
    margin: 0.5rem;
    padding: 1rem !important;
  }
  .card-login .form-floating label {
    font-size: 0.85rem;
  }
  .logo-img {
    max-height: 60px;
  }
  .btn-login {
    padding: 0.75rem 1rem !important;
  }
}
@media (max-height: 500px) and (orientation: landscape) {
  .bg-overlay {
    align-items: flex-start;
    padding-top: 1rem;
    padding-bottom: 1rem;
  }
}

/* ========== Footer ========== */
.row.mt-.bg-light {
  font-size: 0.8rem;
  padding: 0.75rem !important;
}

/* ========== Chart (Dashboard) ========== */
@media (max-width: 767.98px) {
  #myChart,
  #myChart2 {
    max-height: 220px !important;
  }
}

/* ========== Utility ========== */
.text-truncate-mobile {
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
@media (min-width: 768px) {
  .text-truncate-mobile {
    white-space: normal;
    overflow: visible;
  }
}

/* Padding aman untuk area notch/safe area (iPhone dll) */
@supports (padding: max(0px)) {
  body {
    padding-left: max(0px, env(safe-area-inset-left));
    padding-right: max(0px, env(safe-area-inset-right));
  }
  .navbar {
    padding-left: max(0.75rem, env(safe-area-inset-left));
    padding-right: max(0.75rem, env(safe-area-inset-right));
  }
}
