/*
Theme Name: STOP-THE-BLEED Enrollment
Theme URI: https://example.com/
Author: Site Administrator
Author URI: https://example.com/
Description: A standalone WordPress theme for STOP-THE-BLEED class registration with admin-managed classes, approval workflow, private registration codes, auto-close behavior, roster printing, CSV export, and SMTP-ready notifications.
Version: 2.0.16
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GPLv2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: stop-the-bleed-enrollment
*/

:root {
  --stb-red: #b40f14;
  --stb-red-dark: #8f0b10;
  --stb-blue: #0c2f5d;
  --stb-bg: #f6f7f9;
  --stb-card: #ffffff;
  --stb-text: #202124;
  --stb-muted: #5f6368;
  --stb-border: #dadce0;
  --stb-focus: #1a73e8;
  --stb-green: #137333;
  --stb-yellow: #b06000;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  background: var(--stb-bg);
  color: var(--stb-text);
  font-family: Arial, Helvetica, sans-serif;
  line-height: 1.5;
}
.stb-page { max-width: 980px; margin: 0 auto; padding: 18px 14px 48px; }
.stb-header-card, .stb-card {
  background: var(--stb-card);
  border: 1px solid var(--stb-border);
  border-radius: 10px;
  margin-bottom: 14px;
  box-shadow: 0 1px 2px rgba(60,64,67,.08);
  overflow: hidden;
}
.stb-brand-strip { height: 10px; background: var(--stb-red); }
.stb-header-image { width: 100%; display: block; border-bottom: 1px solid var(--stb-border); object-fit: contain; background: #fff; }
.stb-header-content, .stb-card-content { padding: 24px; }
.stb-title { margin: 0 0 10px; font-size: 30px; font-weight: 500; }
.stb-description p { margin: 0 0 12px; }
.stb-required-note { color: var(--stb-red); font-size: 14px; margin-top: 18px; }
.stb-label { display: block; font-size: 16px; margin-bottom: 10px; }
.stb-required { color: var(--stb-red); }
.stb-input {
  width: 100%;
  border: none;
  border-bottom: 1px solid var(--stb-border);
  font-size: 16px;
  padding: 10px 2px;
  outline: none;
  background: transparent;
}
.stb-input:focus { border-bottom: 2px solid var(--stb-focus); }
.stb-option { display: flex; gap: 10px; align-items: flex-start; margin: 12px 0; font-size: 15px; }
.stb-option input { margin-top: 4px; }
.stb-capacity { color: var(--stb-muted); font-size: 13px; margin-left: 2px; }
.stb-full, .stb-closed { color: var(--stb-red); font-weight: 700; }
.stb-actions { display: flex; gap: 12px; align-items: center; margin-top: 18px; flex-wrap: wrap; }
.stb-button {
  appearance: none; border: none; border-radius: 4px; background: var(--stb-red); color: #fff;
  padding: 11px 24px; font-size: 15px; font-weight: 600; cursor: pointer; text-decoration: none;
}
.stb-button:hover { background: var(--stb-red-dark); color: #fff; }
.stb-message { padding: 14px 16px; border-radius: 6px; margin-bottom: 14px; }
.stb-success { background: #e6f4ea; border: 1px solid #b7dfc3; }
.stb-error { background: #fce8e6; border: 1px solid #f5b8b2; }
.stb-footer { color: var(--stb-muted); font-size: 13px; text-align: center; margin-top: 24px; }
.stb-calendar-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 12px; margin-top: 16px; }
.stb-calendar-item { border: 1px solid var(--stb-border); border-left: 6px solid var(--stb-red); border-radius: 10px; padding: 14px; background: #fff; }
.stb-calendar-date { font-weight: 700; color: var(--stb-red); font-size: 16px; }
.stb-calendar-time, .stb-calendar-location, .stb-calendar-seats { color: var(--stb-muted); font-size: 14px; margin-top: 4px; }
.stb-private-badge, .stb-status-badge {
  display: inline-block; margin-top: 8px; margin-right: 6px; padding: 3px 8px; border-radius: 99px; font-size: 12px; font-weight: 700;
}
.stb-private-badge { background: #fff4e5; color: #8a4b00; }
.stb-status-open { background: #e6f4ea; color: var(--stb-green); }
.stb-status-closed { background: #fce8e6; color: var(--stb-red); }

.stb-admin-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 14px; margin: 18px 0; }
.stb-admin-stat { background:#fff; border:1px solid #ccd0d4; border-radius:10px; padding:16px; }
.stb-admin-stat strong { display:block; font-size:26px; line-height:1.1; margin-top:6px; }
.stb-admin-toolbar { display:flex; gap:8px; flex-wrap:wrap; align-items:center; margin: 14px 0; }
.stb-status-pill { padding:3px 8px; border-radius:999px; font-weight:700; font-size:12px; display:inline-block; }
.stb-pill-pending { background:#fff4e5; color:#8a4b00; }
.stb-pill-approved { background:#e6f4ea; color:#137333; }
.stb-pill-disapproved { background:#fce8e6; color:#b40f14; }
.stb-pill-disenrolled { background:#eef0f3; color:#50575e; }

.stb-print-sheet { background:#fff; color:#000; padding:24px; max-width:1100px; margin:0 auto; }
.stb-print-table { width:100%; border-collapse:collapse; margin-top:16px; }
.stb-print-table th, .stb-print-table td { border:1px solid #000; padding:8px; text-align:left; vertical-align:top; }
.stb-signature-line { border-bottom:1px solid #000; height:28px; min-width:160px; display:block; }
@media print {
  #adminmenumain, #wpadminbar, .notice, .stb-no-print, .update-nag { display:none !important; }
  #wpcontent, #wpbody-content { margin:0 !important; padding:0 !important; }
  body { background:#fff !important; }
  .stb-print-sheet { padding:0; max-width:none; }
}
@media (max-width: 640px) {
  .stb-title { font-size: 24px; }
  .stb-header-content, .stb-card-content { padding: 18px; }
  .stb-actions { flex-direction: column; align-items: stretch; }
  .stb-button { width: 100%; text-align:center; }
}


/* ===== v1.9.2 Secure Instructor Portal Repair ===== */
.stb-portal-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap}
.stb-portal-login{max-width:680px;margin:40px auto}
.stb-portal-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:14px 0 18px}
.stb-portal-tabs a{display:inline-block;padding:9px 13px;border:1px solid var(--stb-border);border-radius:8px;background:#fff;text-decoration:none;color:var(--stb-text)}
.stb-portal-tabs a.is-active{background:var(--stb-red);color:#fff;border-color:var(--stb-red)}
.stb-portal-table-wrap{overflow-x:auto;background:#fff;border:1px solid var(--stb-border);border-radius:10px}
.stb-portal-table{width:100%;min-width:960px;border-collapse:collapse}
.stb-portal-table th,.stb-portal-table td{border-bottom:1px solid var(--stb-border);padding:10px;text-align:left;vertical-align:top}
.stb-portal-inline-form{margin:0 0 7px 0}
.stb-portal-inline-form textarea{width:100%;min-height:54px}
.stb-portal-button-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.stb-portal-button{border:none;border-radius:5px;padding:8px 10px;cursor:pointer;background:var(--stb-blue);color:#fff;font-weight:700}
.stb-portal-button.approve{background:#137333}
.stb-portal-button.disapprove{background:#a50e0e}
.stb-portal-button.disenroll{background:#5f6368}
.stb-portal-button.reopen{background:#0c2f5d}
.stb-portal-filter{display:flex;gap:8px;flex-wrap:wrap;align-items:end}
.stb-portal-filter label{display:block;font-size:13px;color:var(--stb-muted)}
.stb-portal-filter select{padding:8px;border:1px solid var(--stb-border);border-radius:6px;max-width:100%}
.stb-portal-notice{border-radius:8px;padding:12px 14px;margin:12px 0}
.stb-portal-notice.success{background:#e6f4ea;border:1px solid #b7dfc3}
.stb-portal-notice.error{background:#fce8e6;border:1px solid #f5b8b2}
@media print{.stb-portal-tabs,.stb-portal-filter,.stb-portal-button-row,.stb-portal-inline-form textarea,.stb-actions,.stb-no-print{display:none!important}.stb-page{max-width:none;padding:0}.stb-card{border:none;box-shadow:none}}


/* ===== v1.9.3 Branded Instructor Login Page ===== */
.stb-login-hero {
  background: linear-gradient(135deg, #b40f14 0%, #7f070b 100%);
  color: #fff;
  border-radius: 16px;
  overflow: hidden;
  margin-bottom: 18px;
  box-shadow: 0 10px 30px rgba(0,0,0,.16);
}
.stb-login-hero-inner {
  padding: 34px 28px;
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 22px;
  align-items: center;
}
.stb-login-logo {
  width: 110px;
  height: 110px;
  border-radius: 22px;
  background: rgba(255,255,255,.12);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px;
}
.stb-login-logo img {
  max-width: 100%;
  max-height: 100%;
}
.stb-login-title {
  font-size: 34px;
  line-height: 1.1;
  margin: 0 0 10px;
  font-weight: 800;
}
.stb-login-subtitle {
  font-size: 18px;
  margin: 0;
  opacity: .95;
}
.stb-login-grid {
  display: grid;
  grid-template-columns: 1.25fr .75fr;
  gap: 16px;
}
.stb-login-panel {
  background: #fff;
  border: 1px solid var(--stb-border);
  border-radius: 14px;
  padding: 24px;
  box-shadow: 0 1px 2px rgba(60,64,67,.08);
}
.stb-login-panel h2 {
  margin-top: 0;
}
.stb-login-list {
  margin: 0;
  padding-left: 20px;
}
.stb-login-list li {
  margin: 8px 0;
}
.stb-login-button {
  display: inline-block;
  width: 100%;
  text-align: center;
  background: var(--stb-red);
  color: #fff;
  padding: 13px 18px;
  border-radius: 8px;
  font-weight: 800;
  text-decoration: none;
  margin: 8px 0 10px;
}
.stb-login-button:hover {
  background: var(--stb-red-dark);
  color: #fff;
}
.stb-login-secondary {
  display: inline-block;
  width: 100%;
  text-align: center;
  background: #fff;
  color: var(--stb-blue);
  border: 1px solid var(--stb-blue);
  padding: 11px 18px;
  border-radius: 8px;
  font-weight: 700;
  text-decoration: none;
}
.stb-login-note {
  color: var(--stb-muted);
  font-size: 13px;
  margin-top: 12px;
}
@media (max-width: 760px) {
  .stb-login-hero-inner {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .stb-login-logo {
    margin: 0 auto;
  }
  .stb-login-grid {
    grid-template-columns: 1fr;
  }
  .stb-login-title {
    font-size: 28px;
  }
}


/* ===== v1.9.4 Unified Instructor Access Dashboard ===== */
.stb-instructor-public-link {
  display: inline-block;
  margin-top: 8px;
  font-weight: 700;
  color: var(--stb-blue);
  text-decoration: none;
}
.stb-instructor-public-link:hover {
  text-decoration: underline;
}
.stb-login-panel .stb-admin-dashboard-cards {
  margin-top: 0;
}


/* ===== v1.9.5 Forced Instructor Re-Authentication ===== */
.stb-security-panel {
  border-left: 6px solid var(--stb-red);
}
.stb-security-small {
  color: var(--stb-muted);
  font-size: 13px;
  margin-top: 10px;
}


/* ===== v1.9.6 WordPress-Style Instructor Dashboard Restore ===== */
.stb-admin-shell {
  max-width: 1180px;
  margin: 0 auto;
  padding: 22px 14px 48px;
}
.stb-admin-topbar {
  background: #1d2327;
  color: #fff;
  border-radius: 10px 10px 0 0;
  padding: 14px 18px;
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
  flex-wrap: wrap;
}
.stb-admin-topbar h1 {
  font-size: 22px;
  margin: 0;
  color: #fff;
}
.stb-admin-topbar a {
  color: #fff;
}
.stb-admin-body {
  background: #f0f0f1;
  border: 1px solid #c3c4c7;
  border-top: none;
  border-radius: 0 0 10px 10px;
  padding: 20px;
}
.stb-admin-notice {
  border-left: 4px solid #00a32a;
  background: #fff;
  padding: 10px 12px;
  margin: 12px 0;
}
.stb-admin-notice.error {
  border-left-color: #d63638;
}
.stb-admin-card {
  background: #fff;
  border: 1px solid #c3c4c7;
  box-shadow: 0 1px 1px rgba(0,0,0,.04);
  padding: 16px;
  margin: 0 0 16px;
}
.stb-admin-card h2 {
  margin-top: 0;
  font-size: 18px;
}
.stb-admin-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: end;
  flex-wrap: wrap;
  gap: 12px;
}
.stb-admin-filters {
  display: flex;
  align-items: end;
  flex-wrap: wrap;
  gap: 10px;
}
.stb-admin-filters label {
  display: block;
  color: #50575e;
  font-size: 12px;
  margin-bottom: 3px;
}
.stb-admin-filters select {
  min-width: 190px;
  max-width: 100%;
  padding: 7px;
  border: 1px solid #8c8f94;
  border-radius: 4px;
  background: #fff;
}
.stb-wp-button,
.stb-wp-button-primary,
.stb-wp-button-danger {
  display: inline-block;
  border-radius: 3px;
  border: 1px solid #2271b1;
  padding: 7px 12px;
  line-height: 1.2;
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
}
.stb-wp-button {
  background: #f6f7f7;
  color: #2271b1;
}
.stb-wp-button-primary {
  background: #2271b1;
  color: #fff;
}
.stb-wp-button-danger {
  background: #d63638;
  border-color: #d63638;
  color: #fff;
}
.stb-wp-button-muted {
  background: #50575e;
  border-color: #50575e;
  color: #fff;
}
.stb-wp-table-wrap {
  width: 100%;
  overflow-x: auto;
  border: 1px solid #c3c4c7;
  background: #fff;
}
.stb-wp-table {
  width: 100%;
  min-width: 1050px;
  border-collapse: collapse;
  background: #fff;
}
.stb-wp-table th {
  background: #f6f7f7;
  border-bottom: 1px solid #c3c4c7;
  color: #1d2327;
  font-weight: 600;
  padding: 10px;
  text-align: left;
}
.stb-wp-table td {
  border-bottom: 1px solid #dcdcde;
  padding: 10px;
  vertical-align: top;
}
.stb-wp-table tr:nth-child(even) td {
  background: #f9f9f9;
}
.stb-action-form textarea {
  width: 100%;
  min-height: 54px;
  margin-bottom: 6px;
}
.stb-action-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.stb-login-link-row {
  margin-top: 16px;
}
.stb-login-link-row a {
  margin-right: 10px;
}
.stb-admin-counts {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 12px;
}
.stb-admin-count {
  background: #fff;
  border: 1px solid #c3c4c7;
  padding: 14px;
}
.stb-admin-count strong {
  display: block;
  font-size: 28px;
}
@media (max-width: 760px) {
  .stb-admin-body {
    padding: 12px;
  }
  .stb-admin-toolbar,
  .stb-admin-filters {
    display: block;
  }
  .stb-admin-filters > div,
  .stb-admin-filters button,
  .stb-admin-filters a {
    margin: 0 0 10px;
    width: 100%;
  }
  .stb-admin-filters select,
  .stb-wp-button,
  .stb-wp-button-primary,
  .stb-wp-button-danger {
    width: 100%;
    text-align: center;
  }
}
@media print {
  .stb-no-print,
  .stb-admin-topbar,
  .stb-admin-filters,
  .stb-action-form textarea,
  .stb-action-buttons {
    display: none !important;
  }
  .stb-admin-shell {
    max-width: none;
    padding: 0;
  }
  .stb-admin-body,
  .stb-admin-card,
  .stb-wp-table-wrap {
    border: none;
    box-shadow: none;
    background: #fff;
  }
  .stb-wp-table {
    min-width: 0;
  }
}


/* ===== v1.9.7 Targeted Secure Instructor Dashboard ===== */
.stb-secure-admin {
  max-width: 1180px;
  margin: 0 auto;
  padding: 22px 14px 48px;
  font-family: Arial, Helvetica, sans-serif;
}
.stb-secure-login {
  max-width: 760px;
  margin: 40px auto;
}
.stb-secure-header {
  background: #b40f14;
  color: #fff;
  border-radius: 12px 12px 0 0;
  padding: 18px 22px;
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: center;
  flex-wrap: wrap;
}
.stb-secure-header h1 {
  margin: 0;
  font-size: 25px;
  color: #fff;
}
.stb-secure-header a {
  color: #fff;
}
.stb-secure-body {
  background: #f6f7f7;
  border: 1px solid #c3c4c7;
  border-top: none;
  padding: 20px;
  border-radius: 0 0 12px 12px;
}
.stb-secure-card {
  background: #fff;
  border: 1px solid #c3c4c7;
  border-radius: 8px;
  padding: 16px;
  margin-bottom: 16px;
}
.stb-secure-card h2 {
  margin: 0 0 12px;
  font-size: 20px;
}
.stb-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}
.stb-kpi {
  background: #fff;
  border: 1px solid #c3c4c7;
  border-radius: 8px;
  padding: 14px;
}
.stb-kpi strong {
  display: block;
  font-size: 30px;
  line-height: 1.1;
  color: #1d2327;
}
.stb-kpi span {
  color: #50575e;
  font-weight: 700;
}
.stb-dash-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.stb-admin-btn {
  display: inline-block;
  border-radius: 4px;
  border: 1px solid #2271b1;
  background: #f6f7f7;
  color: #2271b1;
  padding: 8px 13px;
  line-height: 1.2;
  font-weight: 700;
  text-decoration: none;
  cursor: pointer;
}
.stb-admin-btn-primary {
  background: #2271b1;
  color: #fff;
}
.stb-admin-btn-danger {
  background: #d63638;
  border-color: #d63638;
  color: #fff;
}
.stb-admin-btn-muted {
  background: #50575e;
  border-color: #50575e;
  color: #fff;
}
.stb-table-scroll {
  overflow-x: auto;
  border: 1px solid #c3c4c7;
  background: #fff;
}
.stb-admin-table {
  width: 100%;
  min-width: 980px;
  border-collapse: collapse;
}
.stb-admin-table th {
  background: #f0f0f1;
  border-bottom: 1px solid #c3c4c7;
  color: #1d2327;
  text-align: left;
  padding: 10px;
  font-weight: 700;
}
.stb-admin-table td {
  border-bottom: 1px solid #dcdcde;
  padding: 10px;
  vertical-align: top;
}
.stb-admin-table tr:nth-child(even) td {
  background: #fafafa;
}
.stb-notice {
  padding: 12px 14px;
  margin-bottom: 16px;
  border-left: 4px solid #00a32a;
  background: #fff;
}
.stb-notice.error {
  border-left-color: #d63638;
}
.stb-action-form textarea,
.stb-class-form input[type="text"],
.stb-class-form input[type="date"],
.stb-class-form input[type="time"],
.stb-class-form input[type="number"],
.stb-class-form textarea,
.stb-settings-form input[type="email"],
.stb-settings-form input[type="text"] {
  width: 100%;
  max-width: 720px;
  padding: 8px;
  border: 1px solid #8c8f94;
  border-radius: 4px;
}
.stb-action-form textarea {
  min-height: 58px;
}
.stb-action-row {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 6px;
}
.stb-class-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(220px, 1fr));
  gap: 14px;
}
.stb-class-form-grid .full {
  grid-column: 1 / -1;
}
.stb-admin-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.stb-status-pill {
  display: inline-block;
  border-radius: 999px;
  padding: 3px 9px;
  font-weight: 700;
  font-size: 12px;
}
.stb-status-pending { background: #fff4e5; color: #8a4b00; }
.stb-status-approved { background: #e6f4ea; color: #137333; }
.stb-status-disapproved, .stb-status-disenrolled { background: #fce8e6; color: #a50e0e; }
.stb-status-open { background: #e6f4ea; color: #137333; }
.stb-status-closed { background: #fce8e6; color: #a50e0e; }
@media (max-width: 760px) {
  .stb-secure-body { padding: 12px; }
  .stb-dash-actions, .stb-admin-nav, .stb-action-row { display: block; }
  .stb-admin-btn, .stb-admin-btn-primary, .stb-admin-btn-danger, .stb-admin-btn-muted {
    display: block;
    width: 100%;
    text-align: center;
    margin-bottom: 8px;
  }
  .stb-class-form-grid { grid-template-columns: 1fr; }
  .stb-class-form-grid .full { grid-column: auto; }
}
@media print {
  .stb-no-print, .stb-secure-header, .stb-dash-actions, .stb-action-form, .stb-admin-nav {
    display: none !important;
  }
  .stb-secure-admin { max-width: none; padding: 0; }
  .stb-secure-body, .stb-secure-card, .stb-table-scroll { border: none; background: #fff; padding: 0; }
  .stb-admin-table { min-width: 0; }
}


/* ===== v1.9.8 Cleanup and Mobile Instructor Refinement ===== */
.stb-footer .stb-instructor-public-link,
.stb-single-instructor-link {
  display: inline-block;
  margin-top: 8px;
  font-weight: 700;
  color: var(--stb-blue);
  text-decoration: none;
}
.stb-footer .stb-instructor-public-link:hover,
.stb-single-instructor-link:hover {
  text-decoration: underline;
}
@media (max-width: 760px) {
  .stb-secure-admin { padding: 12px 8px 32px; }
  .stb-secure-header {
    padding: 14px;
    border-radius: 10px 10px 0 0;
  }
  .stb-secure-header h1 { font-size: 20px; }
  .stb-secure-body { padding: 10px; }
  .stb-kpi-grid {
    grid-template-columns: repeat(2, minmax(120px, 1fr));
    gap: 8px;
  }
  .stb-kpi { padding: 10px; }
  .stb-kpi strong { font-size: 24px; }
  .stb-table-scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .stb-admin-table {
    min-width: 900px;
    font-size: 13px;
  }
  .stb-action-form textarea { min-height: 72px; }
  .stb-action-row .stb-admin-btn,
  .stb-dash-actions .stb-admin-btn,
  .stb-admin-nav a {
    margin-bottom: 8px;
  }
}


/* ===== v2.0 Editable Public Content Settings ===== */
.stb-content-settings textarea {
  width: 100%;
  max-width: 900px;
  min-height: 170px;
}
.stb-content-settings input[type="text"],
.stb-content-settings input[type="url"] {
  width: 100%;
  max-width: 900px;
}


/* ===== v2.0.5 Class Selection Cleanup ===== */
.stb-class-selection-heading{margin-top:0;font-size:20px;font-weight:600;}

/* v2.0.8 Editable Form Settings */
.stb-form-settings input[type="text"], .stb-form-settings textarea { width:100%; max-width:900px; }
.stb-form-settings textarea { min-height:90px; }

/* v2.0.9 Disenrolled Archive */
.stb-archive-card{border-left:6px solid #50575e;}
.stb-admin-btn-archive{background:#3c434a;border-color:#3c434a;color:#fff;}
.stb-status-archived{background:#eef0f3;color:#3c4043;}

/* v2.0.10 Archive Page */
.stb-archive-page-note{color:#646970;margin:0 0 14px;}


/* ===== v2.0.11 Count Fix + Mobile Readability ===== */
.stb-mobile-reg-cards {
  display: none;
}
.stb-mobile-reg-card {
  background: #fff;
  border: 1px solid #c3c4c7;
  border-radius: 10px;
  margin: 12px 0;
  padding: 14px;
  box-shadow: 0 1px 2px rgba(0,0,0,.06);
}
.stb-mobile-reg-card h3 {
  margin: 0 0 8px;
  font-size: 18px;
}
.stb-mobile-reg-row {
  margin: 6px 0;
  font-size: 14px;
}
.stb-mobile-reg-row strong {
  display: block;
  color: #50575e;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .02em;
}
.stb-dashboard-refresh-note {
  font-size: 13px;
  color: #646970;
  margin: 8px 0 0;
}
@media (max-width: 760px) {
  .stb-secure-admin {
    padding: 8px 6px 28px;
  }
  .stb-secure-header {
    padding: 14px 12px;
  }
  .stb-secure-header h1 {
    font-size: 19px;
    line-height: 1.2;
  }
  .stb-secure-body {
    padding: 10px 8px;
  }
  .stb-kpi-grid {
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }
  .stb-kpi {
    padding: 12px 10px;
    border-radius: 10px;
  }
  .stb-kpi strong {
    font-size: 26px;
  }
  .stb-kpi span {
    font-size: 12px;
  }
  .stb-dash-actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
  }
  .stb-admin-btn,
  .stb-admin-btn-primary,
  .stb-admin-btn-danger,
  .stb-admin-btn-muted,
  .stb-admin-btn-archive {
    width: 100%;
    text-align: center;
    box-sizing: border-box;
    margin-bottom: 6px;
    min-height: 40px;
  }
  .stb-secure-card {
    padding: 12px;
    border-radius: 10px;
  }
  .stb-secure-card h2 {
    font-size: 18px;
  }
  .stb-table-scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border-radius: 8px;
  }
  .stb-admin-table {
    min-width: 860px;
    font-size: 13px;
  }
  .stb-admin-table th,
  .stb-admin-table td {
    padding: 8px;
  }
  .stb-action-form textarea {
    min-height: 78px;
    font-size: 15px;
  }
  .stb-action-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 6px;
  }
  .stb-mobile-reg-cards {
    display: block;
  }
  .stb-registration-management-table {
    display: none;
  }
}


/* ===== v2.0.12 Auto-Hide Fields + Light/Dark Mode ===== */
.stb-theme-toggle-wrap {
  display: flex;
  justify-content: flex-end;
  max-width: 900px;
  margin: 0 auto 10px;
  padding: 0 14px;
}
.stb-theme-toggle {
  border: 1px solid var(--stb-border);
  background: var(--stb-card);
  color: var(--stb-text);
  border-radius: 999px;
  padding: 7px 12px;
  cursor: pointer;
  font-weight: 700;
  box-shadow: 0 1px 2px rgba(60,64,67,.08);
}
body.stb-dark-mode {
  --stb-bg: #111827;
  --stb-card: #1f2937;
  --stb-text: #f9fafb;
  --stb-muted: #d1d5db;
  --stb-border: #374151;
  --stb-focus: #93c5fd;
  background: var(--stb-bg);
  color: var(--stb-text);
}
body.stb-dark-mode .stb-header-card,
body.stb-dark-mode .stb-card,
body.stb-dark-mode .stb-calendar-item,
body.stb-dark-mode .stb-secure-card,
body.stb-dark-mode .stb-kpi,
body.stb-dark-mode .stb-mobile-reg-card {
  background: var(--stb-card);
  color: var(--stb-text);
  border-color: var(--stb-border);
}
body.stb-dark-mode .stb-input,
body.stb-dark-mode textarea,
body.stb-dark-mode select,
body.stb-dark-mode input[type="text"],
body.stb-dark-mode input[type="email"],
body.stb-dark-mode input[type="search"],
body.stb-dark-mode input[type="url"],
body.stb-dark-mode input[type="number"],
body.stb-dark-mode input[type="date"],
body.stb-dark-mode input[type="time"] {
  color: var(--stb-text);
  background: #111827;
  border-color: var(--stb-border);
}
body.stb-dark-mode .stb-admin-table,
body.stb-dark-mode .stb-admin-table td,
body.stb-dark-mode .stb-admin-table th,
body.stb-dark-mode .stb-wp-table,
body.stb-dark-mode .stb-wp-table td,
body.stb-dark-mode .stb-wp-table th {
  background: #1f2937;
  color: var(--stb-text);
  border-color: var(--stb-border);
}
body.stb-dark-mode .stb-admin-table tr:nth-child(even) td,
body.stb-dark-mode .stb-wp-table tr:nth-child(even) td {
  background: #273449;
}
body.stb-dark-mode .stb-secure-body,
body.stb-dark-mode .stb-admin-body {
  background: #111827;
  border-color: var(--stb-border);
}
body.stb-dark-mode a {
  color: #93c5fd;
}
.stb-hidden-by-settings {
  display: none !important;
}
@media (max-width: 760px) {
  .stb-theme-toggle-wrap {
    justify-content: center;
  }
  .stb-theme-toggle {
    width: 100%;
    max-width: 360px;
  }
}


/* ===== v2.0.13 Toggle Position + Validation Fix ===== */
.stb-theme-toggle-wrap {
  justify-content: flex-start !important;
  max-width: 900px;
  margin: 0 auto 10px !important;
  padding: 0 14px !important;
}
.stb-theme-toggle {
  min-width: 128px;
}
.stb-form-settings .stb-disable-note {
  color: #646970;
  font-style: italic;
  margin-top: 4px;
}
@media (max-width: 760px) {
  .stb-theme-toggle-wrap {
    justify-content: flex-start !important;
  }
  .stb-theme-toggle {
    width: auto !important;
    max-width: none !important;
  }
}


/* ===== v2.0.14 Top-Right Toggle + Required Fields Confirmation ===== */
.stb-theme-toggle-wrap {
  justify-content: flex-end !important;
  max-width: 900px;
  margin: 0 auto 10px !important;
  padding: 0 14px !important;
}
.stb-theme-toggle {
  min-width: 128px;
}
@media (max-width: 760px) {
  .stb-theme-toggle-wrap {
    justify-content: flex-end !important;
  }
  .stb-theme-toggle {
    width: auto !important;
    max-width: none !important;
  }
}
