/* =========================================================
   V. Indomitus Padel — CSS Public
   Thème : Noir · Vert padel · Blanc
   Police : Barlow Condensed + Barlow
   ========================================================= */

/* ── RESET & VARIABLES ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --green:       #2ecc71;
  --green-dark:  #27ae60;
  --green-glow:  rgba(46,204,113,0.15);
  --dark:        #0d1117;
  --dark2:       #111827;
  --dark3:       #1a2234;
  --surface:     #1e2a3a;
  --border:      rgba(255,255,255,0.08);
  --text:        #e2e8f0;
  --text-muted:  #6b7280;
  --white:       #ffffff;
  --radius:      6px;
  --font-display: 'Barlow Condensed', sans-serif;
  --font-body:    'Barlow', sans-serif;
}

html { scroll-behavior: smooth; }
body { background: var(--dark); color: var(--text); font-family: var(--font-body); font-size: 16px; line-height: 1.6; overflow-x: hidden; }
a { color: var(--green); text-decoration: none; }
img { max-width: 100%; display: block; }
button { cursor: pointer; font-family: inherit; }

/* ── HEADER ── */
.site-header { position: fixed; top: 0; left: 0; right: 0; z-index: 100; background: rgba(13,17,23,0.95); backdrop-filter: blur(12px); border-bottom: 1px solid var(--border); }
.header-inner { max-width: 1200px; margin: 0 auto; padding: 0 1.5rem; height: 64px; display: flex; align-items: center; gap: 2rem; }
.header-brand { display: flex; align-items: center; gap: 0.75rem; color: var(--white); font-family: var(--font-display); font-size: 1.1rem; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; }
.header-logo { height: 38px; width: auto; object-fit: contain; }
.header-nav { margin-left: auto; display: flex; align-items: center; gap: 0.25rem; }
.header-nav a { color: var(--text-muted); font-size: 0.88rem; font-weight: 500; letter-spacing: 0.5px; text-transform: uppercase; padding: 0.5rem 0.9rem; border-radius: var(--radius); transition: color 0.2s, background 0.2s; }
.header-nav a:hover, .header-nav a.active { color: var(--white); background: rgba(255,255,255,0.06); }
.nav-reserve { background: var(--green) !important; color: var(--dark) !important; font-weight: 700 !important; padding: 0.5rem 1.2rem !important; }
.nav-reserve:hover { background: var(--green-dark) !important; }
.nav-reserve-disabled { opacity: 0.4; cursor: not-allowed; }

/* ── HERO ── */
.hero-section { min-height: 100vh; display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; padding-top: 64px; }
.hero-bg { position: absolute; inset: 0; background: radial-gradient(ellipse at 60% 40%, rgba(46,204,113,0.12) 0%, transparent 60%), radial-gradient(ellipse at 20% 80%, rgba(46,204,113,0.06) 0%, transparent 50%), var(--dark); }
.hero-bg::after { content: ''; position: absolute; inset: 0; background-image: linear-gradient(rgba(46,204,113,0.03) 1px, transparent 1px), linear-gradient(90deg, rgba(46,204,113,0.03) 1px, transparent 1px); background-size: 60px 60px; }
.hero-content { position: relative; z-index: 1; text-align: center; padding: 2rem 1.5rem; max-width: 700px; }
.hero-badge { display: inline-block; background: var(--green-glow); border: 1px solid rgba(46,204,113,0.3); color: var(--green); font-family: var(--font-display); font-size: 0.75rem; font-weight: 600; letter-spacing: 3px; text-transform: uppercase; padding: 0.4rem 1.2rem; border-radius: 20px; margin-bottom: 1.5rem; }
.hero-name { font-family: var(--font-display); font-size: clamp(2.8rem, 8vw, 5.5rem); font-weight: 800; line-height: 1; letter-spacing: -1px; color: var(--white); text-transform: uppercase; margin-bottom: 0.75rem; }
.hero-tagline { font-family: var(--font-display); font-size: 1.2rem; font-weight: 300; letter-spacing: 4px; color: var(--green); text-transform: uppercase; margin-bottom: 2rem; }
.hero-stats { display: flex; align-items: center; justify-content: center; gap: 0; margin-bottom: 2.5rem; background: rgba(255,255,255,0.04); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
.hero-stat { flex: 1; padding: 1.1rem 1.5rem; text-align: center; }
.hero-stat-sep { width: 1px; height: 50px; background: var(--border); }
.stat-num { display: block; font-family: var(--font-display); font-size: 2rem; font-weight: 800; color: var(--green); line-height: 1; }
.stat-num small { font-size: 1rem; }
.stat-lbl { display: block; font-size: 0.72rem; font-weight: 500; letter-spacing: 1px; text-transform: uppercase; color: var(--text-muted); margin-top: 0.2rem; }
.hero-actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
.btn-reserve { display: inline-block; background: var(--green); color: var(--dark); font-family: var(--font-display); font-size: 1rem; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; padding: 0.9rem 2.2rem; border-radius: var(--radius); border: none; transition: all 0.2s; }
.btn-reserve:hover { background: var(--green-dark); transform: translateY(-1px); box-shadow: 0 8px 24px rgba(46,204,113,0.3); }
.btn-disabled { opacity: 0.4; cursor: not-allowed; }
.btn-secondary-cta { display: inline-block; background: transparent; color: var(--white); font-family: var(--font-display); font-size: 1rem; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; padding: 0.9rem 2rem; border-radius: var(--radius); border: 1px solid rgba(255,255,255,0.2); transition: all 0.2s; }
.btn-secondary-cta:hover { border-color: var(--green); color: var(--green); }

/* ── SECTIONS COMMUNES ── */
.section-inner { max-width: 1200px; margin: 0 auto; padding: 5rem 1.5rem; }
.section-header { text-align: center; margin-bottom: 3rem; }
.section-header h2 { font-family: var(--font-display); font-size: clamp(2rem, 5vw, 3rem); font-weight: 800; text-transform: uppercase; letter-spacing: -0.5px; color: var(--white); }
.section-header p { margin-top: 0.5rem; color: var(--text-muted); font-size: 1rem; }
.section-header.light h2 { color: var(--white); }

/* ── PRÉSENTATION ── */
.presentation-section { background: var(--dark2); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.pres-inner { max-width: 1200px; margin: 0 auto; padding: 5rem 1.5rem; display: grid; grid-template-columns: 1fr 340px; gap: 4rem; align-items: start; }
.pres-text h2 { font-family: var(--font-display); font-size: 2rem; font-weight: 700; color: var(--white); margin-bottom: 1rem; line-height: 1.2; }
.pres-text p { color: var(--text); line-height: 1.8; font-size: 0.97rem; }
.pres-horaires { background: var(--dark3); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.75rem; }
.pres-horaires h3 { font-family: var(--font-display); font-size: 1.2rem; font-weight: 700; color: var(--green); text-transform: uppercase; letter-spacing: 2px; margin-bottom: 1.25rem; }
.horaires-list { display: flex; flex-direction: column; gap: 0.5rem; }
.horaire-row { display: flex; justify-content: space-between; align-items: center; font-size: 0.88rem; padding: 0.5rem 0; border-bottom: 1px solid var(--border); }
.horaire-row:last-child { border-bottom: none; }
.horaire-jour { color: var(--text-muted); }
.horaire-heure { color: var(--white); font-weight: 500; }
.contact-box { margin-top: 1.5rem; display: flex; flex-direction: column; gap: 0.6rem; }
.contact-tel, .contact-mail { color: var(--green); font-size: 0.88rem; display: flex; align-items: center; gap: 0.4rem; transition: color 0.2s; }
.contact-tel:hover, .contact-mail:hover { color: var(--green-dark); }

/* ── TERRAINS ── */
.terrains-section { background: var(--dark); }
.terrains-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.terrain-card { background: var(--dark2); border: 1px solid var(--border); border-radius: var(--radius); padding: 2rem; position: relative; transition: all 0.2s; }
.terrain-card:hover { border-color: var(--green); transform: translateY(-3px); box-shadow: 0 8px 32px rgba(46,204,113,0.1); }
.terrain-featured { border-color: rgba(46,204,113,0.3); background: linear-gradient(135deg, var(--dark2) 0%, rgba(46,204,113,0.05) 100%); }
.terrain-badge { display: inline-block; background: var(--green); color: var(--dark); font-family: var(--font-display); font-size: 0.65rem; font-weight: 700; letter-spacing: 2px; padding: 0.2rem 0.6rem; border-radius: 3px; margin-bottom: 1rem; }
.terrain-card h3 { font-family: var(--font-display); font-size: 1.5rem; font-weight: 800; color: var(--white); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 0.3rem; }
.terrain-type { color: var(--text-muted); font-size: 0.85rem; margin-bottom: 1.25rem; }
.terrain-infos { display: flex; flex-direction: column; gap: 0.4rem; font-size: 0.88rem; color: var(--text); margin-bottom: 1.5rem; }
.terrain-btn { display: block; text-align: center; background: var(--green); color: var(--dark); font-family: var(--font-display); font-size: 0.9rem; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; padding: 0.7rem 1.5rem; border-radius: var(--radius); border: none; transition: all 0.2s; }
.terrain-btn:hover { background: var(--green-dark); }


/* ── PHOTO TERRAIN ── */
.terrain-photo {
  width: 100%;
  height: 140px;
  background-size: cover;
  background-position: center;
  border-radius: 4px 4px 0 0;
  margin: -2rem -2rem 1.25rem -2rem;
  width: calc(100% + 4rem);
  position: relative;
  overflow: hidden;
}
.terrain-photo::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 50px;
  background: linear-gradient(transparent, var(--dark2));
}
/* ── SERVICES ── */
.services-section { background: var(--dark2); border-top: 1px solid var(--border); }
.services-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
.service-card { background: var(--dark3); border: 1px solid var(--border); border-radius: var(--radius); padding: 2rem; transition: border-color 0.2s; }
.service-card:hover { border-color: rgba(46,204,113,0.3); }
.service-icon { font-family: var(--font-display); font-size: 0.7rem; font-weight: 700; letter-spacing: 3px; color: var(--green); text-transform: uppercase; margin-bottom: 0.75rem; }
.service-card h3 { font-family: var(--font-display); font-size: 1.3rem; font-weight: 700; color: var(--white); margin-bottom: 0.75rem; }
.service-card p { color: var(--text-muted); font-size: 0.9rem; line-height: 1.7; }
.service-link { display: inline-block; margin-top: 1rem; color: var(--green); font-size: 0.88rem; font-weight: 600; transition: color 0.2s; }
.service-link:hover { color: var(--green-dark); }

/* Tournois client */
.client-tournaments-section { background: var(--dark); border-top: 1px solid var(--border); }
.client-tournaments-head { align-items: flex-end; display: flex; justify-content: space-between; gap: 1rem; }
.client-tournaments-head > div { min-width: 0; }
.client-tournaments-all-link {
  border: 1px solid rgba(46,204,113,.35);
  border-radius: var(--radius);
  color: var(--green);
  font-family: var(--font-display);
  font-size: .9rem;
  font-weight: 800;
  letter-spacing: 1px;
  padding: .75rem 1rem;
  text-transform: uppercase;
  white-space: nowrap;
}
.client-tournaments-all-link:hover { background: var(--green-glow); border-color: var(--green); }
.client-tournaments-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.25rem; }
.client-tournaments-all .client-tournaments-grid { grid-template-columns: repeat(auto-fill, minmax(360px, 1fr)); }
.client-tournament-card { background: var(--dark2); border: 1px solid var(--border); border-radius: var(--radius); transition: border-color .2s, transform .2s; overflow: hidden; }
.client-tournament-card:hover { border-color: rgba(46,204,113,.35); transform: translateY(-2px); }
.client-tournament-card[open] { border-color: rgba(46,204,113,.45); }
.ct-summary { cursor: pointer; display: grid; grid-template-columns: 130px 1fr auto; gap: 1rem; list-style: none; padding: 1rem; }
.ct-summary::-webkit-details-marker { display: none; }
.ct-thumb { align-items: center; aspect-ratio: 4/3; background: linear-gradient(135deg, var(--dark3), rgba(46,204,113,.12)); background-position: center; background-size: cover; border: 1px solid var(--border); border-radius: var(--radius); color: var(--green); display: flex; font-family: var(--font-display); font-weight: 800; justify-content: center; letter-spacing: 1px; min-width: 0; overflow: hidden; text-transform: uppercase; }
.ct-summary-main { min-width: 0; }
.ct-card-head, .ct-meta, .ct-links { display: flex; flex-wrap: wrap; gap: .5rem; align-items: center; }
.ct-card-head { justify-content: space-between; margin-bottom: 1rem; }
.ct-status { background: var(--green-glow); border: 1px solid rgba(46,204,113,.28); border-radius: 999px; color: var(--green); font-size: .72rem; font-weight: 700; letter-spacing: 1px; padding: .25rem .65rem; text-transform: uppercase; }
.status-full .ct-status, .status-cancelled .ct-status { background: rgba(231,76,60,.12); border-color: rgba(231,76,60,.25); color: #ff8a80; }
.status-announced .ct-status { background: rgba(255,255,255,.06); border-color: var(--border); color: var(--text); }
.status-running .ct-status { background: rgba(52,152,219,.12); border-color: rgba(52,152,219,.25); color: #7cc7ff; }
.status-finished .ct-status { background: rgba(184,151,90,.14); border-color: rgba(184,151,90,.28); color: #d8bf7a; }
.ct-date { color: var(--text-muted); font-size: .82rem; }
.client-tournament-card h3, .ct-title { color: var(--white); display: block; font-family: var(--font-display); font-size: 1.45rem; font-weight: 800; letter-spacing: .5px; line-height: 1.05; margin-bottom: .85rem; text-transform: uppercase; }
.ct-meta { margin-bottom: 1rem; }
.ct-meta span { background: var(--dark3); border: 1px solid var(--border); border-radius: 4px; color: var(--text); font-size: .78rem; padding: .35rem .55rem; }
.ct-desc, .ct-note, .ct-live p { color: var(--text-muted); display: block; font-size: .88rem; line-height: 1.6; }
.ct-desc.full { margin-bottom: 1rem; }
.ct-open-label { align-self: center; border: 1px solid var(--border); border-radius: var(--radius); color: var(--text); font-family: var(--font-display); font-size: .78rem; font-weight: 800; letter-spacing: 1px; padding: .55rem .75rem; text-transform: uppercase; white-space: nowrap; }
.client-tournament-card[open] .ct-open-label { background: var(--green); border-color: var(--green); color: var(--dark); }
.ct-detail { border-top: 1px solid var(--border); padding: 1rem; }
.ct-note { background: rgba(255,255,255,.05); border: 1px solid var(--border); border-radius: var(--radius); margin: 1rem 0; padding: .75rem; }
.ct-note.blocked { background: rgba(231,76,60,.08); border-color: rgba(231,76,60,.22); color: #ffaaa3; }
.ct-note a { color: var(--green); font-weight: 800; }
.ct-toggle-form, .ct-submit { background: var(--green); border: 0; border-radius: var(--radius); color: var(--dark); font-family: var(--font-display); font-weight: 800; letter-spacing: 1px; margin-top: 1rem; padding: .75rem 1rem; text-transform: uppercase; width: 100%; }
.ct-register-form { display: none; margin-top: 1rem; }
.ct-register-form.open { display: block; }
.ct-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; }
.ct-register-form input, .ct-register-form select, .ct-register-form textarea { width: 100%; background: var(--dark3); border: 1px solid var(--border); border-radius: var(--radius); color: var(--text); font-family: var(--font-body); margin-bottom: .75rem; outline: none; padding: .72rem .85rem; }
.ct-register-form input:focus, .ct-register-form select:focus, .ct-register-form textarea:focus { border-color: var(--green); }
.hp-field { left: -9999px; position: absolute; }
.ct-form-message { color: var(--text-muted); font-size: .85rem; margin-top: .65rem; min-height: 1.2em; }
.ct-form-message.success { color: var(--green); }
.ct-form-message.error { color: #ff8a80; }
.ct-live { border-top: 1px solid var(--border); display: grid; gap: .85rem; margin-top: 1rem; padding-top: 1rem; }
.ct-live-col { background: rgba(255,255,255,.03); border: 1px solid var(--border); border-radius: var(--radius); padding: .85rem; }
.ct-live-col strong { color: var(--white); display: block; font-family: var(--font-display); letter-spacing: 1px; margin-bottom: .4rem; text-transform: uppercase; }
.ct-standings { background: var(--dark3); border: 1px solid var(--border); border-radius: var(--radius); list-style-position: inside; padding: .85rem 1rem; }
.ct-standings li { color: var(--text); display: flex; justify-content: space-between; gap: .75rem; padding: .25rem 0; }
.ct-winner { border: 1px solid rgba(46,204,113,.28); border-radius: var(--radius); color: var(--green); font-weight: 700; margin-top: 1rem; padding: .75rem; }
.ct-links { margin-top: 1rem; }
.ct-links a { border: 1px solid var(--border); border-radius: var(--radius); color: var(--text); font-size: .85rem; padding: .55rem .8rem; }
.ct-links a:hover { border-color: var(--green); color: var(--green); }

.tournaments-page { background: var(--dark); min-height: 100vh; padding-top: 64px; }
.tournaments-page-hero {
  background:
    radial-gradient(circle at 18% 12%, rgba(46,204,113,.16), transparent 28rem),
    radial-gradient(circle at 86% 4%, rgba(52,152,219,.12), transparent 26rem),
    linear-gradient(180deg, var(--dark2), var(--dark));
  border-bottom: 1px solid var(--border);
}
.tournaments-page-hero .section-inner { padding-bottom: 3rem; padding-top: 4rem; }
.tournaments-page-kicker {
  color: var(--green);
  display: block;
  font-family: var(--font-display);
  font-size: .85rem;
  font-weight: 800;
  letter-spacing: 3px;
  text-transform: uppercase;
}
.tournaments-page-hero h1 {
  color: var(--white);
  font-family: var(--font-display);
  font-size: clamp(3.5rem, 9vw, 7rem);
  font-weight: 800;
  letter-spacing: 1px;
  line-height: .9;
  margin: .35rem 0 .75rem;
  text-transform: uppercase;
}
.tournaments-page-hero p { color: var(--text-muted); line-height: 1.7; max-width: 760px; }
.tournaments-page-stats {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-top: 2rem;
}
.tournaments-page-stats div {
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1rem;
}
.tournaments-page-stats strong {
  color: var(--white);
  display: block;
  font-family: var(--font-display);
  font-size: 2.2rem;
  line-height: 1;
}
.tournaments-page-stats span {
  color: var(--text-muted);
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
}

/* Tournois public v2 */
.tournois-public-page { background:#020617; }
.tournois-public-page .site-header { background:rgba(2,6,23,.92); border-bottom:1px solid rgba(148,163,184,.12); box-shadow:0 18px 48px rgba(0,0,0,.24); }
.tournois-public-page .header-inner { max-width:1540px; height:72px; }
.tournois-public-page .header-nav a.active { color:#22c55e; background:transparent; }
.tournois-public-page .nav-reserve { display:inline-flex; align-items:center; gap:8px; min-height:44px; border-radius:8px; background:#22c55e!important; color:#03120b!important; box-shadow:0 12px 30px rgba(34,197,94,.22); }
.tournois-public-page .nav-reserve svg { width:17px; height:17px; stroke:currentColor; fill:none; stroke-width:2.2; stroke-linecap:round; stroke-linejoin:round; }
.tournaments-public-v2 { min-height:100vh; padding-top:72px; background:radial-gradient(circle at 72% 4%,rgba(34,197,94,.12),transparent 28rem),#020617; color:#fff; }
.tp-container { width:min(1450px,calc(100% - 64px)); margin:0 auto; }
.tp-hero { position:relative; min-height:430px; overflow:hidden; border-bottom:1px solid rgba(148,163,184,.14); background:linear-gradient(180deg,#050b14,#07111f 58%,#020617); }
.tp-hero:before { content:""; position:absolute; inset:0; background:linear-gradient(90deg,rgba(2,6,23,.98) 0%,rgba(2,6,23,.82) 42%,rgba(2,6,23,.28) 74%,rgba(2,6,23,.92) 100%),url('../assets/img/fond.png') center/cover; opacity:.72; }
.tp-hero:after { content:""; position:absolute; inset:0; background:radial-gradient(circle at 78% 42%,rgba(34,197,94,.22),transparent 20rem),linear-gradient(180deg,transparent 72%,#020617 100%); pointer-events:none; }
.tp-hero-bg { position:absolute; inset:0; z-index:1; pointer-events:none; }
.tp-racket { position:absolute; right:7%; top:52px; width:410px; height:410px; transform:rotate(-24deg); opacity:.24; color:#22c55e; filter:drop-shadow(0 0 36px rgba(34,197,94,.45)); }
.tp-racket svg { width:100%; height:100%; stroke:currentColor; fill:none; stroke-width:2.1; stroke-linecap:round; stroke-linejoin:round; }
.tp-ball { position:absolute; right:25%; top:124px; width:86px; height:86px; border-radius:50%; background:radial-gradient(circle at 32% 28%,#8ef46b,#22c55e 38%,#0f5e2b 70%,#052e16 100%); box-shadow:0 0 55px rgba(34,197,94,.5), inset -18px -20px 30px rgba(0,0,0,.38); opacity:.78; }
.tp-hero-inner { position:relative; z-index:2; padding:72px 0 40px; }
.tp-hero-copy { max-width:760px; }
.tp-kicker { display:block; color:#22c55e; font-family:var(--font-display); font-size:18px; font-weight:900; letter-spacing:8px; text-transform:uppercase; }
.tp-hero h1 { margin:16px 0 18px; font-family:var(--font-display); font-size:clamp(72px,8vw,118px); font-weight:900; line-height:.82; text-transform:uppercase; letter-spacing:1px; color:#fff; text-shadow:3px 4px 0 rgba(0,0,0,.5); }
.tp-hero p { max-width:690px; color:#aab6c8; font-size:18px; line-height:1.75; }
.tp-kpis { display:grid; grid-template-columns:repeat(4,1fr); gap:28px; margin-top:34px; }
.tp-kpis article { min-height:104px; display:grid; grid-template-columns:58px auto; grid-template-rows:auto auto; align-items:center; column-gap:18px; padding:22px 28px; border:1px solid rgba(148,163,184,.18); border-radius:8px; background:linear-gradient(145deg,rgba(15,23,42,.82),rgba(2,6,23,.78)); box-shadow:inset 0 1px 0 rgba(255,255,255,.035),0 18px 42px rgba(0,0,0,.24); }
.tp-kpis svg { grid-row:1/3; width:38px; height:38px; padding:10px; box-sizing:content-box; border-radius:50%; background:rgba(34,197,94,.13); color:#22c55e; stroke:currentColor; fill:none; stroke-width:2.25; stroke-linecap:round; stroke-linejoin:round; }
.tp-kpis strong { display:block; font-family:var(--font-display); font-size:43px; line-height:.9; color:#fff; }
.tp-kpis span { color:#94a3b8; font-size:13px; font-weight:900; letter-spacing:2px; text-transform:uppercase; }
.tp-list-section { padding:42px 0 30px; background:linear-gradient(180deg,#07111f,#020617); }
.tp-section-head { display:flex; align-items:flex-end; justify-content:space-between; gap:24px; margin-bottom:24px; }
.tp-section-head h2 { position:relative; margin:0; font-family:var(--font-display); font-size:46px; line-height:.9; font-weight:900; text-transform:uppercase; color:#fff; }
.tp-section-head h2:after { content:""; display:block; width:46px; height:3px; margin-top:16px; background:#22c55e; box-shadow:0 0 18px rgba(34,197,94,.55); }
.tp-section-head p { margin-top:10px; color:#94a3b8; }
.tp-filters { display:flex; gap:10px; flex-wrap:wrap; justify-content:flex-end; }
.tp-filters button { min-height:38px; border:1px solid rgba(148,163,184,.16); border-radius:7px; background:rgba(15,23,42,.58); color:#94a3b8; padding:0 18px; font-family:var(--font-display); font-size:14px; font-weight:900; letter-spacing:1.4px; text-transform:uppercase; }
.tp-filters button.is-active { border-color:rgba(34,197,94,.58); background:rgba(34,197,94,.14); color:#22c55e; }
.tp-grid { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:26px; }
.tp-card { border:1px solid rgba(34,197,94,.22); border-radius:12px; overflow:hidden; background:linear-gradient(145deg,rgba(15,23,42,.92),rgba(2,6,23,.98)); box-shadow:0 24px 58px rgba(0,0,0,.26); transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease; }
.tp-card:hover { transform:translateY(-3px); border-color:rgba(34,197,94,.34); box-shadow:0 28px 70px rgba(0,0,0,.34),0 0 34px rgba(34,197,94,.08); }
.tp-card[hidden] { display:none; }
.tp-card-media { position:relative; aspect-ratio:16/9; margin:14px 14px 0; border:1px solid rgba(34,197,94,.25); border-radius:10px; background:radial-gradient(circle at 50% 26%,rgba(34,197,94,.18),transparent 48%),linear-gradient(145deg,#0f172a,#020617); overflow:hidden; }
.tournament-card-poster img { display:block; width:100%; height:100%; object-fit:contain; object-position:center center; background:#020617; }
.tp-card-fallback { position:absolute; inset:0; display:grid; place-items:center; align-content:center; gap:8px; color:#22c55e; font-family:var(--font-display); font-weight:900; letter-spacing:2px; text-transform:uppercase; }
.tp-card-fallback svg { width:48px; height:48px; stroke:#facc15; fill:none; stroke-width:1.9; stroke-linecap:round; stroke-linejoin:round; filter:drop-shadow(0 0 18px rgba(250,204,21,.32)); }
.tp-status { flex:0 0 auto; display:inline-flex; align-items:center; justify-content:center; min-height:24px; border:1px solid rgba(34,197,94,.34); border-radius:999px; background:rgba(34,197,94,.14); color:#22c55e; padding:0 10px; font-size:11px; font-weight:900; letter-spacing:.8px; text-transform:uppercase; white-space:nowrap; }
.status-upcoming .tp-status { background:rgba(56,189,248,.12); border-color:rgba(56,189,248,.32); color:#7dd3fc; }
.status-finished .tp-status { background:rgba(250,204,21,.12); border-color:rgba(250,204,21,.32); color:#fde68a; }
.tp-card-body { padding:15px 20px 18px; }
.tp-title-row { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:6px; }
.tp-card-date { display:flex; align-items:center; flex-wrap:nowrap; gap:18px; margin-bottom:9px; color:#cbd5e1; font-size:14px; }
.tp-card-date span { display:inline-flex; align-items:center; gap:6px; }
.tp-card svg { width:17px; height:17px; stroke:currentColor; fill:none; stroke-width:2.25; stroke-linecap:round; stroke-linejoin:round; }
.tp-card h3 { min-width:0; min-height:0; margin:0; color:#fff; font-family:var(--font-display); font-size:30px; line-height:.96; font-weight:900; text-transform:uppercase; letter-spacing:.4px; overflow:hidden; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; }
.tp-tags { display:flex; align-items:center; flex-wrap:wrap; gap:7px; min-height:0; margin-bottom:9px; }
.tp-tags span { display:inline-flex; align-items:center; min-height:28px; border:1px solid rgba(148,163,184,.13); border-radius:6px; background:rgba(15,23,42,.86); color:#cbd5e1; padding:0 10px; font-size:13px; }
.tp-inscrits { display:flex; align-items:center; gap:8px; padding:10px 0; border-top:1px solid rgba(148,163,184,.14); border-bottom:1px solid rgba(148,163,184,.14); min-width:0; }
.tp-inscrits div { display:inline-flex; align-items:center; gap:5px; color:#94a3b8; font-size:10.5px; text-transform:uppercase; letter-spacing:.35px; white-space:nowrap; }
.tp-inscrits div svg { width:16px; height:16px; padding:4px; box-sizing:content-box; border-radius:50%; background:rgba(34,197,94,.12); color:#22c55e; }
.tp-inscrits strong { display:inline; color:#fff; font-size:12px; }
.tp-inscrits b { margin-left:auto; color:#22c55e; font-family:var(--font-display); font-size:23px; line-height:1; text-transform:uppercase; text-align:right; text-shadow:0 0 18px rgba(34,197,94,.35); white-space:nowrap; }
.tp-waiting-count { color:#fbbf24!important; }
.tp-waiting-count svg { background:rgba(245,158,11,.14)!important; color:#f59e0b!important; }
.tp-actions { display:grid; grid-template-columns:1fr; gap:9px; margin-top:12px; }
.tp-level,.tp-btn { min-height:42px; display:inline-flex; align-items:center; justify-content:center; gap:8px; border-radius:7px; font-weight:900; text-align:center; }
.tp-level { flex:1 1 auto; justify-content:flex-start; min-width:58px; max-width:86px; min-height:auto; border:0; color:#cbd5e1; background:transparent; font-size:11px; letter-spacing:.2px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.tp-btn { border:1px solid rgba(34,197,94,.30); background:rgba(2,6,23,.40); color:#fff; font-family:var(--font-display); font-size:15px; letter-spacing:1px; text-transform:uppercase; }
.tp-btn:hover { border-color:#22c55e; color:#22c55e; }
.tp-btn-primary { border-color:#22c55e; background:#22c55e; color:#03120b; box-shadow:0 12px 28px rgba(34,197,94,.24); }
.tp-btn-primary:hover { color:#03120b; filter:brightness(1.05); }
.tp-btn-waitlist { border-color:#f59e0b; background:linear-gradient(135deg,#f59e0b,#fbbf24); color:#140d02; box-shadow:0 12px 28px rgba(245,158,11,.22); }
.tp-btn-waitlist:hover { color:#140d02; filter:brightness(1.04); }
.tp-btn-wide { grid-column:1/-1; width:100%; min-height:44px; }
.tp-btn-disabled,.tp-btn-club { border-color:rgba(148,163,184,.22); background:rgba(148,163,184,.10); color:#cbd5e1; box-shadow:none; }
.tp-waitlist-note { margin:0 0 8px; color:#fbbf24; font-size:12px; font-weight:800; text-transform:uppercase; letter-spacing:.55px; }
.tp-register-form { margin-top:16px; padding-top:16px; border-top:1px solid rgba(148,163,184,.14); }
.tp-register-form.open { display:block; }
.tp-empty { min-height:240px; display:grid; place-items:center; gap:18px; border:1px dashed rgba(148,163,184,.22); border-radius:8px; background:rgba(15,23,42,.55); color:#94a3b8; }
.tp-final-line { margin:22px 0 0; display:flex; align-items:center; justify-content:center; gap:10px; color:#94a3b8; font-size:19px; }
.tp-final-line svg { width:22px; height:22px; stroke:#22c55e; fill:none; stroke-width:2.2; stroke-linecap:round; stroke-linejoin:round; }
body.tp-modal-lock { overflow:hidden; }
.tp-modal[aria-hidden="true"] { display:none; }
.tp-modal[aria-hidden="false"] { position:fixed; inset:0; z-index:1000; display:grid; place-items:center; padding:28px; }
.tp-modal-backdrop { position:absolute; inset:0; background:rgba(2,6,23,.78); backdrop-filter:blur(8px); }
.tp-modal-dialog { position:relative; width:min(1030px,100%); max-height:90vh; overflow:auto; border:1px solid rgba(34,197,94,.22); border-radius:18px; background:linear-gradient(145deg,rgba(15,23,42,.98),rgba(3,7,18,.98)); color:#fff; box-shadow:0 34px 110px rgba(0,0,0,.62),0 0 48px rgba(34,197,94,.10); }
.tp-modal-dialog:before { content:""; position:absolute; inset:0; pointer-events:none; border-radius:18px; background:radial-gradient(circle at 20% 4%,rgba(34,197,94,.12),transparent 24rem),linear-gradient(180deg,rgba(255,255,255,.035),transparent 130px); }
.tp-modal-x { position:absolute; z-index:3; right:18px; top:16px; width:38px; height:38px; border:1px solid rgba(148,163,184,.18); border-radius:10px; background:rgba(2,6,23,.52); color:#fff; font-size:28px; line-height:1; }
.tp-modal-x:hover { border-color:rgba(34,197,94,.58); color:#22c55e; }
.tp-modal-head { position:relative; z-index:1; display:grid; grid-template-columns:390px 1fr; gap:28px; padding:34px 38px 24px; }
.tp-modal-poster { aspect-ratio:4/3; border:1px solid rgba(34,197,94,.24); border-radius:13px; background:#020617; overflow:hidden; box-shadow:0 22px 50px rgba(0,0,0,.34); }
.tp-modal-poster img { display:block; width:100%; height:100%; object-fit:contain; object-position:center; background:#020617; }
.tp-modal-fallback { width:100%; height:100%; display:grid; place-items:center; color:#22c55e; font-family:var(--font-display); font-size:38px; font-weight:900; letter-spacing:3px; text-transform:uppercase; background:radial-gradient(circle at 50% 36%,rgba(34,197,94,.18),transparent 55%),#020617; }
.tp-modal-summary { min-width:0; padding-right:42px; align-self:center; }
.tp-modal-status { display:inline-flex; align-items:center; min-height:26px; border-radius:999px; padding:0 10px; font-family:var(--font-display); font-size:13px; font-weight:900; letter-spacing:1px; text-transform:uppercase; }
.tp-modal-status.blue { border:1px solid rgba(56,189,248,.34); background:rgba(56,189,248,.12); color:#7dd3fc; }
.tp-modal-status.green { border:1px solid rgba(34,197,94,.36); background:rgba(34,197,94,.13); color:#22c55e; }
.tp-modal-status.orange { border:1px solid rgba(245,158,11,.38); background:rgba(245,158,11,.14); color:#fbbf24; }
.tp-modal-status.gold { border:1px solid rgba(250,204,21,.30); background:rgba(250,204,21,.11); color:#fde68a; }
.tp-modal-summary h3 { margin:14px 0 14px; font-family:var(--font-display); font-size:clamp(38px,4.2vw,60px); line-height:.9; font-weight:900; text-transform:uppercase; color:#fff; text-shadow:2px 3px 0 rgba(0,0,0,.4); overflow-wrap:anywhere; }
.tp-modal-meta,.tp-modal-tags,.tp-modal-stats { display:flex; align-items:center; flex-wrap:wrap; gap:12px; }
.tp-modal-meta { color:#cbd5e1; font-size:16px; }
.tp-modal-tags { margin-top:14px; }
.tp-modal-tags span { min-height:30px; display:inline-flex; align-items:center; border:1px solid rgba(148,163,184,.15); border-radius:7px; background:rgba(2,6,23,.48); color:#cbd5e1; padding:0 12px; font-size:13px; }
.tp-modal-stats { margin-top:18px; padding-top:16px; border-top:1px solid rgba(148,163,184,.13); color:#cbd5e1; font-size:14px; }
.tp-modal-stats strong { color:#fff; }
.tp-modal-stats .waiting { color:#fbbf24; }
.tp-modal-stats b { margin-left:auto; color:#22c55e; font-family:var(--font-display); font-size:26px; line-height:1; white-space:nowrap; }
.tp-modal-tabs { position:relative; z-index:1; display:flex; gap:6px; padding:0 38px; border-top:1px solid rgba(148,163,184,.13); border-bottom:1px solid rgba(148,163,184,.13); overflow-x:auto; }
.tp-modal-tabs button { position:relative; min-height:58px; border:0; background:transparent; color:#94a3b8; padding:0 18px; font-family:var(--font-display); font-size:15px; font-weight:900; letter-spacing:1px; text-transform:uppercase; white-space:nowrap; }
.tp-modal-tabs button:after { content:""; position:absolute; left:14px; right:14px; bottom:0; height:2px; background:transparent; box-shadow:none; }
.tp-modal-tabs button.is-active { color:#22c55e; }
.tp-modal-tabs button.is-active:after { background:#22c55e; box-shadow:0 0 18px rgba(34,197,94,.55); }
.tp-modal-content { position:relative; z-index:1; padding:22px 38px 26px; }
.tp-modal-panel { display:none; }
.tp-modal-panel.is-active { display:block; }
.tp-modal-info-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:14px; }
.tp-modal-info-grid article,.tp-modal-list,.tp-modal-matches,.tp-modal-standings { border:1px solid rgba(148,163,184,.13); border-radius:10px; background:rgba(11,18,32,.72); box-shadow:inset 0 1px 0 rgba(255,255,255,.025); }
.tp-modal-info-grid article { min-height:142px; padding:18px; }
.tp-modal-info-grid h4 { margin:0 0 14px; color:#fff; font-family:var(--font-display); font-size:17px; font-weight:900; letter-spacing:.8px; text-transform:uppercase; }
.tp-modal-info-grid p { margin:0; color:#cbd5e1; line-height:1.65; font-size:14px; }
.tp-modal-list,.tp-modal-matches,.tp-modal-standings { overflow:hidden; }
.tp-modal-row,.tp-modal-match,.tp-modal-standing { display:flex; align-items:center; gap:14px; padding:14px 16px; border-bottom:1px solid rgba(148,163,184,.10); color:#fff; }
.tp-modal-row:last-child,.tp-modal-match:last-child,.tp-modal-standing:last-child { border-bottom:0; }
.tp-modal-row { justify-content:space-between; }
.tp-modal-row span,.tp-modal-standing strong { min-width:0; }
.tp-modal-row small,.tp-modal-match small,.tp-modal-standing small { display:block; margin-top:3px; color:#94a3b8; font-size:12px; font-weight:600; }
.tp-modal-row b { flex:0 0 auto; color:#22c55e; font-size:12px; text-transform:uppercase; letter-spacing:.7px; }
.tp-modal-row b.orange { color:#f59e0b; }
.tp-modal-row-stack { align-items:flex-start; }
.tp-modal-empty { margin:0; border:1px solid rgba(148,163,184,.13); border-radius:10px; background:rgba(11,18,32,.72); color:#94a3b8; padding:24px; }
.tp-modal-match { display:grid; grid-template-columns:120px minmax(0,1fr) 70px minmax(0,1fr) 88px; }
.tp-modal-match strong { min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.tp-modal-match b { justify-self:center; color:#fff; font-family:var(--font-display); font-size:21px; }
.tp-modal-match em { justify-self:end; color:#22c55e; font-style:normal; font-size:12px; text-transform:uppercase; }
.tp-modal-standing { display:grid; grid-template-columns:46px minmax(0,1fr) 90px; }
.tp-modal-standing span { color:#cbd5e1; font-family:var(--font-display); font-size:24px; font-weight:900; }
.tp-modal-standing b { justify-self:end; color:#fff; }
.tp-modal-standing.rank-1 span,.tp-modal-standing.rank-1 b { color:#facc15; }
.tp-modal-standing.rank-2 span { color:#e5e7eb; }
.tp-modal-standing.rank-3 span { color:#f97316; }
.tp-modal-footer { position:relative; z-index:1; display:grid; grid-template-columns:1fr 1fr; gap:12px; padding:0 38px 34px; }
.tp-modal-footer .tp-btn { width:100%; min-height:46px; }

/* Tournois public premium - refonte cible */
.tournois-public-page { background:#02070b; }
.tournois-public-page .client-unified-header { background:#02070b!important; }
.tournaments-public-v2 { min-height:100vh; padding-top:0; background:linear-gradient(180deg,#02070b 0%,#06101b 48%,#02070b 100%); color:#fff; }
.tp-container { width:min(1420px,calc(100% - 64px)); margin:0 auto; }
.tp-hero { min-height:430px; background:#02070b; border-bottom:1px solid rgba(255,255,255,.10); }
.tp-hero:before { background:linear-gradient(90deg,rgba(2,7,11,.98) 0%,rgba(2,7,11,.82) 39%,rgba(2,7,11,.34) 70%,rgba(2,7,11,.84) 100%),linear-gradient(180deg,rgba(2,7,11,.20),#02070b 96%),url('../assets/img/fond.png') center 42%/cover no-repeat; opacity:1; }
.tp-hero:after { background:radial-gradient(circle at 79% 47%,rgba(34,197,94,.24),transparent 23rem),linear-gradient(180deg,transparent 70%,rgba(2,7,11,.98) 100%); }
.tp-racket { right:8%; top:48px; width:390px; height:390px; opacity:.17; }
.tp-ball { right:50%; top:218px; width:38px; height:38px; opacity:.74; }
.tp-hero-inner { padding:58px 0 34px; }
.tp-hero-copy { max-width:720px; }
.tp-kicker { font-size:14px; letter-spacing:9px; color:#22e07a; }
.tp-hero h1 { margin:16px 0 16px; font-size:clamp(72px,6.4vw,96px); line-height:.84; letter-spacing:.5px; text-shadow:0 4px 24px rgba(0,0,0,.55); }
.tp-hero p { max-width:660px; color:#dbe6f3; font-size:18px; line-height:1.55; }
.tp-kpis { grid-template-columns:repeat(4,minmax(0,1fr)); gap:28px; margin-top:42px; }
.tp-kpis article { min-height:96px; border-radius:14px; border-color:rgba(255,255,255,.13); background:linear-gradient(145deg,rgba(12,24,38,.72),rgba(5,11,18,.72)); backdrop-filter:blur(6px); }
.tp-kpis svg { width:36px; height:36px; padding:12px; background:rgba(34,197,94,.15); color:#22e07a; }
.tp-kpis strong { font-size:44px; text-shadow:0 3px 18px rgba(0,0,0,.45); }
.tp-kpis span { color:#cbd5e1; }
.tp-list-section { padding:32px 0 110px; background:radial-gradient(circle at 12% 0,rgba(34,197,94,.07),transparent 24rem),linear-gradient(180deg,#06101b,#02070b); }
.tp-section-head { align-items:flex-end; margin-bottom:26px; }
.tp-section-head h2 { font-size:42px; letter-spacing:.2px; }
.tp-section-head p { color:#b7c4d4; font-size:16px; }
.tp-filters button { min-height:42px; border-radius:10px; padding:0 24px; background:rgba(10,18,30,.82); }
.tp-filters button:hover { border-color:rgba(34,197,94,.46); color:#22e07a; }
.tp-grid { display:grid; grid-template-columns:1fr; gap:18px; }
.tp-card { position:relative; display:grid; grid-template-columns:300px minmax(0,1fr) 176px; gap:24px; align-items:center; width:100%; min-height:194px; padding:18px; border-radius:18px; border:1px solid rgba(255,255,255,.10); background:linear-gradient(145deg,rgba(10,21,34,.92),rgba(4,10,16,.96)); box-shadow:0 24px 70px rgba(0,0,0,.28),inset 0 1px 0 rgba(255,255,255,.035); overflow:visible; }
.tp-card:hover { transform:translateY(-2px); border-color:rgba(34,197,94,.58); box-shadow:0 30px 86px rgba(0,0,0,.36),0 0 34px rgba(34,197,94,.10); }
.tp-card[hidden] { display:none; }
.tp-card-media { align-self:stretch; min-height:164px; margin:0; border-radius:12px; border-color:rgba(255,255,255,.12); aspect-ratio:auto; }
.tournament-card-poster img { width:100%; height:100%; object-fit:cover; object-position:center; background:#02070b; }
.tp-card-fallback { position:absolute; inset:0; background:radial-gradient(circle at 55% 30%,rgba(34,197,94,.22),transparent 52%),linear-gradient(145deg,#0b1726,#02070b); }
.tp-status { position:absolute; left:12px; top:12px; min-height:30px; padding:0 12px; border-color:rgba(34,197,94,.50); background:#22c55e; color:#04110a; z-index:2; box-shadow:0 10px 24px rgba(0,0,0,.28); }
.status-upcoming .tp-status { background:#1f9ff2; color:#03111c; border-color:rgba(125,211,252,.52); }
.status-finished .tp-status { background:#64748b; color:#fff; border-color:rgba(148,163,184,.54); }
.tp-card-body { min-width:0; padding:0; }
.tp-title-row { margin-bottom:16px; }
.tp-card h3 { font-size:30px; line-height:1; -webkit-line-clamp:1; }
.tp-card-date { gap:22px; margin-bottom:14px; color:#d7e1ef; font-size:15px; }
.tp-card-date span { min-width:0; white-space:nowrap; }
.tp-card-date svg { color:#cbd5e1; }
.tp-card svg { width:19px; height:19px; }
.tp-tags { margin-bottom:16px; }
.tp-tags span { min-height:34px; border-radius:8px; background:rgba(10,18,30,.86); color:#d7e1ef; }
.tp-inscrits { gap:22px; padding:16px 0 0; border-bottom:0; }
.tp-inscrits div { font-size:12px; color:#cbd5e1; }
.tp-inscrits strong { font-size:14px; }
.tp-level { max-width:none; min-height:30px; padding:0 12px; border:1px solid rgba(34,197,94,.22); border-radius:999px; background:rgba(34,197,94,.09); color:#fff; font-size:12px; }
.tp-card-side { align-self:stretch; display:flex; flex-direction:column; justify-content:flex-end; align-items:stretch; gap:14px; }
.tp-card-side > b { color:#22e07a; font-family:var(--font-display); font-size:34px; line-height:1; text-align:right; text-shadow:0 0 24px rgba(34,197,94,.35); white-space:nowrap; }
.tp-actions { display:grid; gap:10px; margin:0; }
.tp-btn { min-height:46px; border-radius:11px; font-size:15px; }
.tp-btn-primary { border-color:#22c55e; background:linear-gradient(135deg,#19c96b,#22e07a); color:#03120b; }
.tp-btn-ghost { background:rgba(2,7,11,.55); color:#fff; }
.tp-btn-wide { min-height:46px; }
.tp-register-form { grid-column:1/-1; margin:2px 0 0; padding:18px; border:1px solid rgba(255,255,255,.10); border-radius:14px; background:rgba(2,7,11,.42); }
.tp-final-line { margin-top:24px; font-size:17px; }
@media(max-width:1280px){.tp-grid{grid-template-columns:repeat(3,1fr)}.tp-kpis{grid-template-columns:repeat(2,1fr)}}
@media(max-width:920px){.tp-container{width:min(100% - 32px,720px)}.tp-hero-inner{padding-top:50px}.tp-section-head{display:grid}.tp-filters{justify-content:flex-start}.tp-grid{grid-template-columns:repeat(2,1fr)}.tp-racket{right:-12%;opacity:.18}.tp-ball{right:14%}.tp-modal[aria-hidden="false"]{padding:18px}.tp-modal-head{grid-template-columns:260px 1fr;padding:28px 24px 20px;gap:20px}.tp-modal-tabs{padding:0 24px}.tp-modal-content{padding:20px 24px 24px}.tp-modal-footer{padding:0 24px 28px}.tp-modal-match{grid-template-columns:1fr;gap:6px}.tp-modal-match b,.tp-modal-match em{justify-self:start}}
@media(max-width:640px){.tournaments-public-v2{padding-top:64px}.tournois-public-page .header-inner{height:64px}.tp-container{width:calc(100% - 24px)}.tp-hero{min-height:auto}.tp-hero h1{font-size:66px}.tp-hero p{font-size:16px}.tp-kicker{font-size:14px;letter-spacing:5px}.tp-kpis{grid-template-columns:1fr;gap:12px}.tp-kpis article{min-height:88px;padding:16px}.tp-grid{grid-template-columns:1fr}.tp-card h3{min-height:auto}.tp-title-row{align-items:center}.tp-section-head h2{font-size:38px}.tp-filters button{flex:1 1 calc(50% - 6px);padding:0 10px}.tp-racket,.tp-ball{display:none}.tp-inscrits{display:grid;grid-template-columns:1fr;align-items:start}.tp-inscrits b{margin-left:0;justify-self:start}.tp-level{max-width:none}.tp-actions{grid-template-columns:1fr}.ct-form-grid{grid-template-columns:1fr}.tp-modal[aria-hidden="false"]{padding:10px}.tp-modal-dialog{max-height:94vh;border-radius:14px}.tp-modal-head{grid-template-columns:1fr;padding:24px 18px 18px}.tp-modal-summary{padding-right:30px}.tp-modal-summary h3{font-size:38px}.tp-modal-stats b{margin-left:0}.tp-modal-tabs{padding:0 18px}.tp-modal-tabs button{min-height:52px;padding:0 12px}.tp-modal-content{padding:18px}.tp-modal-info-grid{grid-template-columns:1fr}.tp-modal-standing{grid-template-columns:36px minmax(0,1fr);}.tp-modal-standing b{grid-column:2;justify-self:start}.tp-modal-footer{grid-template-columns:1fr;padding:0 18px 24px}}

@media(max-width:1280px){
  .tp-grid{grid-template-columns:1fr}
}
@media(max-width:1180px){
  .tp-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}
  .tp-grid{grid-template-columns:1fr}
  .tp-card{grid-template-columns:260px minmax(0,1fr); align-items:start}
  .tp-card-side{grid-column:2; flex-direction:row; align-items:center; justify-content:space-between}
  .tp-card-side > b{text-align:left}
}
@media(max-width:820px){
  .tp-container{width:min(100% - 32px,720px)}
  .tp-hero{min-height:auto}
  .tp-hero-inner{padding:48px 0 32px}
  .tp-section-head{display:grid; align-items:start}
  .tp-filters{justify-content:flex-start}
  .tp-card{grid-template-columns:1fr; gap:16px; padding:16px}
  .tp-card-media{height:220px}
  .tp-card-side{grid-column:auto; flex-direction:column; align-items:stretch}
  .tp-card-side > b{text-align:left}
  .tp-actions{grid-template-columns:1fr 1fr}
}
@media(max-width:520px){
  .tp-container{width:calc(100% - 28px)}
  .tp-hero-inner{padding:38px 0 26px}
  .tp-kicker{font-size:12px; letter-spacing:5px}
  .tp-hero h1{font-size:54px}
  .tp-hero p{font-size:15px}
  .tp-kpis{grid-template-columns:1fr 1fr; gap:10px; margin-top:26px}
  .tp-kpis article{min-height:84px; grid-template-columns:44px auto; padding:14px; column-gap:11px}
  .tp-kpis svg{width:25px;height:25px;padding:8px}
  .tp-kpis strong{font-size:31px}
  .tp-kpis span{font-size:10px; letter-spacing:1px}
  .tp-list-section{padding-top:28px}
  .tp-section-head h2{font-size:31px}
  .tp-filters{display:grid; grid-template-columns:1fr 1fr}
  .tp-filters button{padding:0 10px; font-size:12px}
  .tp-card-media{height:190px}
  .tp-card h3{font-size:24px}
  .tp-card-date{display:flex; flex-wrap:wrap; gap:10px 14px; font-size:14px}
  .tp-inscrits{display:grid; grid-template-columns:1fr 1fr; gap:10px}
  .tp-level{justify-content:center}
  .tp-inscrits .tp-level{grid-column:1/-1}
  .tp-card-side > b{font-size:30px}
  .tp-actions{grid-template-columns:1fr}
  .ct-form-grid{grid-template-columns:1fr}
  .tp-racket,.tp-ball{display:none}
}

/* ── GALERIE ── */
.galerie-section { background: var(--dark); }
.galerie-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 1rem; }
.galerie-item { position: relative; cursor: zoom-in; overflow: hidden; border-radius: var(--radius); aspect-ratio: 4/3; background: var(--dark2); }
.galerie-item img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s; }
.galerie-item:hover img { transform: scale(1.05); }
.galerie-titre { position: absolute; bottom: 0; left: 0; right: 0; background: linear-gradient(transparent, rgba(0,0,0,0.7)); color: #fff; font-size: 0.82rem; padding: 1rem 0.75rem 0.5rem; }

/* ── PARTENAIRES ── */
.partenaires-section { background: var(--dark2); border-top: 1px solid var(--border); }
.partenaires-section .section-inner { padding: 2.5rem 1.5rem; }
.partenaires-label { text-align: center; font-size: 0.75rem; font-weight: 600; letter-spacing: 3px; text-transform: uppercase; color: var(--text-muted); margin-bottom: 1.25rem; }
.partenaires-logos { display: flex; justify-content: center; align-items: center; gap: 3rem; flex-wrap: wrap; }
.partenaire { font-family: var(--font-display); font-size: 0.85rem; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,0.3); }

/* ── FOOTER ── */
.site-footer { background: var(--dark2); border-top: 1px solid var(--border); }
.footer-inner { max-width: 1200px; margin: 0 auto; padding: 3rem 1.5rem; display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 2rem; align-items: start; }
.footer-logo { height: 40px; width: auto; margin-bottom: 0.75rem; }
.footer-club { font-family: var(--font-display); font-size: 1.1rem; font-weight: 700; color: var(--white); text-transform: uppercase; letter-spacing: 1px; }
.footer-slogan { color: var(--text-muted); font-size: 0.82rem; margin-top: 0.25rem; }
.footer-infos { display: flex; flex-direction: column; gap: 0.5rem; font-size: 0.88rem; color: var(--text-muted); }
.footer-infos a { color: var(--text-muted); transition: color 0.2s; }
.footer-infos a:hover { color: var(--green); }
.footer-social-col { display: flex; gap: 0.75rem; }
.social-btn { display: flex; align-items: center; justify-content: center; width: 38px; height: 38px; background: rgba(255,255,255,0.06); border: 1px solid var(--border); border-radius: var(--radius); color: var(--text-muted); transition: all 0.2s; }
.social-btn:hover { background: var(--green-glow); border-color: var(--green); color: var(--green); }
.footer-bottom { max-width: 1200px; margin: 0 auto; padding: 1rem 1.5rem; border-top: 1px solid var(--border); display: flex; align-items: center; gap: 2rem; font-size: 0.8rem; color: var(--text-muted); }
.footer-bottom strong { color: var(--green); }
.footer-admin-link { margin-left: auto; color: var(--text-muted); font-size: 0.75rem; opacity: 0.4; transition: opacity 0.2s; }
.footer-admin-link:hover { opacity: 1; color: var(--text-muted); }
.resa-footer { margin-top: auto; }

/* ── PAGE RESERVATION ── */
.resa-page { min-height: 100vh; display: flex; flex-direction: column; background: var(--dark); }
.resa-main { flex: 1; padding-top: 64px; padding-bottom: 3rem; }
.resa-container { max-width: 700px; margin: 0 auto; padding: 2rem 1.5rem; }
.resa-infos-bar { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; background: var(--dark2); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; margin-bottom: 2rem; }
.resa-info-item { padding: 1rem; border-right: 1px solid var(--border); display: flex; align-items: center; gap: 0.6rem; }
.resa-info-item:last-child { border-right: none; }
.ri-icon { font-size: 1.2rem; flex-shrink: 0; }
.resa-info-item strong { display: block; color: var(--white); font-size: 0.82rem; font-weight: 600; }
.resa-info-item small { color: var(--text-muted); font-size: 0.75rem; }
.resa-form-card { background: var(--dark2); border: 1px solid var(--border); border-radius: var(--radius); padding: 2.5rem; }
.resa-title { font-family: var(--font-display); font-size: 1.8rem; font-weight: 800; color: var(--white); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 2rem; }

/* Type selector */
.form-section { margin-bottom: 1.5rem; }
.form-section-label { display: block; font-size: 0.82rem; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; color: var(--text-muted); margin-bottom: 0.75rem; }
.type-selector { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.type-btn { background: var(--dark3); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.25rem 1rem; display: flex; flex-direction: column; align-items: flex-start; gap: 0.3rem; cursor: pointer; transition: all 0.2s; text-align: left; }
.type-btn:hover { border-color: rgba(46,204,113,0.4); }
.type-btn.active { border-color: var(--green); background: var(--green-glow); }
.type-icon { font-size: 1.5rem; }
.type-name { font-family: var(--font-display); font-size: 1rem; font-weight: 700; color: var(--white); text-transform: uppercase; letter-spacing: 0.5px; }
.type-desc { font-size: 0.78rem; color: var(--text-muted); }

/* Form fields */
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.form-group { margin-bottom: 1.25rem; }
.form-group label { display: block; font-size: 0.82rem; font-weight: 600; letter-spacing: 0.5px; text-transform: uppercase; color: var(--text-muted); margin-bottom: 0.5rem; }
.req { color: var(--green); }
.opt { font-weight: 400; text-transform: none; letter-spacing: 0; font-size: 0.78rem; }
.form-group input, .form-group select { width: 100%; background: var(--dark3); border: 1px solid var(--border); border-radius: var(--radius); padding: 0.75rem 1rem; color: var(--text); font-size: 0.92rem; font-family: var(--font-body); outline: none; transition: border-color 0.2s; }
.form-group input:focus, .form-group select:focus { border-color: var(--green); }
.form-group select option { background: var(--dark3); }

/* Calendrier */
.cal-wrapper { background: var(--dark3); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
.cal-nav { display: flex; align-items: center; justify-content: space-between; padding: 0.75rem 1rem; border-bottom: 1px solid var(--border); }
.cal-month-label { font-family: var(--font-display); font-size: 1rem; font-weight: 700; color: var(--white); text-transform: uppercase; letter-spacing: 1px; }
.cal-nav-btn { background: none; border: 1px solid var(--border); border-radius: 3px; color: var(--text-muted); width: 32px; height: 32px; font-size: 1.2rem; transition: all 0.2s; }
.cal-nav-btn:hover { border-color: var(--green); color: var(--green); }
.cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); padding: 0.75rem; gap: 3px; }
.cal-header-cell { text-align: center; font-size: 0.72rem; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; color: var(--text-muted); padding: 0.3rem; }
.cal-cell { background: none; border: 1px solid transparent; border-radius: 4px; color: var(--text); font-size: 0.88rem; font-family: var(--font-body); aspect-ratio: 1; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: all 0.15s; }
.cal-cell.empty { background: none; cursor: default; }
.cal-cell:not(.empty):not(.disabled):hover { background: var(--green-glow); border-color: rgba(46,204,113,0.3); color: var(--white); }
.cal-cell.selected { background: var(--green); color: var(--dark); font-weight: 700; border-color: var(--green); }
.cal-cell.disabled { color: rgba(255,255,255,0.15); cursor: not-allowed; }
.cal-cell.weekend:not(.disabled) { color: var(--green); }

/* Créneaux */
.heure-slots { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: 0.75rem; }
.slot-group-label { width: 100%; font-size: 0.72rem; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: var(--text-muted); margin-top: 0.5rem; margin-bottom: 0.1rem; }
.slot-group-label:first-child { margin-top: 0; }
.slot-btn { background: var(--dark3); border: 1px solid var(--border); border-radius: var(--radius); color: var(--text); font-family: var(--font-body); font-size: 0.88rem; padding: 0.5rem 1rem; transition: all 0.15s; }
.slot-btn:not(.disabled):hover { border-color: var(--green); color: var(--green); }
.slot-btn.selected { background: var(--green); border-color: var(--green); color: var(--dark); font-weight: 700; }
.slot-btn.disabled { opacity: 0.3; cursor: not-allowed; }
.no-slots { color: var(--text-muted); font-style: italic; font-size: 0.88rem; width: 100%; }

/* Submit */
.btn-submit { width: 100%; background: var(--green); color: var(--dark); font-family: var(--font-display); font-size: 1.1rem; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; padding: 1rem 2rem; border: none; border-radius: var(--radius); margin-top: 1.5rem; transition: all 0.2s; }
.btn-submit:hover:not(:disabled) { background: var(--green-dark); box-shadow: 0 8px 24px rgba(46,204,113,0.3); }
.btn-submit:disabled { opacity: 0.6; cursor: not-allowed; }
.resa-note { margin-top: 0.75rem; text-align: center; font-size: 0.78rem; color: var(--text-muted); }
.resa-error-msg { background: rgba(231,76,60,0.1); border: 1px solid rgba(231,76,60,0.3); color: #e74c3c; padding: 0.75rem 1rem; border-radius: var(--radius); font-size: 0.88rem; margin-top: 1rem; }
.resa-error-msg.resa-info-msg { background: rgba(34,197,94,0.1); border-color: rgba(34,197,94,0.35); color: #35f17b; }

/* Success */
.resa-success-msg { text-align: center; padding: 3rem 2rem; }
.success-icon { width: 64px; height: 64px; background: var(--green); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 2rem; color: var(--dark); margin: 0 auto 1.5rem; font-weight: 700; }
.resa-success-msg h2 { font-family: var(--font-display); font-size: 1.8rem; font-weight: 800; color: var(--white); text-transform: uppercase; margin-bottom: 0.75rem; }
.resa-success-msg p { color: var(--text-muted); margin-bottom: 2rem; }
.success-terrain { color: var(--green) !important; margin-top: -1rem; }
.btn-back { display: inline-block; background: none; border: 1px solid var(--border); color: var(--text-muted); font-family: var(--font-display); font-size: 0.9rem; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; padding: 0.75rem 1.5rem; border-radius: var(--radius); margin-top: 1rem; transition: all 0.2s; }
.btn-back:hover { border-color: var(--green); color: var(--green); }

/* Fermeture / bloqué */
.closed-overlay { min-height: 100vh; display: flex; align-items: center; justify-content: center; background: var(--dark); padding: 2rem; }
.closed-box { text-align: center; max-width: 440px; }
.closed-logo { height: 80px; margin: 0 auto 1.5rem; }
.closed-box h1 { font-family: var(--font-display); font-size: 2.2rem; font-weight: 800; color: var(--white); text-transform: uppercase; margin-bottom: 1rem; }
.closed-icon { font-size: 3rem; margin: 1rem 0; }
.closed-box p { color: var(--text-muted); line-height: 1.8; margin-bottom: 1.5rem; }
.closed-contact { display: inline-block; color: var(--green); font-family: var(--font-display); font-size: 1.2rem; font-weight: 700; letter-spacing: 2px; }
.resa-blocked { min-height: 80vh; display: flex; align-items: center; justify-content: center; padding: 2rem; padding-top: 84px; }
.resa-blocked-box { text-align: center; max-width: 420px; }
.blocked-icon { font-size: 3rem; margin-bottom: 1rem; }
.resa-blocked-box h1 { font-family: var(--font-display); font-size: 2rem; font-weight: 800; color: var(--white); text-transform: uppercase; margin-bottom: 0.75rem; }
.resa-blocked-box p { color: var(--text-muted); margin-bottom: 1.5rem; line-height: 1.7; }

/* Flash info */
#flash-overlay { position: fixed; inset: 0; z-index: 9999; display: flex; align-items: center; justify-content: center; background: rgba(0,0,0,0.8); }
#flash-box { position: relative; width: min(92vw, 480px); background: var(--dark2); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
.flash-img { min-height: 280px; background-size: cover; background-position: center; position: relative; }
.flash-img-overlay { position: absolute; inset: 0; background: linear-gradient(transparent 30%, rgba(0,0,0,0.7)); }
.flash-txt { position: absolute; bottom: 0; padding: 1.5rem; }
.flash-txt h2 { font-family: var(--font-display); font-size: 1.5rem; font-weight: 700; color: #fff; margin-bottom: 0.4rem; }
.flash-txt p { color: rgba(255,255,255,0.85); font-size: 0.9rem; }
.flash-noimg { padding: 2.5rem 2rem; text-align: center; }
.flash-logo { height: 60px; margin: 0 auto 1rem; }
.flash-noimg h2 { font-family: var(--font-display); font-size: 1.5rem; font-weight: 700; color: var(--white); margin-bottom: 0.5rem; }
.flash-noimg p { color: var(--text-muted); }
.flash-action { padding: 1.25rem; background: var(--dark3); text-align: center; }
.flash-btn { display: inline-block; background: var(--green); color: var(--dark); font-family: var(--font-display); font-size: 0.95rem; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; padding: 0.75rem 1.75rem; border-radius: var(--radius); transition: background 0.2s; }
.flash-btn:hover { background: var(--green-dark); }
.flash-close { position: absolute; top: 10px; right: 10px; background: rgba(0,0,0,0.5); border: 1px solid rgba(255,255,255,0.2); border-radius: 50%; color: #fff; width: 32px; height: 32px; font-size: 0.85rem; display: flex; align-items: center; justify-content: center; transition: all 0.2s; }
.flash-close:hover { background: rgba(0,0,0,0.8); border-color: var(--green); }

/* ── RESPONSIVE ── */
@media (max-width: 900px) {
  .pres-inner { grid-template-columns: 1fr; }
  .terrains-grid { grid-template-columns: 1fr; }
  .services-grid { grid-template-columns: 1fr; }
  .client-tournaments-head { align-items: flex-start; flex-direction: column; }
  .client-tournaments-all .client-tournaments-grid { grid-template-columns: 1fr; }
  .tournaments-page-stats { grid-template-columns: 1fr 1fr; }
  .ct-summary { grid-template-columns: 96px 1fr; }
  .ct-open-label { grid-column: 1 / -1; text-align: center; }
  .footer-inner { grid-template-columns: 1fr 1fr; }
  .resa-infos-bar { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .header-name { display: none; }
  .header-nav a:not(.nav-reserve) { display: none; }
  .hero-stats { flex-direction: column; }
  .hero-stat-sep { width: 80px; height: 1px; }
  .type-selector { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .footer-inner { grid-template-columns: 1fr; }
  .resa-infos-bar { grid-template-columns: 1fr 1fr; }
  .resa-form-card { padding: 1.5rem; }
  .footer-bottom { flex-wrap: wrap; gap: 0.5rem; }
  .footer-admin-link { margin-left: 0; }
  .ct-form-grid { grid-template-columns: 1fr; gap: 0; }
  .ct-summary { grid-template-columns: 1fr; }
  .ct-thumb { aspect-ratio: 16/8; }
  .ct-card-head { align-items: flex-start; flex-direction: column; }
  .tournaments-page-stats { grid-template-columns: 1fr; }
}
/* Reservation cart */
.cart-actions-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:stretch}
.btn-cart-add{border:1px solid rgba(46,204,113,.45);background:rgba(46,204,113,.12);color:#2ecc71;font-weight:800;text-transform:uppercase;letter-spacing:.04em;border-radius:8px;padding:1rem;cursor:pointer}
.btn-cart-add:hover{background:rgba(46,204,113,.2)}
.booking-cart-fab{position:fixed;right:22px;bottom:22px;z-index:80;border:1px solid rgba(46,204,113,.5);background:#2ecc71;color:#06130d;border-radius:999px;padding:13px 20px;font-weight:900;box-shadow:0 18px 45px rgba(0,0,0,.35);cursor:pointer}
.booking-cart-fab span{display:inline-grid;place-items:center;min-width:24px;height:24px;margin-left:8px;border-radius:999px;background:#06130d;color:#fff}
.booking-cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,.58);z-index:88;display:none}
.booking-cart-overlay.open{display:block}
.booking-cart-panel{position:fixed;right:0;top:0;width:min(430px,94vw);height:100vh;z-index:90;transform:translateX(105%);transition:transform .24s ease;background:#111827;border-left:1px solid #2b3548;color:#fff;padding:22px;box-shadow:-24px 0 70px rgba(0,0,0,.4);display:flex;flex-direction:column;gap:16px}
.booking-cart-panel.open{transform:translateX(0)}
.booking-cart-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;border-bottom:1px solid #2b3548;padding-bottom:14px}
.booking-cart-head strong{display:block;font-family:"Barlow Condensed",sans-serif;font-size:1.55rem;text-transform:uppercase;letter-spacing:.04em}
.booking-cart-head small{color:#8fa3c7}
.booking-cart-head button{border:1px solid #2b3548;background:#182235;color:#fff;border-radius:6px;width:34px;height:34px;cursor:pointer}
.booking-cart-lines{display:grid;gap:10px;overflow:auto;min-height:90px;max-height:42vh;padding-right:4px}
.booking-cart-empty{border:1px dashed #2b3548;border-radius:10px;padding:28px;text-align:center;color:#8fa3c7}
.booking-cart-line{position:relative;border:1px solid #2b3548;background:#182235;border-radius:10px;padding:13px 42px 13px 14px;display:grid;gap:4px}
.booking-cart-line strong{font-size:1rem}
.booking-cart-line span,.booking-cart-line em{color:#9fb3d8;font-style:normal}
.booking-cart-line b{color:#2ecc71}
.cart-line-remove{position:absolute;top:10px;right:10px;border:1px solid rgba(231,76,60,.45);background:rgba(231,76,60,.16);color:#ff7979;border-radius:6px;width:26px;height:26px;cursor:pointer}
.booking-cart-totals{border-top:1px solid #2b3548;border-bottom:1px solid #2b3548;padding:12px 0;display:grid;gap:9px}
.booking-cart-totals div{display:flex;justify-content:space-between;gap:14px;color:#9fb3d8}
.booking-cart-totals strong{color:#fff}
.booking-cart-totals .total{font-size:1.08rem;color:#fff}
.booking-cart-totals .total strong{color:#2ecc71}
.booking-cart-help{color:#8fa3c7;margin:0;line-height:1.45}
.booking-cart-message{min-height:22px;color:#2ecc71}
.booking-cart-message a{color:#3498db}
.btn-cart-checkout,.btn-cart-continue{border:0;border-radius:8px;padding:13px 16px;font-weight:900;cursor:pointer;text-transform:uppercase;letter-spacing:.04em}
.btn-cart-checkout{background:#2ecc71;color:#06130d}
.btn-cart-continue{background:#182235;color:#fff;border:1px solid #2b3548}
.account-top-link{height:38px;display:inline-flex!important;align-items:center;gap:8px;padding:0 14px!important;border:1px solid rgba(255,255,255,.16);border-radius:7px;background:rgba(2,7,13,.42);color:#fff!important;text-decoration:none;text-transform:uppercase;font-size:.86rem;font-weight:900}
.account-top-link:hover{border-color:#2ecc71;color:#2ecc71!important;background:rgba(46,204,113,.10)}
.account-top-link svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2}
@media (max-width:700px){.cart-actions-row{grid-template-columns:1fr}.booking-cart-fab{right:14px;bottom:14px}}
