/* assets/css/ncaa-rankings.css */

/* ==========================
   NCAA Rankings page layout
   ========================== */

.page-rankings__section {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.page-rankings__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 4px;
}

.page-rankings__subtitle {
  font-size: 0.9rem;
  color: var(--text-muted);
  margin: 4px 0 0;
}

.page-rankings__updated {
  display: inline-block;
  font-size: 0.8rem;
  margin-top: 2px;
  opacity: 0.85;
}

/* Controls (poll date dropdown) */
.page-rankings__controls {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.85rem;
}

.page-rankings__controls label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.page-rankings__controls select {
  font-family: var(--font-sans);
  font-size: 0.85rem;
  padding: 4px 22px 4px 8px;
  border-radius: 999px;
  border: 1px solid var(--border-subtle);
  background: var(--card-bg);
  color: var(--text-main);
}

/* Mobile layout tweaks */
@media (max-width: 700px) {
  .page-rankings__header {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }

  .page-rankings__controls {
    align-self: flex-start;
  }
}

/* ==========================
   Rankings card & table
   ========================== */

.rankings-card {
  background: var(--card-bg);
  border-radius: 12px;
  border: 1px solid var(--card-border);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.7);
  overflow: hidden;
}

/* Table base */
.rankings-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}

.rankings-table thead {
  background: linear-gradient(
    90deg,
    rgba(255, 255, 255, 0.03),
    rgba(255, 255, 255, 0.03)
  );
}

.rankings-table th,
.rankings-table td {
  padding: 9px 12px;
  text-align: left;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.rankings-table th {
  font-size: 0.8rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text-muted);
}

/* Column sizing */
.rankings-table__col-rank {
  width: 52px;
}

.rankings-table__col-record {
  width: 130px;
}

.rankings-table__col-points {
  width: 90px;
}

.rankings-table__col-prev {
  width: 90px;
}

/* Zebra + hover */
.rankings-table tbody tr:nth-child(2n) {
  background: rgba(255, 255, 255, 0.01);
}

.rankings-table tbody tr:hover {
  background: rgba(255, 255, 255, 0.04);
}

/* ==========================
   Team cell
   ========================== */

.rankings-table__cell-rank {
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}

.rankings-table__cell-team {
  padding-right: 16px;
}

.rankings-table__team {
  display: flex;
  align-items: center;
  gap: 8px;
}

.rankings-table__logo {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
  border: 1px solid var(--border-subtle);
  background: rgba(0, 0, 0, 0.25);
}

.rankings-table__logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.rankings-table__team-name {
  font-weight: 500;
}

.rankings-table__team-votes {
  font-size: 0.78rem;
  color: var(--text-muted);
  margin-left: 2px;
}

/* Record / points cells */
.rankings-table__cell-record,
.rankings-table__cell-points {
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

/* ==========================
   Previous rank & trends
   ========================== */

.rankings-table__cell-prev {
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.rankings-table__prev-rank {
  display: inline-block;
  min-width: 22px;
}

.rankings-table__trend {
  margin-left: 4px;
  font-size: 0.8rem;
}

/* Green up, red down, neutral gray */
.rankings-table__trend--up {
  color: #4ade80; /* soft green */
}

.rankings-table__trend--down {
  color: #f97373; /* soft red */
}

.rankings-table__trend--same {
  color: var(--text-muted);
}

/* ==========================
   Empty-state text
   ========================== */

.page-rankings__section > p {
  font-size: 0.9rem;
  color: var(--text-muted);
}
