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

/* ============================================================
   BBAC · "Star Atlas" design system
   Refined astronomical-instrument aesthetic — dark ink surfaces,
   gold/azure accents, serif headings, mono labels.
   ============================================================ */

:root {
    /* ---- ink / surfaces ---- */
    --ink-900: #0a0d15;   /* page */
    --ink-850: #0e121d;   /* deep panel */
    --ink-800: #141926;   /* surface */
    --ink-750: #1a2030;   /* raised */
    --ink-700: #222a3c;   /* hover / input */

    /* ---- hairlines ---- */
    --line:        rgba(157, 174, 214, 0.13);
    --line-strong: rgba(157, 174, 214, 0.22);

    /* ---- text ---- */
    --tx:   #eef1f7;
    --tx-2: #b3bccd;
    --tx-3: #767f93;

    /* ---- accents ---- */
    --gold:       #e7b95f;   /* starlight */
    --gold-deep:  #d49f3c;
    --gold-soft:  rgba(231, 185, 95, 0.12);
    --gold-line:  rgba(231, 185, 95, 0.34);
    --azure:      #8fb2db;   /* cool info */
    --azure-soft: rgba(143, 178, 219, 0.12);

    /* ---- status ---- */
    --ok:   #74c79a;
    --warn: #e7b95f;
    --bad:  #df9090;

    /* ---- radii ---- */
    --radius-panel: 16px;
    --radius-control: 11px;

    --bs-body-bg: var(--ink-900);
    --bs-body-color: var(--tx-2);
    --bs-border-color: var(--line);
    --bs-link-color: var(--azure);
    --bs-link-hover-color: var(--gold);
    --bs-secondary-color: var(--tx-3);
    --bs-emphasis-color: #ffffff;
    --bs-heading-color: var(--tx);
}

/* ---------------------------------------------------------- *
   Base + starfield
 * ---------------------------------------------------------- */
body {
    background: var(--ink-900);
    color: var(--tx-2);
    font-family: 'Space Grotesk', 'Segoe UI', Roboto, sans-serif;
    -webkit-font-smoothing: antialiased;
    position: relative;
    min-height: 100vh;
}

/* sparse, static starfield — premium, no neon glow */
body::before {
    content: '';
    position: fixed;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    opacity: 0.7;
    background-image:
        radial-gradient(1.4px 1.4px at 38px 70px, rgba(255, 255, 255, 0.55), transparent),
        radial-gradient(1px 1px at 150px 200px, rgba(255, 255, 255, 0.40), transparent),
        radial-gradient(1.2px 1.2px at 250px 120px, rgba(143, 178, 219, 0.55), transparent),
        radial-gradient(1px 1px at 80px 300px, rgba(255, 255, 255, 0.35), transparent),
        radial-gradient(1.6px 1.6px at 320px 360px, rgba(231, 185, 95, 0.45), transparent),
        radial-gradient(1px 1px at 200px 440px, rgba(255, 255, 255, 0.30), transparent),
        radial-gradient(1.1px 1.1px at 30px 520px, rgba(255, 255, 255, 0.30), transparent);
    background-repeat: repeat;
    background-size: 380px 580px;
}

/* ---------------------------------------------------------- *
   Typography
 * ---------------------------------------------------------- */
h1, h2, h3, h4, h5, h6,
.navbar-brand,
.display-5 {
    font-family: 'Spectral', Georgia, serif;
    font-weight: 500;
    letter-spacing: -0.01em;
    color: var(--tx);
    line-height: 1.12;
}

a { color: var(--azure); }
a:hover { color: var(--gold); }

.serif { font-family: 'Spectral', Georgia, serif; }
.mono  { font-family: 'Space Mono', ui-monospace, monospace; }
.lead  { font-size: 15px; line-height: 1.5; color: var(--tx-2); }
.small { font-size: 12.5px; line-height: 1.45; }

/* eyebrow / coordinate label — small caps mono with a tick mark */
.eyebrow {
    font-family: 'Space Mono', monospace;
    font-size: 10.5px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--tx-3);
    display: flex;
    align-items: center;
    gap: 8px;
}
.eyebrow .tick {
    width: 14px;
    height: 1px;
    background: var(--gold-line);
    flex: none;
}

/* ---------------------------------------------------------- *
   Brand mark — celestial ring + dot
 * ---------------------------------------------------------- */
.mark {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    border: 1px solid var(--gold-line);
    position: relative;
    flex: none;
    display: inline-block;
}
.mark::before {
    content: '';
    position: absolute;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--gold);
    top: -3px;
    left: 50%;
    transform: translateX(-50%);
    box-shadow: 0 0 6px rgba(231, 185, 95, 0.6);
}
.mark::after {
    content: '';
    position: absolute;
    inset: 7px;
    border-radius: 50%;
    border: 1px solid var(--line-strong);
}
.avatar {
    width: 42px;
    height: 42px;
    border-radius: 12px;
    border: 1px solid var(--line);
    background: var(--ink-750);
    object-fit: cover;
    flex: none;
}
.avatar-lg {
    width: 64px;
    height: 64px;
    border-radius: 16px;
}
.photo-crop-preview {
    width: 160px;
    max-width: 100%;
    aspect-ratio: 1;
    border-radius: 16px;
    border: 1px solid var(--line);
    background: var(--ink-850);
    object-fit: cover;
}
.wordmark {
    font-family: 'Spectral', serif;
    font-weight: 500;
    color: var(--tx);
    font-size: 16px;
    letter-spacing: 0.01em;
    line-height: 1;
}
.wordmark small {
    display: block;
    font-family: 'Space Mono', monospace;
    font-weight: 400;
    font-size: 8.5px;
    letter-spacing: 0.28em;
    color: var(--tx-3);
    text-transform: uppercase;
    margin-top: 3px;
}
.brand-lockup { display: flex; align-items: center; gap: 10px; }
.brand-logo { width: 34px; height: 34px; object-fit: contain; flex: none; mix-blend-mode: screen; }

/* ---------------------------------------------------------- *
   Surfaces — panels (replace ad-hoc card glassiness)
 * ---------------------------------------------------------- */
.panel {
    background: var(--ink-800);
    border: 1px solid var(--line);
    border-radius: var(--radius-panel);
}
.panel-deep { background: var(--ink-850); }
.panel-raised { background: var(--ink-750); }
.panel-pad { padding: 18px; }
.panel-featured {
    border-color: var(--gold-line);
    background: linear-gradient(180deg, rgba(231, 185, 95, 0.06), var(--ink-800) 60%);
}

/* ---------------------------------------------------------- *
   Buttons
 * ---------------------------------------------------------- */
.btn {
    font-family: 'Space Grotesk', sans-serif;
    font-weight: 600;
    font-size: 14px;
    letter-spacing: 0.01em;
    border-radius: var(--radius-control);
    padding: 13px 18px;
    transition: all .18s ease;
    line-height: 1;
}
.btn:active { transform: translateY(1px); }
.btn:disabled,
.btn.disabled {
    opacity: 0.58;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}
.btn-block, .btn-atlas-block { width: 100%; }
.btn-sm, .btn-atlas-sm { padding: 9px 13px; font-size: 12.5px; border-radius: 9px; }

.btn-gold,
.btn-primary,
.btn-warning {
    background: linear-gradient(180deg, #efc878, var(--gold-deep));
    border: 1px solid transparent;
    color: #2a1d05;
    box-shadow: 0 6px 18px rgba(212, 159, 60, 0.22);
}
.btn-gold:hover,
.btn-primary:hover,
.btn-primary:focus,
.btn-warning:hover,
.btn-warning:focus {
    filter: brightness(1.05);
    transform: translateY(-1px);
    color: #2a1d05;
}

.btn-ghost,
.btn-outline-light,
.btn-outline-primary {
    background: transparent;
    color: var(--tx);
    border: 1px solid var(--line-strong);
}
.btn-ghost:hover,
.btn-outline-light:hover,
.btn-outline-primary:hover {
    border-color: var(--gold-line);
    color: var(--gold);
    background: transparent;
}

.btn-quiet,
.btn-secondary,
.btn-outline-secondary {
    background: var(--ink-750);
    color: var(--tx-2);
    border: 1px solid var(--line);
}
.btn-quiet:hover,
.btn-secondary:hover,
.btn-outline-secondary:hover {
    color: var(--tx);
    border-color: var(--line-strong);
    background: var(--ink-750);
}

.btn-success {
    background: rgba(116, 199, 154, 0.14);
    border: 1px solid rgba(116, 199, 154, 0.4);
    color: var(--ok);
}
.btn-danger {
    background: rgba(223, 144, 144, 0.12);
    border: 1px solid rgba(223, 144, 144, 0.4);
    color: var(--bad);
}
.btn-danger:hover, .btn-success:hover { filter: brightness(1.15); }

/* ---------------------------------------------------------- *
   Status pills
 * ---------------------------------------------------------- */
.pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-family: 'Space Mono', monospace;
    font-size: 10.5px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    padding: 5px 10px;
    border-radius: 999px;
    border: 1px solid var(--line);
    background: var(--ink-750);
    color: var(--tx-2);
}
.pill .dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.pill-active,
.status-approved,
.status-active,
.status-registered,
.status-available {
    color: var(--ok) !important;
    border-color: rgba(116, 199, 154, 0.4) !important;
    background: rgba(116, 199, 154, 0.08) !important;
    box-shadow: none !important;
}
.pill-pending,
.status-pending,
.status-pending_payment,
.status-payment_submitted,
.status-submitted,
.status-waitlisted,
.status-in_use,
.status-maintenance {
    color: var(--warn) !important;
    border-color: var(--gold-line) !important;
    background: var(--gold-soft) !important;
    box-shadow: none !important;
}
.pill-bad,
.status-cancelled,
.status-rejected,
.status-expired,
.status-lost {
    color: var(--bad) !important;
    border-color: rgba(223, 144, 144, 0.4) !important;
    background: rgba(223, 144, 144, 0.08) !important;
    box-shadow: none !important;
}
.badge[class*="status-"] {
    font-family: 'Space Mono', monospace;
    letter-spacing: 0.08em;
    font-weight: 400;
    text-transform: uppercase;
    border-radius: 999px;
}

/* ---------------------------------------------------------- *
   Forms / fields
 * ---------------------------------------------------------- */
.field { margin-bottom: 14px; }
.field > label,
.form-label {
    display: block;
    font-size: 11px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    font-family: 'Space Mono', monospace;
    color: var(--tx-3);
    margin-bottom: 7px;
    font-weight: 400;
}
.input,
.form-control,
.form-select,
select.input {
    width: 100%;
    box-sizing: border-box;
    background: var(--ink-850);
    border: 1px solid var(--line-strong);
    border-radius: var(--radius-control);
    padding: 13px 14px;
    color: var(--tx);
    font-family: 'Space Grotesk', sans-serif;
    font-size: 14.5px;
    transition: border-color .15s ease, background .15s ease;
}
.input::placeholder,
.form-control::placeholder { color: var(--tx-3); }
a:focus-visible,
button:focus-visible,
.btn:focus-visible,
.nav-link:focus-visible,
.dropdown-item:focus-visible,
.pill[href]:focus-visible,
.tab-bar a:focus-visible,
.list-group-item-action:focus-visible {
    outline: 2px solid var(--gold);
    outline-offset: 3px;
    box-shadow: 0 0 0 4px var(--gold-soft);
}
.input:focus,
.form-control:focus,
.form-select:focus {
    outline: none;
    border-color: var(--gold-line);
    background: var(--ink-800);
    color: #fff;
    box-shadow: 0 0 0 3px var(--gold-soft);
}
.form-control:disabled,
.form-select:disabled {
    background: rgba(15, 23, 42, 0.3);
    color: var(--tx-3);
}
.form-check-input {
    background-color: var(--ink-850);
    border-color: var(--line-strong);
}
.form-check-input:focus {
    border-color: var(--gold);
    box-shadow: 0 0 0 3px var(--gold-soft);
}
.form-check-input:checked {
    background-color: var(--gold);
    border-color: var(--gold);
}
.input-row { display: flex; gap: 10px; }
.input-row > .field { flex: 1; }

/* ---------------------------------------------------------- *
   Auth / join — step track, optional-details disclosure
 * ---------------------------------------------------------- */
.step-track { display: flex; gap: 6px; }
.step-track-item { flex: 1; }
.step-track-bar { height: 3px; border-radius: 2px; background: var(--ink-700); }
.step-track-item.active .step-track-bar { background: var(--gold); }
.step-track-label {
    font-size: 9px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--tx-3);
    margin-top: 6px;
}
.step-track-item.active .step-track-label { color: var(--gold); }

.optional-details-toggle {
    cursor: pointer;
    color: var(--azure);
    font-size: 13px;
    font-family: 'Space Grotesk', sans-serif;
    list-style: none;
}
.optional-details-toggle::-webkit-details-marker { display: none; }
.optional-details-toggle::marker { content: ''; }
.invalid-feedback { color: var(--bad); }
.is-invalid { border-color: var(--bad) !important; }

/* ---------------------------------------------------------- *
   Payment proof — upload dropzone
 * ---------------------------------------------------------- */
.upload-drop {
    position: relative;
    display: block;
    border: 1.5px dashed var(--gold-line);
    border-radius: 14px;
    padding: 28px 18px;
    text-align: center;
    background: var(--gold-soft);
    cursor: pointer;
}
.upload-drop:focus-within {
    border-color: var(--gold);
    box-shadow: 0 0 0 3px var(--gold-soft);
}
.upload-drop input[type="file"] { position: absolute; inset: 0; opacity: 0; cursor: pointer; }
.upload-drop-icon {
    width: 46px;
    height: 46px;
    border-radius: 12px;
    background: var(--ink-800);
    border: 1px solid var(--line);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 12px;
}
.upload-drop-title { color: var(--tx); font-size: 14.5px; font-weight: 600; font-family: 'Space Grotesk', sans-serif; }
.upload-drop-hint { font-size: 10.5px; color: var(--tx-3); margin-top: 6px; }
.upload-drop-selected { border-style: solid; border-color: var(--ok); background: rgba(116,199,154,0.08); }
.upload-drop-selected .upload-drop-title { color: var(--ok); word-break: break-all; }
.upload-drop-selected .upload-drop-hint { color: var(--ok); opacity: 0.7; }

/* ---------------------------------------------------------- *
   Plan choice cards (renewal / switch-plan radio cards)
 * ---------------------------------------------------------- */
.plan-choice { cursor: pointer; display: block; transition: border-color .15s ease, background .15s ease; }
.plan-choice:has(input:checked) {
    border-color: var(--gold-line);
    background: linear-gradient(180deg, rgba(231, 185, 95, 0.06), var(--ink-800) 60%);
}
.plan-choice:has(input:disabled) { opacity: 0.55; cursor: not-allowed; }

.login-form,
.settings-form { max-width: 720px; }

/* ---------------------------------------------------------- *
   Key/value rows (used in summaries, plan cards, payment detail)
 * ---------------------------------------------------------- */
.kv { display: flex; justify-content: space-between; align-items: baseline; padding: 7px 0; gap: 16px; }
.kv + .kv { border-top: 1px solid var(--line); }
.kv .k { font-size: 13px; color: var(--tx-3); white-space: nowrap; }
.kv .v { font-family: 'Space Mono', monospace; font-size: 13px; color: var(--tx); text-align: right; }

/* ---------------------------------------------------------- *
   Marketing — hero heading, plan teaser rows
 * ---------------------------------------------------------- */
.hero-heading h1,
.hero-heading h2 {
    font-size: 38px;
    line-height: 1.08;
    max-width: 460px;
}
.plan-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 13px 0;
    border-top: 1px solid var(--line);
    text-decoration: none;
    color: inherit;
}
.plan-row:hover .plan-row-name { color: var(--gold); }
.plan-row-name {
    color: var(--tx);
    font-size: 14.5px;
    font-weight: 600;
    font-family: 'Space Grotesk', sans-serif;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    transition: color .15s ease;
}
.plan-row-tag {
    font-size: 11px;
    color: var(--tx-3);
    margin-top: 4px;
}

/* ---------------------------------------------------------- *
   Dividers
 * ---------------------------------------------------------- */
hr, .rule { height: 1px; background: var(--line); border: 0; margin: 0; opacity: 1; }
.rule-star {
    display: flex; align-items: center; gap: 12px; color: var(--tx-3);
}
.rule-star::before, .rule-star::after {
    content: ''; flex: 1; height: 1px; background: var(--line);
}

/* ---------------------------------------------------------- *
   Navigation — sticky blurred app bar (replaces glassy navbar)
 * ---------------------------------------------------------- */
.club-nav,
.app-bar {
    background: rgba(10, 13, 21, 0.78);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-bottom: 1px solid var(--line);
    box-shadow: none;
    position: sticky;
    top: 0;
    z-index: 1030;
}
.club-nav .navbar-brand {
    font-weight: 500;
    letter-spacing: 0.01em;
    background: none;
    -webkit-text-fill-color: unset;
    color: var(--tx);
    text-shadow: none;
}
.club-nav .nav-link {
    color: var(--tx-2);
    font-family: 'Space Grotesk', sans-serif;
    font-size: 14px;
    transition: color .15s ease;
}
.club-nav .nav-link:hover,
.club-nav .nav-link.active {
    color: var(--gold);
    text-shadow: none;
}

.admin-nav-shell {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
}
.admin-nav-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex: none;
}
.admin-nav-toggle {
    border: 1px solid var(--line-strong);
    border-radius: var(--radius-control);
    padding: 9px 11px;
    box-shadow: none !important;
}
.admin-nav-toggle:focus {
    box-shadow: 0 0 0 3px var(--gold-soft) !important;
}
.admin-nav-collapse {
    justify-content: flex-end;
}
.admin-nav-groups {
    align-items: center;
    gap: 8px;
}
.admin-nav-group-toggle {
    padding: 9px 13px !important;
    border: 1px solid var(--line);
    border-radius: 999px;
    font-family: 'Space Mono', monospace !important;
    font-size: 11px !important;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    background: var(--ink-850);
    color: var(--tx-2) !important;
}
.admin-nav-group-toggle:hover,
.admin-nav-group-toggle.active,
.admin-nav-group.show .admin-nav-group-toggle {
    color: var(--gold) !important;
    border-color: var(--gold-line);
    background: var(--gold-soft);
}
.admin-nav-menu {
    min-width: 210px;
    padding: 8px;
    margin-top: 8px !important;
    background: var(--ink-850);
    border: 1px solid var(--line-strong);
    border-radius: var(--radius-control);
    box-shadow: 0 18px 36px rgba(0, 0, 0, 0.28);
}
.admin-nav-link {
    border-radius: 8px;
    padding: 9px 11px;
    color: var(--tx-2);
    font-family: 'Space Grotesk', sans-serif;
    font-size: 13.5px;
}
.admin-nav-link:hover,
.admin-nav-link:focus {
    color: var(--tx);
    background: var(--ink-750);
}
.admin-nav-link.active,
.admin-nav-link:active {
    color: var(--gold);
    background: var(--gold-soft);
}

@media (max-width: 991.98px) {
    .admin-nav-shell {
        align-items: stretch;
        flex-direction: column;
        gap: 10px;
    }
    .admin-nav-top,
    .admin-nav-collapse,
    .admin-nav-groups {
        width: 100%;
    }
    .admin-nav-groups {
        align-items: stretch;
        gap: 8px;
        padding: 4px 0 6px;
    }
    .admin-nav-group-toggle {
        width: 100%;
        display: flex;
        align-items: center;
        justify-content: space-between;
        border-radius: var(--radius-control);
    }
    .admin-nav-menu {
        position: static !important;
        transform: none !important;
        width: 100%;
        margin: 6px 0 0 !important;
        box-shadow: none;
    }
}

/* ---------------------------------------------------------- *
   Bottom tab bar — mobile primary nav for authenticated members
 * ---------------------------------------------------------- */
.tab-bar {
    display: none;
    position: fixed;
    left: 0; right: 0; bottom: 0;
    z-index: 1030;
    padding: 9px 6px calc(env(safe-area-inset-bottom, 0px) + 9px);
    justify-content: space-around;
    background: rgba(10, 13, 21, 0.86);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-top: 1px solid var(--line);
}
.tab-bar a {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    flex: 1;
    padding: 2px 0;
    color: var(--tx-3);
    text-decoration: none;
    font-family: 'Space Grotesk', sans-serif;
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.02em;
    transition: color .15s ease;
}
.tab-bar a svg { display: block; }
.tab-bar a.active { color: var(--gold); font-weight: 600; }

@media (max-width: 991.98px) {
    body.has-tab-bar { padding-bottom: 64px; }
    body.has-tab-bar .tab-bar { display: flex; }
}

/* ---------------------------------------------------------- *
   Cards / panels (Bootstrap card re-theme — used where .panel
   markup hasn't been ported yet)
 * ---------------------------------------------------------- */
.card {
    background: var(--ink-800);
    border: 1px solid var(--line);
    border-radius: var(--radius-panel);
    color: var(--tx-2);
    backdrop-filter: none;
    transition: border-color .2s ease;
}
.card:hover {
    transform: none;
    border-color: var(--line-strong);
    box-shadow: none;
}
.club-panel,
.hero-band {
    background: var(--ink-800);
    border: 1px solid var(--line);
    border-radius: var(--radius-panel);
    padding: 1.25rem;
    box-shadow: none;
    backdrop-filter: none;
}
.hero-band::after { display: none; }
.hero-band h1 {
    background: none;
    -webkit-text-fill-color: unset;
    color: var(--tx);
}
.hero-band .lead,
.hero-band p { color: var(--tx-2); }

@keyframes twinkle {
    0%, 100% { opacity: 0.7; }
    50% { opacity: 1; }
}
.hero-starfield {
    position: relative;
    overflow: hidden;
}
.hero-starfield::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(1px 1px at 15% 25%, rgba(255,255,255,0.9), transparent),
        radial-gradient(1.5px 1.5px at 72% 18%, rgba(231,185,95,0.8), transparent),
        radial-gradient(1px 1px at 88% 60%, rgba(255,255,255,0.7), transparent),
        radial-gradient(2px 2px at 40% 75%, rgba(143,178,219,0.6), transparent),
        radial-gradient(1px 1px at 55% 40%, rgba(255,255,255,0.5), transparent),
        radial-gradient(1px 1px at 30% 55%, rgba(231,185,95,0.5), transparent);
    animation: twinkle 4s ease-in-out infinite;
    pointer-events: none;
    z-index: 0;
}
.hero-starfield > * { position: relative; z-index: 1; }

.mann-ki-baat-strip {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 12px 16px;
    border-top: 1px solid var(--gold-line);
    border-bottom: 1px solid var(--gold-line);
    margin: 32px 0;
    flex-wrap: wrap;
}
.mann-ki-baat-label {
    font-family: 'Space Grotesk', sans-serif;
    font-size: 13px;
    color: var(--gold);
    letter-spacing: 0.04em;
}

/* ---------------------------------------------------------- *
   Tables / lists / alerts
 * ---------------------------------------------------------- */
.table {
    --bs-table-bg: transparent;
    --bs-table-color: var(--tx-2);
    --bs-table-striped-bg: rgba(157, 174, 214, 0.04);
    --bs-table-striped-color: var(--tx-2);
    --bs-table-hover-bg: rgba(231, 185, 95, 0.06);
    --bs-table-hover-color: var(--tx);
    --bs-table-border-color: var(--line);
    border-color: var(--line);
}
.table thead th {
    color: var(--tx-3);
    font-family: 'Space Mono', monospace;
    letter-spacing: 0.12em;
    font-size: 10.5px;
    font-weight: 400;
    text-transform: uppercase;
    border-bottom-color: var(--line);
}

.list-group-item {
    background: var(--ink-800);
    border-color: var(--line);
    color: var(--tx-2);
}
.list-group-item-action:hover,
.list-group-item-action:focus {
    background: var(--ink-750);
    color: var(--tx);
}

.alert {
    background: var(--ink-800);
    border: 1px solid var(--line);
    border-radius: var(--radius-control);
    color: var(--tx-2);
    backdrop-filter: none;
}
.alert-success { border-color: rgba(116, 199, 154, 0.4); color: var(--ok); }
.alert-info    { border-color: var(--gold-line); color: var(--azure); }
.alert-warning { border-color: var(--gold-line); color: var(--warn); }
.alert-danger  { border-color: rgba(223, 144, 144, 0.4); color: var(--bad); }

/* ---------------------------------------------------------- *
   Footer
 * ---------------------------------------------------------- */
footer {
    border-top: 1px solid var(--line) !important;
    color: var(--tx-3);
}

/* ---------------------------------------------------------- *
   Misc
 * ---------------------------------------------------------- */
.text-muted, .muted { color: var(--tx-3) !important; }
.markdown-content > :last-child { margin-bottom: 0; }
.markdown-content ul { padding-left: 1.25rem; }
.markdown-content a { color: var(--azure); }

::-webkit-scrollbar { width: 0; height: 0; }

/* ---------------------------------------------------------- *
   Sky calendar — month grid with moon-phase icons
 * ---------------------------------------------------------- */
.cal-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 6px;
}
.cal-weekday {
    font-family: 'Space Mono', monospace;
    font-size: 10px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--tx-3);
    text-align: center;
    padding-bottom: 6px;
}
.cal-cell {
    background: var(--ink-800);
    border: 1px solid var(--line);
    border-radius: var(--radius-control);
    padding: 10px;
    min-height: 96px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 4px;
}
.cal-cell-empty { background: none; border-color: transparent; }
.cal-cell-today { border-color: var(--gold-line); background: var(--gold-soft); }
.cal-cell-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 4px;
}
.cal-day-num {
    font-family: 'Space Mono', monospace;
    font-size: 13px;
    line-height: 1;
    color: var(--tx-2);
    margin-top: 1px;
}
.cal-cell-today .cal-day-num { color: var(--gold); font-weight: 700; }
.cal-moon { display: inline-flex; flex: none; opacity: 0.9; }
.cal-events { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 3px; }
.cal-events li { font-size: 11px; line-height: 1.3; }
.cal-events a {
    color: var(--azure);
    text-decoration: none;
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.cal-events a:hover { color: var(--gold); }

@media (max-width: 575.98px) {
    .cal-grid { gap: 3px; }
    .cal-cell { padding: 7px 6px; min-height: 70px; gap: 3px; border-radius: 10px; }
    .cal-weekday { font-size: 9px; letter-spacing: 0.08em; }
    .cal-day-num { font-size: 11px; }
    .cal-moon svg { width: 20px; height: 20px; }
    .cal-events { display: none; }
}

@media print {
    body { background: #000 !important; }
    .navbar, footer, .tab-bar, .id-card-actions, .eyebrow { display: none !important; }
    .id-card { border-color: #c8a84b; box-shadow: none; }
}
