@import url('https://fonts.googleapis.com/css2?family=Rajdhani:wght@400;500;600;700&family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;600;700&display=swap');

/* ============================================= */
/* Bronze Squadron JSOC Unified Theme v14        */
/* Personnel File aesthetic — mono/tactical      */
/* J-code accent colors preserved               */
/* ============================================= */

:root,
html,
body,
[data-theme],
[data-theme="dark"],
[data-theme="light"],
.dark,
.light,
body.dark,
body.light {
    color-scheme: dark !important;

    --bs-black: #030711;
    --bs-bg: #050a14;
    --bs-bg-soft: #08111f;

    --bs-surface: rgba(7, 15, 29, 0.58);
    --bs-surface-hover: rgba(12, 25, 43, 0.78);
    --bs-surface-solid: #08111f;

    --bs-border: rgba(120, 141, 160, 0.20);
    --bs-border-strong: rgba(201, 145, 58, 0.60);

    --bs-bronze: #c9913a;
    --bs-bronze-light: #e0b76c;
    --bs-bronze-soft: rgba(201, 145, 58, 0.16);

    --bs-steel: #9fb3c8;
    --bs-slate: #708090;

    --bs-cyan: #9fd8ef;
    --bs-blue: #4da3ff;
    --bs-green: #7fd6a4;
    --bs-gold: #ffcc73;
    --bs-orange: #d98b3a;
    --bs-red: #e36b6b;
    --bs-purple: #b68cff;

    --bs-text: #dfe8f2;
    --bs-text-strong: #f4f7fb;
    --bs-text-muted: #b8c4cf;
    --bs-text-soft: #8d9aaa;

    --bs-shadow-sm: 0 1px 2px rgba(0,0,0,0.35);
    --bs-shadow-md: 0 4px 12px rgba(0,0,0,0.38);
    --bs-shadow-lg: 0 8px 24px rgba(0,0,0,0.48);

    --bs-glow: 0 0 20px rgba(88,199,232,0.08);
    --bs-glow-strong: 0 0 30px rgba(201,145,58,0.20);

    --bs-radius-sm: 4px;
    --bs-radius: 6px;
    --bs-radius-lg: 8px;

    --bs-transition: 180ms ease;

    --bs-mono: 'JetBrains Mono', 'Courier New', monospace;

    --color-background: var(--bs-bg) !important;
    --color-foreground: var(--bs-text) !important;
    --color-card: var(--bs-surface) !important;
    --color-border: var(--bs-border) !important;
    --color-primary: var(--bs-bronze) !important;
}

/* ============================================= */
/* Force Light Mode To Match Dark Mode           */
/* ============================================= */

[data-theme="light"],
.light,
body.light {
    color-scheme: dark !important;
    --bs-bg: #050a14 !important;
    --bs-bg-soft: #08111f !important;
    --bs-surface: rgba(7, 15, 29, 0.58) !important;
    --bs-surface-hover: rgba(12, 25, 43, 0.78) !important;
    --bs-text: #dfe8f2 !important;
    --bs-text-strong: #f4f7fb !important;
    --bs-text-muted: #b8c4cf !important;
    --bs-text-soft: #8d9aaa !important;
    --bs-border: rgba(120,141,160,0.20) !important;
}

/* ============================================= */
/* Base / Background                             */
/* ============================================= */

html,
body {
    min-height: 100vh;
    margin: 0;
    font-family: var(--bs-mono) !important;
    color: var(--bs-text);
    background:
        linear-gradient(rgba(2,6,13,0.72), rgba(2,6,13,0.78)),
        url('https://www.bronzesquadron.com/storage/resources/tarmakback-69dd1402c2efc.png')
        center / cover fixed no-repeat !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
}

body,
#app,
main,
.page,
.content,
main.responsive {
    background-color: transparent !important;
}

/* Tactical grid overlay */
body::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    background:
        linear-gradient(rgba(88,199,232,0.018) 1px, transparent 1px),
        linear-gradient(90deg, rgba(88,199,232,0.018) 1px, transparent 1px),
        repeating-linear-gradient(
            to bottom,
            rgba(255,255,255,0.012) 0,
            rgba(255,255,255,0.012) 1px,
            transparent 1px,
            transparent 5px
        );
    background-size: 46px 46px, 46px 46px, 100% 5px;
    opacity: 0.6;
}

main,
#app,
body > .responsive,
body > .content {
    position: relative;
    z-index: 1;
}

* { box-sizing: border-box; }

/* ============================================= */
/* Typography — Monospace everywhere             */
/* ============================================= */

h1, h2, h3, h4, h5, h6,
p, span, a, li, td, th,
input, textarea, select,
.card-title,
.header-logo span,
.page-title,
button, .btn {
    font-family: var(--bs-mono) !important;
}

h1, h2, h3 {
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    color: var(--bs-text-strong) !important;
}

/* ============================================= */
/* Role / User Name Protection                   */
/* ============================================= */

a[href*="/profile"],
.username,
.user-name,
.author-name,
.member-name,
.user-link {
    font-weight: 700 !important;
    text-shadow: none !important;
    letter-spacing: 0.04em !important;
}

[class*="role"],
[class*="group"],
[class*="rank"],
[class*="badge"] {
    text-shadow: none !important;
}

/* ============================================= */
/* Links                                         */
/* ============================================= */

a:not([href*="/profile"]),
a:not([href*="/profile"]):link,
a:not([href*="/profile"]):visited,
a:not([href*="/profile"]):active,
a:not([href*="/profile"]):focus {
    color: var(--bs-cyan) !important;
    text-decoration: none !important;
    transition: color var(--bs-transition);
}

a:not([href*="/profile"]):hover {
    color: var(--bs-bronze-light) !important;
}

/* ============================================= */
/* Header                                        */
/* ============================================= */

header.header {
    position: relative;
    background: rgba(2, 5, 11, 0.96) !important;
    border-bottom: 1px solid rgba(201,145,58,0.35);
    padding: 12px 0;
    box-shadow: 0 2px 20px rgba(0,0,0,0.60);
}

header.header::after {
    content: "";
    display: block;
    height: 1px;
    margin-top: 10px;
    background: linear-gradient(
        90deg,
        transparent,
        rgba(88,199,232,0.35),
        rgba(201,145,58,0.55),
        transparent
    );
}

.header-logo {
    color: var(--bs-text-strong) !important;
    font-family: var(--bs-mono) !important;
    font-weight: 700 !important;
    font-size: 1rem !important;
    letter-spacing: 0.14em !important;
    text-transform: uppercase !important;
    text-decoration: none !important;
}

.header-logo span {
    color: var(--bs-text-strong) !important;
}

header.header .btn-link {
    color: var(--bs-text-muted) !important;
    font-family: var(--bs-mono) !important;
    font-size: 0.78rem !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
    transition: color var(--bs-transition);
}

header.header .btn-link:hover {
    color: var(--bs-bronze-light) !important;
}

/* ============================================= */
/* Header Dropdown                               */
/* ============================================= */

[data-controller="forumify--menu"] {
    position: relative !important;
    z-index: 999999 !important;
}

header.header .menu,
.menu {
    position: absolute !important;
    z-index: 2147483647 !important;
    background: rgba(3, 6, 14, 0.99) !important;
    border: 1px solid rgba(201,145,58,0.40) !important;
    border-top: 2px solid var(--bs-bronze) !important;
    box-shadow: 0 18px 42px rgba(0,0,0,0.90) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}

header.header .menu a.btn-link,
.menu a.btn-link {
    color: var(--bs-text-muted) !important;
    background: transparent !important;
    font-size: 0.78rem !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
}

header.header .menu a.btn-link:hover,
.menu a.btn-link:hover {
    color: var(--bs-bronze-light) !important;
    background: rgba(201,145,58,0.10) !important;
}

/* ============================================= */
/* .box — universal surface                      */
/* ============================================= */

.box {
    background: rgba(4, 8, 18, 0.88) !important;
    border: 1px solid rgba(120, 141, 160, 0.18) !important;
    border-left: 3px solid rgba(201, 145, 58, 0.50) !important;
    border-radius: var(--bs-radius) !important;
    box-shadow: 0 2px 12px rgba(0,0,0,0.50) !important;
    color: var(--bs-text) !important;
    position: relative !important;
    overflow: visible !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}

/* ============================================= */
/* Cards                                         */
/* ============================================= */

.card,
.forum-list .card,
.panel,
.modal-content {
    background: rgba(4, 8, 18, 0.88) !important;
    border: 1px solid rgba(120, 141, 160, 0.15) !important;
    border-left: 3px solid var(--bs-section-accent, rgba(201,145,58,0.50)) !important;
    border-radius: var(--bs-radius) !important;
    box-shadow: 0 2px 12px rgba(0,0,0,0.50) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    position: relative !important;
    z-index: auto !important;
    overflow: visible !important;
    transition: border-color var(--bs-transition), box-shadow var(--bs-transition);
}

.card:hover,
.forum-list .card:hover {
    border-left-color: var(--bs-section-accent, var(--bs-bronze)) !important;
    box-shadow:
        0 0 18px color-mix(in srgb, var(--bs-section-accent, #c9913a) 15%, transparent),
        0 4px 16px rgba(0,0,0,0.55) !important;
}

/* ============================================= */
/* Card / Group Headers                          */
/* Personnel file label style                    */
/* ============================================= */

.card-title {
    background: rgba(2, 5, 11, 0.92) !important;
    border: 0 !important;
    border-left: 3px solid var(--bs-section-accent, var(--bs-bronze)) !important;
    border-bottom: 1px dashed rgba(201,145,58,0.25) !important;
    padding: 10px 16px !important;
    color: var(--bs-bronze-light) !important;
    font-family: var(--bs-mono) !important;
    font-size: 0.72rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.18em !important;
    text-transform: uppercase !important;
    line-height: 1.2 !important;
    text-shadow: none !important;
    position: relative !important;
    overflow: hidden !important;
}

.card-title h4,
.card-title .text-subtitle {
    color: var(--bs-bronze-light) !important;
    font-family: var(--bs-mono) !important;
    font-size: 0.72rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.18em !important;
    text-transform: uppercase !important;
    margin: 0 !important;
}

/* Sweep shimmer on header */
.card-title::after {
    content: "";
    position: absolute;
    top: 0; left: -40%;
    width: 30%; height: 100%;
    background: linear-gradient(90deg, transparent, rgba(201,145,58,0.12), transparent);
    animation: bsHeaderSweep 9s ease-in-out infinite;
}

/* ============================================= */
/* Forum List Rows                               */
/* ============================================= */

.forum-list ul {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.forum-list li {
    border-bottom: 1px dashed rgba(120,141,160,0.14) !important;
    padding: 14px 16px !important;
}

.forum-list li:last-child {
    border-bottom: none !important;
}

.forum-list hr {
    display: none !important;
}

/* Forum title */
.forum-list li h3 {
    margin: 0 0 4px !important;
}

.forum-list li h3 a {
    color: var(--bs-text-strong) !important;
    font-family: var(--bs-mono) !important;
    font-size: 0.88rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
    line-height: 1.2 !important;
}

.forum-list li h3 a:hover {
    color: var(--bs-bronze-light) !important;
}

/* Forum description */
.forum-list .col-xs-4 > div,
.forum-list .col-md-3 > div {
    color: var(--bs-text-soft) !important;
    font-size: 0.76rem !important;
    letter-spacing: 0.03em !important;
    margin-top: 3px !important;
}

/* ============================================= */
/* Subforums                                     */
/* ============================================= */

.forum-subforums {
    margin-top: 8px !important;
    line-height: 1.6 !important;
}

.forum-subforums a:not([href*="/profile"]) {
    color: var(--bs-bronze-light) !important;
    font-size: 0.72rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
    opacity: 0.85 !important;
    margin-right: 12px !important;
    font-family: var(--bs-mono) !important;
}

.forum-subforums a:hover {
    color: var(--bs-gold) !important;
    opacity: 1 !important;
}

/* ============================================= */
/* Last Post Column                              */
/* ============================================= */

.forum-list li .flex.gap-1.hide-phone {
    font-size: 0.72rem !important;
    font-family: var(--bs-mono) !important;
    line-height: 1.4 !important;
    max-width: 260px !important;
    color: var(--bs-text-soft) !important;
}

.forum-list li .flex.gap-1.hide-phone > div > a:not([href*="/profile"]) {
    color: var(--bs-cyan) !important;
    font-size: 0.76rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.04em !important;
    text-transform: none !important;
    display: block !important;
    margin-bottom: 2px !important;
}

.forum-list li .flex.gap-1.hide-phone > div > a:not([href*="/profile"]):hover {
    color: var(--bs-bronze-light) !important;
}

.forum-list li .flex.gap-1.hide-phone a[href*="/profile"] {
    font-size: 0.70rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
}

.forum-list li .text-small {
    color: var(--bs-text-soft) !important;
    font-size: 0.68rem !important;
    letter-spacing: 0.04em !important;
}

/* Avatar in last post */
.forum-list li .avatar {
    width: 28px !important;
    height: 28px !important;
    max-width: 28px !important;
    max-height: 28px !important;
    border-radius: 2px !important;
    opacity: 0.85;
}

/* ============================================= */
/* Topic Page                                    */
/* ============================================= */

.topic-header {
    border-left: 3px solid var(--bs-bronze) !important;
    padding: 1rem 1.25rem !important;
}

.topic-header h2 {
    color: var(--bs-text-strong) !important;
    font-family: var(--bs-mono) !important;
    font-weight: 700 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    font-size: 1.1rem !important;
}

.topic-header .text-small {
    color: var(--bs-text-soft) !important;
    font-size: 0.70rem !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
}

/* ============================================= */
/* Comments                                      */
/* ============================================= */

li.comment.box {
    display: flex !important;
    flex-direction: row !important;
    border-left: 3px solid rgba(201, 145, 58, 0.35) !important;
    padding: 0 !important;
    animation: none !important;
}

li.comment.box.answer {
    border-left: 3px solid var(--bs-green) !important;
}

/* Author sidebar */
.comment-author {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    min-width: 130px !important;
    max-width: 130px !important;
    padding: 1rem 0.75rem !important;
    background: rgba(2, 5, 11, 0.70) !important;
    border-right: 1px dashed rgba(120, 141, 160, 0.15) !important;
    gap: 0.3rem !important;
}

.comment-author .avatar {
    width: 48px !important;
    height: 48px !important;
    border-radius: 2px !important;
    margin-bottom: 0.4rem !important;
}

.comment-author a[href*="/profile"] {
    font-size: 0.72rem !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
    text-align: center !important;
}

.comment-author .text-small {
    font-size: 0.62rem !important;
    letter-spacing: 0.04em !important;
    color: var(--bs-text-soft) !important;
    text-align: center !important;
}

.comment-author ul {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    text-align: center !important;
}

.comment-author ul li {
    font-size: 0.64rem !important;
    letter-spacing: 0.05em !important;
    text-transform: uppercase !important;
    line-height: 1.4 !important;
}

/* Comment content */
.comment-content {
    flex: 1 1 0% !important;
    min-width: 0 !important;
    display: flex !important;
    flex-direction: column !important;
}

.comment-content .text-secondary {
    color: var(--bs-text-soft) !important;
    font-size: 0.68rem !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
}

.comment-content .text-light {
    color: var(--bs-text-soft) !important;
    opacity: 0.7;
    font-size: 0.64rem !important;
}

/* Post body text — readable size, not all-caps */
.comment-content .pl-4 {
    font-size: 0.88rem !important;
    letter-spacing: 0.02em !important;
    line-height: 1.7 !important;
}

.comment-toolbar .btn-link {
    color: var(--bs-text-soft) !important;
    opacity: 0.6;
    transition: opacity var(--bs-transition);
}

.comment-toolbar .btn-link:hover {
    color: var(--bs-bronze-light) !important;
    opacity: 1;
}

/* Row separator inside comment */
.comment-content hr {
    border: none !important;
    border-top: 1px dashed rgba(120,141,160,0.18) !important;
    margin: 0 !important;
}

/* Answer badge */
.alert-success {
    background: rgba(4, 16, 8, 0.82) !important;
    border: 1px solid rgba(127,214,164,0.30) !important;
    color: var(--bs-green) !important;
    border-radius: var(--bs-radius-sm) !important;
    font-size: 0.72rem !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
}

/* Locked warning */
.alert-warning {
    background: rgba(16, 10, 2, 0.82) !important;
    border: 1px solid rgba(217,139,58,0.30) !important;
    color: var(--bs-gold) !important;
    border-radius: var(--bs-radius-sm) !important;
    font-size: 0.72rem !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    padding: 0.5rem 1rem !important;
}

.alert {
    background: rgba(4, 8, 18, 0.88) !important;
    border: 1px solid var(--bs-border) !important;
    color: var(--bs-text) !important;
    border-radius: var(--bs-radius-sm) !important;
    font-size: 0.80rem !important;
    letter-spacing: 0.04em !important;
}

/* Pagination */
.box.p-2 {
    border-left-width: 1px !important;
    padding: 0.5rem !important;
    font-size: 0.72rem !important;
    letter-spacing: 0.06em !important;
}

/* ============================================= */
/* General Metadata / Muted Text                 */
/* ============================================= */

.thread-meta,
.thread-meta span,
.text-muted,
.text-small,
.text-secondary,
label {
    color: var(--bs-text-soft) !important;
    font-size: 0.72rem !important;
    letter-spacing: 0.05em !important;
}

/* Online dot */
.dot { animation: bsStatusPulse 2.2s ease-in-out infinite; }

/* ============================================= */
/* Breadcrumbs                                   */
/* ============================================= */

.breadcrumbs,
.text-small.breadcrumbs,
div.breadcrumbs {
    font-size: 0.68rem !important;
    letter-spacing: 0.10em !important;
    text-transform: uppercase !important;
    color: var(--bs-text-soft) !important;
}

/* ============================================= */
/* Forms                                         */
/* ============================================= */

input, textarea, select, .form-control, .form-select {
    background: rgba(2,5,11,0.88) !important;
    border: 1px solid rgba(120,141,160,0.20) !important;
    border-bottom: 1px solid rgba(201,145,58,0.35) !important;
    border-radius: var(--bs-radius-sm) !important;
    color: var(--bs-text) !important;
    font-family: var(--bs-mono) !important;
    font-size: 0.82rem !important;
    letter-spacing: 0.04em !important;
}

input::placeholder, textarea::placeholder {
    color: var(--bs-text-soft) !important;
    opacity: 0.6;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
    font-size: 0.72rem !important;
}

input:focus, textarea:focus, select:focus,
.form-control:focus, .form-select:focus {
    background: rgba(2,5,11,0.95) !important;
    border-color: var(--bs-bronze-light) !important;
    box-shadow: 0 0 0 1px rgba(201,145,58,0.25) !important;
    outline: none !important;
}

/* ============================================= */
/* Tables                                        */
/* ============================================= */

table, .table {
    background: rgba(2,5,11,0.70) !important;
    font-size: 0.80rem !important;
    letter-spacing: 0.04em !important;
}

.table thead, thead {
    background: rgba(2,5,11,0.90) !important;
    border-bottom: 1px solid rgba(201,145,58,0.30) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.10em !important;
    font-size: 0.68rem !important;
    color: var(--bs-bronze-light) !important;
}

.table tbody tr, tbody tr {
    border-color: rgba(120,141,160,0.10) !important;
    border-bottom-style: dashed !important;
}

.table tbody tr:hover, tbody tr:hover {
    background: rgba(201,145,58,0.05) !important;
}

/* ============================================= */
/* Tag / Status Badges                           */
/* ============================================= */

.tag {
    font-family: var(--bs-mono) !important;
    font-size: 0.62rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.12em !important;
    text-transform: uppercase !important;
    border-radius: 2px !important;
    padding: 2px 7px !important;
    color: #000000 !important;
}

/* ============================================= */
/* Buttons                                       */
/* ============================================= */

.btn, button, a.btn {
    font-family: var(--bs-mono) !important;
    font-size: 0.72rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.10em !important;
    text-transform: uppercase !important;
    border-radius: var(--bs-radius-sm) !important;
    transition:
        background var(--bs-transition),
        border-color var(--bs-transition),
        color var(--bs-transition),
        box-shadow var(--bs-transition) !important;
}

.btn *, button *, a.btn * {
    color: inherit !important;
    fill: currentColor !important;
    stroke: currentColor !important;
}

.btn-primary, button.btn-primary, a.btn-primary {
    color: #0b111a !important;
    background: linear-gradient(180deg, #e0b76c, #c9913a) !important;
    border: 1px solid rgba(255,204,115,0.70) !important;
    box-shadow: none !important;
    text-shadow: none !important;
}

.btn-primary *, button.btn-primary *, a.btn-primary * {
    color: #0b111a !important;
    fill: #0b111a !important;
    stroke: #0b111a !important;
}

.btn-primary:hover, button.btn-primary:hover, a.btn-primary:hover {
    color: #05070b !important;
    background: linear-gradient(180deg, var(--bs-gold), var(--bs-bronze-light)) !important;
    border-color: var(--bs-gold) !important;
    box-shadow: 0 0 12px rgba(201,145,58,0.30) !important;
}

.btn-outlined {
    color: var(--bs-text-muted) !important;
    background: rgba(4,8,18,0.76) !important;
    border: 1px solid rgba(120,141,160,0.30) !important;
    border-radius: var(--bs-radius-sm) !important;
}

.btn-outlined:hover {
    color: var(--bs-text-strong) !important;
    border-color: rgba(201,145,58,0.45) !important;
}

.btn-secondary, .btn-outline-secondary, .btn-outline-primary {
    color: var(--bs-text) !important;
    background: rgba(4,8,18,0.76) !important;
    border: 1px solid rgba(120,141,160,0.30) !important;
}

.btn-secondary:hover, .btn-outline-secondary:hover, .btn-outline-primary:hover {
    color: var(--bs-text-strong) !important;
    border-color: rgba(88,199,232,0.45) !important;
}

.btn-success, button.btn-success, a.btn-success {
    color: #06120c !important;
    background: linear-gradient(180deg, #8be0ad, #4ca774) !important;
    border-color: rgba(127,214,164,0.70) !important;
    text-shadow: none !important;
}

.btn-danger, button.btn-danger, a.btn-danger {
    color: #ffffff !important;
    background: linear-gradient(180deg, #e36b6b, #9f3434) !important;
    border-color: rgba(227,107,107,0.70) !important;
}

.btn-warning, button.btn-warning, a.btn-warning {
    color: #120c02 !important;
    background: linear-gradient(180deg, #ffcc73, #d98b3a) !important;
    border-color: rgba(255,204,115,0.70) !important;
    text-shadow: none !important;
}

.btn-info, button.btn-info, a.btn-info {
    color: #031018 !important;
    background: linear-gradient(180deg, #7ddbf2, #58c7e8) !important;
    border-color: rgba(88,199,232,0.70) !important;
    text-shadow: none !important;
}

.btn:disabled, button:disabled, .btn.disabled,
button.disabled, a.btn.disabled, [aria-disabled="true"] {
    color: var(--bs-text-soft) !important;
    background: rgba(20,30,45,0.60) !important;
    border: 1px solid rgba(120,141,160,0.18) !important;
    opacity: 0.75 !important;
    cursor: not-allowed !important;
}

/* ============================================= */
/* Footer                                        */
/* ============================================= */

footer {
    background: rgba(2,4,10,0.92) !important;
    border-top: 1px dashed rgba(201,145,58,0.25) !important;
    font-size: 0.68rem !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
}

/* ============================================= */
/* Overflow / Stacking Fix                       */
/* ============================================= */

.card, .forum-list .card, .box, .post, .thread, .panel {
    position: relative !important;
    z-index: auto !important;
    overflow: visible !important;
    transform: none !important;
    filter: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}

li.comment.box { overflow: visible !important; }

.card-body, main.responsive, #app, .page, .content {
    overflow: visible !important;
}

/* ============================================= */
/* Sidebar Layout                                */
/* ============================================= */

.bs-command-layout {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 330px !important;
    gap: 22px !important;
    align-items: start !important;
}

.bs-command-main { min-width: 0 !important; }

.bs-command-panel {
    width: 330px !important;
    max-width: 330px !important;
    position: sticky !important;
    top: 20px !important;
    align-self: start !important;
    background: rgba(3, 6, 14, 0.90) !important;
    border-radius: var(--bs-radius) !important;
    overflow: hidden !important;
}

@media (max-width: 1100px) {
    .bs-command-layout { grid-template-columns: 1fr !important; }
    .bs-command-panel {
        position: static !important;
        width: 100% !important;
        max-width: none !important;
    }
}

.bs-command-dash { display: grid; gap: 14px; width: 100%; }

.bs-command-card {
    background: rgba(3, 6, 14, 0.88) !important;
    border: 1px solid rgba(59,85,128,0.50) !important;
    border-left: 3px solid var(--bs-bronze) !important;
    border-radius: var(--bs-radius) !important;
    color: var(--bs-text) !important;
    box-shadow: 0 2px 12px rgba(0,0,0,0.40) !important;
    overflow: hidden !important;
}

.bs-command-card summary {
    cursor: pointer;
    list-style: none;
    padding: 12px 16px;
    color: var(--bs-bronze-light) !important;
    font-family: var(--bs-mono) !important;
    font-size: 0.68rem;
    letter-spacing: 0.18em;
    font-weight: 700;
    text-transform: uppercase;
    border-bottom: 1px dashed rgba(201,145,58,0.25) !important;
    background: rgba(2,4,10,0.70) !important;
}

.bs-command-card summary::-webkit-details-marker { display: none; }
.bs-command-card summary::after { content: "+"; float: right; color: var(--bs-text-soft) !important; }
.bs-command-card[open] summary::after { content: "–"; }

.bs-command-card-body { padding: 12px 16px 14px; }

.bs-command-card-body strong {
    display: block;
    color: var(--bs-text-strong) !important;
    font-family: var(--bs-mono) !important;
    font-size: 0.88rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    line-height: 1.2;
}

.bs-command-card-body p {
    margin: 5px 0 0;
    color: var(--bs-text-muted) !important;
    font-family: var(--bs-mono) !important;
    font-size: 0.72rem;
    letter-spacing: 0.03em;
    line-height: 1.5;
}

.bs-command-link-list { margin-top: 10px; }

.bs-command-link-list a {
    display: block;
    margin-top: 8px;
    color: var(--bs-bronze-light) !important;
    font-family: var(--bs-mono) !important;
    font-weight: 700;
    text-decoration: none !important;
    font-size: 0.72rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.bs-command-link-list a:hover {
    color: var(--bs-text-strong) !important;
}

/* Comms Check */
.bs-online-wrap .card {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
}

.bs-online-wrap .card-title { display: none !important; }
.bs-online-wrap .card-body { padding: 0 !important; }

.bs-online-wrap ul.card-body > li.flex {
    padding: 7px 16px !important;
    border-bottom: 1px dashed rgba(120,141,160,0.12) !important;
    gap: 10px !important;
    list-style: none !important;
}

.bs-online-wrap ul.card-body > li.flex:last-child { border-bottom: none !important; }
.bs-online-wrap ul.card-body > li.flex:hover { background: rgba(201,145,58,0.05) !important; }
.bs-online-wrap ul.card-body > li.flex .avatar { display: none !important; }

.bs-online-wrap ul.card-body > li.flex::before {
    content: "";
    display: inline-block;
    width: 6px; height: 6px;
    min-width: 6px;
    border-radius: 50%;
    background: #57d487;
    box-shadow: 0 0 4px rgba(87,212,135,0.65);
    align-self: center;
    margin-right: 4px;
}

.bs-online-wrap ul.card-body > li.flex a[href*="/profile"] {
    font-family: var(--bs-mono) !important;
    font-size: 0.72rem !important;
    font-weight: 700 !important;
    color: #dfe8f2 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    text-decoration: none !important;
}

.bs-online-wrap ul.card-body > li.flex a[href*="/profile"]:hover {
    color: var(--bs-bronze-light) !important;
}

.bs-online-wrap-footer {
    padding: 6px 16px;
    border-top: 1px dashed rgba(120,141,160,0.14);
    font-family: var(--bs-mono) !important;
    font-size: 0.62rem;
    letter-spacing: 0.18em;
    color: #708090;
    font-weight: 700;
    text-transform: uppercase;
}

.bs-command-frame { display: block; width: 100%; border: 0; }

/* Sidebar buttons */
.bs-command-card .btn-primary,
.bs-command-card .btn-success,
.bs-command-card button,
.bs-command-card a.btn-primary {
    width: 100% !important;
    background: linear-gradient(90deg, rgba(217,150,31,0.95), rgba(241,185,82,0.95)) !important;
    border: 1px solid rgba(255,210,120,0.60) !important;
    color: #101722 !important;
    font-family: var(--bs-mono) !important;
    font-weight: 700 !important;
    font-size: 0.68rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.12em !important;
    border-radius: 2px !important;
    box-shadow: none !important;
}

.bs-command-card .btn-primary:hover,
.bs-command-card .btn-success:hover,
.bs-command-card button:hover,
.bs-command-card a.btn-primary:hover {
    background: #ffffff !important;
    color: #0b1220 !important;
}

.bs-command-card .btn-primary:disabled,
.bs-command-card .btn-success:disabled,
.bs-command-card button:disabled,
.bs-command-card button[disabled] {
    background: rgba(3,6,14,0.88) !important;
    border: 1px solid rgba(86,215,255,0.35) !important;
    color: #56d7ff !important;
    opacity: 1 !important;
    cursor: default !important;
}

.bs-command-card .btn-primary:disabled *,
.bs-command-card button:disabled * { color: #56d7ff !important; }

.bs-command-card .alert,
.bs-command-card .alert-success,
.bs-command-card [class*="success"],
.bs-command-card [class*="reported"] {
    background: rgba(3,6,14,0.88) !important;
    border: 1px solid rgba(86,215,255,0.35) !important;
    color: #56d7ff !important;
}

/* ============================================= */
/* J-Code Accent Colors                          */
/* ============================================= */

.forum-list .card:has(li a[href*="j-1-"]) { --bs-section-accent: #4da3ff; }
.forum-list .card:has(li a[href*="j-2-"]) { --bs-section-accent: #b68cff; }
.forum-list .card:has(li a[href*="j-3-"]) { --bs-section-accent: #e36b6b; }
.forum-list .card:has(li a[href*="j-4-"]) { --bs-section-accent: #d98b3a; }
.forum-list .card:has(li a[href*="j-5-"]) { --bs-section-accent: #9fb3c8; }
.forum-list .card:has(li a[href*="j-6-"]) { --bs-section-accent: #9fd8ef; }
.forum-list .card:has(li a[href*="j-7-"]) { --bs-section-accent: #7fd6a4; }
.forum-list .card:has(li a[href*="welcome-to-bronze"]),
.forum-list .card:has(li a[href*="unit-announcements"]) { --bs-section-accent: #c9913a; }
.forum-list .card:has(li a[href*="all-bronze-squadron-news"]) { --bs-section-accent: #708090; }
.forum-list .card:has(li a[href*="enlist"]) { --bs-section-accent: #7fd6a4; }
.forum-list .card:has(li a[href*="discipline-actions"]) { --bs-section-accent: #e0b76c; }
.forum-list .card:has(li a[href*="nswdg-"]) { --bs-section-accent: #e36b6b; }
.forum-list .card:has(li a[href*="160th-soar"]),
.forum-list .card:has(li a[href*="aviation"]) { --bs-section-accent: #9fd8ef; }

.forum-list .card {
    border-left-color: var(--bs-section-accent, rgba(201,145,58,0.50)) !important;
}

.forum-list .card .card-title {
    border-left-color: var(--bs-section-accent, var(--bs-bronze)) !important;
}

.forum-list .card:hover {
    box-shadow:
        0 0 18px color-mix(in srgb, var(--bs-section-accent, #c9913a) 12%, transparent),
        0 4px 16px rgba(0,0,0,0.55) !important;
}

/* J-Code badge in header */
.forum-list .card:has(li a[href*="j-1-"]) .card-title::after,
.forum-list .card:has(li a[href*="j-2-"]) .card-title::after,
.forum-list .card:has(li a[href*="j-3-"]) .card-title::after,
.forum-list .card:has(li a[href*="j-4-"]) .card-title::after,
.forum-list .card:has(li a[href*="j-5-"]) .card-title::after,
.forum-list .card:has(li a[href*="j-6-"]) .card-title::after,
.forum-list .card:has(li a[href*="j-7-"]) .card-title::after {
    float: right !important;
    font-size: 0.60rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.18em !important;
    padding: 1px 7px !important;
    border-radius: 2px !important;
    background: rgba(0,0,0,0.50) !important;
    border: 1px solid var(--bs-section-accent) !important;
    color: var(--bs-section-accent) !important;
    font-family: var(--bs-mono) !important;
    position: static !important;
    width: auto !important;
    height: auto !important;
    animation: none !important;
    background-image: none !important;
}

.forum-list .card:has(li a[href*="j-1-"]) .card-title::after { content: "J-1" !important; }
.forum-list .card:has(li a[href*="j-2-"]) .card-title::after { content: "J-2" !important; }
.forum-list .card:has(li a[href*="j-3-"]) .card-title::after { content: "J-3" !important; }
.forum-list .card:has(li a[href*="j-4-"]) .card-title::after { content: "J-4" !important; }
.forum-list .card:has(li a[href*="j-5-"]) .card-title::after { content: "J-5" !important; }
.forum-list .card:has(li a[href*="j-6-"]) .card-title::after { content: "J-6" !important; }
.forum-list .card:has(li a[href*="j-7-"]) .card-title::after { content: "J-7" !important; }

/* ============================================= */
/* Forum Group Collapse (JS-powered)             */
/* ============================================= */

.forum-list .card ul {
    transition: max-height 0.28s ease, opacity 0.22s ease;
    overflow: hidden;
}

.forum-list .card.bs-collapsed ul {
    max-height: 0 !important;
    opacity: 0 !important;
}

.forum-list .card .card-title {
    cursor: pointer;
    user-select: none;
}

.bs-collapse-arrow {
    float: right;
    font-size: 0.62rem;
    letter-spacing: 0.14em;
    color: var(--bs-text-soft);
    transition: transform 0.22s ease;
    display: inline-block;
    margin-top: 1px;
}

.forum-list .card.bs-collapsed .bs-collapse-arrow {
    transform: rotate(-90deg);
}

/* ============================================= */
/* Scan sweep animation (body only)              */
/* ============================================= */

body::after {
    content: "";
    position: fixed;
    inset: -40% 0;
    pointer-events: none;
    z-index: 0;
    background: linear-gradient(
        to bottom,
        transparent 0%,
        rgba(88,199,232,0.00) 45%,
        rgba(88,199,232,0.05) 50%,
        rgba(88,199,232,0.00) 55%,
        transparent 100%
    );
    animation: bsScanSweep 11s linear infinite;
    opacity: 0.45;
}

/* ============================================= */
/* Keyframes                                     */
/* ============================================= */

@keyframes bsScanSweep {
    0%   { transform: translateY(-35%); }
    100% { transform: translateY(35%); }
}

@keyframes bsHeaderSweep {
    0%   { left: -45%; opacity: 0; }
    20%  { opacity: 1; }
    55%  { left: 115%; opacity: 0; }
    100% { left: 115%; opacity: 0; }
}

@keyframes bsStatusPulse {
    0%, 100% { filter: drop-shadow(0 0 0 rgba(127,214,164,0)); opacity: 0.85; }
    50%       { filter: drop-shadow(0 0 5px rgba(127,214,164,0.70)); opacity: 1; }
}

/* ============================================= */
/* Accessibility                                 */
/* ============================================= */

a:focus-visible,
button:focus-visible,
.btn:focus-visible,
[role="menuitem"]:focus-visible {
    outline: 1px solid var(--bs-bronze-light);
    outline-offset: 2px;
}

/* ============================================= */
/* Reduced Motion                                */
/* ============================================= */

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation: none !important;
        transition: none !important;
        scroll-behavior: auto !important;
    }
}

/* ============================================= */
/* NOTE: Add the following <script> block to     */
/* your forum-command-dashboard snippet to       */
/* enable collapsible forum groups.              */
/* ============================================= */