/* -------------------------------------------------
   Material 3 Expressive theme for RaceDX (LIGHT default)
   ------------------------------------------------- */

:root{
  --rdx-primary: var(--wp-admin-theme-color, #1a73e8);
  --rdx-on-primary: #ffffff;

  --rdx-surface: #f6f7fb;
  --rdx-surface-container: #ffffff;
  --rdx-surface-container-high: #eef1f7;

  --rdx-on-surface: #101114;
  --rdx-on-surface-variant: #394150;
  --rdx-outline: #d8dde6;

  --rdx-radius-xl: 24px;
  --rdx-radius-lg: 18px;
  --rdx-radius-md: 14px;
  --rdx-radius-pill: 9999px;

  --rdx-shadow-1: 0 1px 3px rgba(0,0,0,.10), 0 1px 2px rgba(0,0,0,.06);
  --rdx-shadow-2: 0 6px 18px rgba(0,0,0,.12), 0 2px 6px rgba(0,0,0,.08);

  --rdx-font: system-ui, -apple-system, "Roboto", "Inter", "Segoe UI", sans-serif;
}

/* Если вдруг захочешь тёмную тему — добавь body.racedx-dark */
body.racedx-dark{
  --rdx-surface: #0c0e12;
  --rdx-surface-container: #12151b;
  --rdx-surface-container-high: #1a1f27;

  --rdx-on-surface: #eef1f6;
  --rdx-on-surface-variant: #b7c0cf;
  --rdx-outline: #2a303b;

  --rdx-shadow-1: 0 1px 3px rgba(0,0,0,.55);
  --rdx-shadow-2: 0 8px 20px rgba(0,0,0,.60);
}

.racedx-global-header,
.racedx-container{
  font-family: var(--rdx-font);
  color: var(--rdx-on-surface);
}

/* ---------------- GLOBAL HEADER ---------------- */
.racedx-global-header{
  margin: 10px auto 8px;
  max-width: 1200px;
  padding: 0 8px;
}

/* ---------------- GLOBAL SEARCH ---------------- */
.racedx-global-search .racedx-search{
  width: 100%;
}

.racedx-global-search input{
  width: 100%;
  background: var(--rdx-surface-container-high);
  border: 1px solid var(--rdx-outline);
  border-radius: var(--rdx-radius-pill);
  padding: 12px 14px;
  font-size: 1.02rem;
  outline: none;
  transition: box-shadow .15s ease, border-color .15s ease, background .15s ease;
}

.racedx-global-search input:focus{
  background: var(--rdx-surface-container);
  border-color: color-mix(in srgb, var(--rdx-primary) 70%, var(--rdx-outline));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--rdx-primary) 20%, transparent);
}

/* ---------------- RACE TOOLBAR (CHIPS, WRAP) ---------------- */
.racedx-race-toolbar{
  display: flex;
  flex-wrap: wrap;              /* ✅ несколько строк */
  justify-content: center;
  gap: 8px;
  padding: 10px 2px 2px;
  max-width: 1200px;
  margin: 0 auto;
}

.racedx-chip{
  border: 1px solid var(--rdx-outline);
  background: var(--rdx-surface-container);
  color: var(--rdx-on-surface);
  border-radius: var(--rdx-radius-pill);
  padding: 8px 12px;
  font-size: .95rem;
  font-weight: 700;
  letter-spacing: .2px;
  cursor: pointer;
  white-space: nowrap;
  box-shadow: none;
  transition: transform .12s ease, background .12s ease, border-color .12s ease, box-shadow .12s ease;
}

.racedx-chip:hover{
  transform: translateY(-1px);
  box-shadow: var(--rdx-shadow-1);
  border-color: color-mix(in srgb, var(--rdx-primary) 35%, var(--rdx-outline));
}

.racedx-chip.is-active{
  background: color-mix(in srgb, var(--rdx-primary) 12%, var(--rdx-surface-container));
  border-color: color-mix(in srgb, var(--rdx-primary) 55%, var(--rdx-outline));
  box-shadow: var(--rdx-shadow-1);
}

/* ---------------- TITLES (single-view tabs mode) ---------------- */
.racedx-group-title{
  text-align: center;
  margin: 22px auto 8px;
  font-size: 1.55rem;
  font-weight: 800;
  color: var(--rdx-on-surface);
  max-width: 1200px;
  padding: 0 8px;
}

.racedx-distance-title{
  position: relative;
  user-select: none;

  max-width: 760px;
  margin: 8px auto 8px;
  padding: 10px 56px 10px 14px;

  border: 1px solid var(--rdx-outline);
  border-radius: var(--rdx-radius-pill);
  background: var(--rdx-surface-container);
  box-shadow: var(--rdx-shadow-1);

  font-size: 1.18rem;
  font-weight: 700;
  text-align: center;
  color: var(--rdx-on-surface);
}

.racedx-distance-toggle{
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);

  font-size: .8rem;
  font-weight: 700;
  color: var(--rdx-primary);
  border: 1px solid color-mix(in srgb, var(--rdx-primary) 60%, var(--rdx-outline));
  padding: 2px 10px;
  border-radius: var(--rdx-radius-pill);
  pointer-events: none;
  background: transparent;
}

/* ---------------- LOCAL TOOLBAR INSIDE VIEW ---------------- */
.racedx-container{
  max-width: 1200px;
  margin: 0 auto 14px;
  padding: 0 8px 4px;
}

.racedx-toolbar{
  display: flex;
  flex-wrap: wrap;
  gap: 10px 12px;
  align-items: center;
  justify-content: space-between;
  margin: 8px 0 10px;
}

.racedx-filters{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.racedx-filter{
  display: flex;
  gap: 6px;
  align-items: center;
}

.racedx-filter-label{
  font-size: .92rem;
  font-weight: 600;
  color: var(--rdx-on-surface-variant);
}

.racedx-filter select{
  background: var(--rdx-surface-container-high);
  border: 1px solid var(--rdx-outline);
  border-radius: var(--rdx-radius-pill);
  padding: 6px 10px;
  min-width: 120px;
  font-size: .92rem;
  outline: none;
}

.racedx-filter select:focus{
  border-color: color-mix(in srgb, var(--rdx-primary) 70%, var(--rdx-outline));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--rdx-primary) 18%, transparent);
  background: var(--rdx-surface-container);
}

.racedx-search input{
  background: var(--rdx-surface-container-high);
  border: 1px solid var(--rdx-outline);
  border-radius: var(--rdx-radius-pill);
  padding: 8px 12px;
  font-size: .95rem;
  width: 240px;
  outline: none;
}

/* ---------------- TABLE (DESKTOP) ---------------- */
.racedx-table-wrapper{
  background: var(--rdx-surface-container);
  border: 1px solid var(--rdx-outline);
  border-radius: var(--rdx-radius-xl);
  overflow-x: auto;
  box-shadow: var(--rdx-shadow-1);
}

.racedx-table{
  width: 100%;
  border-collapse: collapse;
  font-size: .95rem;
  min-width: 640px;
}

.racedx-table th,
.racedx-table td{
  padding: 10px 12px;
  text-align: center;
  border-bottom: 1px solid var(--rdx-outline);
  white-space: nowrap;
}

.racedx-table th{
  position: sticky;
  top: 0;
  background: var(--rdx-surface-container-high);
  font-weight: 700;
  color: var(--rdx-on-surface-variant);
  z-index: 1;
}

.racedx-table tr:hover td{
  background: color-mix(in srgb, var(--rdx-primary) 6%, var(--rdx-surface-container));
}

/* ---------------- MOBILE CARDS ---------------- */
.racedx-mobile-list{
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.racedx-card{
  border: 1px solid var(--rdx-outline);
  border-radius: var(--rdx-radius-lg);
  background: var(--rdx-surface-container);
  box-shadow: var(--rdx-shadow-1);
  padding: 10px;
}

.racedx-card-header{
  display: grid;
  grid-template-columns: 56px 76px 1fr auto;
  gap: 8px;
  align-items: center;
  cursor: pointer;
}

.racedx-place{ font-weight: 700; }
.racedx-bib{ color: var(--rdx-primary); font-weight: 800; }
.racedx-name{ font-weight: 700; }
.racedx-time{ font-weight: 700; text-align: right; }

.racedx-card-body{
  display: none;
  border-top: 1px dashed var(--rdx-outline);
  margin-top: 8px;
  padding-top: 8px;
  font-size: .95rem;
  color: var(--rdx-on-surface-variant);
}

.racedx-card.open .racedx-card-body{ display: block; }

/* ---------------- FOOTER + BUTTON ---------------- */
.racedx-footer{
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  margin-top: 10px;
}

.racedx-count{
  font-size: .9rem;
  color: var(--rdx-on-surface-variant);
}

.racedx-toggle-btn{
  border: none;
  background: var(--rdx-primary);
  color: var(--rdx-on-primary);
  border-radius: var(--rdx-radius-pill);
  padding: 8px 14px;
  font-size: .95rem;
  font-weight: 700;
  cursor: pointer;
  box-shadow: var(--rdx-shadow-1);
  transition: transform .12s ease, box-shadow .12s ease, opacity .12s ease;
}

.racedx-toggle-btn:hover{
  transform: translateY(-1px);
  box-shadow: var(--rdx-shadow-2);
  opacity: .95;
}

/* ---------------- VISIBILITY ---------------- */
.racedx-hidden{ display: none !important; }

/* ---------- Layout by orientation ---------- */

/* 1) Портрет — всегда мобилка */
@media (orientation: portrait){
  .racedx-table-wrapper{ display:none !important; }
  .racedx-mobile-list{ display:flex !important; }
}

/* 2) Ландшафт + достаточно широкий экран — ПК таблица */
@media (orientation: landscape) and (min-width: 769px){
  .racedx-table-wrapper{ display:block !important; }
  .racedx-mobile-list{ display:none !important; }
}

/* 3) Ландшафт, но узкий экран (телефон повернули) — оставляем мобилку */
@media (orientation: landscape) and (max-width: 768px){
  .racedx-table-wrapper{ display:none !important; }
  .racedx-mobile-list{ display:flex !important; }
}


/* скрываем метку "Свернуть/Показать" в заголовке */
.racedx-distance-toggle{
  display: none !important;
}

/* убираем лишний отступ справа, который был под метку */
.racedx-distance-title{
  padding-right: 14px !important;
}





/* ---------- Mobile dropdown instead of chips ---------- */

.racedx-race-toolbar-wrap{
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* селект — материал 3 */
.racedx-race-select-wrap{
  display: none;           /* как было */
  justify-content: center;
  position: relative;      /* ✅ нужно для стрелки */
  width: 100%;
}

.racedx-race-select{
  width: 100%;
  max-width: 520px;
  background: var(--rdx-surface-container);
  border: 1px solid var(--rdx-outline);
  border-radius: var(--rdx-radius-pill);
  padding: 10px 44px 10px 14px;  /* ✅ справа место под стрелку */
  font-size: 1rem;
  font-weight: 700;
  color: var(--rdx-on-surface);
  box-shadow: var(--rdx-shadow-1);
  outline: none;

  appearance: none;        /* ✅ убираем нативную стрелку где можно */
  -webkit-appearance: none;
  -moz-appearance: none;
}

.racedx-race-select:focus{
  border-color: color-mix(in srgb, var(--rdx-primary) 70%, var(--rdx-outline));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--rdx-primary) 18%, transparent);
}

/* ✅ наша стрелочка */
.racedx-race-select-wrap::after{
  content: "▾";
  position: absolute;
  right: 18px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1.1rem;
  color: var(--rdx-on-surface-variant);
  pointer-events: none;    /* чтобы клик шёл в select */
}
/* ✅ Мобилка в портрете: показываем select, скрываем chips */
@media (max-width:768px) and (orientation: portrait){
  .racedx-race-toolbar{ display: none !important; }
  .racedx-race-select-wrap{ display: flex !important; }
}



/* ---------- Highlight chips with matches (Material Orange) ---------- */

/* материал-оранжевый акцент */
:root{
  --rdx-orange: #FB8C00;        /* Material Orange 600 */
  --rdx-orange-soft: #FFF3E0;   /* Material Orange 50 */
  --rdx-on-orange: #ffffff;
}

.racedx-chip.has-matches{
  border-color: var(--rdx-orange) !important;
  background: var(--rdx-orange-soft) !important;
  box-shadow: var(--rdx-shadow-1);
  position: relative;
  color: var(--rdx-on-surface);
}

/* бейдж с количеством совпадений */
.racedx-chip.has-matches::after{
  content: attr(data-matches);
  position: absolute;
  top: -6px;
  right: -6px;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 9999px;
  background: var(--rdx-orange);
  color: var(--rdx-on-orange);
  font-size: .72rem;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--rdx-shadow-1);
}

/* скрываем заголовок дистанции "Результаты/Results" */
.racedx-distance-generic{
  display: none !important;
}


/* ---------- Auto refresh toggle ---------- */
.racedx-refresh-control{
  display: flex;
  align-items: center;
  gap: 6px;
  margin-left: auto;
  font-size: .85rem;
  color: var(--rdx-on-surface-variant);
  white-space: nowrap;
}

.racedx-refresh-label{
  opacity: .8;
}

.racedx-refresh-toggle{
  border-radius: var(--rdx-radius-pill);
  border: 1px solid var(--rdx-outline);
  background: var(--rdx-surface-container-high);
  color: var(--rdx-on-surface); /* 🔹 тёмный текст на светлом фоне */
  padding: 6px 12px;
  font-size: .82rem;
  cursor: pointer;
  transition: background .15s ease, color .15s ease,
              border-color .15s ease, box-shadow .15s ease;
}

.racedx-refresh-toggle.is-on{
  background: var(--rdx-primary);
  border-color: var(--rdx-primary);
  color: var(--rdx-on-primary);
  box-shadow: var(--rdx-shadow-2);
}


/* Не менять цвет текста при наведении на активную вкладку */
.racedx-chip.is-active,
.racedx-chip.is-active:hover{
  background: color-mix(in srgb, var(--rdx-primary) 12%, var(--rdx-surface-container));
  border-color: color-mix(in srgb, var(--rdx-primary) 55%, var(--rdx-outline));
  box-shadow: var(--rdx-shadow-1);
  color: var(--rdx-on-surface); /* всегда тёмный текст */
  cursor: default;
}


/* ---------- Yellow card (warning) ---------- */
.racedx-yellow-card{
  display: inline-block;
  width: 14px;
  height: 14px;
  margin-left: 10px;
  border-radius: 4px;
  background: #f4d06f;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.10);
  vertical-align: -2px; /* чтобы не "провисало" вместе с ФИО */
}

.racedx-yellow-card-count{
  display: inline-block;
  margin-left: 4px;
  font-size: .92em;
  font-weight: 800;
  color: var(--rdx-on-surface-variant);
  vertical-align: -1px;
}

.racedx-warning{
  color: var(--rdx-on-surface);
}

