/* Student Loan Management - CRM UI */
:root{--slm-primary:#2563eb}

.slm-app{display:flex;gap:0;min-height:70vh;font-family:system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial,sans-serif;color:#111;background:#f5f7fb;border-radius:12px;overflow:hidden;border:1px solid rgba(0,0,0,0.06)}
.slm-sidebar{width:250px;background:#0f172a;color:#fff;padding:18px 14px}
.slm-brand{font-weight:800;letter-spacing:0.4px;margin:4px 8px 16px;font-size:16px}
.slm-side-nav{display:flex;flex-direction:column;gap:6px}
.slm-side-link{display:block;padding:10px 12px;border-radius:10px;color:rgba(255,255,255,0.85);text-decoration:none;font-weight:600;font-size:13px}
.slm-side-link:hover{background:rgba(255,255,255,0.08)}
.slm-side-link.active{background:rgba(37,99,235,0.25);border:1px solid rgba(37,99,235,0.35);color:#fff}

.slm-main{flex:1;padding:18px}
.slm-topbar{display:flex;justify-content:space-between;align-items:center;background:#fff;border:1px solid rgba(0,0,0,0.06);border-radius:12px;padding:14px 16px;margin-bottom:14px}
.slm-title{font-weight:800}
.slm-user{font-weight:600;color:#334155}

.slm-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin:10px 0 16px}
.slm-card{background:#fff;border:1px solid rgba(0,0,0,0.06);border-radius:14px;padding:14px}
.slm-card-label{font-size:12px;color:#64748b;font-weight:700;text-transform:uppercase;letter-spacing:0.5px}
.slm-card-value{font-size:22px;font-weight:900;color:var(--slm-primary);margin-top:6px}

.slm-card-link{text-decoration:none;color:inherit;display:block}
.slm-card-link:hover{box-shadow:0 8px 20px rgba(0,0,0,0.08);transform:translateY(-1px)}

.slm-panel{background:#fff;border:1px solid rgba(0,0,0,0.06);border-radius:14px;padding:16px;margin-bottom:14px}
.slm-panel h2{margin:0 0 10px;font-size:16px}

.slm-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width:900px){.slm-sidebar{display:none}.slm-grid{grid-template-columns:1fr}}

.slm-field{margin-bottom:10px}
.slm-field label{display:block;font-weight:700;font-size:12px;color:#475569;margin-bottom:6px}
.slm-field input,.slm-field select,.slm-field textarea{width:100%;padding:10px 12px;border-radius:10px;border:1px solid rgba(0,0,0,0.12);background:#fff;box-sizing:border-box}
.slm-field textarea{min-height:90px}

.slm-btn{display:inline-block;padding:10px 14px;border-radius:10px;border:1px solid rgba(0,0,0,0.08);background:#fff;color:#0f172a;font-weight:800;text-decoration:none;cursor:pointer}
.slm-btn-primary{background:var(--slm-primary);color:#fff;border-color:var(--slm-primary)}
.slm-btn-danger{background:#fee2e2;color:#991b1b;border-color:#fecaca}
.slm-btn + .slm-btn{margin-left:8px}

/* Prevent button overlap / improve spacing in all forms */
.slm-panel form{padding-bottom:4px}
.slm-panel form .slm-btn{margin-top:12px}
.slm-panel form input.slm-input[type="file"]{padding:8px 10px}
.slm-panel form textarea.slm-input{margin-bottom:2px}

.slm-table{width:100%;border-collapse:collapse}
.slm-table th,.slm-table td{padding:10px 10px;border-bottom:1px solid rgba(0,0,0,0.06);text-align:left;font-size:13px}
.slm-table th{font-size:12px;text-transform:uppercase;letter-spacing:0.4px;color:#64748b}
.slm-badge{display:inline-block;padding:4px 8px;border-radius:999px;font-weight:800;font-size:11px;background:#e2e8f0;color:#334155}
.slm-badge.ok{background:#dcfce7;color:#166534}
.slm-badge.off{background:#fee2e2;color:#991b1b}

.slm-notice{padding:12px 14px;border-radius:12px;margin:10px 0;border:1px solid rgba(37,99,235,0.25);background:#eff6ff;color:#1e40af;font-weight:700}
.slm-notice.slm-error{border-color:rgba(220,38,38,0.25);background:#fef2f2;color:#991b1b}

/* keep auth blocks neat on front-end */
.slm-auth-container{max-width:520px;margin:24px auto}

/* -------------------------------------------------
   Compatibility layer (templates use these classes)
   ------------------------------------------------- */
.slm-section{margin:6px 0 14px}
.slm-header-row{display:flex;gap:12px;align-items:center;justify-content:space-between;margin-bottom:12px}
.slm-header-row h2{margin:0;font-size:18px}

.slm-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width:900px){.slm-grid-2{grid-template-columns:1fr}}

.slm-label{display:block;font-weight:700;font-size:12px;color:#475569;margin:10px 0 6px}
.slm-input{width:100%;padding:10px 12px;border-radius:10px;border:1px solid rgba(0,0,0,0.12);background:#fff;box-sizing:border-box}
.slm-input:focus{outline:none;border-color:rgba(37,99,235,0.7);box-shadow:0 0 0 3px rgba(37,99,235,0.15)}

.slm-table-wrap{overflow:auto;border:1px solid rgba(0,0,0,0.06);border-radius:12px}
.slm-empty{text-align:center;color:#64748b;padding:14px}

.slm-thread{display:flex;flex-direction:column;gap:10px}
.slm-msg{background:#fff;border:1px solid rgba(0,0,0,0.06);border-radius:12px;padding:10px 12px}
.slm-msg-meta{font-size:12px;color:#64748b;margin-bottom:6px}

.slm-link{color:var(--slm-primary);text-decoration:none;font-weight:800;font-size:13px;background:none;border:none;padding:0;cursor:pointer}
.slm-link:hover{text-decoration:underline}
.slm-link-danger{color:#b91c1c}

/* Ticket UI */
.slm-thread{max-height:320px;overflow:auto;border:1px solid rgba(0,0,0,0.06);border-radius:12px;padding:10px;background:#f8fafc}
.slm-msg{padding:10px 12px;border-radius:12px;background:#fff;border:1px solid rgba(0,0,0,0.06);margin-bottom:8px}
.slm-msg-meta{font-size:12px;color:#64748b;font-weight:700;margin-bottom:6px}

/* Fullscreen CRM pages */
body.slm-fullscreen{margin:0;background:#f5f7fb}
.slm-fullscreen-wrap{padding:18px}

/* Admin "Login as" banner */
.slm-impersonate-bar{position:sticky;top:0;z-index:9999;background:#0f172a;color:#fff;padding:10px 14px;font-family:system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial,sans-serif}
.slm-impersonate-bar a{color:#93c5fd;font-weight:800;text-decoration:none}
.slm-impersonate-bar a:hover{text-decoration:underline}


/* Topbar My Account dropdown */
.slm-account{position:relative;outline:none}
.slm-account-trigger{display:flex;align-items:center;gap:10px;cursor:pointer;user-select:none}
.slm-avatar{width:34px;height:34px;border-radius:999px;object-fit:cover;border:2px solid rgba(15,23,42,.08)}
.slm-caret{font-size:12px;opacity:.7}
.slm-account-menu{display:none;position:absolute;right:0;top:calc(100% + 10px);background:#fff;border:1px solid rgba(15,23,42,.08);box-shadow:0 14px 30px rgba(15,23,42,.12);border-radius:12px;min-width:200px;overflow:hidden;z-index:50}
.slm-account:focus .slm-account-menu,
.slm-account:hover .slm-account-menu{display:block}
.slm-account-item{display:block;padding:10px 12px;color:#0f172a;text-decoration:none;font-weight:600}
.slm-account-item:hover{background:rgba(37,99,235,.08)}
.slm-account-sep{height:1px;background:rgba(15,23,42,.08)}
.slm-danger{color:#b91c1c}
.slm-danger:hover{background:rgba(185,28,28,.08)}

/* Profile page */
.slm-profile-grid{display:grid;grid-template-columns:260px 1fr;gap:18px;align-items:start}
.slm-profile-img{width:200px;height:200px;border-radius:18px;object-fit:cover;border:1px solid rgba(15,23,42,.08);background:#f8fafc}
.slm-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.slm-form-actions{margin-top:14px;padding-top:10px;display:flex;gap:10px;flex-wrap:wrap}

/* Ensure buttons never overlap fields */
.slm-panel form{padding-bottom:14px}

/* Fix button overlap in forms */
.slm-panel form .slm-btn{margin-top:10px}
.slm-panel form .slm-input{margin-bottom:10px}
