@charset "UTF-8";

/* ============ Theme de base ============ */
:root{
  --ffg-blue: #0a2a66;
  --ffg-blue-dark: #082a55;
  --ffg-blue-ring: rgba(10,42,102,.28);
  --ffg-gray-bg: #eef2f7;
  --ffg-border: #d9e0ea;
  --ffg-text: #0f172a;
  --ffg-text-dark: #0f2550;
  --ffg-highlight: #2563eb;
  --ffg-row-alt: #f8fafc;
  --ffg-row-hover: #eef6ff;
  --ffg-header-row: linear-gradient(0deg,#e2e8f0,#f1f5f9);
  --ffg-accent: #2a99d5;
}

html{
  font-family: Arial, Helvetica, sans-serif;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  color:#1a1d56;
  font-size:10px;
}
body{ margin:0; background:#fff; }

/* ============ Header FFGym ============ */
.ffgym-header{
  position: relative;
  display:flex; align-items:center;
  background:var(--ffg-blue); color:#fff;
  padding:.9rem 1.5rem;
}
.ffgym-logo{ height:48px; }
.ffgym-header h1{
  margin:0;
  position:absolute; left:50%; transform:translateX(-50%);
  font-size:2.4rem; font-weight:700;
}

/* ============ Conteneur principal ============ */
.result{
  max-width:1200px;
  margin:0 auto;
  padding:20px 16px 40px;
}

/* ============ Formulaire / Filtres ============ */
.form-card{
  max-width:980px; margin:20px auto;
  background:var(--ffg-gray-bg); border:1px solid var(--ffg-border); border-radius:12px;
  padding:24px 28px; box-shadow:0 8px 18px rgba(2,6,23,.06);
}
.form-grid{
  display:flex; flex-wrap:wrap; justify-content:center; align-items:flex-start;
  gap:20px 32px;
}
.form-field{
  display:flex; flex-direction:column; gap:6px; text-align:center;
}
.form-field label{
  font-size:1.6rem; font-weight:700; color:var(--ffg-text-dark);
}
.form-field select,
.form-field input[type="text"]{
  height:38px; padding:8px 10px;
  border:1px solid #cdd6e1; border-radius:8px; background:#fff;
  font-size:1.4rem; transition:box-shadow .2s, border-color .2s;
  min-width:200px; text-align:center;
}
.form-field select:focus,
.form-field input[type="text"]:focus{
  outline:none; border-color:var(--ffg-highlight);
  box-shadow:0 0 0 4px rgba(37,99,235,.2);
}

/* --- Discipline/radio choices --- */
.form-field .choices-list{
  padding:0; margin:8px 0 0; list-style:none;
  display:flex; flex-wrap:wrap; gap:6px 16px;
  justify-content:center;
}
.form-field .choices-list li{
  display:flex; align-items:center; gap:4px;
  line-height:2.5rem; min-height:2.5rem;
}
.form-field .choices-list li img{
  max-height:2.5rem; vertical-align:middle;
}
.form-field .choices-list li label{
  font-size:1.3rem; font-weight:600; cursor:pointer;
}
.form-field .choices-list li label.noImage{
  padding-left:4px;
}
.form-field .choices-list li input[type="radio"]{
  width:1.4rem; height:1.4rem; margin:0; cursor:pointer;
}

/* ============ Bouton primaire ============ */
.btn{
  appearance:none; display:inline-flex; align-items:center; justify-content:center; gap:8px;
  height:46px; padding:0 28px; border-radius:9999px;
  border:1px solid var(--ffg-blue-dark);
  background:linear-gradient(180deg,#0c3a8a 0%, var(--ffg-blue) 100%);
  color:#fff; font-size:1.4rem; font-weight:800; letter-spacing:.3px;
  text-transform:uppercase; cursor:pointer; user-select:none;
  box-shadow:0 10px 20px rgba(2,6,23,.10), 0 2px 6px rgba(2,6,23,.08);
  transition:transform .06s, box-shadow .2s, filter .2s;
}
.btn:hover{ transform:translateY(-1px); filter:brightness(1.06); }
.btn:active{ transform:translateY(0); filter:brightness(.98); }
.btn:focus{ outline:none; box-shadow:0 0 0 4px var(--ffg-blue-ring), 0 8px 18px rgba(2,6,23,.10); }

/* ============ Titres sections ============ */
.section-title{
  text-align:center; font-size:2.2rem; font-weight:700;
  color:var(--ffg-blue); margin:24px 0 12px;
}
.section-title .toggle-button{
  margin-left:12px; cursor:pointer;
  display:inline-block; width:0; height:0;
  border-top:12px solid var(--ffg-accent);
  border-left:5px solid transparent;
  border-right:5px solid transparent;
  vertical-align:middle;
}

/* ============ Resultats Grid ============ */
.results-outside{
  width:100%; max-width:980px;
  margin:12px auto 32px;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
}
.results-grid{
  background:#fff;
  border:1px solid #cbd5e1;
  border-radius:12px;
  overflow:hidden;
  box-shadow:0 8px 18px rgba(2,6,23,.06);
}
.rg-row{
  display:grid; gap:0; align-items:center; text-align:center;
}
.rg-row .c{
  display:flex; align-items:center; justify-content:center;
  height:100%; min-height:44px;
  padding:10px 12px; border-bottom:1px solid #e2e8f0;
  font-size:1.4rem; color:var(--ffg-text); word-break:break-word;
}
.rg-row .c.nowrap{ white-space:nowrap; }

.rg-header,
.rg-header .c{
  background:var(--ffg-header-row);
  color:var(--ffg-text); text-align:center;
}
.rg-header .c{
  text-transform:uppercase; letter-spacing:.2px; font-size:1.4rem;
  border-bottom:1px solid #cbd5e1; font-weight:700;
}
.results-grid .rg-row:nth-child(2n+1):not(.rg-header) .c{ background:var(--ffg-row-alt); }
.results-grid .rg-row:hover:not(.rg-header) .c{ background:var(--ffg-row-hover); }

/* sous-titre dans la grille */
.rg-subheader .c{
  background:#dde4f0; color:var(--ffg-accent);
  font-weight:700; font-size:1.5rem;
  border-bottom:1px solid #c5cfe0;
}

/* Lien details dans la grille */
.rg-row .c.lien{
  color:var(--ffg-accent); cursor:pointer;
  text-decoration:underline; font-style:italic;
}
.rg-row .c a{
  color:var(--ffg-accent); text-decoration:underline;
}

/* --- Grille Calendrier : 5 colonnes --- */
.results-grid.calendrier .rg-row{
  grid-template-columns:
    minmax(140px,1.2fr)
    minmax(220px,2fr)
    minmax(150px,1fr)
    minmax(160px,1fr)
    minmax(110px,.7fr);
}
/* --- Grille Calendrier 6 col (avec recyclage) --- */
.results-grid.calendrier-6 .rg-row{
  grid-template-columns:
    minmax(140px,1.2fr)
    minmax(200px,1.8fr)
    minmax(110px,.8fr)
    minmax(150px,1fr)
    minmax(160px,1fr)
    minmax(110px,.7fr);
}
/* Headers sur une seule ligne */
.rg-header .c{ white-space:nowrap; }

/* --- Grille Resultats : 5 colonnes --- */
.results-grid.resultats .rg-row{
  grid-template-columns:
    minmax(140px,1.5fr)
    minmax(90px,.7fr)
    minmax(140px,1fr)
    minmax(140px,1fr)
    minmax(80px,.6fr);
}
/* --- Grille Recus : 3 colonnes --- */
.results-grid.recus .rg-row{
  grid-template-columns:
    minmax(200px,1.5fr)
    minmax(200px,1.5fr)
    minmax(150px,1fr);
}

/* Ligne mois (full width) dans calendrier */
.rg-month{
  background:#dde4f0;
}
.rg-month .c{
  color:var(--ffg-accent); font-weight:700; font-size:1.5rem;
  grid-column: 1 / -1;
  justify-content:center;
  border-bottom:1px solid #c5cfe0;
  background:#dde4f0;
}

/* ============ Card infos formation (aff_datelieu) ============ */
.info-card{
  max-width:900px; margin:20px auto;
  background:var(--ffg-gray-bg); border:1px solid var(--ffg-border); border-radius:12px;
  overflow:hidden; box-shadow:0 8px 18px rgba(2,6,23,.06);
}
.info-card .info-title{
  background:var(--ffg-blue); color:#fff;
  text-align:center; padding:14px 20px;
  font-size:1.8rem; font-weight:700;
}
.info-card .info-row{
  display:flex; border-bottom:1px solid #dce3ed;
  font-size:1.4rem;
}
.info-card .info-row:nth-child(even){ background:#f4f6fa; }
.info-card .info-row .info-label{
  flex:0 0 240px; padding:12px 16px;
  font-weight:700; color:var(--ffg-text-dark);
}
.info-card .info-row .info-value{
  flex:1; padding:12px 16px; color:var(--ffg-text);
}
.info-card .info-row.doc-row .info-value a{
  color:var(--ffg-accent); text-decoration:underline;
}
.info-card .info-actions{
  text-align:center; padding:16px;
}

/* ============ Formulaire inscription ============ */
.inscription-card{
  max-width:900px; margin:20px auto;
  background:#fff; border:1px solid var(--ffg-border); border-radius:12px;
  overflow:hidden; box-shadow:0 8px 18px rgba(2,6,23,.06);
}
.inscription-card .section-header{
  background:#e2e8f0; padding:10px 20px;
  font-size:1.5rem; font-weight:700; color:var(--ffg-text-dark);
  border-bottom:1px solid #cbd5e1;
}
.inscription-card .form-row{
  display:flex; flex-wrap:wrap; gap:8px 16px;
  padding:10px 20px; border-bottom:1px solid #eef2f7;
  font-size:1.4rem; align-items:center;
}
.inscription-card .form-row:nth-child(even){ background:#f8fafc; }
.inscription-card .form-row label.field-label{
  flex:0 0 180px; font-weight:700; color:var(--ffg-text-dark);
}
.inscription-card .form-row input[type="text"],
.inscription-card .form-row input[type="email"]{
  flex:1; min-width:150px; height:34px; padding:6px 10px;
  border:1px solid #cdd6e1; border-radius:6px; background:#fff;
  font-size:1.3rem;
}
.inscription-card .form-row input[type="text"]:focus,
.inscription-card .form-row input[type="email"]:focus{
  outline:none; border-color:var(--ffg-highlight);
  box-shadow:0 0 0 3px rgba(37,99,235,.15);
}
.inscription-card .form-row input[type="radio"],
.inscription-card .form-row input[type="checkbox"]{
  width:1.4rem; height:1.4rem; margin-right:6px; cursor:pointer;
}
.inscription-card .form-actions{
  text-align:center; padding:20px;
}
.inscription-card p.instructions{
  padding:16px 20px; font-size:1.3rem; line-height:1.8;
  color:#374151; text-align:center;
}
.inscription-card a.rule{
  color:var(--ffg-accent); text-decoration:underline; font-size:1.3rem;
}

/* togglable */
.togglable{ display:none; }

/* ============ Message confirmation ============ */
.confirmation-msg{
  max-width:800px; margin:30px auto; text-align:center;
  background:var(--ffg-gray-bg); border:1px solid var(--ffg-border); border-radius:12px;
  padding:30px 24px; box-shadow:0 8px 18px rgba(2,6,23,.06);
}
.confirmation-msg h2{
  font-size:1.6rem; color:var(--ffg-text-dark); margin:10px 0;
  font-weight:600; line-height:1.6;
}

/* ============ Utilitaires ============ */
.text-center{ text-align:center; }
.mt-20{ margin-top:20px; }
.mb-20{ margin-bottom:20px; }
