/*
 * OrgTrack – theme.css
 * Visual design inspired by betweenfriends.ab.ca
 * Colours driven by CSS variables set in base.html from BrandingProfile.
 * Fallback values match the Between Friends AB colour palette.
 */

:root {
  --ot-primary:        #1e3a6e;   /* BF dark navy       */
  --ot-secondary:      #6b7280;   /* medium grey        */
  --ot-accent:         #6b7280;   /* grey               */
  --ot-nav-text:       #ffffff;
  --ot-font:           'DM Sans', 'Segoe UI', sans-serif;

  /* Extended palette */
  --ot-navy-light:     #2e4f8e;
  --ot-grey-light:     #edf2f7;
  --ot-pink:           #d9027d;
  --ot-green:          #009739;
  --ot-yellow:         #f1b434;
}

/* ── Base ──────────────────────────────────────────────────────────────── */
body {
  font-family: var(--ot-font);
  background-color: #edf2f7;   /* light cool grey-blue */
  color: #1a1a1a;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

main {
  flex: 1;
}

h1, h2 {
  color: #6b7280;
  font-weight: 800;
}

/* ── Navbar ─────────────────────────────────────────────────── BF block nav ── */
.ot-navbar {
  background-color: #ffffff !important;
  border-bottom: 3px solid var(--ot-primary);
  padding-top: 0;
  padding-bottom: 0;
}

.ot-navbar .navbar-brand {
  color: var(--ot-primary) !important;
  font-weight: 800;
  letter-spacing: .02em;
  padding: .9rem 1rem;
}

.ot-navbar .nav-link {
  color: var(--ot-primary) !important;
  font-weight: 700;
  text-transform: uppercase;
  font-size: .8rem;
  letter-spacing: .06em;
  padding: .95rem 1.1rem !important;
  border-bottom: none !important;
  transition: background-color .15s ease;
}

.ot-navbar .nav-link:hover {
  color: #ffffff !important;
  background-color: var(--ot-primary);
  border-bottom: none !important;
}

.ot-navbar .nav-link.active {
  color: #ffffff !important;
  background-color: var(--ot-primary);
  border-bottom: none !important;
}

.ot-navbar .dropdown-menu {
  border-top: 4px solid var(--ot-primary);
  border-radius: 0;
  box-shadow: 0 4px 12px rgba(0,0,0,.18);
}

.ot-navbar .dropdown-item {
  color: var(--ot-primary);
  font-weight: 600;
}

.ot-navbar .dropdown-item:hover {
  background-color: var(--ot-primary);
  color: #ffffff;
  font-weight: 700;
}

.ot-navbar .navbar-toggler {
  border-color: var(--ot-primary);
}

.ot-navbar .navbar-toggler-icon {
  filter: none;
}

/* ── Footer ────────────────────────────────────────────────────────────── */
.ot-footer {
  background-color: #ffffff;
  color: #1a1a1a;
  border-top: 1px solid #dee2e6;
}

/* ── Buttons ── BF style: uppercase, bold, reversed hover, square corners ─── */
.btn {
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: .05em;
  border-radius: 0;
  font-size: .85rem;
}

.btn-primary {
  background-color: #6b7280 !important;
  border-color: #6b7280 !important;
  color: #fff !important;
  border-width: 2px;
}
.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active,
.btn-primary.active,
.show > .btn-primary.dropdown-toggle {
  background-color: #4b5563 !important;
  border-color: #4b5563 !important;
  color: #fff !important;
}

.btn-secondary {
  background-color: var(--ot-secondary);
  border: 2px solid var(--ot-secondary);
  color: #fff;
}

.btn-secondary:hover {
  background-color: #fff;
  border-color: var(--ot-secondary);
  color: var(--ot-secondary);
}

.btn-accent {
  background-color: var(--ot-accent);
  border: 2px solid var(--ot-accent);
  color: #fff;
}

.btn-accent:hover {
  background-color: #fff;
  border-color: var(--ot-accent);
  color: var(--ot-accent);
}

/* ── Cards ─────────────────────────────────────────────────────────────── */
.card {
  border: none;
  border-radius: 0;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .08);
}

.card-header {
  background-color: #6b7280;
  color: #fff;
  border-radius: 0 !important;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  font-size: .82rem;
}

/* ── Stat cards (dashboard) ─────────────────────────────────────────────── */
.stat-card {
  border-left: 5px solid var(--ot-primary);
  background: #fff;
  border-radius: 0;
  padding: 1.4rem 1.6rem;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .08);
  transition: transform .15s ease, box-shadow .15s ease;
}

.stat-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 18px rgba(0, 0, 0, .15);
}

.stat-card .stat-value {
  font-size: 2.5rem;
  font-weight: 800;
  color: #6b7280;
  line-height: 1;
}

.stat-card .stat-label {
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: #666;
  font-weight: 700;
  margin-top: .4rem;
}

/* ── Page header ────────────────────────────────────────────────────────── */
.page-header {
  border-bottom: 3px solid var(--ot-primary);
  padding-bottom: .5rem;
  margin-bottom: 1.5rem;
  color: #6b7280;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .04em;
}

/* ── Badge overrides ────────────────────────────────────────────────────── */
.badge-active   { background-color: #009739; }
.badge-inactive { background-color: #6c757d; }
.badge-pending  { background-color: #f1b434; color: #000; }

/* ── Tables ─────────────────────────────────────────────────────────────── */
.table thead th {
  background-color: #6b7280;
  color: #fff;
  border: none;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  font-size: .8rem;
}

/* ── Form focus states ─────────────────────────────────────────────────── */
.form-control:focus,
.form-select:focus {
  border-color: #6b7280;
  box-shadow: 0 0 0 .2rem rgba(107, 114, 128, .25);
}

/* ── Colour swatches (branding page) ───────────────────────────────────── */
.colour-swatch {
  display: inline-block;
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 50%;
  border: 1px solid rgba(0,0,0,.2);
  vertical-align: middle;
}

/* ── Bootstrap utility overrides → grey ────────────────────────────────── */
.bg-primary       { background-color: #6b7280 !important; }
.text-primary     { color: #6b7280 !important; }
.btn-outline-primary {
  --bs-btn-color:              #6b7280;
  --bs-btn-border-color:       #6b7280;
  --bs-btn-hover-color:        #fff;
  --bs-btn-hover-bg:           #6b7280;
  --bs-btn-hover-border-color: #6b7280;
  --bs-btn-active-color:       #fff;
  --bs-btn-active-bg:          #4b5563;
  --bs-btn-active-border-color:#4b5563;
  --bs-btn-focus-shadow-rgb:   107, 114, 128;
}
