/* ===============================
   RESET & BASE
================================ */
*{box-sizing:border-box;font-family:Inter,Segoe UI,system-ui,sans-serif}
body{margin:0;background:#F4F7FB;color:#1F2937;font-size:14px}

/* ===============================
   THEME
================================ */
:root{
  --primary:#2563EB;
  --accent:#F59E0B;
  --danger:#DC2626;
  --white:#FFFFFF;
  --dark:#1F2937;
  --muted:#6B7280;
  --border:#E5E7EB;
}

/* ===============================
   LAYOUT
================================ */
.dashboard{max-width:720px;margin:auto;padding:16px}
.container{max-width:420px;margin:60px auto;background:#fff;border-radius:16px;padding:24px;box-shadow:0 20px 40px rgba(0,0,0,.08)}
.card{background:#fff;border-radius:16px;padding:18px;margin-bottom:16px;box-shadow:0 12px 30px rgba(0,0,0,.06)}

/* ===============================
   HEADER / BADGE
================================ */
.user-card{display:flex;justify-content:space-between;align-items:center}
.badge-primary{background:var(--primary);color:#fff;padding:6px 12px;border-radius:999px;font-size:12px;font-weight:600}

/* ===============================
   TYPO
================================ */
h3{margin:0 0 6px}
small{color:var(--muted)}
.section-title{margin:0 0 14px;font-size:15px;color:var(--muted)}

/* ===============================
   FORM
================================ */
.form-group{margin-bottom:16px}
label{display:block;font-size:13px;margin-bottom:6px;color:var(--muted)}
input,select{width:100%;padding:14px;border-radius:10px;border:1px solid var(--border);font-size:14px}
input:focus,select:focus{outline:none;border-color:var(--primary)}

/* ===============================
   BUTTON
================================ */
.btn{padding:14px;border-radius:10px;border:none;font-size:15px;font-weight:600;cursor:pointer}
.btn-primary{background:var(--primary);color:#fff}
.btn-accent{background:var(--accent);color:#fff}
.btn-danger{background:#FEE2E2;color:var(--danger)}
.btn-sm{padding:6px 10px;font-size:12px;border-radius:8px;text-decoration:none}

/* ===============================
   MENU GRID
================================ */
.menu-grid{display:grid;grid-template-columns:1fr;gap:12px}
.menu-item{display:flex;gap:14px;align-items:center;padding:14px;border-radius:14px;background:#F8FAFC;text-decoration:none;color:var(--dark);transition:.2s}
.menu-item span{font-size:22px}
.menu-item strong{display:block}
.menu-item small{color:var(--muted)}
.menu-item:hover{background:var(--primary);color:#fff}
.menu-item:hover small{color:#E0E7FF}
.menu-item.logout{background:#FEE2E2;color:var(--danger)}

/* ===============================
   SEARCH BAR
================================ */
.search-bar{display:flex;gap:8px;margin:14px 0}
.search-bar input{flex:1}

/* ===============================
   TABLE MODERN
================================ */
.table-wrapper{overflow-x:auto}
.table-card{width:100%;border-collapse:collapse}
.table-card thead th{font-size:12px;text-transform:uppercase;color:var(--muted);padding:12px;text-align:left;border-bottom:2px solid var(--border)}
.table-card tbody td{padding:14px 12px;border-bottom:1px solid var(--border)}
.table-card tbody tr:hover{background:#F8FAFC}

/* MOBILE TABLE */
@media(max-width:600px){
  .table-card thead{display:none}
  .table-card tr{display:block;margin-bottom:12px;background:#fff;border-radius:14px;box-shadow:0 8px 20px rgba(0,0,0,.05);padding:10px}
  .table-card td{display:flex;justify-content:space-between;border:none;padding:8px 10px}
  .table-card td::before{content:attr(data-label);font-size:12px;color:var(--muted);font-weight:600}
}

.badge-active{
  background:#16a34a;
  color:#fff;
  padding:6px 14px;
  border-radius:999px;
  font-size:12px;
  font-weight:700;
}

.role-nonaktif .badge-active{
  background:#9ca3af;
}
