:root{
  --green:#2F5D2F;
  --green-soft:#6E8F3D;
  --dark:#18351f;
  --cream:#F4EBDD;
  --paper:#FFF8EC;
  --line:#e1d5c2;
  --soft:#ecf1df;
  --wood:#8A5A2B;
  --lake:#DCEBF1;
  --shadow:0 14px 40px rgba(24,53,31,.14);
  --shadow-soft:0 8px 24px rgba(24,53,31,.10);
}
*{box-sizing:border-box}
body{
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:
    radial-gradient(circle at top left, rgba(110,143,61,.18), transparent 35%),
    linear-gradient(180deg,#eef4e9,#f7f1e6 45%,#fff8ec);
  color:#21301f;
  padding-bottom:82px;
}
.topbar{position:sticky;top:0;z-index:5;display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:rgba(255,250,241,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.brand{display:flex;gap:10px;align-items:center;text-decoration:none;color:var(--dark)}
.brand-icon{width:42px;height:42px;border-radius:14px;object-fit:cover;box-shadow:0 6px 16px rgba(24,53,31,.18)}
.brand-mark{font-size:30px}
.brand small{display:block;color:#66715c}
.menu-btn{border:0;background:var(--green);color:white;border-radius:12px;padding:10px 12px;font-size:18px}
.mobile-menu{display:none;position:fixed;right:14px;top:66px;z-index:10;background:white;border:1px solid var(--line);box-shadow:var(--shadow);border-radius:18px;padding:10px}
.mobile-menu.open{display:grid}
.mobile-menu a{padding:10px 18px;text-decoration:none;color:var(--dark);border-radius:12px}
.mobile-menu a:hover{background:var(--soft)}
.page{max-width:1100px;margin:auto;padding:16px}
.hero{
  min-height:350px;
  border-radius:28px;
  background:
    linear-gradient(90deg,rgba(24,53,31,.78),rgba(24,53,31,.22)),
    url('/static/img/01_hero_principal_defi_nature_zecmdp.png');
  background-size:cover;
  background-position:center;
  display:flex;
  align-items:end;
  padding:28px;
  color:white;
  box-shadow:var(--shadow);
  overflow:hidden;
  border:1px solid rgba(255,255,255,.22);
}
.hero-card{max-width:720px;padding:22px;border-radius:24px;background:linear-gradient(90deg,rgba(24,53,31,.55),rgba(24,53,31,.10));backdrop-filter:blur(2px)}
.hero h1{font-size:clamp(34px,7vw,60px);line-height:1;margin:6px 0;text-shadow:0 2px 14px rgba(0,0,0,.28)}
.hero p{max-width:620px;font-size:18px}
.eyebrow{text-transform:uppercase;letter-spacing:.12em;font-size:13px}
.hero-actions,.section-title{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:14px;padding:12px 16px;text-decoration:none;border:0;font-weight:700;cursor:pointer;box-shadow:var(--shadow-soft)}
.primary{background:var(--green);color:white}
.primary:hover{background:#244b24}
.ghost{background:rgba(255,255,255,.78);border:1px solid rgba(255,255,255,.55);color:var(--dark)}
.grid{display:grid;gap:14px}
.cards-2{grid-template-columns:repeat(auto-fit,minmax(190px,1fr));margin:18px 0}
.feature-card,.panel,.progress-card,.login-card{background:var(--paper);border:1px solid var(--line);border-radius:24px;padding:20px;box-shadow:var(--shadow)}
.feature-card{text-decoration:none;color:var(--dark);min-height:170px;transition:transform .18s ease, box-shadow .18s ease}
.feature-card:hover{transform:translateY(-2px);box-shadow:0 18px 44px rgba(24,53,31,.18)}
.feature-card span{font-size:42px}
.feature-card h2{margin:8px 0}
.image-card{padding:0;overflow:hidden;display:flex;flex-direction:column;background:white}
.image-card img{width:100%;height:130px;object-fit:cover;display:block}
.image-card div{padding:16px}
.image-card p{margin-bottom:0}
.leaf{background:#edf5dc}.camera{background:#f2dfc9}.quiz{background:#dfeef0}.passport{background:#ead9bd}
.page-head{
  background:
    linear-gradient(90deg,rgba(255,250,241,.94),rgba(255,250,241,.78)),
    url('/static/img/05_banniere_secondaire_pages_internes.png');
  background-size:cover;
  background-position:center;
  border:1px solid var(--line);
  border-radius:24px;
  padding:20px;
  margin-bottom:18px;
  box-shadow:var(--shadow-soft);
}
.page-head h1{margin:0 0 8px;font-size:34px}
.section-title{justify-content:space-between}
.section-title a{color:var(--green);font-weight:700}
.list-cards{display:grid;gap:12px}
.mini-card,.challenge-card{border:1px solid var(--line);background:white;border-radius:18px;padding:16px}
.challenge-card{display:flex;justify-content:space-between;gap:16px;align-items:center}
.challenge-card h2{margin:4px 0}
.badge-row,.badge-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px}
.badge{background:white;border:1px solid var(--line);border-radius:18px;text-align:center;padding:14px}
.badge span{font-size:38px;display:block}
.badge.big{min-height:190px}.badge.locked{filter:grayscale(1);opacity:.45}
.bingo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:10px}
.bingo-cell{background:white;border:1px solid var(--line);border-radius:16px;min-height:120px;padding:12px;cursor:pointer}
.bingo-cell span{font-size:30px;display:block}
.bingo-cell.checked{background:#dfeecb;border-color:var(--green);box-shadow:inset 0 0 0 3px rgba(47,93,47,.22)}
.progress-card{margin-bottom:14px}
.progress-card div{display:flex;justify-content:space-between}
progress{width:100%;height:16px;accent-color:var(--green)}
.quiz-box button{display:block;width:100%;text-align:left;margin:10px 0;padding:14px;border-radius:14px;border:1px solid var(--line);background:white}
.quiz-box button.correct{background:#e1f2d4;border-color:var(--green)}
.quiz-box button.wrong{background:#ffe2d7;border-color:#bc5c3c}
.form-grid{display:grid;gap:10px}
.form-grid input,.form-grid textarea,.form-grid select{width:100%;padding:12px;border-radius:14px;border:1px solid var(--line);font:inherit;background:white}
.form-grid textarea{min-height:100px}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:14px}
.gallery-grid.small{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}
.photo-card{background:white;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:0 8px 20px rgba(0,0,0,.06)}
.photo-card img{width:100%;height:180px;object-fit:cover;display:block}
.photo-card div,.photo-card strong,.photo-card small,.photo-card p{margin:10px}
.stamp-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}
.stamp{border:2px dashed #a18a64;border-radius:18px;padding:14px;background:#fff}
.stamp strong{display:block}
.admin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:14px}
.admin-list{max-height:300px;overflow:auto}
.login-card{max-width:440px;margin:50px auto}
.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:6;display:grid;grid-template-columns:repeat(auto-fit,minmax(64px,1fr));background:rgba(255,250,241,.94);border-top:1px solid var(--line);backdrop-filter:blur(12px)}
.bottom-nav a{text-align:center;text-decoration:none;color:var(--dark);padding:10px 4px;font-size:20px}
.bottom-nav span{display:block;font-size:12px}
.flash-wrap{display:grid;gap:8px;margin-bottom:12px}
.flash{border-radius:14px;padding:12px;background:white;border:1px solid var(--line)}
.flash.success{background:#e4f4d8}.flash.danger{background:#ffe1d9}.flash.warning{background:#fff3c4}.flash.info{background:#dff1ff}
@media(min-width:800px){
  .bottom-nav{display:none}
  body{padding-bottom:0}
  .page{padding:24px}
  .mobile-menu{position:static;display:flex;background:transparent;border:0;box-shadow:none;padding:0}
  .menu-btn{display:none}
  .mobile-menu a{padding:8px 10px}
  .topbar{gap:18px}
  .hero{padding:42px}
}
@media(max-width:520px){
  .hero{min-height:310px;padding:18px;border-radius:24px}
  .hero-card{padding:16px;border-radius:20px}
  .image-card img{height:115px}
}

/* =========================================================
   V1.3 — modules actifs et annotations discrètes Loi 25
   ========================================================= */
.fine-print {
  font-size: 12px !important;
  line-height: 1.35 !important;
  color: #66715c !important;
  margin-top: 8px !important;
}

.consent-line {
  display: flex !important;
  align-items: flex-start !important;
  gap: 8px !important;
  font-size: 12px !important;
  line-height: 1.35 !important;
  color: #4b5848 !important;
  background: rgba(255,255,255,.62) !important;
  border: 1px solid var(--line) !important;
  border-radius: 14px !important;
  padding: 10px 12px !important;
}

.consent-line input {
  width: auto !important;
  margin-top: 2px !important;
}

.subtle-panel {
  background: rgba(255,248,236,.78) !important;
}

.completeChallenge.completed,
.completeChallenge:disabled {
  opacity: .72 !important;
  cursor: default !important;
  background: #6E8F3D !important;
}

.passport-stats {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)) !important;
  gap: 12px !important;
  margin: 12px 0 16px !important;
}

.passport-stats div {
  background: #fff !important;
  border: 1px solid var(--line) !important;
  border-radius: 18px !important;
  padding: 14px !important;
  text-align: center !important;
}

.passport-stats strong {
  display: block !important;
  font-size: 32px !important;
  color: var(--green) !important;
}

.passport-stats span {
  display: block !important;
  font-size: 13px !important;
  color: #66715c !important;
}


/* =========================================================
   V1.4 — admin avancé, images personnalisées et pop-up quiz
   ========================================================= */
.admin-full { margin-top: 16px !important; }
.admin-inline-form { margin-bottom: 18px !important; }
.admin-edit-list { display: grid !important; gap: 12px !important; }
.admin-edit-card { display: grid !important; grid-template-columns: 88px repeat(3, minmax(120px, 1fr)) auto auto auto !important; gap: 10px !important; align-items: center !important; padding: 12px !important; background: #fff !important; border: 1px solid var(--line) !important; border-radius: 18px !important; }
.admin-edit-card.wide { grid-template-columns: 88px repeat(2, minmax(180px, 1fr)) repeat(3, minmax(90px, 1fr)) auto auto auto !important; }
.admin-edit-card input,.admin-edit-card textarea,.admin-edit-card select { width: 100% !important; padding: 9px !important; border-radius: 12px !important; border: 1px solid var(--line) !important; }
.admin-edit-card textarea { min-height: 58px !important; }
.admin-preview { width: 72px !important; height: 72px !important; border-radius: 16px !important; background: var(--soft) !important; display: flex !important; align-items: center !important; justify-content: center !important; overflow: hidden !important; font-size: 36px !important; }
.admin-preview img { width: 100% !important; height: 100% !important; object-fit: cover !important; display: block !important; }
.mini-check { display: flex !important; gap: 6px !important; align-items: center !important; font-size: 12px !important; color: #566250 !important; }
.mini-check input { width: auto !important; }
.danger-link { color: #8b2f1f !important; }
.bingo-img { width: 58px !important; height: 58px !important; object-fit: cover !important; border-radius: 14px !important; display: block !important; margin-bottom: 8px !important; }
.challenge-card-with-image { align-items: stretch !important; }
.challenge-img { width: 150px !important; min-height: 120px !important; object-fit: cover !important; border-radius: 16px !important; }
.quiz-img { width: 100% !important; max-height: 260px !important; object-fit: cover !important; border-radius: 18px !important; margin-bottom: 14px !important; }
.badge-img { width: 74px !important; height: 74px !important; object-fit: cover !important; border-radius: 20px !important; display: block !important; margin: 0 auto 10px !important; }
.quiz-modal { position: fixed !important; inset: 0 !important; z-index: 1000 !important; background: rgba(24,53,31,.55) !important; display: flex !important; align-items: center !important; justify-content: center !important; padding: 18px !important; }
.quiz-modal[hidden] { display: none !important; }
.quiz-modal-card { width: min(440px, 100%) !important; background: var(--paper) !important; border: 1px solid var(--line) !important; border-radius: 24px !important; box-shadow: var(--shadow) !important; padding: 24px !important; text-align: center !important; }
.quiz-modal-card h2 { margin-top: 0 !important; color: var(--green) !important; }
@media(max-width: 900px){ .admin-edit-card,.admin-edit-card.wide { grid-template-columns: 1fr !important; } .admin-preview { width: 100% !important; height: 140px !important; } .challenge-card-with-image { display: grid !important; } .challenge-img { width: 100% !important; height: 180px !important; } }


/* =========================================================
   HERO FINAL V17 — Ordinateur + téléphone dédié
   Image ordinateur : 01_hero_principal_defi_nature_zecmdp.png
   Image téléphone  : 01_hero_mobile_defi_nature_zecmdp.png
   ========================================================= */

/* Ordinateur / tablette large */
.hero-clean {
  max-width: 1040px !important;
  margin: 28px auto 18px auto !important;
  min-height: 360px !important;
  display: flex !important;
  align-items: flex-end !important;
  padding: 0 !important;
  position: relative !important;
  background: url("/static/img/01_hero_principal_defi_nature_zecmdp.png") center center / cover no-repeat !important;
  border-radius: 28px !important;
  overflow: hidden !important;
  box-shadow: var(--shadow) !important;
  border: 0 !important;
}

.hero-clean .hero-bottom {
  width: 100% !important;
  padding: 0 24px 20px 24px !important;
  display: grid !important;
  grid-template-columns: auto 1fr auto !important;
  align-items: end !important;
  gap: 18px !important;
  background: transparent !important;
  backdrop-filter: none !important;
  box-shadow: none !important;
}

.hero-clean .hero-actions {
  grid-column: 1 !important;
  margin: 0 !important;
  display: flex !important;
  justify-content: flex-start !important;
  align-items: center !important;
}

.hero-clean .hero-bottom p {
  grid-column: 2 !important;
  margin: 0 !important;
  color: #fff !important;
  font-size: clamp(18px, 1.7vw, 22px) !important;
  font-weight: 800 !important;
  line-height: 1.18 !important;
  text-align: center !important;
  max-width: 640px !important;
  justify-self: center !important;
  text-shadow: 0 3px 12px rgba(0,0,0,.72) !important;
}

.hero-clean .btn.primary {
  background: #2F5D2F !important;
  color: #fff !important;
  border: 1px solid rgba(255,255,255,.30) !important;
  white-space: nowrap !important;
  box-shadow: 0 6px 16px rgba(0,0,0,.25) !important;
}

.hero-clean .hero-card {
  display: none !important;
}

.module-grid,
.panel {
  max-width: 1040px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Téléphone : utilise l'image mobile 1080 x 900 complète */
@media screen and (max-width: 700px) {

  html body .topbar {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    min-height: 72px !important;
    padding: 10px 56px 10px 12px !important;
    position: sticky !important;
    top: 0 !important;
  }

  html body .brand {
    width: 100% !important;
    max-width: calc(100vw - 82px) !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 10px !important;
    margin: 0 auto !important;
    padding: 0 !important;
    text-align: center !important;
  }

  html body .brand-icon {
    flex: 0 0 auto !important;
    width: 42px !important;
    height: 42px !important;
  }

  html body .brand span {
    display: block !important;
    min-width: 0 !important;
    text-align: center !important;
  }

  html body .brand strong,
  html body .brand small {
    display: block !important;
    text-align: center !important;
    white-space: normal !important;
    line-height: 1.1 !important;
  }

  html body .brand strong {
    font-size: 17px !important;
  }

  html body .brand small {
    font-size: 12px !important;
  }

  html body .menu-btn {
    position: absolute !important;
    right: 12px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    z-index: 20 !important;
  }

  html body .hero-clean {
    width: 100% !important;
    max-width: calc(100vw - 28px) !important;
    min-height: auto !important;
    height: auto !important;
    aspect-ratio: 1080 / 900 !important;
    margin: 18px auto 118px auto !important;
    padding: 0 !important;
    display: block !important;
    position: relative !important;
    overflow: visible !important;
    border-radius: 24px !important;
    background: url("/static/img/01_hero_mobile_defi_nature_zecmdp.png") center center / cover no-repeat !important;
    box-shadow: var(--shadow) !important;
  }

  html body .hero-clean .hero-bottom {
    position: absolute !important;
    left: 0 !important;
    right: 0 !important;
    top: auto !important;
    bottom: -104px !important;
    width: 100% !important;
    height: auto !important;
    padding: 0 !important;
    margin: 0 !important;
    display: block !important;
    background: transparent !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    pointer-events: auto !important;
  }

  html body .hero-clean .hero-bottom p {
    position: static !important;
    display: block !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 0 10px 0 !important;
    padding: 0 4px !important;
    transform: none !important;
    color: #18351f !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    line-height: 1.32 !important;
    text-align: center !important;
    text-shadow: none !important;
  }

  html body .hero-clean .hero-actions {
    position: static !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 4px !important;
  }

  html body .hero-clean .btn.primary {
    width: 100% !important;
    max-width: 320px !important;
    white-space: nowrap !important;
  }

  html body .module-grid,
  html body .panel {
    max-width: calc(100vw - 28px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}

/* =========================================================
   V18 — Défis Nature : explications, boutons clairs, badges
   ========================================================= */

.defis-head p {
  max-width: 980px !important;
}

.defis-howto {
  margin-bottom: 16px !important;
}

.howto-steps {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)) !important;
  gap: 12px !important;
}

.howto-steps div,
.howto-step-card {
  background: var(--howto-bg, #fff) !important;
  border: 1px solid var(--line) !important;
  border-radius: 18px !important;
  padding: 14px !important;
}

.howto-steps strong {
  width: 34px !important;
  height: 34px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 50% !important;
  background: var(--howto-accent, var(--green)) !important;
  color: white !important;
  margin-bottom: 8px !important;
}

.howto-steps span {
  display: block !important;
  font-weight: 800 !important;
  color: var(--howto-text, var(--dark)) !important;
  margin-bottom: 4px !important;
}

.howto-steps small {
  display: block !important;
  color: var(--howto-text, #66715c) !important;
  line-height: 1.35 !important;
}

.defis-list {
  gap: 14px !important;
}

.defis-card.challenge-card-with-image {
  align-items: center !important;
}

.defis-card {
  display: grid !important;
  grid-template-columns: auto 1fr auto !important;
  gap: 16px !important;
  padding: 18px !important;
}

.defis-card .challenge-main {
  min-width: 0 !important;
}

.defis-card h2 {
  margin: 8px 0 !important;
}

.challenge-meta {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  align-items: center !important;
}

.points-pill,
.category-pill,
.photo-pill {
  display: inline-flex !important;
  align-items: center !important;
  border-radius: 999px !important;
  padding: 6px 10px !important;
  font-size: 13px !important;
  line-height: 1 !important;
  font-weight: 700 !important;
}

.points-pill {
  background: #e4f4d8 !important;
  color: var(--green) !important;
}

.category-pill {
  background: #fff6df !important;
  color: #70511f !important;
  border: 1px solid #ead9bd !important;
}

.photo-pill {
  background: #dfeef0 !important;
  color: #27535b !important;
}

.photo-pill.muted {
  background: #f1efe8 !important;
  color: #66715c !important;
}

.defis-card .completeChallenge {
  align-self: center !important;
  min-width: 190px !important;
  min-height: auto !important;
  padding: 13px 16px !important;
  white-space: normal !important;
  line-height: 1.15 !important;
}

.photo-submit-panel {
  margin-top: 18px !important;
}

.photo-submit-panel > p {
  color: #4b5848 !important;
  max-width: 850px !important;
}

@media(max-width: 760px) {
  .defis-card {
    grid-template-columns: 1fr !important;
  }

  .defis-card .challenge-img {
    width: 100% !important;
    height: 170px !important;
  }

  .defis-card .completeChallenge {
    width: 100% !important;
    min-width: 0 !important;
  }

  .challenge-meta {
    gap: 6px !important;
  }

  .points-pill,
  .category-pill,
  .photo-pill {
    font-size: 12px !important;
  }
}

/* =========================================================
   Page Installer / QR code — Défi Nature ZECMDP
   Ces styles remplacent le fichier séparé installer_page_patch.css.
   ========================================================= */

.installer-head p { max-width: 760px; }
.installer-grid { display: grid; grid-template-columns: 1fr 260px; gap: 24px; align-items: center; }
.qr-box { text-align: center; }
.qr-box img {
  width: 240px;
  max-width: 100%;
  border-radius: 20px;
  background: white;
  border: 1px solid var(--line);
  padding: 12px;
  box-shadow: var(--shadow-soft);
}
.qr-box small { display: block; margin-top: 8px; color: #66715c; }
.installer-steps ol { padding-left: 22px; }
.installer-steps li { margin: 8px 0; }
@media(max-width: 700px) {
  .installer-grid { grid-template-columns: 1fr; }
  .qr-box { order: -1; }
}

/* =========================================================
   V19 — Entête image propre au module Défis Nature
   ========================================================= */

.module-header-image {
  max-width: 1180px !important;
  margin: 12px auto 22px auto !important;
  border-radius: 28px !important;
  overflow: hidden !important;
  box-shadow: var(--shadow-soft) !important;
  border: 1px solid var(--line) !important;
  background: transparent !important;
}

.module-header-image img {
  width: 100% !important;
  height: auto !important;
  display: block !important;
}

.module-header-defis {
  margin-top: 12px !important;
}

@media(max-width: 700px) {
  .module-header-image {
    max-width: calc(100vw - 28px) !important;
    margin: 12px auto 16px auto !important;
    border-radius: 22px !important;
  }
}

/* =========================================================
   V20 — Menu intégré dans l'entête sur ordinateur
   ========================================================= */

@media(min-width: 800px) {
  .topbar {
    display: grid !important;
    grid-template-columns: auto 1fr !important;
    align-items: center !important;
    gap: 24px !important;
    padding: 12px 22px !important;
  }

  .topbar .brand {
    justify-self: start !important;
  }

  .topbar .mobile-menu {
    position: static !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 20px !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    padding: 0 !important;
  }

  .topbar .mobile-menu a {
    padding: 8px 0 !important;
    font-weight: 800 !important;
    font-size: 18px !important;
    color: var(--dark) !important;
    text-decoration: none !important;
    border-radius: 0 !important;
  }

  .topbar .mobile-menu a:hover {
    background: transparent !important;
    color: var(--green) !important;
  }
}

@media(max-width: 799px) {
  .topbar .mobile-menu {
    display: none !important;
    position: fixed !important;
    right: 14px !important;
    top: 78px !important;
    z-index: 10 !important;
    background: white !important;
    border: 1px solid var(--line) !important;
    box-shadow: var(--shadow) !important;
    border-radius: 18px !important;
    padding: 10px !important;
  }

  .topbar .mobile-menu.open {
    display: grid !important;
  }

  .topbar .mobile-menu a {
    font-weight: 700 !important;
  }
}

/* =========================================================
   V24 — Puzzle Nature
   ========================================================= */

.puzzle-panel .section-title {
  align-items: flex-start !important;
}

.puzzle-stats {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr)) !important;
  gap: 12px !important;
  margin: 16px 0 !important;
}

.puzzle-stats div {
  background: #fff !important;
  border: 1px solid var(--line) !important;
  border-radius: 18px !important;
  padding: 14px !important;
  text-align: center !important;
}

.puzzle-stats strong {
  display: block !important;
  color: var(--green) !important;
  font-size: 30px !important;
}

.puzzle-stats span {
  display: block !important;
  color: #66715c !important;
  font-size: 13px !important;
  margin-top: 4px !important;
}

.puzzle-board {
  width: min(620px, 100%) !important;
  aspect-ratio: 1 / 1 !important;
  margin: 18px auto !important;
  display: grid !important;
  gap: 5px !important;
  background: #d6cab8 !important;
  border: 8px solid #fff !important;
  border-radius: 24px !important;
  box-shadow: var(--shadow-soft) !important;
  overflow: hidden !important;
  touch-action: none !important;
  user-select: none !important;
}

.puzzle-tile {
  width: 100% !important;
  height: 100% !important;
  border: 0 !important;
  border-radius: 10px !important;
  background-repeat: no-repeat !important;
  cursor: grab !important;
  background-color: #efe4d3 !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.55), 0 4px 10px rgba(0,0,0,.12) !important;
  transition: transform .12s ease, filter .12s ease, box-shadow .12s ease !important;
  touch-action: none !important;
  user-select: none !important;
  -webkit-user-select: none !important;
  -webkit-touch-callout: none !important;
}

.puzzle-tile:hover {
  filter: brightness(1.04) !important;
}

.puzzle-tile.selected {
  filter: brightness(1.08) saturate(1.05) !important;
  box-shadow: inset 0 0 0 3px rgba(63,111,31,.45), 0 8px 18px rgba(0,0,0,.18) !important;
}

.puzzle-tile.pressed,
.puzzle-tile.dragging {
  cursor: grabbing !important;
}

.puzzle-tile.dragging {
  opacity: .94 !important;
  transition: none !important;
  will-change: transform !important;
  box-shadow: inset 0 0 0 2px rgba(255,255,255,.7), 0 14px 26px rgba(0,0,0,.25) !important;
}

.puzzle-selector {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)) !important;
  gap: 10px !important;
  margin: 16px 0 10px !important;
}

.puzzle-choice {
  border: 1px solid var(--line) !important;
  border-radius: 18px !important;
  background: #fff !important;
  box-shadow: var(--shadow-soft) !important;
  padding: 12px 14px !important;
  text-align: left !important;
  cursor: pointer !important;
}

.puzzle-choice strong {
  display: block !important;
  color: var(--green) !important;
  font-size: 18px !important;
}

.puzzle-choice span {
  display: block !important;
  color: #66715c !important;
  font-size: 13px !important;
  margin-top: 3px !important;
}

.puzzle-choice.active {
  border-color: rgba(63,111,31,.5) !important;
  box-shadow: 0 0 0 3px rgba(63,111,31,.12), var(--shadow-soft) !important;
}

.puzzle-actions {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
  margin-top: 12px !important;
}

.puzzle-best-panel {
  margin-top: 18px !important;
}

.puzzle-admin-card textarea {
  min-height: 70px !important;
}

@media(max-width: 700px) {
  .puzzle-board {
    width: 100% !important;
    gap: 4px !important;
    border-width: 6px !important;
    border-radius: 20px !important;
  }

  .puzzle-tile {
    border-radius: 8px !important;
  }

  .puzzle-selector {
    grid-template-columns: 1fr !important;
  }

  .puzzle-actions .btn {
    width: 100% !important;
  }
}

/* Menu du bas : 5 liens quand le Puzzle est ajouté */
.bottom-nav {
  grid-template-columns: repeat(5, 1fr) !important;
}

@media(min-width:800px) {
  .bottom-nav {
    display: none !important;
  }
}

/* =========================================================
   V25 — Profil local avec pseudo
   ========================================================= */

.profile-modal {
  position: fixed !important;
  inset: 0 !important;
  z-index: 1200 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 18px !important;
  background: rgba(24,53,31,.58) !important;
}

.profile-modal[hidden] {
  display: none !important;
}

.profile-modal-card {
  width: min(480px, 100%) !important;
  background: var(--paper) !important;
  border: 1px solid var(--line) !important;
  border-radius: 26px !important;
  box-shadow: var(--shadow) !important;
  padding: 24px !important;
}

.profile-modal-card h2 {
  margin-top: 0 !important;
  color: var(--green) !important;
}

.profile-field {
  display: grid !important;
  gap: 6px !important;
  margin: 14px 0 8px !important;
  font-weight: 800 !important;
  color: var(--dark) !important;
}

.profile-field input {
  width: 100% !important;
  padding: 13px 14px !important;
  border-radius: 14px !important;
  border: 1px solid var(--line) !important;
  font: inherit !important;
  background: white !important;
}

.profile-modal-actions {
  display: flex !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
  margin-top: 16px !important;
}

.profile-modal-actions .btn {
  flex: 1 1 180px !important;
}

.profile-panel {
  margin-bottom: 14px !important;
}

.profile-summary {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)) !important;
  gap: 12px !important;
  margin: 12px 0 !important;
}

.profile-summary div {
  background: #fff !important;
  border: 1px solid var(--line) !important;
  border-radius: 18px !important;
  padding: 14px !important;
  text-align: center !important;
}

.profile-summary strong {
  display: block !important;
  font-size: 24px !important;
  color: var(--green) !important;
  overflow-wrap: anywhere !important;
}

.profile-summary span {
  display: block !important;
  color: #66715c !important;
  font-size: 13px !important;
  margin-top: 4px !important;
}

@media(max-width: 700px) {
  .profile-modal-card {
    padding: 20px !important;
    border-radius: 22px !important;
  }
}

/* =========================================================
   V26 — Synchronisation locale vers serveur
   ========================================================= */

.sync-table-wrap {
  overflow-x: auto !important;
  border: 1px solid var(--line) !important;
  border-radius: 18px !important;
  background: #fff !important;
}

.sync-table {
  width: 100% !important;
  border-collapse: collapse !important;
  min-width: 760px !important;
}

.sync-table th,
.sync-table td {
  padding: 10px 12px !important;
  border-bottom: 1px solid var(--line) !important;
  text-align: left !important;
  vertical-align: top !important;
  font-size: 13px !important;
}

.sync-table th {
  background: #f3eadb !important;
  color: var(--dark) !important;
}

.sync-table code {
  white-space: pre-wrap !important;
  word-break: break-word !important;
  font-size: 12px !important;
  color: #4b5848 !important;
}

.sync-admin-panel {
  margin-top: 16px !important;
}

/* =========================================================
   V27 — Classement Puzzle + badges Puzzle locaux
   ========================================================= */

.leaderboard-table-wrap {
  overflow-x: auto !important;
  border: 1px solid var(--line) !important;
  border-radius: 18px !important;
  background: #fff !important;
}

.leaderboard-table {
  width: 100% !important;
  border-collapse: collapse !important;
  min-width: 680px !important;
}

.leaderboard-table th,
.leaderboard-table td {
  padding: 12px 14px !important;
  border-bottom: 1px solid var(--line) !important;
  text-align: left !important;
}

.leaderboard-table th {
  background: #f3eadb !important;
  color: var(--dark) !important;
}

.leaderboard-table tbody tr:nth-child(1) td:first-child strong {
  color: #9b6b12 !important;
}

.puzzle-title-actions {
  display: flex !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
}

.puzzle-badges-panel {
  margin-top: 14px !important;
}

.puzzle-badges-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)) !important;
  gap: 12px !important;
}

.puzzle-badge {
  background: #fff !important;
  border: 1px solid var(--line) !important;
  border-radius: 18px !important;
  padding: 16px !important;
  text-align: center !important;
  box-shadow: var(--shadow-soft) !important;
}

.puzzle-badge span {
  display: block !important;
  font-size: 38px !important;
  margin-bottom: 8px !important;
}

.puzzle-badge strong {
  display: block !important;
  color: var(--dark) !important;
  margin-bottom: 6px !important;
}

.puzzle-badge small {
  color: #66715c !important;
  line-height: 1.35 !important;
}

.puzzle-badge.locked {
  filter: grayscale(1) !important;
  opacity: .45 !important;
  box-shadow: none !important;
}

@media(max-width: 700px) {
  .puzzle-title-actions .btn {
    width: 100% !important;
  }
}


/* =========================================================
   V33 — Retour base stable
   ========================================================= */

/* Correctif : retrait des essais CSS/JS intégrés hors ligne.
   La priorité est de restaurer le fonctionnement complet de l'application. */

/* =========================================================
   V34 — Administration : menu rapide et ancres
   ========================================================= */

.admin-quick-nav {
  position: sticky !important;
  top: 68px !important;
  z-index: 4 !important;
  max-width: 1100px !important;
  margin: 0 auto 16px auto !important;
  padding: 10px !important;
  display: flex !important;
  gap: 8px !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
  background: rgba(255, 248, 236, .96) !important;
  border: 1px solid var(--line) !important;
  border-radius: 20px !important;
  box-shadow: var(--shadow-soft) !important;
  backdrop-filter: blur(10px) !important;
}

.admin-quick-nav a {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 9px 12px !important;
  border-radius: 999px !important;
  background: #fff !important;
  border: 1px solid var(--line) !important;
  color: var(--dark) !important;
  text-decoration: none !important;
  font-weight: 800 !important;
  font-size: 14px !important;
  white-space: nowrap !important;
}

.admin-quick-nav a:hover {
  background: var(--green) !important;
  color: #fff !important;
}

#admin-settings,
#admin-security,
#admin-bingo,
#admin-defis,
#admin-quiz,
#admin-puzzle,
#admin-badges,
#admin-photos,
#admin-sync {
  scroll-margin-top: 150px !important;
}

.admin-full > h2,
.admin-grid .panel > h2 {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  color: var(--green) !important;
}

#admin-settings > h2::before { content: "⚙️"; }
#admin-security > h2::before { content: "🔐"; }
#admin-bingo > h2::before { content: "🌲"; }
#admin-defis > h2::before { content: "📸"; }
#admin-quiz > h2::before { content: "❓"; }
#admin-puzzle > h2::before { content: "🧩"; }
#admin-badges > h2::before { content: "🏅"; }
#admin-photos > h2::before { content: "🖼️"; }
#admin-sync > h2::before { content: "🔄"; }

.admin-back-top {
  text-align: center !important;
  margin: 24px 0 8px !important;
}

@media(max-width: 760px) {
  .admin-quick-nav {
    top: 74px !important;
    justify-content: flex-start !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    border-radius: 16px !important;
    margin-bottom: 12px !important;
    padding: 8px !important;
  }

  .admin-quick-nav a {
    flex: 0 0 auto !important;
    font-size: 13px !important;
    padding: 8px 11px !important;
  }

  #admin-settings,
  #admin-security,
  #admin-bingo,
  #admin-defis,
  #admin-quiz,
  #admin-puzzle,
  #admin-badges,
  #admin-photos,
  #admin-sync {
    scroll-margin-top: 145px !important;
  }
}

/* =========================================================
   V35 — Admin : Paramètres et Sécurité plus larges
   ========================================================= */

.admin-grid {
  max-width: 1100px !important;
  margin: 16px auto !important;
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 16px !important;
  align-items: stretch !important;
}

.admin-grid .panel {
  width: 100% !important;
  min-width: 0 !important;
}

.admin-grid .panel form {
  height: 100% !important;
}

.admin-grid .panel textarea,
.admin-grid .panel input {
  width: 100% !important;
}

@media(max-width: 820px) {
  .admin-grid {
    grid-template-columns: 1fr !important;
    max-width: calc(100vw - 32px) !important;
  }
}

/* =========================================================
   V36 — Correctif admin : boutons Paramètres/Sécurité
   ========================================================= */

.admin-grid {
  align-items: start !important;
}

.admin-grid .panel {
  height: auto !important;
  align-self: start !important;
}

.admin-grid .panel form {
  height: auto !important;
  min-height: 0 !important;
  align-content: start !important;
}

.admin-grid .panel .btn {
  width: 100% !important;
  min-height: 52px !important;
  height: auto !important;
  margin-top: 2px !important;
}

.admin-grid + .admin-full {
  margin-top: 18px !important;
}

@media(min-width: 821px) {
  .admin-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

/* =========================================================
   V37 — Passeport enrichi
   ========================================================= */

.passport-head {
  margin-bottom: 14px !important;
}

.passport-hero {
  display: grid !important;
  grid-template-columns: 1.35fr .9fr !important;
  gap: 16px !important;
  align-items: stretch !important;
  margin-bottom: 16px !important;
  background:
    radial-gradient(circle at top left, rgba(110,143,61,.18), transparent 45%),
    var(--paper) !important;
}

.passport-profile-main {
  display: grid !important;
  grid-template-columns: auto 1fr auto !important;
  gap: 16px !important;
  align-items: center !important;
}

.passport-avatar {
  width: 74px !important;
  height: 74px !important;
  border-radius: 24px !important;
  display: grid !important;
  place-items: center !important;
  background: #fff !important;
  border: 1px solid var(--line) !important;
  font-size: 38px !important;
  box-shadow: var(--shadow-soft) !important;
}

.passport-kicker {
  display: inline-flex !important;
  color: #66715c !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
}

.passport-profile-main h2 {
  margin: 3px 0 5px !important;
  color: var(--green) !important;
  font-size: clamp(28px, 4vw, 44px) !important;
  line-height: 1 !important;
  overflow-wrap: anywhere !important;
}

.passport-profile-main p {
  margin: 3px 0 !important;
  color: #4b5848 !important;
}

.passport-score-card {
  background: #fff !important;
  border: 1px solid var(--line) !important;
  border-radius: 22px !important;
  padding: 18px !important;
  display: grid !important;
  gap: 10px !important;
  align-content: center !important;
  box-shadow: var(--shadow-soft) !important;
}

.passport-score-card > strong {
  font-size: clamp(34px, 5vw, 54px) !important;
  color: var(--green) !important;
  line-height: 1 !important;
}

.passport-score-card progress {
  width: 100% !important;
  height: 16px !important;
  accent-color: var(--green) !important;
}

.passport-level-row {
  display: flex !important;
  justify-content: space-between !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
  color: #66715c !important;
  font-weight: 700 !important;
}

.passport-level-row span {
  color: var(--dark) !important;
}

.passport-dashboard {
  margin-bottom: 16px !important;
}

.passport-stats-rich {
  grid-template-columns: repeat(auto-fit, minmax(135px, 1fr)) !important;
}

.passport-two-cols {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 16px !important;
  margin-bottom: 16px !important;
}

.last-achievement {
  display: grid !important;
  grid-template-columns: auto 1fr !important;
  gap: 14px !important;
  align-items: center !important;
  background: #fff !important;
  border: 1px solid var(--line) !important;
  border-radius: 18px !important;
  padding: 14px !important;
}

.last-achievement > span {
  width: 54px !important;
  height: 54px !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 18px !important;
  background: var(--soft) !important;
  font-size: 30px !important;
}

.last-achievement strong {
  color: var(--green) !important;
  font-size: 18px !important;
}

.last-achievement p {
  margin: 4px 0 0 !important;
  color: #4b5848 !important;
}

.passport-actions {
  display: grid !important;
  gap: 10px !important;
}

.passport-badge-grid {
  margin-top: 12px !important;
}

.stamps-panel {
  margin-top: 16px !important;
}

.passport-stamp-grid {
  gap: 12px !important;
}

.passport-stamp {
  position: relative !important;
  padding: 16px !important;
  border-radius: 18px !important;
  background: #fff !important;
  border: 2px dashed #d6cab8 !important;
  box-shadow: none !important;
  transition: transform .15s ease, opacity .15s ease !important;
}

.passport-stamp em {
  display: block !important;
  font-style: normal !important;
  color: #66715c !important;
  font-size: 12px !important;
  margin-bottom: 4px !important;
}

.passport-stamp strong {
  display: block !important;
  color: var(--dark) !important;
}

.stamp-status {
  display: inline-flex !important;
  margin-bottom: 8px !important;
  padding: 5px 9px !important;
  border-radius: 999px !important;
  background: #f1efe8 !important;
  color: #66715c !important;
  font-size: 12px !important;
  font-weight: 800 !important;
}

.passport-stamp.unlocked {
  border-style: solid !important;
  border-color: #b9d8a8 !important;
  background: #f7fff2 !important;
  box-shadow: var(--shadow-soft) !important;
}

.passport-stamp.unlocked .stamp-status {
  background: #e4f4d8 !important;
  color: var(--green) !important;
}

.passport-stamp.locked {
  opacity: .62 !important;
  filter: grayscale(.35) !important;
}

.danger-zone {
  margin-top: 16px !important;
}

@media(max-width: 820px) {
  .passport-hero,
  .passport-two-cols {
    grid-template-columns: 1fr !important;
  }

  .passport-profile-main {
    grid-template-columns: auto 1fr !important;
  }

  .passport-profile-main .btn {
    grid-column: 1 / -1 !important;
    width: 100% !important;
  }
}

@media(max-width: 520px) {
  .passport-profile-main {
    grid-template-columns: 1fr !important;
    text-align: center !important;
  }

  .passport-avatar {
    margin: auto !important;
  }

  .passport-level-row {
    justify-content: center !important;
    text-align: center !important;
  }
}

/* =========================================================
   V38 — Sons courts + bouton activer/désactiver
   ========================================================= */

.topbar-actions {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
}

.sound-toggle {
  border: 1px solid var(--line) !important;
  background: #fff !important;
  color: var(--dark) !important;
  border-radius: 12px !important;
  padding: 9px 11px !important;
  font-size: 18px !important;
  line-height: 1 !important;
  cursor: pointer !important;
  box-shadow: var(--shadow-soft) !important;
}

.sound-toggle.enabled {
  background: var(--green) !important;
  color: #fff !important;
  border-color: var(--green) !important;
}

.sound-toggle:hover {
  transform: translateY(-1px) !important;
}

@media(max-width: 700px) {
  .topbar-actions {
    gap: 6px !important;
  }

  .sound-toggle {
    padding: 10px 11px !important;
  }
}

/* =========================================================
   V39 — Admin : sections repliables
   ========================================================= */

.admin-panel-controls {
  max-width: 1100px !important;
  margin: -4px auto 14px auto !important;
  display: flex !important;
  gap: 10px !important;
  justify-content: center !important;
  flex-wrap: wrap !important;
}

.admin-panel-controls .btn {
  min-width: 150px !important;
}

.admin-collapsible > h2 {
  justify-content: space-between !important;
  flex-wrap: wrap !important;
}

.admin-collapse-toggle {
  margin-left: auto !important;
  border: 1px solid var(--line) !important;
  background: #fff !important;
  color: var(--dark) !important;
  border-radius: 999px !important;
  padding: 7px 11px !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  cursor: pointer !important;
  box-shadow: var(--shadow-soft) !important;
}

.admin-collapse-toggle:hover {
  background: var(--green) !important;
  color: #fff !important;
}

.admin-collapsible.collapsed > *:not(h2) {
  display: none !important;
}

.admin-collapsible.collapsed {
  padding-bottom: 16px !important;
}

.admin-collapsible.collapsed > h2 {
  margin-bottom: 0 !important;
}

@media(max-width: 760px) {
  .admin-panel-controls {
    justify-content: stretch !important;
    margin: 0 auto 12px auto !important;
  }

  .admin-panel-controls .btn {
    flex: 1 1 140px !important;
  }

  .admin-collapse-toggle {
    width: 100% !important;
    margin: 8px 0 0 0 !important;
  }
}

/* =========================================================
   V40 — Admin : gestion des sons par section
   ========================================================= */

#admin-sounds {
  scroll-margin-top: 150px !important;
}

#admin-sounds > h2::before {
  content: "🔊";
}

.sound-admin-form {
  display: grid !important;
  gap: 16px !important;
}

.sound-admin-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)) !important;
  gap: 14px !important;
}

.sound-admin-card {
  background: #fff !important;
  border: 1px solid var(--line) !important;
  border-radius: 18px !important;
  padding: 16px !important;
  box-shadow: var(--shadow-soft) !important;
}

.sound-admin-card h3 {
  margin: 0 0 8px !important;
  color: var(--green) !important;
}

.sound-admin-card audio {
  width: 100% !important;
  margin: 8px 0 !important;
}

.sound-admin-card input[type="file"] {
  width: 100% !important;
  margin-top: 8px !important;
}

@media(max-width: 760px) {
  #admin-sounds {
    scroll-margin-top: 145px !important;
  }
}

/* =========================================================
   V41 — Accueil : cartes enrichies
   ========================================================= */

.home-intro-panel {
  display: grid !important;
  grid-template-columns: 1fr auto !important;
  align-items: center !important;
  gap: 16px !important;
  margin-top: 18px !important;
  background:
    radial-gradient(circle at top left, rgba(110,143,61,.16), transparent 42%),
    var(--paper) !important;
}

.home-intro-panel h2 {
  margin: 4px 0 6px !important;
  color: var(--green) !important;
}

.home-intro-panel p {
  margin: 0 !important;
  color: #4b5848 !important;
}

.home-kicker {
  display: inline-flex !important;
  color: #66715c !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
}

.home-module-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 16px !important;
  margin: 18px 0 !important;
}

.home-card {
  position: relative !important;
  min-height: 260px !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
  background: #fff !important;
  border: 1px solid var(--line) !important;
  border-radius: 26px !important;
  box-shadow: var(--shadow-soft) !important;
  text-decoration: none !important;
  color: var(--dark) !important;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease !important;
}

.home-card:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 18px 44px rgba(24,53,31,.18) !important;
  border-color: rgba(47,93,47,.34) !important;
}

.home-card img {
  width: 100% !important;
  height: 140px !important;
  object-fit: cover !important;
  display: block !important;
}

.home-card-large {
  grid-column: span 2 !important;
  min-height: 300px !important;
}

.home-card-large img {
  height: 178px !important;
}

.home-card-body {
  padding: 16px !important;
  display: grid !important;
  gap: 6px !important;
  flex: 1 !important;
}

.home-card-tag {
  justify-self: start !important;
  display: inline-flex !important;
  align-items: center !important;
  padding: 5px 9px !important;
  border-radius: 999px !important;
  background: #e4f4d8 !important;
  color: var(--green) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
}

.home-card h2 {
  margin: 2px 0 0 !important;
  color: var(--dark) !important;
}

.home-card p {
  margin: 0 !important;
  color: #4b5848 !important;
  line-height: 1.35 !important;
}

.home-card strong {
  margin-top: 4px !important;
  color: var(--green) !important;
}

.home-howto {
  margin-bottom: 18px !important;
}

.home-steps {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 14px !important;
  margin-top: 12px !important;
}

.home-steps div {
  background: #fff !important;
  border: 1px solid var(--line) !important;
  border-radius: 20px !important;
  padding: 16px !important;
  box-shadow: var(--shadow-soft) !important;
}

.home-steps span {
  width: 36px !important;
  height: 36px !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 999px !important;
  background: var(--green) !important;
  color: #fff !important;
  font-weight: 900 !important;
  margin-bottom: 10px !important;
}

.home-steps strong {
  display: block !important;
  color: var(--dark) !important;
  margin-bottom: 5px !important;
}

.home-steps p {
  margin: 0 !important;
  color: #4b5848 !important;
}

@media(max-width: 980px) {
  .home-module-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .home-card-large {
    grid-column: span 1 !important;
  }

  .home-card-large img {
    height: 140px !important;
  }
}

@media(max-width: 700px) {
  .home-intro-panel {
    grid-template-columns: 1fr !important;
    text-align: center !important;
  }

  .home-intro-panel .btn {
    width: 100% !important;
  }

  .home-module-grid,
  .home-steps {
    grid-template-columns: 1fr !important;
  }

  .home-card {
    min-height: auto !important;
  }

  .home-card img,
  .home-card-large img {
    height: 150px !important;
  }
}

/* =========================================================
   V42 — Correctif proportions cartes d'accueil
   ========================================================= */

/* Les images des cartes d'accueil étaient trop hautes sur grand écran.
   On réduit la hauteur et on donne plus d'espace au texte. */

.home-module-grid {
  align-items: stretch !important;
}

.home-card {
  min-height: 235px !important;
}

.home-card img {
  height: 110px !important;
  object-fit: cover !important;
  object-position: center !important;
}

.home-card-large {
  min-height: 260px !important;
}

.home-card-large img {
  height: 120px !important;
}

.home-card-body {
  padding: 14px 16px 16px !important;
}

.home-card h2 {
  font-size: 24px !important;
  line-height: 1.08 !important;
}

.home-card p {
  font-size: 15px !important;
}

@media(max-width: 980px) {
  .home-card,
  .home-card-large {
    min-height: auto !important;
  }

  .home-card img,
  .home-card-large img {
    height: 125px !important;
  }
}

@media(max-width: 700px) {
  .home-card img,
  .home-card-large img {
    height: 135px !important;
  }

  .home-card h2 {
    font-size: 26px !important;
  }
}


/* =========================================================
   V43 — Image distincte pour Classement
   ========================================================= */

/* La carte Classement utilise maintenant 11_carte_classement_puzzle.png
   afin d’éviter la confusion avec la carte Passeport. */

/* =========================================================
   V44 — Admin : cartes d’accueil et images d’entête
   ========================================================= */

.page-head {
  background:
    linear-gradient(90deg,rgba(255,250,241,.94),rgba(255,250,241,.78)),
    var(--page-head-bg, url('/static/img/05_banniere_secondaire_pages_internes.png')) !important;
  background-size: cover !important;
  background-position: center !important;
}

#admin-home-cards,
#admin-headers {
  scroll-margin-top: 150px !important;
}

#admin-home-cards > h2::before { content: "🏠"; }
#admin-headers > h2::before { content: "🖼️"; }

.home-cards-admin-form,
.headers-admin-form {
  display: grid !important;
  gap: 16px !important;
}

.home-cards-admin-grid,
.headers-admin-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)) !important;
  gap: 14px !important;
}

.home-card-admin-card,
.header-admin-card {
  background: #fff !important;
  border: 1px solid var(--line) !important;
  border-radius: 18px !important;
  padding: 16px !important;
  box-shadow: var(--shadow-soft) !important;
  display: grid !important;
  gap: 9px !important;
}

.home-card-admin-card h3,
.header-admin-card h3 {
  margin: 2px 0 !important;
  color: var(--green) !important;
}

.home-card-admin-card textarea {
  min-height: 90px !important;
}

.header-admin-preview {
  width: 100% !important;
  aspect-ratio: 4 / 1 !important;
  border-radius: 14px !important;
  overflow: hidden !important;
  border: 1px solid var(--line) !important;
  background: #f6efe4 !important;
}

.header-admin-preview img,
.home-card-admin-card .admin-preview img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}

.home-card-admin-card input[type="file"],
.header-admin-card input[type="file"] {
  width: 100% !important;
}

@media(max-width: 760px) {
  #admin-home-cards,
  #admin-headers {
    scroll-margin-top: 145px !important;
  }
}

/* =========================================================
   V45 — Galerie : partage Facebook
   ========================================================= */

.photo-card-image-link {
  display: block !important;
  color: inherit !important;
  text-decoration: none !important;
}

.photo-share-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  margin-top: 12px !important;
}

.photo-share-page {
  display: grid !important;
  grid-template-columns: 1.25fr .85fr !important;
  gap: 18px !important;
  align-items: start !important;
}

.photo-share-main-img {
  width: 100% !important;
  max-height: 680px !important;
  object-fit: contain !important;
  border-radius: 22px !important;
  background: #fff !important;
  border: 1px solid var(--line) !important;
  box-shadow: var(--shadow-soft) !important;
}

.photo-share-details {
  background: #fff !important;
  border: 1px solid var(--line) !important;
  border-radius: 22px !important;
  padding: 18px !important;
  box-shadow: var(--shadow-soft) !important;
}

.photo-share-details h2 {
  margin: 10px 0 4px !important;
  color: var(--green) !important;
}

.photo-share-details small {
  display: block !important;
  color: #66715c !important;
  margin-bottom: 12px !important;
}

@media(max-width: 820px) {
  .photo-share-page {
    grid-template-columns: 1fr !important;
  }

  .photo-share-actions .btn {
    width: 100% !important;
  }
}


/* =========================================================
   V46 — Galerie : Open Graph Facebook renforcé
   ========================================================= */

/* Les pages individuelles de photos utilisent maintenant des URL HTTPS
   forcées, og:image:secure_url, og:image:width et og:image:height. */


/* =========================================================
   V47 — Facebook preview image 1200x630
   ========================================================= */

/* Les pages de partage Facebook utilisent une image Open Graph
   générée en 1200x630 dans static/uploads/facebook/. */



/* =========================================================
   V48 — Entêtes personnalisées sans voile ni texte superposé
   Format conseillé : 2048 x 512 px, ratio 4:1.
   ========================================================= */

.module-header-image {
  width: 100% !important;
  max-width: 1180px !important;
  margin: 12px auto 22px auto !important;
  padding: 0 !important;
  border-radius: 28px !important;
  overflow: hidden !important;
  box-shadow: var(--shadow-soft) !important;
  border: 1px solid var(--line) !important;
  background: transparent !important;
}

.module-header-image img {
  width: 100% !important;
  height: auto !important;
  display: block !important;
  filter: none !important;
  opacity: 1 !important;
}

@media(max-width: 700px) {
  .module-header-image {
    max-width: calc(100vw - 28px) !important;
    margin: 12px auto 16px auto !important;
    border-radius: 22px !important;
  }
}

/* =========================================================
   V49 — Texte optionnel sous les bandeaux d’entête
   ========================================================= */

.module-intro-text {
  width: 100% !important;
  max-width: 1180px !important;
  margin: -8px auto 24px auto !important;
  padding: 18px 22px !important;
  border-radius: 22px !important;
  border: 1px solid var(--line) !important;
  background: rgba(255, 250, 241, .94) !important;
  box-shadow: var(--shadow-soft) !important;
  color: #243523 !important;
  font-size: clamp(1rem, 1.15vw, 1.12rem) !important;
  line-height: 1.65 !important;
  white-space: pre-line !important;
}

.header-textarea-label {
  display: grid !important;
  gap: 6px !important;
  font-weight: 700 !important;
  color: #2f5e2f !important;
}

.header-textarea-label textarea {
  width: 100% !important;
  min-height: 150px !important;
  resize: vertical !important;
  font-size: 15px !important;
  line-height: 1.45 !important;
}

@media(max-width: 700px) {
  .module-intro-text {
    max-width: calc(100vw - 28px) !important;
    margin: -4px auto 18px auto !important;
    padding: 15px 16px !important;
    border-radius: 18px !important;
    font-size: 1rem !important;
    line-height: 1.58 !important;
  }
}


/* =========================================================
   V50 — Autonomie admin / modules visibles
   ========================================================= */

.home-season-label {
  display: inline-flex !important;
  align-items: center !important;
  width: fit-content !important;
  margin-bottom: 10px !important;
  padding: 7px 12px !important;
  border-radius: 999px !important;
  background: rgba(255, 250, 241, .90) !important;
  color: var(--dark) !important;
  font-weight: 800 !important;
  font-size: 13px !important;
  letter-spacing: .02em !important;
  box-shadow: 0 5px 16px rgba(0,0,0,.12) !important;
}

.season-message {
  white-space: pre-line !important;
  font-size: clamp(1rem, 1.1vw, 1.12rem) !important;
  line-height: 1.62 !important;
  margin: 18px 0 !important;
  border-left: 5px solid var(--green) !important;
}

.module-admin-grid {
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)) !important;
}

.module-admin-card {
  position: relative !important;
}

.module-admin-card.module-disabled {
  opacity: .70 !important;
  background: #f3f0ea !important;
}

.module-main-toggle {
  border: 1px solid rgba(47, 93, 47, .22) !important;
  background: #eef5e6 !important;
  padding: 10px 12px !important;
  border-radius: 14px !important;
  font-weight: 800 !important;
}

#admin-settings label,
.module-admin-card label {
  display: grid !important;
  gap: 6px !important;
  color: #2d3f2b !important;
  font-weight: 700 !important;
}

#admin-settings select,
#admin-settings input,
#admin-settings textarea,
.module-admin-card input,
.module-admin-card textarea {
  font-weight: 500 !important;
}

@media(max-width: 700px) {
  .bottom-nav a {
    font-size: 17px !important;
    padding: 9px 2px !important;
  }
  .bottom-nav span {
    font-size: 10px !important;
    line-height: 1.05 !important;
  }
  .season-message {
    margin: 14px 0 !important;
    padding: 16px !important;
  }
}


/* =========================================================
   V52 — Admin : configuration du bloc Comment ça fonctionne
   ========================================================= */

.defis-howto-admin-form .full-label {
  display: block !important;
  margin-bottom: 16px !important;
}

.defis-howto-admin-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)) !important;
  gap: 16px !important;
  margin: 14px 0 18px !important;
}

.defis-howto-admin-card {
  background: #fff !important;
  border: 1px solid var(--line) !important;
  border-radius: 20px !important;
  padding: 14px !important;
  box-shadow: var(--shadow-soft) !important;
}

.defis-howto-admin-card h3 {
  margin: 0 0 10px !important;
  color: var(--green) !important;
}

.admin-howto-preview {
  margin-bottom: 12px !important;
}

.color-admin-row {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 10px !important;
  align-items: end !important;
}

.color-admin-row label {
  font-size: 13px !important;
}

.color-admin-row input[type="color"] {
  width: 100% !important;
  height: 42px !important;
  padding: 3px !important;
}

@media(max-width: 760px) {
  .color-admin-row {
    grid-template-columns: 1fr !important;
  }
}

/* =========================================================
   V53 — Sécurité, stabilité et pages d'erreur
   ========================================================= */
.security-checklist {
  display: grid !important;
  gap: 8px !important;
  margin-top: 14px !important;
  padding: 14px !important;
  border: 1px solid rgba(47, 93, 47, .18) !important;
  border-radius: 18px !important;
  background: rgba(238, 245, 230, .75) !important;
  color: var(--green) !important;
  font-weight: 700 !important;
}

.admin-audit-table-wrap {
  overflow-x: auto !important;
  border: 1px solid var(--line) !important;
  border-radius: 18px !important;
  background: #fff !important;
}

.admin-audit-table {
  width: 100% !important;
  border-collapse: collapse !important;
  min-width: 760px !important;
}

.admin-audit-table th,
.admin-audit-table td {
  padding: 10px 12px !important;
  border-bottom: 1px solid rgba(47, 93, 47, .12) !important;
  text-align: left !important;
  vertical-align: top !important;
  font-size: 14px !important;
}

.admin-audit-table th {
  color: var(--green) !important;
  background: rgba(238, 245, 230, .65) !important;
}

.error-card {
  max-width: 760px !important;
  margin: 44px auto !important;
  padding: 34px !important;
  border: 1px solid var(--line) !important;
  border-radius: 28px !important;
  background: var(--cream) !important;
  box-shadow: var(--shadow-soft) !important;
  text-align: center !important;
}

.error-card strong {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 72px !important;
  height: 72px !important;
  border-radius: 999px !important;
  background: var(--green) !important;
  color: #fff !important;
  font-size: 24px !important;
  margin-bottom: 16px !important;
}

.error-card h1 {
  margin: 0 0 10px !important;
  color: var(--green) !important;
}

.app-version-footer {
  max-width: 1180px !important;
  margin: 0 auto 82px !important;
  padding: 0 18px !important;
  text-align: right !important;
  font-size: 12px !important;
  color: rgba(33, 49, 31, .58) !important;
}

@media(max-width: 760px) {
  .error-card {
    margin: 22px 12px !important;
    padding: 24px 18px !important;
  }
  .app-version-footer {
    text-align: center !important;
    margin-bottom: 76px !important;
  }
}

/* =========================================================
   V54 — Sauvegardes et journal admin
   ========================================================= */
.backup-status-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)) !important;
  gap: 14px !important;
  margin: 16px 0 !important;
}

.backup-status-card {
  display: grid !important;
  gap: 6px !important;
  padding: 16px !important;
  border: 1px solid rgba(47, 93, 47, .16) !important;
  border-radius: 18px !important;
  background: rgba(255, 255, 255, .88) !important;
  box-shadow: var(--shadow-soft) !important;
}

.backup-status-card strong {
  color: var(--green) !important;
  font-size: 14px !important;
}

.backup-status-card span {
  font-size: 18px !important;
  font-weight: 800 !important;
  color: var(--dark) !important;
}

.backup-status-card small,
.backup-status-card code {
  overflow-wrap: anywhere !important;
  color: rgba(33, 49, 31, .74) !important;
  font-size: 12px !important;
}

.backup-actions-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 12px !important;
  align-items: center !important;
  margin: 16px 0 !important;
}

.backup-actions-row form {
  margin: 0 !important;
}

.audit-actions-row {
  justify-content: space-between !important;
}

.audit-clean-label {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  margin-right: 8px !important;
  font-weight: 700 !important;
  color: var(--dark) !important;
}

.audit-clean-label input {
  width: 90px !important;
}

.admin-warning {
  padding: 12px 14px !important;
  border: 1px solid rgba(150, 73, 0, .22) !important;
  border-radius: 14px !important;
  background: #fff3df !important;
  color: #7d3d00 !important;
  font-weight: 700 !important;
}

@media(max-width: 760px) {
  .backup-actions-row,
  .audit-actions-row,
  .audit-actions-row form,
  .audit-clean-label {
    display: grid !important;
    width: 100% !important;
  }
  .backup-actions-row .btn,
  .audit-actions-row .btn {
    width: 100% !important;
    justify-content: center !important;
  }
}

/* =========================================================
   V55 — Interface admin en panneaux internes
   ========================================================= */
.admin-panel-menu {
  max-width: 1120px !important;
  margin: 18px auto !important;
  padding: 22px !important;
  border: 1px solid var(--line) !important;
  border-radius: 28px !important;
  background: rgba(255, 248, 236, .96) !important;
  box-shadow: var(--shadow-soft) !important;
}

.admin-panel-menu.is-hidden {
  display: none !important;
}

.admin-menu-head {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 18px !important;
  margin-bottom: 18px !important;
}

.admin-menu-head h1 {
  margin: 0 0 6px !important;
  color: var(--green) !important;
  font-size: clamp(28px, 4vw, 42px) !important;
  line-height: 1.05 !important;
}

.admin-menu-head p:not(.eyebrow) {
  margin: 0 !important;
  max-width: 760px !important;
  color: rgba(33, 49, 31, .78) !important;
  font-size: 16px !important;
}

.admin-logout-shortcut {
  flex: 0 0 auto !important;
}

.admin-menu-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)) !important;
  gap: 14px !important;
}

.admin-menu-card {
  display: grid !important;
  grid-template-columns: auto 1fr !important;
  grid-template-areas: "icon title" "icon text" !important;
  align-items: center !important;
  column-gap: 12px !important;
  row-gap: 3px !important;
  padding: 16px !important;
  min-height: 94px !important;
  color: var(--dark) !important;
  text-decoration: none !important;
  border: 1px solid rgba(47, 93, 47, .16) !important;
  border-radius: 20px !important;
  background: rgba(255, 255, 255, .92) !important;
  box-shadow: 0 12px 28px rgba(31, 51, 28, .08) !important;
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease !important;
}

.admin-menu-card:hover,
.admin-menu-card:focus-visible {
  transform: translateY(-2px) !important;
  border-color: rgba(47, 93, 47, .34) !important;
  box-shadow: 0 18px 36px rgba(31, 51, 28, .12) !important;
  outline: none !important;
}

.admin-menu-card span {
  grid-area: icon !important;
  display: inline-flex !important;
  width: 44px !important;
  height: 44px !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 16px !important;
  background: rgba(47, 93, 47, .10) !important;
  font-size: 24px !important;
}

.admin-menu-card strong {
  grid-area: title !important;
  color: var(--green) !important;
  font-size: 16px !important;
  line-height: 1.15 !important;
}

.admin-menu-card small {
  grid-area: text !important;
  color: rgba(33, 49, 31, .70) !important;
  line-height: 1.25 !important;
  font-size: 13px !important;
}

.admin-panel-screen {
  display: none !important;
}

.admin-panel-screen.is-active {
  display: block !important;
  width: min(1120px, calc(100vw - 32px)) !important;
  max-width: 1120px !important;
  max-height: calc(100vh - 150px) !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  margin: 18px auto !important;
  padding: 22px !important;
  scroll-margin-top: 92px !important;
}

.admin-grid {
  max-width: 1120px !important;
}

.admin-panel-open .admin-grid {
  display: block !important;
  max-width: 1120px !important;
  margin: 0 auto !important;
}

.admin-panel-toolbar {
  position: sticky !important;
  top: -22px !important;
  z-index: 5 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  margin: -22px -22px 18px !important;
  padding: 12px 16px !important;
  border-bottom: 1px solid var(--line) !important;
  border-radius: 24px 24px 0 0 !important;
  background: rgba(255, 248, 236, .98) !important;
  box-shadow: 0 10px 24px rgba(31, 51, 28, .08) !important;
  backdrop-filter: blur(8px) !important;
}

.admin-panel-toolbar span {
  color: var(--green) !important;
  font-weight: 900 !important;
  text-align: right !important;
}

.admin-return-menu {
  flex: 0 0 auto !important;
}

.admin-back-top-legacy {
  display: none !important;
}

@media(max-width: 820px) {
  .admin-panel-menu {
    width: calc(100vw - 24px) !important;
    margin: 12px auto !important;
    padding: 16px !important;
    border-radius: 22px !important;
  }
  .admin-menu-head {
    display: grid !important;
  }
  .admin-logout-shortcut {
    width: 100% !important;
    justify-content: center !important;
  }
  .admin-menu-grid {
    grid-template-columns: 1fr !important;
  }
  .admin-panel-screen.is-active {
    width: calc(100vw - 20px) !important;
    max-height: calc(100vh - 120px) !important;
    padding: 16px !important;
    border-radius: 22px !important;
  }
  .admin-panel-toolbar {
    top: -16px !important;
    margin: -16px -16px 16px !important;
    border-radius: 22px 22px 0 0 !important;
    display: grid !important;
  }
  .admin-panel-toolbar span {
    text-align: left !important;
  }
  .admin-return-menu {
    width: 100% !important;
    justify-content: center !important;
  }
}


/* =========================================================
   V55B — Cartes d’accueil configurables
   ========================================================= */
.admin-format-note {
  display: grid !important;
  gap: 5px !important;
  padding: 14px 16px !important;
  border: 1px solid rgba(47, 93, 47, .22) !important;
  border-radius: 18px !important;
  background: #eef5e6 !important;
  color: #21311f !important;
  margin: 8px 0 6px !important;
}

.admin-format-note strong {
  color: var(--green) !important;
}

.admin-format-note span,
.admin-format-note small {
  line-height: 1.45 !important;
}

.home-card-admin-card .home-card-admin-preview {
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 2 / 1 !important;
  border-radius: 16px !important;
  background: #f6efe4 !important;
  border: 1px solid var(--line) !important;
  display: block !important;
  overflow: hidden !important;
}

.home-card-admin-card .home-card-admin-preview img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}

.home-card-admin-card input[maxlength="45"] {
  font-weight: 700 !important;
}

@media(max-width: 760px) {
  .admin-format-note {
    padding: 12px !important;
  }
}


/* V56F — Bingo Nature affiche parchemin fidèle, avec zones interactives superposées.
   Objectif : rendu proche de la maquette proposée, sans surcharge Python et sans débordement mobile. */
.sr-only{
  position:absolute!important;
  width:1px!important;
  height:1px!important;
  padding:0!important;
  margin:-1px!important;
  overflow:hidden!important;
  clip:rect(0,0,0,0)!important;
  white-space:nowrap!important;
  border:0!important;
}
.bingo-reference-stage{
  width:100%;
  max-width:100%;
  overflow:hidden;
  margin:0 auto 20px;
  padding:18px 0;
  border-radius:28px;
  background:
    radial-gradient(circle at 50% 0%, rgba(255,236,181,.14), transparent 32%),
    linear-gradient(180deg,#1b1009,#0d0805 62%,#1a0f08);
  box-shadow:0 20px 55px rgba(0,0,0,.22);
}
.bingo-reference-shell{
  width:min(100%, 920px);
  max-width:100%;
  margin:0 auto;
  padding:0 clamp(8px, 2.2vw, 18px);
}
.bingo-reference-poster{
  position:relative;
  width:100%;
  max-width:900px;
  aspect-ratio:2 / 3;
  margin:0 auto;
  overflow:hidden;
  border-radius:14px;
  background-image:url('/static/img/bingo_poster_reference_v56f.webp');
  background-repeat:no-repeat;
  background-position:center;
  background-size:contain;
  filter:drop-shadow(0 18px 26px rgba(0,0,0,.28));
  isolation:isolate;
}
.bingo-reference-count{
  position:absolute;
  left:42%;
  top:21.2%;
  width:17%;
  height:4.7%;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:4;
  border-radius:999px;
  background:rgba(67,38,24,.95);
  box-shadow:0 1px 0 rgba(255,255,255,.14) inset;
  color:#fff7e9;
  text-shadow:0 2px 3px rgba(0,0,0,.4);
  pointer-events:none;
}
.bingo-reference-count strong{
  display:block;
  font-size:clamp(18px, 4.1vw, 38px);
  line-height:1;
  letter-spacing:.04em;
}
.bingo-reference-count progress{display:none!important;}
.bingo-reference-hotspot{
  position:absolute;
  left:var(--x);
  top:var(--y);
  width:var(--w);
  height:var(--h);
  z-index:3;
  display:block;
  min-height:0!important;
  padding:0!important;
  margin:0!important;
  border:0!important;
  border-radius:10px!important;
  background:transparent!important;
  box-shadow:none!important;
  cursor:pointer;
  -webkit-tap-highlight-color:rgba(47,93,47,.18);
  touch-action:manipulation;
}
.bingo-reference-hotspot:focus-visible{
  outline:3px solid rgba(255,255,255,.9);
  outline-offset:-6px;
  box-shadow:0 0 0 5px rgba(47,93,47,.55)!important;
}
.bingo-reference-hotspot::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:12px;
  opacity:0;
  background:rgba(255,255,255,.10);
  transition:opacity .16s ease;
}
.bingo-reference-hotspot:hover::after,
.bingo-reference-hotspot:focus-visible::after{opacity:1;}
.bingo-reference-tick{
  position:absolute;
  left:5.4%;
  bottom:9%;
  width:15.8%;
  aspect-ratio:1;
  z-index:5;
  display:flex!important;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  border:clamp(1px, .28vw, 3px) solid #214a20;
  background:linear-gradient(180deg,#f4ffe8,#d9f0c4);
  color:#214a20;
  font-size:clamp(14px, 4.4vw, 42px)!important;
  font-weight:900;
  line-height:1;
  opacity:0;
  transform:scale(.72) rotate(-8deg);
  box-shadow:0 3px 10px rgba(0,0,0,.28);
  transition:opacity .18s ease, transform .18s ease;
}
.bingo-reference-hotspot.checked .bingo-reference-tick{
  opacity:1;
  transform:scale(1) rotate(-8deg);
}
.bingo-reference-hotspot.checked::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:12px;
  background:rgba(47,93,47,.10);
  box-shadow:inset 0 0 0 3px rgba(47,93,47,.32);
}
.bingo-reference-feedback{
  position:absolute;
  left:22%;
  right:23%;
  bottom:3.2%;
  z-index:4;
  margin:0;
  padding:.45em .7em;
  border-radius:999px;
  background:rgba(255,248,226,.88);
  color:#3c2415;
  font-weight:800;
  text-align:center;
  font-size:clamp(10px, 1.65vw, 16px);
  line-height:1.2;
  box-shadow:0 3px 10px rgba(0,0,0,.18);
}
.bingo-reference-feedback.is-good{
  background:rgba(226,244,205,.92);
  color:#18351f;
}
.bingo-reference-feedback.pop{animation:bingoFeedbackPop .32s ease;}
@keyframes bingoFeedbackPop{
  0%{transform:scale(.96);}
  55%{transform:scale(1.025);}
  100%{transform:scale(1);}
}
.bingo-note-panel{margin-top:18px;}
@media(max-width:720px){
  .page:has(.bingo-reference-stage){padding-left:8px;padding-right:8px;}
  .bingo-reference-stage{
    margin-left:calc(-1 * max(0px, env(safe-area-inset-left)));
    margin-right:calc(-1 * max(0px, env(safe-area-inset-right)));
    padding:10px 0 12px;
    border-radius:20px;
  }
  .bingo-reference-shell{padding:0 4px;}
  .bingo-reference-poster{
    width:100%;
    max-width:100%;
    border-radius:10px;
  }
  .bingo-reference-count{
    left:41.8%;
    top:21.1%;
    width:17.8%;
  }
  .bingo-reference-count strong{font-size:clamp(13px, 5vw, 24px);}
  .bingo-reference-feedback{
    left:18%;
    right:18%;
    bottom:3.1%;
    font-size:clamp(8px, 2.6vw, 12px);
    padding:.35em .55em;
  }
}
@media(max-width:420px){
  .page:has(.bingo-reference-stage){padding-left:4px;padding-right:4px;}
  .bingo-reference-stage{border-radius:14px;}
  .bingo-reference-count strong{font-size:clamp(12px, 5.8vw, 20px);}
  .bingo-reference-feedback{font-size:clamp(7px, 2.8vw, 10px);}
}
@supports not selector(:has(*)){
  @media(max-width:720px){.page{overflow-x:hidden;}}
}

/* V57A — Mode forêt / hors ligne de base */
.offline-status-btn{
  border:0;
  min-width:48px;
  min-height:48px;
  border-radius:16px;
  background:#2f6b37;
  color:#fff;
  font-size:1.25rem;
  font-weight:900;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 10px 24px rgba(47,107,55,.18);
  cursor:pointer;
}
.offline-status-btn.is-offline{
  background:#8a5a21;
}
.offline-status-btn.has-pending{
  outline:3px solid rgba(255,196,80,.75);
}
.offline-modal[hidden]{display:none!important;}
.offline-modal{
  position:fixed;
  inset:0;
  z-index:1200;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
  background:rgba(20,35,22,.46);
  backdrop-filter:blur(4px);
}
.offline-modal-card{
  width:min(760px, 100%);
  max-height:min(86vh, 780px);
  overflow:auto;
  background:#fff8ec;
  border:1px solid rgba(91,65,29,.22);
  border-radius:28px;
  box-shadow:0 26px 70px rgba(19,38,22,.28);
  padding:24px;
  color:#1d321f;
}
.offline-modal-head{
  display:flex;
  gap:14px;
  justify-content:space-between;
  align-items:flex-start;
  margin-bottom:16px;
}
.offline-modal-head h2{
  margin:0 0 6px;
  font-size:clamp(1.45rem, 4vw, 2rem);
}
.offline-modal-head p{
  margin:0;
  color:#536453;
  line-height:1.45;
}
.offline-modal-close{
  border:0;
  width:42px;
  height:42px;
  flex:0 0 auto;
  border-radius:14px;
  background:#fff;
  color:#1d321f;
  font-size:1.8rem;
  line-height:1;
  cursor:pointer;
  box-shadow:0 6px 16px rgba(25,40,20,.12);
}
.offline-status-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:12px;
  margin:16px 0;
}
.offline-status-grid div{
  background:#fff;
  border:1px solid rgba(91,65,29,.18);
  border-radius:18px;
  padding:14px;
}
.offline-status-grid strong{
  display:block;
  font-size:1.12rem;
  color:#1d321f;
}
.offline-status-grid span{
  display:block;
  margin-top:4px;
  font-size:.88rem;
  color:#61715d;
}
.offline-progress-wrap{
  margin:16px 0;
  background:#fff;
  border:1px solid rgba(91,65,29,.16);
  border-radius:18px;
  padding:14px;
}
.offline-progress-wrap progress{
  width:100%;
  height:14px;
}
.offline-progress-wrap small{
  display:block;
  margin-top:8px;
  color:#536453;
}
.offline-actions,
.home-intro-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  align-items:center;
}
.offline-gallery-option{
  display:flex;
  gap:10px;
  align-items:flex-start;
  margin:16px 0 10px;
  padding:14px;
  background:#fff;
  border:1px solid rgba(91,65,29,.16);
  border-radius:18px;
  line-height:1.35;
}
.offline-gallery-option input{
  width:22px;
  height:22px;
  margin-top:1px;
  flex:0 0 auto;
}
@media(max-width:700px){
  .offline-status-btn{
    min-width:42px;
    min-height:42px;
    border-radius:14px;
    font-size:1.08rem;
  }
  .offline-modal{
    align-items:flex-end;
    padding:10px;
  }
  .offline-modal-card{
    max-height:88vh;
    border-radius:24px 24px 18px 18px;
    padding:18px;
  }
  .offline-status-grid{
    grid-template-columns:1fr;
  }
  .offline-actions,
  .home-intro-actions{
    flex-direction:column;
    align-items:stretch;
    width:100%;
  }
  .offline-actions .btn,
  .home-intro-actions .btn,
  .home-intro-actions button{
    width:100%;
    justify-content:center;
  }
}
@media(max-width:430px){
  .topbar-actions{
    gap:6px;
  }
  .offline-status-btn{
    min-width:38px;
    min-height:38px;
    border-radius:13px;
    font-size:1rem;
  }
}


/* V57B — Synchronisation avancée hors ligne */
.offline-file-queue{
  margin:16px 0;
  padding:14px;
  border-radius:18px;
  background:#fff;
  border:1px solid rgba(91,65,29,.16);
}
.offline-file-queue h3{
  margin:0 0 10px;
  color:#1d321f;
  font-size:1.08rem;
}
.offline-file-queue-item{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:10px 0;
  border-top:1px solid rgba(91,65,29,.12);
}
.offline-file-queue-item:first-child{border-top:0;}
.offline-file-queue-item strong,
.offline-file-queue-item small{display:block;}
.offline-file-queue-item small{margin-top:3px;color:#61715d;line-height:1.35;}
.btn.compact{min-height:34px;padding:.45rem .7rem;font-size:.86rem;}
@media(max-width:700px){
  .offline-file-queue-item{align-items:flex-start;flex-direction:column;}
  .offline-file-queue-item .btn{width:100%;justify-content:center;}
}


/* V57B2 — avis des formulaires hors ligne avancés */
.offline-form-notice {
  border: 1px solid rgba(63,111,31,.25);
  background: rgba(63,111,31,.08);
  color: #17351d;
  border-radius: 18px;
  padding: 12px 14px;
  font-weight: 700;
  line-height: 1.35;
  margin-bottom: 12px;
}
.offline-form-notice.success {
  background: rgba(63,111,31,.10);
}
.offline-form-notice.error {
  border-color: rgba(160,50,35,.35);
  background: rgba(160,50,35,.08);
  color: #5c1f17;
}


/* V57B3 — progression visible lors de la synchronisation manuelle */
.offline-progress-wrap small {
  display: block;
  margin-top: 0.45rem;
  font-weight: 700;
}
#syncNowBtn:disabled,
#prepareOfflineBtn:disabled {
  opacity: 0.72;
  cursor: wait;
}

/* V58B — Bingo responsive : papyrus original conservé sur mobile */
.bingo-desktop-layout{display:block;}
.bingo-mobile-layout{display:none;}
.bingo-mobile-papyrus{
  position:relative;
  width:min(100%, 760px);
  margin:0 auto;
  padding:clamp(12px, 3.2vw, 22px);
  border-radius:30px;
  border:8px solid rgba(27,14,8,.96);
  background:
    linear-gradient(180deg,rgba(23,12,7,.98),rgba(13,7,4,.98));
  box-shadow:0 18px 36px rgba(25,12,5,.30), inset 0 0 0 2px rgba(255,248,222,.12);
  overflow:hidden;
}
.bingo-mobile-original-header{
  position:relative;
  display:block;
  width:100%;
  overflow:hidden;
  border-radius:20px 20px 12px 12px;
  background:#2d160c;
  box-shadow:0 8px 18px rgba(22,10,4,.28);
}
.bingo-mobile-original-header img{
  display:block;
  width:100%;
  height:auto;
  object-fit:cover;
}
.bingo-mobile-progress-overlay{
  position:absolute;
  left:50%;
  bottom:6.5%;
  transform:translateX(-50%);
  z-index:2;
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0;
  pointer-events:none;
}
.bingo-mobile-progress-overlay strong{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:clamp(30px, 7vw, 42px);
  min-width:clamp(92px, 24vw, 136px);
  padding:0 .75rem;
  border-radius:999px;
  color:#fff7e9;
  background:rgba(86,51,31,.96);
  font-size:clamp(19px, 6vw, 34px);
  font-weight:950;
  line-height:1;
  box-shadow:0 2px 8px rgba(31,16,8,.32), inset 0 1px 0 rgba(255,255,255,.12);
}
.bingo-mobile-progress-overlay progress{display:none!important;}
.bingo-mobile-grid-wrap{
  position:relative;
  margin-top:12px;
  padding:clamp(12px, 3.4vw, 20px);
  border-radius:16px 16px 22px 22px;
  background:
    radial-gradient(circle at 12% 5%, rgba(255,248,214,.42), transparent 26%),
    radial-gradient(circle at 82% 96%, rgba(101,57,28,.16), transparent 30%),
    linear-gradient(180deg,#ead09a 0%, #e4c082 46%, #d2a463 100%);
  box-shadow:inset 0 0 0 1px rgba(106,62,30,.28), inset 0 0 28px rgba(81,42,18,.20);
}
.bingo-mobile-grid-wrap::before{
  content:"";
  position:absolute;
  inset:6px;
  border-radius:12px 12px 18px 18px;
  border:1px solid rgba(97,57,28,.22);
  pointer-events:none;
}
.bingo-mobile-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:14px;
}
.bingo-mobile-card{
  position:relative;
  display:flex;
  flex-direction:column;
  min-height:0!important;
  padding:0!important;
  overflow:hidden;
  border-radius:14px!important;
  border:2px solid rgba(81,45,21,.55)!important;
  background:linear-gradient(180deg,#f8e5b8,#e9c98d)!important;
  box-shadow:0 5px 12px rgba(54,31,14,.22), inset 0 0 0 2px rgba(255,247,218,.35)!important;
  color:#2c1b10!important;
  text-align:left;
  touch-action:manipulation;
}
.bingo-mobile-card-image{
  display:block;
  width:100%;
  aspect-ratio:1.55 / 1;
  overflow:hidden;
  background:#cba66d;
}
.bingo-mobile-card-image img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
}
.bingo-mobile-card-icon{
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:clamp(34px, 10vw, 54px);
  background:radial-gradient(circle at 50% 35%, #fff0c4, #d3a76a);
}
.bingo-mobile-card-text{
  display:grid;
  grid-template-columns:28px 1fr;
  align-items:center;
  gap:7px;
  padding:8px 8px 9px;
  min-height:76px;
}
.bingo-mobile-check{
  grid-row:1 / span 2;
  width:24px;
  height:24px;
  border-radius:50%;
  border:2px solid #4a2d1d;
  background:#fff6dc;
  box-shadow:inset 0 1px 2px rgba(0,0,0,.16);
}
.bingo-mobile-card strong{
  display:block;
  color:#2c1b10;
  font-size:clamp(13px, 2.4vw, 16px);
  line-height:1.08;
  font-weight:950;
}
.bingo-mobile-card .bingo-status{
  display:block;
  color:#5d4b37;
  font-size:11px;
  line-height:1.1;
}
.bingo-mobile-card.checked{
  border-color:#2f6b37!important;
  box-shadow:0 5px 16px rgba(34,78,37,.28), inset 0 0 0 3px rgba(47,107,55,.25)!important;
}
.bingo-mobile-card.checked .bingo-mobile-check{
  border-color:#214a20;
  background:linear-gradient(180deg,#f4ffe8,#cfe9b9);
  position:relative;
}
.bingo-mobile-card.checked .bingo-mobile-check::after{
  content:"✓";
  position:absolute;
  inset:-3px 0 0 0;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#214a20;
  font-size:25px;
  font-weight:950;
}
.bingo-mobile-card.checked .bingo-status{color:#214a20;font-weight:900;}
.bingo-mobile-footer{
  position:relative;
  z-index:1;
  margin:14px auto 0;
  max-width:560px;
  text-align:center;
  font-weight:850;
  font-style:italic;
  color:#f4e3bf;
  font-size:clamp(13px, 3.6vw, 16px);
}
@media(max-width:720px){
  .bingo-responsive-stage{
    background:linear-gradient(180deg,#1b1009,#0d0805 72%,#1a0f08)!important;
    padding:14px 8px!important;
    border-radius:22px!important;
  }
  .bingo-desktop-layout{display:none!important;}
  .bingo-mobile-layout{display:block!important;}
  .bingo-mobile-grid{grid-template-columns:repeat(2, minmax(0, 1fr));gap:12px;}
  .bingo-mobile-papyrus{padding:10px;border-radius:24px;border-width:7px;}
  .bingo-mobile-original-header{border-radius:16px 16px 10px 10px;}
  .bingo-mobile-grid-wrap{margin-top:10px;padding:12px;border-radius:12px 12px 18px 18px;}
  .bingo-mobile-card strong{font-size:clamp(14px, 4.1vw, 18px);}
  .bingo-mobile-card .bingo-status{font-size:clamp(10px, 3.2vw, 13px);}
  .bingo-mobile-card-text{min-height:86px;padding:8px 7px 10px;}
  .bingo-note-panel h2{font-size:clamp(28px, 8vw, 40px);}
  .bingo-note-panel p{font-size:clamp(18px, 5vw, 24px);}
}
@media(min-width:721px){
  .bingo-mobile-layout{display:none!important;}
  .bingo-desktop-layout{display:block!important;}
}
@media(max-width:380px){
  .bingo-mobile-grid{gap:10px;}
  .bingo-mobile-papyrus{padding:8px;border-width:6px;}
  .bingo-mobile-grid-wrap{padding:10px;}
  .bingo-mobile-card-text{grid-template-columns:24px 1fr;gap:6px;}
  .bingo-mobile-check{width:21px;height:21px;}
  .bingo-mobile-card strong{font-size:clamp(12px, 3.7vw, 16px);}
}


/* =========================================================
   V59A — Sons et ambiances MP3 administrables
   ========================================================= */
.sound-format-note {
  margin-bottom: 6px !important;
}

.ambient-admin-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)) !important;
  gap: 14px !important;
}

.ambient-admin-card label:not(.mini-check) {
  display: grid !important;
  gap: 6px !important;
  color: var(--dark) !important;
  font-weight: 700 !important;
}

.ambient-admin-card input[type="range"] {
  width: 100% !important;
  accent-color: var(--green) !important;
}

.ambient-admin-card small {
  color: var(--muted) !important;
  font-weight: 600 !important;
}

@media(max-width: 700px) {
  .ambient-admin-grid,
  .sound-admin-grid {
    grid-template-columns: 1fr !important;
  }
}


/* =========================================================
   V59B — Accueil mobile : ordre simplifié des actions
   ========================================================= */
.home-mobile-only {
  display: none !important;
}

.home-primary-flow {
  justify-content: flex-end !important;
}

@media(max-width: 700px) {
  /* Sur téléphone, l’accueil commence par l’image/saison, puis la carte
     explicative avec les actions dans l’ordre demandé. */
  .hero-home.hero-clean .hero-bottom p,
  .hero-home.hero-clean .hero-actions {
    display: none !important;
  }

  .hero-home.hero-clean .hero-bottom {
    align-items: flex-start !important;
    justify-content: flex-end !important;
    min-height: auto !important;
  }

  .home-intro-panel {
    margin-top: 14px !important;
    padding: 18px !important;
    text-align: left !important;
  }

  .home-intro-panel h2 {
    font-size: clamp(1.3rem, 6vw, 1.65rem) !important;
    line-height: 1.15 !important;
  }

  .home-intro-panel p {
    font-size: 1rem !important;
    line-height: 1.52 !important;
  }

  .home-primary-flow,
  .home-intro-panel .home-intro-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    align-items: stretch !important;
    width: 100% !important;
    margin-top: 14px !important;
  }

  .home-mobile-only {
    display: inline-flex !important;
  }

  .home-primary-flow .btn,
  .home-primary-flow button {
    width: 100% !important;
    min-height: 46px !important;
    justify-content: center !important;
    text-align: center !important;
  }

  .home-module-grid {
    margin-top: 16px !important;
  }
}


/* =========================================================
   V59B2 — Accueil mobile : pastille Saison superposée
   Objectif : garder "Saison 2026" au bas de l'image Défi Nature
   au lieu de l'envoyer sous le visuel après le réordonnancement mobile.
   ========================================================= */
@media(max-width: 700px) {
  .hero-home.hero-clean {
    margin: 18px auto 16px auto !important;
    overflow: hidden !important;
  }

  .hero-home.hero-clean .hero-bottom {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    display: block !important;
    pointer-events: none !important;
    z-index: 2 !important;
  }

  .hero-home.hero-clean .home-season-label {
    position: absolute !important;
    left: 50% !important;
    bottom: 12px !important;
    transform: translateX(-50%) !important;
    margin: 0 !important;
    z-index: 4 !important;
    pointer-events: auto !important;
    max-width: calc(100% - 28px) !important;
    justify-content: center !important;
    text-align: center !important;
    white-space: nowrap !important;
    background: rgba(255,250,241,.94) !important;
    border: 1px solid rgba(24,53,31,.15) !important;
    box-shadow: 0 8px 18px rgba(0,0,0,.22) !important;
  }

  .home-intro-panel {
    margin-top: 14px !important;
  }
}

/* V60A — Expérience utilisateur globale */
.onboarding-modal{
  position:fixed;
  inset:0;
  z-index:1200;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
  background:rgba(20,35,22,.48);
  backdrop-filter:blur(5px);
}
.onboarding-modal[hidden]{display:none!important;}
.onboarding-card{
  position:relative;
  width:min(720px,100%);
  max-height:min(88vh,820px);
  overflow:auto;
  border-radius:28px;
  padding:30px;
  background:linear-gradient(135deg,#fff8eb,#f6eddb);
  box-shadow:0 28px 70px rgba(14,42,22,.28);
  border:1px solid rgba(70,95,43,.18);
}
.onboarding-close{
  position:absolute;
  top:16px;
  right:16px;
  width:48px;
  height:48px;
  border:0;
  border-radius:18px;
  background:#fff;
  color:#17381e;
  font-size:34px;
  line-height:1;
  font-weight:800;
  cursor:pointer;
  box-shadow:0 8px 24px rgba(22,45,22,.14);
}
.onboarding-kicker,.home-kicker{
  display:inline-block;
  font-size:.78rem;
  letter-spacing:.07em;
  text-transform:uppercase;
  font-weight:800;
  color:#567142;
  margin-bottom:6px;
}
.onboarding-card h2{font-size:clamp(1.8rem,4.5vw,2.8rem);margin:0 58px 10px 0;color:#17381e;}
.onboarding-card p{font-size:clamp(1rem,2.8vw,1.25rem);line-height:1.45;color:#405640;margin:0 0 18px;}
.onboarding-steps{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:10px;
  margin:20px 0;
}
.onboarding-steps div{
  background:#fff;
  border:1px solid #e3d5bd;
  border-radius:18px;
  padding:14px 12px;
  min-height:96px;
}
.onboarding-steps strong{
  display:inline-flex;
  width:34px;
  height:34px;
  border-radius:50%;
  align-items:center;
  justify-content:center;
  background:#2f6b34;
  color:#fff;
  margin-bottom:8px;
}
.onboarding-steps span{display:block;font-weight:800;color:#18371d;line-height:1.2;}
.onboarding-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px;}
.onboarding-skip{display:flex;gap:10px;align-items:center;margin-top:18px;color:#526653;font-size:.95rem;}
.daily-challenge-panel{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:18px;
  align-items:center;
  border-left:8px solid #2f6b34;
}
.daily-challenge-panel h2{margin:.15rem 0 .35rem;color:#18371d;font-size:clamp(1.4rem,3vw,2.1rem);}
.daily-challenge-panel p{margin:0 0 12px;line-height:1.5;color:#405640;}
.daily-challenge-actions{display:flex;flex-direction:column;gap:10px;min-width:170px;}
.home-rules-panel{background:linear-gradient(135deg,#fff8ea,#f3ecd9);}
.home-rules-panel p{font-size:1.05rem;line-height:1.55;white-space:pre-wrap;}
.adventure-hero-panel{
  display:grid;
  grid-template-columns:minmax(0,1.4fr) minmax(260px,.6fr);
  gap:18px;
  align-items:stretch;
}
.adventure-hero-copy h1{font-size:clamp(2rem,5vw,3.4rem);margin:.1rem 0 .5rem;color:#17381e;}
.adventure-hero-copy p{font-size:1.1rem;line-height:1.55;color:#405640;max-width:760px;}
.adventure-score-card{
  background:#fff;
  border:1px solid #ded2bf;
  border-radius:24px;
  padding:20px;
  display:flex;
  flex-direction:column;
  gap:10px;
  justify-content:center;
  box-shadow:0 14px 34px rgba(37,57,27,.10);
}
.adventure-score-card span{font-weight:800;color:#60745d;text-transform:uppercase;font-size:.82rem;letter-spacing:.05em;}
.adventure-score-card strong{font-size:2.1rem;color:#18371d;}
.adventure-profile-panel .passport-profile-main{margin:0;}
.adventure-two-cols{margin-top:0;}
.adventure-badges-panel .badge-grid{margin-top:14px;}
.compact-stamps{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));}
.souvenir-card .souvenir-highlight{
  display:inline-flex;
  margin:.35rem 0 .15rem;
  padding:.25rem .55rem;
  border-radius:999px;
  background:#e8f3df;
  color:#27582e;
  font-weight:800;
}
.admin-soft-separator{
  grid-column:1/-1;
  border:0;
  border-top:1px solid rgba(75,92,54,.16);
  margin:6px 0;
}
.module-header-aventure img{object-fit:cover;}
@media(max-width:760px){
  .onboarding-card{padding:24px 20px;border-radius:24px;}
  .onboarding-card h2{margin-right:48px;}
  .onboarding-steps{grid-template-columns:1fr 1fr;}
  .onboarding-actions .btn{width:100%;}
  .daily-challenge-panel{grid-template-columns:1fr;}
  .daily-challenge-actions{min-width:0;}
  .daily-challenge-actions .btn{width:100%;}
  .adventure-hero-panel{grid-template-columns:1fr;}
  .adventure-score-card strong{font-size:1.8rem;}
  .home-rules-panel p{font-size:1rem;}
}
@media(max-width:420px){
  .onboarding-steps{grid-template-columns:1fr;}
  .onboarding-close{width:44px;height:44px;border-radius:16px;font-size:30px;}
}

/* V60C — liens publics galerie et ajustements de partage */
.photo-public-link {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.55rem;
  margin: 0.65rem 0 0.75rem;
  font-size: 0.86rem;
  color: rgba(31, 50, 29, 0.78);
}
.photo-public-link code {
  display: inline-block;
  max-width: 100%;
  padding: 0.32rem 0.55rem;
  border-radius: 999px;
  background: rgba(63, 111, 31, 0.08);
  border: 1px solid rgba(63, 111, 31, 0.16);
  color: #24451e;
  white-space: normal;
  word-break: break-word;
}
.photo-public-link-large {
  align-items: flex-start;
  flex-direction: column;
  margin: 1rem 0;
}
.photo-public-link-large code {
  border-radius: 1rem;
  width: 100%;
}
.photo-share-actions,
.admin-photo-share-actions {
  flex-wrap: wrap;
}
.copy-feedback-toast {
  position: fixed;
  left: 50%;
  bottom: calc(5.5rem + env(safe-area-inset-bottom));
  transform: translateX(-50%);
  z-index: 9999;
  max-width: min(92vw, 460px);
  padding: 0.85rem 1.1rem;
  border-radius: 999px;
  background: #2f6b37;
  color: #fff;
  font-weight: 800;
  box-shadow: 0 14px 38px rgba(0, 0, 0, 0.24);
}
@media (max-width: 720px) {
  .photo-share-actions .btn,
  .admin-photo-share-actions .btn {
    width: 100%;
  }
  .photo-public-link {
    font-size: 0.82rem;
  }
}


/* V60D — og:image galerie repointée vers aperçu JPG statique pour Facebook. */


/* V60D3 — Intro audio Défis une seule fois
   Affiche le message de réussite directement dans la carte au lieu d'utiliser
   une alerte navigateur, ce qui évite l'impression de recharge et les doublons audio. */
.challenge-feedback {
  display: none;
  margin: .75rem 0 0;
  padding: .75rem .9rem;
  border-radius: 14px;
  background: rgba(63, 111, 31, .12);
  border: 1px solid rgba(63, 111, 31, .24);
  color: #294a1b;
  font-weight: 700;
  line-height: 1.35;
}
.challenge-feedback.show,
.challenge-card.completed .challenge-feedback {
  display: block;
}
.completeChallenge.completed + .challenge-feedback:not(.show) {
  display: none;
}

/* V60D4 — Bouton « Propose ta photo » dans chaque carte Défis Nature. */
.challenge-actions {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  align-items: stretch !important;
  align-self: center !important;
  min-width: 190px !important;
}

.challenge-actions .btn {
  justify-content: center !important;
  text-align: center !important;
  white-space: normal !important;
  line-height: 1.15 !important;
}

.challenge-photo-link {
  border-style: dashed !important;
}

#proposer-photo-galerie {
  scroll-margin-top: 96px !important;
}

.photo-submit-anchor-note {
  font-weight: 700 !important;
  color: var(--green) !important;
}

@media(max-width: 760px) {
  .challenge-actions {
    width: 100% !important;
    min-width: 0 !important;
  }

  .challenge-actions .btn,
  .defis-card .completeChallenge,
  .defis-card .challenge-photo-link {
    width: 100% !important;
  }
}


/* V60D5 — Puzzle Nature 20 morceaux */
.puzzle-board {
  aspect-ratio: var(--puzzle-aspect-ratio, 1 / 1) !important;
}

@media(max-width: 700px) {
  .puzzle-board {
    gap: 3px !important;
  }
  .puzzle-tile {
    border-radius: 6px !important;
  }
}

/* V60I — Modération participants */
.participant-action-stack {
  display: flex;
  flex-direction: column;
  gap: 6px;
  align-items: flex-start;
}
.participant-action-stack form,
.participant-admin-table form {
  margin: 0;
}
.participant-admin-table code {
  word-break: break-all;
}
.participant-blocked-row {
  background: rgba(120, 47, 28, 0.08);
}
.participant-blocked-row td:first-child {
  color: #7a2f1c;
}
@media (max-width: 760px) {
  .participant-action-stack .btn,
  .participant-admin-table .btn {
    width: 100%;
    justify-content: center;
  }
}

/* V60J — Carnet Souvenir privé + partage Facebook */
.carnet-private-intro h2,
.carnet-private-list-panel h2{margin-top:0}
.share-consent-box{
  grid-column:1/-1;
  border:1px solid rgba(47,93,47,.22);
  border-radius:18px;
  padding:14px;
  background:rgba(246,232,199,.34);
}
.share-consent-box legend{
  font-weight:800;
  padding:0 8px;
  color:var(--green-dark);
}
.share-consent-box textarea{
  min-height:84px;
  margin-bottom:10px;
}
.carnet-private-list-panel .gallery-grid{
  margin-top:14px;
}
.souvenir-share-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin:10px;
}
.souvenir-share-actions .btn{
  margin:0;
}
.carnet-share-page .photo-share-main-img{
  max-height:680px;
  object-fit:contain;
  background:#111;
}
@media(max-width:700px){
  .share-consent-box{padding:12px;border-radius:14px}
  .souvenir-share-actions .btn{width:100%;justify-content:center}
}

/* V60J6 — Suppression des souvenirs par l’utilisateur */
.carnet-bulk-actions{
  margin:12px 0 4px;
  padding:12px;
  border:1px dashed rgba(139,47,31,.28);
  border-radius:16px;
  background:rgba(255,246,237,.75);
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
}
.carnet-bulk-actions[hidden]{display:none!important}
.btn.danger,
button.btn.danger{
  background:#8b2f1f;
  border-color:#8b2f1f;
  color:#fff;
}
.btn.danger:hover,
button.btn.danger:hover{
  filter:brightness(.96);
}
.souvenir-delete-actions{
  margin:12px 10px 10px;
  padding-top:10px;
  border-top:1px solid rgba(75,92,54,.15);
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}
.souvenir-select-line{
  display:inline-flex;
  gap:7px;
  align-items:center;
  font-weight:700;
  color:#5c4f3c;
}
.souvenir-select-line input{width:auto}
.souvenir-delete-btn{margin:0}
@media(max-width:700px){
  .carnet-bulk-actions .btn,
  .souvenir-delete-actions .btn{width:100%;justify-content:center}
  .souvenir-delete-actions{align-items:stretch}
}

/* V60J7 — Nettoyage médias orphelins */
.admin-media-cleanup-details {
  margin: 0.85rem 0;
  padding: 0.85rem 1rem;
  border: 1px solid rgba(74, 51, 26, 0.16);
  border-radius: 18px;
  background: rgba(255, 250, 238, 0.72);
}
.admin-media-cleanup-details summary {
  cursor: pointer;
  font-weight: 800;
  color: #173f22;
}
.admin-orphan-list {
  margin: 0.75rem 0 0;
  padding-left: 1.15rem;
  display: grid;
  gap: 0.35rem;
}
.admin-orphan-list code {
  word-break: break-all;
}


/* =========================================================
   V60K — Passeport Nature : textes clarifiés et tampons illustrés
   ========================================================= */

.passport-section-title {
  align-items: flex-start !important;
}

.passport-section-title > div {
  display: grid !important;
  gap: 4px !important;
}

.passport-section-title h2 {
  margin-bottom: 0 !important;
}

.passport-section-help {
  margin: 6px 0 14px !important;
  color: #4f5e48 !important;
  font-size: clamp(15px, 2.1vw, 17px) !important;
  line-height: 1.45 !important;
  font-weight: 650 !important;
}

.puzzle-badges-panel > .passport-section-help,
.puzzle-badges-panel > p.passport-section-help {
  margin-top: 14px !important;
  margin-bottom: 0 !important;
  padding: 10px 12px !important;
  border-radius: 14px !important;
  background: rgba(255,255,255,.72) !important;
  border: 1px solid rgba(180,160,125,.38) !important;
}

.passport-stamp-grid-illustrated {
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)) !important;
  gap: 14px !important;
}

.passport-stamp-illustrated {
  padding: 0 !important;
  overflow: hidden !important;
  border-radius: 20px !important;
  background: #fffaf0 !important;
  border: 2px solid #dac79e !important;
  box-shadow: var(--shadow-soft) !important;
}

.passport-stamp-visual {
  position: relative !important;
  aspect-ratio: 4 / 3 !important;
  width: 100% !important;
  overflow: hidden !important;
  display: grid !important;
  place-items: center !important;
  background:
    radial-gradient(circle at top left, rgba(123, 88, 45, .18), transparent 42%),
    linear-gradient(135deg, #efe1bd, #fff7df) !important;
}

.passport-stamp-visual img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}

.passport-stamp-visual span {
  font-size: 44px !important;
  filter: drop-shadow(0 2px 0 rgba(255,255,255,.5)) !important;
}

.passport-stamp-copy {
  padding: 13px 14px 15px !important;
  display: grid !important;
  gap: 4px !important;
  min-height: 142px !important;
}

.passport-stamp-copy em {
  display: block !important;
  font-style: normal !important;
  color: #66715c !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: .04em !important;
}

.passport-stamp-copy strong {
  display: block !important;
  color: var(--dark) !important;
  font-size: 16px !important;
  line-height: 1.18 !important;
}

.passport-stamp-copy small {
  color: #4f5e48 !important;
  line-height: 1.3 !important;
}

.passport-stamp-illustrated.locked {
  opacity: .76 !important;
  filter: none !important;
}

.passport-stamp-illustrated.locked .passport-stamp-visual img,
.passport-stamp-illustrated.locked .passport-stamp-visual span {
  filter: grayscale(.85) contrast(.9) opacity(.68) !important;
}

.passport-stamp-illustrated.locked .passport-stamp-visual::after {
  content: "À collectionner" !important;
  position: absolute !important;
  inset: auto 10px 10px 10px !important;
  padding: 7px 10px !important;
  border-radius: 999px !important;
  background: rgba(255, 248, 236, .92) !important;
  color: #6b5b3c !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  text-align: center !important;
  box-shadow: 0 8px 18px rgba(0,0,0,.12) !important;
}

.passport-stamp-illustrated.unlocked {
  opacity: 1 !important;
  border-color: #86b866 !important;
  background: #fbfff5 !important;
}

.passport-stamp-illustrated.unlocked .passport-stamp-visual::after {
  content: "✓ Tampon obtenu" !important;
  position: absolute !important;
  inset: auto 10px 10px 10px !important;
  padding: 7px 10px !important;
  border-radius: 999px !important;
  background: rgba(228,244,216,.94) !important;
  color: var(--green) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  text-align: center !important;
  box-shadow: 0 8px 18px rgba(0,0,0,.12) !important;
}

.passport-stamp-illustrated.unlocked .passport-stamp-visual img,
.passport-stamp-illustrated.unlocked .passport-stamp-visual span {
  filter: none !important;
}

@media(max-width: 620px) {
  .passport-stamp-grid-illustrated {
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
  }
  .passport-stamp-copy {
    padding: 10px !important;
    min-height: 132px !important;
  }
  .passport-stamp-copy strong {
    font-size: 14px !important;
  }
  .passport-stamp-copy small {
    font-size: 12px !important;
  }
}

@media(max-width: 430px) {
  .passport-stamp-grid-illustrated {
    grid-template-columns: 1fr !important;
  }
}

/* =========================================================
   V60L — Tampons et badges Passeport administrables
   ========================================================= */
.puzzle-badge-illustrated {
  overflow: hidden !important;
  padding: 0 !important;
  display: grid !important;
  grid-template-rows: auto 1fr auto !important;
  background: #fffaf0 !important;
  border-color: #d8c096 !important;
}

.puzzle-badge-visual {
  width: 100% !important;
  aspect-ratio: 4 / 3 !important;
  display: grid !important;
  place-items: center !important;
  background: linear-gradient(135deg, #efe0b8, #fff7dd) !important;
  overflow: hidden !important;
}

.puzzle-badge-visual img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}

.puzzle-badge-illustrated > strong {
  padding: 12px 12px 4px !important;
  margin: 0 !important;
}

.puzzle-badge-illustrated > small {
  display: block !important;
  padding: 0 12px 14px !important;
}

.puzzle-badge-illustrated.locked .puzzle-badge-visual img,
.puzzle-badge-illustrated.locked .puzzle-badge-visual span {
  filter: grayscale(.9) opacity(.7) !important;
}

.passport-admin-list {
  margin: 12px 0 24px !important;
}

.passport-admin-card,
.passport-stamp-admin-card {
  grid-template-columns: 100px repeat(3, minmax(140px, 1fr)) !important;
}

.passport-admin-card label,
.passport-stamp-admin-card label {
  display: grid !important;
  gap: 4px !important;
  font-size: 13px !important;
  color: #4f5e48 !important;
  font-weight: 700 !important;
}

.passport-admin-card textarea,
.passport-stamp-admin-card textarea {
  min-height: 74px !important;
}

.passport-admin-add-form {
  margin-bottom: 16px !important;
  padding: 14px !important;
  border: 1px solid rgba(180,160,125,.35) !important;
  border-radius: 18px !important;
  background: rgba(255,255,255,.72) !important;
}

@media(max-width: 1000px) {
  .passport-admin-card,
  .passport-stamp-admin-card {
    grid-template-columns: 1fr !important;
  }
}

/* V60M3 — Inscription participants / image sans voile */
.registration-hero {
  position: relative;
  min-height: min(48vh, 460px);
  border-radius: 28px;
  overflow: hidden;
  margin: 1rem auto 1.25rem;
  max-width: 1180px;
  /* Image affichée directement, sans voile ni dégradé par-dessus. */
  background-image: var(--registration-bg);
  background-size: cover;
  background-position: center;
  box-shadow: 0 18px 50px rgba(0,0,0,.28);
}
.registration-hero-overlay {
  position: absolute;
  inset: auto auto clamp(1rem, 3vw, 2rem) clamp(1rem, 3vw, 2rem);
  max-width: min(720px, calc(100% - 2rem));
  padding: clamp(1rem, 3vw, 2rem);
  color: #17351f;
  text-shadow: none;
  background: rgba(255, 250, 241, .90);
  border: 1px solid rgba(225, 207, 176, .78);
  border-radius: 22px;
  box-shadow: 0 12px 34px rgba(0,0,0,.16);
  backdrop-filter: blur(2px);
}
.registration-hero h1 {
  margin: .25rem 0 .35rem;
  font-size: clamp(2rem, 6vw, 4.5rem);
  line-height: .95;
}
.registration-hero p {
  max-width: 780px;
  font-size: clamp(1rem, 2.2vw, 1.35rem);
}
.registration-layout {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
  gap: 1.1rem;
  max-width: 1180px;
  margin: 0 auto 2rem;
}
.registration-info-card,
.registration-form-card {
  align-self: start;
}
.registration-benefits {
  margin: 1rem 0 0;
  padding-left: 1.2rem;
}
.registration-benefits li {
  margin: .55rem 0;
}
.registration-current-profile {
  margin-top: 1rem;
  padding: .8rem 1rem;
  border-radius: 16px;
  background: rgba(97, 134, 65, .14);
  border: 1px solid rgba(97, 134, 65, .35);
}
.registration-form {
  display: grid;
  gap: .9rem;
}
.registration-two-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .75rem;
}
.registration-form label,
.registration-admin-form label {
  display: grid;
  gap: .35rem;
}
.registration-form input[type="text"],
.registration-form input[type="email"],
.registration-form input:not([type]),
.registration-admin-form input:not([type]),
.registration-admin-form textarea {
  width: 100%;
}
.registration-consent {
  display: flex !important;
  grid-template-columns: none !important;
  gap: .65rem !important;
  align-items: flex-start;
  padding: .75rem .85rem;
  border-radius: 14px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
}
.registration-consent input {
  margin-top: .2rem;
  min-width: 18px;
}
.profile-current-summary {
  margin: .7rem 0 1rem;
  padding: .7rem .8rem;
  border-radius: 14px;
  background: rgba(255,255,255,.08);
}
.profile-current-summary small {
  display: block;
  opacity: .82;
}
.wide-preview img {
  max-width: 100%;
  max-height: 260px;
  border-radius: 16px;
  object-fit: cover;
}
@media (max-width: 760px) {
  .registration-hero {
    min-height: 330px;
    border-radius: 22px;
    margin: .5rem .25rem 1rem;
  }
  .registration-layout,
  .registration-two-cols {
    grid-template-columns: 1fr;
  }
  .registration-layout {
    gap: .85rem;
  }
  .registration-hero-overlay {
    inset: auto .85rem .85rem .85rem;
    max-width: none;
    padding: 1rem;
    border-radius: 18px;
  }
  .registration-hero h1 {
    font-size: 2.15rem;
  }
}


/* V60N — Défis avec résumé, photo obligatoire et confidentialité */
.challenge-proof-intro{
  display:flex;
  gap:1rem;
  align-items:center;
}
.challenge-proof-intro h2{
  margin:.15rem 0 .35rem;
}
.challenge-completed-card{
  border-color:rgba(47,93,47,.38);
  box-shadow:0 16px 36px rgba(47,93,47,.16);
}
.photo-pill.completed{
  background:#d9efd1;
  color:#234d28;
  border-color:rgba(47,93,47,.25);
}
.challenge-detail-hero .btn.ghost{
  margin-bottom:1rem;
}
.challenge-detail-layout{
  display:grid;
  grid-template-columns:minmax(180px, 320px) 1fr;
  gap:1.2rem;
  align-items:center;
}
.challenge-detail-img{
  width:100%;
  max-height:260px;
  object-fit:cover;
  border-radius:22px;
  box-shadow:var(--shadow-soft);
}
.challenge-proof-form-panel textarea{
  min-height:140px;
}
.word-counter{
  margin:-.45rem 0 .25rem;
  font-size:.92rem;
  color:#4d5d46;
  font-weight:700;
}
.word-counter.over{
  color:#9d2f1f;
}
.visibility-choice{
  border:1px solid rgba(47,93,47,.18);
  border-radius:18px;
  padding:1rem;
  background:rgba(255,248,236,.75);
}
.visibility-choice legend{
  font-weight:800;
  color:var(--dark);
  padding:0 .35rem;
}
.choice-card{
  display:flex;
  gap:.75rem;
  align-items:flex-start;
  padding:.85rem;
  margin:.55rem 0;
  border:1px solid rgba(47,93,47,.18);
  border-radius:16px;
  background:#fffdf7;
}
.choice-card input{
  width:auto;
  margin-top:.25rem;
}
.choice-card span{
  display:flex;
  flex-direction:column;
  gap:.2rem;
}
.choice-card small{
  color:#5b6a55;
  line-height:1.35;
}
.challenge-proof-done .proof-summary-card{
  padding:1rem;
  border-radius:18px;
  background:rgba(244,235,221,.8);
  border:1px solid rgba(47,93,47,.16);
}
.admin-proof-list{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
  gap:.85rem;
}
.admin-proof-card{
  border:1px solid rgba(47,93,47,.16);
  border-radius:18px;
  padding:1rem;
  background:#fffdf7;
  box-shadow:var(--shadow-soft);
}
.admin-proof-card h4{
  margin:.1rem 0 .35rem;
}
.admin-proof-card p{
  margin:.35rem 0;
}
.admin-proof-card .proof-status{
  display:inline-flex;
  padding:.22rem .55rem;
  border-radius:999px;
  background:#ecf1df;
  font-weight:800;
  font-size:.82rem;
}
@media (max-width:760px){
  .challenge-detail-layout{
    grid-template-columns:1fr;
  }
  .challenge-detail-img{
    max-height:220px;
  }
  .choice-card{
    padding:.75rem;
  }
}


/* V60N3 — Aperçu photo dans le défi complété */
.proof-photo-preview {
  margin-top: 1rem;
}

.proof-photo-preview img {
  width: 100%;
  max-height: 520px;
  object-fit: contain;
  display: block;
  border-radius: 18px;
  border: 1px solid rgba(43, 94, 48, 0.18);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 12px 28px rgba(36, 54, 30, 0.12);
}

@media (max-width: 700px) {
  .proof-photo-preview img {
    max-height: 420px;
    border-radius: 14px;
  }
}


/* V60N4 — Bingo avec résumé de réalisation */
.bingo-cell { text-decoration: none; color: inherit; }
.bingo-detail-hero .bingo-detail-layout {
  display: grid;
  grid-template-columns: minmax(160px, 260px) 1fr;
  gap: 1.5rem;
  align-items: center;
}
.bingo-detail-image {
  border-radius: 24px;
  overflow: hidden;
  background: rgba(255,255,255,.75);
  border: 1px solid rgba(69, 49, 25, .18);
  min-height: 180px;
  display: grid;
  place-items: center;
  box-shadow: 0 12px 30px rgba(0,0,0,.08);
}
.bingo-detail-image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.bingo-detail-image span { font-size: 4rem; }
.bingo-proof-form-panel textarea,
.bingo-proof-done textarea { font-size: 1rem; }
.bingo-proof-done .proof-photo-preview img {
  max-width: 520px;
  width: 100%;
  border-radius: 18px;
  display: block;
  margin-top: .75rem;
  box-shadow: 0 14px 34px rgba(0,0,0,.14);
}
@media (max-width: 720px){
  .bingo-detail-hero .bingo-detail-layout { grid-template-columns: 1fr; }
  .bingo-detail-image { min-height: 220px; }
}

/* V60N5 — Réglages administrables des limites de mots */
.proof-limits-form input[type="number"] {
  max-width: 220px;
}


/* V60N6 — Explication de réponse dans le popup Quiz */
.quiz-modal-explanation {
  margin: 12px auto 16px;
  padding: 12px 14px;
  border-radius: 14px;
  background: rgba(250, 244, 226, 0.92);
  border: 1px solid rgba(123, 86, 42, 0.24);
  color: #3a2a17;
  font-size: 0.98rem;
  line-height: 1.45;
  text-align: left;
  max-width: 560px;
}
.quiz-modal-explanation::before {
  content: "Explication";
  display: block;
  margin-bottom: 5px;
  font-weight: 800;
  color: #6b451b;
}
@media (max-width: 640px) {
  .quiz-modal-explanation {
    font-size: 0.94rem;
    padding: 10px 12px;
  }
}

/* V60N7 — Connexion participant multi-appareils */
.registration-login-callout {
  margin-top: 1rem;
  padding: 1rem;
  border-radius: 16px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(76, 94, 53, .18);
}
.registration-login-callout p { margin: .35rem 0 .75rem; }
.registration-login-layout { align-items: flex-start; }
.password-field-wrap {
  display: flex;
  align-items: stretch;
  gap: 0;
  width: 100%;
  position: relative;
}
.password-field-wrap input {
  flex: 1 1 auto;
  min-width: 0;
  padding-right: 3.2rem !important;
}
.password-eye {
  position: absolute;
  top: 50%;
  right: .35rem;
  transform: translateY(-50%);
  min-width: 2.3rem;
  height: 2.3rem;
  border: 0;
  border-radius: 999px;
  background: rgba(47,93,47,.12);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
}
.password-eye:hover { background: rgba(47,93,47,.22); }
.password-field-wrap.compact input { min-height: 40px; font-size: .92rem; }
.password-field-wrap.compact .password-eye { height: 2rem; min-width: 2rem; font-size: .9rem; }
.status-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: .2rem .55rem;
  font-size: .78rem;
  font-weight: 700;
}
.status-pill.ok { background: rgba(55,128,71,.16); color: #285a2c; }
.status-pill.warn { background: rgba(185,120,20,.18); color: #7a4b08; }
.participant-password-reset {
  min-width: 220px;
  background: rgba(255,255,255,.56);
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 12px;
  padding: .45rem .55rem;
}
.participant-password-reset summary {
  cursor: pointer;
  font-weight: 700;
}
.participant-password-form {
  display: grid;
  gap: .45rem;
  margin-top: .55rem;
}
.participant-password-form label { font-size: .86rem; }
@media (max-width: 700px) {
  .participant-password-reset { min-width: 0; width: 100%; }
  .password-eye { min-width: 2.15rem; height: 2.15rem; }
}
.mini-profile-logout { margin-top: .65rem; }


/* =========================================================
   V60N8 — Menu public allégé sur ordinateur
   ========================================================= */
@media(min-width: 800px) {
  .topbar {
    grid-template-columns: minmax(210px, auto) minmax(0, 1fr) auto !important;
    gap: 14px !important;
    padding: 10px 18px !important;
  }

  .topbar .brand {
    min-width: 0 !important;
    gap: 8px !important;
  }

  .topbar .brand-icon {
    width: 38px !important;
    height: 38px !important;
    border-radius: 12px !important;
  }

  .topbar .brand strong {
    font-size: 15px !important;
    line-height: 1.1 !important;
    white-space: nowrap !important;
  }

  .topbar .brand small {
    font-size: 12px !important;
    line-height: 1.15 !important;
    white-space: nowrap !important;
  }

  .topbar .mobile-menu {
    justify-content: center !important;
    gap: clamp(8px, .9vw, 14px) !important;
    min-width: 0 !important;
    flex-wrap: nowrap !important;
  }

  .topbar .mobile-menu a {
    font-size: clamp(13px, .9vw, 15px) !important;
    line-height: 1.15 !important;
    padding: 6px 0 !important;
    white-space: nowrap !important;
  }

  .topbar-actions {
    justify-self: end !important;
    flex-wrap: nowrap !important;
  }

  .offline-status-btn,
  .sound-toggle {
    min-width: 42px !important;
    min-height: 42px !important;
    padding: 8px 10px !important;
    border-radius: 14px !important;
  }
}

@media(min-width: 800px) and (max-width: 1180px) {
  .topbar {
    grid-template-columns: 1fr auto !important;
    align-items: start !important;
  }

  .topbar .mobile-menu {
    grid-column: 1 / -1 !important;
    order: 3 !important;
    justify-content: flex-start !important;
    flex-wrap: wrap !important;
    row-gap: 4px !important;
  }
}

/* V60N9 — Connexion participant administrable et compacte */
.btn.login-orange,
a.btn.login-orange {
  background: linear-gradient(135deg, #c87721, #e19a38) !important;
  color: #fffaf1 !important;
  border: 1px solid rgba(139, 82, 23, .42) !important;
  box-shadow: 0 8px 22px rgba(184, 108, 34, .22) !important;
}
.btn.login-orange:hover,
a.btn.login-orange:hover {
  transform: translateY(-1px);
  filter: brightness(1.03);
}
.participant-login-shell {
  min-height: clamp(560px, calc(100vh - 160px), 820px);
  margin: -1rem calc(50% - 50vw) 0;
  padding: clamp(1.25rem, 5vw, 4rem) 1rem 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background:
    radial-gradient(circle at 30% 20%, rgba(255,255,255,.36), transparent 34%),
    linear-gradient(110deg, rgba(237,246,232,.72), rgba(255,246,229,.58)),
    var(--participant-login-bg) center/cover no-repeat;
}
.participant-login-card {
  width: min(92vw, 620px);
  padding: clamp(1.15rem, 2.2vw, 1.85rem) !important;
  background: rgba(255, 250, 241, .74) !important;
  border: 1px solid rgba(219, 197, 161, .64) !important;
  border-radius: 24px !important;
  box-shadow: 0 18px 54px rgba(37, 63, 39, .18) !important;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.participant-login-card h1 {
  margin: .2rem 0 .25rem;
  font-size: clamp(1.85rem, 4.5vw, 3.1rem);
  line-height: 1.02;
}
.participant-login-subtitle {
  margin: 0 0 .9rem;
  color: rgba(25, 54, 31, .82);
  font-size: clamp(.98rem, 2vw, 1.12rem);
}
.participant-login-helper {
  margin: .85rem 0 1rem;
  padding: .85rem 1rem;
  border-radius: 18px;
  background: rgba(255,255,255,.46);
  border: 1px solid rgba(76, 94, 53, .16);
}
.participant-login-helper strong {
  display: block;
  margin-bottom: .3rem;
  font-size: 1.06rem;
}
.participant-login-helper p {
  margin: .35rem 0;
  line-height: 1.42;
}
.participant-login-card .registration-form {
  gap: .75rem;
}
.participant-login-card .registration-form input {
  min-height: 46px;
}
.participant-login-card .btn.primary {
  width: 100%;
}
.participant-login-bottom-actions {
  margin-top: .9rem;
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
  justify-content: center;
}
.participant-login-bottom-actions .btn {
  flex: 1 1 210px;
}
.admin-soft-separator {
  width: 100%;
  border: 0;
  border-top: 1px solid rgba(63, 111, 31, .18);
  margin: .6rem 0 .25rem;
}
@media (max-width: 760px) {
  .participant-login-shell {
    min-height: calc(100vh - 96px);
    align-items: flex-start;
    padding-top: 1.2rem;
  }
  .participant-login-card {
    width: min(94vw, 520px);
    border-radius: 20px !important;
  }
  .participant-login-helper {
    padding: .75rem .85rem;
  }
  .participant-login-bottom-actions .btn {
    flex-basis: 100%;
  }
}

/* V60N10 — Bandeaux Facebook administrables */
.fb-banner-active-note {
  margin: .75rem 0 1rem;
}
.fb-banner-actions-row,
.fb-banner-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  align-items: flex-end;
  margin: .75rem 0 1rem;
}
.fb-banner-actions-row form,
.fb-banner-card-actions form {
  margin: 0;
}
.fb-banner-one-form {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
  align-items: flex-end;
}
.fb-banner-one-form label {
  min-width: min(100%, 320px);
}
.fb-banner-form {
  margin-top: .75rem;
}
.fb-banner-fieldset {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: .75rem;
  padding: .9rem;
  border-radius: 18px;
  background: rgba(255,255,255,.36);
  border: 1px solid rgba(69, 103, 48, .16);
}
.fb-banner-fieldset h4,
.fb-banner-fieldset .fine-print {
  grid-column: 1 / -1;
  margin: 0;
}
.fb-banner-model-list {
  display: grid;
  gap: 1rem;
  margin-top: .75rem;
}
.fb-banner-model-card {
  padding: 1rem;
  border-radius: 20px;
  background: rgba(255, 250, 241, .55);
  border: 1px solid rgba(63, 111, 31, .16);
  box-shadow: 0 10px 30px rgba(25, 48, 30, .08);
}
.fb-banner-model-card > header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: .8rem;
  margin-bottom: .65rem;
}
.fb-banner-model-card > header strong,
.fb-banner-model-card > header small {
  display: block;
}
.fb-banner-update-form {
  padding: .75rem 0 0;
}
@media (max-width: 760px) {
  .fb-banner-actions-row,
  .fb-banner-one-form,
  .fb-banner-card-actions,
  .fb-banner-model-card > header {
    align-items: stretch;
    flex-direction: column;
  }
  .fb-banner-card-actions .btn,
  .fb-banner-actions-row .btn,
  .fb-banner-model-card > header .btn {
    width: 100%;
  }
}
