/* ============================================================
   e-PRP USM DEMO - style.css
   Tema warna USM
   ============================================================ */
:root{
  --primary:#4B146C; --primary-dark:#35104D; --gold:#C89B3C;
  --bg:#F6F7FB; --card:#FFFFFF; --text:#1F2937; --muted:#6B7280;
  --border:#E5E7EB; --success:#15803D; --warning:#D97706;
  --danger:#B91C1C; --info:#2563EB;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  background:var(--bg);color:var(--text);line-height:1.5;font-size:15px}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}

/* ---------- Topbar ---------- */
.topbar{background:var(--primary);color:#fff;height:60px;display:flex;align-items:center;
  justify-content:space-between;padding:0 20px;position:sticky;top:0;z-index:50;
  box-shadow:0 2px 8px rgba(0,0,0,.15)}
.topbar .brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:18px;color:#fff}
.topbar .brand .logo{background:var(--gold);color:var(--primary-dark);width:34px;height:34px;
  border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:800}
.topbar .user{display:flex;align-items:center;gap:14px;font-size:14px}
.topbar .user .role-tag{background:rgba(255,255,255,.15);padding:4px 10px;border-radius:20px;font-size:12px}
.topbar .user a{color:#fff;opacity:.9}

/* ---------- Demo banner ---------- */
.demo-banner{background:var(--gold);color:var(--primary-dark);text-align:center;
  font-size:12.5px;font-weight:600;padding:6px 12px}

/* ---------- Layout ---------- */
.layout{display:flex;min-height:calc(100vh - 60px)}
.sidebar{width:240px;background:var(--primary-dark);color:#cbb8da;padding:18px 0;flex-shrink:0}
.sidebar .menu-title{font-size:11px;text-transform:uppercase;letter-spacing:.5px;
  color:#9b86b3;padding:10px 20px 6px}
.sidebar a{display:block;color:#e3d9ee;padding:11px 20px;font-size:14px;border-left:3px solid transparent}
.sidebar a:hover{background:rgba(255,255,255,.06);text-decoration:none}
.sidebar a.active{background:rgba(200,155,60,.18);border-left-color:var(--gold);color:#fff;font-weight:600}
.content{flex:1;padding:26px 30px;max-width:100%;overflow-x:auto}
.content.full{max-width:1100px;margin:0 auto}

/* ---------- Headings ---------- */
.page-title{font-size:22px;font-weight:700;color:var(--primary-dark);margin-bottom:4px}
.page-sub{color:var(--muted);font-size:14px;margin-bottom:22px}

/* ---------- Cards ---------- */
.card{background:var(--card);border:1px solid var(--border);border-radius:12px;
  padding:22px;margin-bottom:20px;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.card h3{font-size:16px;color:var(--primary-dark);margin-bottom:14px}
.grid{display:grid;gap:18px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}

/* ---------- Stat cards ---------- */
.stat{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:18px 20px}
.stat .num{font-size:30px;font-weight:800;color:var(--primary)}
.stat .lbl{color:var(--muted);font-size:13px;margin-top:2px}
.stat.accent{border-top:3px solid var(--gold)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border:none;border-radius:8px;
  font-size:14px;font-weight:600;cursor:pointer;transition:.15s;text-decoration:none}
.btn:hover{opacity:.9;text-decoration:none}
.btn-primary{background:var(--primary);color:#fff}
.btn-gold{background:var(--gold);color:var(--primary-dark)}
.btn-success{background:var(--success);color:#fff}
.btn-danger{background:var(--danger);color:#fff}
.btn-warning{background:var(--warning);color:#fff}
.btn-info{background:var(--info);color:#fff}
.btn-outline{background:#fff;border:1px solid var(--border);color:var(--text)}
.btn-sm{padding:6px 12px;font-size:13px}
.btn-block{width:100%;justify-content:center}

/* ---------- Badges ---------- */
.badge{display:inline-block;padding:4px 11px;border-radius:20px;font-size:12px;font-weight:600}
.badge-success{background:#dcfce7;color:var(--success)}
.badge-danger{background:#fee2e2;color:var(--danger)}
.badge-warning{background:#fef3c7;color:var(--warning)}
.badge-info{background:#dbeafe;color:var(--info)}
.badge-muted{background:#f3f4f6;color:var(--muted)}

/* ---------- Tables ---------- */
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--border)}
th{background:#faf7fc;color:var(--primary-dark);font-size:12.5px;text-transform:uppercase;letter-spacing:.3px}
tr:hover td{background:#fafafa}

/* ---------- Forms ---------- */
.form-group{margin-bottom:16px}
label{display:block;margin-bottom:6px;font-weight:600;font-size:13.5px;color:#374151}
input,select,textarea{width:100%;padding:10px 12px;border:1px solid var(--border);
  border-radius:8px;font-size:14px;font-family:inherit;background:#fff}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(75,20,108,.12)}
textarea{min-height:90px;resize:vertical}
.help{font-size:12.5px;color:var(--muted);margin-top:4px}

/* ---------- Stepper ---------- */
.stepper{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:24px}
.stepper .step{flex:1;min-width:90px;text-align:center;padding:10px 6px;border-radius:8px;
  background:#f3f0f7;color:var(--muted);font-size:12.5px;font-weight:600;border:1px solid var(--border)}
.stepper .step.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.stepper .step.done{background:#e9e1f2;color:var(--primary)}

/* ---------- Timeline ---------- */
.timeline{list-style:none;padding-left:6px}
.timeline li{position:relative;padding:0 0 22px 28px;border-left:2px solid var(--border)}
.timeline li:last-child{border-left-color:transparent}
.timeline li .dot{position:absolute;left:-9px;top:0;width:16px;height:16px;border-radius:50%;
  background:#fff;border:3px solid var(--border)}
.timeline li.done .dot{border-color:var(--success);background:var(--success)}
.timeline li.current .dot{border-color:var(--gold);background:var(--gold)}
.timeline li .tl-title{font-weight:600;font-size:14px}
.timeline li .tl-time{font-size:12px;color:var(--muted)}

/* ---------- Alerts / Toast ---------- */
.alert{padding:12px 16px;border-radius:8px;font-size:14px;margin-bottom:18px}
.alert-info{background:#dbeafe;color:#1e40af}
.alert-success{background:#dcfce7;color:#166534}
.alert-warning{background:#fef3c7;color:#92400e}
.alert-danger{background:#fee2e2;color:#991b1b}
.toast{position:fixed;top:74px;right:20px;z-index:100;min-width:260px;padding:14px 18px;
  border-radius:10px;color:#fff;box-shadow:0 6px 20px rgba(0,0,0,.2);animation:slidein .3s}
.toast.success{background:var(--success)} .toast.danger{background:var(--danger)}
.toast.info{background:var(--info)}
@keyframes slidein{from{transform:translateX(40px);opacity:0}to{transform:none;opacity:1}}

/* ---------- Modal ---------- */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200;
  align-items:flex-start;justify-content:center;padding:40px 16px;overflow:auto}
.modal-overlay.open{display:flex}
.modal{background:#fff;border-radius:12px;width:100%;max-width:560px;padding:24px}
.modal h3{margin-bottom:14px;color:var(--primary-dark)}
.modal .modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:18px}

/* ---------- Misc ---------- */
.kv{display:grid;grid-template-columns:200px 1fr;gap:8px 16px;font-size:14px}
.kv .k{color:var(--muted)}
.smup-note{background:#f0fdf4;border:1px dashed var(--success);color:#166534;
  padding:8px 12px;border-radius:8px;font-size:12.5px;margin-bottom:14px}
.flex{display:flex;align-items:center;gap:10px}
.between{justify-content:space-between}
.mt{margin-top:16px}.mb{margin-bottom:16px}
.text-muted{color:var(--muted)}.text-right{text-align:right}

/* ---------- Responsive ---------- */
@media(max-width:860px){
  .grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}
  .sidebar{width:100%;display:flex;flex-wrap:wrap;padding:8px}
  .sidebar .menu-title{display:none}
  .sidebar a{border-left:none;border-radius:6px;padding:8px 12px}
  .layout{flex-direction:column}
  .kv{grid-template-columns:1fr}
  .content{padding:18px 14px}
}
@media(max-width:560px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}
