/* ── Torn Tracker custom styles ───────────────────────────────────────── */

/* ── Torn Tracker custom styles ───────────────────────────────────────── */

:root {
    --tt-border: #30363d;
    --tt-muted: #8b949e;
    --tt-accent: #58a6ff;
    --tt-warn: #d29922;
    --tt-success: #3fb950;
    --tt-danger: #f85149;
}

[data-bs-theme="dark"] {
    --tt-bg: #0d1117;
    --tt-surface: #161b22;
    --tt-border: #30363d;
    --tt-text: #e6edf3;
    --tt-muted: #8b949e;
}

[data-bs-theme="light"] {
    --tt-bg: #f6f8fa;
    --tt-surface: #ffffff;
    --tt-border: #d0d7de;
    --tt-text: #1f2328;
    --tt-muted: #656d76;
    --tt-accent: #0969da;
    --tt-warn: #9a6700;
    --tt-success: #1a7f37;
    --tt-danger: #cf222e;
}

body {
    background-color: var(--tt-bg) !important;
    color: var(--tt-text);
    font-family: 'Segoe UI', system-ui, sans-serif;
}

.card {
    background-color: var(--tt-surface) !important;
}

/* ── Light mode: override hardcoded dark utility classes ──────────────── */

[data-bs-theme="light"] .bg-dark {
    background-color: var(--tt-surface) !important;
}

[data-bs-theme="light"] .bg-black {
    background-color: #ffffff !important;
}

[data-bs-theme="light"] .text-light,
[data-bs-theme="light"] .text-white {
    color: var(--tt-text) !important;
}

[data-bs-theme="light"] .text-muted {
    color: var(--tt-muted) !important;
}

[data-bs-theme="light"] .border-secondary {
    border-color: var(--tt-border) !important;
}

/* Tables — target cells directly for reliable override */
[data-bs-theme="light"] .table-dark {
    --bs-table-bg: var(--tt-surface);
    --bs-table-color: var(--tt-text);
    --bs-table-border-color: var(--tt-border);
    --bs-table-striped-bg: #f0f2f5;
    --bs-table-hover-bg: #e8ecf0;
    color: var(--tt-text) !important;
    border-color: var(--tt-border) !important;
}

[data-bs-theme="light"] .table-dark > :not(caption) > * > * {
    background-color: var(--tt-surface) !important;
    color: var(--tt-text) !important;
    border-bottom-color: var(--tt-border) !important;
}

[data-bs-theme="light"] .table-dark > thead > tr > * {
    background-color: #f0f2f5 !important;
    color: var(--tt-text) !important;
}

[data-bs-theme="light"] .table-dark > tbody > tr:hover > * {
    background-color: #e8ecf0 !important;
}

[data-bs-theme="light"] .table-secondary {
    --bs-table-bg: #f0f2f5;
    --bs-table-color: var(--tt-text);
}

[data-bs-theme="light"] .table-secondary > :not(caption) > * > * {
    background-color: #f0f2f5 !important;
    color: var(--tt-text) !important;
}

/* Form controls */
[data-bs-theme="light"] .form-control.bg-dark,
[data-bs-theme="light"] .form-select.bg-dark {
    background-color: #ffffff !important;
    border-color: var(--tt-border) !important;
}

[data-bs-theme="light"] .form-control.text-white,
[data-bs-theme="light"] .form-select.text-white,
[data-bs-theme="light"] .form-control.text-light,
[data-bs-theme="light"] .form-select.text-light {
    color: var(--tt-text) !important;
}

/* Navbar */
[data-bs-theme="light"] .navbar-dark {
    --bs-navbar-color: var(--tt-text);
    --bs-navbar-hover-color: var(--tt-accent);
}

[data-bs-theme="light"] .navbar-dark .nav-link {
    color: var(--tt-text) !important;
}

[data-bs-theme="light"] .navbar-dark .nav-link:hover {
    color: var(--tt-accent) !important;
}

[data-bs-theme="light"] .navbar-dark .navbar-brand {
    color: var(--tt-accent) !important;
}

[data-bs-theme="light"] .navbar {
    border-bottom-color: var(--tt-border) !important;
}

/* Dropdown menus */
[data-bs-theme="light"] .dropdown-menu-dark {
    background-color: #ffffff !important;
    border-color: var(--tt-border) !important;
}

[data-bs-theme="light"] .dropdown-menu-dark .dropdown-item {
    color: var(--tt-text) !important;
}

[data-bs-theme="light"] .dropdown-menu-dark .dropdown-item:hover,
[data-bs-theme="light"] .dropdown-menu-dark .dropdown-item.active {
    background-color: #f0f2f5 !important;
    color: var(--tt-accent) !important;
}

[data-bs-theme="light"] .dropdown-menu-dark .dropdown-divider {
    border-color: var(--tt-border) !important;
}

/* Badges */
[data-bs-theme="light"] .badge.bg-secondary {
    background-color: #e0e3e8 !important;
    color: #1f2328 !important;
}

/* Buttons */
[data-bs-theme="light"] .btn-outline-secondary {
    border-color: var(--tt-border) !important;
    color: var(--tt-text) !important;
}

/* Toast */
[data-bs-theme="light"] .toast.bg-dark {
    background-color: #ffffff !important;
    color: var(--tt-text) !important;
}

/* Page link (pagination) */
[data-bs-theme="light"] .page-link.bg-dark {
    background-color: #ffffff !important;
    color: var(--tt-text) !important;
}

/* Footer */
[data-bs-theme="light"] footer {
    border-color: var(--tt-border) !important;
}

/* Navbar toggler (mobile) */
[data-bs-theme="light"] .navbar-dark .navbar-toggler {
    border-color: var(--tt-border) !important;
}
[data-bs-theme="light"] .navbar-dark .navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(33, 37, 41, 0.75)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
}

/* Close buttons (e.g. toast dismiss) */
[data-bs-theme="light"] .btn-close-white {
    filter: none !important;
}

/* Input group add-ons */
[data-bs-theme="light"] .input-group-text.bg-dark {
    background-color: #f0f2f5 !important;
    color: var(--tt-text) !important;
    border-color: var(--tt-border) !important;
}

/* Modals */
[data-bs-theme="light"] .modal-content.bg-dark {
    background-color: var(--tt-surface) !important;
    color: var(--tt-text) !important;
    border-color: var(--tt-border) !important;
}

/* Table tweaks */
#memberTable thead th {
    font-size: 0.72rem;
    letter-spacing: 0.07em;
    color: var(--tt-muted);
    border-bottom: 1px solid var(--tt-border);
}

#memberTable tbody tr:hover td {
    background-color: rgba(88, 166, 255, 0.05);
}

#memberTable td {
    border-color: var(--tt-border);
    padding: 0.55rem 0.75rem;
    font-size: 0.9rem;
}

/* Navbar bottom border */
.navbar {
    border-bottom: 1px solid var(--tt-border) !important;
}

/* Status dots */
.text-success { color: var(--tt-success) !important; }
.text-danger  { color: var(--tt-danger)  !important; }
.text-warning { color: var(--tt-warn)    !important; }
.text-info    { color: var(--tt-accent)  !important; }

/* Search input */
#memberSearch {
    background-color: var(--tt-surface) !important;
    border-color: var(--tt-border) !important;
    color: var(--tt-text) !important;
}
#memberSearch:focus {
    border-color: var(--tt-accent) !important;
    box-shadow: 0 0 0 0.2rem rgba(88, 166, 255, 0.2);
}

/* Footer */
footer {
    color: var(--tt-muted);
    font-size: 0.8rem;
}

/* ── OC Tier Badges (add to custom.css) ── */

/* Spawn symbol pill used in catalog headers */
.oc-spawn-symbol {
  display: inline-block;
  font-size: 1.1rem;
  font-weight: 700;
  width: 1.8rem;
  text-align: center;
  border-radius: 4px;
  padding: 0 4px;
  margin-right: 4px;
}

/* Tier badge used in dashboard + catalog */
.oc-tier-badge {
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  padding: 2px 7px;
  border-radius: 4px;
}

/* Colors matching in-game Torn OC tiers */
.oc-tier-grey,   .oc-tier-λ { background-color: #0d2e16 !important; color: #69db7c !important; }
.oc-tier-blue,   .oc-tier-Σ { background-color: #3d2e00 !important; color: #ffe066 !important; }
.oc-tier-gold,   .oc-tier-Φ { background-color: #3d1f00 !important; color: #ffa94d !important; }
.oc-tier-purple, .oc-tier-Ψ, .tier-psi { background-color: #3d1010 !important; color: #ff8787 !important; }
.oc-tier-violet, .oc-tier-Ω { background-color: #2a1a4a !important; color: #9775fa !important; border: 1px solid #5533aa !important; }

/* Catalog card hover */
.oc-catalog-card {
  transition: border-color 0.15s;
}
.oc-catalog-card:hover {
  border-color: #666 !important;
}
.oc-catalog-card.border-warning:hover {
  border-color: #ffc107 !important;
}

/* Tier filter buttons */
.oc-tier-btn {
  border: 1px solid transparent;
  opacity: 0.6;
  transition: opacity .15s;
}
.oc-tier-btn:hover,
.oc-tier-btn-active {
  opacity: 1 !important;
  box-shadow: 0 0 0 2px rgba(255,255,255,0.15);
}

/* Apply the same tier colors to buttons */
.btn.oc-tier-λ { background-color: #0d2e16 !important; color: #69db7c !important; border-color: #69db7c !important; }
.btn.oc-tier-Σ { background-color: #3d2e00 !important; color: #ffe066 !important; border-color: #ffe066 !important; }
.btn.oc-tier-Φ { background-color: #3d1f00 !important; color: #ffa94d !important; border-color: #ffa94d !important; }
.btn.oc-tier-Ψ { background-color: #3d1010 !important; color: #ff8787 !important; border-color: #ff8787 !important; }
.btn.oc-tier-Ω { background-color: #2a1a4a !important; color: #9775fa !important; border-color: #9775fa !important; }