/* ========================================
   Pages — Consolidated page-specific styles
   Extracted from individual HTML prototypes
   ======================================== */


/* ========================================
   Layout (shared across all pages)
   ======================================== */

/* Minimum page height: header + content + footer */
.page-wrapper {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

.page-wrapper > main {
  flex: 1;
}

/* ---- Hamburger menu (CSS-only, no JS) ---- */
.hamburger-toggle {
  display: none; /* hidden checkbox */
}

.hamburger-label {
  display: none;
}

.mobile-nav {
  display: none;
  position: absolute;
  top: var(--header-height);
  left: 0;
  right: 0;
  background-color: var(--color-primary-800);
  box-shadow: var(--shadow-lg);
  z-index: 99;
  flex-direction: column;
  padding: var(--space-2) 0;
  transform: translateY(-10px);
  opacity: 0;
  transition: transform var(--transition-base), opacity var(--transition-base);
}

.mobile-nav a {
  display: block;
  padding: var(--space-3) var(--space-6);
  color: var(--color-primary-200);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  text-decoration: none;
  transition: background-color var(--transition-fast), color var(--transition-fast);
}

.mobile-nav a:hover {
  background-color: var(--color-primary-700);
  color: var(--color-header-text);
  text-decoration: none;
}

.mobile-nav__meta {
  display: flex;
  justify-content: flex-end;
  padding: var(--space-2) var(--space-4) var(--space-1);
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  margin-top: var(--space-2);
}

.site-header__mobile-actions {
  display: none;
}

.search-toggle-label,
.hamburger-label {
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-md);
  color: var(--color-primary-200);
  font-size: 1.25rem;
  cursor: pointer;
  transition: background-color var(--transition-fast), color var(--transition-fast);
  user-select: none;
  -webkit-user-select: none;
  line-height: 1;
}

.search-toggle-label:hover,
.hamburger-label:hover {
  background: rgba(255, 255, 255, 0.12);
  color: var(--color-header-text);
}

/* When checkbox is checked, show the mobile nav */
.hamburger-toggle:checked ~ .mobile-nav {
  display: flex;
  transform: translateY(0);
  opacity: 1;
}

/* Mobile search icon toggle */
.search-toggle {
  display: none; /* hidden checkbox */
}

.search-toggle-label {
  display: none;
}

.mobile-search-bar {
  display: none;
  position: absolute;
  top: var(--header-height);
  left: 0;
  right: 0;
  background-color: var(--color-primary-800);
  padding: var(--space-3) var(--space-4);
  box-shadow: var(--shadow-lg);
  z-index: 98;
  transform: translateY(-10px);
  opacity: 0;
  transition: transform var(--transition-base), opacity var(--transition-base);
}

.search-toggle:checked ~ .mobile-search-bar {
  display: block;
  transform: translateY(0);
  opacity: 1;
}

.mobile-search-bar .search-input__field {
  background-color: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.15);
  color: var(--color-text-inverse);
}

.mobile-search-bar .search-input__field::placeholder {
  color: rgba(255, 255, 255, 0.5);
}

.mobile-search-bar .search-input__field:focus {
  background-color: rgba(255, 255, 255, 0.15);
  border-color: rgba(255, 255, 255, 0.3);
  box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.1);
}

.mobile-search-bar .search-input__icon {
  color: rgba(255, 255, 255, 0.5);
}

@media (max-width: 639px) {
  .site-header__mobile-actions {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    margin-left: auto;
    flex-shrink: 0;
  }

  .hamburger-label,
  .search-toggle-label {
    display: inline-flex;
  }

  /* Hide desktop search on mobile */
  .site-header__search {
    display: none;
  }

  /* Hide desktop nav on mobile */
  .site-header__nav {
    display: none;
  }

  .theme-toggle--desktop {
    display: none;
  }

  .theme-toggle--mobile {
    display: inline-flex;
  }
}

@media (min-width: 640px) {
  /* Always hide mobile nav & search on desktop */
  .mobile-nav {
    display: none !important;
  }
  .mobile-search-bar {
    display: none !important;
  }
}

/* ---- Footer multi-row layout ---- */
.site-footer__top {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-6);
  margin-bottom: var(--space-6);
}

.site-footer__brand {
  font-size: var(--font-size-h4);
  font-weight: var(--font-weight-bold);
  color: var(--color-text);
}

.site-footer__brand span {
  color: var(--color-primary-300);
}

.site-footer__social {
  display: flex;
  gap: var(--space-4);
  list-style: none;
}

.site-footer__social a {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  transition: color var(--transition-fast);
}

.site-footer__social a:hover {
  color: var(--color-primary-500);
  text-decoration: none;
}

.site-footer__social-icon {
  width: 20px;
  height: 20px;
  fill: currentColor;
}

.site-footer__bottom {
  border-top: 1px solid var(--color-gray-200);
  padding-top: var(--space-4);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
}

@media (max-width: 639px) {
  .site-footer__top {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
  .site-footer__bottom {
    flex-direction: column;
    text-align: center;
  }
}

/* ---- Placeholder content cards (layout.html) ---- */
.placeholder-card {
  background-color: var(--color-surface);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: var(--space-6);
  border: 1px solid var(--color-gray-100);
}

.placeholder-card__bar {
  height: 12px;
  background-color: var(--color-gray-200);
  border-radius: var(--radius-sm);
  margin-bottom: var(--space-3);
}

.placeholder-card__bar--short {
  width: 60%;
}

.placeholder-card__bar--medium {
  width: 80%;
}

.placeholder-card__bar--long {
  width: 100%;
}


/* ========================================
   Home Page
   ======================================== */

/* Homepage sections — consistent spacing and alternating backgrounds */
.homepage-section {
  padding: var(--space-12) 0;
}

.section--alt {
  background-color: var(--color-gray-50);
}

/* Competitions sub-headings within merged section */
.competitions-subheading {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  margin-bottom: var(--space-3);
  margin-top: var(--space-6);
}

.competitions-subheading:first-of-type {
  margin-top: 0;
}

/* Hero section */
.hero {
  background: linear-gradient(135deg, var(--color-primary-900) 0%, var(--color-primary-700) 60%, var(--color-primary-600) 100%);
  color: var(--color-text-inverse);
  padding: var(--space-16) 0 calc(var(--space-16) + var(--space-10));
  text-align: center;
  position: relative;
  overflow: hidden;
}

.hero::before {
  content: '';
  position: absolute;
  top: -30%;
  right: -10%;
  width: 50%;
  height: 160%;
  background: radial-gradient(ellipse, rgba(255, 255, 255, 0.05) 0%, transparent 70%);
  pointer-events: none;
}

.hero__title {
  font-size: 2.75rem;
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--space-4);
  color: var(--color-text-inverse);
  letter-spacing: var(--letter-spacing-tight);
}

.hero__tagline {
  font-size: var(--font-size-h4);
  opacity: 0.85;
  margin: 0 auto var(--space-8);
  max-width: 600px;
}

.hero__search {
  max-width: 560px;
  margin: 0 auto;
}

.hero__search .search-input__field {
  background-color: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.2);
  color: var(--color-text-inverse);
}

.hero__search .search-input__field::placeholder {
  color: rgba(255, 255, 255, 0.55);
}

.hero__search .search-input__field:focus {
  background-color: rgba(255, 255, 255, 0.18);
  border-color: rgba(255, 255, 255, 0.4);
  box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.1);
}

.hero__search .search-input__icon {
  color: rgba(255, 255, 255, 0.55);
}

/* Hero #1 champion cards */
.hero__champions {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
  margin-top: var(--space-10);
}

.hero__champion-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-4) var(--space-3);
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-lg);
  text-decoration: none;
  color: var(--color-text-inverse);
  transition: background-color var(--transition-fast), border-color var(--transition-fast);
}

.hero__champion-card:hover {
  background: rgba(255, 255, 255, 0.14);
  border-color: rgba(255, 255, 255, 0.22);
  text-decoration: none;
  color: var(--color-text-inverse);
}

.hero__champion-size {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  opacity: 0.7;
}

.hero__champion-handler {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  text-align: center;
  line-height: 1.3;
}

.hero__champion-dog {
  font-size: var(--font-size-xs);
  opacity: 0.7;
}

.hero__champion-rating {
  font-size: var(--font-size-h4);
  font-weight: var(--font-weight-bold);
  font-variant-numeric: tabular-nums;
  margin-top: var(--space-1);
}

@media (max-width: 639px) {
  .hero {
    padding: var(--space-10) 0 var(--space-12);
  }
  .hero__title {
    font-size: 2rem;
  }
  .hero__tagline {
    font-size: var(--font-size-base);
  }
  .hero__champions {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-3);
    margin-top: var(--space-8);
  }
}

@media (min-width: 640px) and (max-width: 1023px) {
  .hero__champions {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Spotlight section — size tabs for mobile */
.size-tabs {
  display: none;
}

@media (max-width: 1023px) {
  .size-tabs {
    display: flex;
    width: 100%;
    margin-bottom: var(--space-4);
    border-radius: var(--radius-md);
  }

  .size-tabs .pill {
    flex: 1 1 0;
    min-width: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: var(--space-2) var(--space-2);
  }

  .size-tabs .pill.active {
    background-color: var(--color-gray-100);
    color: var(--color-text);
  }

  .size-tab-content {
    display: none;
  }
  .size-tab-content.active {
    display: block;
  }
}

@media (min-width: 1024px) {
  .size-tabs {
    display: none;
  }
  .size-tab-content {
    display: block !important;
  }
}

/* Spotlight column */
.spotlight-col__title {
  font-size: var(--font-size-h4);
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--space-3);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.spotlight-col__title .badge-size {
  font-size: var(--font-size-sm);
  padding: var(--space-1) var(--space-3);
}

/* Uniform spotlight cards */
.size-tab-content {
  min-width: 0;
}

.size-tab-content .team-card {
  padding: var(--space-3) var(--space-4);
  margin-bottom: var(--space-2);
}

.size-tab-content .team-card__dog {
  color: var(--color-text-tertiary);
  font-size: var(--font-size-sm);
}

.size-tab-content .team-card__rating {
  flex-shrink: 0;
  white-space: nowrap;
}

/* Latest Event section — colored background to stand out */
.latest-event {
  padding: var(--space-12) 0;
  background: linear-gradient(135deg, var(--color-primary-800) 0%, var(--color-primary-600) 100%);
  color: var(--color-text-inverse);
}

.latest-event__heading {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-6);
}

.latest-event__heading h2 {
  color: var(--color-text-inverse);
  margin: 0;
}

.latest-event__heading .section-header__link {
  color: rgba(255, 255, 255, 0.7);
}

.latest-event__heading .section-header__link:hover {
  color: var(--color-text-inverse);
}

.latest-event__title-row {
  margin-bottom: var(--space-5);
}

.latest-event__name {
  font-size: var(--font-size-h2);
  font-weight: var(--font-weight-bold);
  margin: 0;
  color: var(--color-text-inverse);
}

.latest-event__meta {
  color: rgba(255, 255, 255, 0.7);
  font-size: var(--font-size-sm);
  margin-top: var(--space-1);
}

.latest-event__stats-row {
  display: flex;
  gap: var(--space-6);
  margin-bottom: var(--space-8);
}

.latest-event__stat {
  text-align: center;
  padding: var(--space-4) var(--space-6);
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: var(--radius-lg);
}

.latest-event__stat-value {
  font-size: var(--font-size-h2);
  font-weight: var(--font-weight-bold);
  font-variant-numeric: tabular-nums;
  color: var(--color-text-inverse);
  line-height: 1;
}

.latest-event__stat-label {
  font-size: var(--font-size-xs);
  color: rgba(255, 255, 255, 0.6);
  margin-top: var(--space-1);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
}

.latest-event__performers-label {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.6);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  margin-bottom: var(--space-3);
}

.latest-event__performer {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-2);
  text-decoration: none;
  color: var(--color-text-inverse);
  transition: background-color var(--transition-fast);
}

.latest-event__performer:hover {
  background: rgba(255, 255, 255, 0.14);
  text-decoration: none;
  color: var(--color-text-inverse);
}

.latest-event__performer-rank {
  color: rgba(255, 255, 255, 0.5);
  font-weight: var(--font-weight-semibold);
  min-width: 1.5em;
}

.latest-event__performer-size {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  color: rgba(255, 255, 255, 0.45);
  margin-left: var(--space-2);
  white-space: nowrap;
}

.latest-event__performer-name {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: var(--font-weight-medium);
}

.latest-event__performer-stats {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-left: auto;
  flex-shrink: 0;
  font-size: var(--font-size-sm);
  font-variant-numeric: tabular-nums;
}

.latest-event__performer-top3 {
  font-weight: var(--font-weight-bold);
  color: rgba(255, 255, 255, 0.95);
}

.latest-event__performer-finish {
  color: rgba(255, 255, 255, 0.6);
}

.latest-event__performer-best {
  color: rgba(255, 255, 255, 0.7);
  font-weight: var(--font-weight-medium);
}

@media (max-width: 639px) {
  .latest-event__stats-row {
    flex-wrap: wrap;
    gap: var(--space-3);
  }

  .latest-event__stat {
    flex: 1;
    min-width: 80px;
    padding: var(--space-3) var(--space-4);
  }

  .latest-event__stat-value {
    font-size: var(--font-size-h3);
  }

  .latest-event__heading {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-2);
  }

  .latest-event__performer {
    flex-wrap: wrap;
    gap: var(--space-1) var(--space-3);
    padding: var(--space-2) var(--space-3);
  }

  .latest-event__performer-name {
    flex: 1 1 0;
    white-space: normal;
    overflow: visible;
    text-overflow: unset;
  }

  .latest-event__performer-stats {
    width: 100%;
    margin-left: calc(1.5em + var(--space-3));
  }
}


/* ========================================
   Rankings Page
   ======================================== */

/* Rankings filters */
.rankings-filter-row .filter-group {
  flex: 1;
  min-width: 0;
}

.rankings-filter-row .pill-group,
.rankings-filter-row .dropdown,
.rankings-filter-row .dropdown__select,
.rankings-filter-row .search-input {
  width: 100%;
}

.rankings-filter-row .pill-group {
  justify-content: center;
}

.rankings-filter-size .pill-group {
  display: flex;
  width: 100%;
}

.rankings-filter-size .pill-group .pill {
  flex: 1 1 25%;
  min-width: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* Name search in filter bar */
.filter-bar__search {
  margin-left: auto;
}

.filter-bar__search .search-input {
  max-width: none;
}

@media (max-width: 639px) {
  .rankings-filter-row {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
  }

  .rankings-filter-row .filter-group {
    width: 100%;
  }

  .rankings-filter-size { order: 1; }
  .rankings-filter-country { order: 2; }
  .filter-bar__search { order: 3; }

  .filter-bar__search {
    margin-left: 0;
    width: 100%;
  }
}

/* Competitions filters */
.competition-filter-search {
  flex: 1;
  min-width: 0;
}

@media (max-width: 639px) {
  .competition-filter-bar .container {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-2);
  }

  .competition-filter-bar .filter-group {
    flex: 0 0 100%;
    width: 100%;
    margin-left: 0;
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-1);
  }

  .competition-filter-year,
  .competition-filter-tier,
  .competition-filter-search {
    width: 100%;
    margin-left: 0;
  }

  /* Keep labels accessible, but visually hidden on mobile */
  .competition-filter-bar .filter-group__label {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }

  /* Balanced segmented controls on mobile */
  .competition-filter-year .pill-group,
  .competition-filter-tier .pill-group {
    display: flex;
    width: 100%;
  }

  .competition-filter-year .pill,
  .competition-filter-tier .pill {
    flex: 1 1 0;
    min-width: 0;
    text-align: center;
  }
}

/* Runs sub-info */
.cell-runs__total {
  font-weight: var(--font-weight-semibold);
  font-variant-numeric: tabular-nums;
}

.cell-runs__fraction {
  font-size: var(--font-size-xs);
  color: var(--color-text-tertiary);
}


/* ========================================
   Team Profile Page
   ======================================== */

/* Chart placeholder */
.chart-placeholder {
  border: 2px dashed var(--color-gray-200);
  border-radius: var(--radius-lg);
  padding: var(--space-12) var(--space-4);
  text-align: center;
  color: var(--color-text-tertiary);
  font-size: var(--font-size-sm);
  background-color: var(--color-surface);
  min-height: 250px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
}

.chart-placeholder__icon {
  font-size: 2.5rem;
  opacity: 0.3;
}

/* Results pagination info */
.results-info {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  padding: var(--space-3) 0;
}

/* Inactive variant section */
.inactive-section {
  margin-top: var(--space-12);
  padding-top: var(--space-8);
  border-top: 2px dashed var(--color-gray-200);
}

.inactive-section__label {
  font-size: var(--font-size-sm);
  color: var(--color-text-tertiary);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  font-weight: var(--font-weight-semibold);
  margin-bottom: var(--space-4);
}

/* Hero card inactive overlay dimming */
.hero-card--inactive {
  opacity: 0.75;
}


/* ========================================
   Handler Profile Page
   ======================================== */

.handler-header {
  margin-bottom: var(--space-2);
}

.handler-header__name {
  font-size: 2rem;
  font-weight: var(--font-weight-bold);
  margin: 0;
  line-height: 1.2;
}

.handler-header__meta {
  color: var(--color-text-secondary);
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-1);
}

.handler-teams-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.handler-team-row {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  background-color: var(--color-surface);
  border: 1px solid var(--color-gray-100);
  border-radius: var(--radius-lg);
  padding: var(--space-4) var(--space-5);
  transition: all var(--transition-fast);
  text-decoration: none;
  color: inherit;
}

.handler-team-row:visited {
  color: inherit;
}

.handler-team-row:hover {
  box-shadow: var(--shadow-md);
  border-color: var(--color-gray-200);
  transform: translateY(-1px);
  text-decoration: none;
}

.handler-team-row--inactive { opacity: 0.65; }

.handler-team-row__main {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.handler-team-row__dog {
  display: flex;
  flex-direction: column;
}

.handler-team-row__name {
  font-size: var(--font-size-h4);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text);
}

.handler-team-row__reg-name {
  font-size: var(--font-size-sm);
  color: var(--color-text-tertiary);
}

.handler-team-row__breed {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
}

.handler-team-row__badges {
  display: flex; gap: var(--space-1); flex-wrap: wrap;
}

.handler-team-row__stats {
  display: flex;
  gap: var(--space-2);
  flex-shrink: 0;
}

.handler-team-row__stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  background-color: var(--color-surface-alt);
  min-width: 56px;
}

.handler-team-row__stat-value {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  font-variant-numeric: tabular-nums;
  line-height: 1;
}

.handler-team-row__stat-label {
  font-size: var(--font-size-xs);
  color: var(--color-text-tertiary);
  margin-top: 2px;
}

.handler-team-row__rating {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex-shrink: 0;
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-md);
  background: linear-gradient(135deg, var(--color-primary-50), var(--color-info-bg));
  border: 1px solid var(--color-primary-100);
  min-width: 72px;
  margin-left: auto;
}

.handler-team-row__rating-value {
  font-size: var(--font-size-h3);
  font-weight: var(--font-weight-bold);
  font-variant-numeric: tabular-nums;
  color: var(--color-primary-700);
  line-height: 1;
}

.handler-team-row__rating-label {
  font-size: var(--font-size-xs);
  color: var(--color-primary-600);
  margin-top: 2px;
}

.handler-team-row__peak {
  font-size: var(--font-size-xs);
  color: var(--color-text-tertiary);
  margin-top: 2px;
}

.badge-inactive {
  background-color: var(--color-gray-100);
  color: var(--color-text-tertiary);
  border: 1px solid var(--color-gray-200);
}

@media (max-width: 768px) {
  .handler-team-row {
    flex-wrap: wrap;
    gap: var(--space-3);
  }

  .handler-team-row__stats,
  .handler-team-row__rating {
    margin-left: 0;
  }

  .handler-header__name {
    font-size: 1.5rem;
  }
}


[data-theme="dark"] .handler-team-row__rating {
  background: linear-gradient(135deg, rgba(124, 58, 237, 0.1), rgba(124, 58, 237, 0.05));
  border-color: rgba(139, 92, 246, 0.2);
}

[data-theme="dark"] .handler-team-row__rating-value {
  color: var(--color-primary-300);
}

[data-theme="dark"] .handler-team-row__rating-label {
  color: var(--color-primary-400);
}

/* Handler profile link (on team detail page) */
.handler-profile-link {
  display: inline;
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
}

.handler-profile-link:hover {
  color: var(--color-link-hover);
}

.handler-profile-link__label {
  color: var(--color-text-tertiary);
}

.handler-profile-link__name {
  font-weight: var(--font-weight-medium);
}


/* ========================================
   Competitions Page
   ======================================== */

/* View toggle (segmented control) */
.view-toggle {
  display: inline-flex;
  background-color: var(--color-surface-alt);
  border-radius: var(--radius-full);
  padding: var(--space-1);
  gap: var(--space-1);
}

.view-toggle__btn {
  padding: var(--space-2) var(--space-5);
  border-radius: var(--radius-full);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-secondary);
  text-decoration: none;
  transition: all var(--transition-fast);
}

.view-toggle__btn:hover {
  color: var(--color-text);
  text-decoration: none;
}

.view-toggle__btn.active {
  background-color: var(--color-surface);
  color: var(--color-text);
  box-shadow: var(--shadow-sm);
  font-weight: var(--font-weight-semibold);
}

.filter-bar .search-input {
  max-width: 220px;
}

@media (max-width: 639px) {
  .filter-bar .search-input {
    max-width: none;
    width: 100%;
  }
}


/* ========================================
   How It Works Page
   ======================================== */

.hiw-hero {
  background: linear-gradient(135deg, var(--color-primary-900) 0%, var(--color-primary-700) 100%);
  color: var(--color-text-inverse);
  padding: var(--space-16) 0;
  text-align: center;
}

.hiw-hero h1 {
  color: var(--color-text-inverse);
  font-size: 2.5rem;
  margin-bottom: var(--space-3);
}

.hiw-hero p {
  font-size: var(--font-size-h4);
  opacity: 0.85;
  max-width: 640px;
  margin: 0 auto;
}

.hiw-section {
  padding: var(--space-12) 0;
}

.hiw-section--alt {
  background-color: var(--color-gray-50);
}

.hiw-section h2 {
  margin-bottom: var(--space-6);
}

.hiw-section h3 {
  margin-top: var(--space-6);
  margin-bottom: var(--space-3);
}

.hiw-section p,
.hiw-section li {
  line-height: var(--line-height-loose);
  color: var(--color-text-secondary);
}

.hiw-section ul,
.hiw-section ol {
  padding-left: var(--space-6);
  margin-bottom: var(--space-4);
}

.hiw-section li {
  margin-bottom: var(--space-2);
}

.hiw-callout {
  background-color: var(--color-primary-50);
  border-left: 4px solid var(--color-primary-500);
  padding: var(--space-4) var(--space-6);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  margin: var(--space-6) 0;
}

[data-theme="dark"] .hiw-callout {
  background-color: rgba(124, 58, 237, 0.10);
  border-left-color: var(--color-primary-400);
}

.hiw-callout p {
  color: var(--color-text);
  margin-bottom: 0;
}

.hiw-two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-8);
  margin: var(--space-6) 0;
}

@media (max-width: 639px) {
  .hiw-two-col {
    grid-template-columns: 1fr;
  }
  .hiw-hero h1 {
    font-size: var(--font-size-h1);
  }
}

.hiw-affects-card {
  background-color: var(--color-surface);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
}

.hiw-affects-card h4 {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.hiw-affects-card--yes h4 {
  color: var(--color-success);
}

.hiw-affects-card--no h4 {
  color: var(--color-error);
}

/* Size mapping table */
.mapping-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--font-size-sm);
  margin: var(--space-4) 0;
}

.mapping-table th {
  text-align: left;
  padding: var(--space-3) var(--space-4);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  color: var(--color-text-secondary);
  background-color: var(--color-gray-50);
  border-bottom: 2px solid var(--color-gray-200);
}

.mapping-table td {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-gray-100);
  vertical-align: middle;
}

.mapping-table tbody tr:hover {
  background-color: var(--color-primary-50);
}

[data-theme="dark"] .mapping-table tbody tr:hover {
  background-color: rgba(124, 58, 237, 0.10);
}

/* Disclaimer section */
.disclaimer-list {
  list-style: none;
  padding-left: 0;
}

.disclaimer-list li {
  position: relative;
  padding: var(--space-4) var(--space-4) var(--space-4) var(--space-8);
  background-color: var(--color-surface);
  border: 1px solid var(--color-gray-100);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-3);
}

.disclaimer-list li::before {
  content: "!";
  position: absolute;
  left: var(--space-3);
  top: var(--space-4);
  width: 20px;
  height: 20px;
  background-color: var(--color-warning-bg);
  color: var(--color-warning);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
}

/* Mechanism list (vertical stack with numbered items) */
.mechanism-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  margin: var(--space-6) 0;
}

.mechanism-item {
  display: grid;
  grid-template-columns: 48px 1fr;
  gap: var(--space-4);
  background-color: var(--color-surface);
  border-radius: var(--radius-lg);
  padding: var(--space-5) var(--space-6);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--color-gray-100);
}

.mechanism-item__number {
  font-size: 1.75rem;
  font-weight: var(--font-weight-bold);
  color: var(--color-primary-200);
  line-height: 1;
  padding-top: var(--space-1);
  text-align: center;
}

[data-theme="dark"] .mechanism-item__number {
  color: var(--color-primary-700);
}

.mechanism-item__content h4 {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  color: var(--color-text);
  margin-bottom: var(--space-2);
}

.mechanism-item__content p {
  font-size: var(--font-size-sm);
}

.mechanism-item__why {
  font-style: italic;
  color: var(--color-text-tertiary);
  margin-bottom: 0;
  margin-top: var(--space-2);
}

@media (max-width: 639px) {
  .mechanism-item {
    grid-template-columns: 36px 1fr;
    gap: var(--space-3);
    padding: var(--space-4);
  }
  .mechanism-item__number {
    font-size: 1.5rem;
  }
}

.content-narrow {
  max-width: 780px;
}


/* ========================================
   Search Dropdown Page
   ======================================== */

/* Search demo specific */
.search-demo-wrapper {
  position: relative;
  max-width: 480px;
}

/* Force dropdown visible for demo */
.search-demo-wrapper .search-dropdown {
  display: block;
}


/* ========================================
   States Page (Empty, Error, Loading)
   ======================================== */

/* 404 page */
.not-found {
  text-align: center;
  padding: var(--space-16) var(--space-4);
}

.not-found__code {
  font-size: 6rem;
  font-weight: var(--font-weight-bold);
  color: var(--color-gray-200);
  line-height: 1;
  margin-bottom: var(--space-4);
}

.not-found__title {
  font-size: var(--font-size-h2);
  font-weight: var(--font-weight-bold);
  color: var(--color-text);
  margin-bottom: var(--space-3);
}

.not-found__description {
  font-size: var(--font-size-base);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-6);
  max-width: 480px;
  margin-left: auto;
  margin-right: auto;
}

.not-found__links {
  display: flex;
  gap: var(--space-4);
  justify-content: center;
  flex-wrap: wrap;
}

/* Error state */
.error-state {
  text-align: center;
  padding: var(--space-12) var(--space-4);
  background-color: var(--color-error-bg);
  border-radius: var(--radius-lg);
  border: 1px solid rgba(209, 41, 61, 0.15);
}

.error-state__icon {
  font-size: 3rem;
  margin-bottom: var(--space-4);
}

.error-state__title {
  font-size: var(--font-size-h3);
  font-weight: var(--font-weight-bold);
  color: var(--color-text);
  margin-bottom: var(--space-2);
}

.error-state__description {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-6);
}

/* Skeleton loading */
@keyframes skeleton-shimmer {
  0% {
    background-position: -200% 0;
  }
  100% {
    background-position: 200% 0;
  }
}

.skeleton {
  background: linear-gradient(
    90deg,
    var(--color-gray-100) 25%,
    var(--color-gray-200) 37%,
    var(--color-gray-100) 63%
  );
  background-size: 200% 100%;
  animation: skeleton-shimmer 1.5s ease-in-out infinite;
  border-radius: var(--radius-sm);
}

.skeleton-bar {
  height: 14px;
  margin-bottom: var(--space-3);
}

.skeleton-bar--short { width: 40%; }
.skeleton-bar--medium { width: 65%; }
.skeleton-bar--long { width: 90%; }
.skeleton-bar--full { width: 100%; }

.skeleton-circle {
  border-radius: var(--radius-full);
}

/* Skeleton table */
.skeleton-table {
  width: 100%;
  border-collapse: collapse;
}

.skeleton-table th {
  text-align: left;
  padding: var(--space-3) var(--space-4);
  border-bottom: 2px solid var(--color-gray-200);
}

.skeleton-table td {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-gray-100);
}

.skeleton-table .skeleton-bar {
  margin-bottom: 0;
}

/* Skeleton stat cards */
.skeleton-stat-card {
  background-color: var(--color-surface);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: var(--space-6);
  text-align: center;
}

.skeleton-stat-card .skeleton-bar {
  margin-left: auto;
  margin-right: auto;
}

/* Skeleton hero card */
.skeleton-hero {
  background: linear-gradient(135deg, var(--color-primary-900) 0%, var(--color-primary-700) 100%);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-8);
  align-items: center;
}

.skeleton-hero .skeleton {
  background: linear-gradient(
    90deg,
    rgba(255, 255, 255, 0.08) 25%,
    rgba(255, 255, 255, 0.15) 37%,
    rgba(255, 255, 255, 0.08) 63%
  );
  background-size: 200% 100%;
  animation: skeleton-shimmer 1.5s ease-in-out infinite;
}

@media (max-width: 639px) {
  .skeleton-hero {
    grid-template-columns: 1fr;
    padding: var(--space-6);
  }
}


/* ========================================
   Shared: Demo sections
   (used by search-dropdown.html and states.html)
   ======================================== */

.demo-section {
  margin-bottom: var(--space-12);
}

.demo-label {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  color: var(--color-text-tertiary);
  margin-bottom: var(--space-2);
}

.demo-description {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-4);
}

/* States page overrides for demo-section */
.states-page .demo-section {
  padding-bottom: var(--space-12);
  border-bottom: 2px solid var(--color-gray-100);
}

.states-page .demo-section:last-child {
  border-bottom: none;
}

.states-page .demo-description {
  margin-bottom: var(--space-6);
}


/* ========================================
   Compare Teams Page
   ======================================== */

.compare-input-row {
  display: flex;
  gap: var(--space-3);
  align-items: flex-end;
}

.compare-input-field {
  flex: 1;
  min-width: 0;
}

.compare-btn {
  flex-shrink: 0;
  height: 42px;
}

.compare-error {
  font-size: var(--font-size-sm);
  color: var(--color-error);
  background-color: var(--color-error-bg);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
}

@media (max-width: 639px) {
  .compare-input-row {
    flex-direction: column;
    align-items: stretch;
  }

  .compare-btn {
    width: 100%;
  }
}
