/* ── BSS Student Enrolment Plugin Styles ── */
#bsse-wrap, #bsse-admin-wrap {
  font-family: 'Segoe UI', Arial, sans-serif;
  max-width: 960px;
  margin: 0 auto;
  padding: 16px;
  color: #222;
}
.bsse-title { font-size: 22px; font-weight: 700; color: #1a5276; margin-bottom: 18px; }
.bsse-card {
  background: #fff;
  border: 1px solid #d5e8f5;
  border-radius: 10px;
  padding: 20px 24px;
  margin-bottom: 20px;
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
.bsse-card h3 { margin: 0 0 14px; font-size: 16px; color: #1a5276; }
.bsse-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 14px;
}
.bsse-field { display: flex; flex-direction: column; }
.bsse-field label { font-size: 13px; font-weight: 600; margin-bottom: 4px; color: #444; }
.bsse-field input, .bsse-field select {
  padding: 9px 11px;
  border: 1px solid #b0cfe8;
  border-radius: 6px;
  font-size: 14px;
  outline: none;
  transition: border .2s;
}
.bsse-field input:focus, .bsse-field select:focus { border-color: #2980b9; }
.req { color: #e74c3c; }
.bsse-row { display: flex; gap: 10px; align-items: center; margin-bottom: 10px; flex-wrap: wrap; }
.bsse-row input[type=text] {
  flex: 1; min-width: 220px;
  padding: 9px 12px; border: 1px solid #b0cfe8; border-radius: 6px; font-size: 14px;
}
/* Buttons */
.bsse-btn {
  padding: 9px 18px; border: none; border-radius: 6px; cursor: pointer;
  font-size: 13px; font-weight: 600; transition: opacity .2s;
}
.bsse-btn:hover { opacity: .85; }
.bsse-btn-blue   { background:#2980b9; color:#fff; }
.bsse-btn-green  { background:#27ae60; color:#fff; }
.bsse-btn-red    { background:#e74c3c; color:#fff; }
.bsse-btn-orange { background:#e67e22; color:#fff; }
.bsse-btn-grey   { background:#95a5a6; color:#fff; }
.bsse-btn-dark   { background:#555; color:#fff; }
/* Search results */
#bsse-search-results {
  border: 1px solid #cde; border-radius: 6px; margin-top: 6px; display: none; max-height: 240px; overflow-y: auto;
}
.bsse-result-row {
  padding: 9px 14px; cursor: pointer; font-size: 13px; border-bottom: 1px solid #eaf2fa;
  transition: background .15s;
}
.bsse-result-row:hover { background: #eaf4fb; }
/* Selected member */
.bsse-selected-box {
  background: #e8f6ef; border: 1px solid #27ae60; border-radius: 7px;
  padding: 10px 14px; margin-top: 10px; font-size: 13px; color: #1d6e40;
  font-weight: 600;
}
/* Age tag */
.bsse-age-tag {
  display: inline-block; background: #2980b9; color: #fff;
  border-radius: 14px; padding: 4px 14px; font-size: 13px;
  margin: 10px 0; font-weight: 600;
}
.bsse-age-tag.age-warn { background: #e74c3c; }
/* Messages */
.bsse-msg {
  padding: 9px 14px; border-radius: 6px; font-size: 13px; margin-top: 10px;
}
.bsse-msg.ok  { background: #d5f5e3; color: #1e8449; border: 1px solid #a9dfbf; }
.bsse-msg.err { background: #fdecea; color: #c0392b; border: 1px solid #f5b7b1; }
.bsse-actions { display: flex; gap: 10px; margin-top: 16px; flex-wrap: wrap; }
.bsse-success { background: #eafaf1; border-color: #27ae60; }
.bsse-success h3 { color: #1e8449; }

/* ── Admin ── */
.bsse-admin-header {
  display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px;
}
.bsse-admin-header h2 { margin: 0; color: #1a5276; font-size: 20px; }
.bsse-stats { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 16px; }
.bsse-stat {
  flex: 1; min-width: 110px; border-radius: 9px; padding: 14px 10px;
  text-align: center; font-size: 13px; font-weight: 600; color: #fff;
}
.bsse-stat span { display: block; font-size: 28px; font-weight: 700; margin-top: 4px; }
.bsse-stat-blue   { background: #2980b9; }
.bsse-stat-orange { background: #e67e22; }
.bsse-stat-green  { background: #27ae60; }
.bsse-stat-red    { background: #e74c3c; }
.bsse-filter-bar  { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; margin-bottom: 12px; }
.bsse-filter-btns { display: flex; gap: 6px; flex-wrap: wrap; }
.bsse-filter-btn  {
  padding: 7px 16px; border: 1px solid #b0cfe8; border-radius: 20px;
  background: #fff; cursor: pointer; font-size: 13px; font-weight: 600; color: #2980b9;
}
.bsse-filter-btn.active { background: #2980b9; color: #fff; border-color: #2980b9; }
#bsse-search-admin {
  flex: 1; min-width: 180px; padding: 8px 12px; border: 1px solid #b0cfe8;
  border-radius: 6px; font-size: 13px;
}
.bsse-bulk-bar { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin-bottom: 12px; }
.bsse-table-wrap { overflow-x: auto; }
#bsse-admin-table {
  width: 100%; border-collapse: collapse; font-size: 13px;
  word-break: break-word;
}
#bsse-admin-table th {
  background: #1a5276; color: #fff; padding: 10px 8px;
  text-align: left; white-space: nowrap;
}
#bsse-admin-table td { padding: 8px; border-bottom: 1px solid #e3eef8; vertical-align: top; }
#bsse-admin-table tr:nth-child(even) td { background: #f4f9fd; }
#bsse-admin-table tr:hover td { background: #e8f3fb; }
.bsse-status-badge {
  display: inline-block; padding: 3px 10px; border-radius: 12px;
  font-size: 12px; font-weight: 700; text-transform: uppercase;
}
.bsse-status-badge.approved { background: #d5f5e3; color: #1e8449; }
.bsse-status-badge.pending  { background: #fef9e7; color: #b7770d; }
.bsse-status-badge.rejected { background: #fdecea; color: #c0392b; }
.bsse-row-actions { display: flex; gap: 4px; flex-wrap: wrap; }
.bsse-row-btn {
  padding: 4px 9px; border: none; border-radius: 4px;
  font-size: 12px; font-weight: 600; cursor: pointer;
}
/* Edit strip */
.bsse-edit-strip {
  background: #fffde7; border: 1px solid #f0c040; border-radius: 10px;
  padding: 18px 22px; margin-top: 16px;
}
.bsse-edit-strip h3 { margin: 0 0 14px; color: #7d6608; }

@media (max-width: 600px) {
  .bsse-stats { flex-direction: column; }
  .bsse-admin-header { flex-direction: column; gap: 8px; }
  .bsse-filter-bar { flex-direction: column; align-items: stretch; }
}
