@import url('https://fonts.googleapis.com/css2?family=ASAP:ital,wght@0,400..700;1,400..700&family=JetBrains+Mono:ital,wght@0,100..800;1,100..800&display=swap');

/* Bootstrap overrides */
:root, [data-bs-theme="dark"] {
  --bs-body-bg:          #0a120f;
  --bs-body-color:       #333333;
  --bs-body-font-family: 'ASAP', 'Aptos', -apple-system, sans-serif;
  --bs-primary:          #011c16;
  --bs-primary-rgb:      1, 28, 22;
  --bs-secondary-rgb:    128, 128, 128;
  --bs-border-color:     rgba(255,255,255,0.07);
  --bs-card-bg:          #0d1a12;
  --bs-link-color:       #011c16;
  --bs-link-hover-color: #000000;
}

html { background: #dcdcdc; }

body {
  background: transparent;
  color: #333333;
  font-family: 'ASAP', 'Aptos', -apple-system, sans-serif;
  -webkit-font-smoothing: antialiased;
  opacity: 0;
  animation: fadeIn 0.35s ease-out forwards;
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(3px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* NAVBAR */
.navbar-custom {
  background: #011c16 !important;
  border-bottom: 1px solid rgba(255,255,255,0.06) !important;
  box-shadow: 0 2px 16px rgba(0,0,0,0.4);
}

.nav-tab {
  color: #c0c0c0;
  text-decoration: none;
  padding: 8px 16px;
  border-radius: 4px;
  font-size: 0.9rem;
  font-weight: 500;
  transition: all 0.2s ease;
  border-bottom: 2px solid transparent;
}

.nav-tab:hover { color: #ffffff; background: rgba(255,255,255,0.05); }

.nav-tab.on {
  color: #ffffff !important;
  background: transparent !important;
  border-bottom: 2px solid #ffffff !important;
  border-radius: 0 !important;
  font-weight: 700;
}

/* HEADINGS — light bg = black, dark bg = white */
h1, h2, h3, h4, h5, h6 {
  font-family: 'ASAP', 'Aptos', sans-serif;
  font-weight: 700;
  color: #111111;
}

/* TABLES */
.table {
  --bs-table-bg: transparent;
  --bs-table-hover-bg: rgba(255,255,255,0.03);
  --bs-table-border-color: rgba(255,255,255,0.07);
  font-size: 0.88rem;
}

.table thead th {
  background: #080d0a !important;
  color: #ffffff !important;
  text-transform: uppercase;
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  border-bottom: 1px solid rgba(255,255,255,0.1) !important;
}

.table tbody tr { transition: background 0.15s ease; }
.table tbody td {
  border-bottom: 1px solid rgba(255,255,255,0.05);
  color: #c0c0c0;
}

.table td.font-monospace, .table td.text-end {
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 0.82rem;
  color: #ffffff;
}

.table tfoot tr { border-top: 2px solid rgba(255,255,255,0.1) !important; }
.table tfoot td { font-weight: bold; color: #e8e8e8; }

/* BUTTONS */
.btn {
  font-family: 'ASAP', sans-serif;
  font-weight: 600;
  border-radius: 4px;
  transition: all 0.2s ease;
}

.btn-primary {
  background: #ffffff !important;
  border-color: #ffffff !important;
  color: #011c16 !important;
  font-weight: 700;
}

.btn-primary:hover {
  background: #e0e0e0 !important;
  border-color: #e0e0e0 !important;
  transform: translateY(-1px);
}

.btn-outline-gold, .btn-outline-info {
  border-color: rgba(255,255,255,0.2) !important;
  color: #c0c0c0 !important;
  background: transparent;
}

.btn-outline-gold:hover, .btn-outline-info:hover {
  background: rgba(255,255,255,0.08) !important;
  color: #ffffff !important;
  transform: translateY(-1px);
}

.btn-outline-secondary {
  border-color: rgba(255,255,255,0.15) !important;
  color: #808080 !important;
}

.btn-outline-secondary:hover {
  background: rgba(255,255,255,0.06) !important;
  color: #c0c0c0 !important;
  transform: translateY(-1px);
}

.btn-outline-success {
  border-color: rgba(255,255,255,0.2) !important;
  color: #c0c0c0 !important;
}

.btn-outline-success:hover {
  background: rgba(255,255,255,0.08) !important;
  color: #ffffff !important;
  transform: translateY(-1px);
}

.btn-outline-danger {
  border-color: rgba(255,255,255,0.15) !important;
  color: #808080 !important;
}

.btn-outline-danger:hover {
  background: rgba(255,255,255,0.06) !important;
  color: #c0c0c0 !important;
  transform: translateY(-1px);
}

.btn-outline-light {
  border-color: rgba(255,255,255,0.15) !important;
  color: #c0c0c0 !important;
}

.btn-outline-light:hover {
  background: rgba(255,255,255,0.08) !important;
  color: #ffffff !important;
  transform: translateY(-1px);
}

.btn-warning {
  background: #ffffff !important;
  border-color: #ffffff !important;
  color: #011c16 !important;
  font-weight: 700;
}

.btn-warning:hover {
  background: #e0e0e0 !important;
  transform: translateY(-1px);
}

.btn-outline-danger.btn-sm { color: #808080 !important; }

/* CARDS & SURFACES */
.bg-dark, .card, .p-3.bg-dark, .p-3.rounded, .dropdown-menu {
  background-color: #0d1a12 !important;
  border: 1px solid rgba(255,255,255,0.07) !important;
}

.bg-dark.border-warning, .p-3.bg-dark.border-warning {
  border-color: rgba(255,255,255,0.12) !important;
}

/* FORM CONTROLS */
.form-label {
  font-family: 'JetBrains Mono', monospace;
  text-transform: uppercase;
  font-size: 0.72rem;
  letter-spacing: 0.05em;
  color: #c0c0c0;
  font-weight: 600;
}

.form-control, .form-select {
  background-color: #e9ebf2 !important;
  border: 1px solid rgba(255,255,255,0.1) !important;
  color: #111111 !important;
}

.form-control:focus, .form-select:focus {
  background-color: #ffffff !important;
  border-color: rgba(255,255,255,0.25) !important;
  box-shadow: 0 0 0 0.2rem rgba(255,255,255,0.05) !important;
}

.form-control::placeholder { color: #808080; }

.form-control:disabled, .form-select:disabled {
  background-color: #050808 !important;
  color: rgba(255,255,255,0.25) !important;
}

.form-text { color: #808080 !important; font-size: 0.72rem; }

/* BADGES */
.badge { font-family: 'JetBrains Mono', monospace; font-size: 0.72rem; border-radius: 3px; }

.badge-posted {
  background-color: #1a2e20 !important;
  color: #c0c0c0 !important;
  border: 1px solid rgba(255,255,255,0.1);
}

.badge-draft {
  background-color: rgba(255,255,255,0.05) !important;
  color: #808080 !important;
  border: 1px solid rgba(255,255,255,0.08);
}

/* LOGIN PAGE */
body.login-body {
  background: transparent;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
}

/* Login top header bar (matches FP&A .topbar) */
.topbar-login {
  width: 100%;
  background: #011c16;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  padding: 6px 28px;
  box-shadow: 0 2px 16px rgba(0,0,0,0.4);
  margin-bottom: 40px;
}
.topbar-login img { height: 47px; width: auto; }

.btn-logout {
  color: #011c16;
  text-decoration: none;
  border: none;
  padding: 5px 14px;
  border-radius: 5px;
  font-size: 12px;
  font-weight: 700;
  background: #ffffff;
  transition: background 0.2s;
}

.btn-logout:hover { background: #e8e8e8; color: #011c16; }

.auth-card {
  background: #0d1a12 !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  border-radius: 10px;
  box-shadow: 0 12px 40px rgba(0,0,0,0.5);
  width: 100%;
  max-width: 460px;
  overflow: hidden;
  margin: 20px;
}


.nav-tabs {
  border-bottom: 1px solid rgba(255,255,255,0.07) !important;
  background: rgba(0,0,0,0.2);
}

.nav-tabs .nav-link {
  color: #808080;
  border: none !important;
  padding: 12px 16px;
  font-weight: 500;
  font-size: 0.85rem;
  background: transparent !important;
  transition: all 0.2s ease;
}

.nav-tabs .nav-link:hover { color: #ffffff; background: rgba(255,255,255,0.04) !important; }

.nav-tabs .nav-link.active {
  color: #ffffff !important;
  background: #0d1a12 !important;
  border-bottom: 2px solid #ffffff !important;
  font-weight: 700;
}

.card-body-custom { padding: 26px; }

.disclaimer-box {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 6px;
  padding: 14px;
  font-size: 0.78rem;
  color: #808080;
}

/* ALERTS */
.alert { border-radius: 4px; font-size: 0.85rem; font-weight: 500; }
.alert-success { background: rgba(255,255,255,0.04) !important; border-color: rgba(255,255,255,0.1) !important; color: #c0c0c0 !important; }
.alert-danger  { background: rgba(255,255,255,0.04) !important; border-color: rgba(255,255,255,0.1) !important; color: #808080 !important; }
.alert-warning { background: rgba(255,255,255,0.04) !important; border-color: rgba(255,255,255,0.1) !important; color: #c0c0c0 !important; }
.alert-info    { background: rgba(255,255,255,0.04) !important; border-color: rgba(255,255,255,0.1) !important; color: #c0c0c0 !important; }
.alert-dark    { background: #0d1a12 !important; border-color: rgba(255,255,255,0.07) !important; color: #808080 !important; }

/* MISC */
.text-warning-custom, .text-muted-lite { color: #c0c0c0 !important; }
.border-warning-custom { border-color: rgba(255,255,255,0.12) !important; }
.computed-range-bar { background: #080d0a !important; border-color: rgba(255,255,255,0.08) !important; }
.text-success { color: #c0c0c0 !important; }
.text-danger  { color: #808080 !important; }
.text-muted   { color: #808080 !important; }
.dropdown-item { color: #c0c0c0 !important; }
.dropdown-item:hover { background: rgba(255,255,255,0.06) !important; color: #ffffff !important; }
.dropdown-divider { border-color: rgba(255,255,255,0.07) !important; }
.mono, code, pre { font-family: 'JetBrains Mono', monospace !important; font-size: 0.8rem !important; }

/* Neutralize Bootstrap yellow → palette greys (no gold anywhere) */
.badge.bg-warning { background: rgba(255,255,255,0.08) !important; color: #c0c0c0 !important; border: 1px solid rgba(255,255,255,0.1); }
.badge.bg-secondary { background: rgba(255,255,255,0.06) !important; color: #c0c0c0 !important; }
.border-warning { border-color: rgba(255,255,255,0.12) !important; }
.text-warning { color: #c0c0c0 !important; }

/* Session badges in navbar */
.badge.bg-dark { background: rgba(255,255,255,0.06) !important; color: #c0c0c0 !important; }
.badge.bg-dark.border-info { border-color: rgba(255,255,255,0.1) !important; color: #e8e8e8 !important; }
