/* ============================================================================
   Pulsa — brand layer over Bootstrap 5.3
   Colours sampled from the club badge. Override Bootstrap CSS variables;
   do not recompile Sass.
   ============================================================================ */

:root {
  /* brand */
  --brand-terracotta:      #C45F3B;
  --brand-terracotta-deep: #A04A2C;
  --brand-amber:           #E2A04A;
  --brand-mustard:         #E8B739;
  --brand-sage:            #7A9A5C;
  --brand-sage-deep:       #5B7A3B;
  --brand-sky:             #BFD3D6;
  --brand-cream:           #F1E5C8;
  --brand-paper:           #F6EDD9;
  --brand-paper-2:         #ECE0C5;
  --brand-card:            #FDFAF1;
  --brand-line:            #D6C5A1;
  --brand-charcoal:        #2A1F1A;
  --brand-charcoal-2:      #4A3A30;
  --brand-muted:           #8A7A6E;

  /* Bootstrap 5.3 overrides */
  --bs-primary:        var(--brand-terracotta);
  --bs-primary-rgb:    196, 95, 59;
  --bs-success:        var(--brand-sage);
  --bs-success-rgb:    122, 154, 92;
  --bs-info:           var(--brand-sky);
  --bs-info-rgb:       191, 211, 214;
  --bs-warning:        var(--brand-amber);
  --bs-warning-rgb:    226, 160, 74;
  --bs-body-bg:        var(--brand-paper);
  --bs-body-color:     var(--brand-charcoal);
  --bs-body-font-family: "Inter Tight", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --bs-border-color:   var(--brand-line);
  --bs-link-color:     var(--brand-terracotta-deep);
  --bs-link-hover-color: var(--brand-terracotta);
}

body { font-variant-numeric: normal; }

h1, h2, h3, h4, h5 { letter-spacing: -0.02em; font-weight: 700; }

/* Buttons — re-tint primary so hover uses the deep terracotta */
.btn-primary {
  --bs-btn-bg: var(--brand-terracotta);
  --bs-btn-border-color: var(--brand-terracotta);
  --bs-btn-hover-bg: var(--brand-terracotta-deep);
  --bs-btn-hover-border-color: var(--brand-terracotta-deep);
  --bs-btn-active-bg: var(--brand-terracotta-deep);
  --bs-btn-active-border-color: var(--brand-terracotta-deep);
}
.btn-outline-primary {
  --bs-btn-color: var(--brand-terracotta);
  --bs-btn-border-color: var(--brand-terracotta);
  --bs-btn-hover-bg: var(--brand-terracotta);
  --bs-btn-hover-border-color: var(--brand-terracotta);
}
.btn-outline-secondary {
  --bs-btn-color: var(--brand-charcoal);
  --bs-btn-border-color: var(--brand-line);
  --bs-btn-hover-bg: var(--brand-paper-2);
  --bs-btn-hover-color: var(--brand-charcoal);
  --bs-btn-hover-border-color: var(--brand-line);
}

/* Navbar — charcoal w/ cream type, bigger brand mark */
.navbar.bg-dark { background-color: var(--brand-charcoal) !important; }
.navbar-dark .navbar-brand { color: var(--brand-cream); display: inline-flex; align-items: center; gap: 10px; }
.navbar-dark .navbar-brand img { width: 32px; height: 32px; border-radius: 50%; }
.navbar-dark .nav-link { color: var(--brand-cream); opacity: .85; }
.navbar-dark .nav-link:hover { color: #fff; opacity: 1; }
.navbar-dark .btn-outline-light {
  --bs-btn-color: var(--brand-cream);
  --bs-btn-border-color: var(--brand-cream);
  --bs-btn-hover-bg: var(--brand-cream);
  --bs-btn-hover-color: var(--brand-charcoal);
}

/* Tables — cream-paper rows, charcoal head, tabular numerals throughout */
.table { font-variant-numeric: tabular-nums; --bs-table-bg: var(--brand-card); --bs-table-border-color: var(--brand-line); }
.table > :not(caption) > * > * { background-color: var(--brand-card); color: var(--brand-charcoal); }
.table-dark {
  --bs-table-bg: var(--brand-charcoal);
  --bs-table-color: var(--brand-cream);
  --bs-table-border-color: var(--brand-charcoal-2);
}
.table-hover > tbody > tr:hover > * { background-color: var(--brand-paper-2); }

/* Cards / list-groups — warm cream surface */
.card { background-color: var(--brand-card); border-color: var(--brand-line); }
.card-header { background-color: var(--brand-paper-2); border-color: var(--brand-line); color: var(--brand-charcoal); font-weight: 600; }
.list-group-item { background-color: var(--brand-card); border-color: var(--brand-line); color: var(--brand-charcoal); }
.list-group-item-action:hover { background-color: var(--brand-paper-2); color: var(--brand-charcoal); }

/* Muted text — warmer than Bootstrap's neutral grey */
.text-muted { color: var(--brand-muted) !important; }

/* Code-ish accents */
code { color: var(--brand-terracotta-deep); background: var(--brand-paper-2); padding: 1px 6px; border-radius: 3px; }

/* Badges — re-tint */
.badge.bg-primary  { background-color: var(--brand-terracotta) !important; }
.badge.bg-success  { background-color: var(--brand-sage) !important; }
.badge.bg-info     { background-color: var(--brand-sky) !important; color: var(--brand-charcoal) !important; }
.badge.bg-warning  { background-color: var(--brand-amber) !important; color: var(--brand-charcoal) !important; }
.badge.bg-secondary{ background-color: var(--brand-muted) !important; }

/* ============================================================================
   Component additions used by the templates (see TASKS.md)
   ============================================================================ */

/* Rank pill — gold/silver/bronze/numbered */
.rank-pill {
  display: inline-block;
  min-width: 26px;
  text-align: center;
  padding: 2px 6px;
  background: var(--brand-charcoal);
  color: var(--brand-cream);
  border-radius: 4px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  font-size: 13px;
  line-height: 1.4;
}
.rank-pill--gold   { background: var(--brand-amber); color: var(--brand-charcoal); }
.rank-pill--silver { background: #B8A890; color: var(--brand-charcoal); }
.rank-pill--bronze { background: var(--brand-terracotta); color: #fff; }

/* Scoreboard cell — split points / metric */
.points-cell { font-variant-numeric: tabular-nums; line-height: 1.2; }
.points-cell .pts { font-size: 16px; font-weight: 700; color: var(--brand-charcoal); }
.points-cell .sub { display: block; font-size: 11px; color: var(--brand-muted); margin-top: 1px; }
.points-cell .pts--empty { color: #BBA894; font-weight: 500; }

/* Stat card metric number */
.metric-num { font-size: 2.6rem; font-weight: 700; line-height: 1; letter-spacing: -0.02em; color: var(--brand-charcoal); font-variant-numeric: tabular-nums; }

/* Segmented control (replaces stock <select> for scoreboard mode) */
.segmented {
  display: inline-flex;
  background: var(--brand-paper-2);
  padding: 4px;
  border-radius: 6px;
  gap: 2px;
}
.segmented .seg {
  background: transparent;
  color: var(--brand-charcoal);
  border: 0;
  padding: 6px 12px;
  font-size: 13px;
  font-weight: 500;
  border-radius: 4px;
  cursor: pointer;
  text-decoration: none;
  line-height: 1.4;
}
.segmented .seg.is-active {
  background: var(--brand-charcoal);
  color: var(--brand-cream);
}

/* Avatar gradient fallback (for users with no uploaded photo) */
.avatar-fallback {
  background: linear-gradient(135deg, var(--brand-terracotta), var(--brand-amber));
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  flex-shrink: 0;
}

/* Finish-position row highlights — 1st/2nd/3rd place */
.finish-row-1 { background: rgba(226, 160, 74, 0.18); }
.finish-row-2 { background: rgba(184, 168, 144, 0.20); }
.finish-row-3 { background: rgba(196, 95, 59, 0.12); }

/* ============================================================================
   Existing functional CSS — KEEP
   ============================================================================ */

.logo-preview img {
  background: repeating-conic-gradient(#eee 0 25%, #fff 0 50%) 50% / 16px 16px;
}
.logo-transparent-bg {
  background: repeating-conic-gradient(#eee 0 25%, #fff 0 50%) 50% / 16px 16px;
}
.logo-transparent-bg--sm {
  background: repeating-conic-gradient(#eee 0 25%, #fff 0 50%) 50% / 8px 8px;
}
