/* past_picks.css — version clean, lisible, carrée
   Objectif: garder ton thème (variables global.css/layout.css),
   mais rendre la page ultra ordonnée + code couleur KO/OK. */

/* ---------------- Tokens / cohérence ---------------- */
:root{
  --pp-radius: 14px;
  --pp-brd: rgba(0,0,0,0.08);
  --pp-brd-2: rgba(0,0,0,0.06);
  --pp-bg: var(--background-light);
  --pp-shadow: var(--shadow-md);

  --pp-ok: rgba(40,167,69,1);
  --pp-ok-bg: rgba(40,167,69,0.08);
  --pp-ko: rgba(220,53,69,1);
  --pp-ko-bg: rgba(220,53,69,0.08);
}

/* ---------------- Layout général ---------------- */
.main-content .container{
  max-width: var(--pp-max);
}

.section + .section{
  margin-top: 18px;
}

/* Titres : un poil plus "carré" */
.section-title{
  letter-spacing: -0.01em;
}

/* ---------------- Callout ---------------- */
.info-callout{
  max-width: var(--pp-max);
  margin: 0 auto 14px;
  padding: 12px 14px;
  border-radius: var(--pp-radius);
  border: 1px solid var(--pp-brd);
  background: rgba(29,78,216,0.06);
  color: var(--text-color-dark);
  line-height: 1.4;
}

/* ---------------- Panel "Type de pick" ---------------- */
.picks-panel{
  margin: 14px auto 16px;
  padding: 14px 16px;
  max-width: var(--pp-max);
  background: var(--pp-bg);
  border: 1px solid var(--pp-brd-2);
  border-radius: var(--pp-radius);
  box-shadow: var(--pp-shadow);
}

.picks-panel__label{
  font-weight: 950;
  color: var(--primary-color);
  margin-bottom: 10px;
}

/* Tabs */
.pick-tabs{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}

.pick-tab{
  appearance: none;
  border: 1px solid rgba(0,0,0,0.12);
  background: #fff;
  color: var(--primary-color);
  font-weight: 950;
  border-radius: 9999px;
  padding: 10px 14px;
  cursor: pointer;
  transition: background 0.15s ease, border-color 0.15s ease, transform 0.06s ease;
  box-shadow: 0 6px 14px rgba(0,0,0,0.05);
}

.pick-tab:hover{
  background: rgba(29,78,216,0.06);
  border-color: rgba(29,78,216,0.22);
}
.pick-tab:active{ transform: scale(0.99); }

.pick-tab.is-active{
  background: rgba(29,78,216,0.11);
  border-color: rgba(29,78,216,0.32);
}

/* ---------------- Filtres ---------------- */
.filters-row{
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 16px;
  align-items: end;
  max-width: var(--pp-max);
  margin: 0 auto;
}

@media (max-width: 900px){
  .filters-row{ grid-template-columns: 1fr; }
}

.slider-container label{
  display: block;
  font-weight: 950;
  color: var(--primary-color);
  margin: 0 0 6px;
}

.slider-row{
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

#probability-slider{
  width: 100%;
  accent-color: var(--primary-color);
}

/* Badge valeur slider (actuel dans ton HTML: .slider-value-badge) */
.slider-value-badge{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 66px;
  padding: 8px 12px;
  border-radius: 9999px;
  font-weight: 950;
  color: #fff;
  background: var(--primary-color);
  box-shadow: 0 8px 18px rgba(0,0,0,0.10);
}

/* Ton bouton existe déjà (btn-secondary) -> on l’aligne propre */
#reset-default.btn-secondary{
  margin-left: auto;
}

/* Select ligue : lisible, propre */
#league-select{
  width: 100%;
  height: 44px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,0.12);
  background: #fff;
  padding: 0 12px;
  font-weight: 900;
  color: var(--text-color-dark);
}

#league-select:focus{
  outline: 3px solid rgba(29,78,216,0.18);
  outline-offset: 2px;
}

.stat-help{
  margin: 8px 0 0;
  font-size: 0.94rem;
  color: var(--muted);
  line-height: 1.4;
}

/* ---------------- Stats (tu utilises .stat-box via past_results.css) ---------------- */
/* Optionnel : léger alignement si besoin */
.performance-section{
  gap: 12px;
}

/* ---------------- Chart ---------------- */
.chart-card{
  max-width: var(--pp-max);
  margin: 0 auto;
  padding: 16px;
  background: var(--pp-bg);
  border: 1px solid var(--pp-brd-2);
  border-radius: var(--pp-radius);
  box-shadow: var(--pp-shadow);
}

.chart-title{
  margin: 0 0 10px;
  font-size: 1.1rem;
  font-weight: 1000;
  color: var(--primary-color);
}

.chart-wrap{
  position: relative;
  height: 320px;
}
@media (max-width: 600px){
  .chart-wrap{ height: 280px; }
}

.chart-wrap canvas{
  width: 100% !important;
  height: 100% !important;
  display: block;
}

.chart-help{
  margin-top: 10px;
  color: var(--muted);
  font-size: 0.95rem;
}

/* ---------------- Table head + actions ---------------- */
.table-head{
  max-width: var(--pp-max);
  margin: 0 auto 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.table-actions{
  display: flex;
  align-items: center;
  gap: 10px;
}

/* ---------------- Table card ---------------- */
.table-wrap{
  max-width: var(--pp-max);
  margin: 0 auto;
  overflow-x: auto;
  border-radius: var(--pp-radius);
  border: 1px solid var(--pp-brd-2);
  background: var(--pp-bg);
  box-shadow: var(--pp-shadow);
}

/* Table */
.results-table{
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  min-width: 920px; /* desktop stable, scroll mobile */
}

.results-table th,
.results-table td{
  padding: 12px 12px;
  border-bottom: 1px solid rgba(0,0,0,0.06);
  text-align: left;
  vertical-align: middle;
  white-space: nowrap;
}

/* Colonne match: autorise retour ligne */
.results-table td:nth-child(3){
  white-space: normal;
  min-width: 280px;
}

/* Header sticky clean */
.results-table thead th{
  position: sticky;
  top: 0;
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(8px);
  font-weight: 1000;
  color: var(--primary-color);
  z-index: 1;
}

/* Zebra + hover */
.results-table tbody tr:nth-child(even){
  background: rgba(0,0,0,0.02);
}
.results-table tbody tr:hover{
  background: rgba(29,78,216,0.05);
}

/* ---------------- Code couleur OK/KO sur la ligne ---------------- */
/* Liseré vertical discret à gauche + fond léger */
.results-table tbody tr.row-ok{
  box-shadow: inset 4px 0 0 rgba(40,167,69,0.75);
  background: linear-gradient(90deg, var(--pp-ok-bg), rgba(0,0,0,0) 45%);
}
.results-table tbody tr.row-ko{
  box-shadow: inset 4px 0 0 rgba(220,53,69,0.75);
  background: linear-gradient(90deg, var(--pp-ko-bg), rgba(0,0,0,0) 45%);
}

/* Hover : on garde le code couleur perceptible */
.results-table tbody tr.row-ok:hover{
  background: linear-gradient(90deg, rgba(40,167,69,0.12), rgba(29,78,216,0.05) 60%);
}
.results-table tbody tr.row-ko:hover{
  background: linear-gradient(90deg, rgba(220,53,69,0.12), rgba(29,78,216,0.05) 60%);
}

/* ---------------- Pills ---------------- */
.pill{
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 9999px;
  border: 1px solid rgba(0,0,0,0.12);
  font-weight: 950;
  background: #fff;
}

.pill.ok{
  border-color: rgba(40,167,69,0.28);
  background: rgba(40,167,69,0.10);
  color: rgba(25,120,55,1);
}

.pill.ko{
  border-color: rgba(220,53,69,0.28);
  background: rgba(220,53,69,0.10);
  color: rgba(160,30,45,1);
}

/* Résultat cell: score + badge compact */
.result-cell{
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.result-score{
  font-weight: 950;
  color: var(--text-color-dark);
}

/* Loading */
.loading-indicator{
  max-width: var(--pp-max);
  margin: 10px auto;
  padding: 10px 14px;
  border-radius: 12px;
  border: 1px dashed rgba(0,0,0,0.18);
  color: var(--muted);
  background: rgba(255,255,255,0.6);
}
/* ================================
   Centrage global des sections
   ================================ */

.section,
.global-performance-section,
.picks-panel,
.chart-card,
.table-head,
.table-wrap,
.info-callout,
.loading-indicator {
  max-width: var(--content-max-width);
  margin-left: auto;
  margin-right: auto;
}

/* =========================
   Mobile: table -> cards
   (inspiré UX past_results)
   ========================= */
@media (max-width: 720px){

  /* plus de scroll horizontal */
  .table-wrap{
    overflow-x: visible;
    max-width: 100%;
  }

  /* la table n'impose plus de largeur */
  .results-table{
    min-width: 0 !important;
    width: 100%;
  }

  /* on masque l'entête */
  .results-table thead{
    display: none;
  }

  /* on “décompose” la table en blocs */
  .results-table,
  .results-table tbody,
  .results-table tr,
  .results-table td{
    display: block;
    width: 100%;
  }

  /* chaque ligne devient une carte */
  .results-table tr{
    border-bottom: 1px solid rgba(0,0,0,0.06);
    padding: 8px 0;
  }

  /* layout label/value */
  .results-table td{
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
    padding: 10px 12px;
    white-space: normal; /* crucial */
  }

  /* label à gauche */
  .results-table td::before{
    content: attr(data-label);
    flex: 0 0 92px;
    font-weight: 950;
    color: var(--muted);
    line-height: 1.2;
  }

  /* valeur à droite */
  .results-table td{
    line-height: 1.25;
  }

  /* Match: autorise wrap propre */
  .results-table td:nth-child(3){
    white-space: normal !important;
  }

  /* Pills plus compactes */
  .pill{
    padding: 5px 9px;
    font-weight: 950;
  }

  /* Résultat: score + badge aligné */
  .result-cell{
    justify-content: flex-end;
    width: 100%;
  }
}

.table-wrap{
  -webkit-overflow-scrolling: touch;
}

/* =========================
   Cards view (copie past_results)
   ========================= */

:root{
  --correct-color: #28a745;
  --wrong-color: #dc3545;
  --neutral-color: #ffc107;
}

[data-theme="dark"]{
  --correct-color: #28a745;
  --wrong-color: #dc3545;
  --neutral-color: #ffc107;
}

.results-column{
  max-width: 1000px;
  margin: 24px auto 34px;
  padding: 14px;
  background-color: var(--background-light);
  border-radius: 12px;
  box-shadow: var(--shadow-md);
}

/* card */
.result-box{
  padding: 12px;
  border-radius: 10px;
  margin-bottom: 14px;
  background-color: var(--background-light);
  box-shadow: var(--shadow-sm);
  border-left: 5px solid var(--correct-color); /* OK par défaut */
  cursor: default;
  transition: transform 0.12s ease, box-shadow 0.2s ease;
}

.result-box.wrong-result{
  border-left-color: var(--wrong-color);
}

.result-box.neutral-result{
  border-left-color: var(--neutral-color);
}

.result-box:hover{
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.result-info-header{
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.result-topline{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.result-topline .meta{
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  color: var(--text-color-dark);
  font-size: 13px;
}

.meta .league{
  font-weight: 900;
  color: var(--primary-color);
}

.meta .date{
  font-style: italic;
  opacity: 0.9;
}

.match-title{
  font-weight: 1000;
  color: var(--text-color-dark);
  font-size: 16px;
  line-height: 1.25;
}

.result-row{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.badge{
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 999px;
  font-weight: 1000;
  font-size: 12px;
  border: 1px solid rgba(0,0,0,0.12);
  background: rgba(0,0,0,0.03);
}

.badge.ok{
  color: rgba(25,120,55,1);
  border-color: rgba(40,167,69,0.28);
  background: rgba(40,167,69,0.12);
}

.badge.ko{
  color: rgba(160,30,45,1);
  border-color: rgba(220,53,69,0.28);
  background: rgba(220,53,69,0.12);
}

.badge.na{
  color: rgba(140,110,10,1);
  border-color: rgba(255,193,7,0.30);
  background: rgba(255,193,7,0.14);
}

/* progress bar (proba) */
.progress-bar-container{
  margin-top: 8px;
}

.progress-bar{
  height: 12px;
  border-radius: 6px;
  background: rgba(0,0,0,0.07);
  overflow: hidden;
}

.progress{
  height: 100%;
  width: 0%;
  background-color: rgba(45,107,199,0.70);
  border-radius: 6px;
  transition: width 0.35s ease;
}

.progress-label{
  margin-top: 6px;
  font-size: 12px;
  color: var(--muted);
  display: flex;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

/* bouton charger plus */
/* .load-more-button{
  display: block;
  margin: 18px auto 0;
  background-color: rgba(45,107,199,0.70);
  color: #ffffff;
  border: none;
  border-radius: 8px;
  padding: 12px 18px;
  font-size: 15px;
  font-weight: 900;
  cursor: pointer;
  transition: opacity 0.2s ease, transform 0.06s ease;
}

.load-more-button:hover{ opacity: 0.92; }
.load-more-button:active{ transform: scale(0.99); } */

/* Mobile: aucun débordement, tout wrap */
@media (max-width: 720px){
  .results-column{
    margin: 16px 10px 26px;
    padding: 12px;
  }
  .match-title{ font-size: 15px; }
}

/* =========================
   KPI / Stat blocks
   ========================= */

.global-performance-section{
  max-width: 1040px;
  margin: 28px auto;
}

.performance-stats{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 16px;
}

@media (max-width: 720px){
  .performance-stats{
    grid-template-columns: 1fr;
  }
}

/* Carte KPI */
.stat-box{
  background: var(--background-light);
  border-radius: 14px;
  padding: 16px 18px;
  box-shadow: var(--shadow-md);
  border-left: 5px solid var(--primary-color);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 6px;
}

/* Label (texte descriptif) */
.stat-label{
  font-size: 13px;
  font-weight: 900;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* Valeur principale */
.stat-value{
  font-size: 32px;
  font-weight: 1000;
  color: var(--primary-color);
  line-height: 1.1;
}

/* Variantes couleur */
.stat-box.success{
  border-left-color: #28a745;
}
.stat-box.success .stat-value{
  color: #28a745;
}

.stat-box.info{
  border-left-color: var(--primary-color);
}

.stat-box.warning{
  border-left-color: #ffc107;
}
.stat-box.warning .stat-value{
  color: #b58900;
}

/* =========================
   Bouton secondaire
   ========================= */

.btn-secondary{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  height: 40px;
  padding: 0 14px;

  border-radius: 10px;
  border: 1px solid rgba(0,0,0,0.18);
  background: rgba(255,255,255,0.85);

  font-weight: 900;
  font-size: 14px;
  color: var(--primary-color);

  cursor: pointer;
  white-space: nowrap;

  transition:
    background-color 0.15s ease,
    border-color 0.15s ease,
    box-shadow 0.15s ease,
    transform 0.05s ease;
}

.btn-secondary:hover{
  background: rgba(29,78,216,0.08);
  border-color: rgba(29,78,216,0.35);
  box-shadow: 0 6px 14px rgba(0,0,0,0.08);
}

.btn-secondary:active{
  transform: scale(0.98);
}

.btn-secondary:focus-visible{
  outline: 3px solid rgba(29,78,216,0.25);
  outline-offset: 2px;
}

/* Désactivé */
.btn-secondary:disabled{
  opacity: 0.5;
  cursor: not-allowed;
  box-shadow: none;
}
.slider-container {
    text-align: center;
    max-width: 600px;
    margin: 10px auto;
}
.tp-hero-actions{
  display: flex;
  gap: 12px;
  justify-content: center; /* centrage desktop */
}

/* Mobile */
@media (max-width: 640px){
  .tp-hero-actions{
    flex-direction: column;
    align-items: stretch; /* boutons pleine largeur */
  }

  .tp-hero-actions .cta-button{
    width: 100%;
    text-align: center;
  }
}
