/* cmsms stylesheet: TT Club modified: vendredi 10 avril 2026 12:14:38 */
/* ================================================================
   ASTT CLUB TT — style.css | Bootstrap 5 + FontAwesome 6
   ================================================================ */
:root {
  --tt-primary: #0d6efd;
  --tt-accent: #f0b429;
  --tt-dark: #0d1b4b;
  --tt-hero-gradient: linear-gradient(135deg, #0d1b4b 0%, #1565c0 60%, #0d6efd 100%);
  --tt-card-radius: 14px;
  --tt-shadow: 0 6px 24px rgba(13,110,253,.12);
  --tt-transition: all .28s cubic-bezier(.4,0,.2,1);
}

/* Typographie */
body { font-family:'Open Sans',sans-serif; background:#f7f8fc; }
h1,h2,h3,h4,h5,h6,.club-name,.hero-title { font-family:'Rajdhani',sans-serif; font-weight:700; }
a { text-decoration:none; transition:var(--tt-transition); }

/* Topbar */
.topbar { background:#0d1b4b !important; border-bottom:2px solid var(--tt-primary); font-size:.82rem; }
.topbar-social { width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;font-size:.76rem; }
.topbar-social:hover { background:var(--tt-primary);transform:translateY(-2px); }

/* Navbar */
#mainNav { background:linear-gradient(90deg,#0d1b4b,var(--tt-primary)) !important; border-bottom:3px solid var(--tt-accent); }
.logo-img { transition:var(--tt-transition); }
.navbar-brand:hover .logo-img { transform:rotate(10deg) scale(1.08); }
.navbar-nav .nav-link { font-family:'Rajdhani',sans-serif;font-weight:600;font-size:1rem;border-radius:8px;position:relative;transition:var(--tt-transition); }
.navbar-nav .nav-link::after { content:'';position:absolute;bottom:2px;left:50%;right:50%;height:2px;background:var(--tt-accent);transition:var(--tt-transition);border-radius:2px; }
.navbar-nav .nav-link:hover::after,.navbar-nav .nav-link.active::after { left:12px;right:12px; }
.navbar-nav .nav-link:hover,.navbar-nav .nav-link.active { background:rgba(255,255,255,.08);color:var(--tt-accent) !important; }

/* Dropdown */
.dropdown-menu-dark { background:#0d1b4b !important;border:1px solid rgba(255,255,255,.1) !important;border-radius:10px !important;min-width:240px; }
.dropdown-menu-dark .dropdown-item { font-size:.9rem;padding:.4rem 1rem;border-radius:6px;margin:1px 6px;width:calc(100% - 12px);transition:var(--tt-transition); }
.dropdown-menu-dark .dropdown-item:hover { background:rgba(13,110,253,.3);color:#fff !important;transform:translateX(4px); }
.dropdown-menu-dark .dropdown-header { font-size:.7rem;letter-spacing:.8px;text-transform:uppercase;color:var(--tt-accent) !important; }

/* Breadcrumb */
.breadcrumb-nav {
    background: #f8f9fa;
    border-bottom: 1px solid #e9ecef;
    padding: .6rem 0;
    font-size: .82rem;
}
.breadcrumb-nav a {
    color: #0d6efd;
    text-decoration: none;
}
.breadcrumb-nav a:hover {
    text-decoration: underline;
}

/* Live badge */
.live-badge,.live-dot { animation:pulse-live 1.5s infinite; }
.live-dot { width:10px;height:10px;border-radius:50%;background:#dc3545;display:inline-block; }
@keyframes pulse-live { 0%,100%{opacity:1}50%{opacity:.4} }

/* Hero */
.hero-section { background:var(--tt-hero-gradient);min-height:540px;position:relative;overflow:hidden;display:flex;align-items:center; }
.hero-ball { position:absolute;right:5%;top:50%;transform:translateY(-50%);font-size:14rem;color:rgba(255,255,255,.04);animation:float 6s ease-in-out infinite; }
@keyframes float { 0%,100%{transform:translateY(-50%) rotate(0deg)}50%{transform:translateY(-55%) rotate(15deg)} }
.hero-title { font-size:clamp(2.2rem,5vw,3.8rem);color:white;line-height:1.1; }
.hero-subtitle { font-size:1.15rem;color:rgba(255,255,255,.8); }
.hero-badge { background:var(--tt-accent);color:#111;font-weight:700;font-family:'Rajdhani'; }

/* Sections */
.section-title { position:relative;padding-bottom:.6rem;margin-bottom:1.5rem; }
.section-title::after { content:'';position:absolute;bottom:0;left:0;width:48px;height:3px;background:var(--tt-primary);border-radius:2px; }
.section-title.text-center::after { left:50%;transform:translateX(-50%); }

/* Cards */
.card { border-radius:var(--tt-card-radius) !important;border:none !important;box-shadow:var(--tt-shadow);transition:var(--tt-transition); }
.card:hover { transform:translateY(-4px);box-shadow:0 14px 38px rgba(13,110,253,.18); }

/* Résultats */
.match-row { border-left:3px solid transparent;transition:var(--tt-transition); }
.match-row:hover { background:rgba(13,110,253,.04);border-left-color:var(--tt-primary); }
.match-row.win  { border-left-color:#198754; }
.match-row.loss { border-left-color:#dc3545; }
.standings-table tr.my-team { background:rgba(13,110,253,.07);font-weight:600; }
.standings-table tr.my-team td:first-child { border-left:3px solid var(--tt-primary); }

/* Statistiques */
.stat-number { font-family:'Rajdhani';font-size:2rem;font-weight:700;color:var(--tt-primary);line-height:1; }
.stat-label { font-size:.72rem;color:#888;text-transform:uppercase;letter-spacing:.5px; }
.player-avatar { width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--tt-primary),#0d1b4b);display:flex;align-items:center;justify-content:center;color:white;font-size:1.3rem;flex-shrink:0; }

/* News badges */
.news-badge { font-size:.68rem;padding:.2rem .6rem;border-radius:20px;font-weight:600; }
.news-badge.club   { background:#e3f0ff;color:#0d6efd; }
.news-badge.fftt   { background:#fff3cd;color:#856404; }
.news-badge.ligue  { background:#d1e7dd;color:#0f5132; }
.news-badge.comite { background:#f8d7da;color:#842029; }

/* Newsletter */
.newsletter-section { background:linear-gradient(135deg,#0d1b4b,#1565c0);border-radius:20px;position:relative;overflow:hidden; }

/* Tarifs */
.tarif-price { font-family:'Rajdhani';font-size:2.8rem;font-weight:700;color:var(--tt-primary);line-height:1; }
.tarif-card.featured { border-top:4px solid var(--tt-accent) !important;position:relative; }

/* Organigramme */
.org-avatar { width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--tt-primary),#0d1b4b);display:flex;align-items:center;justify-content:center;color:white;font-size:1.8rem;margin:0 auto 1rem; }
.org-role { font-size:.72rem;text-transform:uppercase;letter-spacing:.8px;color:var(--tt-primary);font-weight:600; }

/* Boutique */
.product-img { height:200px;object-fit:cover;border-radius:var(--tt-card-radius) var(--tt-card-radius) 0 0; }
.badge-promo { position:absolute;top:12px;right:12px;background:var(--tt-accent);color:#111;font-weight:700; }

/* Compte */
.account-sidebar .list-group-item.active { background:var(--tt-primary);border-color:var(--tt-primary); }
.account-sidebar .list-group-item { border-radius:8px !important;margin-bottom:4px;font-size:.9rem; }

/* Footer */
.footer-links li { margin-bottom:.4rem; }
.footer-links a { color:rgba(255,255,255,.55);font-size:.88rem;transition:var(--tt-transition); }
.footer-links a:hover { color:white;padding-left:5px; }
.social-footer { width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;transition:var(--tt-transition); }
.social-footer:hover { background:var(--tt-primary) !important;border-color:var(--tt-primary) !important;color:white !important;transform:translateY(-3px); }

/* Anti-spam */
.hp-field { display:none !important;visibility:hidden;position:absolute; }

/* Scroll top */
.btn-scroll-top { position:fixed;bottom:24px;right:24px;z-index:9999;width:44px;height:44px;border-radius:50%;display:none;align-items:center;justify-content:center;padding:0; }
.btn-scroll-top.show { display:flex; }

/* Responsive */
@media(max-width:767px){
  .hero-section { min-height:380px;padding:2rem 0; }
  .hero-title { font-size:2rem; }
  .hero-ball { font-size:7rem;opacity:.25; }
}
@media print { .topbar,.navbar,footer,.btn-scroll-top { display:none !important; } }

/* ================================================================
   PAGE ÉQUIPE – styles complémentaires
   ================================================================ */

/* Hero équipe */
.team-hero { background:linear-gradient(135deg,#f0f4ff 0%,#e8f0fe 100%);border-bottom:3px solid var(--tt-primary); }
.team-title { font-size:clamp(1.8rem,4vw,2.8rem);color:#1a1a2e; }

/* Stats hero */
.team-stat-box { border-radius:10px; }
.team-stat-num { font-family:'Rajdhani',sans-serif;font-size:1.5rem;font-weight:700;line-height:1.1; }
.team-stat-lbl { font-size:.62rem;opacity:.85;text-transform:uppercase;letter-spacing:.5px; }

/* Prochain match card */
.next-match-card { border-radius:14px;overflow:hidden; }
.team-logo-placeholder { width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid #dee2e6;background:#f8f9fa; }
.team-logo-placeholder.home { border-color:var(--tt-primary);background:#e8f0fe; }
.team-logo-placeholder.away { border-color:#dc3545;background:#fde8e8; }
.vs-badge { background:var(--tt-dark);color:white;font-family:'Rajdhani',sans-serif;font-size:1.3rem;font-weight:700;width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto; }
.nowrap { white-space:nowrap; }

/* Onglets équipe */
.nav-tabs-team .nav-link { font-family:'Rajdhani',sans-serif;font-weight:600;font-size:.95rem;color:#666;border-radius:8px 8px 0 0;padding:.6rem 1.1rem;transition:var(--tt-transition); }
.nav-tabs-team .nav-link:hover { background:rgba(13,110,253,.07);color:var(--tt-primary); }
.nav-tabs-team .nav-link.active { color:var(--tt-primary);background:white;border-bottom-color:white; }

/* Classement */
.standings-table-full th { font-size:.82rem;letter-spacing:.3px;white-space:nowrap; }
.standing-row td { vertical-align:middle;font-size:.9rem; }
.standing-row.my-team-row { background:rgba(13,110,253,.06);font-weight:600; }
.standing-row.my-team-row td:first-child { border-left:4px solid var(--tt-primary); }
.standing-row.promotion { background:rgba(25,135,84,.05); }
.standing-row.promotion td:first-child { border-left:4px solid #198754; }
.standing-row.relegation { background:rgba(220,53,69,.05); }
.standing-row.relegation td:first-child { border-left:4px solid #dc3545; }

/* Badges rang */
.rank-badge { display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;font-weight:700;font-size:.85rem;background:#e9ecef;color:#555; }
.rank-badge.rank-1 { background:gold;color:#333; }
.rank-badge.rank-2 { background:#c0c0c0;color:#333; }
.rank-badge.rank-3 { background:#cd7f32;color:white; }
.rank-badge.rank-last { background:rgba(220,53,69,.15);color:#dc3545; }

/* Points badge */
.pts-badge { display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;border-radius:8px;font-weight:700;font-size:1rem;background:var(--tt-primary);color:white;padding:0 6px; }
.pts-badge.our-pts { background:var(--tt-primary);box-shadow:0 0 0 2px var(--tt-accent); }
.pts-badge.pts-danger { background:#dc3545; }

/* Logo mini */
.mini-logo { width:32px;height:32px;border-radius:50%;background:#f0f4ff;border:1px solid #dee2e6;display:flex;align-items:center;justify-content:center;flex-shrink:0; }
.our-team-logo { background:#e8f0fe;border-color:var(--tt-primary); }

/* Forme (5 derniers) */
.form-dot { display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;font-size:.65rem;font-weight:700;color:white;flex-shrink:0; }
.form-dot.win { background:#198754; }
.form-dot.loss { background:#dc3545; }
.form-dot.draw { background:#ffc107;color:#333; }

/* Timeline résultats */
.results-timeline { display:flex;flex-direction:column;gap:1rem; }
.journee-block { border-radius:12px;overflow:hidden;background:white;box-shadow:var(--tt-shadow);transition:var(--tt-transition); }
.journee-block:hover { box-shadow:0 10px 30px rgba(13,110,253,.14); }
.journee-header { display:flex;align-items:center;flex-wrap:wrap;gap:.4rem;padding:.6rem 1rem;background:#f8f9fa;border-bottom:1px solid #e9ecef; }
.match-card-inner { padding:1rem; }
.match-teams { display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem; }
.team { display:flex;align-items:center;gap:.5rem; }
.team.text-end { flex-direction:row-reverse; }
.match-score-zone { display:flex;justify-content:center; }

/* Score box */
.score-box { display:flex;align-items:center;gap:.3rem;padding:.4rem .8rem;border-radius:10px;font-family:'Rajdhani',sans-serif;font-weight:700;font-size:1.5rem;min-width:80px;justify-content:center; }
.win-score { background:#d1e7dd;border:2px solid #198754; }
.loss-score { background:#f8d7da;border:2px solid #dc3545; }
.upcoming-score { background:#f8f9fa;border:2px dashed #adb5bd;flex-direction:column;gap:0; }
.score-home,.score-away { font-size:1.6rem;line-height:1; }
.score-sep { color:#666;font-size:1.2rem; }
.score-time { font-size:.8rem;font-family:'Open Sans',sans-serif;font-weight:400;color:#888;line-height:1.2; }

/* Couleur bordure gauche selon résultat */
.win-card { border-left:4px solid #198754; }
.loss-card { border-left:4px solid #dc3545; }
.upcoming-card { border-left:4px solid #6c757d; }

.match-meta { display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;padding-top:.4rem;border-top:1px solid #f0f0f0;margin-top:.5rem; }

/* Graphique ranking CSS */
.rank-bar-group { flex:1;display:flex;flex-direction:column;align-items:center; }
.rank-bar { width:100%;border-radius:4px 4px 0 0;min-height:4px;transition:var(--tt-transition); }
.rank-bar:hover { filter:brightness(1.15); }

/* Responsive */
@media(max-width:575px){
  .match-teams { grid-template-columns:1fr auto 1fr;gap:.5rem; }
  .score-box { min-width:60px;padding:.3rem .5rem;font-size:1.2rem; }
  .score-home,.score-away { font-size:1.3rem; }
  .team-stat-num { font-size:1.2rem; }
}
/* ================================================================
   PAGE JOUEUR – styles + animations
   ================================================================ */

/* ── Hero ── */
.player-hero {
  background: linear-gradient(135deg, #f0f4ff 0%, #e8f0fe 100%);
  border-bottom: 3px solid var(--tt-primary);
}
.player-name {
  font-size: clamp(2rem, 4vw, 3rem);
  color: #1a1a2e;
}
.player-photo {
  width: 130px; height: 130px;
  border-radius: 50%;
  border: 4px solid var(--tt-primary);
  object-fit: cover;
  box-shadow: 0 8px 32px rgba(13,110,253,.25);
}
.player-photo-fallback {
  width: 130px; height: 130px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--tt-primary), #0d1b4b);
  border: 4px solid var(--tt-primary);
  display: flex; align-items: center; justify-content: center;
}
.player-hero-avatar { position: relative; }
.player-status-badge {
  position: absolute; bottom: 4px; left: 50%;
  transform: translateX(-50%);
  background: white; border: 1px solid #e9ecef;
  border-radius: 20px; padding: 1px 10px;
  font-size: .7rem; font-weight: 600;
  white-space: nowrap; box-shadow: 0 2px 8px rgba(0,0,0,.1);
}

/* Style tags */
.style-tag {
  background: white;
  border: 1px solid #dee2e6;
  border-radius: 20px;
  padding: .3rem .8rem;
  font-size: .82rem;
  font-weight: 500;
  box-shadow: 0 2px 6px rgba(0,0,0,.06);
  transition: var(--tt-transition);
}
.style-tag:hover { border-color: var(--tt-primary); color: var(--tt-primary); }

/* Barre classement */
.classement-progress { border-radius: 8px; background: #e9ecef; }
.classement-bar { border-radius: 8px; }

/* KPI card */
.kpi-card { border-radius: var(--tt-card-radius) !important; overflow: hidden; }
.kpi-box {
  padding: 1.2rem .8rem;
  text-align: center;
  transition: var(--tt-transition);
}
.kpi-box:hover { background: rgba(13,110,253,.04); }
.kpi-number {
  font-family: 'Rajdhani', sans-serif;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1;
  display: inline-block;
}
.kpi-unit {
  font-family: 'Rajdhani', sans-serif;
  font-size: 1.1rem;
  font-weight: 700;
  color: #888;
  display: inline-block;
}
.kpi-label {
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .6px;
  color: #aaa;
  margin-top: .2rem;
}

/* ── Onglets joueur ── */
.nav-tabs-player .nav-link {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 600;
  font-size: .95rem;
  color: #666;
  border-radius: 8px 8px 0 0;
  padding: .6rem 1.2rem;
  transition: var(--tt-transition);
}
.nav-tabs-player .nav-link:hover { background: rgba(13,110,253,.06); color: var(--tt-primary); }
.nav-tabs-player .nav-link.active { color: var(--tt-primary); background: white; border-bottom-color: white; }

/* ── Stat cards animées ── */
.stat-card-animated {
  border: none !important;
  box-shadow: var(--tt-shadow);
  border-radius: var(--tt-card-radius) !important;
  overflow: hidden;
  transition: var(--tt-transition);
}
.stat-card-animated:hover { box-shadow: 0 12px 40px rgba(13,110,253,.16); transform: translateY(-2px); }

/* ── Graphique barres classement ── */
.chart-container {
  display: flex;
  align-items: flex-end;
  gap: .5rem;
  height: 180px;
  padding: .5rem 0;
}
.chart-y-axis {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
  padding: 10px 0;
  font-size: .7rem;
  color: #aaa;
  text-align: right;
  min-width: 38px;
}
.chart-bars-wrapper {
  flex: 1;
  height: 100%;
  position: relative;
  display: flex;
  flex-direction: column;
}
.chart-bars {
  flex: 1;
  display: flex;
  align-items: flex-end;
  gap: 8px;
  padding: 0 4px;
}
.chart-baseline {
  height: 2px;
  background: #dee2e6;
  margin: 0 4px;
  border-radius: 1px;
}
.chart-bar-group {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  cursor: pointer;
}
.chart-bar-inner {
  width: 100%;
  border-radius: 6px 6px 0 0;
  background: var(--tt-primary);
  opacity: .75;
  transition: all .6s cubic-bezier(.4,0,.2,1);
  position: relative;
}
.chart-bar-group.current .chart-bar-inner {
  opacity: 1;
  background: var(--tt-accent);
  box-shadow: 0 4px 12px rgba(240,180,41,.4);
}
.chart-bar-group:hover .chart-bar-inner { opacity: 1; filter: brightness(1.1); }
.chart-bar-tooltip {
  font-size: .65rem;
  color: #888;
  text-align: center;
  white-space: nowrap;
}
.chart-delta {
  font-size: .68rem;
  font-weight: 700;
  padding: 1px 4px;
  border-radius: 4px;
  opacity: 0;
  transition: opacity .3s;
}
.chart-bar-group:hover .chart-delta { opacity: 1; }
.chart-delta.pos { color: #198754; background: #d1e7dd; }
.chart-delta.neg { color: #dc3545; background: #f8d7da; }

/* ── Win/Loss bars ── */
.win-loss-display { display: flex; flex-direction: column; gap: .2rem; }
.wl-row { display: flex; align-items: center; gap: .8rem; }
.wl-label { display: flex; align-items: center; gap: .3rem; min-width: 110px; font-size: .88rem; }
.wl-bar-wrap { flex: 1; height: 14px; background: #e9ecef; border-radius: 7px; overflow: hidden; }
.wl-bar { height: 100%; border-radius: 7px; transition: width 1.2s cubic-bezier(.4,0,.2,1); }
.win-bar  { background: linear-gradient(90deg, #198754, #20c997); }
.loss-bar { background: linear-gradient(90deg, #dc3545, #e74c3c); }
.dom-bar  { background: linear-gradient(90deg, var(--tt-primary), #0dcaf0); }
.ext-bar  { background: linear-gradient(90deg, #ffc107, #fd7e14); }
.wl-count { min-width: 44px; text-align: right; font-size: .88rem; }

/* Mini stats */
.mini-stat-box {
  background: #f8f9fa;
  border-radius: 10px;
  padding: .6rem .3rem;
  transition: var(--tt-transition);
}
.mini-stat-box:hover { background: #e8f0fe; }
.mini-stat-val {
  font-family: 'Rajdhani', sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1;
}
.mini-stat-lbl { font-size: .62rem; color: #aaa; text-transform: uppercase; letter-spacing: .4px; }

/* ── Forme séquence ── */
.form-sequence {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.form-bubble {
  width: 36px; height: 36px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: .85rem;
  color: white;
  cursor: default;
  transition: var(--tt-transition);
  animation: bubblePop .4s cubic-bezier(.34,1.56,.64,1) both;
}
.form-bubble.win-b { background: #198754; }
.form-bubble.loss-b { background: #dc3545; }
.form-bubble:hover { transform: scale(1.15); }
@keyframes bubblePop {
  from { transform: scale(0); opacity: 0; }
  to   { transform: scale(1); opacity: 1; }
}

/* Streak */
.streak-box {
  background: linear-gradient(135deg, #fff5f5, #ffe4e4);
  border: 1px solid #ffc9c9;
  border-radius: 12px;
  padding: .8rem 1rem;
}
.streak-inner { display: flex; align-items: center; gap: .8rem; }
.streak-num {
  font-family: 'Rajdhani', sans-serif;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1;
}
.streak-lbl { font-size: .82rem; color: #888; }

/* Matchs récents mini */
.recent-matches-mini { display: flex; flex-direction: column; gap: .4rem; }
.rmm-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: .4rem .6rem;
  background: #f8f9fa;
  border-radius: 8px;
  font-size: .82rem;
  transition: var(--tt-transition);
}
.rmm-row:hover { background: #e8f0fe; }

/* ── Tableau H2H ── */
.h2h-table th { font-size: .82rem; white-space: nowrap; }
.h2h-row td { font-size: .88rem; }
.h2h-row:hover { background: rgba(13,110,253,.04); }
.h2h-badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: .25rem .55rem;
  border-radius: 6px;
  font-weight: 700;
  font-size: .82rem;
  cursor: default;
  transition: var(--tt-transition);
  position: relative;
}
.h2h-badge:hover { transform: scale(1.08); }
.h2h-badge.win    { background: #d1e7dd; color: #0f5132; }
.h2h-badge.loss   { background: #f8d7da; color: #842029; }
.h2h-badge.pending { background: #e9ecef; color: #6c757d; }
.h2h-score {
  font-size: .68rem;
  font-weight: 400;
  opacity: .75;
  margin-left: 1px;
}

/* ── Tableau matchs ── */
.sticky-top-header th { position: sticky; top: 0; z-index: 1; }
.match-tr { transition: var(--tt-transition); }
.match-tr.win-tr td:first-child  { border-left: 3px solid #198754; }
.match-tr.loss-tr td:first-child { border-left: 3px solid #dc3545; }
.match-tr:hover { background: rgba(13,110,253,.04); }
.result-pill {
  display: inline-flex; align-items: center;
  padding: .3rem .7rem;
  border-radius: 20px;
  font-weight: 700; font-size: .8rem;
}
.win-pill  { background: #d1e7dd; color: #0f5132; }
.loss-pill { background: #f8d7da; color: #842029; }
.pts-change {
  display: inline-block;
  padding: .2rem .5rem;
  border-radius: 6px;
  font-weight: 700;
  font-size: .85rem;
}
.pts-change.positive { background: #d1e7dd; color: #0f5132; }
.pts-change.negative { background: #f8d7da; color: #842029; }

/* ── Stats détaillées ── */
.stats-detail-grid { display: flex; flex-direction: column; gap: .9rem; }
.stat-detail-row { display: flex; align-items: center; gap: .8rem; }
.sdl { display: flex; align-items: center; gap: .5rem; min-width: 180px; font-size: .85rem; }
.sdl i { width: 18px; text-align: center; }
.sd-bar-wrap { flex: 1; height: 12px; background: #e9ecef; border-radius: 6px; overflow: hidden; }
.sd-bar { height: 100%; border-radius: 6px; transition: width 1.4s cubic-bezier(.4,0,.2,1); }
.sd-val { min-width: 44px; text-align: right; font-size: .85rem; }

/* ── Radar Chart ── */
.radar-chart { position: relative; width: 220px; height: 220px; }
.radar-svg { width: 100%; height: 100%; }
.radar-data-poly {
  transform-origin: center;
  animation: radarDraw .8s cubic-bezier(.4,0,.2,1) forwards;
}
@keyframes radarDraw {
  from { opacity: 0; transform: scale(.4); }
  to   { opacity: 1; transform: scale(1); }
}
.radar-labels { position: absolute; inset: 0; }
.rl { position: absolute; font-size: .68rem; text-align: center; line-height: 1.2; color: #555; }
.rl strong { display: block; color: var(--tt-primary); font-size: .82rem; }
.rl-top { top: -12px; left: 50%; transform: translateX(-50%); }
.rl-tr  { top: 18%; right: -18px; }
.rl-br  { bottom: 18%; right: -18px; }
.rl-bot { bottom: -16px; left: 50%; transform: translateX(-50%); }
.rl-bl  { bottom: 18%; left: -18px; }
.rl-tl  { top: 18%; left: -18px; }

/* ── Palmarès timeline ── */
.timeline-palma { display: flex; flex-direction: column; gap: 0; padding: 1rem 1.5rem; }
.palma-item {
  display: flex; align-items: center; gap: 1rem;
  padding: 1rem;
  border-left: 3px solid #dee2e6;
  margin-left: 20px;
  position: relative;
  transition: var(--tt-transition);
}
.palma-item:hover { background: rgba(13,110,253,.03); border-radius: 0 10px 10px 0; }
.palma-icon {
  position: absolute; left: -22px;
  width: 38px; height: 38px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem;
  border: 2px solid white;
  box-shadow: 0 2px 8px rgba(0,0,0,.12);
}
.palma-item.gold   .palma-icon { background: gold; color: #333; }
.palma-item.silver .palma-icon { background: #c0c0c0; color: white; }
.palma-item.bronze .palma-icon { background: #cd7f32; color: white; }
.palma-item.neutral .palma-icon { background: var(--tt-primary); color: white; }
.palma-item.gold   { border-left-color: gold; }
.palma-item.silver { border-left-color: #c0c0c0; }
.palma-item.bronze { border-left-color: #cd7f32; }
.palma-item.neutral { border-left-color: var(--tt-primary); }
.palma-content { flex: 1; }
.palma-year {
  font-family: 'Rajdhani', sans-serif;
  font-size: 1.3rem;
  font-weight: 700;
  color: #ccc;
}

/* ── Bouton xs ── */
.btn-xs { padding: .15rem .45rem; font-size: .75rem; }

/* ── Animated bars (IntersectionObserver) ── */
.animated-bar { transition: width 1.2s cubic-bezier(.4,0,.2,1); }

/* ── Responsive ── */
@media(max-width: 575px) {
  .player-photo, .player-photo-fallback { width: 90px; height: 90px; }
  .kpi-number { font-size: 1.6rem; }
  .radar-chart { width: 170px; height: 170px; }
  .sdl { min-width: 120px; font-size: .78rem; }
  .wl-label { min-width: 80px; font-size: .78rem; }
  .chart-container { height: 130px; }
}
/* ════════════════════════════════════════════
   TOPBAR
════════════════════════════════════════════ */
.topbar {
    background: #0a0f2c;
    border-bottom: 2px solid #0d6efd;
    font-size: .8rem;
    color: rgba(255,255,255,.75);
}
.topbar-social {
    width: 26px; height: 26px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 50%; font-size: .76rem;
    transition: background .2s, transform .2s;
}
.topbar-social:hover { background: #0d6efd; color: #fff !important; transform: translateY(-2px); }
.btn-topbar { font-size: .76rem; padding: 3px 12px; border-radius: 20px; font-weight: 600; }

/* ════════════════════════════════════════════
   NAVBAR
════════════════════════════════════════════ */
#mainNav {
    background: linear-gradient(90deg, #0a0f2c 0%, #1565c0 100%) !important;
    border-bottom: 3px solid #f0b429;
    padding: .45rem 0;
    transition: padding .3s ease, box-shadow .3s ease;
}
#mainNav.shrink { padding: .22rem 0; box-shadow: 0 4px 24px rgba(10,15,44,.4) !important; }

/* Logo */
.logo-wrap { width: 52px; height: 52px; flex-shrink: 0; transition: transform .3s ease; }
.navbar-brand:hover .logo-wrap { transform: rotate(8deg) scale(1.07); }
.logo-img { width:52px; height:52px; border-radius:50%; border:2.5px solid rgba(255,255,255,.85); object-fit:cover; }
.logo-fallback { width:52px;height:52px;border-radius:50%;background:rgba(255,255,255,.12);border:2.5px solid rgba(255,255,255,.85);display:flex;align-items:center;justify-content:center;color:white;font-size:1.3rem; }
.club-name { font-family:'Rajdhani',sans-serif; font-weight:700; font-size:1.15rem; color:white; letter-spacing:.5px; line-height:1; }
.club-sub { font-size:.58rem; letter-spacing:1.4px; text-transform:uppercase; color:#f0b429; line-height:1; display:block; margin-top:2px; }

/* Liens nav niveau 1 */
.navbar-nav .nav-link {
    font-family: 'Rajdhani', sans-serif;
    font-weight: 600;
    font-size: 1rem;
    letter-spacing: .3px;
    border-radius: 8px;
    position: relative;
    transition: all .25s ease;
    color: rgba(255,255,255,.9) !important;
    padding: .45rem .9rem !important;
}
.navbar-nav .nav-link::after {
    content: '';
    position: absolute; bottom: 3px; left: 50%; right: 50%;
    height: 2px; background: #f0b429;
    transition: left .25s ease, right .25s ease;
    border-radius: 2px;
}
.navbar-nav .nav-link:hover::after,
.navbar-nav .nav-link.active::after { left: 10px; right: 10px; }
.navbar-nav .nav-link:hover,
.navbar-nav .nav-link.active {
    background: rgba(255,255,255,.09);
    color: #f0b429 !important;
}
/* Caret Bootstrap nativif */
.navbar-nav .dropdown-toggle::after { border: none; content: none; }
.navbar-nav .dropdown-toggle .fa-solid { transition: transform .25s ease; }
.navbar-nav .dropdown-toggle[aria-expanded="true"] > i.fa-chevron-down { transform: rotate(180deg); }

/* Dropdown */
.nav-dropdown-custom {
    background: #0a0f2c !important;
    border: 1px solid rgba(255,255,255,.1) !important;
    border-radius: 10px !important;
    padding: .5rem 0;
    margin-top: 6px !important;
    animation: dropFadeIn .18s ease forwards;
}
@keyframes dropFadeIn {
    from { opacity:0; transform:translateY(-6px); }
    to   { opacity:1; transform:translateY(0); }
}
.nav-dropdown-custom .dropdown-header {
    font-size: .72rem;
    letter-spacing: .9px;
    text-transform: uppercase;
    color: #f0b429 !important;
    padding: .55rem 1.1rem .25rem;
}
.nav-dropdown-custom .dropdown-divider { border-color: rgba(255,255,255,.1); margin: .35rem 0; }
.nav-dropdown-custom .dropdown-item {
    font-size: .88rem;
    padding: .4rem 1.1rem;
    color: rgba(255,255,255,.8) !important;
    border-radius: 6px;
    margin: 1px 6px;
    width: calc(100% - 12px);
    transition: background .2s ease, transform .2s ease, color .2s ease;
}
.nav-dropdown-custom .dropdown-item:hover,
.nav-dropdown-custom .dropdown-item:focus {
    background: rgba(13,110,253,.25) !important;
    color: #fff !important;
    transform: translateX(3px);
}
.nav-dropdown-custom .dropdown-item.active {
    background: rgba(13,110,253,.35) !important;
    color: #fff !important;
}

/* Badge LIVE */
.live-badge { animation: pulseLive 1.4s infinite; }
@keyframes pulseLive { 0%,100%{opacity:1} 50%{opacity:.45} }

/* ════════════════════════════════════════════
   MOBILE OFFCANVAS
════════════════════════════════════════════ */
.accordion-button::after { filter: invert(1) brightness(2); }
.accordion-button:not(.collapsed) { color: #f0b429 !important; }
.mobile-link { transition: background .2s ease, color .2s ease; }
.mobile-link:hover { background: rgba(13,110,253,.2); color: #fff !important; }
.mobile-link.active-mobile { color: #f0b429 !important; font-weight: 700; }
.mobile-sub-link { transition: color .2s ease, padding-left .2s ease; }
.mobile-sub-link:hover { color: #fff !important; padding-left: 4px; }

/* ════════════════════════════════════════════
   BREADCRUMB
════════════════════════════════════════════ */
.breadcrumb-bar { border-left: 3px solid #0d6efd; }
.breadcrumb-item a { color: #0d6efd; transition: color .2s; }
.breadcrumb-item a:hover { color: #0a58ca; }
.breadcrumb-item + .breadcrumb-item::before { color: #adb5bd; }

/* ════════════════════════════════════════════
   FOOTER
════════════════════════════════════════════ */
.footer-links li { margin-bottom: .38rem; }
.footer-links a { color: rgba(255,255,255,.55); font-size: .87rem; transition: color .2s, padding-left .2s; }
.footer-links a:hover { color: white; padding-left: 4px; }
.social-footer { width:34px; height:34px; display:inline-flex; align-items:center; justify-content:center; transition: all .2s; }
.social-footer:hover { background: #0d6efd !important; border-color: #0d6efd !important; color: white !important; transform: translateY(-3px); }

/* ════════════════════════════════════════════
   SCROLL TO TOP
════════════════════════════════════════════ */
.btn-scroll-top {
    position: fixed; bottom: 24px; right: 24px; z-index: 9999;
    width: 44px; height: 44px; border-radius: 50%;
    display: none; align-items: center; justify-content: center; padding: 0;
}
.btn-scroll-top.show { display: flex; }

/* ================================================================
   HERO CINÉMATIQUE
================================================================ */

.hero-cinema {
    position: relative;
    width: 100%;
    height: 100svh;
    min-height: 600px;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* ── Slides ── */
.hero-slides { position: absolute; inset: 0; }

.hero-slide {
    position: absolute; inset: 0;
    background-size: cover;
    background-position: center;
    opacity: 0;
    transform: scale(1.06);
    transition: opacity 1.4s ease, transform 8s ease;
    will-change: transform, opacity;
}
.hero-slide.active {
    opacity: 1;
    transform: scale(1);
}
.hero-slide.prev {
    opacity: 0;
    transform: scale(1.06);
}

/* Fallback dégradé animé */
.hero-slide-fallback {
    position: absolute; inset: 0;
    background: linear-gradient(135deg,
        #0a0f2c 0%, #1565c0 35%,
        #0d47a1 60%, #0a0f2c 100%);
    background-size: 300% 300%;
    animation: gradientShift 12s ease infinite;
    z-index: -1;
}
@keyframes gradientShift {
    0%   { background-position: 0% 50%; }
    50%  { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}

/* ── Overlays ── */
.hero-overlay-gradient {
    position: absolute; inset: 0;
    background: linear-gradient(
        to bottom,
        rgba(10,15,44,.35) 0%,
        rgba(10,15,44,.15) 30%,
        rgba(10,15,44,.55) 70%,
        rgba(10,15,44,.92) 100%
    );
    z-index: 1;
}
.hero-overlay-vignette {
    position: absolute; inset: 0;
    background: radial-gradient(ellipse at center,
        transparent 40%, rgba(10,15,44,.6) 100%);
    z-index: 2;
}
.hero-overlay-scan {
    position: absolute; inset: 0;
    background: repeating-linear-gradient(
        0deg,
        transparent,
        transparent 2px,
        rgba(255,255,255,.012) 2px,
        rgba(255,255,255,.012) 4px
    );
    z-index: 3;
    pointer-events: none;
}

/* ── Particules ── */
.hero-particles {
    position: absolute; inset: 0;
    z-index: 4;
    pointer-events: none;
    overflow: hidden;
}
.particle {
    position: absolute;
    border-radius: 50%;
    background: rgba(240,180,41,.6);
    animation: particleFloat linear infinite;
}
@keyframes particleFloat {
    0%   { transform: translateY(110vh) scale(0); opacity: 0; }
    10%  { opacity: 1; }
    90%  { opacity: .5; }
    100% { transform: translateY(-10vh) scale(1); opacity: 0; }
}

/* ── Contenu ── */
.hero-content {
    position: relative;
    z-index: 10;
    text-align: center;
    padding: 2rem 1.5rem;
    max-width: 820px;
    width: 100%;
}

/* Animation d'entrée générique */
[data-anim] {
    opacity: 0;
    transform: translateY(20px);
    animation: heroReveal .8s var(--tt-ease, ease) var(--delay, 0s) forwards;
}
[data-anim="fade-down"] {
    transform: translateY(-20px);
}
@keyframes heroReveal {
    to { opacity: 1; transform: translateY(0); }
}

/* Logo hero */
.hero-logo-ring {
    width: 100px; height: 100px;
    border-radius: 50%;
    border: 3px solid rgba(240,180,41,.7);
    box-shadow: 0 0 0 8px rgba(240,180,41,.12),
                0 0 40px rgba(13,110,253,.4);
    overflow: hidden;
    margin: 0 auto;
    animation: logoGlow 3s ease-in-out infinite;
}
@keyframes logoGlow {
    0%,100% { box-shadow: 0 0 0 8px rgba(240,180,41,.12), 0 0 40px rgba(13,110,253,.4); }
    50%      { box-shadow: 0 0 0 14px rgba(240,180,41,.2), 0 0 60px rgba(13,110,253,.6); }
}
.hero-logo-img { width:100%; height:100%; object-fit:cover; }
.hero-logo-fallback {
    width:100%; height:100%;
    background: linear-gradient(135deg, #1565c0, #0a0f2c);
    display: flex; align-items: center; justify-content: center;
    font-size: 2.5rem; color: white;
}

/* Eyebrow */
.hero-eyebrow {
    display: flex; align-items: center; justify-content: center;
    gap: 1rem; margin: 1.2rem 0 .8rem;
}
.eyebrow-line {
    display: block; width: 40px; height: 1px;
    background: linear-gradient(90deg, transparent, rgba(240,180,41,.7));
}
.eyebrow-line:last-child { transform: scaleX(-1); }
.eyebrow-text {
    font-size: .75rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: rgba(255,255,255,.7);
    font-family: 'Open Sans', sans-serif;
}

/* Titre */
.hero-title {
    display: flex; flex-direction: column;
    gap: .1rem;
    margin-bottom: 1rem;
}
.hero-title-top {
    font-family: 'Open Sans', sans-serif;
    font-size: clamp(.85rem, 2vw, 1rem);
    letter-spacing: 3px;
    text-transform: uppercase;
    color: rgba(255,255,255,.6);
    font-weight: 400;
}
.hero-title-main {
    font-family: 'Rajdhani', sans-serif;
    font-size: clamp(3rem, 9vw, 7rem);
    font-weight: 700;
    line-height: .95;
    color: white;
    text-shadow: 0 4px 30px rgba(0,0,0,.4);
    letter-spacing: -1px;
    background: linear-gradient(135deg, #fff 40%, #f0b429 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.hero-title-sub {
    font-family: 'Rajdhani', sans-serif;
    font-size: clamp(1.1rem, 3vw, 1.6rem);
    font-weight: 500;
    letter-spacing: 4px;
    text-transform: uppercase;
    color: rgba(240,180,41,.85);
}

/* Tagline */
.hero-tagline {
    display: flex; align-items: center; justify-content: center;
    flex-wrap: wrap; gap: .5rem;
    margin-bottom: 1.8rem;
}
.tag-word {
    font-size: clamp(.82rem, 1.8vw, 1rem);
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: rgba(255,255,255,.75);
    font-weight: 500;
}
.tag-dot { color: #f0b429; font-size: 1.2rem; }

/* CTA Boutons */
.hero-cta { display: flex; justify-content: center; flex-wrap: wrap; gap: 1rem; margin-bottom: 2.5rem; }
.btn-hero-primary {
    display: inline-flex; align-items: center;
    padding: .85rem 2rem;
    background: linear-gradient(135deg, #f0b429, #e0980a);
    color: #0a0f2c !important;
    font-family: 'Rajdhani', sans-serif;
    font-weight: 700;
    font-size: 1rem;
    letter-spacing: .5px;
    border-radius: 50px;
    border: none;
    box-shadow: 0 8px 30px rgba(240,180,41,.4);
    transition: all .3s ease;
    text-decoration: none;
}
.btn-hero-primary:hover {
    transform: translateY(-3px);
    box-shadow: 0 14px 40px rgba(240,180,41,.55);
}
.btn-hero-secondary {
    display: inline-flex; align-items: center; gap: .6rem;
    padding: .85rem 2rem;
    background: rgba(255,255,255,.1);
    backdrop-filter: blur(8px);
    color: white !important;
    font-family: 'Rajdhani', sans-serif;
    font-weight: 600;
    font-size: 1rem;
    border-radius: 50px;
    border: 1px solid rgba(255,255,255,.25);
    transition: all .3s ease;
    text-decoration: none;
}
.btn-hero-secondary:hover {
    background: rgba(255,255,255,.2);
    border-color: rgba(255,255,255,.5);
    transform: translateY(-3px);
}
.live-dot {
    width: 10px; height: 10px; border-radius: 50%;
    background: #dc3545;
    animation: pulseDot 1.2s infinite;
    flex-shrink: 0;
}
@keyframes pulseDot {
    0%,100% { box-shadow: 0 0 0 0 rgba(220,53,69,.6); }
    50%      { box-shadow: 0 0 0 6px rgba(220,53,69,0); }
}

/* Stats hero */
.hero-stats {
    display: flex; align-items: center; justify-content: center;
    flex-wrap: wrap; gap: 0;
    background: rgba(255,255,255,.07);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 20px;
    padding: 1.2rem 2rem;
    max-width: 560px;
    margin: 0 auto;
}
.hstat { text-align: center; padding: 0 1.5rem; }
.hstat-num {
    font-family: 'Rajdhani', sans-serif;
    font-size: 2rem; font-weight: 700;
    color: white; line-height: 1;
}
.hstat-plus { font-family:'Rajdhani',sans-serif; font-size:1.2rem; color:#f0b429; vertical-align:super; }
.hstat-lbl { font-size: .65rem; letter-spacing: 1px; text-transform: uppercase; color: rgba(255,255,255,.55); margin-top: .2rem; }
.hstat-sep { width: 1px; height: 36px; background: rgba(255,255,255,.15); }

/* ── Indicateurs ── */
.hero-indicators {
    position: absolute;
    bottom: 90px; left: 50%;
    transform: translateX(-50%);
    display: flex; gap: 8px;
    z-index: 10;
}
.hi {
    width: 28px; height: 4px;
    border-radius: 2px;
    background: rgba(255,255,255,.35);
    border: none; cursor: pointer;
    transition: all .3s ease;
    padding: 0;
}
.hi.active { width: 48px; background: #f0b429; }

/* ── Contrôles nav ── */
.hero-nav {
    position: absolute; top: 50%; transform: translateY(-50%);
    z-index: 10;
    width: 48px; height: 48px;
    border-radius: 50%;
    background: rgba(255,255,255,.1);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255,255,255,.2);
    color: white; font-size: 1rem;
    cursor: pointer;
    transition: all .3s ease;
    display: flex; align-items: center; justify-content: center;
}
.hero-nav:hover { background: rgba(240,180,41,.3); border-color: #f0b429; }
.hero-prev { left: 20px; }
.hero-next { right: 20px; }

/* ── Scroll hint ── */
.hero-scroll-hint {
    position: absolute; bottom: 28px; left: 50%;
    transform: translateX(-50%);
    display: flex; flex-direction: column; align-items: center; gap: 6px;
    z-index: 10;
    color: rgba(255,255,255,.5);
    font-size: .7rem; letter-spacing: 1.5px;
    text-transform: uppercase;
}
.scroll-mouse {
    width: 22px; height: 34px;
    border: 2px solid rgba(255,255,255,.3);
    border-radius: 11px;
    display: flex; justify-content: center; padding-top: 5px;
}
.scroll-wheel {
    width: 3px; height: 7px;
    background: rgba(255,255,255,.6);
    border-radius: 2px;
    animation: scrollWheel 2s ease infinite;
}
@keyframes scrollWheel {
    0%   { transform: translateY(0); opacity: 1; }
    100% { transform: translateY(10px); opacity: 0; }
}

/* ================================================================
   TICKER
================================================================ */
.news-ticker {
    display: flex; overflow: hidden;
    height: 40px; align-items: center;
}
.ticker-label {
    flex-shrink: 0;
    background: rgba(0,0,0,.2);
    height: 100%;
    display: flex; align-items: center;
    padding: 0 1.2rem;
    font-family: 'Rajdhani', sans-serif;
    font-weight: 700;
    font-size: .85rem;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: white;
    white-space: nowrap;
}
.ticker-track { flex: 1; overflow: hidden; position: relative; }
.ticker-content {
    display: flex; align-items: center; gap: 4rem;
    white-space: nowrap;
    animation: tickerScroll 30s linear infinite;
    font-size: .82rem;
    color: rgba(255,255,255,.9);
    padding: 0 2rem;
}
.ticker-content:hover { animation-play-state: paused; }
@keyframes tickerScroll {
    0%   { transform: translateX(100%); }
    100% { transform: translateX(-100%); }
}

/* ================================================================
   SECTION INTRO
================================================================ */
.section-eyebrow { margin-bottom: .5rem; }
.eyebrow-pill {
    display: inline-flex; align-items: center;
    background: rgba(13,110,253,.1);
    color: #0d6efd;
    border: 1px solid rgba(13,110,253,.2);
    border-radius: 50px;
    padding: .35rem 1rem;
    font-size: .8rem;
    font-weight: 600;
    letter-spacing: .5px;
}
.section-big-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 700;
    line-height: 1.15;
    color: #0a0f2c;
}

/* Galerie intro */
.intro-gallery {
    position: relative;
    height: 440px;
}
.igal-main {
    position: absolute;
    top: 0; left: 0;
    width: 68%; height: 80%;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0,0,0,.15);
}
.igal-secondary {
    position: absolute;
    bottom: 0; right: 0;
    width: 52%; height: 58%;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0,0,0,.15);
    border: 4px solid white;
}
.igal-img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.igal-main:hover .igal-img,
.igal-secondary:hover .igal-img { transform: scale(1.04); }
.igal-ph {
    width: 100%; height: 100%;
    background: linear-gradient(135deg, #e8f0fe, #f0f4ff);
    display: flex; align-items: center; justify-content: center;
}
.igal-stat-card {
    position: absolute;
    top: 16px; right: 28%;
    background: white;
    border-radius: 16px;
    padding: .8rem 1.2rem;
    display: flex; align-items: center; gap: .8rem;
    box-shadow: 0 10px 40px rgba(0,0,0,.12);
    animation: floatCard 4s ease-in-out infinite;
    z-index: 2;
}
.igal-hours-card {
    position: absolute;
    bottom: 62%; left: 60%;
    background: #0a0f2c;
    color: white;
    border-radius: 14px;
    padding: .7rem 1rem;
    display: flex; align-items: center; gap: .6rem;
    box-shadow: 0 10px 30px rgba(10,15,44,.3);
    animation: floatCard 4s ease-in-out 2s infinite;
    z-index: 2;
    white-space: nowrap;
}
@keyframes floatCard {
    0%,100% { transform: translateY(0); }
    50%      { transform: translateY(-8px); }
}
.isc-icon { font-size: 1.5rem; }
.isc-num  { font-family:'Rajdhani',sans-serif; font-size:1.1rem; font-weight:700; color:#0a0f2c; line-height:1; }
.isc-lbl  { font-size: .68rem; color: #888; }
.ich-title { font-size: .78rem; font-weight: 600; line-height: 1; }
.ich-times { font-size: .68rem; color: rgba(255,255,255,.6); }

/* ================================================================
   SECTION CHIFFRES
================================================================ */
.section-numbers {
    background: linear-gradient(135deg, #0a0f2c 0%, #1565c0 100%);
}
.number-card {
    text-align: center;
    padding: 2rem 1rem;
    border-radius: 20px;
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.1);
    backdrop-filter: blur(8px);
    transition: all .3s ease;
}
.number-card:hover {
    transform: translateY(-6px);
    background: rgba(255,255,255,.12);
}
.nc-icon { font-size: 1.6rem; color: #f0b429; margin-bottom: .8rem; }
.nc-num {
    font-family: 'Rajdhani', sans-serif;
    font-size: 3rem; font-weight: 700;
    color: white; line-height: 1;
    display: inline-block;
}
.nc-plus { font-family:'Rajdhani',sans-serif; font-size:1.5rem; color:#f0b429; display:inline-block; }
.nc-lbl { font-size: .75rem; letter-spacing: 1px; text-transform: uppercase; color: rgba(255,255,255,.55); margin-top: .4rem; }
.nc-bar {
    height: 3px; border-radius: 2px;
    background: rgba(255,255,255,.1);
    margin: .8rem auto 0; width: 60%;
    position: relative; overflow: hidden;
}
.nc-bar::after {
    content: '';
    position: absolute; top: 0; left: 0;
    height: 100%; width: var(--w, 50%);
    background: linear-gradient(90deg, #f0b429, #0d6efd);
    border-radius: 2px;
    animation: barFill 1.5s ease forwards;
}
@keyframes barFill { from { width: 0; } }

/* ================================================================
   SECTION MATCHS
================================================================ */
.match-upcoming-card {
    background: white;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(0,0,0,.07);
    transition: all .3s ease;
    border: 1px solid #e9ecef;
}
.match-upcoming-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 40px rgba(13,110,253,.14);
}
.muc-header {
    display: flex; justify-content: space-between; align-items: center;
    padding: .8rem 1.1rem;
    background: #f8f9fa;
    border-bottom: 1px solid #e9ecef;
}
.muc-date { font-size: .75rem; color: #888; }
.muc-teams {
    display: flex; align-items: center; justify-content: space-between;
    padding: 1.2rem 1.1rem;
    gap: .5rem;
}
.muc-team {
    display: flex; flex-direction: column; align-items: center;
    gap: .4rem; font-weight: 600; font-size: .88rem;
    text-align: center; flex: 1;
}
.muc-logo {
    width: 44px; height: 44px; border-radius: 50%;
    background: #f0f4ff;
    border: 2px solid #e9ecef;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.1rem; color: #aaa;
}
.muc-logo.home { border-color: #0d6efd; background: #e8f0fe; color: #0d6efd; }
.muc-vs {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.2rem; font-weight: 700;
    color: #ccc; flex-shrink: 0;
}
.muc-footer {
    display: flex; justify-content: space-between; align-items: center;
    padding: .7rem 1.1rem;
    background: #f8f9fa;
    border-top: 1px solid #e9ecef;
}
.btn-xs { padding: .15rem .55rem; font-size: .72rem; }

/* ================================================================
   SECTION ACTUALITÉS
================================================================ */
.news-card {
    background: white;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(0,0,0,.06);
    transition: all .3s ease;
    height: 100%;
    display: flex; flex-direction: column;
}
.news-card:hover { transform: translateY(-5px); box-shadow: 0 14px 40px rgba(13,110,253,.13); }
.nc-img-wrap {
    height: 180px;
    background: linear-gradient(135deg, #e8f0fe, #f0f4ff);
    position: relative;
    display: flex; align-items: center; justify-content: center;
}
.nc-badge {
    position: absolute; top: 12px; left: 12px;
    border-radius: 20px; padding: .25rem .7rem;
    font-size: .7rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .5px;
}
.nc-badge.club  { background: #0d6efd; color: white; }
.nc-badge.fftt  { background: #f0b429; color: #333; }
.nc-badge.ligue { background: #198754; color: white; }
.nc-body { padding: 1.2rem; flex: 1; display: flex; flex-direction: column; }
.nc-date { font-size: .75rem; color: #aaa; }
.nc-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.1rem; font-weight: 700;
    color: #0a0f2c; margin: .4rem 0 .6rem;
    line-height: 1.25;
}
.nc-excerpt { font-size: .85rem; color: #777; flex: 1; }
.nc-link {
    display: inline-flex; align-items: center;
    color: #0d6efd; font-size: .82rem; font-weight: 600;
    margin-top: .8rem; text-decoration: none;
    transition: gap .2s;
}
.nc-link:hover { text-decoration: underline; }

/* ================================================================
   SECTION CTA
================================================================ */
.section-cta {
    position: relative;
    padding: 6rem 0;
    overflow: hidden;
}
.cta-bg {
    position: absolute; inset: 0;
    background: linear-gradient(135deg, #0a0f2c 0%, #1565c0 100%);
}
.cta-overlay {
    position: absolute; inset: 0;
    background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Ccircle cx='30' cy='30' r='2'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.cta-ping-icon {
    width: 80px; height: 80px; border-radius: 50%;
    background: rgba(240,180,41,.15);
    border: 2px solid rgba(240,180,41,.4);
    display: flex; align-items: center; justify-content: center;
    font-size: 2rem; color: #f0b429;
    margin: 0 auto 1.5rem;
    animation: logoGlow 3s ease-in-out infinite;
}
.cta-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 700; color: white;
}
.cta-sub { color: rgba(255,255,255,.65); font-size: 1.05rem; }
.btn-cta-main {
    display: inline-flex; align-items: center;
    padding: 1rem 2.2rem;
    background: linear-gradient(135deg, #f0b429, #e0980a);
    color: #0a0f2c !important;
    font-family: 'Rajdhani', sans-serif;
    font-weight: 700; font-size: 1.05rem;
    border-radius: 50px; text-decoration: none;
    box-shadow: 0 8px 30px rgba(240,180,41,.35);
    transition: all .3s ease;
}
.btn-cta-main:hover { transform: translateY(-3px); box-shadow: 0 14px 40px rgba(240,180,41,.5); }
.btn-cta-outline {
    display: inline-flex; align-items: center;
    padding: 1rem 2.2rem;
    background: transparent;
    color: white !important;
    font-family: 'Rajdhani', sans-serif;
    font-weight: 600; font-size: 1.05rem;
    border-radius: 50px; text-decoration: none;
    border: 2px solid rgba(255,255,255,.35);
    transition: all .3s ease;
}
.btn-cta-outline:hover { border-color: white; background: rgba(255,255,255,.08); transform: translateY(-3px); }

/* ================================================================
   REVEAL AU SCROLL
================================================================ */
[data-reveal] {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity .7s ease, transform .7s ease;
    transition-delay: var(--rd, 0s);
}
[data-reveal="left"]  { transform: translateX(-30px); }
[data-reveal="right"] { transform: translateX(30px); }
[data-reveal].revealed {
    opacity: 1;
    transform: translate(0);
}

/* Responsive */
@media(max-width:575px){
    .intro-gallery { height: 280px; }
    .igal-main { width: 75%; height: 75%; }
    .igal-secondary { width: 55%; height: 52%; }
    .igal-stat-card, .igal-hours-card { display: none; }
    .hero-stats { padding: .8rem 1rem; }
    .hstat { padding: 0 .8rem; }
    .hstat-num { font-size: 1.4rem; }
    .hero-nav { display: none; }
}
/* ================================================================
   SECTION ACTUALITÉS — Homepage
================================================================ */

/* ── Titre de section ── */
.section-news .section-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: clamp(1.6rem, 3vw, 2.2rem);
    font-weight: 700;
    color: #0a0f2c;
    margin-bottom: 0;
}

/* ── Carte news ── */
.news-card {
    background: white;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(0,0,0,.06);
    border: 1px solid #e9ecef;
    display: flex;
    flex-direction: column;
    height: 100%;
    transition: transform .3s ease, box-shadow .3s ease;
}
.news-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 14px 40px rgba(13,110,253,.13);
}

/* ── Zone image ── */
.nc-img-wrap {
    height: 160px;
    flex-shrink: 0;
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, #e8f0fe, #f0f4ff);
    display: flex;
    align-items: center;
    justify-content: center;
}
.nc-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    transition: transform .5s ease;
}
.news-card:hover .nc-img {
    transform: scale(1.05);
}
.nc-img-ph {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    color: #bcc8e0;
}

/* ── Badge catégorie ── */
.nc-badge {
    position: absolute;
    top: 10px;
    left: 10px;
    z-index: 2;
    border-radius: 20px;
    padding: .25rem .75rem;
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .6px;
    box-shadow: 0 2px 8px rgba(0,0,0,.15);
}
.nc-badge.club   { background: #0d6efd; color: white; }
.nc-badge.fftt   { background: #f0b429; color: #1a1a2e; }
.nc-badge.ligue  { background: #198754; color: white; }
.nc-badge.comite { background: #dc3545; color: white; }

/* ── Corps texte ── */
.nc-body {
    flex: 1;
    padding: 1.1rem 1.2rem 1.2rem;
    display: flex;
    flex-direction: column;
    gap: .4rem;
    min-height: 0;
}

/* ── Date ── */
.nc-date {
    font-size: .72rem;
    color: #aab0c0;
    font-style: normal;
    letter-spacing: .3px;
}

/* ── Titre article ── */
.nc-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.08rem;
    font-weight: 700;
    color: #0a0f2c;
    line-height: 1.3;
    margin: 0;
}
.nc-title-link {
    color: inherit;
    text-decoration: none;
    transition: color .2s ease;
}
.nc-title-link:hover {
    color: #0d6efd;
}

/* ── Extrait ── */
.nc-excerpt {
    font-size: .84rem;
    color: #6c757d;
    line-height: 1.55;
    margin: 0;
    flex: 1;
    /* Limite à 3 lignes avec ellipsis */
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* ── Auteur ── */
.nc-author {
    display: flex;
    align-items: center;
    gap: .3rem;
    font-size: .75rem;
    color: #aab0c0;
}

/* ── Lien "Lire la suite" ── */
.nc-link {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    color: #0d6efd;
    font-size: .82rem;
    font-weight: 600;
    text-decoration: none;
    margin-top: auto;
    padding-top: .6rem;
    border-top: 1px solid #f0f2f5;
    transition: gap .2s ease, color .2s ease;
}
.nc-link:hover {
    color: #0a58ca;
    gap: .6rem;
}
.nc-link i {
    transition: transform .2s ease;
}
.nc-link:hover i {
    transform: translateX(3px);
}

/* ── Responsive ── */
@media (max-width: 767px) {
    .nc-img-wrap {
        height: 180px; /* un peu plus grand sur mobile = colonne unique */
    }
    .nc-title {
        font-size: 1rem;
    }
}
@media (max-width: 575px) {
    .news-card {
        border-radius: 12px;
    }
    .nc-img-wrap {
        height: 160px;
    }
}
/* ================================================================
   PAGE CONTACT
================================================================ */

/* ── Hero page générique ── */
.page-hero {
    background: linear-gradient(135deg, #0a0f2c 0%, #1565c0 100%);
    padding: 4rem 0 3rem;
    text-align: center;
    position: relative;
    overflow: hidden;
}
.page-hero::after {
    content: '';
    position: absolute; inset: 0;
    background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Ccircle cx='30' cy='30' r='2'/%3E%3C/g%3E%3C/svg%3E");
    pointer-events: none;
}
.page-hero-content { position: relative; z-index: 1; }
.page-hero-icon {
    width: 70px; height: 70px; border-radius: 50%;
    background: rgba(255,255,255,.1);
    border: 2px solid rgba(255,255,255,.2);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.8rem; color: #f0b429;
    margin: 0 auto 1.2rem;
}
.page-hero-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: clamp(2rem, 5vw, 3.2rem);
    font-weight: 700; color: white; margin-bottom: .5rem;
}
.page-hero-sub {
    color: rgba(255,255,255,.65);
    font-size: 1rem; line-height: 1.7;
}

/* ── Carte infos contact ── */
.contact-info-card {
    background: white;
    border-radius: 20px;
    padding: 1.8rem;
    box-shadow: 0 4px 24px rgba(0,0,0,.07);
    border: 1px solid #e9ecef;
}
.cic-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.3rem; font-weight: 700;
    color: #0a0f2c; margin-bottom: 1.4rem;
    padding-bottom: .8rem;
    border-bottom: 2px solid #f0b429;
    display: inline-block;
}
.cic-item {
    display: flex; gap: 1rem; align-items: flex-start;
    padding: .8rem 0;
    border-bottom: 1px solid #f0f2f5;
}
.cic-item:last-child { border-bottom: none; }
.cic-icon {
    width: 38px; height: 38px; border-radius: 10px;
    background: linear-gradient(135deg, #e8f0fe, #f0f4ff);
    display: flex; align-items: center; justify-content: center;
    color: #0d6efd; font-size: .95rem;
    flex-shrink: 0;
}
.cic-label { font-size: .72rem; text-transform: uppercase; letter-spacing: .8px; color: #aaa; margin-bottom: .2rem; }
.cic-value { font-size: .9rem; color: #333; line-height: 1.6; }
.cic-value a { color: #0d6efd; text-decoration: none; }
.cic-value a:hover { text-decoration: underline; }

/* ── Réseaux sociaux ── */
.contact-social-card {
    background: white;
    border-radius: 20px;
    padding: 1.4rem 1.8rem;
    box-shadow: 0 4px 24px rgba(0,0,0,.07);
    border: 1px solid #e9ecef;
}
.csc-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.1rem; font-weight: 700;
    color: #0a0f2c; margin-bottom: 1rem;
}
.csc-links { display: flex; flex-direction: column; gap: .6rem; }
.csc-link {
    display: flex; align-items: center; gap: .8rem;
    padding: .6rem 1rem;
    border-radius: 10px;
    text-decoration: none;
    font-size: .88rem; font-weight: 600;
    transition: all .2s ease;
    border: 1px solid #e9ecef;
    color: #333;
}
.csc-link:hover { transform: translateX(4px); }
.csc-link.facebook { color: #1877f2; }
.csc-link.facebook:hover { background: #e8f0fe; border-color: #1877f2; }
.csc-link.instagram { color: #e1306c; }
.csc-link.instagram:hover { background: #fce4ec; border-color: #e1306c; }
.csc-link.twitter { color: #000; }
.csc-link.twitter:hover { background: #f5f5f5; border-color: #000; }

/* ── Carte map ── */
.contact-map-card {
    background: white;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 4px 24px rgba(0,0,0,.07);
    border: 1px solid #e9ecef;
}
.map-wrap { overflow: hidden; }
.map-link {
    display: block;
    padding: .6rem 1rem;
    font-size: .78rem;
    color: #0d6efd;
    text-decoration: none;
    text-align: center;
    border-top: 1px solid #e9ecef;
}
.map-link:hover { background: #f8f9fa; }

/* ── Carte formulaire ── */
.contact-form-card {
    background: white;
    border-radius: 20px;
    padding: 2.2rem;
    box-shadow: 0 4px 24px rgba(0,0,0,.07);
    border: 1px solid #e9ecef;
}
.cfc-header { margin-bottom: 1.8rem; padding-bottom: 1.2rem; border-bottom: 1px solid #f0f2f5; }
.cfc-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.5rem; font-weight: 700; color: #0a0f2c;
    margin-bottom: .3rem;
}
.cfc-sub { font-size: .82rem; color: #aaa; margin: 0; }

/* ── Champs formulaire ── */
.form-group-custom { display: flex; flex-direction: column; gap: .4rem; }
.fcl {
    font-size: .82rem; font-weight: 600;
    color: #444; letter-spacing: .2px;
}
.fci-wrap {
    position: relative;
    display: flex; align-items: center;
}
.fci-icon {
    position: absolute; left: .9rem;
    color: #adb5bd; font-size: .85rem;
    pointer-events: none; z-index: 1;
    transition: color .2s;
}
.fci-icon-ta { top: .85rem; align-self: flex-start; }
.fci {
    width: 100%;
    padding: .7rem .9rem .7rem 2.4rem;
    border: 1.5px solid #dee2e6;
    border-radius: 10px;
    font-size: .9rem;
    color: #333;
    background: #fafbfc;
    transition: border-color .2s, box-shadow .2s, background .2s;
    outline: none;
    appearance: none;
}
.fci:focus {
    border-color: #0d6efd;
    background: white;
    box-shadow: 0 0 0 3px rgba(13,110,253,.1);
}
.fci-wrap:focus-within .fci-icon { color: #0d6efd; }
.fci-select { cursor: pointer; }
.fci-textarea {
    padding-top: .75rem;
    resize: vertical;
    min-height: 130px;
}
.fci-wrap-textarea { align-items: flex-start; }
.has-error .fci { border-color: #dc3545; background: #fff8f8; }
.has-error .fci:focus { box-shadow: 0 0 0 3px rgba(220,53,69,.1); }
.fc-error {
    font-size: .75rem; color: #dc3545;
    display: flex; align-items: center; gap: .3rem;
}

/* ── Anti-spam ── */
.antispam-wrap {
    display: flex; align-items: center;
    flex-wrap: wrap; gap: .8rem;
}
.antispam-question {
    display: flex; align-items: center;
    background: #f0f4ff;
    border: 1px solid #d0deff;
    border-radius: 10px;
    padding: .6rem 1rem;
    font-size: .9rem; font-weight: 600; color: #0a0f2c;
    flex-shrink: 0;
}

/* ── RGPD ── */
.rgpd-label {
    display: flex; gap: .8rem; align-items: flex-start;
    cursor: pointer;
}
.rgpd-check {
    width: 18px; height: 18px;
    border-radius: 4px; cursor: pointer;
    flex-shrink: 0; margin-top: .15rem;
    accent-color: #0d6efd;
}
.rgpd-text {
    font-size: .82rem; color: #666; line-height: 1.5;
}
.rgpd-text a { color: #0d6efd; }

/* ── Bouton submit ── */
.btn-contact-submit {
    display: inline-flex; align-items: center;
    padding: .9rem 2.2rem;
    background: linear-gradient(135deg, #0d6efd, #1565c0);
    color: white;
    font-family: 'Rajdhani', sans-serif;
    font-weight: 700; font-size: 1.05rem;
    border: none; border-radius: 50px;
    cursor: pointer;
    box-shadow: 0 6px 24px rgba(13,110,253,.35);
    transition: all .3s ease;
    width: 100%;
    justify-content: center;
}
.btn-contact-submit:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 32px rgba(13,110,253,.45);
}
.btn-contact-submit:active { transform: translateY(0); }
.submit-note {
    font-size: .75rem; color: #aaa;
    text-align: center; margin-top: .8rem; margin-bottom: 0;
}

/* ── Message succès ── */
.form-success-msg {
    text-align: center;
    padding: 3rem 2rem;
}
.fsm-icon {
    font-size: 4rem; color: #198754;
    margin-bottom: 1rem;
    animation: successPop .5s cubic-bezier(.175,.885,.32,1.275);
}
@keyframes successPop {
    from { transform: scale(0); opacity: 0; }
    to   { transform: scale(1); opacity: 1; }
}
.form-success-msg h3 {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.8rem; font-weight: 700; color: #0a0f2c;
}
.form-success-msg p { color: #666; }

/* ── Responsive ── */
@media (max-width: 575px) {
    .contact-form-card { padding: 1.4rem; }
    .antispam-wrap { flex-direction: column; align-items: flex-start; }
    .btn-contact-submit { font-size: .95rem; }
}
/* ================================================================
   PAGE ÉQUIPE — equipe.tpl
================================================================ */

/* ── Hero ── */
.equipe-hero {
    position: relative;
    background: #0a0f2c;
    overflow: hidden;
}
.equipe-hero-bg {
    position: absolute; inset: 0;
    background: linear-gradient(135deg, #0a0f2c 0%, #1565c0 100%);
}
.equipe-hero-bg::after {
    content: '';
    position: absolute; inset: 0;
    background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Ccircle cx='30' cy='30' r='2'/%3E%3C/g%3E%3C/svg%3E");
}
.equipe-hero-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(to bottom, transparent 60%, rgba(10,15,44,.8) 100%);
}

/* Badges division/poule */
.equipe-hero-badges {
    display: flex; align-items: center; flex-wrap: wrap; gap: .5rem;
}
.ehb-division {
    background: #f0b429;
    color: #0a0f2c;
    font-family: 'Rajdhani', sans-serif;
    font-weight: 700; font-size: .85rem;
    padding: .3rem .9rem;
    border-radius: 50px;
    letter-spacing: .5px;
}
.ehb-poule, .ehb-saison {
    font-size: .82rem;
    color: rgba(255,255,255,.7);
}
.ehb-sep { color: rgba(255,255,255,.3); }

.equipe-hero-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: clamp(1.8rem, 4vw, 3rem);
    font-weight: 700;
    color: white;
    margin: 0;
}
.equipe-hero-meta {
    display: flex; flex-wrap: wrap; gap: 1rem;
}
.ehm-item { font-size: .85rem; color: rgba(255,255,255,.65); }

/* KPI hero */
.equipe-hero-kpi {
    background: rgba(255,255,255,.08);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 20px;
    padding: 1.2rem;
    display: flex; align-items: center; justify-content: center;
    gap: 0; flex-wrap: wrap;
}
.ehkpi { text-align: center; padding: .5rem 1rem; }
.ehkpi-val {
    font-family: 'Rajdhani', sans-serif;
    font-size: 2rem; font-weight: 700;
    color: white; line-height: 1;
}
.ehkpi-val sup { font-size: 1rem; }
.ehkpi-lbl {
    font-size: .65rem; letter-spacing: 1px;
    text-transform: uppercase;
    color: rgba(255,255,255,.5);
    margin-top: .2rem;
}
.ehkpi-sep {
    width: 1px; height: 40px;
    background: rgba(255,255,255,.15);
}

/* Barre de forme hero */
.equipe-forme-bar {
    background: rgba(0,0,0,.25);
    border-top: 1px solid rgba(255,255,255,.08);
}
.forme-label {
    font-size: .78rem; font-weight: 600;
    text-transform: uppercase; letter-spacing: 1px;
    color: rgba(255,255,255,.5);
}
.forme-dot {
    width: 30px; height: 30px; border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: .65rem; font-weight: 700; color: white;
    letter-spacing: 0;
}
.forme-dot.win  { background: #198754; }
.forme-dot.loss { background: #dc3545; }
.forme-dot.draw { background: #6c757d; }

/* ── Onglets nav ── */
.equipe-tabs-nav {
    background: white;
    border-bottom: 2px solid #e9ecef;
    z-index: 100;
    box-shadow: 0 2px 12px rgba(0,0,0,.07);
}
.etab-nav {
    display: flex; gap: 0;
    overflow-x: auto;
    scrollbar-width: none;
    flex-wrap: nowrap;
}
.etab-nav::-webkit-scrollbar { display: none; }
.etab-btn {
    display: flex; align-items: center;
    padding: 1rem 1.4rem;
    background: none; border: none;
    font-family: 'Rajdhani', sans-serif;
    font-size: 1rem; font-weight: 600;
    color: #888;
    white-space: nowrap;
    cursor: pointer;
    position: relative;
    transition: color .2s;
}
.etab-btn::after {
    content: '';
    position: absolute; bottom: -2px; left: 0; right: 0;
    height: 3px; background: #0d6efd;
    border-radius: 2px 2px 0 0;
    transform: scaleX(0);
    transition: transform .2s;
}
.etab-btn.active { color: #0d6efd; }
.etab-btn.active::after { transform: scaleX(1); }
.etab-btn:hover { color: #0d6efd; }

/* ── Contenu onglets ── */
.equipe-tab-content { background: #f8f9fa; min-height: 60vh; }

/* ── Carte générique ── */
.equipe-card {
    background: white;
    border-radius: 16px;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 16px rgba(0,0,0,.05);
    overflow: hidden;
}
.equipe-card-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 1rem 1.4rem;
    border-bottom: 1px solid #f0f2f5;
    background: #fafbfc;
}
.ech-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.1rem; font-weight: 700;
    color: #0a0f2c; margin: 0;
}

/* ── Tableau classement ── */
.equipe-standing-table {
    font-size: .88rem;
}
.equipe-standing-table thead th {
    background: #f8f9fa;
    font-size: .72rem; text-transform: uppercase;
    letter-spacing: .8px; color: #888;
    font-weight: 600; border-bottom: 2px solid #e9ecef;
    padding: .7rem .8rem;
}
.equipe-standing-table tbody td {
    padding: .7rem .8rem;
    vertical-align: middle;
    border-color: #f0f2f5;
}
.equipe-standing-table tbody tr:hover { background: #f8f9fa; }

.standing-promotion { border-left: 3px solid #198754; }
.standing-relegation { border-left: 3px solid #dc3545; }
.standing-our-team {
    background: rgba(13,110,253,.05) !important;
    border-left: 3px solid #0d6efd;
    font-weight: 600;
}

/* Badges rang */
.rank-badge {
    display: inline-flex; align-items: center; justify-content: center;
    width: 28px; height: 28px; border-radius: 50%;
    font-size: .8rem; font-weight: 700;
    background: #e9ecef; color: #555;
}
.rank-badge.gold   { background: linear-gradient(135deg,#f0b429,#e0980a); color:white; }
.rank-badge.silver { background: linear-gradient(135deg,#adb5bd,#868e96); color:white; }
.rank-badge.bronze { background: linear-gradient(135deg,#cd7f32,#a0522d); color:white; }

/* Badge points */
.pts-badge {
    display: inline-flex; align-items: center; justify-content: center;
    min-width: 32px; height: 24px;
    background: #0d47a1; color: white;
    border-radius: 12px; font-size: .8rem; font-weight: 700;
    padding: 0 .5rem;
}
.pts-badge.our     { background: #0d6efd; }
.pts-badge.relegate { background: #dc3545; }

/* Forme mini */
.forme-mini { display: flex; gap: 2px; justify-content: center; }
.fm-dot {
    width: 20px; height: 20px; border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: .55rem; font-weight: 700; color: white;
}
.fm-dot.win  { background: #198754; }
.fm-dot.loss { background: #dc3545; }
.fm-dot.draw { background: #6c757d; }

/* Légende */
.standing-legend {
    display: flex; gap: 1.2rem; flex-wrap: wrap;
    padding: .8rem 1.4rem;
    font-size: .75rem; color: #888;
    border-top: 1px solid #f0f2f5;
    background: #fafbfc;
}
.sl-item { display: flex; align-items: center; gap: .4rem; }
.sl-item.promotion i { color: #198754; }
.sl-item.relegation i { color: #dc3545; }
.sl-item.our i { color: #0d6efd; }

/* ── Prochain match ── */
.next-match-card { padding: 1.2rem; }
.nmc-date {
    font-size: .82rem; color: #888;
    margin-bottom: 1rem;
}
.nmc-teams {
    display: flex; align-items: center;
    justify-content: space-between; gap: .5rem;
    margin-bottom: 1rem;
}
.nmc-team {
    display: flex; flex-direction: column;
    align-items: center; gap: .4rem;
    font-size: .88rem; font-weight: 600;
    text-align: center; flex: 1;
}
.nmc-logo {
    width: 44px; height: 44px; border-radius: 50%;
    background: #f0f4ff;
    border: 2px solid #e9ecef;
    display: flex; align-items: center; justify-content: center;
    color: #aaa; font-size: 1.1rem;
}
.nmc-logo.home { border-color: #0d6efd; background: #e8f0fe; color: #0d6efd; }
.nmc-vs {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.3rem; font-weight: 700; color: #ccc;
}
.nmc-venue { font-size: .78rem; color: #999; margin-bottom: 1rem; }

/* Countdown */
.nmc-countdown {
    display: flex; gap: .5rem; justify-content: center;
    background: #f8f9fa; border-radius: 12px; padding: .8rem;
}
.cd-block { text-align: center; flex: 1; }
.cd-val {
    display: block;
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.6rem; font-weight: 700;
    color: #0d6efd; line-height: 1;
}
.cd-lbl { font-size: .6rem; text-transform: uppercase; color: #aaa; letter-spacing: .5px; }

/* ── Bilan ── */
.bilan-bar-labels {
    display: flex; justify-content: space-between;
    font-size: .82rem; margin-bottom: .4rem;
}
.bilan-bar {
    height: 10px; border-radius: 5px;
    overflow: hidden; display: flex;
    background: #f0f2f5;
}
.bilan-bar-win  { background: #198754; border-radius: 5px 0 0 5px; transition: width 1s ease; }
.bilan-bar-loss { background: #dc3545; border-radius: 0 5px 5px 0; transition: width 1s ease; }
.bilan-stat {
    background: #f8f9fa; border-radius: 10px;
    padding: .6rem .4rem;
}
.bs-val { font-family: 'Rajdhani', sans-serif; font-size: 1.3rem; font-weight: 700; }
.bs-lbl { font-size: .65rem; color: #aaa; text-transform: uppercase; letter-spacing: .5px; }

/* ── Résultats ── */
.results-filter-bar {
    display: flex; gap: .5rem; flex-wrap: wrap;
}
.rfb-btn {
    padding: .45rem 1.1rem;
    border-radius: 50px;
    border: 1.5px solid #dee2e6;
    background: white;
    font-size: .82rem; font-weight: 600;
    color: #666; cursor: pointer;
    transition: all .2s;
}
.rfb-btn.active, .rfb-btn:hover {
    background: #0d6efd; border-color: #0d6efd; color: white;
}

.journee-block { margin-bottom: 1.2rem; }
.journee-header {
    display: flex; align-items: center; gap: .8rem;
    margin-bottom: .5rem;
}
.jh-num {
    font-family: 'Rajdhani', sans-serif;
    font-size: .95rem; font-weight: 700; color: #0a0f2c;
}
.jh-date { font-size: .78rem; color: #999; }
.jh-away {
    font-size: .72rem; font-weight: 700;
    padding: .15rem .6rem; border-radius: 10px;
    background: #e8f0fe; color: #0d6efd;
    margin-left: auto;
}
.jh-away.upcoming { background: #fff3cd; color: #856404; }

.match-card {
    background: white;
    border-radius: 14px;
    border: 1px solid #e9ecef;
    overflow: hidden;
    box-shadow: 0 2px 10px rgba(0,0,0,.04);
}
.win-card  { border-left: 4px solid #198754; }
.loss-card { border-left: 4px solid #dc3545; }
.upcoming-card { border-left: 4px solid #f0b429; border-style: dashed solid dashed solid; }

.mc-teams {
    display: flex; align-items: center;
    justify-content: space-between;
    padding: 1rem 1.2rem; gap: .5rem;
}
.mc-team {
    display: flex; flex-direction: column;
    align-items: center; gap: .3rem;
    flex: 1; text-align: center;
}
.mc-logo {
    width: 40px; height: 40px; border-radius: 50%;
    background: #f0f4ff; border: 2px solid #e9ecef;
    display: flex; align-items: center; justify-content: center;
    color: #aaa; font-size: 1rem;
}
.mc-logo.home { border-color: #0d6efd; background: #e8f0fe; color: #0d6efd; }
.mc-name { font-size: .85rem; font-weight: 600; }
.mc-score {
    display: flex; align-items: center; gap: .5rem;
    font-family: 'Rajdhani', sans-serif;
    font-size: 2rem; font-weight: 700;
    flex-shrink: 0;
}
.mc-score.upcoming {
    font-size: 1.2rem; color: #ccc;
}
.mcs-home, .mcs-away { min-width: 36px; text-align: center; }
.mcs-home.win  { color: #198754; }
.mcs-away.loss { color: #dc3545; }
.mcs-sep { color: #ccc; font-size: 1.5rem; }

.mc-footer {
    display: flex; align-items: center; justify-content: space-between;
    padding: .6rem 1.2rem;
    background: #fafbfc; border-top: 1px solid #f0f2f5;
}
.mc-result-pill {
    font-size: .72rem; font-weight: 700;
    padding: .2rem .7rem; border-radius: 20px;
    text-transform: uppercase; letter-spacing: .5px;
}
.mc-result-pill.win      { background: #d1e7dd; color: #0f5132; }
.mc-result-pill.loss     { background: #f8d7da; color: #842029; }
.mc-result-pill.upcoming { background: #fff3cd; color: #856404; }

.mc-detail-btn {
    background: none; border: 1px solid #dee2e6;
    border-radius: 20px; padding: .2rem .8rem;
    font-size: .75rem; color: #666; cursor: pointer;
    transition: all .2s;
}
.mc-detail-btn:hover { background: #0d6efd; border-color: #0d6efd; color: white; }

/* Détail individuel */
.mc-detail { padding: 0 1.2rem 1rem; }
.mc-detail-table { font-size: .82rem; }
.mc-detail-table thead th {
    font-size: .7rem; text-transform: uppercase;
    letter-spacing: .6px; color: #aaa; font-weight: 600;
}
.det-win  { background: rgba(25,135,84,.04); }
.det-loss { background: rgba(220,53,69,.04); }
.det-pill {
    font-size: .72rem; font-weight: 700;
    padding: .15rem .6rem; border-radius: 10px;
}
.det-pill.win  { background: #d1e7dd; color: #0f5132; }
.det-pill.loss { background: #f8d7da; color: #842029; }

/* ── Composition ── */
.section-subtitle {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.2rem; font-weight: 700; color: #0a0f2c;
}
.staff-card {
    background: white; border-radius: 14px;
    border: 1px solid #e9ecef;
    padding: 1.2rem; text-align: center;
    transition: transform .2s, box-shadow .2s;
}
.staff-card:hover { transform: translateY(-3px); box-shadow: 0 8px 24px rgba(0,0,0,.08); }
.stc-avatar {
    width: 56px; height: 56px; border-radius: 50%;
    background: linear-gradient(135deg, #e8f0fe, #dbeafe);
    border: 2px solid #0d6efd;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.4rem; color: #0d6efd;
    margin: 0 auto .8rem;
}
.stc-name { font-weight: 700; color: #0a0f2c; margin-bottom: .2rem; }
.stc-role { font-size: .78rem; color: #888; }

/* Tableau joueurs */
.equipe-players-table { font-size: .88rem; }
.equipe-players-table thead th {
    background: #f8f9fa;
    font-size: .72rem; text-transform: uppercase;
    letter-spacing: .8px; color: #888; font-weight: 600;
    border-bottom: 2px solid #e9ecef;
    padding: .7rem .8rem;
}
.equipe-players-table tbody td {
    padding: .7rem .8rem;
    vertical-align: middle;
    border-color: #f0f2f5;
}
.equipe-players-table tbody tr:hover { background: #f8f9fa; }

.player-name-cell {
    display: flex; align-items: center; gap: .8rem;
}
.pnc-avatar {
    width: 34px; height: 34px; border-radius: 50%;
    background: linear-gradient(135deg, #0d6efd, #1565c0);
    color: white; font-size: .72rem; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.classement-badge {
    background: #0a0f2c; color: white;
    font-size: .78rem; font-weight: 700;
    padding: .15rem .6rem; border-radius: 10px;
}

/* Barre performance */
.perf-bar-wrap {
    display: flex; align-items: center; gap: .6rem;
}
.perf-bar {
    flex: 1; height: 8px; border-radius: 4px;
    background: #f0f2f5; overflow: hidden; position: relative;
}
.perf-bar::after {
    content: '';
    position: absolute; inset: 0;
    width: var(--pw, 0%);
    background: var(--pc, #0d6efd);
    border-radius: 4px;
    animation: barFill 1s ease forwards;
}
.perf-val { font-size: .78rem; font-weight: 700; color: #555; width: 36px; text-align: right; }

/* Badge % victoires */
.pct-badge {
    display: inline-block;
    padding: .2rem .6rem; border-radius: 10px;
    font-size: .78rem; font-weight: 700;
}
.pct-badge.success { background: #d1e7dd; color: #0f5132; }
.pct-badge.primary { background: #cfe2ff; color: #084298; }
.pct-badge.warning { background: #fff3cd; color: #856404; }
.pct-badge.danger  { background: #f8d7da; color: #842029; }

/* ── Statistiques ── */
/* Graphique classement */
.ranking-chart { overflow-x: auto; }
.rc-bars {
    display: flex; gap: .5rem;
    min-width: 500px;
}
.rc-yaxis {
    display: flex; flex-direction: column;
    justify-content: space-between;
    padding: 10px 0;
    font-size: .65rem; color: #aaa; text-align: right;
    width: 30px; flex-shrink: 0;
    height: 220px;
}
.rc-grid {
    flex: 1; position: relative;
    height: 220px;
}
.rc-gridlines {
    position: absolute; inset: 0;
    display: flex; flex-direction: column;
    justify-content: space-between;
    padding: 10px 0;
}
.rc-gl {
    width: 100%; height: 1px;
    background: #f0f2f5;
}
.rc-svg {
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 200px;
}
.rc-line { stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round; }
.rc-area { opacity: .5; }
.rc-xlabels {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    display: flex; justify-content: space-between;
    font-size: .65rem; color: #aaa;
    padding: 0 2px;
}

/* Progress bars stats */
.stat-progress-item {}
.spi-label {
    display: flex; justify-content: space-between;
    font-size: .82rem; margin-bottom: .4rem;
}
.spi-val { font-weight: 700; }
.spi-bar {
    height: 8px; border-radius: 4px;
    background: #f0f2f5; overflow: hidden;
}
.spi-fill {
    height: 100%; border-radius: 4px;
    width: var(--fw, 0%);
    animation: barFill 1.2s ease forwards;
}
.spi-fill.success { background: #198754; }
.spi-fill.primary { background: #0d6efd; }
.spi-fill.warning { background: #f0b429; }
.spi-fill.info    { background: #0dcaf0; }
.spi-fill.danger  { background: #dc3545; }

/* Mini stats */
.mini-stat-box {
    background: #f8f9fa; border-radius: 10px;
    padding: .7rem .4rem;
}
.msb-val {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.2rem; font-weight: 700;
}
.msb-lbl { font-size: .65rem; color: #aaa; text-transform: uppercase; letter-spacing: .4px; }

/* ── Animation barFill ── */
@keyframes barFill {
    from { width: 0 !important; }
}

/* ── Responsive ── */
@media (max-width: 991px) {
    .equipe-hero-kpi { margin-top: 0; }
}
@media (max-width: 575px) {
    .equipe-hero-kpi { gap: 0; }
    .ehkpi { padding: .4rem .6rem; }
    .ehkpi-val { font-size: 1.5rem; }
    .etab-btn { padding: .8rem 1rem; font-size: .88rem; }
    .mc-score { font-size: 1.5rem; }
}
/* ── Contenu onglets ── */
.equipe-tab-content {
    background: #f8f9fa;
    /* Supprimer le min-height fixe qui crée l'espace vide */
    min-height: 0;
}

/* S'assurer que les panes inactifs ne prennent aucun espace */
.equipe-tab-content .tab-pane {
    display: none;
}
.equipe-tab-content .tab-pane.active.show {
    display: block;
}
/* ── Nul/Match nul ── */
.forme-dot.draw   { background: #6c757d; }
.fm-dot.draw      { background: #6c757d; }

.standing-draw    { border-left: 3px solid #6c757d; }

.win-card         { border-left: 4px solid #198754; }
.loss-card        { border-left: 4px solid #dc3545; }
.draw-card        { border-left: 4px solid #6c757d; }  /* ← nouveau */
.upcoming-card    { border-left: 4px dashed #f0b429; }

.mc-result-pill.draw  { background: #e2e3e5; color: #41464b; } /* ← nouveau */
.mc-result-pill.win   { background: #d1e7dd; color: #0f5132; }
.mc-result-pill.loss  { background: #f8d7da; color: #842029; }

.det-draw { background: rgba(108,117,125,.04); } /* ← ligne neutre dans détail */
.det-pill.draw { background: #e2e3e5; color: #41464b; }

.bilan-bar-win  { background: #198754; border-radius: 5px 0 0 5px; transition: width 1s ease; }
.bilan-bar-draw { background: #6c757d; transition: width 1s ease; }           /* ← nouveau */
.bilan-bar-loss { background: #dc3545; border-radius: 0 5px 5px 0; transition: width 1s ease; }

/* ================================================================
   DÉTAIL FEUILLE DE MATCH
================================================================ */

.mc-detail-full {
    border-top: 1px solid #f0f2f5;
}

/* ── En-tête ── */
.mdf-header {
    background: linear-gradient(135deg, #0a0f2c, #1565c0);
    padding: 1.2rem 1.4rem;
    display: flex;
    flex-direction: column;
    gap: .8rem;
}
.mdf-competition {
    font-size: .75rem;
    color: rgba(255,255,255,.6);
    text-transform: uppercase;
    letter-spacing: .8px;
}
.mdf-score-global {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .8rem;
    flex-wrap: wrap;
}
.mdf-team-home,
.mdf-team-away {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.1rem;
    font-weight: 700;
    color: white;
}
.mdf-score-box {
    font-family: 'Rajdhani', sans-serif;
    font-size: 2rem;
    font-weight: 700;
    min-width: 44px;
    height: 44px;
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}
.mdf-score-box.win  { background: #198754; color: white; }
.mdf-score-box.loss { background: #dc3545; color: white; }
.mdf-score-box.draw { background: #6c757d; color: white; }
.mdf-sep {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.5rem;
    color: rgba(255,255,255,.4);
}

/* ── Sections ── */
.mdf-section {
    padding: 1.2rem 1.4rem;
    border-bottom: 1px solid #f0f2f5;
}
.mdf-section:last-child { border-bottom: none; }
.mdf-section-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1rem;
    font-weight: 700;
    color: #0a0f2c;
    margin-bottom: 1rem;
    padding-bottom: .5rem;
    border-bottom: 2px solid #f0b429;
    display: inline-block;
}

/* ── Tableau composition ── */
.mdf-compo-table {
    font-size: .85rem;
    margin-bottom: 0;
}
.mdf-compo-table thead th {
    background: #f8f9fa;
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .6px;
    color: #888;
    font-weight: 600;
    padding: .6rem .8rem;
    border-bottom: 2px solid #e9ecef;
}
.mdf-compo-table tbody td {
    padding: .6rem .8rem;
    vertical-align: middle;
    border-color: #f0f2f5;
}
.mdf-compo-table tbody tr:hover { background: #fafbfc; }

.team-label {
    font-family: 'Rajdhani', sans-serif;
    font-weight: 700;
    font-size: .9rem;
}
.team-label.home { color: #0d6efd; }
.team-label.away { color: #6c757d; }

.clt-pill {
    display: inline-block;
    background: #e8f0fe;
    color: #0d47a1;
    font-size: .72rem;
    font-weight: 600;
    padding: .15rem .6rem;
    border-radius: 10px;
    white-space: nowrap;
}
.clt-pill.away {
    background: #f0f2f5;
    color: #555;
}

/* ── Tableau parties ── */
.mdf-parties-table {
    font-size: .85rem;
    margin-bottom: 0;
}
.mdf-parties-table thead th {
    background: #f8f9fa;
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .6px;
    color: #888;
    font-weight: 600;
    padding: .6rem .8rem;
    border-bottom: 2px solid #e9ecef;
}
.mdf-parties-table tbody td {
    padding: .55rem .8rem;
    vertical-align: middle;
    border-color: #f0f2f5;
    font-size: .85rem;
}

/* Couleur ligne selon résultat */
.partie-win  { border-left: 3px solid #198754; }
.partie-loss { border-left: 3px solid #dc3545; }
.partie-draw { border-left: 3px solid #6c757d; }
.partie-win:hover  { background: rgba(25,135,84,.04); }
.partie-loss:hover { background: rgba(220,53,69,.04); }
.partie-draw:hover { background: rgba(108,117,125,.04); }

/* Double */
.partie-double { background: rgba(240,180,41,.04); }
.partie-double.partie-win  { border-left-color: #0d6efd; }
.double-badge {
    display: inline-block;
    background: #f0b429;
    color: #0a0f2c;
    font-size: .55rem;
    font-weight: 700;
    padding: .1rem .3rem;
    border-radius: 4px;
    letter-spacing: .5px;
}

/* Score de la partie */
.partie-score {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 52px;
    padding: .2rem .6rem;
    border-radius: 20px;
    font-family: 'Rajdhani', sans-serif;
    font-size: .9rem;
    font-weight: 700;
}
.partie-score.win  { background: #d1e7dd; color: #0f5132; }
.partie-score.loss { background: #f8d7da; color: #842029; }
.partie-score.draw { background: #e2e3e5; color: #41464b; }

/* Sets */
.sets-detail {
    font-size: .72rem;
    color: #888;
    font-family: 'Rajdhani', sans-serif;
    letter-spacing: .5px;
}

/* Score final */
.mdf-final-score {
    background: #f8f9fa;
    font-size: .9rem;
}
.final-score-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 60px;
    padding: .3rem .8rem;
    border-radius: 20px;
    font-family: 'Rajdhani', sans-serif;
    font-size: 1rem;
    font-weight: 700;
}
.final-score-pill.win  { background: #198754; color: white; }
.final-score-pill.loss { background: #dc3545; color: white; }
.final-score-pill.draw { background: #6c757d; color: white; }

/* ── Responsive ── */
@media (max-width: 575px) {
    .mdf-score-global { gap: .5rem; }
    .mdf-team-home,
    .mdf-team-away { font-size: .9rem; }
    .mdf-score-box { font-size: 1.5rem; min-width: 36px; height: 36px; }
    .mdf-section { padding: 1rem; }
}

/* Carte match nul */
.draw-card { border-left: 4px solid #6c757d; }

/* Pill résultat nul */
.mc-result-pill.draw { background: #e2e3e5; color: #41464b; }

/* Indicateur domicile nul */
.jh-away.draw { background: #e2e3e5; color: #41464b; }

/* Ligne partie nulle */
.partie-draw { border-left: 3px solid #6c757d; }
.partie-draw:hover { background: rgba(108,117,125,.04); }
.partie-double.partie-draw { border-left-color: #6c757d; }

/* Score partie nul */
.partie-score.draw { background: #e2e3e5; color: #41464b; }

/* Score final nul */
.final-score-pill.draw { background: #6c757d; color: white; }

/* Forme dot nul (si pas déjà présent) */
.forme-dot.draw { background: #6c757d; }
.fm-dot.draw    { background: #6c757d; }

/* ================================================================
   FOOTER — AFFILIATIONS & LABELS FFTT
================================================================ */

/* ── Logos affiliations ── */
.footer-affil-logos {
    display: flex;
    gap: .6rem;
    flex-wrap: wrap;
}
.affil-logo-link {
    text-decoration: none;
    transition: transform .2s;
}
.affil-logo-link:hover { transform: translateY(-2px); }

.affil-logo {
    width: 52px; height: 52px;
    border-radius: 10px;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    gap: 1px;
    font-size: .55rem;
    font-weight: 700;
    letter-spacing: .3px;
    text-transform: uppercase;
    transition: box-shadow .2s;
}
.affil-logo:hover {
    box-shadow: 0 4px 16px rgba(255,255,255,.15);
}
.affil-logo.fftt {
    background: linear-gradient(135deg, #003189, #0050c8);
    color: white;
    border: 1px solid rgba(255,255,255,.15);
}
.affil-logo.ligue {
    background: linear-gradient(135deg, #198754, #0f5132);
    color: white;
    font-size: 1.1rem;
    border: 1px solid rgba(255,255,255,.1);
}
.affil-logo.comite {
    background: linear-gradient(135deg, #6f42c1, #4b2d8f);
    color: white;
    font-size: 1.1rem;
    border: 1px solid rgba(255,255,255,.1);
}
.affil-abbr {
    font-size: .7rem;
    font-weight: 800;
    letter-spacing: .5px;
    line-height: 1;
}
.affil-sub {
    font-size: .5rem;
    opacity: .75;
    letter-spacing: .3px;
}

/* ── Labels FFTT ── */
.footer-labels-title {
    display: flex;
    align-items: center;
    gap: .4rem;
    margin-top: .4rem;
}
.footer-labels-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .5rem;
}
.footer-label-card {
    display: flex;
    align-items: center;
    gap: .5rem;
    padding: .45rem .6rem;
    border-radius: 8px;
    border: 1px solid rgba(255,255,255,.1);
    transition: all .2s;
    cursor: default;
}
.footer-label-card:hover {
    transform: translateY(-2px);
    border-color: rgba(255,255,255,.25);
}

/* Couleurs par label */
.footer-label-card.avenir {
    background: rgba(25,135,84,.15);
    border-color: rgba(25,135,84,.3);
}
.footer-label-card.avenir .flc-icon { color: #4ade80; }

.footer-label-card.responsable {
    background: rgba(13,110,253,.15);
    border-color: rgba(13,110,253,.3);
}
.footer-label-card.responsable .flc-icon { color: #60a5fa; }

.footer-label-card.citoyen {
    background: rgba(240,180,41,.15);
    border-color: rgba(240,180,41,.3);
}
.footer-label-card.citoyen .flc-icon { color: #f0b429; }

.footer-label-card.performance {
    background: rgba(220,53,69,.15);
    border-color: rgba(220,53,69,.3);
}
.footer-label-card.performance .flc-icon { color: #f87171; }

.flc-icon {
    font-size: .9rem;
    flex-shrink: 0;
    width: 20px;
    text-align: center;
}
.flc-body { min-width: 0; }
.flc-name {
    font-size: .68rem;
    font-weight: 700;
    color: white;
    line-height: 1;
    white-space: nowrap;
}
.flc-stars {
    display: flex;
    gap: 1px;
    margin-top: 2px;
}
.flc-stars i {
    font-size: .5rem;
    color: #f0b429;
}
.flc-stars .fa-regular { opacity: .35; }

/* ── Si images officielles disponibles ── */
.footer-labels-imgs {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    align-items: center;
}
.footer-label-img {
    height: 48px;
    width: auto;
    object-fit: contain;
    filter: drop-shadow(0 2px 4px rgba(0,0,0,.3));
    transition: transform .2s;
}
.footer-label-img:hover { transform: translateY(-2px) scale(1.05); }

/* ================================================================
   PAGE HORAIRES
================================================================ */

/* ── Info cards ── */
.horaire-info-card {
    background: white;
    border-radius: 16px;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
    padding: 1.4rem 1rem;
    text-align: center;
    transition: transform .2s, box-shadow .2s;
}
.horaire-info-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(13,110,253,.1);
}
.hic-icon {
    font-size: 1.6rem;
    color: #0d6efd;
    margin-bottom: .6rem;
}
.hic-val {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.6rem;
    font-weight: 700;
    color: #0a0f2c;
    line-height: 1;
}
.hic-lbl {
    font-size: .75rem;
    color: #888;
    margin-top: .3rem;
    text-transform: uppercase;
    letter-spacing: .5px;
}

/* ── Légende ── */
.horaire-legend {
    display: flex;
    flex-wrap: wrap;
    gap: .6rem;
    padding: .8rem 1.2rem;
    background: white;
    border-radius: 12px;
    border: 1px solid #e9ecef;
}
.hl-item {
    font-size: .78rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: .3rem;
}
.hl-item.babies  i { color: #6f42c1; }
.hl-item.jeunes  i { color: #0d6efd; }
.hl-item.loisirs i { color: #198754; }
.hl-item.dept    i { color: #fd7e14; }
.hl-item.national i { color: #dc3545; }
.hl-item.compet  i { color: #f0b429; }

/* ── Carte jour ── */
.jour-card {
    background: white;
    border-radius: 16px;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
    overflow: hidden;
    display: flex;
    align-items: stretch;
}

/* En-tête jour (bande colorée à gauche) */
.jour-header {
    width: 90px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    padding: 1rem .5rem;
    text-align: center;
}
.jour-nom { display: flex; flex-direction: column; align-items: center; }
.jour-lettre {
    font-family: 'Rajdhani', sans-serif;
    font-size: 2.2rem;
    font-weight: 700;
    color: white;
    line-height: 1;
}
.jour-full {
    font-size: .65rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: rgba(255,255,255,.8);
    margin-top: .1rem;
}

/* Couleurs par jour */
.jour-header.lundi    { background: linear-gradient(160deg, #0d6efd, #0a58ca); }
.jour-header.mardi    { background: linear-gradient(160deg, #6f42c1, #58359a); }
.jour-header.mercredi { background: linear-gradient(160deg, #0dcaf0, #0aa2c0); }
.jour-header.jeudi    { background: linear-gradient(160deg, #198754, #146c43); }
.jour-header.vendredi { background: linear-gradient(160deg, #fd7e14, #ca6510); }
.jour-header.samedi   { background: linear-gradient(160deg, #dc3545, #b02a37); }
.jour-header.dimanche { background: linear-gradient(160deg, #f0b429, #cc9520); }

/* Créneaux */
.jour-creneaux {
    flex: 1;
    display: flex;
    flex-wrap: wrap;
    gap: 0;
    padding: .5rem;
    align-content: flex-start;
}
.creneau {
    display: flex;
    align-items: center;
    gap: .8rem;
    padding: .55rem .8rem;
    margin: .2rem;
    border-radius: 10px;
    border-left: 3px solid;
    flex: 1;
    min-width: 260px;
    transition: transform .15s;
}
.creneau:hover { transform: translateX(3px); }

/* Couleurs créneaux */
.creneau.babies  { background: rgba(111,66,193,.07); border-color: #6f42c1; }
.creneau.jeunes  { background: rgba(13,110,253,.07);  border-color: #0d6efd; }
.creneau.loisirs { background: rgba(25,135,84,.07);   border-color: #198754; }
.creneau.dept    { background: rgba(253,126,20,.07);  border-color: #fd7e14; }
.creneau.national{ background: rgba(220,53,69,.07);   border-color: #dc3545; }
.creneau.compet  { background: rgba(240,180,41,.07);  border-color: #f0b429; }

.cr-heure {
    font-family: 'Rajdhani', sans-serif;
    font-size: .95rem;
    font-weight: 700;
    color: #0a0f2c;
    white-space: nowrap;
    min-width: 110px;
    flex-shrink: 0;
}
.cr-label {
    font-size: .85rem;
    color: #444;
    flex: 1;
}
.cr-badge {
    font-size: .65rem;
    font-weight: 700;
    padding: .15rem .55rem;
    border-radius: 10px;
    background: #e9ecef;
    color: #555;
    white-space: nowrap;
    flex-shrink: 0;
    text-transform: uppercase;
    letter-spacing: .4px;
}
.cr-badge.baby   { background: #e9d8fd; color: #6f42c1; }
.cr-badge.compet { background: #fff3cd; color: #856404; }

/* ── Note bas de page ── */
.horaire-note {
    background: #f0f4ff;
    border: 1px solid #d0deff;
    border-radius: 12px;
    padding: .9rem 1.2rem;
    font-size: .85rem;
    color: #444;
}
.horaire-note a { color: #0d6efd; }

/* ── Responsive ── */
@media (max-width: 575px) {
    .jour-card { flex-direction: column; }
    .jour-header {
        width: 100%;
        flex-direction: row;
        gap: .8rem;
        padding: .7rem 1rem;
        justify-content: flex-start;
    }
    .jour-lettre { font-size: 1.5rem; }
    .jour-full { font-size: .7rem; margin-top: 0; }
    .cr-heure { min-width: 90px; font-size: .85rem; }
    .creneau { min-width: 200px; }
}

/* ================================================================
   PAGE TARIFS & LICENCES
================================================================ */

/* ── Titre de section ── */
.tarifs-section-title { border-bottom: 2px solid #f0f2f5; padding-bottom: .8rem; }
.tst-h {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.4rem; font-weight: 700; color: #0a0f2c; margin: 0;
}

/* ── Carte tarif ── */
.tarif-card {
    background: white;
    border-radius: 20px;
    border: 2px solid #e9ecef;
    padding: 1.8rem 1.4rem;
    text-align: center;
    height: 100%;
    display: flex; flex-direction: column; gap: .6rem;
    position: relative; overflow: hidden;
    transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.tarif-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 16px 48px rgba(0,0,0,.1);
}

/* Couleurs par catégorie */
.tarif-card.baby1   { border-color: #d8b4fe; }
.tarif-card.baby1:hover { border-color: #a855f7; box-shadow: 0 16px 48px rgba(168,85,247,.15); }
.tarif-card.baby2   { border-color: #c4b5fd; }
.tarif-card.baby2:hover { border-color: #8b5cf6; box-shadow: 0 16px 48px rgba(139,92,246,.15); }
.tarif-card.jeunes  { border-color: #bfdbfe; }
.tarif-card.jeunes:hover  { border-color: #3b82f6; box-shadow: 0 16px 48px rgba(59,130,246,.15); }
.tarif-card.seniors { border-color: #fca5a5; }
.tarif-card.seniors:hover { border-color: #ef4444; box-shadow: 0 16px 48px rgba(239,68,68,.15); }
.tarif-card.loisir  { border-color: #bbf7d0; }
.tarif-card.loisir:hover  { border-color: #22c55e; box-shadow: 0 16px 48px rgba(34,197,94,.15); }
.tarif-card.loisir-plus { border-color: #a7f3d0; }
.tarif-card.loisir-plus:hover { border-color: #10b981; box-shadow: 0 16px 48px rgba(16,185,129,.15); }
.tarif-card.exterieur { border-color: #fed7aa; }
.tarif-card.exterieur:hover { border-color: #f97316; box-shadow: 0 16px 48px rgba(249,115,22,.15); }

/* Carte featured */
.tarif-card.featured {
    border-color: #f0b429;
    background: linear-gradient(160deg, #fff 80%, #fffbeb 100%);
}
.tarif-card.featured:hover {
    border-color: #d97706;
    box-shadow: 0 16px 48px rgba(240,180,41,.2);
}
.tc-badge-featured {
    position: absolute; top: 12px; right: 12px;
    background: linear-gradient(135deg, #f0b429, #d97706);
    color: white; font-size: .65rem; font-weight: 700;
    padding: .2rem .6rem; border-radius: 20px;
    text-transform: uppercase; letter-spacing: .5px;
}

/* Ribbon */
.tc-ribbon {
    position: absolute; top: 12px; left: 12px;
    background: #e9d8fd; color: #6f42c1;
    font-size: .65rem; font-weight: 700;
    padding: .2rem .6rem; border-radius: 20px;
    text-transform: uppercase; letter-spacing: .5px;
}

/* Icône */
.tc-icon {
    font-size: 2.2rem; margin: .4rem 0 .2rem;
}
.tarif-card.baby1   .tc-icon { color: #a855f7; }
.tarif-card.baby2   .tc-icon { color: #8b5cf6; }
.tarif-card.jeunes  .tc-icon { color: #3b82f6; }
.tarif-card.seniors .tc-icon { color: #ef4444; }
.tarif-card.loisir  .tc-icon { color: #22c55e; }
.tarif-card.loisir-plus .tc-icon { color: #10b981; }
.tarif-card.exterieur .tc-icon { color: #f97316; }

/* Catégorie */
.tc-categorie {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1rem; font-weight: 700;
    color: #0a0f2c; line-height: 1.3;
    min-height: 2.6rem;
    display: flex; align-items: center; justify-content: center;
}

/* Prix */
.tc-prix {
    display: flex; align-items: flex-start;
    justify-content: center; gap: .1rem;
    margin: .4rem 0 .2rem;
}
.tc-montant {
    font-family: 'Rajdhani', sans-serif;
    font-size: 3.2rem; font-weight: 700;
    color: #0a0f2c; line-height: 1;
}
.tc-euro {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.4rem; font-weight: 600;
    color: #888; margin-top: .4rem;
}

/* Naissance */
.tc-naissance {
    font-size: .78rem; color: #888;
    background: #f8f9fa; border-radius: 20px;
    padding: .25rem .8rem; display: inline-block;
}

/* Option (critérium) */
.tc-option {
    font-size: .82rem; color: #555;
    background: #fffbeb;
    border: 1px solid #fde68a;
    border-radius: 8px; padding: .4rem .7rem;
    text-align: left;
}

/* Détails */
.tc-details {
    list-style: none; padding: 0; margin: .4rem 0 0;
    text-align: left;
}
.tc-details li {
    font-size: .82rem; color: #555;
    padding: .25rem 0;
    border-bottom: 1px solid #f0f2f5;
    display: flex; align-items: flex-start; gap: .3rem;
}
.tc-details li:last-child { border-bottom: none; }

/* ── Réductions ── */
.reductions-card {
    background: white;
    border-radius: 20px;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 16px rgba(0,0,0,.05);
    padding: 1.8rem;
}
.rc-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.2rem; font-weight: 700;
    color: #0a0f2c; margin-bottom: 1.2rem;
}
.reduction-item {
    display: flex; align-items: center; gap: 1rem;
    padding: .8rem 1rem;
    background: #f8f9fa; border-radius: 12px;
    border: 1px solid #e9ecef;
    height: 100%;
    transition: transform .2s;
}
.reduction-item:hover { transform: translateY(-2px); }
.ri-icon {
    width: 44px; height: 44px; border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.2rem; flex-shrink: 0;
}
.ri-icon.famille  { background: #ede9fe; color: #7c3aed; }
.ri-icon.foyer    { background: #dbeafe; color: #2563eb; }
.ri-icon.emploi   { background: #dcfce7; color: #16a34a; }
.ri-icon.passsport{ background: #fef3c7; color: #d97706; }
.ri-montant {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.3rem; font-weight: 700; color: #0a0f2c;
}
.ri-label { font-size: .78rem; color: #666; line-height: 1.3; }

/* ── Documents ── */
.documents-card {
    background: white;
    border-radius: 20px;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 16px rgba(0,0,0,.05);
    padding: 1.8rem;
}
.dc-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.2rem; font-weight: 700;
    color: #0a0f2c; margin-bottom: 1.2rem;
}
.doc-link {
    display: flex; align-items: center; gap: .8rem;
    padding: .9rem 1rem;
    background: #f8f9fa;
    border: 1.5px solid #e9ecef;
    border-radius: 12px;
    text-decoration: none;
    color: inherit;
    transition: all .2s;
    height: 100%;
}
.doc-link:hover {
    background: #e8f0fe;
    border-color: #0d6efd;
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(13,110,253,.12);
}
.dl-icon {
    width: 40px; height: 40px; border-radius: 10px;
    background: #fee2e2; color: #dc2626;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.1rem; flex-shrink: 0;
}
.dl-body { flex: 1; }
.dl-name { font-weight: 700; font-size: .9rem; color: #0a0f2c; }
.dl-desc { font-size: .75rem; color: #888; }
.dl-arrow {
    color: #0d6efd; font-size: .9rem;
    transition: transform .2s;
}
.doc-link:hover .dl-arrow { transform: translateY(3px); }

/* ── Paiement ── */
.paiement-card {
    background: white;
    border-radius: 20px;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 16px rgba(0,0,0,.05);
    padding: 1.8rem;
}
.pc-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.2rem; font-weight: 700;
    color: #0a0f2c; margin-bottom: 1.2rem;
}
.paiement-item {
    text-align: center;
    padding: 1.2rem;
    background: #f8f9fa;
    border-radius: 14px;
    border: 1px solid #e9ecef;
    height: 100%;
    transition: transform .2s;
}
.paiement-item:hover { transform: translateY(-3px); }
.pi-label {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1rem; font-weight: 700; color: #0a0f2c;
    margin-bottom: .3rem;
}
.pi-desc { font-size: .8rem; color: #666; }
.pi-desc a { color: #0d6efd; word-break: break-all; }
.paiement-note {
    background: #f0f4ff;
    border: 1px solid #d0deff;
    border-radius: 10px;
    padding: .8rem 1rem;
    font-size: .82rem; color: #444;
}

/* ── Responsive ── */
@media (max-width: 575px) {
    .tc-montant { font-size: 2.4rem; }
    .tarif-card { padding: 1.4rem 1rem; }
}

/* ================================================================
   PAGE ACTUALITÉS
================================================================ */

/* ── Toolbar ── */
.actus-toolbar {
    display: flex;
    flex-direction: column;
    gap: .8rem;
}

/* Barre de recherche */
.actus-search {
    position: relative;
    display: flex;
    align-items: center;
}
.as-icon {
    position: absolute; left: 1rem;
    color: #adb5bd; font-size: .9rem;
    pointer-events: none;
}
.as-input {
    width: 100%;
    padding: .75rem 2.8rem .75rem 2.6rem;
    border: 1.5px solid #dee2e6;
    border-radius: 50px;
    font-size: .9rem;
    background: white;
    transition: border-color .2s, box-shadow .2s;
    outline: none;
}
.as-input:focus {
    border-color: #0d6efd;
    box-shadow: 0 0 0 3px rgba(13,110,253,.1);
}
.as-clear {
    position: absolute; right: 1rem;
    background: none; border: none;
    color: #adb5bd; cursor: pointer;
    font-size: .9rem; padding: 0;
    transition: color .2s;
}
.as-clear:hover { color: #dc3545; }

/* Filtres */
.actus-filters {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
}
.af-btn {
    display: inline-flex; align-items: center;
    padding: .45rem 1rem;
    border-radius: 50px;
    border: 1.5px solid #dee2e6;
    background: white;
    font-size: .82rem; font-weight: 600;
    color: #666; cursor: pointer;
    transition: all .2s;
    white-space: nowrap;
}
.af-btn:hover { border-color: #0d6efd; color: #0d6efd; }
.af-btn.active { background: #0d6efd; border-color: #0d6efd; color: white; }
.af-btn.club.active   { background: #0d6efd; border-color: #0d6efd; }
.af-btn.fftt.active   { background: #d97706; border-color: #d97706; }
.af-btn.ligue.active  { background: #16a34a; border-color: #16a34a; }
.af-btn.presse.active { background: #7c3aed; border-color: #7c3aed; }

/* Compteur */
.actus-count {
    font-size: .8rem; color: #aaa;
}

/* ── Grille articles ── */
.actus-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.4rem;
}
@media (max-width: 575px) {
    .actus-grid { grid-template-columns: 1fr; }
}

/* ── Carte article ── */
.actu-card {
    background: white;
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
    transition: transform .3s ease, box-shadow .3s ease;
    display: flex; flex-direction: column;
}
.actu-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 12px 36px rgba(0,0,0,.1);
}
.actu-card[style*="display:none"] { display: none !important; }

.actu-card-link {
    text-decoration: none;
    color: inherit;
    display: flex; flex-direction: column;
    height: 100%;
}

/* Image */
.actu-img-wrap {
    position: relative;
    height: 200px;
    overflow: hidden;
    background: linear-gradient(135deg, #e8f0fe, #f0f4ff);
    flex-shrink: 0;
}
.actu-img {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform .5s ease;
}
.actu-card:hover .actu-img { transform: scale(1.05); }
.actu-img-ph {
    position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
    color: #c8d6f0;
}
.actu-img-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(to bottom, transparent 50%, rgba(0,0,0,.3) 100%);
}

/* Badge catégorie */
.actu-cat-badge {
    position: absolute; top: 12px; left: 12px;
    z-index: 2;
    font-size: .68rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .6px;
    padding: .25rem .75rem; border-radius: 20px;
    box-shadow: 0 2px 8px rgba(0,0,0,.15);
}
.actu-cat-badge.club   { background: #0d6efd; color: white; }
.actu-cat-badge.fftt   { background: #f0b429; color: #1a1a2e; }
.actu-cat-badge.ligue  { background: #16a34a; color: white; }
.actu-cat-badge.presse { background: #7c3aed; color: white; }

/* Corps */
.actu-body {
    padding: 1.1rem 1.2rem 1.2rem;
    display: flex; flex-direction: column;
    gap: .5rem; flex: 1;
}
.actu-meta { display: flex; align-items: center; gap: .8rem; }
.actu-date { font-size: .72rem; color: #aaa; }
.actu-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.05rem; font-weight: 700;
    color: #0a0f2c; line-height: 1.3;
    margin: 0;
    transition: color .2s;
}
.actu-card:hover .actu-title { color: #0d6efd; }
.actu-excerpt {
    font-size: .83rem; color: #6c757d;
    line-height: 1.55; flex: 1;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.actu-read-more {
    display: inline-flex; align-items: center; gap: .3rem;
    font-size: .8rem; font-weight: 600;
    color: #0d6efd; margin-top: auto;
    padding-top: .6rem;
    border-top: 1px solid #f0f2f5;
    transition: gap .2s;
}
.actu-card:hover .actu-read-more { gap: .6rem; }

/* Message vide */
.actus-empty {
    text-align: center;
    padding: 3rem 1rem;
    color: #aaa;
}

/* ── Pagination ── */
.actus-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
}
.ap-btn {
    width: 40px; height: 40px;
    border-radius: 50%;
    border: 1.5px solid #dee2e6;
    background: white;
    color: #555; cursor: pointer;
    font-size: .85rem;
    transition: all .2s;
    display: flex; align-items: center; justify-content: center;
}
.ap-btn:hover:not(:disabled) {
    background: #0d6efd; border-color: #0d6efd; color: white;
}
.ap-btn:disabled { opacity: .35; cursor: default; }
.ap-pages { display: flex; gap: .4rem; }
.ap-page {
    width: 40px; height: 40px;
    border-radius: 50%;
    border: 1.5px solid #dee2e6;
    background: white;
    color: #555; cursor: pointer;
    font-size: .88rem; font-weight: 600;
    transition: all .2s;
    display: flex; align-items: center; justify-content: center;
}
.ap-page.active {
    background: #0d6efd; border-color: #0d6efd; color: white;
}
.ap-page:hover:not(.active) {
    border-color: #0d6efd; color: #0d6efd;
}

/* ════════════════════════════════
   SIDEBAR
════════════════════════════════ */
.actus-sidebar {
    position: sticky;
    top: 80px;
    display: flex; flex-direction: column; gap: 1.4rem;
}
.sidebar-widget {
    background: white;
    border-radius: 16px;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
    padding: 1.4rem;
}
.sw-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.05rem; font-weight: 700;
    color: #0a0f2c;
    margin-bottom: 1rem;
    padding-bottom: .6rem;
    border-bottom: 2px solid #f0b429;
    display: flex; align-items: center;
}

/* Recherche sidebar */
.sw-search {
    display: flex; gap: .5rem;
}
.sw-search-input {
    flex: 1;
    padding: .6rem .9rem;
    border: 1.5px solid #dee2e6;
    border-radius: 8px;
    font-size: .85rem; outline: none;
    transition: border-color .2s;
}
.sw-search-input:focus { border-color: #0d6efd; }
.sw-search-btn {
    padding: .6rem .9rem;
    background: #0d6efd; border: none;
    border-radius: 8px; color: white;
    cursor: pointer; transition: background .2s;
}
.sw-search-btn:hover { background: #0a58ca; }

/* Catégories sidebar */
.sw-categories {
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-direction: column; gap: .4rem;
}
.swc-btn {
    width: 100%;
    display: flex; align-items: center; gap: .7rem;
    padding: .6rem .8rem;
    background: #f8f9fa;
    border: 1.5px solid #e9ecef;
    border-radius: 10px;
    cursor: pointer; text-align: left;
    transition: all .2s;
    font-size: .85rem;
}
.swc-btn:hover { border-color: #0d6efd; background: #e8f0fe; }
.swc-btn.active { background: #e8f0fe; border-color: #0d6efd; }
.swc-icon {
    width: 28px; height: 28px; border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    font-size: .75rem; flex-shrink: 0;
}
.swc-icon.all    { background: #e9ecef;   color: #555; }
.swc-icon.club   { background: #dbeafe;   color: #0d6efd; }
.swc-icon.fftt   { background: #fef3c7;   color: #d97706; }
.swc-icon.ligue  { background: #dcfce7;   color: #16a34a; }
.swc-icon.presse { background: #ede9fe;   color: #7c3aed; }
.swc-label { flex: 1; font-weight: 600; color: #333; }
.swc-count {
    background: #e9ecef; color: #666;
    font-size: .7rem; font-weight: 700;
    padding: .1rem .5rem; border-radius: 10px;
}
.swc-btn.active .swc-count { background: #0d6efd; color: white; }

/* Articles récents */
.sw-recents {
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-direction: column; gap: .6rem;
}
.sw-recent-item {
    display: flex; gap: .7rem; align-items: flex-start;
}
.sri-img {
    width: 56px; height: 48px; border-radius: 8px;
    background: linear-gradient(135deg, #e8f0fe, #f0f4ff);
    overflow: hidden; flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    color: #c8d6f0; font-size: .8rem;
}
.sri-img img { width: 100%; height: 100%; object-fit: cover; }
.sri-body { flex: 1; min-width: 0; }
.sri-title {
    font-size: .8rem; font-weight: 600;
    color: #0a0f2c; line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-decoration: none;
    transition: color .2s;
}
.sri-title:hover { color: #0d6efd; }
.sri-date { font-size: .7rem; color: #aaa; margin-top: .2rem; }

/* Réseaux sociaux */
.sw-socials {
    display: flex; flex-direction: column; gap: .5rem;
}
.sws-btn {
    display: flex; align-items: center; gap: .8rem;
    padding: .65rem 1rem;
    border-radius: 10px;
    border: 1.5px solid #e9ecef;
    text-decoration: none;
    font-size: .85rem; font-weight: 600;
    color: #333; transition: all .2s;
}
.sws-btn:hover { transform: translateX(4px); }
.sws-btn.facebook { color: #1877f2; }
.sws-btn.facebook:hover { background: #e8f0fe; border-color: #1877f2; }
.sws-btn.twitter { color: #000; }
.sws-btn.twitter:hover { background: #f5f5f5; border-color: #000; }
.sws-btn.youtube { color: #dc2626; }
.sws-btn.youtube:hover { background: #fee2e2; border-color: #dc2626; }

/* ================================================================
   PAGE ACTUALITÉS
================================================================ */

/* ── Toolbar ── */
.actus-toolbar {
    display: flex;
    flex-direction: column;
    gap: .8rem;
}

/* Barre de recherche */
.actus-search {
    position: relative;
    display: flex;
    align-items: center;
}
.as-icon {
    position: absolute; left: 1rem;
    color: #adb5bd; font-size: .9rem;
    pointer-events: none;
}
.as-input {
    width: 100%;
    padding: .75rem 2.8rem .75rem 2.6rem;
    border: 1.5px solid #dee2e6;
    border-radius: 50px;
    font-size: .9rem;
    background: white;
    transition: border-color .2s, box-shadow .2s;
    outline: none;
}
.as-input:focus {
    border-color: #0d6efd;
    box-shadow: 0 0 0 3px rgba(13,110,253,.1);
}
.as-clear {
    position: absolute; right: 1rem;
    background: none; border: none;
    color: #adb5bd; cursor: pointer;
    font-size: .9rem; padding: 0;
    transition: color .2s;
}
.as-clear:hover { color: #dc3545; }

/* Filtres */
.actus-filters {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
}
.af-btn {
    display: inline-flex; align-items: center;
    padding: .45rem 1rem;
    border-radius: 50px;
    border: 1.5px solid #dee2e6;
    background: white;
    font-size: .82rem; font-weight: 600;
    color: #666; cursor: pointer;
    transition: all .2s;
    white-space: nowrap;
}
.af-btn:hover { border-color: #0d6efd; color: #0d6efd; }
.af-btn.active { background: #0d6efd; border-color: #0d6efd; color: white; }
.af-btn.club.active   { background: #0d6efd; border-color: #0d6efd; }
.af-btn.fftt.active   { background: #d97706; border-color: #d97706; }
.af-btn.ligue.active  { background: #16a34a; border-color: #16a34a; }
.af-btn.presse.active { background: #7c3aed; border-color: #7c3aed; }

/* Compteur */
.actus-count {
    font-size: .8rem; color: #aaa;
}

/* ── Grille articles ── */
.actus-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.4rem;
}
@media (max-width: 575px) {
    .actus-grid { grid-template-columns: 1fr; }
}

/* ── Carte article ── */
.actu-card {
    background: white;
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
    transition: transform .3s ease, box-shadow .3s ease;
    display: flex; flex-direction: column;
}
.actu-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 12px 36px rgba(0,0,0,.1);
}
.actu-card[style*="display:none"] { display: none !important; }

.actu-card-link {
    text-decoration: none;
    color: inherit;
    display: flex; flex-direction: column;
    height: 100%;
}

/* Image */
.actu-img-wrap {
    position: relative;
    height: 200px;
    overflow: hidden;
    background: linear-gradient(135deg, #e8f0fe, #f0f4ff);
    flex-shrink: 0;
}
.actu-img {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform .5s ease;
}
.actu-card:hover .actu-img { transform: scale(1.05); }
.actu-img-ph {
    position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
    color: #c8d6f0;
}
.actu-img-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(to bottom, transparent 50%, rgba(0,0,0,.3) 100%);
}

/* Badge catégorie */
.actu-cat-badge {
    position: absolute; top: 12px; left: 12px;
    z-index: 2;
    font-size: .68rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .6px;
    padding: .25rem .75rem; border-radius: 20px;
    box-shadow: 0 2px 8px rgba(0,0,0,.15);
}
.actu-cat-badge.club   { background: #0d6efd; color: white; }
.actu-cat-badge.fftt   { background: #f0b429; color: #1a1a2e; }
.actu-cat-badge.ligue  { background: #16a34a; color: white; }
.actu-cat-badge.presse { background: #7c3aed; color: white; }

/* Corps */
.actu-body {
    padding: 1.1rem 1.2rem 1.2rem;
    display: flex; flex-direction: column;
    gap: .5rem; flex: 1;
}
.actu-meta { display: flex; align-items: center; gap: .8rem; }
.actu-date { font-size: .72rem; color: #aaa; }
.actu-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.05rem; font-weight: 700;
    color: #0a0f2c; line-height: 1.3;
    margin: 0;
    transition: color .2s;
}
.actu-card:hover .actu-title { color: #0d6efd; }
.actu-excerpt {
    font-size: .83rem; color: #6c757d;
    line-height: 1.55; flex: 1;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.actu-read-more {
    display: inline-flex; align-items: center; gap: .3rem;
    font-size: .8rem; font-weight: 600;
    color: #0d6efd; margin-top: auto;
    padding-top: .6rem;
    border-top: 1px solid #f0f2f5;
    transition: gap .2s;
}
.actu-card:hover .actu-read-more { gap: .6rem; }

/* Message vide */
.actus-empty {
    text-align: center;
    padding: 3rem 1rem;
    color: #aaa;
}

/* ── Pagination ── */
.actus-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
}
.ap-btn {
    width: 40px; height: 40px;
    border-radius: 50%;
    border: 1.5px solid #dee2e6;
    background: white;
    color: #555; cursor: pointer;
    font-size: .85rem;
    transition: all .2s;
    display: flex; align-items: center; justify-content: center;
}
.ap-btn:hover:not(:disabled) {
    background: #0d6efd; border-color: #0d6efd; color: white;
}
.ap-btn:disabled { opacity: .35; cursor: default; }
.ap-pages { display: flex; gap: .4rem; }
.ap-page {
    width: 40px; height: 40px;
    border-radius: 50%;
    border: 1.5px solid #dee2e6;
    background: white;
    color: #555; cursor: pointer;
    font-size: .88rem; font-weight: 600;
    transition: all .2s;
    display: flex; align-items: center; justify-content: center;
}
.ap-page.active {
    background: #0d6efd; border-color: #0d6efd; color: white;
}
.ap-page:hover:not(.active) {
    border-color: #0d6efd; color: #0d6efd;
}

/* ════════════════════════════════
   SIDEBAR
════════════════════════════════ */
.actus-sidebar {
    position: sticky;
    top: 80px;
    display: flex; flex-direction: column; gap: 1.4rem;
}
.sidebar-widget {
    background: white;
    border-radius: 16px;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
    padding: 1.4rem;
}
.sw-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.05rem; font-weight: 700;
    color: #0a0f2c;
    margin-bottom: 1rem;
    padding-bottom: .6rem;
    border-bottom: 2px solid #f0b429;
    display: flex; align-items: center;
}

/* Recherche sidebar */
.sw-search {
    display: flex; gap: .5rem;
}
.sw-search-input {
    flex: 1;
    padding: .6rem .9rem;
    border: 1.5px solid #dee2e6;
    border-radius: 8px;
    font-size: .85rem; outline: none;
    transition: border-color .2s;
}
.sw-search-input:focus { border-color: #0d6efd; }
.sw-search-btn {
    padding: .6rem .9rem;
    background: #0d6efd; border: none;
    border-radius: 8px; color: white;
    cursor: pointer; transition: background .2s;
}
.sw-search-btn:hover { background: #0a58ca; }

/* Catégories sidebar */
.sw-categories {
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-direction: column; gap: .4rem;
}
.swc-btn {
    width: 100%;
    display: flex; align-items: center; gap: .7rem;
    padding: .6rem .8rem;
    background: #f8f9fa;
    border: 1.5px solid #e9ecef;
    border-radius: 10px;
    cursor: pointer; text-align: left;
    transition: all .2s;
    font-size: .85rem;
}
.swc-btn:hover { border-color: #0d6efd; background: #e8f0fe; }
.swc-btn.active { background: #e8f0fe; border-color: #0d6efd; }
.swc-icon {
    width: 28px; height: 28px; border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    font-size: .75rem; flex-shrink: 0;
}
.swc-icon.all    { background: #e9ecef;   color: #555; }
.swc-icon.club   { background: #dbeafe;   color: #0d6efd; }
.swc-icon.fftt   { background: #fef3c7;   color: #d97706; }
.swc-icon.ligue  { background: #dcfce7;   color: #16a34a; }
.swc-icon.presse { background: #ede9fe;   color: #7c3aed; }
.swc-label { flex: 1; font-weight: 600; color: #333; }
.swc-count {
    background: #e9ecef; color: #666;
    font-size: .7rem; font-weight: 700;
    padding: .1rem .5rem; border-radius: 10px;
}
.swc-btn.active .swc-count { background: #0d6efd; color: white; }

/* Articles récents */
.sw-recents {
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-direction: column; gap: .6rem;
}
.sw-recent-item {
    display: flex; gap: .7rem; align-items: flex-start;
}
.sri-img {
    width: 56px; height: 48px; border-radius: 8px;
    background: linear-gradient(135deg, #e8f0fe, #f0f4ff);
    overflow: hidden; flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    color: #c8d6f0; font-size: .8rem;
}
.sri-img img { width: 100%; height: 100%; object-fit: cover; }
.sri-body { flex: 1; min-width: 0; }
.sri-title {
    font-size: .8rem; font-weight: 600;
    color: #0a0f2c; line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-decoration: none;
    transition: color .2s;
}
.sri-title:hover { color: #0d6efd; }
.sri-date { font-size: .7rem; color: #aaa; margin-top: .2rem; }

/* Réseaux sociaux */
.sw-socials {
    display: flex; flex-direction: column; gap: .5rem;
}
.sws-btn {
    display: flex; align-items: center; gap: .8rem;
    padding: .65rem 1rem;
    border-radius: 10px;
    border: 1.5px solid #e9ecef;
    text-decoration: none;
    font-size: .85rem; font-weight: 600;
    color: #333; transition: all .2s;
}
.sws-btn:hover { transform: translateX(4px); }
.sws-btn.facebook { color: #1877f2; }
.sws-btn.facebook:hover { background: #e8f0fe; border-color: #1877f2; }
.sws-btn.twitter { color: #000; }
.sws-btn.twitter:hover { background: #f5f5f5; border-color: #000; }
.sws-btn.youtube { color: #dc2626; }
.sws-btn.youtube:hover { background: #fee2e2; border-color: #dc2626; }

/* ================================================================
   PAGE ACTUALITÉS — CSS COMPLET
================================================================ */

/* ── Toolbar ── */
.actus-toolbar {
    display: flex;
    flex-direction: column;
    gap: .8rem;
}

/* Barre de recherche */
.actus-search {
    position: relative;
    display: flex;
    align-items: center;
}
.as-icon {
    position: absolute; left: 1rem;
    color: #adb5bd; font-size: .9rem;
    pointer-events: none;
}
.as-input {
    width: 100%;
    padding: .75rem 2.8rem .75rem 2.6rem;
    border: 1.5px solid #dee2e6;
    border-radius: 50px;
    font-size: .9rem;
    background: white;
    transition: border-color .2s, box-shadow .2s;
    outline: none;
}
.as-input:focus {
    border-color: #0d6efd;
    box-shadow: 0 0 0 3px rgba(13,110,253,.1);
}
.as-clear {
    position: absolute; right: 1rem;
    background: none; border: none;
    color: #adb5bd; cursor: pointer;
    font-size: .9rem; padding: 0;
    transition: color .2s;
}
.as-clear:hover { color: #dc3545; }

/* ── Onglets actus ── */
.actus-tabs-nav {
    display: flex;
    gap: .4rem;
    flex-wrap: wrap;
    border-bottom: 2px solid #e9ecef;
    padding-bottom: 0;
}
.atab-btn {
    display: inline-flex; align-items: center;
    padding: .7rem 1.1rem;
    background: none; border: none;
    font-family: 'Rajdhani', sans-serif;
    font-size: .95rem; font-weight: 600;
    color: #888; cursor: pointer;
    white-space: nowrap;
    position: relative;
    transition: color .2s;
    border-radius: 8px 8px 0 0;
}
.atab-btn::after {
    content: '';
    position: absolute; bottom: -2px;
    left: 0; right: 0; height: 3px;
    background: #0d6efd;
    border-radius: 2px 2px 0 0;
    transform: scaleX(0);
    transition: transform .2s;
}
.atab-btn.active { color: #0d6efd; }
.atab-btn.active::after { transform: scaleX(1); }
.atab-btn:hover { color: #0d6efd; background: #f0f4ff; }

/* Couleurs par onglet */
.atab-btn[data-tab="fftt"].active        { color: #d97706; }
.atab-btn[data-tab="fftt"].active::after { background: #d97706; }
.atab-btn[data-tab="ligue"].active        { color: #16a34a; }
.atab-btn[data-tab="ligue"].active::after { background: #16a34a; }
.atab-btn[data-tab="comite"].active        { color: #ca8a04; }
.atab-btn[data-tab="comite"].active::after { background: #ca8a04; }
.atab-btn[data-tab="presse"].active        { color: #7c3aed; }
.atab-btn[data-tab="presse"].active::after { background: #7c3aed; }

/* Panes */
.atab-pane { display: none; }
.atab-pane.active { display: block; }

/* ── Compteur résultats ── */
.actus-count {
    font-size: .8rem;
    color: #aaa;
}

/* ── Grille articles ── */
.actus-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.4rem;
}
@media (max-width: 575px) {
    .actus-grid { grid-template-columns: 1fr; }
}

/* ── Carte article ── */
.actu-card {
    background: white;
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
    transition: transform .3s ease, box-shadow .3s ease;
    display: flex;
    flex-direction: column;
}
.actu-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 12px 36px rgba(0,0,0,.1);
}

.actu-card-link {
    text-decoration: none;
    color: inherit;
    display: flex;
    flex-direction: column;
    height: 100%;
}

/* Zone image */
.actu-img-wrap {
    position: relative;
    height: 200px;
    overflow: hidden;
    background: linear-gradient(135deg, #e8f0fe, #f0f4ff);
    flex-shrink: 0;
}
.actu-img,
.rss-img {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform .5s ease;
}
.actu-card:hover .actu-img,
.actu-card:hover .rss-img { transform: scale(1.05); }

.actu-img-ph {
    position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
    color: #c8d6f0;
}
.actu-img-ph.rss-ph {
    background: linear-gradient(135deg, #f8f9fa, #e9ecef);
    color: #adb5bd;
}
.actu-img-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(to bottom, transparent 50%, rgba(0,0,0,.3) 100%);
}

/* Badge catégorie */
.actu-cat-badge {
    position: absolute; top: 12px; left: 12px;
    z-index: 2;
    font-size: .68rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .6px;
    padding: .25rem .75rem; border-radius: 20px;
    box-shadow: 0 2px 8px rgba(0,0,0,.15);
}
.actu-cat-badge.club   { background: #0d6efd; color: white; }
.actu-cat-badge.fftt   { background: #d97706; color: white; }
.actu-cat-badge.ligue  { background: #16a34a; color: white; }
.actu-cat-badge.comite { background: #ca8a04; color: white; }
.actu-cat-badge.presse { background: #7c3aed; color: white; }

/* Icône lien externe (cartes RSS) */
.rss-external-icon {
    position: absolute; bottom: 10px; right: 10px;
    z-index: 2;
    width: 28px; height: 28px; border-radius: 50%;
    background: rgba(255,255,255,.8);
    display: flex; align-items: center; justify-content: center;
    font-size: .7rem; color: #555;
}

/* Corps carte */
.actu-body {
    padding: 1.1rem 1.2rem 1.2rem;
    display: flex; flex-direction: column;
    gap: .5rem; flex: 1;
}
.actu-meta {
    display: flex; align-items: center;
    flex-wrap: wrap; gap: .5rem;
}
.actu-date { font-size: .72rem; color: #aaa; }

.rss-source-tag {
    font-size: .68rem; font-weight: 600;
    background: #f0f2f5; color: #888;
    padding: .1rem .5rem; border-radius: 8px;
    max-width: 140px;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

.actu-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.05rem; font-weight: 700;
    color: #0a0f2c; line-height: 1.3;
    margin: 0;
    transition: color .2s;
}
.actu-card:hover .actu-title { color: #0d6efd; }

.actu-excerpt {
    font-size: .83rem; color: #6c757d;
    line-height: 1.55; flex: 1;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.actu-read-more {
    display: inline-flex; align-items: center; gap: .3rem;
    font-size: .8rem; font-weight: 600;
    color: #0d6efd; margin-top: auto;
    padding-top: .6rem;
    border-top: 1px solid #f0f2f5;
    transition: gap .2s;
}
.actu-card:hover .actu-read-more { gap: .6rem; }

/* Message vide */
.actus-empty {
    text-align: center;
    padding: 3rem 1rem;
    color: #aaa;
}

/* Flux indisponible */
.rss-unavailable {
    text-align: center;
    padding: 3rem 1rem;
    background: #f8f9fa;
    border-radius: 16px;
    border: 1px dashed #dee2e6;
    color: #aaa;
}

/* ── Pagination ── */
.actus-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
}
.ap-btn {
    width: 40px; height: 40px;
    border-radius: 50%;
    border: 1.5px solid #dee2e6;
    background: white;
    color: #555; cursor: pointer;
    font-size: .85rem;
    transition: all .2s;
    display: flex; align-items: center; justify-content: center;
}
.ap-btn:hover:not(:disabled) {
    background: #0d6efd; border-color: #0d6efd; color: white;
}
.ap-btn:disabled { opacity: .35; cursor: default; }
.ap-pages { display: flex; gap: .4rem; flex-wrap: wrap; }
.ap-page {
    width: 40px; height: 40px;
    border-radius: 50%;
    border: 1.5px solid #dee2e6;
    background: white;
    color: #555; cursor: pointer;
    font-size: .88rem; font-weight: 600;
    transition: all .2s;
    display: flex; align-items: center; justify-content: center;
}
.ap-page.active {
    background: #0d6efd; border-color: #0d6efd; color: white;
}
.ap-page:hover:not(.active) {
    border-color: #0d6efd; color: #0d6efd;
}

/* ── En-tête source RSS ── */
.rss-source-header {
    display: flex; align-items: center; gap: 1rem;
    padding: 1rem 1.2rem;
    border-radius: 14px;
    border: 1px solid;
}
.rss-source-header.fftt   { background: #fffbeb; border-color: #fde68a; }
.rss-source-header.ligue  { background: #f0fdf4; border-color: #bbf7d0; }
.rss-source-header.comite { background: #fefce8; border-color: #fef08a; }
.rss-source-header.presse { background: #faf5ff; border-color: #e9d5ff; }

.rsh-logo {
    width: 44px; height: 44px; border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.2rem; flex-shrink: 0;
}
.rss-source-header.fftt   .rsh-logo { background: #fef3c7; color: #d97706; }
.rss-source-header.ligue  .rsh-logo { background: #dcfce7; color: #16a34a; }
.rss-source-header.comite .rsh-logo { background: #fef9c3; color: #ca8a04; }
.rss-source-header.presse .rsh-logo { background: #ede9fe; color: #7c3aed; }

.rsh-name { font-weight: 700; font-size: .9rem; color: #0a0f2c; }
.rsh-link {
    font-size: .75rem; color: #0d6efd;
    text-decoration: none;
}
.rsh-link:hover { text-decoration: underline; }
.rsh-sources {
    display: flex; gap: .4rem;
    margin-top: .3rem; flex-wrap: wrap;
}
.rhs-tag {
    font-size: .65rem; font-weight: 600;
    background: #e9ecef; color: #555;
    padding: .1rem .5rem; border-radius: 8px;
}
.rsh-badge {
    margin-left: auto;
    font-size: .65rem; font-weight: 700;
    background: #e9ecef; color: #666;
    padding: .2rem .6rem; border-radius: 10px;
    letter-spacing: .4px; text-transform: uppercase;
    flex-shrink: 0;
}

/* ════════════════════════════════
   SIDEBAR
════════════════════════════════ */
.actus-sidebar {
    position: sticky;
    top: 80px;
    display: flex; flex-direction: column; gap: 1.4rem;
}
.sidebar-widget {
    background: white;
    border-radius: 16px;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
    padding: 1.4rem;
}
.sw-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.05rem; font-weight: 700;
    color: #0a0f2c;
    margin-bottom: 1rem;
    padding-bottom: .6rem;
    border-bottom: 2px solid #f0b429;
    display: flex; align-items: center;
}

/* Recherche sidebar */
.sw-search {
    display: flex; gap: .5rem;
}
.sw-search-input {
    flex: 1;
    padding: .6rem .9rem;
    border: 1.5px solid #dee2e6;
    border-radius: 8px;
    font-size: .85rem; outline: none;
    transition: border-color .2s;
}
.sw-search-input:focus { border-color: #0d6efd; }
.sw-search-btn {
    padding: .6rem .9rem;
    background: #0d6efd; border: none;
    border-radius: 8px; color: white;
    cursor: pointer; transition: background .2s;
}
.sw-search-btn:hover { background: #0a58ca; }

/* Sources sidebar */
.sw-sources {
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-direction: column; gap: .4rem;
}
.sws-source-btn {
    width: 100%;
    display: flex; align-items: center; gap: .7rem;
    padding: .6rem .8rem;
    background: #f8f9fa;
    border: 1.5px solid #e9ecef;
    border-radius: 10px;
    cursor: pointer; text-align: left;
    transition: all .2s;
}
.sws-source-btn:hover { border-color: #0d6efd; background: #e8f0fe; }
.sws-source-btn.active { background: #e8f0fe; border-color: #0d6efd; }

.sws-icon {
    width: 30px; height: 30px; border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    font-size: .8rem; flex-shrink: 0;
}
.sws-icon.club   { background: #dbeafe; color: #0d6efd; }
.sws-icon.fftt   { background: #fef3c7; color: #d97706; }
.sws-icon.ligue  { background: #dcfce7; color: #16a34a; }
.sws-icon.comite { background: #fef9c3; color: #ca8a04; }
.sws-icon.presse { background: #ede9fe; color: #7c3aed; }

.sws-texts {
    display: flex; flex-direction: column;
    gap: .1rem; flex: 1;
}
.sws-label { font-weight: 600; font-size: .85rem; color: #333; }
.sws-origin { font-size: .68rem; color: #aaa; }

/* Réseaux sociaux sidebar */
.sw-socials {
    display: flex; flex-direction: column; gap: .5rem;
}
.sws-btn {
    display: flex; align-items: center; gap: .8rem;
    padding: .65rem 1rem;
    border-radius: 10px;
    border: 1.5px solid #e9ecef;
    text-decoration: none;
    font-size: .85rem; font-weight: 600;
    color: #333; transition: all .2s;
}
.sws-btn:hover { transform: translateX(4px); }
.sws-btn.facebook { color: #1877f2; }
.sws-btn.facebook:hover { background: #e8f0fe; border-color: #1877f2; }
.sws-btn.twitter  { color: #000; }
.sws-btn.twitter:hover  { background: #f5f5f5; border-color: #000; }
.sws-btn.youtube  { color: #dc2626; }
.sws-btn.youtube:hover  { background: #fee2e2; border-color: #dc2626; }

/* ── Responsive ── */
@media (max-width: 991px) {
    .actus-sidebar { position: static; }
}
@media (max-width: 575px) {
    .actus-tabs-nav { gap: .2rem; }
    .atab-btn { padding: .6rem .7rem; font-size: .82rem; }
    .actu-img-wrap { height: 160px; }
}

/* corrections page actus */
.atab-pane          { display: none !important; }
.atab-pane.active   { display: block !important; }

/* ================================================================
   PAGE DÉTAIL ARTICLE
================================================================ */

/* ── Hero ── */
.nd-hero-section { background: #0a0f2c; }

.nd-hero {
    position: relative;
    min-height: 420px;
    display: flex; align-items: flex-end;
    overflow: hidden;
}
.nd-hero.nd-hero-no-img {
    min-height: 280px;
    background: linear-gradient(135deg, #0a0f2c 0%, #1565c0 100%);
}
.nd-bg-img {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    object-position: center top;
}
.nd-hero-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(
        to bottom,
        rgba(10,15,44,.3) 0%,
        rgba(10,15,44,.85) 100%
    );
}
.nd-hero-content {
    padding: 3rem 0 2.5rem;
    display: flex; flex-direction: column; gap: .8rem;
    max-width: 760px;
}
.nd-meta-top {
    display: flex; align-items: center;
    flex-wrap: wrap; gap: .8rem;
}
.nd-date, .nd-author {
    font-size: .82rem;
    color: rgba(255,255,255,.7);
}
.nd-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: clamp(1.8rem, 4vw, 3rem);
    font-weight: 700; color: white;
    line-height: 1.15; margin: 0;
}
.nd-summary-hero {
    color: rgba(255,255,255,.75);
    font-size: 1.05rem; line-height: 1.6;
    margin: 0; max-width: 680px;
}

/* ── Corps article ── */
.nd-article {
    background: white;
    border-radius: 20px;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 16px rgba(0,0,0,.05);
    overflow: hidden;
}
.nd-body {
    padding: 2rem 2.2rem;
    font-size: .95rem;
    color: #333;
    line-height: 1.85;
}
.nd-body h2, .nd-body h3, .nd-body h4 {
    font-family: 'Rajdhani', sans-serif;
    font-weight: 700; color: #0a0f2c;
    margin-top: 1.8rem;
}
.nd-body h2 { font-size: 1.6rem; }
.nd-body h3 { font-size: 1.3rem; }
.nd-body img {
    max-width: 100%; border-radius: 12px;
    margin: 1.2rem 0;
    box-shadow: 0 4px 20px rgba(0,0,0,.1);
}
.nd-body a { color: #0d6efd; }
.nd-body a:hover { text-decoration: underline; }
.nd-body ul, .nd-body ol {
    padding-left: 1.5rem; margin: 1rem 0;
}
.nd-body li { margin-bottom: .4rem; }
.nd-body blockquote {
    border-left: 4px solid #f0b429;
    background: #fffbeb;
    padding: 1rem 1.4rem;
    border-radius: 0 10px 10px 0;
    margin: 1.5rem 0;
    color: #555; font-style: italic;
}

/* ── Partage ── */
.nd-share {
    display: flex; align-items: center; gap: .8rem;
    flex-wrap: wrap;
    padding: 1rem 0;
    border-top: 1px solid #e9ecef;
    border-bottom: 1px solid #e9ecef;
}
.nd-share-label {
    font-size: .85rem; font-weight: 600;
    color: #555;
}
.nd-share-btn {
    width: 36px; height: 36px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: .9rem; color: white;
    text-decoration: none;
    transition: transform .2s, box-shadow .2s;
}
.nd-share-btn:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,.2); }
.nd-share-btn.facebook { background: #1877f2; }
.nd-share-btn.twitter  { background: #000; }

/* ── Retour ── */
.nd-back-wrap { padding-top: .5rem; }
.nd-back-btn {
    display: inline-flex; align-items: center;
    color: #0d6efd; font-weight: 600;
    font-size: .9rem; text-decoration: none;
    transition: gap .2s;
    gap: .4rem;
}
.nd-back-btn:hover { gap: .8rem; }

/* ── Sidebar ── */
.nd-sidebar { position: sticky; top: 80px; }

.nd-recent-item {
    display: flex; align-items: flex-start; gap: .8rem;
    padding: .7rem 0;
    border-bottom: 1px solid #f0f2f5;
    text-decoration: none; color: inherit;
    transition: background .2s;
}
.nd-recent-item:last-child { border-bottom: none; }
.nd-recent-item:hover .nd-recent-title { color: #0d6efd; }

.nd-recent-img {
    width: 64px; height: 52px;
    border-radius: 8px; overflow: hidden;
    background: linear-gradient(135deg, #e8f0fe, #f0f4ff);
    flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
}
.nd-recent-img img {
    width: 100%; height: 100%; object-fit: cover;
}
.nd-recent-ph { color: #c8d6f0; font-size: .9rem; }

.nd-recent-body { flex: 1; min-width: 0; }
.nd-recent-title {
    font-size: .82rem; font-weight: 600;
    color: #0a0f2c; line-height: 1.3;
    transition: color .2s;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.nd-recent-date {
    font-size: .7rem; color: #aaa;
    margin-top: .2rem; display: block;
}

/* ── Responsive ── */
@media (max-width: 767px) {
    .nd-hero { min-height: 300px; }
    .nd-body { padding: 1.4rem 1.2rem; }
    .nd-sidebar { position: static; margin-top: 2rem; }
}

/* ── Ticker bandeau ── */
.news-ticker {
    display: flex;
    overflow: hidden;
    height: 40px;          /* ← hauteur fixe stricte */
    align-items: center;
    white-space: nowrap;   /* ← empêche le retour à la ligne */
}
.ticker-label {
    flex-shrink: 0;
    background: rgba(0,0,0,.2);
    height: 100%;
    display: flex; align-items: center;
    padding: 0 1.2rem;
    font-family: 'Rajdhani', sans-serif;
    font-weight: 700;
    font-size: .85rem;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: white;
    white-space: nowrap;   /* ← idem */
    z-index: 1;
}
.ticker-track {
    flex: 1;
    overflow: hidden;
    height: 100%;
    display: flex;
    align-items: center;
}
.ticker-content {
    display: flex;
    align-items: center;
    gap: 4rem;
    white-space: nowrap;   /* ← crucial : tout sur une ligne */
    animation: tickerScroll 30s linear infinite;
    font-size: .82rem;
    color: rgba(255,255,255,.9);
    padding: 0 2rem;
    line-height: 40px;     /* ← aligne verticalement sur la hauteur du bandeau */
}
.ticker-content:hover { animation-play-state: paused; }
.ticker-content span {
    white-space: nowrap;   /* ← chaque item aussi */
    flex-shrink: 0;
}
@keyframes tickerScroll {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

/* ================================================================
   PAGE LA SALLE
================================================================ */

/* ── Info cards rapides ── */
.salle-info-card {
    background: white;
    border-radius: 16px;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
    padding: 1.4rem 1rem;
    text-align: center;
    transition: transform .2s, box-shadow .2s;
}
.salle-info-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(13,110,253,.1);
}
.sic-icon { font-size: 1.6rem; color: #0d6efd; margin-bottom: .6rem; }
.sic-val {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.5rem; font-weight: 700;
    color: #0a0f2c; line-height: 1;
}
.sic-lbl {
    font-size: .72rem; color: #888;
    margin-top: .3rem;
    text-transform: uppercase; letter-spacing: .5px;
}

/* ── Galerie ── */
.salle-gallery {
    display: grid;
    grid-template-columns: 1.6fr 1fr;
    grid-template-rows: 240px 240px;
    gap: 1rem;
    border-radius: 20px;
    overflow: hidden;
}
.sg-main {
    grid-row: 1 / 3;  /* occupe les 2 lignes à gauche */
    position: relative; overflow: hidden;
    background: #e8f0fe;
    border-radius: 16px;
    cursor: pointer;
}
.sg-secondary {
    position: relative; overflow: hidden;
    background: #e8f0fe;
    border-radius: 16px;
    cursor: pointer;
}
.sg-img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform .5s ease;
    display: block;
}
.sg-main:hover .sg-img,
.sg-secondary:hover .sg-img { transform: scale(1.05); }

.sg-ph {
    position: absolute; inset: 0;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    background: linear-gradient(135deg, #e8f0fe, #f0f4ff);
    color: #adb5bd;
}
.sg-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(to top, rgba(10,15,44,.6) 0%, transparent 50%);
    display: flex; align-items: flex-end;
    padding: 1rem;
    opacity: 0;
    transition: opacity .3s ease;
}
.sg-main:hover .sg-overlay,
.sg-secondary:hover .sg-overlay { opacity: 1; }
.sg-overlay span {
    color: white; font-size: .85rem;
    font-weight: 600; letter-spacing: .3px;
}

/* ── Carte infos ── */
.salle-card {
    background: white;
    border-radius: 16px;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
    padding: 1.6rem;
}
.sc-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.15rem; font-weight: 700;
    color: #0a0f2c; margin-bottom: 1.2rem;
    padding-bottom: .7rem;
    border-bottom: 2px solid #f0b429;
    display: flex; align-items: center;
}
.sc-list {
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-direction: column; gap: .8rem;
}
.sc-list li {
    display: flex; gap: .9rem; align-items: flex-start;
    padding-bottom: .8rem;
    border-bottom: 1px solid #f0f2f5;
}
.sc-list li:last-child { border-bottom: none; padding-bottom: 0; }
.scl-icon {
    width: 34px; height: 34px; border-radius: 8px;
    background: #e8f0fe; color: #0d6efd;
    display: flex; align-items: center; justify-content: center;
    font-size: .85rem; flex-shrink: 0;
}
.scl-label {
    font-size: .72rem; text-transform: uppercase;
    letter-spacing: .6px; color: #aaa; margin-bottom: .15rem;
}
.scl-val { font-size: .88rem; color: #333; line-height: 1.5; }

/* ── Horaires ── */
.sc-horaires {
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-direction: column; gap: 0;
}
.sc-horaires li {
    display: flex; justify-content: space-between;
    align-items: center;
    padding: .55rem 0;
    border-bottom: 1px solid #f0f2f5;
    font-size: .88rem;
}
.sc-horaires li:last-child { border-bottom: none; }
.sch-jour { font-weight: 600; color: #0a0f2c; }
.sch-heure { color: #0d6efd; font-weight: 500; }

/* ── Carte map ── */
.salle-map-card {
    background: white;
    border-radius: 16px;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
    padding: 1.6rem;
    height: 100%;
}
.salle-map-wrap {
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid #e9ecef;
}
.salle-map-wrap iframe { display: block; }

/* ── Responsive ── */
@media (max-width: 767px) {
    .salle-gallery {
        grid-template-columns: 1fr;
        grid-template-rows: 220px 160px 160px;
    }
    .sg-main { grid-row: 1; }
}
@media (max-width: 575px) {
    .salle-gallery { gap: .6rem; }
}

/* ================================================================
   PAGES PARTENAIRES
================================================================ */

/* ── Intro ── */
.partenaires-intro { text-align: center; }

/* ── Séparateur section ── */
.partenaires-section {}
.ps-header {
    display: flex; align-items: center; gap: 1rem;
    margin-bottom: 2rem;
}
.psh-line {
    flex: 1; height: 1px;
    background: linear-gradient(90deg, transparent, #dee2e6);
}
.psh-line:last-child {
    background: linear-gradient(90deg, #dee2e6, transparent);
}
.psh-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.1rem; font-weight: 700;
    color: #888; text-transform: uppercase;
    letter-spacing: 1.5px; white-space: nowrap;
}

/* ── Grille partenaires ── */
.partenaires-grid {
    display: grid;
    gap: 1rem;
}
.partenaires-grid.principal {
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
}
.partenaires-grid.local {
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
}

/* ── Card partenaire ── */
.partenaire-card {
    display: flex; flex-direction: column;
    align-items: center; gap: .6rem;
    padding: 1.2rem .8rem;
    background: white;
    border: 1.5px solid #e9ecef;
    border-radius: 14px;
    text-decoration: none;
    transition: all .25s ease;
    cursor: pointer;
}
.partenaire-card:hover {
    border-color: #0d6efd;
    transform: translateY(-4px);
    box-shadow: 0 8px 28px rgba(13,110,253,.12);
}
.pc-logo-wrap {
    width: 100%; height: 70px;
    display: flex; align-items: center; justify-content: center;
    overflow: hidden;
}
.partenaires-grid.principal .pc-logo-wrap { height: 90px; }

.pc-logo {
    max-width: 100%; max-height: 100%;
    object-fit: contain;
    filter: grayscale(30%);
    transition: filter .25s;
}
.partenaire-card:hover .pc-logo { filter: grayscale(0%); }

.pc-logo-ph {
    width: 52px; height: 52px; border-radius: 12px;
    background: #f0f4ff; color: #0d6efd;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.3rem;
}
.pc-name {
    font-size: .78rem; font-weight: 600;
    color: #555; text-align: center;
    line-height: 1.3;
}

/* ── CTA ── */
.partenaires-cta {
    background: linear-gradient(135deg, #0a0f2c, #1565c0);
    border-radius: 20px;
    padding: 3rem 2rem;
    text-align: center;
    color: white;
}
.pcta-icon {
    font-size: 2.5rem; color: #f0b429;
    margin-bottom: 1rem;
}
.pcta-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.8rem; font-weight: 700;
    margin-bottom: .5rem;
}
.pcta-sub {
    color: rgba(255,255,255,.7);
    margin-bottom: 1.5rem; line-height: 1.6;
}

/* ── Partenariat KPI ── */
.partenariat-kpi {
    background: white;
    border-radius: 16px;
    border: 1px solid #e9ecef;
    padding: 1.4rem 1rem;
    text-align: center;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
}
.pkpi-val {
    font-family: 'Rajdhani', sans-serif;
    font-size: 2rem; font-weight: 700; color: #0d6efd;
}
.pkpi-lbl {
    font-size: .75rem; color: #888;
    text-transform: uppercase; letter-spacing: .5px;
}

/* ── Formules ── */
.formule-card {
    background: white;
    border-radius: 20px;
    border: 2px solid #e9ecef;
    padding: 1.8rem 1.4rem;
    text-align: center;
    height: 100%;
    display: flex; flex-direction: column;
    position: relative; overflow: hidden;
    transition: transform .3s, box-shadow .3s, border-color .3s;
}
.formule-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 14px 40px rgba(0,0,0,.1);
}
.formule-card.featured {
    border-color: #f0b429;
    background: linear-gradient(160deg, #fff 80%, #fffbeb 100%);
}
.fc-badge {
    position: absolute; top: 12px; right: 12px;
    background: #f0b429; color: #0a0f2c;
    font-size: .65rem; font-weight: 700;
    padding: .2rem .6rem; border-radius: 20px;
    text-transform: uppercase;
}
.fc-header {
    display: flex; flex-direction: column;
    align-items: center; gap: .4rem;
    margin-bottom: .8rem;
}
.fc-icon {
    font-size: 1.8rem;
}
.formule-card.bronze   .fc-icon { color: #cd7f32; }
.formule-card.argent   .fc-icon { color: #adb5bd; }
.formule-card.or       .fc-icon { color: #f0b429; }
.formule-card.sur-mesure .fc-icon { color: #0d6efd; }

.fc-level {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.2rem; font-weight: 700; color: #0a0f2c;
}
.fc-price {
    font-size: .82rem; color: #888;
    margin-bottom: 1rem;
}
.fc-avantages {
    list-style: none; padding: 0; margin: 0 0 1.2rem;
    text-align: left; flex: 1;
}
.fc-avantages li {
    font-size: .82rem; color: #555;
    padding: .35rem 0;
    border-bottom: 1px solid #f0f2f5;
    display: flex; align-items: flex-start; gap: .3rem;
}
.fc-avantages li:last-child { border-bottom: none; }
.fc-avantages li.text-muted { color: #ccc !important; }

.fc-btn {
    display: block;
    padding: .7rem 1rem;
    border-radius: 50px;
    background: #f0f2f5; color: #555;
    font-size: .85rem; font-weight: 700;
    text-decoration: none; text-align: center;
    transition: all .2s;
    margin-top: auto;
}
.fc-btn:hover { background: #0d6efd; color: white; }
.fc-btn.or { background: #f0b429; color: #0a0f2c; }
.fc-btn.or:hover { background: #d97706; color: white; }
.fc-btn.sur-mesure { background: #e8f0fe; color: #0d6efd; }
.fc-btn.sur-mesure:hover { background: #0d6efd; color: white; }

/* ── Avantages ── */
.avantage-card {
    background: white;
    border-radius: 16px;
    border: 1px solid #e9ecef;
    padding: 1.4rem 1.2rem;
    text-align: center;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
    transition: transform .2s, box-shadow .2s;
}
.avantage-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(13,110,253,.1);
}
.avt-icon {
    font-size: 1.6rem; color: #0d6efd;
    margin-bottom: .6rem;
}
.avt-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1rem; font-weight: 700;
    color: #0a0f2c; margin-bottom: .4rem;
}
.avt-desc { font-size: .82rem; color: #888; line-height: 1.5; }

/* ── Section title partenariat ── */
.partenariat-section-title {
    border-bottom: 2px solid #f0f2f5;
    padding-bottom: .8rem;
}

/* ================================================================
   PAGE SITUATION MENSUELLE
================================================================ */

/* ── Hero spécial ── */
.sitm-hero {
    background: linear-gradient(135deg, #0a0f2c 0%, #1a237e 50%, #1565c0 100%) !important;
}

/* ── Navigation mois ── */
.sitm-nav-mois {
    display: flex; justify-content: center;
}
.sitm-nav-btns {
    display: flex; align-items: center; gap: 1rem;
    background: white;
    border-radius: 50px;
    padding: .6rem 1.2rem;
    box-shadow: 0 4px 20px rgba(0,0,0,.08);
    border: 1px solid #e9ecef;
}
.sitm-nav-btns a {
    display: inline-flex; align-items: center; gap: .4rem;
    padding: .4rem .9rem;
    border-radius: 50px;
    background: #f0f4ff;
    color: #0d6efd;
    font-size: .85rem; font-weight: 600;
    text-decoration: none;
    transition: all .2s;
}
.sitm-nav-btns a:hover { background: #0d6efd; color: white; }
.sitm-nav-label {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1rem; font-weight: 700;
    color: #0a0f2c; white-space: nowrap;
}

/* ── Section title ── */
.sitm-section-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.3rem; font-weight: 700;
    color: #0a0f2c; margin-bottom: 1.5rem;
    display: flex; align-items: center;
}

/* ── Podium ── */
.podium-wrap {
    display: flex;
    align-items: flex-end;
    justify-content: center;
    gap: 1rem;
    padding: 0 1rem 0;
    min-height: 220px;
}
.podium-item {
    display: flex; flex-direction: column; align-items: center;
    gap: .5rem; flex: 1; max-width: 200px;
    animation: podiumRise .6s cubic-bezier(.175,.885,.32,1.275) forwards;
    opacity: 0;
}
.podium-item:nth-child(1) { animation-delay: .3s; }
.podium-item:nth-child(2) { animation-delay: .1s; }
.podium-item:nth-child(3) { animation-delay: .5s; }
@keyframes podiumRise {
    from { opacity: 0; transform: translateY(30px); }
    to   { opacity: 1; transform: translateY(0); }
}

.podium-avatar {
    width: 56px; height: 56px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-family: 'Rajdhani', sans-serif;
    font-size: 1rem; font-weight: 700; color: white;
    border: 3px solid;
}
.podium-item.rank-1 .podium-avatar { background: linear-gradient(135deg,#f0b429,#e0980a); border-color: #f0b429; width:68px;height:68px;font-size:1.2rem; }
.podium-item.rank-2 .podium-avatar { background: linear-gradient(135deg,#adb5bd,#868e96); border-color: #adb5bd; }
.podium-item.rank-3 .podium-avatar { background: linear-gradient(135deg,#cd7f32,#a0522d); border-color: #cd7f32; }

.podium-name {
    font-family: 'Rajdhani', sans-serif;
    font-size: .85rem; font-weight: 700;
    color: #0a0f2c; text-align: center;
    line-height: 1.2;
}
.podium-pts {
    font-size: .78rem; color: #888;
}
.podium-bar {
    width: 100%; border-radius: 12px 12px 0 0;
    display: flex; align-items: center; justify-content: center;
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.4rem; font-weight: 700; color: white;
    padding-top: .5rem;
    animation: barGrow .8s ease forwards;
    transform-origin: bottom;
}
.podium-item.rank-1 .podium-bar { height: 120px; background: linear-gradient(160deg,#f0b429,#e0980a); }
.podium-item.rank-2 .podium-bar { height: 90px; background: linear-gradient(160deg,#adb5bd,#868e96); }
.podium-item.rank-3 .podium-bar { height: 70px; background: linear-gradient(160deg,#cd7f32,#a0522d); }
@keyframes barGrow {
    from { transform: scaleY(0); }
    to   { transform: scaleY(1); }
}

/* ── Toolbar ── */
.sitm-toolbar {
    display: flex; align-items: center;
    flex-wrap: wrap; gap: 1rem;
    background: white;
    border-radius: 14px;
    border: 1px solid #e9ecef;
    padding: .8rem 1.2rem;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
}
.sitm-search-wrap {
    position: relative; display: flex; align-items: center;
    flex: 1; min-width: 200px;
}
.sitm-search-icon {
    position: absolute; left: .9rem;
    color: #adb5bd; font-size: .85rem;
    pointer-events: none;
}
.sitm-search-input {
    width: 100%;
    padding: .6rem .9rem .6rem 2.4rem;
    border: 1.5px solid #dee2e6;
    border-radius: 50px;
    font-size: .88rem; outline: none;
    transition: border-color .2s, box-shadow .2s;
}
.sitm-search-input:focus {
    border-color: #0d6efd;
    box-shadow: 0 0 0 3px rgba(13,110,253,.1);
}
.sitm-search-clear {
    position: absolute; right: .8rem;
    background: none; border: none;
    color: #adb5bd; cursor: pointer; font-size: .85rem;
    transition: color .2s;
}
.sitm-search-clear:hover { color: #dc3545; }

.sitm-stats-bar {
    display: flex; gap: 1rem; flex-wrap: wrap;
}
.ssb-item {
    font-size: .8rem; color: #555;
    display: flex; align-items: center; gap: .3rem;
}

/* ── Tableau ── */
.sitm-table-wrap {
    background: white;
    border-radius: 16px;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 16px rgba(0,0,0,.05);
    overflow: hidden;
}
.sitm-table {
    margin: 0;
    font-size: .88rem;
}
.sitm-table thead th {
    background: linear-gradient(135deg, #0a0f2c, #1565c0);
    color: white;
    font-family: 'Rajdhani', sans-serif;
    font-size: .78rem; font-weight: 600;
    text-transform: uppercase; letter-spacing: .8px;
    padding: .9rem .8rem;
    border: none;
    white-space: nowrap;
}
.sitm-th.sortable { cursor: pointer; transition: background .2s; }
.sitm-th.sortable:hover { background: rgba(255,255,255,.15); }
.sitm-th.sorted-asc  .fa-sort { display: none; }
.sitm-th.sorted-desc .fa-sort { display: none; }

.sitm-row {
    transition: background .15s;
    border-bottom: 1px solid #f0f2f5;
}
.sitm-row:hover { background: #f0f4ff; }
.sitm-row td { padding: .7rem .8rem; vertical-align: middle; }

/* Rang */
.sitm-rank-cell {}
.sitm-rank {
    display: inline-flex; align-items: center; justify-content: center;
    width: 28px; height: 28px; border-radius: 50%;
    font-size: .8rem; font-weight: 700;
    background: #e9ecef; color: #555;
}
.sitm-row:nth-child(1) .sitm-rank { background: linear-gradient(135deg,#f0b429,#e0980a); color:white; }
.sitm-row:nth-child(2) .sitm-rank { background: linear-gradient(135deg,#adb5bd,#868e96); color:white; }
.sitm-row:nth-child(3) .sitm-rank { background: linear-gradient(135deg,#cd7f32,#a0522d); color:white; }

/* Nom joueur */
.sitm-name-cell {}
.sitm-player-link {
    display: flex; align-items: center; gap: .7rem;
    text-decoration: none; color: inherit;
}
.sitm-avatar {
    width: 34px; height: 34px; border-radius: 50%;
    background: linear-gradient(135deg, #0d6efd, #1565c0);
    color: white; font-size: .72rem; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    font-family: 'Rajdhani', sans-serif;
}
.sitm-player-name {
    font-weight: 600; color: #0a0f2c;
    font-size: .88rem; line-height: 1.2;
}
.sitm-player-link:hover .sitm-player-name { color: #0d6efd; }
.sitm-player-licence {
    font-size: .7rem; color: #aaa;
}

/* Points badge */
.sitm-pts-badge {
    display: inline-flex; align-items: center; justify-content: center;
    min-width: 52px;
    background: #0a0f2c; color: white;
    font-family: 'Rajdhani', sans-serif;
    font-size: .88rem; font-weight: 700;
    padding: .2rem .6rem; border-radius: 12px;
}
.sitm-pts-badge.gold   { background: linear-gradient(135deg,#f0b429,#e0980a); }
.sitm-pts-badge.silver { background: linear-gradient(135deg,#adb5bd,#868e96); }
.sitm-pts-badge.bronze { background: linear-gradient(135deg,#cd7f32,#a0522d); }

/* Rang */
.sitm-rang {
    font-size: .82rem; color: #666;
}
.sitm-rang.dep {
    font-weight: 700; color: #0d6efd;
}

/* Progression */
.sitm-prog {
    display: inline-flex; align-items: center;
    font-size: .78rem; font-weight: 700;
    padding: .2rem .5rem; border-radius: 8px;
    white-space: nowrap;
}
.sitm-prog.up     { background: #d1e7dd; color: #0f5132; }
.sitm-prog.down   { background: #f8d7da; color: #842029; }
.sitm-prog.stable { background: #e9ecef; color: #6c757d; }

.sitm-prog-an {
    font-size: .78rem; font-weight: 600;
}
.sitm-prog-an.up   { color: #198754; }
.sitm-prog-an.down { color: #dc3545; }
.sitm-prog-an.stable { color: #aaa; }

/* Lignes filtrées */
.sitm-row[style*="display:none"] { display: none !important; }

/* Message vide */
.sitm-empty {
    text-align: center; padding: 3rem;
    color: #aaa;
}

/* ── Responsive ── */
@media (max-width: 575px) {
    .podium-item.rank-1 .podium-bar { height: 80px; }
    .podium-item.rank-2 .podium-bar { height: 60px; }
    .podium-item.rank-3 .podium-bar { height: 45px; }
    .sitm-toolbar { padding: .6rem; }
}

/* ================================================================
   PAGE RÉSULTATS
================================================================ */

/* ── Onglets ── */
.res-tabs-nav {
    display: flex; gap: .4rem; flex-wrap: wrap;
    border-bottom: 2px solid #e9ecef;
    padding-bottom: 0;
}
.res-tab-btn {
    display: inline-flex; align-items: center;
    padding: .7rem 1.2rem;
    background: none; border: none;
    font-family: 'Rajdhani', sans-serif;
    font-size: .95rem; font-weight: 600;
    color: #888; cursor: pointer;
    white-space: nowrap;
    position: relative;
    transition: color .2s;
    border-radius: 8px 8px 0 0;
}
.res-tab-btn::after {
    content: '';
    position: absolute; bottom: -2px; left: 0; right: 0; height: 3px;
    background: #0d6efd; border-radius: 2px 2px 0 0;
    transform: scaleX(0); transition: transform .2s;
}
.res-tab-btn.active         { color: #0d6efd; }
.res-tab-btn.active::after  { transform: scaleX(1); }
.res-tab-btn:hover          { color: #0d6efd; background: #f0f4ff; }

.res-tab-pane              { display: none; }
.res-tab-pane.active       { display: block; }

/* ── Filtre division ── */
.res-filter-bar {
    display: flex; gap: .5rem; flex-wrap: wrap;
}
.rfb-btn {
    padding: .4rem 1rem;
    border-radius: 50px;
    border: 1.5px solid #dee2e6;
    background: white;
    font-size: .82rem; font-weight: 600;
    color: #666; cursor: pointer;
    transition: all .2s;
}
.rfb-btn:hover, .rfb-btn.active {
    background: #0d6efd; border-color: #0d6efd; color: white;
}

/* ── Grille résultats ── */
.res-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
    gap: 1rem;
}
@media (max-width: 575px) {
    .res-grid { grid-template-columns: 1fr; }
}

/* ── Card résultat ── */
.res-card {
    background: white;
    border-radius: 16px;
    border: 1px solid #e9ecef;
    border-left: 4px solid #e9ecef;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
    overflow: hidden;
    transition: transform .25s, box-shadow .25s;
    display: flex; flex-direction: column;
}
.res-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 28px rgba(0,0,0,.1);
}
.res-card.win-card      { border-left-color: #198754; }
.res-card.loss-card     { border-left-color: #dc3545; }
.res-card.draw-card     { border-left-color: #6c757d; }
.res-card.upcoming-card { border-left-color: #f0b429; border-left-style: dashed; }

/* En-tête card */
.res-card-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: .6rem .9rem;
    background: #fafbfc;
    border-bottom: 1px solid #f0f2f5;
    gap: .5rem; flex-wrap: wrap;
}
.rch-left, .rch-right {
    display: flex; align-items: center; gap: .5rem;
    flex-wrap: wrap;
}
.res-div-badge {
    font-size: .65rem; font-weight: 700;
    padding: .15rem .55rem; border-radius: 10px;
    text-transform: uppercase; letter-spacing: .4px;
}
.res-div-badge.nationale     { background: #cfe2ff; color: #084298; }
.res-div-badge.regionale     { background: #d1e7dd; color: #0f5132; }
.res-div-badge.departementale{ background: #fff3cd; color: #664d03; }
.res-div-badge.d1            { background: #cfe2ff; color: #084298; }
.res-div-badge.d2            { background: #d1e7dd; color: #0f5132; }
.res-div-badge.d3            { background: #ede9fe; color: #4c1d95; }

.res-competition {
    font-size: .72rem; color: #888;
    font-weight: 500;
}
.res-journee {
    font-family: 'Rajdhani', sans-serif;
    font-size: .8rem; font-weight: 700;
    color: #0d6efd;
    background: #e8f0fe;
    padding: .1rem .5rem; border-radius: 8px;
}
.res-date { font-size: .72rem; color: #aaa; }

/* Corps card */
.res-card-body {
    display: flex; align-items: center;
    justify-content: space-between;
    padding: .9rem;
    gap: .5rem; flex: 1;
}
.res-team {
    display: flex; flex-direction: column;
    align-items: center; gap: .35rem;
    flex: 1; text-align: center;
    min-width: 0;
}
.res-team.right { }
.res-team.our-team .res-team-name { color: #0d6efd; font-weight: 700; }

.res-logo {
    width: 44px; height: 44px; object-fit: contain;
    border-radius: 4px;
}
.res-logo-ph {
    width: 44px; height: 44px; border-radius: 50%;
    background: #f0f4ff;
    display: flex; align-items: center; justify-content: center;
    color: #aaa; font-size: 1.1rem;
}
.res-team.our-team .res-logo-ph {
    background: #e8f0fe; color: #0d6efd;
    border: 2px solid #0d6efd;
}
.res-team-name {
    font-size: .78rem; font-weight: 600;
    color: #333; line-height: 1.2;
    word-break: break-word;
}
.res-dom-badge {
    font-size: .6rem; font-weight: 700;
    padding: .1rem .4rem; border-radius: 8px;
    background: #d1e7dd; color: #0f5132;
}
.res-dom-badge.ext {
    background: #cfe2ff; color: #084298;
}

/* Score */
.res-score-wrap {
    display: flex; flex-direction: column;
    align-items: center; gap: .3rem;
    flex-shrink: 0; min-width: 80px;
}
.res-score.played {
    display: flex; align-items: center; gap: .3rem;
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.8rem; font-weight: 700;
}
.res-score-a, .res-score-b { min-width: 28px; text-align: center; }
.res-score-a.win, .res-score-b.win   { color: #198754; }
.res-score-a.loss, .res-score-b.loss { color: #dc3545; }
.res-score-a.draw, .res-score-b.draw { color: #6c757d; }
.res-score-sep { color: #ccc; font-size: 1.2rem; }

.res-score.upcoming {
    display: flex; flex-direction: column;
    align-items: center; gap: .2rem;
}
.res-vs {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.3rem; font-weight: 700; color: #ccc;
}
.res-heure { font-size: .72rem; color: #888; }

.res-result-pill {
    font-size: .65rem; font-weight: 700;
    padding: .15rem .55rem; border-radius: 10px;
    text-transform: uppercase; letter-spacing: .4px;
}
.res-result-pill.win      { background: #d1e7dd; color: #0f5132; }
.res-result-pill.loss     { background: #f8d7da; color: #842029; }
.res-result-pill.draw     { background: #e2e3e5; color: #41464b; }
.res-result-pill.upcoming { background: #fff3cd; color: #856404; }

/* Pied card */
.res-card-footer {
    padding: .55rem .9rem;
    background: #fafbfc;
    border-top: 1px solid #f0f2f5;
    display: flex; justify-content: flex-end;
}
.res-detail-btn {
    font-size: .75rem; font-weight: 600;
    color: #0d6efd; text-decoration: none;
    display: inline-flex; align-items: center;
    padding: .2rem .6rem;
    border-radius: 8px;
    border: 1px solid #dee2e6;
    transition: all .2s;
}
.res-detail-btn:hover {
    background: #0d6efd; color: white; border-color: #0d6efd;
}

/* ── Pagination ── */
.res-pagination-wrap { display: flex; justify-content: center; }

/* ================================================================
   PAGE SITUATION LIVE
================================================================ */

/* ── Hero ── */
.live-hero {
    position: relative;
    background: #0a0f2c !important;
    overflow: hidden;
}
.live-hero-bg {
    position: absolute; inset: 0;
    background: radial-gradient(ellipse at 30% 50%, rgba(220,53,69,.25) 0%, transparent 60%),
                radial-gradient(ellipse at 70% 50%, rgba(13,110,253,.2) 0%, transparent 60%),
                linear-gradient(135deg, #0a0f2c 0%, #1a0a2c 100%);
    animation: liveBgPulse 4s ease-in-out infinite;
}
@keyframes liveBgPulse {
    0%,100% { opacity: 1; }
    50%      { opacity: .8; }
}

/* Icône pulsante */
.live-pulse-icon {
    position: relative;
    width: 72px; height: 72px;
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 1rem;
    font-size: 1.8rem; color: #dc3545;
    z-index: 2;
}
.live-pulse-ring {
    position: absolute; inset: 0;
    border: 2px solid rgba(220,53,69,.6);
    border-radius: 50%;
    animation: liveRingPulse 2s ease-out infinite;
}
.live-pulse-ring.delay { animation-delay: 1s; }
@keyframes liveRingPulse {
    0%   { transform: scale(.8); opacity: 1; }
    100% { transform: scale(2);  opacity: 0; }
}

/* Badge LIVE hero */
.live-badge-hero {
    display: inline-block;
    background: #dc3545;
    color: white;
    font-size: .7rem; font-weight: 700;
    padding: .2rem .6rem;
    border-radius: 20px;
    vertical-align: middle;
    margin-left: .6rem;
    animation: liveBadgePulse 1.5s ease-in-out infinite;
    letter-spacing: 1px;
}
@keyframes liveBadgePulse {
    0%,100% { box-shadow: 0 0 0 0 rgba(220,53,69,.5); }
    50%      { box-shadow: 0 0 0 8px rgba(220,53,69,0); }
}

/* Warning provisoire */
.live-warning {
    display: inline-flex; align-items: center;
    background: rgba(255,193,7,.15);
    border: 1px solid rgba(255,193,7,.4);
    color: #ffc107;
    border-radius: 20px;
    padding: .4rem 1rem;
    font-size: .78rem;
    margin-top: .8rem;
}

/* ── Stat cards ── */
.live-stat-card {
    background: white;
    border-radius: 16px;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
    padding: 1.2rem 1rem;
    text-align: center;
    transition: transform .2s, box-shadow .2s;
}
.live-stat-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(0,0,0,.1);
}
.live-stat-card.best {
    background: linear-gradient(135deg, #0a0f2c, #1565c0);
    border-color: #1565c0;
}
.live-stat-card.best .lsc-val,
.live-stat-card.best .lsc-lbl { color: white; }

.lsc-icon {
    width: 44px; height: 44px; border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.1rem; margin: 0 auto .7rem;
}
.lsc-icon.gainers { background: #d1e7dd; color: #198754; }
.lsc-icon.losers  { background: #f8d7da; color: #dc3545; }
.lsc-icon.stable  { background: #e9ecef; color: #6c757d; }
.lsc-icon.best    { background: rgba(240,180,41,.2); color: #f0b429; }

.lsc-val {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.8rem; font-weight: 700;
    color: #0a0f2c; line-height: 1;
}
.lsc-lbl {
    font-size: .72rem; color: #888;
    text-transform: uppercase; letter-spacing: .5px;
    margin-top: .3rem;
}

/* ── Filtres ── */
.live-filter-btns {
    display: flex; gap: .4rem; flex-wrap: wrap;
}
.live-filter-btn {
    padding: .4rem .9rem;
    border-radius: 50px;
    border: 1.5px solid #dee2e6;
    background: white;
    font-size: .8rem; font-weight: 600;
    color: #666; cursor: pointer;
    transition: all .2s; white-space: nowrap;
}
.live-filter-btn[data-filter="up"].active    { background: #198754; border-color: #198754; color: white; }
.live-filter-btn[data-filter="down"].active  { background: #dc3545; border-color: #dc3545; color: white; }
.live-filter-btn[data-filter="stable"].active{ background: #6c757d; border-color: #6c757d; color: white; }
.live-filter-btn[data-filter="all"].active   { background: #0d6efd; border-color: #0d6efd; color: white; }
.live-filter-btn:hover:not(.active)          { border-color: #0d6efd; color: #0d6efd; }

/* ── Grille ── */
.live-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 1rem;
}
@media (max-width: 575px) {
    .live-grid { grid-template-columns: repeat(2, 1fr); gap: .6rem; }
}

/* ── Card joueur ── */
.live-card {
    background: white;
    border-radius: 16px;
    border: 1px solid #e9ecef;
    border-top: 3px solid #e9ecef;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
    overflow: hidden;
    display: flex; flex-direction: column;
    transition: transform .25s, box-shadow .25s;
}
.live-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 10px 32px rgba(0,0,0,.1);
}
.live-card.up   { border-top-color: #198754; }
.live-card.down { border-top-color: #dc3545; }
.live-card.stable { border-top-color: #dee2e6; }

/* En-tête card */
.lc-header {
    display: flex; align-items: center; gap: .7rem;
    padding: .9rem .9rem .5rem;
}
.lc-avatar {
    width: 40px; height: 40px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-family: 'Rajdhani', sans-serif;
    font-size: .85rem; font-weight: 700; color: white;
    flex-shrink: 0;
}
.lc-avatar.up     { background: linear-gradient(135deg, #198754, #146c43); }
.lc-avatar.down   { background: linear-gradient(135deg, #dc3545, #b02a37); }
.lc-avatar.stable { background: linear-gradient(135deg, #6c757d, #495057); }

.lc-info { flex: 1; min-width: 0; }
.lc-name-link {
    font-weight: 700; font-size: .85rem;
    color: #0a0f2c; text-decoration: none;
    display: block;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    transition: color .2s;
}
.lc-name-link:hover { color: #0d6efd; }
.lc-clt { font-size: .72rem; color: #aaa; margin-top: .1rem; }

.lc-trend-icon {
    font-size: 1rem; flex-shrink: 0;
}
.lc-trend-icon.up     { color: #198754; }
.lc-trend-icon.down   { color: #dc3545; }
.lc-trend-icon.stable { color: #dee2e6; }

/* Corps card */
.lc-body { padding: .5rem .9rem .7rem; flex: 1; }
.lc-points-label {
    font-size: .68rem; color: #aaa;
    text-transform: uppercase; letter-spacing: .5px;
    margin-bottom: .3rem;
}
.lc-points {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.6rem; font-weight: 700;
    line-height: 1; margin-bottom: .5rem;
}
.lc-points.up     { color: #198754; }
.lc-points.down   { color: #dc3545; }
.lc-points.stable { color: #aaa; font-size: 1.1rem; }

/* Barre progression */
.lc-bar-wrap {
    height: 6px; border-radius: 3px;
    background: #f0f2f5; overflow: hidden;
    margin-bottom: .5rem;
}
.lc-bar {
    height: 100%; border-radius: 3px;
    transition: width 1s ease;
    min-width: 3px;
}
.lc-bar.up     { background: linear-gradient(90deg, #d1e7dd, #198754); }
.lc-bar.down   { background: linear-gradient(90deg, #f8d7da, #dc3545); }
.lc-bar.stable { background: #dee2e6; }

/* Projection */
.lc-projection {
    display: flex; align-items: center;
    justify-content: space-between;
    font-size: .75rem;
    background: #f8f9fa;
    border-radius: 8px;
    padding: .3rem .5rem;
}
.lcp-label { color: #aaa; }
.lcp-val   { font-weight: 700; color: #0a0f2c; }

/* Pied card */
.lc-footer {
    padding: .5rem .9rem;
    border-top: 1px solid #f0f2f5;
    background: #fafbfc;
}
.lc-detail-link {
    font-size: .75rem; font-weight: 600;
    color: #0d6efd; text-decoration: none;
    display: inline-flex; align-items: center;
    transition: gap .2s; gap: .3rem;
}
.lc-detail-link:hover { gap: .6rem; }

/* ── Note bas ── */
.live-note {
    background: #fff3cd;
    border: 1px solid #fde68a;
    border-radius: 12px;
    padding: .9rem 1.2rem;
    font-size: .85rem; color: #664d03;
}

/* ── Responsive ── */
@media (max-width: 575px) {
    .live-card { border-radius: 12px; }
    .lc-points { font-size: 1.3rem; }
    .lc-name-link { font-size: .78rem; }
}

/* ================================================================
   PAGES LÉGALES
================================================================ */

/* ── Card principale ── */
.legal-card {
    background: white;
    border-radius: 20px;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 20px rgba(0,0,0,.06);
    overflow: hidden;
}

/* ── Section ── */
.legal-section {
    padding: 2rem 2.4rem;
    border-bottom: 1px solid #f0f2f5;
}
.legal-section:last-child { border-bottom: none; }

.legal-title {
    display: flex; align-items: center; gap: .9rem;
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.25rem; font-weight: 700;
    color: #0a0f2c; margin-bottom: 1.2rem;
}
.legal-num {
    width: 32px; height: 32px; border-radius: 50%;
    background: linear-gradient(135deg, #0d6efd, #1565c0);
    color: white; font-size: .85rem; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}

.legal-content p {
    color: #444; line-height: 1.8; margin-bottom: .8rem;
    font-size: .92rem;
}
.legal-content p:last-child { margin-bottom: 0; }
.legal-content a { color: #0d6efd; }
.legal-content a:hover { text-decoration: underline; }

/* Bloc info (tableau clé/valeur) */
.legal-info-block {
    background: #f8f9fa;
    border-radius: 12px;
    border: 1px solid #e9ecef;
    overflow: hidden;
    margin-top: .8rem;
}
.lib-row {
    display: flex; gap: 1rem;
    padding: .65rem 1rem;
    border-bottom: 1px solid #f0f2f5;
    font-size: .88rem;
}
.lib-row:last-child { border-bottom: none; }
.lib-label {
    font-weight: 600; color: #555;
    min-width: 140px; flex-shrink: 0;
}
.lib-val { color: #333; }
.lib-val a { color: #0d6efd; }

/* Liste légale */
.legal-list {
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-direction: column; gap: .6rem;
}
.legal-list li {
    display: flex; align-items: flex-start;
    font-size: .9rem; color: #444; line-height: 1.5;
}

/* Tableau légal */
.legal-table-wrap {
    overflow-x: auto;
    border-radius: 12px;
    border: 1px solid #e9ecef;
    margin-top: .8rem;
}
.legal-table {
    width: 100%; border-collapse: collapse;
    font-size: .85rem;
}
.legal-table thead th {
    background: #f8f9fa;
    font-size: .75rem; text-transform: uppercase;
    letter-spacing: .6px; color: #888; font-weight: 600;
    padding: .7rem 1rem;
    border-bottom: 2px solid #e9ecef;
    white-space: nowrap;
}
.legal-table tbody td {
    padding: .65rem 1rem;
    border-bottom: 1px solid #f0f2f5;
    color: #444; vertical-align: top;
    line-height: 1.5;
}
.legal-table tbody tr:last-child td { border-bottom: none; }
.legal-table tbody tr:hover { background: #fafbfc; }
.legal-table code {
    background: #f0f2f5; color: #e83e8c;
    padding: .1rem .4rem; border-radius: 4px;
    font-size: .8rem;
}

/* Highlight contact */
.legal-highlight {
    background: #e8f0fe;
    border: 1px solid #c7d9fc;
    border-radius: 12px;
    padding: .9rem 1.2rem;
    font-size: .88rem; color: #333;
    line-height: 1.6;
}
.legal-highlight a { color: #0d6efd; font-weight: 600; }

/* Droits cards */
.legal-right-card {
    display: flex; align-items: flex-start; gap: .8rem;
    padding: .8rem 1rem;
    background: #f8f9fa;
    border-radius: 12px;
    border: 1px solid #e9ecef;
    font-size: .85rem;
    height: 100%;
}
.legal-right-card i { font-size: 1.1rem; flex-shrink: 0; margin-top: .1rem; }
.lrc-title { font-weight: 700; color: #0a0f2c; margin-bottom: .2rem; }
.lrc-desc  { color: #888; font-size: .78rem; }

/* Date de mise à jour */
.legal-update {
    font-size: .82rem; color: #aaa;
    margin-top: 1rem !important;
    font-style: italic;
}

/* ── Résumé politique ── */
.legal-summary {
    background: white;
    border-radius: 16px;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
    padding: 1.4rem;
}
.ls-item {
    text-align: center; padding: .5rem;
}
.ls-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1rem; font-weight: 700;
    color: #0a0f2c; margin-bottom: .3rem;
}
.ls-desc { font-size: .78rem; color: #888; line-height: 1.4; }

/* ── Liens utiles bas de page ── */
.legal-links {
    display: flex; flex-wrap: wrap; gap: .8rem;
}
.ll-btn {
    display: inline-flex; align-items: center;
    padding: .6rem 1.2rem;
    background: white;
    border: 1.5px solid #dee2e6;
    border-radius: 50px;
    color: #555; font-size: .85rem; font-weight: 600;
    text-decoration: none;
    transition: all .2s;
}
.ll-btn:hover {
    border-color: #0d6efd; color: #0d6efd;
    background: #f0f4ff;
}
.ll-btn.external:hover {
    border-color: #198754; color: #198754;
    background: #f0fdf4;
}

/* ── Responsive ── */
@media (max-width: 767px) {
    .legal-section { padding: 1.4rem 1.2rem; }
    .lib-row { flex-direction: column; gap: .2rem; }
    .lib-label { min-width: unset; }
}

/* ================================================================
   PAGE JOUEURS EN CHIFFRES
================================================================ */

/* ── Section title ── */
.joueurs-section-title {
    border-bottom: 2px solid #f0f2f5;
    padding-bottom: .8rem;
}

/* ── KPI cards ── */
.jkpi-card {
    background: white;
    border-radius: 18px;
    border: 1px solid #e9ecef;
    border-top: 4px solid #e9ecef;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
    padding: 1.4rem 1rem;
    text-align: center;
    transition: transform .25s, box-shadow .25s;
}
.jkpi-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 10px 30px rgba(0,0,0,.1);
}
.jkpi-card.total        { border-top-color: #0d6efd; }
.jkpi-card.competiteurs { border-top-color: #f0b429; }
.jkpi-card.jeunes       { border-top-color: #198754; }
.jkpi-card.loisirs      { border-top-color: #17a2b8; }
.jkpi-card.femmes       { border-top-color: #e83e8c; }
.jkpi-card.arbitres     { border-top-color: #6f42c1; }
.jkpi-card.equipes      { border-top-color: #fd7e14; }
.jkpi-card.national     { border-top-color: #dc3545; }

.jkpi-icon {
    font-size: 1.5rem; margin-bottom: .5rem;
}
.jkpi-card.total        .jkpi-icon { color: #0d6efd; }
.jkpi-card.competiteurs .jkpi-icon { color: #f0b429; }
.jkpi-card.jeunes       .jkpi-icon { color: #198754; }
.jkpi-card.loisirs      .jkpi-icon { color: #17a2b8; }
.jkpi-card.femmes       .jkpi-icon { color: #e83e8c; }
.jkpi-card.arbitres     .jkpi-icon { color: #6f42c1; }
.jkpi-card.equipes      .jkpi-icon { color: #fd7e14; }
.jkpi-card.national     .jkpi-icon { color: #dc3545; }

.jkpi-val {
    font-family: 'Rajdhani', sans-serif;
    font-size: 2.4rem; font-weight: 700;
    color: #0a0f2c; line-height: 1;
    margin-bottom: .3rem;
}
.jkpi-lbl {
    font-family: 'Rajdhani', sans-serif;
    font-size: .95rem; font-weight: 700;
    color: #333; margin-bottom: .15rem;
}
.jkpi-sub {
    font-size: .7rem; color: #aaa;
    text-transform: uppercase; letter-spacing: .4px;
}

/* ── Chart cards ── */
.joueurs-chart-card {
    background: white;
    border-radius: 16px;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
    padding: 1.6rem;
    height: 100%;
}
.jcc-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.1rem; font-weight: 700;
    color: #0a0f2c; margin-bottom: 1.4rem;
    display: flex; align-items: center;
}

/* Donut */
.jcc-donut-wrap {
    display: flex; align-items: center;
    gap: 2rem; flex-wrap: wrap;
}
.jcc-donut {
    width: 160px; height: 160px; flex-shrink: 0;
}
.jcc-legend {
    display: flex; flex-direction: column; gap: .6rem;
    flex: 1;
}
.jccl-item {
    display: flex; align-items: center; gap: .6rem;
    font-size: .85rem;
}
.jccl-dot {
    width: 10px; height: 10px; border-radius: 50%;
    flex-shrink: 0;
}
.jccl-label { flex: 1; color: #555; }
.jccl-val   { font-weight: 700; color: #0a0f2c; }

/* Barres évolution */
.jcc-bars-wrap {
    display: flex; align-items: flex-end;
    gap: 1rem; height: 160px;
}
.jcc-bar-item {
    display: flex; flex-direction: column;
    align-items: center; flex: 1; height: 100%;
    gap: .3rem;
}
.jcc-bar-val {
    font-family: 'Rajdhani', sans-serif;
    font-size: .8rem; font-weight: 700; color: #0a0f2c;
}
.jcc-bar-outer {
    flex: 1; width: 100%; display: flex;
    align-items: flex-end;
    background: #f0f2f5; border-radius: 6px;
    overflow: hidden;
}
.jcc-bar-inner {
    width: 100%; border-radius: 6px;
    transition: height 1s ease;
    min-height: 4px;
}
.jcc-bar-label {
    font-size: .65rem; color: #aaa;
    text-align: center; white-space: nowrap;
}

/* ── Badges joueurs ── */
.joueur-badge {
    font-size: .62rem; font-weight: 700;
    padding: .1rem .5rem; border-radius: 8px;
    text-transform: uppercase; letter-spacing: .4px;
    display: inline-block; margin-top: .1rem;
}
.joueur-badge.competition { background: #e8f0fe; color: #0d6efd; }
.joueur-badge.loisir      { background: #e8f9f0; color: #198754; }

/* ── Filtres joueurs ── */
.joueur-filter-btns { display: flex; gap: .4rem; flex-wrap: wrap; }

/* ── Liens résultats ── */
.joueur-links {
    display: flex; gap: .3rem; justify-content: center;
}
.joueur-link-btn {
    width: 30px; height: 30px; border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    font-size: .75rem; text-decoration: none;
    transition: all .2s;
    border: 1.5px solid;
}
.joueur-link-btn.charts {
    color: #0d6efd; border-color: #c7d9fc;
    background: #e8f0fe;
}
.joueur-link-btn.charts:hover {
    background: #0d6efd; color: white; border-color: #0d6efd;
}
.joueur-link-btn.results {
    color: #198754; border-color: #b6dfc8;
    background: #e8f9f0;
}
.joueur-link-btn.results:hover {
    background: #198754; color: white; border-color: #198754;
}

/* ================================================================
   PAGE PLAN DU SITE
================================================================ */

/* ── Card section ── */
.smap-card {
    background: white;
    border-radius: 16px;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
    padding: 1.4rem;
    height: 100%;
    transition: transform .2s, box-shadow .2s;
}
.smap-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 28px rgba(0,0,0,.08);
}

/* ── En-tête ── */
.smap-header {
    display: flex; align-items: center; gap: .9rem;
    margin-bottom: 1rem;
    padding-bottom: .9rem;
    border-bottom: 2px solid #f0f2f5;
}
.smap-icon {
    width: 40px; height: 40px; border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1rem; flex-shrink: 0;
}
.smap-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.1rem; font-weight: 700;
    color: #0a0f2c; margin: 0;
}

/* ── Liens ── */
.smap-links {
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-direction: column; gap: .15rem;
}
.smap-links.single { gap: 0; }

.smap-links li a {
    display: flex; align-items: center;
    padding: .45rem .6rem;
    border-radius: 8px;
    text-decoration: none;
    font-size: .88rem; color: #444;
    transition: background .15s, color .15s;
}
.smap-links li a:hover {
    background: #f0f4ff; color: #0d6efd;
}

/* Label de groupe */
.smap-group-label {
    font-size: .68rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .8px;
    color: #aaa; padding: .5rem .6rem .2rem;
}
.smap-group-label.mt-2 { margin-top: .4rem; }

/* ── Liens rapides ── */
.smap-quicklinks {
    background: linear-gradient(135deg, #0a0f2c, #1565c0);
    border-radius: 20px;
    padding: 2rem;
}
.smap-ql-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.2rem; font-weight: 700;
    color: white; margin-bottom: 1.2rem;
    display: flex; align-items: center;
}
.smap-ql-grid {
    display: flex; flex-wrap: wrap; gap: .8rem;
}
.smap-ql-btn {
    display: inline-flex; align-items: center;
    padding: .6rem 1.2rem;
    background: rgba(255,255,255,.1);
    border: 1px solid rgba(255,255,255,.2);
    border-radius: 50px;
    color: white; font-size: .85rem; font-weight: 600;
    text-decoration: none;
    transition: all .2s;
}
.smap-ql-btn:hover {
    background: white; color: #0a0f2c;
    transform: translateY(-2px);
}

/* ── Responsive ── */
@media (max-width: 575px) {
    .smap-ql-grid { flex-direction: column; }
    .smap-ql-btn  { justify-content: center; }
}

/* ================================================================
   PAGE STAGES ÉTÉ
================================================================ */

/* ── Hero ── */
.stage-hero {
    background: #0a0f2c !important;
    position: relative; overflow: hidden;
}
.stage-hero-bg {
    position: absolute; inset: 0;
    background:
        radial-gradient(ellipse at 20% 50%, rgba(240,180,41,.3) 0%, transparent 55%),
        radial-gradient(ellipse at 80% 30%, rgba(13,110,253,.2) 0%, transparent 55%),
        linear-gradient(135deg, #0a0f2c, #1565c0);
}
.stage-hero-badges {
    display: flex; flex-wrap: wrap;
    gap: .6rem; align-items: center;
    margin-top: 1rem;
}
.shb-item {
    display: inline-flex; align-items: center;
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.2);
    color: white; border-radius: 20px;
    padding: .3rem .9rem; font-size: .82rem; font-weight: 600;
}
.shb-item.urgent {
    background: rgba(220,53,69,.3);
    border-color: rgba(220,53,69,.5);
    color: #fca5a5;
    animation: urgentPulse 2s ease-in-out infinite;
}
@keyframes urgentPulse {
    0%,100% { opacity: 1; }
    50%      { opacity: .7; }
}
.shb-sep { color: rgba(255,255,255,.3); font-size: 1.2rem; }

/* ── Section title ── */
.stages-section-title {
    border-bottom: 2px solid #f0f2f5;
    padding-bottom: .8rem;
}

/* ── Formules ── */
.stage-formule-card {
    background: white;
    border-radius: 20px;
    border: 2px solid #e9ecef;
    padding: 1.8rem;
    height: 100%; position: relative;
    overflow: hidden;
    transition: transform .3s, box-shadow .3s;
}
.stage-formule-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 14px 40px rgba(0,0,0,.1);
}
.stage-formule-card.formule-a {
    border-color: #0d6efd;
    background: linear-gradient(160deg, white 70%, #f0f4ff 100%);
}
.stage-formule-card.formule-b {
    border-color: #f0b429;
    background: linear-gradient(160deg, white 70%, #fffbeb 100%);
}

.sfc-badge {
    position: absolute; top: 16px; right: 16px;
    width: 44px; height: 44px; border-radius: 50%;
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.4rem; font-weight: 700; color: white;
    display: flex; align-items: center; justify-content: center;
}
.formule-a .sfc-badge { background: #0d6efd; }
.formule-b .sfc-badge { background: #f0b429; color: #0a0f2c; }

.sfc-header {
    display: flex; align-items: flex-start; gap: 1rem;
    margin-bottom: 1.2rem;
}
.sfc-icon {
    width: 50px; height: 50px; border-radius: 14px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.3rem; flex-shrink: 0;
}
.formule-a .sfc-icon { background: #e8f0fe; color: #0d6efd; }
.formule-b .sfc-icon { background: #fef3c7; color: #d97706; }

.sfc-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.25rem; font-weight: 700; color: #0a0f2c;
    margin: 0 0 .2rem;
}
.sfc-tagline {
    font-size: .8rem; color: #888; margin: 0;
    font-style: italic;
}

.sfc-body p { font-size: .88rem; color: #555; margin-bottom: .8rem; }
.sfc-list {
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-direction: column; gap: .3rem;
}
.sfc-list li { font-size: .85rem; color: #444; }

.sfc-activities {
    display: flex; flex-wrap: wrap; gap: .4rem;
    margin-top: .4rem;
}
.sfc-act {
    display: inline-flex; align-items: center;
    background: #f8f9fa; border: 1px solid #e9ecef;
    border-radius: 20px; padding: .2rem .7rem;
    font-size: .75rem; color: #555;
}

.sfc-volume {
    margin-top: 1.2rem; padding-top: 1rem;
    border-top: 1px solid #f0f2f5;
    font-size: .85rem; font-weight: 600;
    color: #0a0f2c;
}
.formule-a .sfc-volume { color: #0d6efd; }
.formule-b .sfc-volume { color: #d97706; }

/* ── Périodes ── */
.stage-periode-card {
    background: white;
    border-radius: 20px;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 16px rgba(0,0,0,.06);
    padding: 1.6rem;
    display: flex; flex-direction: column; gap: 1.2rem;
    height: 100%;
}
.spc-num {
    width: 44px; height: 44px; border-radius: 50%;
    background: linear-gradient(135deg, #0a0f2c, #1565c0);
    color: white; font-family: 'Rajdhani', sans-serif;
    font-size: 1.4rem; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
}
.spc-label {
    font-size: .72rem; text-transform: uppercase;
    letter-spacing: .8px; color: #aaa; margin-bottom: .3rem;
}
.spc-range {
    font-size: 1rem; font-weight: 600; color: #0a0f2c;
}
.spc-duration {
    font-size: .78rem; color: #888; margin-top: .2rem;
}
.spc-tarifs {
    display: grid; grid-template-columns: 1fr 1fr; gap: .8rem;
}
.spc-tarif {
    background: #f8f9fa; border-radius: 12px;
    padding: .9rem; text-align: center;
    border: 1.5px solid #e9ecef;
}
.spc-tarif.demi { border-color: #c7d9fc; background: #e8f0fe; }
.spt-label {
    font-size: .72rem; color: #888; margin-bottom: .4rem;
    display: flex; flex-direction: column; gap: .2rem;
    align-items: center;
}
.spt-price {
    font-family: 'Rajdhani', sans-serif;
    font-size: 2rem; font-weight: 700; color: #0a0f2c;
    line-height: 1;
}
.spt-price span { font-size: 1.2rem; }
.spc-tarif.demi .spt-price { color: #0d6efd; }
.spt-badge {
    background: #dc3545; color: white;
    font-size: .6rem; font-weight: 700;
    padding: .1rem .4rem; border-radius: 8px;
    text-transform: uppercase;
}

/* ── Réductions ── */
.stage-remise-card {
    background: linear-gradient(135deg, #0a0f2c, #1565c0);
    border-radius: 16px; padding: 1.4rem 1.6rem;
    display: flex; align-items: flex-start; gap: 1.2rem;
    color: white;
}
.src-icon {
    width: 50px; height: 50px; border-radius: 12px;
    background: rgba(240,180,41,.2);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.3rem; color: #f0b429; flex-shrink: 0;
}
.src-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.1rem; font-weight: 700;
    margin-bottom: .4rem;
}
.src-desc { font-size: .85rem; color: rgba(255,255,255,.75); margin-bottom: .8rem; }
.src-reductions { display: flex; gap: 1rem; flex-wrap: wrap; }
.src-red {
    display: flex; align-items: center; gap: .6rem;
    background: rgba(255,255,255,.1);
    border: 1px solid rgba(255,255,255,.2);
    border-radius: 10px; padding: .4rem .9rem;
}
.src-nb { font-size: .75rem; color: rgba(255,255,255,.6); }
.src-val {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1rem; font-weight: 700; color: #f0b429;
}

/* ── Encadrement ── */
.stage-encadrement {
    background: white;
    border-radius: 16px;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
    padding: 1.6rem;
}
.se-subtitle {
    font-size: .9rem; font-weight: 600; color: #333;
    margin-bottom: 1.4rem; text-align: center;
}
.se-card {
    background: #f8f9fa; border-radius: 14px;
    border: 1px solid #e9ecef;
    padding: 1.4rem 1rem; text-align: center;
    transition: transform .2s, box-shadow .2s;
}
.se-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(0,0,0,.1);
}
.se-avatar {
    width: 70px; height: 70px; border-radius: 50%;
    background: linear-gradient(135deg, #0d6efd, #1565c0);
    color: white; margin: 0 auto 1rem;
    display: flex; align-items: center; justify-content: center;
}
.se-name {
    font-size: .85rem; color: #888;
}
.se-lastname {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.1rem; font-weight: 700; color: #0a0f2c;
    margin-bottom: .3rem;
}
.se-pts { font-size: .72rem; color: #aaa; }

/* ── Timeline journée ── */
.stage-timeline {
    background: white;
    border-radius: 16px;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
    padding: 1.6rem 2rem;
    position: relative;
}
.stage-timeline::before {
    content: '';
    position: absolute; left: 90px; top: 1.6rem; bottom: 3rem;
    width: 2px; background: #f0f2f5;
}
.stl-item {
    display: flex; align-items: center; gap: 1.2rem;
    padding: .55rem 0; position: relative;
}
.stl-time {
    display: flex; flex-direction: column;
    align-items: flex-end; min-width: 72px; flex-shrink: 0;
}
.stl-start {
    font-family: 'Rajdhani', sans-serif;
    font-size: .95rem; font-weight: 700; color: #0a0f2c;
}
.stl-end { font-size: .68rem; color: #aaa; }

.stl-dot {
    width: 12px; height: 12px; border-radius: 50%;
    border: 2px solid white;
    box-shadow: 0 0 0 2px #dee2e6;
    flex-shrink: 0; z-index: 1;
}
.stl-item.sport   .stl-dot { background: #0d6efd; box-shadow: 0 0 0 2px #0d6efd; }
.stl-item.repas   .stl-dot { background: #198754; box-shadow: 0 0 0 2px #198754; }
.stl-item.detente .stl-dot { background: #f0b429; box-shadow: 0 0 0 2px #f0b429; }
.stl-item.nuit    .stl-dot { background: #6c757d; box-shadow: 0 0 0 2px #6c757d; }
.stl-item.matin   .stl-dot { background: #fd7e14; box-shadow: 0 0 0 2px #fd7e14; }

.stl-content {
    background: #f8f9fa; border-radius: 10px;
    padding: .5rem 1rem; font-size: .88rem; color: #444;
    flex: 1; border: 1px solid #f0f2f5;
}
.stl-item.sport   .stl-content { background: #e8f0fe; border-color: #c7d9fc; color: #084298; }
.stl-item.repas   .stl-content { background: #d1e7dd; border-color: #a3cfbb; color: #0f5132; }
.stl-item.detente .stl-content { background: #fff3cd; border-color: #fde68a; color: #664d03; }
.stl-item.nuit    .stl-content { background: #f0f2f5; color: #555; }
.stl-item.matin   .stl-content { background: #fff0e4; border-color: #fed7aa; color: #9a3412; }

.stl-note {
    font-size: .78rem; color: #aaa;
    margin-top: 1rem; margin-bottom: 0;
    font-style: italic; padding-left: .5rem;
}

/* ── Infos pratiques cards ── */
.stage-info-card {
    background: white;
    border-radius: 16px;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
    padding: 1.4rem;
    height: 100%; text-align: center;
    transition: transform .2s, box-shadow .2s;
}
.stage-info-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(0,0,0,.1);
}
.sic-icon {
    font-size: 1.8rem; color: #0d6efd;
    margin-bottom: .8rem;
}
.sic-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.05rem; font-weight: 700;
    color: #0a0f2c; margin-bottom: .5rem;
}
.sic-text {
    font-size: .82rem; color: #777;
    line-height: 1.5; margin-bottom: .8rem;
}
.sic-badge {
    display: inline-block;
    background: #e8f0fe; color: #0d6efd;
    font-size: .72rem; font-weight: 700;
    padding: .2rem .7rem; border-radius: 20px;
}

/* ── Checklist ── */
.stage-checklist-item {
    display: flex; align-items: flex-start; gap: .9rem;
    background: white; border-radius: 12px;
    border: 1px solid #e9ecef;
    padding: .9rem 1rem;
    transition: border-color .2s;
}
.stage-checklist-item:hover { border-color: #0d6efd; }
.sci-icon {
    width: 36px; height: 36px; border-radius: 10px;
    background: #e8f0fe; color: #0d6efd;
    display: flex; align-items: center; justify-content: center;
    font-size: .9rem; flex-shrink: 0;
}
.sci-title {
    font-weight: 700; font-size: .88rem; color: #0a0f2c;
    margin-bottom: .2rem;
}
.sci-desc { font-size: .78rem; color: #888; line-height: 1.4; }

/* ── CTA & téléchargements ── */
.stage-cta-section {
    background: linear-gradient(135deg, #0a0f2c, #1565c0);
    border-radius: 24px;
    padding: 2.5rem;
    color: white;
}
.scs-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.6rem; font-weight: 700;
    margin-bottom: .8rem;
}
.scs-text {
    color: rgba(255,255,255,.75);
    font-size: .9rem; margin-bottom: 1.2rem;
}
.scs-contact {
    display: flex; flex-direction: column; gap: .5rem;
}
.scs-contact-item {
    display: flex; align-items: center;
    font-size: .9rem;
}
.scs-contact-item a { color: #93c5fd; }
.scs-contact-item a:hover { color: white; }

.stage-downloads {
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.15);
    border-radius: 16px; padding: 1.4rem;
}
.sd-title {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.05rem; font-weight: 700;
    color: white; margin-bottom: 1rem;
    display: flex; align-items: center;
}
.sd-btns {
    display: flex; flex-direction: column; gap: .8rem;
    margin-bottom: 1rem;
}
.sd-btn {
    display: flex; align-items: center; gap: 1rem;
    padding: .9rem 1.1rem;
    border-radius: 12px;
    text-decoration: none; color: white;
    transition: all .2s;
}
.sd-btn.primary {
    background: rgba(220,53,69,.3);
    border: 1px solid rgba(220,53,69,.5);
}
.sd-btn.primary:hover {
    background: #dc3545; border-color: #dc3545;
    transform: translateX(4px);
}
.sd-btn.secondary {
    background: rgba(240,180,41,.2);
    border: 1px solid rgba(240,180,41,.4);
}
.sd-btn.secondary:hover {
    background: rgba(240,180,41,.4);
    transform: translateX(4px);
}
.sd-btn-icon { font-size: 1.4rem; flex-shrink: 0; }
.sd-btn-text {
    display: flex; flex-direction: column; flex: 1;
}
.sd-btn-title { font-weight: 700; font-size: .9rem; }
.sd-btn-sub { font-size: .72rem; color: rgba(255,255,255,.6); }
.sd-btn-arrow { font-size: .9rem; color: rgba(255,255,255,.5); }
.sd-note {
    font-size: .75rem; color: rgba(255,255,255,.5);
    margin: 0; line-height: 1.5;
}

/* ── Info accueil ── */
.stage-accueil {
    background: #e8f0fe;
    border: 1px solid #c7d9fc;
    border-radius: 12px;
    padding: .9rem 1.2rem;
    font-size: .88rem; color: #084298;
}

/* ── Responsive ── */
@media (max-width: 767px) {
    .stage-timeline::before { left: 72px; }
    .stl-time { min-width: 58px; }
    .spc-tarifs { grid-template-columns: 1fr 1fr; }
    .stage-cta-section { padding: 1.4rem; }
    .src-reductions { flex-direction: column; gap: .5rem; }
}
@media (max-width: 575px) {
    .stage-formule-card { padding: 1.2rem; }
    .stage-timeline { padding: 1rem 1rem 1rem 1.2rem; }
    .stage-timeline::before { display: none; }
}

/* ================================================================
   PAGE STAGES VACANCES SCOLAIRES
================================================================ */

/* ── Hero ── */
.sv-hero {
    background: #0a0f2c !important;
    position: relative; overflow: hidden;
}
.sv-hero-bg {
    position: absolute; inset: 0;
    background:
        radial-gradient(ellipse at 15% 50%, rgba(25,135,84,.3) 0%, transparent 55%),
        radial-gradient(ellipse at 85% 30%, rgba(13,110,253,.2) 0%, transparent 55%),
        linear-gradient(135deg, #0a0f2c, #1a3a1a);
}

/* ── KPI ── */
.sv-kpi {
    background: white;
    border-radius: 16px;
    border: 1px solid #e9ecef;
    border-top: 4px solid #0d6efd;
    box-shadow: 0 2px 12px rgba(0,0,0,.05);
    padding: 1.2rem 1rem;
    text-align: center;
    transition: transform .2s, box-shadow .2s;
}
.sv-kpi:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(0,0,0,.1);
}
.sv-kpi-icon { font-size: 1.4rem; color: #0d6efd; margin-bottom: .4rem; }
.sv-kpi-val {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.8rem; font-weight: 700; color: #0a0f2c;
    line-height: 1;
}
.sv-kpi-lbl {
    font-family: 'Rajdhani', sans-serif;
    font-size: .9rem; font-weight: 700; color: #333;
    margin: .2rem 0 .1rem;
}
.sv-kpi-sub { font-size: .7rem; color: #aaa; text-transform: uppercase; letter-spacing: .4px; }

/* ── Section title ── */
.sv-section-title { border-bottom: 2px solid #f0f2f5; padding-bottom: .8rem; }

/* ── Cards stages ── */
.sv-stages-list { display: flex; flex-direction: column; gap: 1.2rem; }

.sv-stage-card {
    background: white;
    border-radius: 18px;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 14px rgba(0,0,0,.05);
    overflow: hidden;
    transition: box-shadow .25s;
}
.sv-stage-card:hover { box-shadow: 0 8px 32px rgba(0,0,0,.1); }
.sv-stage-card.upcoming {
    border-color: #0d6efd;
    box-shadow: 0 4px 20px rgba(13,110,253,.12);
}
.sv-stage-card.sv-ete-link {
    border-color: #f0b429;
    box-shadow: 0 4px 20px rgba(240,180,41,.1);
}

/* Header card */
.sv-sc-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 1rem 1.4rem;
    border-bottom: 1px solid #f0f2f5;
    flex-wrap: wrap; gap: .5rem;
}
.sv-sc-header.toussaint  { background: linear-gradient(135deg, #fff7ed, #fed7aa); }
.sv-sc-header.noel       { background: linear-gradient(135deg, #eff6ff, #dbeafe); }
.sv-sc-header.hiver      { background: linear-gradient(135deg, #f0f9ff, #bae6fd); }
.sv-sc-header.printemps  { background: linear-gradient(135deg, #f0fdf4, #bbf7d0); }
.sv-sc-header.ete        { background: linear-gradient(135deg, #fefce8, #fde68a); }

.sv-sc-vacances {
    display: flex; align-items: center; gap: .9rem;
}
.sv-sc-icon {
    width: 42px; height: 42px; border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.1rem; flex-shrink: 0; background: rgba(255,255,255,.6);
}
.sv-sc-header.toussaint  .sv-sc-icon { color: #ea580c; }
.sv-sc-header.noel       .sv-sc-icon { color: #2563eb; }
.sv-sc-header.hiver      .sv-sc-icon { color: #0284c7; }
.sv-sc-header.printemps  .sv-sc-icon { color: #16a34a; }
.sv-sc-header.ete        .sv-sc-icon { color: #d97706; }

.sv-sc-nom {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.1rem; font-weight: 700; color: #0a0f2c;
}
.sv-sc-saison { font-size: .72rem; color: #888; }

/* Statuts */
.sv-sc-status {
    font-size: .72rem; font-weight: 700;
    padding: .3rem .9rem; border-radius: 20px;
    text-transform: uppercase; letter-spacing: .5px;
    white-space: nowrap;
}
.sv-sc-status.past     { background: #e9ecef; color: #6c757d; }
.sv-sc-status.upcoming {
    background: #0d6efd; color: white;
    animation: statusPulse 2s ease-in-out infinite;
}
.sv-sc-status.ete { background: #f0b429; color: #0a0f2c; }
@keyframes statusPulse {
    0%,100% { box-shadow: 0 0 0 0 rgba(13,110,253,.4); }
    50%      { box-shadow: 0 0 0 6px rgba(13,110,253,0); }
}

/* Corps card */
.sv-sc-body { padding: 1.2rem 1.4rem; }

.sv-sc-dates-wrap { margin-bottom: 1rem; }
.sv-sc-date-item {
    font-size: .9rem; color: #444;
    display: flex; align-items: center;
    padding: .5rem .8rem;
    background: #f8f9fa; border-radius: 10px;
    border: 1px solid #e9ecef;
}
.sv-sc-date-item.featured {
    background: #e8f0fe; border-color: #c7d9fc;
    color: #084298; font-size: .95rem;
}

.sv-sc-infos {
    display: flex; flex-wrap: wrap; gap: .6rem;
    margin-bottom: .8rem;
}
.sv-sc-info-item {
    display: inline-flex; align-items: center;
    font-size: .82rem; color: #555;
    background: #f8f9fa; border-radius: 8px;
    padding: .3rem .7rem; border: 1px solid #f0f2f5;
}

.sv-sc-note {
    font-size: .75rem; color: #aaa;
    font-style: italic; margin-top: .5rem;
    display: flex; align-items: flex-start;
}

/* Programme mini timeline */
.sv-programme {
    background: #f8f9fa;
    border-radius: 12px; padding: 1rem 1.2rem;
    margin-bottom: .8rem;
}
.sv-prog-title {
    font-size: .82rem; font-weight: 700; color: #555;
    margin-bottom: .8rem; text-transform: uppercase; letter-spacing: .5px;
}
.sv-prog-timeline {
    display: flex; flex-direction: column; gap: .3rem;
    position: relative;
}
.sv-prog-timeline::before {
    content: '';
    position: absolute; left: 44px; top: 4px; bottom: 4px;
    width: 1px; background: #e9ecef;
}
.sv-pt-item {
    display: flex; align-items: center; gap: .7rem;
    font-size: .8rem;
}
.sv-pt-time {
    min-width: 38px; text-align: right;
    font-family: 'Rajdhani', sans-serif;
    font-size: .78rem; font-weight: 700; color: #aaa;
    flex-shrink: 0;
}
.sv-pt-dot {
    width: 8px; height: 8px; border-radius: 50%;
    background: #dee2e6; flex-shrink: 0; z-index: 1;
}
.sv-pt-item.sport   .sv-pt-dot { background: #0d6efd; }
.sv-pt-item.repas   .sv-pt-dot { background: #198754; }
.sv-pt-item.fin     .sv-pt-dot { background: #dc3545; }
.sv-pt-label { color: #555; }
.sv-pt-item.sport   .sv-pt-label { color: #084298; font-weight: 500; }
.sv-pt-item.repas   .sv-pt-label { color: #0f5132; }

/* CTA dans card */
.sv-sc-cta {
    display: flex; gap: .8rem; flex-wrap: wrap;
    margin-top: 1.2rem; padding-top: 1rem;
    border-top: 1px solid #f0f2f5;
}
.sv-inscrit-btn {
    display: inline-flex; align-items: center;
    padding: .65rem 1.4rem;
    background: #0d6efd; color: white;
    border: none; border-radius: 50px;
    font-size: .88rem; font-weight: 700;
    cursor: pointer; text-decoration: none;
    transition: background .2s, transform .2s;
}
.sv-inscrit-btn:hover {
    background: #0a58ca; color: white; transform: translateY(-2px);
}
.sv-info-btn {
    display: inline-flex; align-items: center;
    padding: .65rem 1.2rem;
    background: white; color: #555;
    border: 1.5px solid #dee2e6; border-radius: 50px;
    font-size: .88rem; font-weight: 600;
    text-decoration: none;
    transition: all .2s;
}
.sv-info-btn:hover { border-color: #0d6efd; color: #0d6efd; }

/* Card été */
.sv-ete-desc { font-size: .85rem; color: #555; line-height: 1.6; margin-bottom: .8rem; }
.sv-ete-periodes { display: flex; gap: .6rem; flex-wrap: wrap; }
.sv-ete-p {
    display: inline-flex; align-items: center;
    background: #fef3c7; color: #d97706;
    border: 1px solid #fde68a;
    border-radius: 20px; padding: .2rem .8rem;
    font-size: .78rem; font-weight: 600;
}
.sv-ete-prix {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.3rem; font-weight: 700; color: #0a0f2c;
    margin-bottom: .8rem;
}
.sv-ete-prix small { font-size: .7rem; color: #aaa; display: block; }
.sv-ete-btn {
    display: inline-flex; align-items: center;
    padding: .6rem 1.4rem;
    background: #f0b429; color: #0a0f2c;
    border-radius: 50px; font-weight: 700; font-size: .88rem;
    text-decoration: none; transition: all .2s;
}
.sv-ete-btn:hover { background: #d97706; color: white; }

/* ── Sidebar ── */
.sv-sidebar { display: flex; flex-direction: column; gap: 1.2rem; position: sticky; top: 80px; }

/* Contact widget */
.sv-contact-widget { border-top: 3px solid #0d6efd; }
.sv-cw-text { font-size: .85rem; color: #555; margin-bottom: 1rem; }
.sv-cw-contact { display: flex; flex-direction: column; gap: .5rem; }
.sv-cw-btn {
    display: flex; align-items: center; gap: .8rem;
    padding: .7rem 1rem; border-radius: 12px;
    text-decoration: none; color: #333;
    border: 1.5px solid #e9ecef;
    transition: all .2s;
}
.sv-cw-btn i { font-size: 1rem; flex-shrink: 0; }
.sv-cw-btn.phone { color: #198754; border-color: #b6dfc8; background: #f0fdf4; }
.sv-cw-btn.phone:hover { background: #198754; color: white; border-color: #198754; }
.sv-cw-btn.email { color: #0d6efd; border-color: #c7d9fc; background: #e8f0fe; }
.sv-cw-btn.email:hover { background: #0d6efd; color: white; border-color: #0d6efd; }
.sv-cw-btn.form { color: #6f42c1; border-color: #d9c5f7; background: #f3eeff; }
.sv-cw-btn.form:hover { background: #6f42c1; color: white; border-color: #6f42c1; }
.sv-cw-label { font-size: .68rem; color: inherit; opacity: .7; text-transform: uppercase; letter-spacing: .4px; }
.sv-cw-val { font-size: .82rem; font-weight: 600; display: block; }

/* Tarifs */
.sv-tarifs { display: flex; flex-direction: column; gap: .5rem; margin-bottom: .8rem; }
.sv-tarif-row {
    display: flex; align-items: center; justify-content: space-between;
    padding: .6rem .8rem; border-radius: 10px;
    background: #f8f9fa; border: 1px solid #f0f2f5;
}
.sv-tarif-label { font-size: .85rem; color: #444; }
.sv-tarif-price {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.2rem; font-weight: 700; color: #0d6efd;
}
.sv-tarif-price.alt { color: #6c757d; }
.sv-tarif-price small { font-size: .65rem; color: #aaa; font-weight: 400; }
.sv-tarif-note { font-size: .75rem; color: #aaa; margin: 0; }

/* Infos pratiques */
.sv-infos-list {
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-direction: column; gap: .7rem;
}
.sv-infos-list li {
    display: flex; align-items: flex-start; gap: .8rem;
    padding-bottom: .7rem; border-bottom: 1px solid #f0f2f5;
    font-size: .85rem;
}
.sv-infos-list li:last-child { border-bottom: none; padding-bottom: 0; }
.sv-il-icon {
    width: 30px; height: 30px; border-radius: 8px;
    background: #e8f0fe; color: #0d6efd;
    display: flex; align-items: center; justify-content: center;
    font-size: .8rem; flex-shrink: 0;
}
.sv-il-label { font-size: .68rem; color: #aaa; text-transform: uppercase; letter-spacing: .4px; margin-bottom: .15rem; }
.sv-il-val { color: #333; line-height: 1.4; }

/* Sidebar été */
.sv-ete-widget { border-top: 3px solid #f0b429; }
.sv-ete-sidebar-btn {
    display: inline-flex; align-items: center;
    padding: .6rem 1.2rem;
    background: #f0b429; color: #0a0f2c;
    border-radius: 50px; font-weight: 700; font-size: .85rem;
    text-decoration: none; transition: all .2s;
}
.sv-ete-sidebar-btn:hover { background: #d97706; color: white; }

/* ── Photos ── */
.sv-photos-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: .8rem;
    border-radius: 16px; overflow: hidden;
}
.sv-photo-item {
    position: relative; overflow: hidden;
    border-radius: 10px; aspect-ratio: 1;
    background: #f0f4ff; cursor: pointer;
}
.sv-photo-img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform .4s ease;
}
.sv-photo-item:hover .sv-photo-img { transform: scale(1.08); }
.sv-photo-overlay {
    position: absolute; inset: 0;
    background: rgba(13,110,253,.3);
    display: flex; align-items: center; justify-content: center;
    color: white; font-size: 1.2rem;
    opacity: 0; transition: opacity .3s;
}
.sv-photo-item:hover .sv-photo-overlay { opacity: 1; }

/* ── Responsive ── */
@media (max-width: 991px) {
    .sv-sidebar { position: static; }
}
@media (max-width: 767px) {
    .sv-sc-header { padding: .8rem 1rem; }
    .sv-sc-body   { padding: 1rem; }
    .sv-photos-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 575px) {
    .sv-photos-grid { grid-template-columns: repeat(2, 1fr); }
    .sv-sc-infos { flex-direction: column; }
}
