/* ── Variables ─────────────────────────────────────────────────────────────── */
:root {
  --gold:      #D4AF37;
  --gold-lt:   #F5D47F;
  --gold-dk:   #A88A1E;
  --black:     #0A0A0A;
  --surface:   #141414;
  --surface2:  #1E1E1E;
  --surface3:  #282828;
  --border:    #2A2A2A;
  --text:      #F0F0F0;
  --text-muted:#888;
  --red:       #E05555;
  --green:     #4CAF82;
  --sidebar-w: 230px;
}

/* ── Reset ─────────────────────────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
body { font-family:'Inter',sans-serif; background:var(--black); color:var(--text); font-size:14px; line-height:1.5; }
a { color:var(--gold); text-decoration:none; }
button { cursor:pointer; border:none; background:none; font-family:inherit; font-size:inherit; }
input,select,textarea { font-family:inherit; font-size:inherit; }
table { border-collapse:collapse; width:100%; }

/* ── Logo ──────────────────────────────────────────────────────────────────── */
.logo-t    { color:var(--gold); font-size:1.4em; font-weight:700; letter-spacing:-1px; }
.logo-rest { color:var(--text); font-size:1.1em; font-weight:600; letter-spacing:3px; }

/* ── LOGIN ─────────────────────────────────────────────────────────────────── */
#login-screen {
  min-height:100vh; display:flex; align-items:center; justify-content:center;
  background: radial-gradient(ellipse at 50% 40%, #1a1500 0%, var(--black) 70%);
}
.login-box {
  background:var(--surface); border:1px solid var(--border);
  border-top:2px solid var(--gold);
  border-radius:12px; padding:40px 36px; width:380px;
  box-shadow: 0 24px 60px rgba(0,0,0,0.6), 0 0 40px rgba(212,175,55,0.08);
}
.login-logo { text-align:center; font-size:1.8rem; letter-spacing:2px; margin-bottom:6px; }
.login-sub  { text-align:center; color:var(--text-muted); font-size:0.8rem; letter-spacing:4px; text-transform:uppercase; margin-bottom:32px; }
.field { margin-bottom:18px; }
.field label { display:block; color:var(--text-muted); font-size:0.75rem; letter-spacing:1px; text-transform:uppercase; margin-bottom:6px; }
.field input {
  width:100%; background:var(--surface2); border:1px solid var(--border);
  border-radius:7px; padding:10px 14px; color:var(--text);
  transition:border-color .2s;
}
.field input:focus { outline:none; border-color:var(--gold); }
.login-error { color:var(--red); font-size:0.82rem; min-height:20px; margin-bottom:10px; text-align:center; }

/* ── Buttons ───────────────────────────────────────────────────────────────── */
.btn-gold {
  background: linear-gradient(135deg, var(--gold-dk), var(--gold), var(--gold-lt));
  color:#000; font-weight:600; border-radius:7px; padding:10px 20px;
  transition:opacity .2s, transform .1s; letter-spacing:.5px;
}
.btn-gold:hover { opacity:.9; }
.btn-gold:active { transform:scale(.98); }
.btn-outline {
  background:transparent; border:1px solid var(--border); color:var(--text-muted);
  border-radius:7px; padding:8px 16px; transition:border-color .2s, color .2s;
}
.btn-outline:hover { border-color:var(--gold); color:var(--gold); }
.btn-danger { background:var(--red); color:#fff; border-radius:7px; padding:8px 16px; transition:opacity .2s; }
.btn-danger:hover { opacity:.85; }
.btn-sm { padding:5px 12px; font-size:0.8rem; }
.w-full { width:100%; display:block; text-align:center; }

/* ── SIDEBAR ───────────────────────────────────────────────────────────────── */
#sidebar {
  position:fixed; top:0; left:0; bottom:0; width:var(--sidebar-w);
  background:var(--surface); border-right:1px solid var(--border);
  display:flex; flex-direction:column; z-index:100;
}
.sidebar-logo {
  padding:22px 20px 18px; border-bottom:1px solid var(--border);
  font-size:1.1rem; letter-spacing:1px;
}
#sidebar-nav { flex:1; overflow-y:auto; padding:10px 0; }
.nav-group-title {
  padding:10px 20px 4px; font-size:0.68rem; letter-spacing:2px;
  text-transform:uppercase; color:var(--text-muted);
}
.nav-item {
  display:flex; align-items:center; gap:10px;
  padding:9px 20px; width:100%; color:var(--text-muted);
  transition:background .15s, color .15s; font-size:0.87rem;
}
.nav-item:hover { background:var(--surface2); color:var(--text); }
.nav-item.active { background:rgba(212,175,55,0.12); color:var(--gold); border-right:2px solid var(--gold); }
.nav-icon { font-size:1rem; width:20px; text-align:center; }
.sidebar-footer { padding:16px; border-top:1px solid var(--border); }

/* ── TOPBAR ────────────────────────────────────────────────────────────────── */
#main { margin-left:var(--sidebar-w); min-height:100vh; display:flex; flex-direction:column; }
#topbar {
  position:sticky; top:0; background:var(--surface); border-bottom:1px solid var(--border);
  padding:14px 28px; display:flex; align-items:center; justify-content:space-between;
  z-index:50;
}
#breadcrumb { font-size:0.9rem; color:var(--text-muted); }
#breadcrumb span { color:var(--gold); font-weight:500; }
#user-info { font-size:0.82rem; color:var(--text-muted); }
#content { padding:28px; flex:1; }

/* ── STAT CARDS ────────────────────────────────────────────────────────────── */
.stat-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:16px; margin-bottom:28px; }
.stat-card {
  background:var(--surface); border:1px solid var(--border); border-radius:10px;
  padding:20px; position:relative; overflow:hidden; transition:border-color .2s;
}
.stat-card:hover { border-color:var(--gold); }
.stat-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,var(--gold-dk),var(--gold),var(--gold-lt));
}
.stat-label { font-size:0.72rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-muted); margin-bottom:10px; }
.stat-value { font-size:2rem; font-weight:700; color:var(--gold); line-height:1; }
.stat-sub { font-size:0.78rem; color:var(--text-muted); margin-top:6px; }

/* ── CHART ─────────────────────────────────────────────────────────────────── */
.chart-card {
  background:var(--surface); border:1px solid var(--border); border-radius:10px;
  padding:20px; margin-bottom:28px;
}
.chart-title { font-size:0.8rem; letter-spacing:2px; text-transform:uppercase; color:var(--text-muted); margin-bottom:16px; }
.chart-card canvas { max-height:260px; }

/* ── PAGE HEADER ───────────────────────────────────────────────────────────── */
.page-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:20px; }
.page-title { font-size:1.2rem; font-weight:600; }
.page-actions { display:flex; gap:10px; align-items:center; }

/* ── SEARCH/FILTER BAR ─────────────────────────────────────────────────────── */
.filter-bar { display:flex; gap:10px; margin-bottom:16px; flex-wrap:wrap; }
.search-input {
  background:var(--surface2); border:1px solid var(--border); border-radius:7px;
  padding:8px 14px; color:var(--text); width:240px; transition:border-color .2s;
}
.search-input:focus { outline:none; border-color:var(--gold); }
.filter-select {
  background:var(--surface2); border:1px solid var(--border); border-radius:7px;
  padding:8px 12px; color:var(--text); transition:border-color .2s;
}
.filter-select:focus { outline:none; border-color:var(--gold); }

/* ── TABLE ─────────────────────────────────────────────────────────────────── */
.table-wrap {
  background:var(--surface); border:1px solid var(--border); border-radius:10px; overflow:hidden;
}
thead tr { background:var(--surface2); border-bottom:1px solid var(--border); }
thead th { padding:12px 16px; text-align:left; font-size:0.72rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-muted); font-weight:500; white-space:nowrap; }
tbody tr { border-bottom:1px solid var(--border); transition:background .15s; }
tbody tr:last-child { border-bottom:none; }
tbody tr:hover { background:var(--surface2); }
tbody td { padding:12px 16px; color:var(--text); vertical-align:middle; }
.td-actions { display:flex; gap:6px; }

/* ── BADGES ────────────────────────────────────────────────────────────────── */
.badge { display:inline-block; padding:2px 9px; border-radius:20px; font-size:0.72rem; font-weight:500; }
.badge-active  { background:rgba(76,175,130,.15); color:var(--green); border:1px solid rgba(76,175,130,.3); }
.badge-inactive{ background:rgba(224,85,85,.1);   color:var(--red);   border:1px solid rgba(224,85,85,.25); }
.badge-pending { background:rgba(212,175,55,.1);  color:var(--gold);  border:1px solid rgba(212,175,55,.3); }
.badge-gold    { background:rgba(212,175,55,.15); color:var(--gold);  border:1px solid rgba(212,175,55,.4); }

/* ── PAGINATION ────────────────────────────────────────────────────────────── */
.pagination { display:flex; align-items:center; justify-content:space-between; padding:14px 16px; border-top:1px solid var(--border); }
.pagination-info { font-size:0.8rem; color:var(--text-muted); }
.pagination-btns { display:flex; gap:4px; }
.pg-btn {
  background:var(--surface2); border:1px solid var(--border); color:var(--text-muted);
  border-radius:5px; padding:5px 11px; font-size:0.82rem; transition:all .15s;
}
.pg-btn:hover:not(:disabled) { border-color:var(--gold); color:var(--gold); }
.pg-btn.active { background:var(--gold); color:#000; border-color:var(--gold); font-weight:600; }
.pg-btn:disabled { opacity:.4; cursor:not-allowed; }

/* ── MODAL ─────────────────────────────────────────────────────────────────── */
#modal-overlay {
  position:fixed; inset:0; background:rgba(0,0,0,.75); backdrop-filter:blur(4px);
  display:none; align-items:center; justify-content:center; z-index:500;
}
#modal-overlay.open { display:flex; }
#modal-box {
  background:var(--surface); border:1px solid var(--border); border-top:2px solid var(--gold);
  border-radius:12px; width:520px; max-width:95vw; max-height:90vh;
  display:flex; flex-direction:column; box-shadow:0 30px 80px rgba(0,0,0,.7);
  animation:slideUp .2s ease;
}
@keyframes slideUp { from { transform:translateY(20px); opacity:0; } to { transform:translateY(0); opacity:1; } }
#modal-header { display:flex; align-items:center; justify-content:space-between; padding:18px 22px; border-bottom:1px solid var(--border); }
#modal-title  { font-size:1rem; font-weight:600; }
.modal-close  { color:var(--text-muted); font-size:1.1rem; transition:color .15s; }
.modal-close:hover { color:var(--red); }
#modal-body   { padding:22px; overflow-y:auto; flex:1; }
#modal-footer { padding:16px 22px; border-top:1px solid var(--border); display:flex; justify-content:flex-end; gap:10px; }
.modal-field  { margin-bottom:16px; }
.modal-field label { display:block; font-size:0.75rem; letter-spacing:1px; text-transform:uppercase; color:var(--text-muted); margin-bottom:6px; }
.modal-field input,
.modal-field select,
.modal-field textarea {
  width:100%; background:var(--surface2); border:1px solid var(--border);
  border-radius:7px; padding:9px 13px; color:var(--text); transition:border-color .2s;
}
.modal-field input:focus,
.modal-field select:focus,
.modal-field textarea:focus { outline:none; border-color:var(--gold); }
.modal-field textarea { resize:vertical; min-height:80px; }
.modal-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
/* Quill editor inside modal */
.modal-field .ql-toolbar { border-radius:7px 7px 0 0; border-color:var(--border) !important; background:#f8f8f8; }
.modal-field .ql-container { border-radius:0 0 7px 7px; border-color:var(--border) !important; background:#fff; color:#111; font-size:0.9rem; }
.modal-field .ql-editor { min-height:160px; }
.modal-field .ql-editor img { max-width:100%; height:auto; border-radius:4px; margin:4px 0; }

/* ── TOAST ─────────────────────────────────────────────────────────────────── */
#toast { position:fixed; bottom:24px; right:24px; display:flex; flex-direction:column; gap:8px; z-index:999; }
.toast {
  background:var(--surface2); border:1px solid var(--border); border-left:3px solid var(--gold);
  border-radius:8px; padding:12px 18px; font-size:0.85rem; color:var(--text);
  box-shadow:0 8px 24px rgba(0,0,0,.5); animation:toastIn .25s ease;
  min-width:240px;
}
.toast.error { border-left-color:var(--red); }
.toast.success { border-left-color:var(--green); }
@keyframes toastIn { from { transform:translateX(20px); opacity:0; } to { transform:translateX(0); opacity:1; } }

/* ── EMPTY STATE ───────────────────────────────────────────────────────────── */
.empty-state { text-align:center; padding:60px 20px; color:var(--text-muted); }
.empty-state .empty-icon { font-size:2.5rem; margin-bottom:12px; opacity:.4; }
.empty-state p { font-size:0.9rem; }

/* ── LOADING ───────────────────────────────────────────────────────────────── */
.loading { text-align:center; padding:60px; color:var(--text-muted); }
.spinner { display:inline-block; width:28px; height:28px; border:2px solid var(--border); border-top-color:var(--gold); border-radius:50%; animation:spin .7s linear infinite; margin-bottom:10px; }
@keyframes spin { to { transform:rotate(360deg); } }

/* ── PENDING CARDS ─────────────────────────────────────────────────────────── */
.pending-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:14px; margin-bottom:28px; }
.pending-card {
  background:var(--surface); border:1px solid var(--border); border-radius:10px;
  padding:18px; display:flex; flex-direction:column; align-items:center; gap:8px;
  cursor:pointer; transition:border-color .2s, background .2s;
}
.pending-card:hover { border-color:var(--gold); background:var(--surface2); }
.pending-count { font-size:2.2rem; font-weight:700; color:var(--red); }
.pending-label { font-size:0.75rem; color:var(--text-muted); text-align:center; }

/* ── SCROLLBAR ─────────────────────────────────────────────────────────────── */
::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--border); border-radius:4px; }
::-webkit-scrollbar-thumb:hover { background:var(--gold-dk); }

/* ── DETAIL VIEW ───────────────────────────────────────────────────────────── */
.detail-list { display:flex; flex-direction:column; }
.detail-item { display:flex; align-items:flex-start; gap:16px; padding:10px 0; border-bottom:1px solid var(--border); }
.detail-item:last-child { border-bottom:none; }
.detail-item label { min-width:160px; flex-shrink:0; font-size:0.72rem; letter-spacing:1px; text-transform:uppercase; color:var(--text-muted); padding-top:2px; }
.detail-item p { color:var(--text); word-break:break-all; line-height:1.6; }
