/* Header styling using --text-strong */
.text-header {
    color: var(--text-strong);
    font-weight: 600;
    /* matches your strong text */
    line-height: 1.3;
    font-size: var(--font-size-lg);
    /* default size for h5-ish headers */
    margin-bottom: var(--spacing-sm);
}

/* ==========================
   Bootstrap buttons & links: use theme variables (all themes)
========================= */
.btn-primary {
    background-color: var(--brand-primary);
    border-color: var(--brand-primary);
    color: var(--text-strong);
}
.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active {
    background-color: var(--brand-primary-hover);
    border-color: var(--brand-primary-hover);
    color: var(--text-strong);
}
.btn-secondary {
    background-color: var(--surface-3);
    border-color: var(--border-strong);
    color: var(--text-main);
}
.btn-secondary:hover,
.btn-secondary:focus,
.btn-secondary:active {
    background-color: var(--surface-4);
    border-color: var(--border-strong);
    color: var(--text-strong);
}
.btn-success {
    background-color: var(--success);
    border-color: var(--success);
    color: var(--text-strong);
}
.btn-success:hover,
.btn-success:focus,
.btn-success:active {
    background-color: var(--success);
    border-color: var(--success);
    color: var(--text-strong);
    filter: brightness(1.08);
}
.btn-info {
    background-color: var(--info);
    border-color: var(--info);
    color: var(--text-strong);
}
.btn-info:hover,
.btn-info:focus,
.btn-info:active {
    background-color: var(--info-hover);
    border-color: var(--info-hover);
    color: var(--text-strong);
}
.btn-warning {
    background-color: var(--warning);
    border-color: var(--warning);
    color: var(--text-strong);
}
.btn-warning:hover,
.btn-warning:focus,
.btn-warning:active {
    background-color: var(--warning);
    border-color: var(--warning);
    color: var(--text-strong);
    filter: brightness(1.08);
}
.btn-danger {
    background-color: var(--error);
    border-color: var(--error);
    color: var(--text-strong);
}
.btn-danger:hover,
.btn-danger:focus,
.btn-danger:active {
    background-color: var(--error);
    border-color: var(--error);
    color: var(--text-strong);
    filter: brightness(1.08);
}
/* Outline buttons */
.btn-outline-primary {
    border-color: var(--brand-primary);
    color: var(--brand-primary);
}
.btn-outline-primary:hover,
.btn-outline-primary:focus,
.btn-outline-primary:active {
    background-color: var(--brand-primary);
    border-color: var(--brand-primary);
    color: var(--text-strong);
}
.btn-outline-secondary {
    border-color: var(--border-strong);
    color: var(--text-main);
}
.btn-outline-secondary:hover,
.btn-outline-secondary:focus,
.btn-outline-secondary:active {
    background-color: var(--surface-3);
    border-color: var(--border-strong);
    color: var(--text-strong);
}
.btn-outline-success {
    border-color: var(--success);
    color: var(--success);
}
.btn-outline-success:hover,
.btn-outline-success:focus,
.btn-outline-success:active {
    background-color: var(--success);
    border-color: var(--success);
    color: var(--text-strong);
}
.btn-outline-info {
    border-color: var(--info);
    color: var(--info);
}
.btn-outline-info:hover,
.btn-outline-info:focus,
.btn-outline-info:active {
    background-color: var(--info);
    border-color: var(--info);
    color: var(--text-strong);
}
.btn-outline-warning {
    border-color: var(--warning);
    color: var(--warning);
}
.btn-outline-warning:hover,
.btn-outline-warning:focus,
.btn-outline-warning:active {
    background-color: var(--warning);
    border-color: var(--warning);
    color: var(--text-strong);
}
.btn-outline-danger {
    border-color: var(--error);
    color: var(--error);
}
.btn-outline-danger:hover,
.btn-outline-danger:focus,
.btn-outline-danger:active {
    background-color: var(--error);
    border-color: var(--error);
    color: var(--text-strong);
}
/* Links: use theme accent */
a {
    color: var(--link-color);
}
a:hover {
    color: var(--link-hover);
}
.link-primary {
    color: var(--brand-primary);
}
.link-primary:hover {
    color: var(--brand-primary-hover);
}
/* Bootstrap badge semantic colors (so they follow theme) */
.bg-primary { background-color: var(--brand-primary) !important; }
.bg-success { background-color: var(--success) !important; }
.bg-warning { background-color: var(--warning) !important; }
.bg-danger { background-color: var(--error) !important; }
.bg-info { background-color: var(--info) !important; }
.bg-secondary { background-color: var(--surface-4) !important; }
.text-primary { color: var(--brand-primary) !important; }
.border-primary { border-color: var(--brand-primary) !important; }

.button {
    padding: var(--spacing-sm) var(--spacing-md);
    border-radius: var(--radius-md);
    border: none;
    font-weight: 600;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.button-primary {
    background: var(--brand-primary);
    color: var(--text-strong);
}

.button-danger {
    background: var(--error);
    color: var(--text-strong);
}

.button-danger:hover,
.btn-danger:hover {
    background: var(--error);
    color: var(--text-strong);
    filter: brightness(0.92);
}

.button-warning {
    background: var(--warning);
    color: var(--text-strong);
}

.button-success {
    background: var(--success);
    color: var(--text-strong);
}

.button-primary:hover {
    background: var(--brand-primary-hover);
}

/* Importance toggles (crew info modal): hover = stay semantic color, not black */
.btn.button-danger:hover,
.btn.button-warning:hover,
.btn.button-success:hover {
    color: var(--text-strong) !important;
}
.btn.button-danger:hover {
    background: var(--error) !important;
    border-color: var(--error);
    filter: brightness(1.1);
}
.btn.button-warning:hover {
    background: var(--warning) !important;
    border-color: var(--warning);
    filter: brightness(1.1);
}
.btn.button-success:hover {
    background: var(--success) !important;
    border-color: var(--success);
    filter: brightness(1.1);
}

/* Importance toggles (crew info modal): selected = prominent, not black */
.btn-check:checked + .btn.button-danger {
    background: var(--error);
    color: var(--text-strong);
    border: 2px solid var(--text-strong);
    box-shadow: 0 0 0 2px var(--error);
}

.btn-check:checked + .btn.button-warning {
    background: var(--warning);
    color: var(--text-strong);
    border: 2px solid var(--text-strong);
    box-shadow: 0 0 0 2px var(--warning);
}

.btn-check:checked + .btn.button-success {
    background: var(--success);
    color: var(--text-strong);
    border: 2px solid var(--text-strong);
    box-shadow: 0 0 0 2px var(--success);
}

.button-secondary {
    background: var(--surface-2);
    color: var(--text-main);
    border: 1px solid var(--border-subtle);
}

.button-info {
    background: var(--info);
    color: var(--text-main);
    border: 1px solid var(--border-subtle);
}

.btn.button-info:hover,
.btn.button-info:focus,
.btn.button-info:active {
    background: var(--info-hover) !important;
    border-color: var(--info-hover) !important;
    color: var(--text-strong) !important;
}

.card {
    background: var(--surface-2);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-md);
    padding: var(--spacing-md);
    transition: background var(--transition-fast), box-shadow var(--transition-fast);
}

.card:hover {
    background: var(--surface-3);
    box-shadow: var(--shadow-lg);
}

/* Main content area: cards use slightly lighter bg for contrast, no hover effect */
.main-content .card {
    background: var(--surface-3);
}
.main-content .card:hover {
    background: var(--surface-3);
    box-shadow: var(--shadow-md);
}

/* Card header for tab content (dark theme) */
.bg-dashboard-header {
    background-color: var(--surface-1);
    border-bottom: 1px solid var(--border-subtle);
}

.badge {
    font-size: 0.75rem;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: var(--radius-sm);
    color: var(--text-inverse);
}

.badge-success {
    background: var(--success);
}

.badge-error {
    background: var(--error);
}

.badge-warning {
    background: var(--warning);
}

.badge-info {
    background: var(--info);
}

/* Base badge style already handled by .subtask-type */

.badge-basic {
    background-color: var(--badge-basic);
    color: var(--text-main);
}

.badge-yesno {
    background-color: var(--badge-yesno);
    color: var(--text-strong);
}

.badge-photo {
    background-color: var(--badge-photo);
    color: var(--text-strong);
}

.badge-textbox {
    background-color: var(--badge-textbox);
    color: var(--text-strong);
}

.badge-header {
    background-color: var(--badge-header);
    color: var(--text-strong);
}


/* ==========================
   Generic Text Classes
========================== */

/* Strong text: default for headings, labels, important text */
.text-strong {
    color: var(--text-strong);
    font-weight: 600;
    /* slightly bolder for emphasis */
    line-height: 1.4;
}

/* Optional: smaller variant */
.text-strong-sm {
    color: var(--text-strong);
    font-weight: 600;
    font-size: 0.875rem;
    /* 14px approx */
    line-height: 1.3;
}

/* Optional: uppercase variant */
.text-strong-uppercase {
    color: var(--text-strong);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* ==========================
   Manage Training Categories (dark)
   Dropdown + #categoryEditor list-group and task rows
========================== */
#manage-categories #categoryDropdown,
#manage-categories .form-select {
    background-color: var(--surface-2, #2b2d31);
    border-color: var(--surface-active, #46484d);
    color: var(--text-main, #d6dbe3);
}
#manage-categories #categoryDropdown:disabled {
    opacity: 0.9;
}

/* Assign Training: category multi-select fits options, no scrollbar */
#assign-training #categorySelect {
    min-height: 0;
    max-height: none;
    overflow: hidden;
}
#assign-training #categorySelect.form-select {
    background-color: var(--surface-2, #2b2d31);
    border-color: var(--surface-active, #46484d);
    color: var(--text-main, #d6dbe3);
}
#assign-training #categorySelect:disabled {
    opacity: 0.8;
}
#categoryEditor .list-group,
#categoryEditor .list-group-item,
#categoryEditor ul.list-group {
    background-color: var(--surface-2, #2b2d31);
    border-color: var(--surface-active, #46484d);
    color: var(--text-main, #d6dbe3);
}
#categoryEditor .list-group-item {
    background-color: var(--surface-3, #313338);
    border-color: var(--surface-active, #46484d);
    color: var(--text-main, #d6dbe3);
}
#categoryEditor .list-group-item:hover {
    background-color: var(--surface-active, #46484d);
}
#categoryEditor .list-group-item .list-group {
    background-color: var(--surface-2, #2b2d31);
}
#categoryEditor .list-group-item .list-group .list-group-item {
    background-color: var(--surface-4, #3a3c40);
}
#categoryEditor .editable,
#categoryEditor .editable:focus {
    color: var(--text-main, #d6dbe3);
    background: transparent;
    border-color: transparent;
    outline: none;
}
#categoryEditor .editable:hover {
    background-color: rgba(255,255,255,0.05);
    border-radius: 4px;
}
#categoryEditor #categoryTitle {
    background-color: var(--surface-2, #2b2d31) !important;
    border-color: var(--surface-active, #46484d) !important;
    color: var(--text-main, #d6dbe3);
}
#categoryEditor .btn-outline-secondary {
    border-color: var(--text-muted, #9aa4b2);
    color: var(--text-muted, #9aa4b2);
}
#categoryEditor .btn-outline-secondary:hover {
    background-color: var(--surface-active, #46484d);
    border-color: var(--text-main, #d6dbe3);
    color: var(--text-main, #d6dbe3);
}
#categoryEditor .btn-outline-danger {
    border-color: var(--error, #b45c5c);
    color: var(--error, #b45c5c);
}
#categoryEditor .btn-outline-danger:hover {
    background-color: var(--error, #b45c5c);
    color: var(--text-strong, #f5f7fa);
}
#categoryEditor .btn-success {
    background-color: var(--success, #1f7a3e);
    border-color: var(--success, #1f7a3e);
    color: var(--text-strong, #f5f7fa);
}
#categoryEditor .btn-success:hover {
    filter: brightness(1.1);
}
#categoryEditor .badge.bg-success {
    background-color: var(--success, #1f7a3e) !important;
    color: var(--text-strong, #f5f7fa);
}

/* =========================
   Training History tab: accordion + table dark mode
========================= */
#training-history .card,
#training-history .card-body {
    background-color: var(--surface-2, #2b2d31);
    color: var(--text-main, #d6dbe3);
    border-color: var(--border-subtle, #46484d);
}
#training-history .card-header {
    background-color: var(--surface-3, #313338);
    border-color: var(--border-subtle, #46484d);
    color: var(--text-strong, #f5f7fa);
}
#training-history .form-label,
#training-history .text-strong,
#training-history h6 {
    color: var(--text-strong, #f5f7fa);
}
#training-history .form-select {
    background-color: var(--surface-1, #232629);
    color: var(--text-main, #d6dbe3);
    border-color: var(--border-strong, #46484d);
}
#training-history .text-muted {
    color: var(--text-muted, #9aa4b2);
}
#training-history .progress {
    background-color: var(--surface-3, #313338);
    border-radius: var(--radius-sm, 4px);
}
#training-history .progress-bar {
    color: var(--text-strong, #f5f7fa);
}
#training-history .progress-bar.bg-danger {
    background-color: var(--error, #b45c5c) !important;
}
#training-history .progress-bar.bg-warning {
    background-color: var(--warning, #b28f1a) !important;
}
#training-history .progress-bar.bg-success {
    background-color: var(--success, #1f7a3e) !important;
}
/* Accordion header badge: do not overlap chevron */
#training-history .accordion-button .badge.position-absolute {
    right: 2.5rem !important;
}
#training-history #history-placeholder.alert-info {
    background-color: rgba(155, 126, 189, 0.2);
    border-color: var(--border-subtle, #46484d);
    color: var(--text-main, #d6dbe3);
}

/* Accordion (category + nested subcategory) */
#training-history .accordion-item {
    background-color: var(--surface-2, #2b2d31);
    border-color: var(--border-subtle, #46484d);
}
#training-history .accordion-button {
    background-color: var(--surface-2, #2b2d31) !important;
    color: var(--text-strong, #f5f7fa) !important;
    border-color: var(--border-subtle, #46484d);
}
#training-history .accordion-button:not(.collapsed) {
    background-color: var(--surface-3, #313338) !important;
    color: var(--text-strong, #f5f7fa) !important;
}
#training-history .accordion-button:hover {
    background-color: var(--surface-4, #3a3c40) !important;
    color: var(--text-strong, #f5f7fa);
}
#training-history .accordion-button::after {
    filter: invert(1);
}
#training-history .accordion-body {
    background-color: var(--surface-2, #2b2d31);
    color: var(--text-main, #d6dbe3);
    border-color: var(--border-subtle, #46484d);
}
/* Nested accordion inside accordion-body */
#training-history .accordion-body .accordion-item {
    background-color: var(--surface-3, #313338);
    border-color: var(--border-subtle, #46484d);
}
#training-history .accordion-body .accordion-button {
    background-color: var(--surface-3, #313338) !important;
    color: var(--text-strong, #f5f7fa) !important;
}
#training-history .accordion-body .accordion-button:not(.collapsed) {
    background-color: var(--surface-4, #3a3c40) !important;
}
#training-history .accordion-body .accordion-body {
    background-color: var(--surface-2, #2b2d31);
    color: var(--text-main, #d6dbe3);
}

/* Tables (Task / Trainee / Trainer columns) */
#training-history .table {
    background-color: var(--surface-2, #2b2d31);
    color: var(--text-main, #d6dbe3);
    border-color: var(--border-subtle, #46484d);
}
#training-history .table thead th {
    background-color: var(--surface-4, #3a3c40);
    color: var(--text-strong, #f5f7fa);
    border-color: var(--border-subtle, #46484d);
    font-weight: 600;
}
#training-history .table tbody td {
    background-color: var(--surface-2, #2b2d31);
    color: var(--text-main, #d6dbe3);
    border-color: var(--border-subtle, #46484d);
}
#training-history .table tbody tr:hover td {
    background-color: var(--surface-3, #313338);
}

/* Badges in accordion headers */
#training-history .accordion-button .badge {
    background-color: var(--surface-4, #3a3c40);
    color: var(--text-main, #d6dbe3);
}
#training-history .accordion-button .badge.bg-success {
    background-color: var(--success, #1f7a3e) !important;
    color: var(--text-strong, #f5f7fa);
}
#training-history .accordion-button .badge.bg-warning,
#training-history .accordion-button .badge.bg-secondary {
    background-color: var(--warning, #b28f1a) !important;
    color: var(--text-strong, #f5f7fa);
}
/* Trainee/Trainer column badges (Training History) – compact for rows */
#training-history .who-when,
#training-history .trainer-badge {
  font-size: 0.75rem;
  padding: 0.2em 0.5em;
  border-radius: 4px;
  line-height: 1.2;
  border: 1px solid rgba(255, 255, 255, 0.1);
}
#training-history .who-when {
  color: var(--text-strong, #f5f7fa);
  background-color: var(--success, #1f7a3e);
}
#training-history .trainer-badge {
  color: var(--text-strong, #f5f7fa);
  background-color: var(--info, #0c8dbd);
}