/* ==========================================================================
   Commitment Center — On3/Rivals-style board, Orangebloods look & feel.
   Toolbar · tabs · rank cards · stats strip · legend · player table.
   Mobile-first; the table collapses to stacked rows on narrow screens.
   ========================================================================== */
/* The page container adds its own grid row-gap on top of each section's
   margin-bottom, doubling the spacing — drop the grid gap here. */
.ob-cc.site-home .site-home__container {
  row-gap: 0;
}

/* Layout: main column + right rail. Mobile-first single column; the 300px
   rail joins on the right from 1024px up. */
.ob-cc__layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--spacing-8);
}

.ob-cc__main {
  min-width: 0;
}

@media screen and (min-width: 1024px) {
  .ob-cc__layout {
    grid-template-columns: minmax(0, 1fr) 300px;
    gap: var(--spacing-8);
    align-items: start;
  }
}

/* Right rail — stacked ad slots; sticks beside the main column on desktop. */
.ob-cc__rail {
  display: grid;
  row-gap: var(--spacing-4);
  min-width: 0;
}

@media screen and (min-width: 1024px) {
  .ob-cc__rail {
    position: sticky;
    top: var(--spacing-4);
  }
}

/* Ad slot placeholder (real ad units are wired by an engineer via AdThrive). */
.ob-cc .site-home__ad {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 300px;
  max-width: 100%;
  min-height: 250px;
  margin: 0 auto;
  background-color: var(--site-background-color);
  border: 1px dashed var(--border-color);
}

.ob-cc .site-home__ad-label {
  font-size: 0.625rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-secondary-color);
}

.ob-cc__head {
  margin-bottom: var(--spacing-4);
}

.ob-cc__eyebrow {
  display: block;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-secondary-color);
}

.ob-cc__title {
  font-size: 1.75rem;
  font-weight: 800;
  color: #36454f;
  border-left: 4px solid var(--site-primary-color);
  padding-left: var(--spacing-4);
}

/* --- Toolbar --- */
.ob-cc__toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-2);
  margin-bottom: 4rem; /* ~one row of breathing room before the tabs */
}

.ob-cc__control {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-2);
  padding: 0.55rem 0.9rem;
  border: 1px solid var(--border-color);
  border-radius: var(--ob-radius-sm);
  background-color: #fff;
  white-space: nowrap;
}

.ob-cc__control-label {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-secondary-color);
}

.ob-cc__control-value {
  font-size: 0.9rem;
  font-weight: 800;
  color: #36454f;
}

/* Dropdown toggles (native <details>). */
.ob-cc__dd {
  position: relative;
  padding: 0;
}

.ob-cc__dd > summary {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-2);
  padding: 0.55rem 0.9rem;
  list-style: none;
  cursor: pointer;
}

.ob-cc__dd > summary::-webkit-details-marker {
  display: none;
}

.ob-cc__caret {
  width: 0.4em;
  height: 0.4em;
  border-right: 2px solid var(--text-secondary-color);
  border-bottom: 2px solid var(--text-secondary-color);
  transform: rotate(45deg);
  transition: transform 0.15s ease;
}

.ob-cc__dd[open] .ob-cc__caret {
  transform: rotate(-135deg);
}

.ob-cc__menu {
  position: absolute;
  left: 0;
  top: calc(100% + 4px);
  z-index: 50;
  min-width: 100%;
  background-color: #fff;
  border: 1px solid var(--border-color);
  border-radius: var(--ob-radius-sm);
  box-shadow: 0 14px 30px rgba(17, 17, 17, 0.12);
  padding: var(--spacing-1);
}

.ob-cc__menu-item {
  display: block;
  padding: 0.45rem 0.8rem;
  border-radius: var(--ob-radius-sm);
  font-size: 0.9rem;
  font-weight: 600;
  color: #36454f;
  text-decoration: none;
  white-space: nowrap;
}

.ob-cc__menu-item:hover {
  background-color: var(--ob-highlight-soft);
  color: var(--site-primary-color);
}

.ob-cc__menu-item.is-active {
  background-color: var(--site-primary-color);
  color: #fff;
}

/* --- Tabs --- */
.ob-cc__tabs {
  display: flex;
  gap: var(--spacing-6);
  border-bottom: 1px solid var(--border-color);
  margin-bottom: var(--spacing-6);
}

.ob-cc__tab {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-2);
  padding: 0 0 var(--spacing-2);
  font-size: 0.95rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--text-secondary-color);
}

.ob-cc__tab.is-active {
  color: #36454f;
  box-shadow: inset 0 -3px 0 var(--site-primary-color);
}

.ob-cc__tab.is-disabled {
  opacity: 0.45;
}

.ob-cc__tab-count {
  font-size: 0.7rem;
  font-weight: 700;
  background-color: var(--ob-highlight-soft);
  color: var(--site-primary-color);
  border-radius: 999px;
  padding: 2px 7px;
}

/* --- Transfer portal sub-nav --- */
.ob-cc__subnav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--spacing-2) var(--spacing-4);
  padding: var(--spacing-2);
  margin-bottom: var(--spacing-4);
  border: 1px solid var(--border-color);
  border-radius: var(--ob-radius);
  background-color: #fff;
}

.ob-cc__subtab {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-2);
  padding: 0.45rem 0.8rem;
  border-radius: var(--ob-radius-sm);
  font-size: 0.85rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--text-secondary-color);
  text-decoration: none;
}

.ob-cc__subtab:hover {
  background-color: var(--ob-highlight-soft);
  color: var(--site-primary-color);
}

.ob-cc__subtab.is-active {
  background-color: var(--ob-highlight-soft);
  color: var(--site-primary-color);
}

.ob-cc__subtab .ob-cc__tab-count {
  background-color: var(--ob-highlight-soft);
}

.ob-cc__subtab.is-active .ob-cc__tab-count {
  background-color: #fff;
}

.ob-cc__subnav-sep {
  width: 1px;
  height: 22px;
  background-color: var(--border-color);
}

.ob-cc__subtab--ext {
  color: var(--text-secondary-color);
}

/* --- Timeline --- */
.ob-cc__timeline {
  list-style: none;
  margin: 0;
  padding: 0;
  background-color: #fff;
  border: 1px solid var(--border-color);
  border-radius: var(--ob-radius);
}

.ob-cc__tl-item {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--spacing-2) var(--spacing-4);
  padding: var(--spacing-4) var(--spacing-6);
  border-top: 1px solid var(--border-color);
}

.ob-cc__tl-item:first-child {
  border-top: 0;
}

.ob-cc__tl-dir {
  flex: none;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.05em;
  padding: 2px 8px;
  border-radius: 999px;
}

.ob-cc__tl-dir--in {
  background-color: #dff3e4;
  color: #2e7d4f;
}

.ob-cc__tl-dir--out {
  background-color: color-mix(in srgb, var(--site-primary-color), #fff 86%);
  color: var(--site-primary-color);
}

.ob-cc__tl-date {
  flex: none;
  font-size: 0.8rem;
  color: var(--text-secondary-color);
  min-width: 92px;
}

.ob-cc__tl-name {
  font-weight: 800;
  color: var(--site-primary-color);
  text-decoration: none;
}

.ob-cc__tl-meta {
  font-size: 0.85rem;
  color: var(--text-secondary-color);
}

/* --- Transfer rankings list --- */
.ob-cc__ranklist {
  list-style: none;
  margin: 0;
  padding: 0;
  background-color: #fff;
  border: 1px solid var(--border-color);
  border-radius: var(--ob-radius);
}

.ob-cc__rankrow {
  display: flex;
  align-items: center;
  gap: var(--spacing-4);
  padding: var(--spacing-4) var(--spacing-6);
  border-top: 1px solid var(--border-color);
}

.ob-cc__rankrow:first-child {
  border-top: 0;
}

.ob-cc__rank-num {
  flex: none;
  width: 1.8rem;
  font-size: 1rem;
  font-weight: 800;
  color: var(--site-primary-color);
  text-align: center;
}

.ob-cc__rank-rating {
  margin-left: auto;
  font-weight: 800;
  color: #36454f;
}

/* --- Rank cards --- */
.ob-cc__rankcards {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--spacing-4);
  margin-bottom: var(--spacing-4);
}

@media screen and (min-width: 640px) {
  .ob-cc__rankcards {
    grid-template-columns: repeat(3, 1fr);
  }
}

.ob-cc__rankcard {
  background-color: #fff;
  border: 1px solid var(--border-color);
  border-top: 3px solid var(--site-primary-color);
  border-radius: var(--ob-radius);
  padding: var(--spacing-4) var(--spacing-6);
}

.ob-cc__rankcard-label {
  display: block;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-secondary-color);
  margin-bottom: var(--spacing-2);
}

.ob-cc__rankcard-num {
  font-size: 2.5rem;
  font-weight: 800;
  line-height: 1;
  color: #36454f;
}

.ob-cc__rankcard-num sup {
  font-size: 1rem;
  font-weight: 700;
}

/* --- Stats strip --- */
.ob-cc__stats {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-6) var(--spacing-12);
  padding: var(--spacing-4) var(--spacing-6);
  margin-bottom: var(--spacing-6);
  background-color: #fff;
  border: 1px solid var(--border-color);
  border-radius: var(--ob-radius);
}

.ob-cc__stat {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-1);
}

.ob-cc__stat-label {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-secondary-color);
}

.ob-cc__stat strong {
  font-size: 1.25rem;
  font-weight: 800;
  color: #36454f;
}

.ob-cc__chips {
  display: inline-flex;
  gap: 4px;
}

.ob-cc__chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 4px;
  font-size: 0.85rem;
  font-weight: 800;
  color: #36454f;
}

.ob-cc__chip--5 {
  background-color: #e7b94e; /* gold = 5★ */
}

.ob-cc__chip--4 {
  background-color: #f1d18a; /* light gold = 4★ */
}

/* --- Legend --- */
.ob-cc__legend {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-6);
  align-items: center;
  padding: var(--spacing-2) var(--spacing-4);
  margin-bottom: var(--spacing-4);
  border: 1px solid var(--border-color);
  border-radius: var(--ob-radius);
  font-size: 0.85rem;
  color: var(--text-secondary-color);
}

.ob-cc__legend-item {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-2);
}

.ob-cc__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 6px;
  font-size: 0.8rem;
  font-weight: 800;
}

.ob-cc__badge--c {
  background-color: var(--ob-highlight-soft);
  color: var(--site-primary-color);
}

.ob-cc__badge--s {
  background-color: #dff3e4;
  color: #2e7d4f;
}

.ob-cc__badge--e {
  background-color: #f3eddf;
  color: #8a6d1f;
}

/* --- Player table --- */
.ob-cc__table {
  background-color: #fff;
  border: 1px solid var(--border-color);
  border-radius: var(--ob-radius);
  overflow: hidden;
}

.ob-cc__row {
  display: grid;
  grid-template-columns: minmax(0, 2.4fr) 0.6fr minmax(0, 1.6fr) 1fr 0.8fr;
  align-items: center;
  gap: var(--spacing-2);
  padding: var(--spacing-4) var(--spacing-6);
  border-top: 1px solid var(--border-color);
}

/* Transfer view: player | pos | rating | status | last→new. */
.ob-cc__row--transfer {
  grid-template-columns: minmax(0, 2fr) 0.5fr minmax(0, 1.4fr) 1fr 1.5fr;
}

/* Timeline view: player | pos | grades/NIL | status | last→new. */
.ob-cc__row--tl {
  grid-template-columns: minmax(0, 1.9fr) 0.4fr minmax(0, 1.5fr) 1fr 1.3fr;
}

.ob-cc__col--grades {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.ob-cc__grade {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.85rem;
}

.ob-cc__grade strong {
  font-weight: 800;
  color: #36454f;
}

.ob-cc__gtag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 26px;
  height: 18px;
  padding: 0 5px;
  border-radius: 4px;
  font-size: 0.6rem;
  font-weight: 800;
  letter-spacing: 0.03em;
}

.ob-cc__gtag--tp {
  background-color: #fbe4e0;
  color: #b5443a;
}

.ob-cc__gtag--hs {
  background-color: var(--site-background-color);
  color: var(--text-secondary-color);
}

/* Status pill (timeline) — Enrolled/Signed/Committed. */
.ob-cc__status-pill {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 700;
  padding: 3px 9px;
  border-radius: 999px;
}

.ob-cc__status-pill--c {
  background-color: var(--ob-highlight-soft);
  color: var(--site-primary-color);
}

.ob-cc__status-pill--s {
  background-color: #dff3e4;
  color: #2e7d4f;
}

.ob-cc__status-pill--e {
  background-color: #f3eddf;
  color: #8a6d1f;
}

.ob-cc__path {
  display: flex;
  align-items: center;
  gap: var(--spacing-2);
}

.ob-cc__path-logo {
  flex: none;
  width: 38px;
  height: 38px;
  border-radius: 8px;
  border: 1px solid var(--border-color);
  background-color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 4px;
}

.ob-cc__path-logo img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  display: block;
}

.ob-cc__path-arrow {
  flex: none;
  color: #36454f;
  font-size: 0.7rem;
}

/* Roster view: player | # | pos | ht | wt | class | rating (On3 layout). */
.ob-cc__row--roster {
  grid-template-columns: minmax(0, 2.4fr) 0.4fr 0.6fr 0.6fr 0.6fr 0.7fr minmax(0, 1.2fr);
}

.ob-cc__col--num {
  font-weight: 800;
  color: var(--site-primary-color);
}

.ob-cc__col--ht,
.ob-cc__col--wt,
.ob-cc__col--class {
  font-size: 0.9rem;
  font-weight: 600;
  color: #36454f;
}

.ob-cc__na {
  color: var(--text-secondary-color);
}

/* Sortable column header buttons (roster). */
.ob-cc__sort {
  -webkit-appearance: none;
  appearance: none;
  border: 0;
  background: none;
  font: inherit;
  color: inherit;
  letter-spacing: inherit;
  text-transform: inherit;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 4px;
}

.ob-cc__sort::after {
  content: "\2195"; /* ↕ */
  font-size: 0.85em;
  opacity: 0.35;
}

.ob-cc__sort:hover {
  color: var(--site-primary-color);
}

.ob-cc__sort[aria-sort] {
  color: var(--site-primary-color);
}

.ob-cc__sort[aria-sort="ascending"]::after {
  content: "\2191"; /* ↑ */
  opacity: 1;
}

.ob-cc__sort[aria-sort="descending"]::after {
  content: "\2193"; /* ↓ */
  opacity: 1;
}

.ob-cc__row--head {
  border-top: 0;
  background-color: var(--site-background-color);
  padding-top: var(--spacing-2);
  padding-bottom: var(--spacing-2);
}

.ob-cc__row--head .ob-cc__col {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-secondary-color);
}

.ob-cc__player {
  display: flex;
  align-items: center;
  gap: var(--spacing-4);
  text-decoration: none;
  min-width: 0;
}

.ob-cc__avatar {
  flex: none;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  overflow: hidden;
  background-color: var(--site-background-color);
}

.ob-cc__avatar img,
.ob-cc .ob-cc__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.ob-cc__playerinfo {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.ob-cc__name {
  font-weight: 800;
  font-size: 1rem;
  color: var(--site-primary-color);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ob-cc__hs,
.ob-cc__phys {
  font-size: 0.8rem;
  color: var(--text-secondary-color);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ob-cc__col--pos {
  font-weight: 800;
  color: #36454f;
}

.ob-cc__stars {
  display: flex;
  align-items: center;
  gap: 1px;
}

.ob-cc__star {
  color: #d8d8d8;
  font-size: 0.85rem;
}

.ob-cc__star.is-on {
  color: var(--site-primary-color);
}

.ob-cc__score {
  margin-left: var(--spacing-2);
  font-weight: 800;
  color: #36454f;
  font-size: 0.95rem;
}

.ob-cc__ranks {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-2);
  margin-top: 2px;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--text-secondary-color);
}

.ob-cc__ranks strong {
  color: #36454f;
}

.ob-cc__col--status {
  display: flex;
  align-items: center;
  gap: var(--spacing-2);
}

.ob-cc__date {
  font-size: 0.85rem;
  color: var(--text-secondary-color);
}

.ob-cc__col--logo {
  display: flex;
  align-items: center;
}

.ob-cc__commit-logo {
  width: 44px;
  height: 44px;
  border-radius: 8px;
  border: 1px solid var(--border-color);
  background-color: #fff;
  padding: 5px;
  object-fit: contain;
  display: block;
}

.ob-cc__profile-link {
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--site-primary-color);
  white-space: nowrap;
}

.ob-cc__profile-link:hover {
  opacity: 0.8;
}

.ob-cc__viewall {
  display: inline-block;
  margin-top: var(--spacing-4);
  font-weight: 700;
  color: var(--site-primary-color);
}

.ob-cc__empty {
  color: var(--text-secondary-color);
  padding: var(--spacing-8) 0;
}

/* Mobile: collapse the grid columns into a stacked card. */
@media screen and (max-width: 760px) {
  .ob-cc__row--head {
    display: none;
  }
  .ob-cc__row {
    grid-template-columns: 1fr auto;
    grid-template-areas:
      "player status"
      "rating rating";
    row-gap: var(--spacing-2);
  }
  .ob-cc__col--player { grid-area: player; }
  .ob-cc__col--status { grid-area: status; align-self: start; }
  .ob-cc__col--rating { grid-area: rating; }
  .ob-cc__col--pos,
  .ob-cc__col--profile { display: none; }

  /* Transfer rows: player + status, with the Last→New chain + rating beneath. */
  .ob-cc__row--transfer {
    grid-template-columns: 1fr auto;
    grid-template-areas:
      "player status"
      "path   path"
      "rating rating";
  }
  .ob-cc__row--transfer .ob-cc__col--player { grid-area: player; }
  .ob-cc__row--transfer .ob-cc__col--status { grid-area: status; align-self: start; }
  .ob-cc__row--transfer .ob-cc__col--path { grid-area: path; }
  .ob-cc__row--transfer .ob-cc__col--rating { grid-area: rating; }
  .ob-cc__row--transfer .ob-cc__col--pos { display: none; }

  /* Timeline rows: player + status, with grades + Last→New beneath. */
  .ob-cc__row--tl {
    grid-template-columns: 1fr auto;
    grid-template-areas:
      "player status"
      "grades grades"
      "path   path";
  }
  .ob-cc__row--tl .ob-cc__col--player { grid-area: player; }
  .ob-cc__row--tl .ob-cc__col--status { grid-area: status; align-self: start; }
  .ob-cc__row--tl .ob-cc__col--grades { grid-area: grades; }
  .ob-cc__row--tl .ob-cc__col--path { grid-area: path; }
  .ob-cc__row--tl .ob-cc__col--pos { display: none; }

  /* Roster rows: number + player on one line; secondary columns hidden. */
  .ob-cc__row--roster {
    grid-template-columns: auto 1fr auto;
    grid-template-areas: "num player class";
  }
  .ob-cc__row--roster .ob-cc__col--num { grid-area: num; align-self: center; }
  .ob-cc__row--roster .ob-cc__col--player { grid-area: player; }
  .ob-cc__row--roster .ob-cc__col--class { grid-area: class; align-self: center; }
  .ob-cc__row--roster .ob-cc__col--pos,
  .ob-cc__row--roster .ob-cc__col--ht,
  .ob-cc__row--roster .ob-cc__col--wt,
  .ob-cc__row--roster .ob-cc__col--rating { display: none; }
}
