:root{--csm-card-bg:#ffffff;--csm-card-border:#e5e7eb;--csm-text:#111827;--csm-muted:#6b7280;--csm-shadow:0 8px 20px rgba(0,0,0,0.08);--csm-radius:14px;--csm-gap:16px}
.csm-wrap{margin-top:20px}

/* NEW: make labels stack above inputs (fixes Position field label) */
.csm-wrap label{display:block;margin-bottom:6px;color:var(--csm-muted);font-size:13px;font-weight:600}

.csm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--csm-gap)}
.csm-card{background:var(--csm-card-bg);border:1px solid var(--csm-card-border);border-radius:var(--csm-radius);box-shadow:var(--csm-shadow);transition:transform .12s ease,box-shadow .12s ease;overflow:hidden}
.csm-card:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(0,0,0,.12)}
.csm-card-body{padding:16px;display:grid;grid-template-columns:64px 1fr;gap:12px;align-items:center}
.csm-avatar{width:64px;height:64px;border-radius:50%;background:#f3f4f6;display:flex;align-items:center;justify-content:center;font-size:28px;color:#6b7280;overflow:hidden}
.csm-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.csm-title{font-weight:600;color:var(--csm-text)}
.csm-sub{color:var(--csm-muted);font-size:13px}
.csm-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:600;color:#fff}
.csm-actions{display:flex;gap:8px;margin-top:10px}
.csm-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:10px;border:1px solid var(--csm-card-border);background:#fff;color:#111827;text-decoration:none;cursor:pointer}
.csm-btn:hover{background:#f9fafb}
.csm-toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:12px}
.csm-input,.csm-select,.csm-textarea{width:100%;padding:10px;border:1px solid #d1d5db;border-radius:10px;background:#fff;font-size:14px}
.csm-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.csm-form-actions{margin-top:16px;display:flex;gap:12px}
.csm-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}
.csm-table th,.csm-table td{padding:10px 12px;border-bottom:1px solid #eef2f7;text-align:left}
.csm-table thead th{background:#f9fafb;font-weight:600}
.csm-badge-present{background:#22c55e}
.csm-badge-absent{background:#ef4444}
.csm-badge-leave{background:#f59e0b}
.csm-badge-late{background:#3b82f6}
.csm-badge-half{background:#8b5cf6}
.csm-badge-none{background:#6b7280}
.csm-chip{display:inline-flex;padding:6px 10px;border-radius:999px;background:#f3f4f6;color:#111827;font-size:12px;font-weight:600;margin-right:8px}
.csm-section{margin-top:22px}
.csm-empty{padding:22px;text-align:center;color:var(--csm-muted)}
@media(max-width:760px){.csm-form-grid{grid-template-columns:1fr}.csm-card-body{grid-template-columns:48px 1fr}.csm-avatar{width:48px;height:48px;font-size:22px}}
/* Staff login shortcode */
.csm-login-wrap{max-width:560px;margin:40px auto;padding:0 16px}
.csm-login-card{background:#fff;border:1px solid var(--csm-card-border);border-radius:24px;box-shadow:var(--csm-shadow);padding:28px}
.csm-login-header{margin-bottom:18px}
.csm-login-eyebrow{display:inline-flex;padding:6px 10px;border-radius:999px;background:#f3f4f6;color:#374151;font-size:12px;font-weight:700;margin-bottom:12px}
.csm-login-title{margin:0 0 8px;font-size:30px;line-height:1.15;color:var(--csm-text)}
.csm-login-subtitle{margin:0;color:var(--csm-muted);font-size:14px}
.csm-login-form{margin-top:18px}
.csm-login-field{margin-bottom:16px}
.csm-login-field label{display:block;margin-bottom:8px;color:var(--csm-text);font-size:14px;font-weight:600}
.csm-login-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:18px}
.csm-login-btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 16px;border-radius:12px;border:1px solid var(--csm-card-border);font-weight:700;text-decoration:none;cursor:pointer}
.csm-login-btn--primary{background:#111827;color:#fff}
.csm-login-btn--primary:hover{background:#0f172a}
.csm-login-btn--secondary{background:#f9fafb;color:#111827}
.csm-login-btn--secondary:hover{background:#f3f4f6}
.csm-login-alert{padding:12px 14px;border-radius:12px;margin-top:14px;margin-bottom:6px;font-size:14px;font-weight:600}
.csm-login-alert--success{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}
.csm-login-alert--error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}
.csm-login-details{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:18px}
.csm-login-detail{padding:12px 14px;border-radius:14px;border:1px solid var(--csm-card-border);background:#f9fafb}
.csm-login-detail span{display:block;font-size:12px;color:var(--csm-muted);margin-bottom:4px}
.csm-login-detail strong{display:block;font-size:14px;color:var(--csm-text);word-break:break-word}

@media(max-width:640px){
  .csm-login-wrap{margin:24px auto}
  .csm-login-card{padding:20px}
  .csm-login-title{font-size:26px}
  .csm-login-details{grid-template-columns:1fr}
  .csm-login-actions{width:100%}
}