/* ================================================================
   Bridge of Hope Recovery — Design Token & Component Override File
   Loaded after Bootstrap, before main.css and page CSS.

   PURPOSE: Ensure every Bootstrap component (modal, table, card,
   dropdown, form) renders in the BOH palette regardless of OS
   color-scheme preference. Bootstrap 5.3 respects prefers-color-scheme
   by default; this file locks every component to our explicit scheme.
   ================================================================ */

/* ── 1. DESIGN TOKENS ───────────────────────────────────────── */

:root {
    /* Backgrounds */
    --boh-bg-page:        #F5F2EE;   /* warm cream — body */
    --boh-bg-cream:       #FFFDF9;   /* near-white cream — cards, modal body */
    --boh-bg-dark:        #2b2f34;   /* charcoal — nav, footer, dark panels */
    --boh-bg-near-black:  #1A1816;   /* near-black — headings, emphasis bg */
    --boh-bg-light:       #f0ece6;   /* lightest warm — hover, zebra */

    /* Text */
    --boh-text-body:      #2C2A26;   /* main body text */
    --boh-text-heading:   #1A1816;   /* headings, strong */
    --boh-text-muted:     #7A7368;   /* secondary / labels */
    --boh-text-subtle:    #9a9390;   /* placeholders, hints */
    --boh-text-on-dark:   #f0ece6;   /* text on charcoal backgrounds */
    --boh-text-on-accent: #ffffff;   /* text on coloured buttons/badges */

    /* Accent palette (matches boundary card colours — the site standard) */
    --boh-blue:           #3A6B8A;   /* primary / slate blue */
    --boh-blue-dark:      #2a4f6a;
    --boh-teal:           #4A7A8A;   /* info */
    --boh-amber:          #C4884A;   /* warning / ochre */
    --boh-amber-dark:     #a0674b;
    --boh-sage:           #709775;   /* green light */
    --boh-sage-dark:      #5C7A5E;   /* success / sage dark */
    --boh-red:            #9B3A3A;   /* danger */
    --boh-red-dark:       #7a2a2a;
    --boh-purple:         #7A5C8A;   /* extra accent */
    --boh-olive:          #8B6914;   /* extra accent */
    --boh-taupe:          #7A7368;   /* secondary */
    --boh-gold:           #A68A64;   /* dividers, decorative */

    /* TRAUMA letter colours — one per pillar */
    --trauma-T:           #3A6B8A;   /* Trust     — slate blue  */
    --trauma-R:           #C4884A;   /* Resiliency — amber      */
    --trauma-A1:          #709775;   /* Accountability — sage   */
    --trauma-U:           #7A5C8A;   /* Understanding — purple  */
    --trauma-M:           #5C7A5E;   /* Mindfulness — sage dark */
    --trauma-A2:          #4A7A8A;   /* Action    — teal        */

    /* Borders */
    --boh-border:         rgba(60,50,40,0.15);
    --boh-border-strong:  rgba(60,50,40,0.28);
}


/* ── 2. NAVBAR (dark charcoal, always white text) ───────────── */

.navbar {
    background-color: var(--boh-bg-dark) !important;
}

.navbar .nav-link,
.navbar .navbar-brand,
.navbar .navbar-text {
    color: var(--boh-text-on-dark) !important;
}

.navbar .nav-link:hover,
.navbar .nav-link:focus,
.navbar .nav-link.active {
    color: #ffffff !important;
}

/* Hamburger spans on mobile */
.navbar-toggler .hamburger span {
    background: var(--boh-text-on-dark);
}

/* Dropdown menus open on cream-white, dark text */
.navbar .dropdown-menu {
    background-color: var(--boh-bg-cream) !important;
    border: 1px solid var(--boh-border-strong);
}

.navbar .dropdown-menu .dropdown-item,
.navbar .dropdown-menu h5,
.navbar .dropdown-menu p,
.navbar .dropdown-menu a:not(.btn) {
    color: var(--boh-text-body) !important;
}

.navbar .dropdown-menu .dropdown-item:hover,
.navbar .dropdown-menu .dropdown-item:focus {
    background-color: var(--boh-bg-light) !important;
    color: var(--boh-text-heading) !important;
}

/* list-group items inside mega-menu */
.navbar .list-group-item {
    background-color: transparent;
    color: var(--boh-text-body) !important;
    border-color: var(--boh-border);
}

.navbar .list-group-item:hover {
    background-color: var(--boh-bg-light) !important;
    color: var(--boh-text-heading) !important;
}


/* ── 3. MODALS ───────────────────────────────────────────────── */

.modal-content {
    background-color: var(--boh-bg-cream);
    border: 1px solid var(--boh-border-strong);
    border-radius: 6px;
    color: var(--boh-text-body);
}

.modal-header {
    background-color: var(--boh-bg-dark);
    color: var(--boh-text-on-dark);
    border-bottom: none;
    border-radius: 6px 6px 0 0;
    padding: 14px 20px;
}

.modal-title {
    color: var(--boh-text-on-dark);
    font-weight: 500;
    letter-spacing: 0.02em;
}

/* White X button in dark modal header */
.modal-header .btn-close {
    filter: invert(1) grayscale(1) brightness(2);
    opacity: 0.8;
}
.modal-header .btn-close:hover {
    opacity: 1;
}

.modal-body {
    background-color: var(--boh-bg-cream);
    color: var(--boh-text-body);
    padding: 20px;
}

.modal-footer {
    background-color: var(--boh-bg-page);
    border-top: 1px solid var(--boh-border);
    border-radius: 0 0 6px 6px;
}

/* Labels and small text inside modals */
.modal-body label,
.modal-body .form-label {
    color: var(--boh-text-muted);
    font-size: 0.85rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin-bottom: 4px;
}

.modal-body .form-control,
.modal-body .form-select {
    background-color: #ffffff;
    border-color: var(--boh-border-strong);
    color: var(--boh-text-body);
}

.modal-body .form-control:focus,
.modal-body .form-select:focus {
    border-color: var(--boh-blue);
    box-shadow: 0 0 0 0.2rem rgba(58,107,138,0.18);
}

/* Section headers inside modal body */
.modal-body h5,
.modal-body h6 {
    color: var(--boh-text-heading);
}

/* Small alert banners inside modals */
.modal-body .alert {
    font-size: 0.9rem;
}


/* ── 4. TABLES ───────────────────────────────────────────────── */

.table {
    color: var(--boh-text-body);
    border-color: var(--boh-border);
    --bs-table-bg: var(--boh-bg-cream);
    --bs-table-striped-bg: var(--boh-bg-page);
    --bs-table-hover-bg: rgba(58,107,138,0.07);
    --bs-table-border-color: var(--boh-border);
    --bs-table-color: var(--boh-text-body);
    --bs-table-striped-color: var(--boh-text-body);
    --bs-table-active-bg: rgba(58,107,138,0.12);
    --bs-table-active-color: var(--boh-text-body);
}

.table thead th {
    background-color: var(--boh-bg-dark);
    color: var(--boh-text-on-dark);
    border-bottom: none;
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding: 10px 14px;
    white-space: nowrap;
}

.table tbody tr:last-child td {
    border-bottom: none;
}

.table-hover tbody tr:hover {
    background-color: rgba(58,107,138,0.07);
    color: var(--boh-text-body);
}

/* Sortable column headers */
.table thead th[data-sort] {
    cursor: pointer;
    user-select: none;
    position: relative;
    padding-right: 24px;
}

.table thead th[data-sort]::after {
    content: '⇕';
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    opacity: 0.4;
    font-size: 0.75rem;
}

.table thead th[data-sort].sort-asc::after  { content: '↑'; opacity: 0.9; }
.table thead th[data-sort].sort-desc::after { content: '↓'; opacity: 0.9; }

.table thead th[data-sort]:hover {
    background-color: #3d4349;
}


/* ── 5. CARDS ────────────────────────────────────────────────── */

.card {
    background-color: var(--boh-bg-cream);
    border-color: var(--boh-border);
    color: var(--boh-text-body);
}

.card-header {
    background-color: var(--boh-bg-page);
    border-bottom: 1px solid var(--boh-border);
    color: var(--boh-text-body);
    font-weight: 600;
}

.card-footer {
    background-color: var(--boh-bg-page);
    border-top: 1px solid var(--boh-border);
}


/* ── 6. FORMS ────────────────────────────────────────────────── */

.form-control,
.form-select {
    background-color: #ffffff;
    border-color: var(--boh-border-strong);
    color: var(--boh-text-body);
}

.form-control::placeholder {
    color: var(--boh-text-subtle);
}

.form-control:focus,
.form-select:focus {
    border-color: var(--boh-blue);
    box-shadow: 0 0 0 0.2rem rgba(58,107,138,0.18);
    background-color: #ffffff;
    color: var(--boh-text-body);
}

.form-label {
    color: var(--boh-text-muted);
    font-size: 0.85rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.form-text {
    color: var(--boh-text-subtle);
}

.form-check-input:checked {
    background-color: var(--boh-blue);
    border-color: var(--boh-blue);
}

.input-group-text {
    background-color: var(--boh-bg-page);
    border-color: var(--boh-border-strong);
    color: var(--boh-text-muted);
}


/* ── 7. BADGES & ALERTS ─────────────────────────────────────── */

/* Already overridden in main.css; these are supplemental fixes. */

.alert {
    border-width: 1px;
}

.alert-info {
    background-color: rgba(74,122,138,0.12) !important;
    border-color: rgba(74,122,138,0.3) !important;
    color: #1e4a57 !important;
}

.alert-success {
    background-color: rgba(92,122,94,0.12) !important;
    border-color: rgba(92,122,94,0.3) !important;
    color: #2d4e2e !important;
}

.alert-warning {
    background-color: rgba(196,136,74,0.12) !important;
    border-color: rgba(196,136,74,0.3) !important;
    color: #6b3e0a !important;
}

.alert-danger {
    background-color: rgba(155,58,58,0.12) !important;
    border-color: rgba(155,58,58,0.3) !important;
    color: #5c1818 !important;
}

/* Primary alert (info-like) */
.alert-primary {
    background-color: rgba(58,107,138,0.12) !important;
    border-color: rgba(58,107,138,0.3) !important;
    color: #1e3d55 !important;
}


/* ── 8. DROPDOWNS (outside nav) ─────────────────────────────── */

.dropdown-menu {
    background-color: var(--boh-bg-cream);
    border: 1px solid var(--boh-border-strong);
}

.dropdown-item {
    color: var(--boh-text-body);
}

.dropdown-item:hover,
.dropdown-item:focus {
    background-color: var(--boh-bg-light);
    color: var(--boh-text-heading);
}

.dropdown-divider {
    border-color: var(--boh-border);
}

.dropdown-header {
    color: var(--boh-text-muted);
    font-size: 0.75rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}


/* ── 9. LIST GROUPS ─────────────────────────────────────────── */

.list-group-item {
    background-color: var(--boh-bg-cream);
    border-color: var(--boh-border);
    color: var(--boh-text-body);
}

.list-group-item.active {
    background-color: var(--boh-blue);
    border-color: var(--boh-blue-dark);
    color: #ffffff;
}

.list-group-item-action:hover,
.list-group-item-action:focus {
    background-color: var(--boh-bg-light);
    color: var(--boh-text-heading);
}


/* ── 10. DARK PANEL UTILITY ─────────────────────────────────── */

/* Use class="boh-dark-panel" for any pane that should have
   the dark admin/IT styling (dark bg, light text, coloured data). */

.boh-dark-panel {
    background-color: var(--boh-bg-dark);
    color: var(--boh-text-on-dark);
    border-radius: 8px;
    padding: 16px;
}

.boh-dark-panel h1,
.boh-dark-panel h2,
.boh-dark-panel h3,
.boh-dark-panel h4,
.boh-dark-panel h5,
.boh-dark-panel h6 {
    color: var(--boh-text-on-dark);
}

.boh-dark-panel .text-muted,
.boh-dark-panel small {
    color: rgba(240,236,230,0.6) !important;
}

.boh-dark-panel .table {
    --bs-table-bg: transparent;
    --bs-table-color: var(--boh-text-on-dark);
    --bs-table-border-color: rgba(255,255,255,0.12);
    --bs-table-hover-bg: rgba(255,255,255,0.07);
}

.boh-dark-panel .table thead th {
    background-color: rgba(0,0,0,0.3);
    color: var(--boh-text-on-dark);
    border-bottom: 1px solid rgba(255,255,255,0.15);
}

.boh-dark-panel .card {
    background-color: rgba(255,255,255,0.06);
    border-color: rgba(255,255,255,0.12);
    color: var(--boh-text-on-dark);
}

.boh-dark-panel .card-header {
    background-color: rgba(0,0,0,0.2);
    border-color: rgba(255,255,255,0.12);
    color: var(--boh-text-on-dark);
}

/* Stat/number emphasis in dark panels */
.boh-dark-panel .boh-stat {
    font-size: 1.8rem;
    font-weight: 700;
    color: lightskyblue;
    line-height: 1;
}

.boh-dark-panel .boh-stat-label {
    font-size: 0.7rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(240,236,230,0.55);
    margin-top: 4px;
}


/* ── 11. TRAUMA FIRST CHARACTERS (drop-caps) ─────────────────
   The existing .first-character class + inline colour1-color10
   classes produce the big drop-cap letters. Here we give them
   a consistent colour that maps to TRAUMA pillars so they are
   always readable on the cream background.
   ────────────────────────────────────────────────────────────── */

.first-character.color1  { color: var(--trauma-T);  }   /* Trust */
.first-character.color2  { color: var(--trauma-R);  }   /* Resiliency */
.first-character.color3  { color: var(--trauma-A1); }   /* Accountability */
.first-character.color4  { color: var(--trauma-U);  }   /* Understanding */
.first-character.color5  { color: var(--trauma-M);  }   /* Mindfulness */
.first-character.color6  { color: var(--trauma-A2); }   /* Action */


/* ── 12. TOOLTIPS & POPOVERS ────────────────────────────────── */

.tooltip .tooltip-inner {
    background-color: var(--boh-bg-near-black);
    color: var(--boh-text-on-dark);
    font-size: 0.82rem;
}

.bs-tooltip-auto[data-popper-placement^=bottom] .tooltip-arrow::before,
.bs-tooltip-bottom .tooltip-arrow::before {
    border-bottom-color: var(--boh-bg-near-black);
}

.popover {
    background-color: var(--boh-bg-cream);
    border-color: var(--boh-border-strong);
}

.popover-header {
    background-color: var(--boh-bg-page);
    color: var(--boh-text-heading);
    border-color: var(--boh-border);
}

.popover-body {
    color: var(--boh-text-body);
}


/* ── 13. PAGINATION ─────────────────────────────────────────── */

.page-link {
    color: var(--boh-blue);
    background-color: var(--boh-bg-cream);
    border-color: var(--boh-border);
}

.page-link:hover {
    color: var(--boh-blue-dark);
    background-color: var(--boh-bg-light);
    border-color: var(--boh-border-strong);
}

.page-item.active .page-link {
    background-color: var(--boh-blue);
    border-color: var(--boh-blue-dark);
    color: #ffffff;
}

.page-item.disabled .page-link {
    color: var(--boh-text-subtle);
    background-color: var(--boh-bg-page);
    border-color: var(--boh-border);
}


/* ── 14. TABS & PILLS ───────────────────────────────────────── */

.nav-tabs .nav-link {
    color: var(--boh-text-muted);
    border-color: transparent;
}

.nav-tabs .nav-link:hover {
    color: var(--boh-text-body);
    border-color: var(--boh-border);
    background-color: var(--boh-bg-light);
}

.nav-tabs .nav-link.active {
    color: var(--boh-text-heading);
    background-color: var(--boh-bg-cream);
    border-color: var(--boh-border) var(--boh-border) var(--boh-bg-cream);
}

.nav-pills .nav-link {
    color: var(--boh-text-body);
}

.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
    background-color: var(--boh-blue);
    color: #ffffff;
}


/* ── 15. ACCORDION ──────────────────────────────────────────── */

.accordion-item {
    background-color: var(--boh-bg-cream);
    border-color: var(--boh-border);
    color: var(--boh-text-body);
}

.accordion-button {
    background-color: var(--boh-bg-page);
    color: var(--boh-text-heading);
}

.accordion-button:not(.collapsed) {
    background-color: rgba(58,107,138,0.1);
    color: var(--boh-blue);
    box-shadow: inset 0 -1px 0 var(--boh-border);
}

.accordion-button:focus {
    box-shadow: 0 0 0 0.2rem rgba(58,107,138,0.18);
}

.accordion-button::after {
    filter: none;
}

.accordion-body {
    background-color: var(--boh-bg-cream);
    color: var(--boh-text-body);
}


/* ── 16. PROGRESS BARS ──────────────────────────────────────── */

.progress {
    background-color: var(--boh-border);
}

.progress-bar {
    background-color: var(--boh-blue);
}


/* ── 17. BODY & PAGE CHROME ─────────────────────────────────── */

/* Ensure body bg never goes white-on-dark from Bootstrap colour-scheme */
body {
    background-color: var(--boh-bg-page) !important;
    color: var(--boh-text-body) !important;
}

/* Footer always dark */
footer {
    background-color: var(--boh-bg-dark) !important;
    color: var(--boh-text-on-dark) !important;
}

/* Headings */
h1, h2, h3, h4, h5, h6 {
    color: var(--boh-text-heading);
}

/* Anchor default (outside nav/buttons) */
a {
    color: var(--boh-blue);
}

a:hover {
    color: var(--boh-blue-dark);
}
