/* payrollmanager client — reusable component styles. One home per visual element. */

/* Card */
.pm-card {
  background: var(--pm-surface);
  border: 1px solid var(--pm-border);
  border-radius: var(--pm-radius);
  box-shadow: var(--pm-shadow-sm);
  padding: var(--pm-sp-5);
}
.pm-card-title { font-size: var(--pm-fs-lg); font-weight: 600; margin-bottom: var(--pm-sp-4); }

/* Buttons */
.pm-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--pm-sp-2);
  font: inherit; font-weight: 600; cursor: pointer;
  padding: 9px 16px; border-radius: var(--pm-radius-sm);
  border: 1px solid var(--pm-border); background: var(--pm-surface-2); color: var(--pm-text);
  transition: filter .15s, background .15s, border-color .15s;
}
.pm-btn:hover { filter: brightness(1.12); }
.pm-btn:disabled { opacity: .5; cursor: not-allowed; }
.pm-btn.primary { background: linear-gradient(135deg, var(--pm-accent), var(--pm-accent-600)); border-color: transparent; color: #04201c; }
.pm-btn.ghost { background: transparent; }
.pm-btn.danger { background: transparent; border-color: var(--pm-danger); color: var(--pm-danger); }
.pm-btn.sm { padding: 5px 10px; font-size: var(--pm-fs-sm); }

/* Inputs */
.pm-field { display: flex; flex-direction: column; gap: 6px; }
.pm-label { font-size: var(--pm-fs-sm); color: var(--pm-text-muted); font-weight: 500; }
.pm-input, .pm-select, .pm-textarea {
  width: 100%; font: inherit; color: var(--pm-text);
  background: var(--pm-bg-elev); border: 1px solid var(--pm-border);
  border-radius: var(--pm-radius-sm); padding: 9px 12px; outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.pm-input:focus, .pm-select:focus, .pm-textarea:focus {
  border-color: var(--pm-accent); box-shadow: 0 0 0 3px var(--pm-accent-soft);
}

/* Table */
.pm-table { width: 100%; border-collapse: collapse; font-size: var(--pm-fs-sm); }
.pm-table th, .pm-table td { text-align: left; padding: 11px 14px; border-bottom: 1px solid var(--pm-border); }
.pm-table th { color: var(--pm-text-muted); font-weight: 600; text-transform: uppercase; font-size: var(--pm-fs-xs); letter-spacing: .4px; }
.pm-table tbody tr:hover { background: var(--pm-surface-2); }
.pm-table .empty { text-align: center; color: var(--pm-text-faint); padding: var(--pm-sp-6); }

/* Badge / pill (leave status etc.) */
.pm-badge { display: inline-flex; align-items: center; gap: 6px; font-size: var(--pm-fs-xs);
  font-weight: 600; padding: 3px 9px; border-radius: 999px; border: 1px solid var(--pm-border); }
.pm-badge.approved   { color: var(--pm-success); border-color: var(--pm-success); }
.pm-badge.disapproved{ color: var(--pm-danger);  border-color: var(--pm-danger); }
.pm-badge.assigned   { color: var(--pm-info);     border-color: var(--pm-info); }
.pm-badge.pending    { color: var(--pm-warning);  border-color: var(--pm-warning); }
.pm-badge.holiday    { color: var(--pm-violet);   border-color: var(--pm-violet); }

/* Sidebar nav */
.pm-sidebar { background: var(--pm-bg-elev); border-right: 1px solid var(--pm-border); padding: var(--pm-sp-5) var(--pm-sp-3); }
.pm-nav { display: flex; flex-direction: column; gap: 2px; margin-top: var(--pm-sp-5); }
.pm-nav a { display: flex; align-items: center; gap: var(--pm-sp-3); padding: 10px 12px;
  border-radius: var(--pm-radius-sm); color: var(--pm-text-muted); font-weight: 500; }
.pm-nav a:hover { background: var(--pm-surface); color: var(--pm-text); text-decoration: none; }
.pm-nav a.active { background: var(--pm-accent-soft); color: var(--pm-accent); }

/* Modal */
.pm-modal-overlay { position: fixed; inset: 0; background: var(--pm-overlay); display: grid; place-items: center; z-index: 50; padding: var(--pm-sp-4); }
.pm-modal { background: var(--pm-surface); border: 1px solid var(--pm-border); border-radius: var(--pm-radius-lg);
  box-shadow: var(--pm-shadow); width: min(560px, 92vw); max-height: 90vh; display: flex; flex-direction: column; }
.pm-modal-head { flex: 0 0 auto; display: flex; align-items: flex-start; justify-content: space-between; gap: var(--pm-sp-3);
  padding: var(--pm-sp-5) var(--pm-sp-5) var(--pm-sp-3); }
.pm-modal-body { flex: 1 1 auto; min-height: 0; overflow-y: auto; padding: 0 var(--pm-sp-5); }
.pm-modal > .pm-row { flex: 0 0 auto; padding: var(--pm-sp-3) var(--pm-sp-5) var(--pm-sp-5); margin-top: 0 !important; }
.pm-modal-close { flex: 0 0 auto; background: transparent; border: none; color: var(--pm-text-muted); cursor: pointer;
  font-size: 24px; line-height: 1; padding: 0 4px; border-radius: var(--pm-radius-sm); }
.pm-modal-close:hover { color: var(--pm-text); }

/* Toast */
.pm-toasts { position: fixed; top: 18px; right: 18px; display: flex; flex-direction: column; gap: 10px; z-index: 60; }
.pm-toast { background: var(--pm-surface-2); border: 1px solid var(--pm-border); border-left-width: 3px;
  border-radius: var(--pm-radius-sm); padding: 11px 16px; box-shadow: var(--pm-shadow-sm); min-width: 240px; }
.pm-toast.success { border-left-color: var(--pm-success); }
.pm-toast.error   { border-left-color: var(--pm-danger); }
.pm-toast.info    { border-left-color: var(--pm-info); }

/* Stat tile */
.pm-stat { background: var(--pm-surface); border: 1px solid var(--pm-border); border-radius: var(--pm-radius); padding: var(--pm-sp-4); }
.pm-stat .v { font-size: var(--pm-fs-2xl); font-weight: 700; }
.pm-stat .k { color: var(--pm-text-muted); font-size: var(--pm-fs-sm); }

/* Master-detail (admin users) */
.pm-split { display: grid; grid-template-columns: 320px 1fr; gap: var(--pm-sp-4); align-items: start; }
@media (max-width: 900px) { .pm-split { grid-template-columns: 1fr; } }
.pm-mlist { display: flex; flex-direction: column; gap: var(--pm-sp-2); }
.pm-mrow {
  display: flex; justify-content: space-between; align-items: center; gap: var(--pm-sp-2);
  padding: 10px 12px; border: 1px solid var(--pm-border); border-radius: var(--pm-radius-sm);
  background: var(--pm-bg-elev); cursor: pointer; transition: border-color .15s, background .15s;
}
.pm-mrow:hover { border-color: var(--pm-accent); }
.pm-mrow.active { border-color: var(--pm-accent); background: var(--pm-accent-soft); }
.pm-mrow .nm { font-weight: 600; }
.pm-mrow .un { color: var(--pm-text-faint); font-size: var(--pm-fs-xs); }
.pm-dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; }
.pm-dot.on { background: var(--pm-success); }
.pm-dot.off { background: var(--pm-danger); }
.pm-detail-empty { display: grid; place-items: center; min-height: 240px; color: var(--pm-text-faint); }

/* Scaffold notice */
.pm-scaffold-note { border: 1px dashed var(--pm-border); border-radius: var(--pm-radius);
  padding: var(--pm-sp-4); color: var(--pm-text-faint); background: var(--pm-bg-elev); font-size: var(--pm-fs-sm); }
