/*
 * Tema Minimal untuk Dashboard Makyem
 * Fokus: kontras jelas, ruang napas, elemen ringan.
 * Tetap gunakan variabel warna yang sudah dipakai project.
 */

:root{
  --custom-purple: #9b59b6;
  --custom-purple-light: #f4ecf7;   /* lebih lembut */
  --custom-purple-dark: #8e44ad;
  --text-muted-600: #6c757d;
  --border-soft: #e9ecef;
  --card-radius: 14px;
  --shadow-soft: 0 6px 18px rgba(0,0,0,.06);
}

*{ box-sizing: border-box; }
html, body{ height:100%; }
body{
  font-family: ui-sans-serif, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif;
  background:#f8f9fb;
  color:#212529;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ===== Buttons ===== */
.btn{ border-radius:10px; }
.btn-custom{
  background: var(--custom-purple);
  color:#fff;
  border:1px solid var(--custom-purple);
  transition: transform .04s ease, box-shadow .2s ease;
}
.btn-custom:hover{ background: var(--custom-purple-dark); color:#fff; box-shadow: var(--shadow-soft); }
.btn-custom:active{ transform: translateY(1px); }
.btn-outline-secondary{ border-color: var(--border-soft); }
.btn-outline-secondary:hover{ background:#f6f7f9; border-color:#dee2e6; }

/* ===== Navbar ===== */
.navbar{
  background:#ffffff !important;
  border-bottom:1px solid var(--border-soft);
}
.navbar .btn.btn-custom{ padding:.35rem .7rem; }

/* ===== Cards ===== */
.card{
  border:1px solid var(--border-soft);
  border-radius: var(--card-radius);
  box-shadow: var(--shadow-soft);
  overflow:hidden;
  background:#fff;
}
.card-header{
  background:#fff;
  border-bottom:1px solid var(--border-soft);
  color:#343a40;
}
.card .form-label{ font-size:.85rem; color: var(--text-muted-600); }

/* ===== Tables ===== */
.table{
  --cell-y: .55rem;
  --cell-x: .8rem;
  margin-bottom:0;
}
.table > :not(caption) > * > *{
  padding: var(--cell-y) var(--cell-x);
  vertical-align: middle;
}
.table thead th{
  font-weight:600;
  color:#495057;
  background:#fafafa;
  border-bottom:1px solid var(--border-soft);
}
.table-striped > tbody > tr:nth-of-type(odd){ background: #fcfcfd; }
.table-hover > tbody > tr:hover{ background: var(--custom-purple-light); }
.table td.text-end{ font-variant-numeric: tabular-nums; }

/* ===== Badge yang bersih ===== */
.badge{ border-radius:999px; font-weight:600; padding:.38rem .55rem; }
.badge.bg-success{ background:#2ecc71 !important; }
.badge.bg-danger{ background:#e74c3c !important; }

/* ===== Pagination ===== */
.pagination .page-link{
  border-radius:10px;
  border:1px solid var(--border-soft);
  color: var(--custom-purple) !important;
}
.pagination .page-item + .page-item{ margin-left:.25rem; }
.pagination .page-link:hover{
  background: var(--custom-purple-light) !important;
  border-color: var(--border-soft);
  color: var(--custom-purple-dark) !important;
}
.pagination .page-item.active .page-link{
  background: var(--custom-purple) !important;
  border-color: var(--custom-purple) !important;
  color:#fff !important;
}
.pagination .page-item.disabled .page-link{
  background:#f1f3f5;
  color:#adb5bd;
}

/* ===== Forms ===== */
.form-control, .form-select{
  border-radius:10px;
  border:1px solid var(--border-soft);
}
.form-control:focus, .form-select:focus{
  border-color: var(--custom-purple);
  box-shadow: 0 0 0 0.15rem rgba(155, 89, 182, .15);
}

/* ===== Alerts ===== */
.alert{
  border-radius:10px;
  border:1px solid var(--border-soft);
  background:#fcfcff;
}

/* ===== Modal ===== */
.modal-content{
  border-radius:16px;
  border:1px solid var(--border-soft);
  box-shadow: var(--shadow-soft);
}
.modal-header{ border-bottom:1px solid var(--border-soft); }
.modal-footer{ border-top:1px solid var(--border-soft); }

/* ===== Toast ===== */
.toast{ border-radius:12px; box-shadow: var(--shadow-soft); }

/* ===== Utility ===== */
.text-gray-300{ color:#dde1ea !important; }
.text-xs{ font-size:.8rem; }
.border-start{ border-left-width:.25rem !important; }
.border-success{ border-color:#1cc88a !important; }
.border-danger{  border-color:#e74a3b !important; }
.border-info{    border-color:#36b9cc !important; }
.border-warning{ border-color:#f6c23e !important; }

/* ===== Responsif ringkas ===== */
@media (max-width: 992px){
  .card .row.g-2 > [class^="col-"]{ margin-bottom:.25rem; }
}
@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.001ms !important; transition-duration:.001ms !important; }
}

/* ===== Tombol Edit & Hapus di Tabel ===== */

/* Definisi umum tombol aksi (Edit, Hapus) */
.table td .btn {
  min-width: 36px;
  height: 36px;
  padding: 0; /* Icon-only */
  display: flex;
  justify-content: center;
  align-items: center;
  border: none;
  border-radius: 50%;
  background: transparent;
  box-shadow: none;
  transition: all 0.3s ease;
  font-size: 1.1rem;
}

/* Hover efek untuk tombol */
.table td .btn:hover {
  transform: scale(1.1);
  background-color: rgba(0, 0, 0, 0.05);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

/* Tombol Edit */
.table td .btn[data-action="edit"],
.table td .btn.btn-warning {
  color: #fff;
  background-color: var(--custom-purple); /* Background ungu */
}

.table td .btn[data-action="edit"]:hover,
.table td .btn.btn-warning:hover {
  background-color: var(--custom-purple-dark); /* Background gelap saat hover */
  color: #fff;
}

/* Tombol Hapus */
.table td .btn[data-action="delete"],
.table td .btn.btn-danger {
  color: #fff;
  background-color: #e74c3c; /* Merah */
}

.table td .btn[data-action="delete"]:hover,
.table td .btn.btn-danger:hover {
  background-color: #c0392b; /* Background lebih gelap saat hover */
  color: #fff;
}

/* Tombol Disabled */
.table td .btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  background: transparent !important;
  color: #adb5bd !important;
  box-shadow: none !important;
}

/* Focus efek agar lebih jelas */
.table td .btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 4px rgba(155, 89, 182, 0.25); /* Efek fokus untuk aksesibilitas */
}
