/* =============================================
   FZDATA MASTER — DARK THEME v3.0
   ============================================= */

@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

:root {
  --fzm-bg:           #1a1d2e;
  --fzm-surface:      #22263a;
  --fzm-surface2:     #2a2f47;
  --fzm-surface3:     #313654;
  --fzm-border:       rgba(255,255,255,.08);
  --fzm-border2:      rgba(255,255,255,.13);
  --fzm-text:         #e8eaf6;
  --fzm-muted:        #8b90b8;
  --fzm-accent:       #6c63ff;
  --fzm-accent2:      #a78bfa;
  --fzm-pink:         #f857a6;
  --fzm-add-btn:      linear-gradient(135deg, #f857a6 0%, #ff5858 100%);
  --fzm-proses-bg:    rgba(108,99,255,.18);
  --fzm-proses-txt:   #a78bfa;
  --fzm-proses-bdr:   rgba(108,99,255,.4);
  --fzm-selesai-bg:   rgba(16,185,129,.15);
  --fzm-selesai-txt:  #34d399;
  --fzm-selesai-bdr:  rgba(52,211,153,.35);
  --fzm-error:        #f87171;
  --fzm-row-hover:    rgba(108,99,255,.1);
  --fzm-shadow:       0 4px 24px rgba(0,0,0,.35);
  --fzm-shadow-lg:    0 16px 48px rgba(0,0,0,.55);
  --fzm-radius:       14px;
  --fzm-radius-sm:    8px;
  --fzm-font:         'DM Sans', sans-serif;
  --fzm-mono:         'JetBrains Mono', monospace;
  --fzm-transition:   all .2s cubic-bezier(.4,0,.2,1);
}

/* ── Reset ─────────────────────────────────── */
.fzm-wrapper *, .fzm-wrapper *::before, .fzm-wrapper *::after {
  box-sizing: border-box;
}

/* ═══════════════════════════════════════════════
   ADMIN TABLE WRAPPER — Full-width, no border-radius
   mengisi area kerja WordPress sepenuhnya
═══════════════════════════════════════════════ */
/* Force WordPress admin content column to not overflow */
#wpbody-content { overflow-x: hidden; }
#wpbody        { overflow-x: hidden; }

.fzm-admin-wrap {
  padding: 0 !important;
  margin-left: 0 !important;
  margin-right: 20px !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  overflow-x: hidden !important;
}

/* Override WordPress .wrap heading & shortcode info */
.fzm-admin-wrap > h1 {
  padding: 16px 28px 8px;
  color: #1d2327;
  margin: 0;
  font-size: 1.3rem;
}

.fzm-wrapper {
  font-family: var(--fzm-font);
  background: var(--fzm-bg);
  color: var(--fzm-text);
  padding: 20px 20px 24px;
  position: relative;
  /* Strict width — never exceed the column WP gives us */
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  border-radius: 0;
  margin: 0;
  overflow-x: hidden;
  overflow-y: visible;
}

/* Decorative glow blobs */
.fzm-wrapper::before {
  content: '';
  position: absolute;
  top: -60px; right: -40px;
  width: 300px; height: 300px;
  background: radial-gradient(circle, rgba(108,99,255,.15) 0%, transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}
.fzm-wrapper::after {
  content: '';
  position: absolute;
  bottom: 80px; left: -60px;
  width: 220px; height: 220px;
  background: radial-gradient(circle, rgba(248,87,166,.08) 0%, transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}

/* ── Header ─────────────────────────────────── */
.fzm-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 24px;
  flex-wrap: wrap;
  gap: 14px;
}

.fzm-title {
  font-size: 1.75rem;
  font-weight: 700;
  margin: 0;
  color: var(--fzm-text);
  letter-spacing: -.5px;
}

/* ── Toolbar ────────────────────────────────── */
.fzm-toolbar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}

.fzm-search-wrap {
  position: relative;
  flex: 1;
  min-width: 200px;
  max-width: 360px;
}

/* No icon padding — icon removed */
.fzm-search {
  width: 100%;
  padding: 9px 14px;
  background: var(--fzm-surface2);
  border: 1px solid var(--fzm-border2);
  border-radius: var(--fzm-radius-sm);
  color: var(--fzm-text);
  font-family: var(--fzm-font);
  font-size: .88rem;
  outline: none;
  transition: var(--fzm-transition);
}
.fzm-search::placeholder { color: var(--fzm-muted); }
.fzm-search:focus { border-color: var(--fzm-accent); box-shadow: 0 0 0 3px rgba(108,99,255,.2); }

/* ── Filter Klasifikasi ─────────────────────────── */
.fzm-filter-wrap { flex-shrink: 0; }
.fzm-filter-wrap select {
  padding: 9px 34px 9px 14px;
  background: var(--fzm-surface2);
  border: 1px solid var(--fzm-border2);
  border-radius: var(--fzm-radius-sm);
  color: var(--fzm-text);
  font-family: var(--fzm-font); font-size: .88rem;
  outline: none; cursor: pointer; transition: var(--fzm-transition);
  appearance: none; -webkit-appearance: none; -moz-appearance: none;
  background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%238b8fa3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 12px center; background-size: 15px;
}
.fzm-filter-wrap select:focus { border-color: var(--fzm-accent); box-shadow: 0 0 0 3px rgba(108,99,255,.2); }

/* ── Buttons ─────────────────────────────────── */
.fzm-btn {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 10px 22px;
  border: none; border-radius: 50px;
  font-family: var(--fzm-font); font-size: .875rem; font-weight: 600;
  cursor: pointer; transition: var(--fzm-transition); line-height: 1;
  white-space: nowrap;
}

.fzm-btn-add {
  background: var(--fzm-add-btn);
  color: #fff;
  box-shadow: 0 4px 18px rgba(248,87,166,.35);
}
.fzm-btn-add:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(248,87,166,.5); }

/* ── Header Actions Group ── */
.fzm-header-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

/* ── Export Button ── */
.fzm-btn-export {
  background: linear-gradient(135deg, #10b981, #059669);
  color: #fff;
  box-shadow: 0 4px 14px rgba(16,185,129,.3);
}
.fzm-btn-export:hover { transform: translateY(-2px); box-shadow: 0 8px 22px rgba(16,185,129,.5); }

/* ── Import Button (label acting as button) ── */
.fzm-btn-import {
  background: linear-gradient(135deg, #3b82f6, #2563eb);
  color: #fff;
  box-shadow: 0 4px 14px rgba(59,130,246,.3);
  cursor: pointer;
}
.fzm-btn-import:hover { transform: translateY(-2px); box-shadow: 0 8px 22px rgba(59,130,246,.5); }

/* ── Sample Download Button ── */
.fzm-btn-sample {
  background: var(--fzm-surface3);
  color: var(--fzm-muted);
  border: 1px solid var(--fzm-border2);
  text-decoration: none;
}
.fzm-btn-sample:hover { color: var(--fzm-text); border-color: var(--fzm-accent); }

/* ── Tambah Kolom Button ── */
.fzm-btn-col {
  background: var(--fzm-surface3);
  color: var(--fzm-text);
  border: 1px solid var(--fzm-border2);
}
.fzm-btn-col:hover { transform: translateY(-2px); border-color: var(--fzm-accent); box-shadow: 0 6px 18px rgba(0,0,0,.25); }

/* ── Hapus Kolom Button ── */
.fzm-btn-col-del {
  background: var(--fzm-surface3);
  color: var(--fzm-error);
  border: 1px solid var(--fzm-border2);
}
.fzm-btn-col-del:hover { transform: translateY(-2px); border-color: var(--fzm-error); box-shadow: 0 6px 18px rgba(248,113,113,.25); background: rgba(248,113,113,.1); }

/* ── Extra (dynamic column) fields di modal ── */
.fzm-extra-group { margin-top: 14px; }

.fzm-btn-primary {
  background: var(--fzm-accent);
  color: #fff;
}
.fzm-btn-primary:hover { background: #5b52f0; transform: translateY(-1px); }

.fzm-btn-secondary {
  background: var(--fzm-surface3);
  color: var(--fzm-muted);
  border: 1px solid var(--fzm-border2);
}
.fzm-btn-secondary:hover { color: var(--fzm-text); }

.fzm-btn-success {
  background: linear-gradient(135deg,#10b981,#059669);
  color: #fff;
}
.fzm-btn-success:hover { transform: translateY(-1px); box-shadow: 0 4px 16px rgba(16,185,129,.35); }

/* ── Table Container ─────────────────────────── */
.fzm-table-container {
  background: var(--fzm-surface);
  border-radius: var(--fzm-radius);
  border: 1px solid var(--fzm-border);
  overflow: hidden;         /* no scroll inside container */
  box-shadow: var(--fzm-shadow);
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

.fzm-table {
  width: 100%;
  max-width: 100%;
  border-collapse: collapse;
  font-size: .82rem;
  table-layout: fixed;      /* honour % widths, never push wider */
}

.fzm-table thead tr {
  background: var(--fzm-surface2);
  border-bottom: 1px solid var(--fzm-border2);
}

.fzm-table th {
  padding: 11px 8px;
  text-align: left;
  font-size: .68rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--fzm-muted);
  white-space: normal;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Kolom ID, KATEGORI, KLASIFIKASI, JUDUL, PENGARANG, PENERBIT punya lebar tetap; sisanya (kolom dinamis + EDIT) menyesuaikan */
.fzm-table th:nth-child(1), .fzm-table td:nth-child(1) { width: 5%;  text-align: center; }
.fzm-table th:nth-child(2), .fzm-table td:nth-child(2) { width: 12%; }
.fzm-table th:nth-child(3), .fzm-table td:nth-child(3) { width: 12%; }
.fzm-table th:nth-child(4), .fzm-table td:nth-child(4) { width: 17%; }
.fzm-table th:nth-child(5), .fzm-table td:nth-child(5) { width: 13%; }
.fzm-table th:nth-child(6), .fzm-table td:nth-child(6) { width: 13%; }
.fzm-table th.fzm-col-aksi, .fzm-table td.fzm-col-aksi { width: 16%; text-align: center; white-space: normal; }

.fzm-table th .fzm-sort { cursor: pointer; user-select: none; }
.fzm-table th .fzm-sort::after { content: ' ↕'; opacity: .4; }

/* ── Kolom Dinamis (header) ──────────────────── */
.fzm-table th.fzm-dyn-th {
  position: relative;
  padding-right: 22px;
}
.fzm-dyn-th-label { display: inline-block; max-width: 100%; overflow: hidden; text-overflow: ellipsis; vertical-align: middle; }
.fzm-col-delete {
  position: absolute;
  top: 50%; right: 4px;
  transform: translateY(-50%);
  width: 16px; height: 16px;
  line-height: 14px;
  border: none;
  border-radius: 50%;
  background: rgba(239,68,68,.15);
  color: #ef4444;
  font-size: .85rem;
  font-weight: 700;
  cursor: pointer;
  text-transform: none;
  letter-spacing: 0;
  transition: var(--fzm-transition);
}
.fzm-col-delete:hover { background: #ef4444; color: #fff; transform: translateY(-50%) scale(1.1); }

.fzm-table td {
  padding: 11px 8px;
  border-bottom: 1px solid var(--fzm-border);
  color: var(--fzm-text);
  vertical-align: middle;
  transition: background .15s ease;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.fzm-table tbody tr:last-child td { border-bottom: none; }
.fzm-table tbody tr:hover td { background: var(--fzm-row-hover); }

.fzm-table td:first-child {
  font-family: var(--fzm-mono);
  font-size: .78rem;
  color: var(--fzm-muted);
}

.fzm-table td.fzm-nik {
  font-family: var(--fzm-mono);
  font-size: .82rem;
  color: var(--fzm-accent2);
}

/* ── Edit Button (AKSI) ──────────────────────── */
.fzm-edit-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 14px;
  border-radius: 20px;
  background: var(--fzm-proses-bg, rgba(108,99,255,.15));
  color: var(--fzm-proses-txt, #6c63ff);
  border: 1px solid var(--fzm-proses-bdr, rgba(108,99,255,.35));
  font-family: var(--fzm-font);
  font-size: .73rem; font-weight: 700;
  letter-spacing: .03em;
  cursor: pointer; transition: var(--fzm-transition);
}
.fzm-edit-btn:hover {
  background: rgba(108,99,255,.35);
  transform: scale(1.05);
  box-shadow: 0 2px 12px rgba(108,99,255,.3);
}

.fzm-delete-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 14px;
  margin-left: 6px;
  border-radius: 20px;
  background: rgba(239,68,68,.12);
  color: #ef4444;
  border: 1px solid rgba(239,68,68,.35);
  font-family: var(--fzm-font);
  font-size: .73rem; font-weight: 700;
  letter-spacing: .03em;
  cursor: pointer; transition: var(--fzm-transition);
}
.fzm-delete-btn:hover {
  background: #ef4444;
  color: #fff;
  transform: scale(1.05);
  box-shadow: 0 2px 12px rgba(239,68,68,.3);
}

/* ── Empty State ─────────────────────────────── */
.fzm-empty {
  text-align: center !important;
  color: var(--fzm-muted);
  padding: 50px 16px !important;
  font-size: .9rem;
}

/* ── Pagination ──────────────────────────────── */
.fzm-pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 20px;
  flex-wrap: wrap;
  gap: 12px;
}

.fzm-page-info {
  font-size: .82rem;
  color: var(--fzm-muted);
}
.fzm-page-info strong { color: var(--fzm-text); }

.fzm-page-controls {
  display: flex; align-items: center; gap: 4px;
}

.fzm-page-btn {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 36px; height: 36px; padding: 0 8px;
  border-radius: var(--fzm-radius-sm);
  background: var(--fzm-surface2);
  border: 1px solid var(--fzm-border);
  color: var(--fzm-muted);
  font-family: var(--fzm-font); font-size: .82rem; font-weight: 600;
  cursor: pointer; transition: var(--fzm-transition);
}
.fzm-page-btn:hover:not(:disabled) { border-color: var(--fzm-accent); color: var(--fzm-accent); }
.fzm-page-btn.fzm-active { background: var(--fzm-accent); border-color: var(--fzm-accent); color: #fff; }
.fzm-page-btn:disabled { opacity: .35; cursor: not-allowed; }

.fzm-per-page {
  display: flex; align-items: center; gap: 8px;
  font-size: .82rem; color: var(--fzm-muted);
}
.fzm-per-page select {
  padding: 6px 10px;
  background: var(--fzm-surface2);
  border: 1px solid var(--fzm-border2);
  border-radius: var(--fzm-radius-sm);
  color: var(--fzm-text);
  font-family: var(--fzm-font); font-size: .82rem;
  outline: none; cursor: pointer;
}

/* ── Shortcode Info Bar ─────────────────────────── */
.fzm-shortcode-info {
  margin-top: 18px;
  padding: 12px 16px;
  background: var(--fzm-surface2);
  border: 1px solid var(--fzm-border2);
  border-radius: var(--fzm-radius-sm);
  font-size: .8rem;
  color: var(--fzm-muted);
}
.fzm-shortcode-info code {
  font-family: var(--fzm-mono);
  font-size: .78rem;
  color: var(--fzm-accent2);
  background: var(--fzm-surface3);
  padding: 2px 7px;
  border-radius: 4px;
}

/* ── Modal ───────────────────────────────────── */
.fzm-modal-overlay {
  display: none; position: fixed; inset: 0;
  background: rgba(0,0,0,.65);
  z-index: 99999; align-items: center; justify-content: center;
  padding: 16px; backdrop-filter: blur(6px);
}
.fzm-modal-overlay.fzm-active { display: flex; animation: fzmFadeIn .2s ease; }
@keyframes fzmFadeIn { from{opacity:0} to{opacity:1} }

.fzm-modal {
  background: var(--fzm-surface);
  border: 1px solid var(--fzm-border2);
  border-radius: var(--fzm-radius);
  box-shadow: var(--fzm-shadow-lg);
  width: 100%; max-width: 460px;
  animation: fzmSlideUp .25s ease; overflow: hidden;
}
.fzm-modal-sm { max-width: 400px; }
@keyframes fzmSlideUp { from{transform:translateY(20px);opacity:0} to{transform:translateY(0);opacity:1} }

.fzm-modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 24px 18px;
  border-bottom: 1px solid var(--fzm-border);
}
.fzm-modal-header h3 { font-size: 1rem; font-weight: 700; margin: 0; color: var(--fzm-text); }

.fzm-modal-close {
  background: var(--fzm-surface3); border: none;
  width: 28px; height: 28px; border-radius: 7px;
  font-size: 1rem; cursor: pointer; color: var(--fzm-muted);
  display: flex; align-items: center; justify-content: center;
  transition: var(--fzm-transition);
}
.fzm-modal-close:hover { background: rgba(248,113,113,.2); color: #f87171; }

.fzm-modal-body { padding: 24px; }
.fzm-modal-footer {
  display: flex; align-items: center; justify-content: flex-end;
  gap: 10px; padding: 16px 24px 20px;
  border-top: 1px solid var(--fzm-border);
}

.fzm-form-group { margin-bottom: 18px; }
.fzm-form-group:last-child { margin-bottom: 0; }
.fzm-form-group label {
  display: block; font-size: .75rem; font-weight: 600;
  color: var(--fzm-muted); margin-bottom: 7px;
  text-transform: uppercase; letter-spacing: .06em;
}
.fzm-required { color: var(--fzm-pink); }
.fzm-form-group input,
.fzm-form-group select {
  display: block;
  width: 100%;
  height: 44px;
  padding: 0 14px;
  background: var(--fzm-surface2);
  border: 1.5px solid var(--fzm-border2);
  border-radius: var(--fzm-radius-sm);
  color: var(--fzm-text);
  font-family: var(--fzm-font); font-size: .9rem; line-height: normal;
  outline: none; transition: var(--fzm-transition); box-sizing: border-box;
  vertical-align: middle;
}
.fzm-form-group select {
  cursor: pointer;
  appearance: none; -webkit-appearance: none; -moz-appearance: none;
  padding-right: 38px;
  background-color: var(--fzm-surface2);
  background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%238b90b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 12px center; background-size: 16px;
}
.fzm-form-group select::-ms-expand { display: none; }
.fzm-form-group select option { background: var(--fzm-surface2); color: var(--fzm-text); }
.fzm-form-group select.fzm-select-placeholder { color: var(--fzm-muted); }
.fzm-form-group input::placeholder { color: var(--fzm-muted); }
.fzm-form-group input:hover, .fzm-form-group select:hover { border-color: var(--fzm-accent2); }
.fzm-form-group input:focus, .fzm-form-group select:focus { border-color: var(--fzm-accent); box-shadow: 0 0 0 3px rgba(108,99,255,.2); background-color: var(--fzm-surface3); }
.fzm-form-group input.fzm-input-error, .fzm-form-group select.fzm-input-error { border-color: var(--fzm-error); box-shadow: 0 0 0 3px rgba(248,113,113,.15); }
.fzm-error { display: block; font-size: .75rem; color: var(--fzm-error); margin-top: 5px; min-height: 16px; }

/* ── Modal: Daftar Hapus Kolom ── */
.fzm-delete-column-list { display: flex; flex-direction: column; gap: 10px; max-height: 320px; overflow-y: auto; }
.fzm-delete-column-item {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 11px 14px;
  background: var(--fzm-surface2);
  border: 1.5px solid var(--fzm-border2);
  border-radius: var(--fzm-radius-sm);
}
.fzm-delete-column-item-label { color: var(--fzm-text); font-size: .9rem; font-weight: 500; word-break: break-word; }
.fzm-delete-column-item-btn {
  flex-shrink: 0;
  background: rgba(248,113,113,.12);
  color: var(--fzm-error);
  border: 1px solid rgba(248,113,113,.35);
  border-radius: var(--fzm-radius-sm);
  padding: 6px 14px;
  font-family: var(--fzm-font); font-size: .78rem; font-weight: 600;
  cursor: pointer; transition: var(--fzm-transition);
}
.fzm-delete-column-item-btn:hover { background: #ef4444; color: #fff; border-color: #ef4444; }
.fzm-delete-column-empty { color: var(--fzm-muted); font-size: .85rem; text-align: center; padding: 20px 0; margin: 0; }

.fzm-confirm-icon {
  width: 54px; height: 54px; border-radius: 50%;
  background: rgba(16,185,129,.15);
  color: #34d399; font-size: 1.4rem;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 16px; font-weight: 700;
}
.fzm-confirm-text { text-align: center; font-size: .9rem; color: var(--fzm-muted); line-height: 1.6; margin: 0 0 14px; }
.fzm-confirm-detail {
  background: var(--fzm-surface2); border: 1px solid var(--fzm-border2);
  border-radius: var(--fzm-radius-sm); padding: 12px 16px;
  font-size: .85rem; color: var(--fzm-text); line-height: 1.8;
  font-family: var(--fzm-mono);
}
.fzm-confirm-detail span { color: var(--fzm-muted); display: inline-block; min-width: 55px; font-size:.75rem; }

/* ── Toast ───────────────────────────────────── */
.fzm-toast {
  position: fixed; bottom: 28px; right: 28px;
  background: var(--fzm-surface2);
  border: 1px solid var(--fzm-border2);
  color: var(--fzm-text);
  padding: 13px 20px; border-radius: var(--fzm-radius-sm);
  font-family: var(--fzm-font); font-size: .875rem; font-weight: 500;
  box-shadow: var(--fzm-shadow-lg);
  z-index: 999999; display: none; align-items: center; gap: 10px;
  max-width: 320px;
}
.fzm-toast.fzm-toast-success { border-left: 3px solid #34d399; }
.fzm-toast.fzm-toast-error   { border-left: 3px solid #f87171; }
.fzm-toast.fzm-show { display: flex; animation: fzmSlideIn .25s ease; }
@keyframes fzmSlideIn { from{transform:translateX(30px);opacity:0} to{transform:translateX(0);opacity:1} }

/* ── Loading ─────────────────────────────────── */
.fzm-btn.fzm-loading { opacity: .65; pointer-events: none; }
.fzm-btn.fzm-loading::after {
  content: ''; width: 13px; height: 13px;
  border: 2px solid rgba(255,255,255,.3);
  border-top-color: #fff; border-radius: 50%;
  animation: fzmSpin .6s linear infinite; margin-left: 4px;
}
@keyframes fzmSpin { to{transform:rotate(360deg)} }


/* ── Responsive ──────────────────────────────── */
@media (max-width: 768px) {
  .fzm-wrapper { padding: 16px; }
  .fzm-table { font-size: .78rem; }
  .fzm-table th, .fzm-table td { padding: 11px 10px; }
  .fzm-header { flex-direction: column; align-items: flex-start; }
  .fzm-header-actions { width: 100%; }
  .fzm-header-actions .fzm-btn { flex: 1; justify-content: center; font-size: .8rem; padding: 9px 12px; }
}

@media (max-width: 520px) {
  .fzm-header-actions { flex-direction: column; }
  .fzm-header-actions .fzm-btn { width: 100%; }
}

/* ═══════════════════════════════════════════════
   VIEW (READ-ONLY) THEME — [fzdata_view]
   Background putih/clear, teks hitam, table jelas
   di atas background putih. Tidak memengaruhi
   tampilan admin/CRUD [fzdata_master] (tetap dark).
═══════════════════════════════════════════════ */
.fzm-wrapper-view {
  --fzm-bg:           #ffffff;
  --fzm-surface:      #ffffff;
  --fzm-surface2:     #f4f5f8;
  --fzm-surface3:     #ebedf2;
  --fzm-border:       rgba(0,0,0,.08);
  --fzm-border2:      rgba(0,0,0,.14);
  --fzm-text:         #171923;
  --fzm-muted:        #5b6072;
  --fzm-accent2:      #7c5cff;
  --fzm-row-hover:    rgba(108,99,255,.06);
  --fzm-shadow:       0 2px 14px rgba(0,0,0,.08);
  --fzm-shadow-lg:    0 10px 30px rgba(0,0,0,.12);
}

/* Wrapper itself: clear/transparent so it blends with page background */
.fzm-wrapper-view {
  background: transparent;
}

/* Matikan glow blobs dekoratif dark-theme agar tidak terlihat aneh di atas putih */
.fzm-wrapper-view::before,
.fzm-wrapper-view::after {
  display: none;
}

/* Table container tampil jelas di atas background putih dengan border tipis */
.fzm-wrapper-view .fzm-table-container {
  background: #ffffff;
  border: 1px solid var(--fzm-border2);
}

.fzm-wrapper-view .fzm-table thead tr {
  background: #f4f5f8;
}

.fzm-wrapper-view .fzm-table tbody tr:hover td {
  background: var(--fzm-row-hover);
}

/* Rapikan toolbar (search, filter kategori, tampilkan X data) agar sejajar & konsisten.
   !important dipakai secara terbatas di sini untuk mengalahkan gaya bawaan tema
   WordPress pada elemen input/select (border, box-shadow, margin, dsb). */
.fzm-toolbar-view {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
  margin-bottom: 20px !important;
}

.fzm-toolbar-view input,
.fzm-toolbar-view select {
  margin: 0 !important;
  box-sizing: border-box !important;
  font-family: var(--fzm-font) !important;
  line-height: normal !important;
  vertical-align: middle !important;
  box-shadow: none !important;
}

/* Search box — mengambil porsi lebar terbesar, sejajar dengan kontrol lain */
.fzm-toolbar-view .fzm-search-wrap {
  flex: 1 1 280px;
  max-width: 420px;
  min-width: 200px;
}
.fzm-toolbar-view .fzm-search {
  height: 42px !important;
  width: 100% !important;
  padding: 0 16px !important;
  border-radius: 10px !important;
  border: 1px solid var(--fzm-border2) !important;
  background-color: var(--fzm-surface2) !important;
  color: var(--fzm-text) !important;
  font-size: .88rem !important;
}
.fzm-toolbar-view .fzm-search:focus {
  border-color: var(--fzm-accent) !important;
  box-shadow: 0 0 0 3px rgba(108,99,255,.15) !important;
}

/* Filter kategori — tinggi & radius sama persis dengan search */
.fzm-toolbar-view .fzm-filter-wrap {
  flex: 0 0 auto;
}
.fzm-toolbar-view .fzm-filter-wrap select {
  height: 42px !important;
  min-width: 170px;
  padding: 0 36px 0 16px !important;
  border-radius: 10px !important;
  border: 1px solid var(--fzm-border2) !important;
  background-color: var(--fzm-surface2) !important;
  color: var(--fzm-text) !important;
  font-size: .88rem !important;
  cursor: pointer;
}

/* Tampilkan X data — label & select sejajar rapi dalam satu baris */
.fzm-toolbar-view .fzm-per-page {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  height: 42px;
  flex: 0 0 auto;
  white-space: nowrap;
  color: var(--fzm-muted);
  font-size: .85rem;
}
.fzm-toolbar-view .fzm-per-page select {
  height: 38px !important;
  padding: 0 30px 0 14px !important;
  border-radius: 8px !important;
  border: 1px solid var(--fzm-border2) !important;
  background-color: var(--fzm-surface2) !important;
  color: var(--fzm-text) !important;
  font-size: .85rem !important;
  outline: none;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%238b8fa3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  background-size: 13px;
  transition: var(--fzm-transition);
}
.fzm-toolbar-view .fzm-per-page select:focus,
.fzm-toolbar-view .fzm-filter-wrap select:focus {
  border-color: var(--fzm-accent) !important;
  box-shadow: 0 0 0 3px rgba(108,99,255,.15) !important;
}

/* Susun ulang jadi vertikal rapi di layar kecil */
@media (max-width: 640px) {
  .fzm-toolbar-view {
    flex-direction: column;
    align-items: stretch;
  }
  .fzm-toolbar-view .fzm-search-wrap {
    max-width: none;
    width: 100%;
  }
  .fzm-toolbar-view .fzm-filter-wrap select {
    width: 100%;
  }
  .fzm-toolbar-view .fzm-per-page {
    justify-content: space-between;
    width: 100%;
  }
}

/* ═══════════════════════════════════════════════
   ADMIN — Panel Edit Judul [fzdata_view]
   Tampil di halaman admin (di atas tabel CRUD),
   mengikuti gaya default WP admin (terang).
═══════════════════════════════════════════════ */
.fzm-view-title-panel {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px;
  background: #ffffff;
  border: 1px solid #dcdcde;
  border-radius: 8px;
  padding: 16px 20px;
  margin: 0 0 20px;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

.fzm-view-title-panel-label {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.fzm-view-title-panel-label strong {
  font-size: .95rem;
  color: #1d2327;
}
.fzm-view-title-panel-label strong code {
  background: #f0f0f1;
  padding: 2px 6px;
  border-radius: 4px;
  font-size: .85rem;
}
.fzm-view-title-panel-desc {
  font-size: .8rem;
  color: #646970;
}

.fzm-view-title-panel-controls {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.fzm-view-title-panel-controls input[type="text"] {
  height: 38px;
  padding: 0 12px;
  border: 1px solid #c3c4c7;
  border-radius: 6px;
  font-size: .88rem;
  min-width: 220px;
  box-sizing: border-box;
}
.fzm-view-title-panel-controls input[type="text"]:focus {
  outline: none;
  border-color: #6c63ff;
  box-shadow: 0 0 0 3px rgba(108,99,255,.15);
}
.fzm-view-title-panel-controls .fzm-btn {
  height: 38px;
  padding: 0 20px;
}
.fzm-view-title-status {
  font-size: .82rem;
  font-weight: 600;
}
.fzm-view-title-status.fzm-status-success { color: #059669; }
.fzm-view-title-status.fzm-status-error   { color: #ef4444; }
