/* ===========================
   Overlay + Loader
   =========================== */
.overlay-container {
  position: relative;
  width: 100%;
  height: 100vh;
}

.overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  display: none;
  justify-content: center;
  align-items: center;
  z-index: 9999;
  opacity: 0;
  transition: opacity 0.3s ease-in-out;
}

.overlay.active {
  display: flex;
  opacity: 1;
}

.loader {
  width: 16px;
  height: 16px;
  box-shadow: 0 30px, 0 -30px;
  border-radius: 4px;
  background: currentColor;
  display: block;
  margin: -50px auto 0;
  position: relative;
  color: #FFF;
  transform: translateY(30px);
  box-sizing: border-box;
  animation: animloader 2s ease infinite;
}

.loader::after,
.loader::before {
  content: '';
  box-sizing: border-box;
  width: 16px;
  height: 16px;
  box-shadow: 0 30px, 0 -30px;
  border-radius: 4px;
  background: currentColor;
  color: #FFF;
  position: absolute;
  left: 30px;
  top: 0;
  animation: animloader 2s 0.2s ease infinite;
}

.loader::before {
  animation-delay: 0.4s;
  left: 60px;
}

@keyframes animloader {
  0% {
    top: 0;
    color: white;
  }
  50% {
    top: 30px;
    color: rgba(255, 255, 255, 0.2);
  }
  100% {
    top: 0;
    color: white;
  }
}
/* ===========================
   Warna nama menu & harga
   =========================== */
:root{
  /* ganti sesuai selera */
  --menu-name-bg: #000000;   /* background strip di bawah (nama menu) */
  --menu-name-color: #ffffff;/* warna teks nama menu */

  --price-bg: #000000;       /* background badge harga */
  --price-color: #ffffff;    /* warna teks harga */
  }
  /* strip bawah (area nama menu) */
.row.grid .fp__menu_item_text{
  background: var(--menu-name-bg) !important;
  color: var(--menu-name-color) !important;
}

/* teks judul / nama menu */
.row.grid .fp__menu_item_text .title{
  color: var(--menu-name-color) !important;
}

/* badge harga (yang lonjong di kanan) */
.row.grid .fp__menu_item{ position: relative; }
.row.grid .fp__menu_item_text .price,
.row.grid .fp__menu_item_text .price span{
  position: absolute;        /* tetap nempel di kanan atas strip */
  top: -18px;
  right: 22px;
  padding: 6px 14px !important;
  border-radius: 999px !important;
  background: var(--price-bg) !important;
  color: var(--price-color) !important;
  font-weight: 700 !important;
  box-shadow: 0 6px 16px rgba(0,0,0,.12) !important;
}

/* ===========================
   KHUSUS KATEGORI: PAKET
   Atur tinggi gambar kartu menu
   =========================== */
.row.grid .paket .fp__menu_item_img{
  aspect-ratio: 16 / 9;   /* rasio default: lebar 16, tinggi 9 */
  width: 100%;
  height: auto;           /* biar ikut aspect-ratio */
  overflow: hidden;
  border-radius: 18px;    /* samakan dengan style kartu kamu */
}

/* Gambar isi: penuhi frame & crop pinggir bila perlu */
.row.grid .paket .fp__menu_item_img img{
  width: 100%;
  height: 100%;
  object-fit: cover;      /* full kiri–kanan–atas–bawah secara proporsi */
  display: block;
}

/* Kalau ada class pembatas tinggi (mh-50), nonaktifkan di area ini */
.row.grid .paket .fp__menu_item_img .mh-50{
  max-height: none !important;
}

/* (Opsional) Sesuaikan rasio di layar kecil biar kartu lebih tinggi */
@media (max-width: 992px){
  .row.grid .paket .fp__menu_item_img{ aspect-ratio: 4 / 3; }
}
@media (max-width: 576px){
  .row.grid .paket .fp__menu_item_img{ aspect-ratio: 1 / 1; } /* kotak */
}

/*===================================================================================