body {
  background-color: #f8fafc;
  color: #1e293b;
  font-family: "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  margin: 0;
  padding: 0;
}

/* ==========================================================================
   📊 AREA DINAMIK & KARTU STATISTIK (DAPAT ANTISIPASI OVERRIDE CSS LAIN)
   ========================================================================== */

#konten-laporan-dinamik {
  padding: 24px;
  max-width: 1400px;
  margin: 0 auto;
  box-sizing: border-box;
}

#konten-laporan-dinamik .grid-statistik {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
  gap: 20px !important;
  margin-bottom: 24px !important;
}

#konten-laporan-dinamik .kartu-stat {
  background: #ffffff !important;
  border-radius: 12px !important;
  padding: 20px !important;
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05) !important;
  border: 1px solid #e2e8f0 !important;
}

#konten-laporan-dinamik .kartu-stat.biru {
  border-left: 5px solid #2563eb !important;
}
#konten-laporan-dinamik .kartu-stat.hijau {
  border-left: 5px solid #16a34a !important;
}
#konten-laporan-dinamik .kartu-stat.kuning {
  border-left: 5px solid #eab308 !important;
}

#konten-laporan-dinamik .ikon-stat {
  font-size: 2.2rem !important;
  background: #f1f5f9 !important;
  padding: 10px !important;
  border-radius: 10px !important;
  display: inline-flex !important;
}

#konten-laporan-dinamik .kartu-stat h3 {
  margin: 0 0 4px 0 !important;
  font-size: 0.85rem !important;
  color: #64748b !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
}

#konten-laporan-dinamik .kartu-stat p {
  margin: 0 !important;
  font-size: 1.6rem !important;
  font-weight: 700 !important;
  color: #0f172a !important;
}

/* ==========================================================================
   🔍 PANEL FILTER & TABEL TRANSAKSI UTAMA
   ========================================================================== */

#konten-laporan-dinamik .kartu-komponen {
  background: #ffffff !important;
  border-radius: 12px !important;
  padding: 24px !important;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05) !important;
  border: 1px solid #e2e8f0 !important;
}

#konten-laporan-dinamik .judul-bagian {
  font-size: 1.2rem !important;
  font-weight: 700 !important;
  color: #0f172a !important;
}

/* Form Filter Baris */
#konten-laporan-dinamik .area-filter {
  background: #f8fafc !important;
  padding: 16px !important;
  border-radius: 8px !important;
  border: 1px solid #e2e8f0 !important;
}

#konten-laporan-dinamik .input-laporan {
  padding: 8px 12px !important;
  border: 1px solid #cbd5e1 !important;
  border-radius: 6px !important;
  font-size: 0.9rem !important;
  color: #0f172a !important;
  background: #ffffff !important;
  height: 38px !important;
}

/* Tombol Desain */
#konten-laporan-dinamik .tombol-aksi {
  padding: 0 18px !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  font-size: 0.85rem !important;
  cursor: pointer !important;
  border: none !important;
  height: 38px !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
}

#konten-laporan-dinamik .btn-cari {
  background-color: #2563eb !important;
  color: white !important;
}
#konten-laporan-dinamik .btn-cari:hover {
  background-color: #1d4ed8 !important;
}
#konten-laporan-dinamik .btn-print {
  background-color: #64748b !important;
  color: white !important;
}
#konten-laporan-dinamik .btn-print:hover {
  background-color: #475569 !important;
}

/* Pembungkus & Grid Tabel */
#konten-laporan-dinamik .tabel-wadah-luas {
  overflow-x: auto !important;
  margin-top: 15px !important;
  border-radius: 8px !important;
  border: 1px solid #e2e8f0 !important;
}

#konten-laporan-dinamik .tabel-transaksi {
  width: 100% !important;
  border-collapse: collapse !important;
  font-size: 0.9rem !important;
}

#konten-laporan-dinamik .tabel-transaksi th {
  background-color: #f1f5f9 !important;
  color: #475569 !important;
  font-weight: 600 !important;
  padding: 14px 16px !important;
  border-bottom: 2px solid #e2e8f0 !important;
  white-space: nowrap !important;
}

#konten-laporan-dinamik .tabel-transaksi td {
  padding: 14px 16px !important;
  border-bottom: 1px solid #e2e8f0 !important;
}

#konten-laporan-dinamik .baris-klik-nota:hover {
  background-color: #f8fafc !important;
}

/* ==========================================================================
   🧾 MODAL POP-UP DETAIL NOTA (FIXED LAYER DAN BADGE)
   ========================================================================== */

/* Latar belakang blur hitam menutupi seluruh layar */
.modal-detail-nota-bg {
  background: rgba(15, 23, 42, 0.6) !important; /* Efek gelap mewah */
  backdrop-filter: blur(4px) !important; /* Efek blur halus */
}

/* Box Putih Nota Struk */
.konten-modal-detail {
  max-height: 85vh !important; /* Maksimal 85% tinggi layar */
  display: flex !important;
  flex-direction: column !important;
}
#md-wadah-list-items {
  display: block !important;
  max-height: 300px !important; /* Atur tinggi list menu di sini */
  overflow-y: auto !important; /* Munculkan scroll jika pesanan banyak */
}

.tabel-detail-items-laporan thead {
  display: block !important;
}
.tabel-detail-items-laporan tr {
  display: flex !important;
  width: 100% !important;
}
.tabel-detail-items-laporan th,
.tabel-detail-items-laporan td {
  flex: 1 !important; /* Membagi ruang sama rata */
}

#md-row-diskon {
  display: none; /* Default */
}

#md-row-diskon[style*="display: block"] {
  display: block !important;
}

@keyframes modalMuncul {
  from {
    transform: scale(0.95);
    opacity: 0;
  }
  to {
    transform: scale(1);
    opacity: 1;
  }
}

.tabel-detail-items-laporan th {
  color: #64748b !important;
  font-weight: 600 !important;
}

.tabel-detail-items-laporan td {
  padding: 8px 0 !important;
  color: #334155 !important;
}

/* Gaya Tampilan Detail Varian & Topping di Struk Modal */
.sub-varian-text {
  font-size: 0.72rem !important;
  color: #64748b !important;
  line-height: 1.35 !important;
  margin-top: 3px !important;
  font-style: italic !important;
  background-color: #f8fafc !important;
  padding: 4px 6px !important;
  border-radius: 4px !important;
  border: 1px dashed #cbd5e1 !important;
  display: inline-block !important;
}

/* ==========================================================================
   🖨️ PRINT RULES (OPTIMASI CETAK KERTAS)
   ========================================================================== */
@media print {
  .header-utama,
  .nav-atas,
  .area-filter {
    display: none !important;
  }
  body {
    background: #ffffff !important;
  }
  #konten-laporan-dinamik {
    padding: 0 !important;
  }
  #konten-laporan-dinamik .kartu-komponen {
    border: none !important;
    padding: 0 !important;
    box-shadow: none !important;
  }
  #konten-laporan-dinamik .grid-statistik {
    grid-template-columns: repeat(3, 1fr) !important;
  }
  #konten-laporan-dinamik .kartu-stat {
    border: 1px solid #cbd5e1 !important;
    box-shadow: none !important;
  }
}

/* ==========================================================================
   🌟 KUNCI RESPONSIVE HEADER & NAVIGASI SERAGAM (laporan.css)
   ========================================================================== */
@media (max-width: 850px) {
  /* 1. MENYAMAKAN HEADER UTAMA: Mengunci posisi agar lurus simetris di HP */

  /* ==========================================================================
       🛠️ REVISI TABEL LAPORAN: ANTI-GESER / ANTI-SCROLL HORIZONTAL DI HP
       ========================================================================== */
  main {
    padding: 10px !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }

  /* Box Filter Tanggal Laporan melipat ke bawah */
  .box-filter-laporan,
  form {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    width: 100% !important;
  }

  .box-filter-laporan input,
  .box-filter-laporan button {
    width: 100% !important;
    box-sizing: border-box !important;
  }

  /* Kartu Ringkasan (Omset Total, Rata-rata, dll) disusun vertikal */
  .grid-summary-laporan {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    margin-bottom: 15px !important;
  }

  /* 🌟 KUNCI UTAMA PERBAIKAN: Mengunci display block KHUSUS untuk .tabel-transaksi utama saja.
       (Ini mencegah rusaknya tabel rincian item nota di dalam modal rincian nota belanja) */
  .tabel-transaksi,
  .tabel-transaksi thead,
  .tabel-transaksi tbody,
  .tabel-transaksi th,
  .tabel-transaksi td,
  .tabel-transaksi tr {
    display: block !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }

  /* Sembunyikan judul kolom tabel teratas asli desktop karena bikin sesak */
  .tabel-transaksi thead tr {
    position: absolute !important;
    top: -9999px !important;
    left: -9999px !important;
  }

  /* Ubah tiap baris data transaksi menjadi satu kotak kartu box laporan yang estetik */
  .tabel-transaksi tr {
    background: #ffffff !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 8px !important;
    padding: 12px !important;
    margin-bottom: 12px !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.02) !important;
  }

  /* Tata letak isian kolom di dalam kartu laporan */
  .tabel-transaksi td {
    border: none !important;
    border-bottom: 1px dashed #f1f5f9 !important;
    position: relative !important;
    padding: 8px 0 8px 45% !important; /* Beri ruang kosong 45% di kiri untuk label nama */
    text-align: right !important; /* Isi data mepet ke kanan */
    font-size: 0.85rem !important;
  }

  .tabel-transaksi td:last-child {
    border-bottom: none !important;
    padding-bottom: 0 !important;
  }

  /* 🌟 TRICK PRE-LABEL: Memasukkan judul teks kolom otomatis di porsi kiri td */
  .tabel-transaksi td:before {
    position: absolute !important;
    top: 8px !important;
    left: 6px !important;
    width: 40% !important;
    padding-right: 10px !important;
    white-space: nowrap !important;
    text-align: left !important;
    font-weight: 700 !important;
    color: #64748b !important;
  }

  /* 🌟 FIXED: Menyelaraskan ulang 7 label kolom agar datanya berpasangan tepat & tidak tertukar */
  .tabel-transaksi td:nth-of-type(1):before {
    content: "📋 No. Nota";
  }
  .tabel-transaksi td:nth-of-type(2):before {
    content: "⏱️ Waktu";
  }
  .tabel-transaksi td:nth-of-type(3):before {
    content: "📍 Meja";
  }
  .tabel-transaksi td:nth-of-type(4):before {
    content: "💳 Metode";
  }
  .tabel-transaksi td:nth-of-type(5):before {
    content: "👤 Kasir";
  }
  .tabel-transaksi td:nth-of-type(6) {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-end !important;
    padding-top: 35px !important; /* Ruang untuk label 'Total' */
  }
  .tabel-transaksi td:nth-of-type(6):before {
    content: "💰 Total";
    position: absolute !important;
    top: 8px !important;
    left: 6px !important;
  }
  .tabel-transaksi td:nth-of-type(6) small {
    margin-top: 4px !important;
    font-size: 0.75rem !important;
  }
  .tabel-transaksi td:nth-of-type(7):before {
    content: "⚙️ Status";
  }
  .tabel-transaksi td:nth-of-type(8):before {
    content: "📝 Keterangan";
  }

  /* Penyesuaian visual elemen status badge lunas/sukses di HP */
  .tabel-transaksi td span {
    display: inline-block !important;
  }

  .tabel-transaksi td:nth-of-type(8) {
    text-align: right !important;
    display: block !important;
    padding-top: 25px !important; /* Memberi ruang agar label tidak menabrak teks */
  }
}

/* Membuat teks keterangan tidak menumpuk dan rapi */
