.elementor-3030 .elementor-element.elementor-element-36d66ce{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-3030 .elementor-element.elementor-element-a6e5331{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}@media(min-width:768px){.elementor-3030 .elementor-element.elementor-element-a6e5331{--content-width:1500px;}}/* Start custom CSS for shortcode, class: .elementor-element-d29f4f8 */.elementor-3030 .elementor-element.elementor-element-d29f4f8 .gp-hero {
  position: relative;
  height: 340px;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  background: #003D52;
}

.elementor-3030 .elementor-element.elementor-element-d29f4f8 .gp-hero-bg {
  position: absolute;
  inset: 0;
}

.elementor-3030 .elementor-element.elementor-element-d29f4f8 .gp-hero-deco-1 {
  position: absolute;
  top: -100px; right: -100px;
  width: 400px; height: 400px;
  border-radius: 50%;
  border: 60px solid rgba(0,174,204,.08);
  pointer-events: none;
}

.elementor-3030 .elementor-element.elementor-element-d29f4f8 .gp-hero-deco-2 {
  position: absolute;
  top: 40px; right: 80px;
  width: 180px; height: 180px;
  border-radius: 50%;
  border: 2px solid rgba(0,174,204,.15);
  pointer-events: none;
}

.elementor-3030 .elementor-element.elementor-element-d29f4f8 .gp-hero-wave {
  position: absolute;
  bottom: -2px; left: 0; right: 0;
  z-index: 2; line-height: 0;
}

.elementor-3030 .elementor-element.elementor-element-d29f4f8 .gp-hero-wave svg { width: 100%; display: block; }

.elementor-3030 .elementor-element.elementor-element-d29f4f8 .gp-hero-content {
  position: relative;
  z-index: 3;
  padding: 0 48px 56px;
  max-width: 1280px;
  margin: 0 auto;
  width: 100%;
}

.elementor-3030 .elementor-element.elementor-element-d29f4f8 .gp-breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 20px;
}

.elementor-3030 .elementor-element.elementor-element-d29f4f8 .gp-breadcrumb a,
.elementor-3030 .elementor-element.elementor-element-d29f4f8 .gp-breadcrumb span {
  font-size: 12px;
  font-weight: 500;
  color: rgba(255,255,255,.5);
  text-decoration: none !important;
  font-family: 'Montserrat', sans-serif;
}

.elementor-3030 .elementor-element.elementor-element-d29f4f8 .gp-breadcrumb a:hover { color: #00AECC; }
.elementor-3030 .elementor-element.elementor-element-d29f4f8 .gp-sep { color: rgba(255,255,255,.25); }
.elementor-3030 .elementor-element.elementor-element-d29f4f8 .gp-current { color: rgba(255,255,255,.9) !important; }

.elementor-3030 .elementor-element.elementor-element-d29f4f8 .gp-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: #00AECC;
  font-family: 'Montserrat', sans-serif;
  margin-bottom: 12px;
}

.elementor-3030 .elementor-element.elementor-element-d29f4f8 .gp-eyebrow::before {
  content: '';
  display: block;
  width: 24px; height: 2px;
  background: #00AECC;
}

.elementor-3030 .elementor-element.elementor-element-d29f4f8 .gp-title {
  font-family: 'Montserrat', sans-serif;
  font-weight: 900;
  font-size: clamp(32px, 5vw, 56px);
  color: white;
  text-transform: uppercase;
  letter-spacing: -1.5px;
  line-height: 0.95;
  margin-bottom: 14px;
}

.elementor-3030 .elementor-element.elementor-element-d29f4f8 .gp-title span { color: #00AECC; }

.elementor-3030 .elementor-element.elementor-element-d29f4f8 .gp-intro {
  font-size: 15px;
  color: rgba(255,255,255,.65);
  max-width: 540px;
  line-height: 1.65;
  font-family: 'Open Sans', sans-serif;
}

@media (max-width: 768px) {
  .elementor-3030 .elementor-element.elementor-element-d29f4f8 .gp-hero { height: 300px; }
  .elementor-3030 .elementor-element.elementor-element-d29f4f8 .gp-hero-content { padding: 0 24px 48px; }
}/* End custom CSS */
/* Start custom CSS for shortcode, class: .elementor-element-c450df6 *//* ════════════════════════════════════════════
   PAGE PLANNINGS
   Shortcode : page_plannings
   Desktop   : calendrier grille 7 jours
   Mobile    : liste par jour avec cards
   Préfixe   : ppl-
════════════════════════════════════════════ */

/* ── WRAPPER ── */
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-wrap {
  font-family: 'Montserrat', sans-serif !important;
}

/* ════════════════════════════════════════════
   FILTRES DESKTOP
════════════════════════════════════════════ */
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-filtres-bar {
  background: white !important;
  border-bottom: 2px solid #00AECC !important;
  box-shadow: 0 4px 20px rgba(0,0,0,.06) !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-filtres-inner {
  padding: 16px 48px !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-filtre-groupe {
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
  flex: 1 !important;
  min-width: 140px !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-filtre-label {
  font-size: 9px !important;
  font-weight: 700 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  color: #4A6070 !important;
  font-family: 'Montserrat', sans-serif !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-filtre-select {
  appearance: none !important;
  -webkit-appearance: none !important;
  background: #F5F9FB url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'%3E%3Cpolyline points='2 3 5 7 8 3' fill='none' stroke='%234A6070' stroke-width='1.8' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat right 12px center !important;
  border: 1.5px solid #D4E4EB !important;
  padding: 9px 32px 9px 12px !important;
  font-family: 'Montserrat', sans-serif !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  color: #003D52 !important;
  cursor: pointer !important;
  transition: border-color .2s !important;
  border-radius: 2px !important;
  width: 100% !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-filtre-select:focus {
  outline: none !important;
  border-color: #00AECC !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-filtre-sep {
  width: 1px !important;
  height: 40px !important;
  background: #D4E4EB !important;
  flex-shrink: 0 !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-filtre-reset {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 9px 16px !important;
  background: transparent !important;
  border: 1.5px solid #D4E4EB !important;
  color: #4A6070 !important;
  font-family: 'Montserrat', sans-serif !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  transition: all .2s !important;
  white-space: nowrap !important;
  border-radius: 2px !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-filtre-reset:hover { border-color: #F2611A !important; color: #F2611A !important; }
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-filtre-reset svg { stroke: currentColor !important; fill: none !important; }

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-filtre-count {
  font-size: 11px !important;
  font-weight: 600 !important;
  color: #4A6070 !important;
  font-family: 'Montserrat', sans-serif !important;
  white-space: nowrap !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-filtre-count span { color: #00AECC !important; font-weight: 800 !important; }

/* ════════════════════════════════════════════
   FILTRES MOBILE — masqués sur desktop
════════════════════════════════════════════ */
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-filtres-mobile {
  display: none !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-filtres-mobile-titre {
  font-size: 9px !important;
  font-weight: 700 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  color: #4A6070 !important;
  margin-bottom: 8px !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-filtres-mobile-row {
  display: flex !important;
  gap: 8px !important;
  margin-bottom: 8px !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-filtre-reset-m {
  display: flex !important;
  align-items: center !important;
  padding: 9px 12px !important;
  background: transparent !important;
  border: 1.5px solid #D4E4EB !important;
  color: #4A6070 !important;
  cursor: pointer !important;
  border-radius: 2px !important;
  flex-shrink: 0 !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-filtre-reset-m svg { stroke: currentColor !important; fill: none !important; }

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-filtre-count-m {
  font-size: 10px !important;
  font-weight: 600 !important;
  color: #4A6070 !important;
  text-align: right !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-filtre-count-m span { color: #00AECC !important; font-weight: 800 !important; }

/* ════════════════════════════════════════════
   TÉLÉCHARGEMENTS
════════════════════════════════════════════ */
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-dl-bar {
  background: #F5F9FB !important;
  border-bottom: 1px solid #D4E4EB !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-dl-inner {
  padding: 12px 48px !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-dl-label {
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  color: #4A6070 !important;
  font-family: 'Montserrat', sans-serif !important;
  white-space: nowrap !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-dl-btns {
  display: flex !important;
  gap: 8px !important;
  flex-wrap: wrap !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-dl-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 7px !important;
  padding: 8px 14px !important;
  background: white !important;
  border: 1.5px solid #00AECC !important;
  color: #003D52 !important;
  font-family: 'Montserrat', sans-serif !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  transition: all .2s !important;
  border-radius: 2px !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-dl-btn svg { stroke: #00AECC !important; fill: none !important; flex-shrink: 0 !important; }
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-dl-btn:hover { background: #003D52 !important; border-color: #003D52 !important; color: white !important; }
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-dl-btn:hover svg { stroke: white !important; }

/* ════════════════════════════════════════════
   CONTENU
════════════════════════════════════════════ */
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-content {
  padding: 40px 48px 64px !important;
}

/* ════════════════════════════════════════════
   CALENDRIER DESKTOP
════════════════════════════════════════════ */
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-cal-wrap {
  overflow-x: auto !important;
  margin-bottom: 20px !important;
  border: 1px solid #D4E4EB !important;
  box-shadow: 0 2px 20px rgba(0,0,0,.05) !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-cal {
  display: grid !important;
  grid-template-columns: 56px repeat(7, 1fr) !important;
  min-width: 860px !important;
  background: white !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-cal-corner { background: #002535 !important; border-right: 1px solid rgba(255,255,255,.08) !important; }

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-cal-jour-header {
  background: #003D52 !important;
  padding: 14px 10px !important;
  text-align: center !important;
  border-right: 1px solid rgba(255,255,255,.08) !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-cal-jour-header:last-child { border-right: none !important; }

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-cal-jour-nom {
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 800 !important;
  font-size: 11px !important;
  color: white !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  display: block !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-cal-jour-cnt {
  font-size: 10px !important;
  color: rgba(255,255,255,.35) !important;
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 500 !important;
  display: block !important;
  margin-top: 3px !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-cal-heure-cell {
  background: #002535 !important;
  border-top: 1px solid rgba(255,255,255,.06) !important;
  border-right: 1px solid rgba(255,255,255,.08) !important;
  display: flex !important;
  align-items: flex-start !important;
  padding: 8px 6px 0 !important;
  min-height: 96px !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-cal-heure-label {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  color: rgba(255,255,255,.25) !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-cal-cell {
  border-top: 1px solid #D4E4EB !important;
  border-right: 1px solid #D4E4EB !important;
  padding: 6px !important;
  min-height: 96px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 5px !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-cal-cell:last-child { border-right: none !important; }

/* ── CARDS DESKTOP ── */
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-card {
  border-radius: 3px !important;
  cursor: pointer !important;
  transition: transform .15s, box-shadow .15s !important;
  position: relative !important;
  overflow: hidden !important;
  border-left: 3px solid transparent !important;
  text-decoration: none !important;
  display: block !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-card:hover { transform: scale(1.03) !important; box-shadow: 0 4px 16px rgba(0,0,0,.14) !important; z-index: 10 !important; }

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-card[data-cat="natation"] { background: rgba(0,119,168,.1) !important; border-left-color: #0077A8 !important; }
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-card[data-cat="fitness"]  { background: rgba(232,93,4,.09) !important; border-left-color: #E85D04 !important; }
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-card[data-cat="bienetre"] { background: rgba(123,94,167,.09) !important; border-left-color: #7B5EA7 !important; }
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-card[data-cat="famille"]  { background: rgba(46,139,87,.09) !important; border-left-color: #2E8B57 !important; }
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-card:not([data-cat]), .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-card[data-cat=""] { background: rgba(0,61,82,.06) !important; border-left-color: #003D52 !important; }

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-card-inner { padding: 8px 10px !important; }

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-card-titre {
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 800 !important;
  font-size: 10px !important;
  color: #003D52 !important;
  line-height: 1.2 !important;
  text-transform: uppercase !important;
  margin-bottom: 3px !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-card[data-cat="natation"] .ppl-card-titre { color: #0077A8 !important; }
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-card[data-cat="fitness"]  .ppl-card-titre { color: #C44D00 !important; }
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-card[data-cat="bienetre"] .ppl-card-titre { color: #6B4E96 !important; }
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-card[data-cat="famille"]  .ppl-card-titre { color: #206B40 !important; }

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-card-heure {
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 900 !important;
  font-size: 13px !important;
  color: #003D52 !important;
  letter-spacing: -.3px !important;
  line-height: 1 !important;
  margin-bottom: 5px !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-card-meta { display: flex !important; gap: 4px !important; flex-wrap: wrap !important; }

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-card-hover {
  position: absolute !important;
  inset: 0 !important;
  background: #003D52 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  opacity: 0 !important;
  transition: opacity .2s !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-card:hover .ppl-card-hover { opacity: 1 !important; }
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-card[data-cat="natation"]:hover .ppl-card-hover { background: #0077A8 !important; }
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-card[data-cat="fitness"]:hover  .ppl-card-hover { background: #E85D04 !important; }
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-card[data-cat="bienetre"]:hover .ppl-card-hover { background: #7B5EA7 !important; }
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-card[data-cat="famille"]:hover  .ppl-card-hover { background: #2E8B57 !important; }

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-card-hover-txt {
  font-size: 10px !important;
  font-weight: 700 !important;
  color: white !important;
  font-family: 'Montserrat', sans-serif !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
}

/* ── VUE MOBILE — masquée sur desktop ── */
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-mobile-view { display: none !important; }

/* ════════════════════════════════════════════
   BADGES
════════════════════════════════════════════ */
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-badge {
  font-size: 8px !important;
  font-weight: 700 !important;
  padding: 2px 6px !important;
  border-radius: 2px !important;
  font-family: 'Montserrat', sans-serif !important;
  letter-spacing: .5px !important;
  text-transform: uppercase !important;
  display: inline-block !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-badge-scolaire { background: rgba(0,174,204,.15) !important; color: #007A9A !important; }
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-badge-vacances  { background: rgba(242,97,26,.12) !important; color: #C44D00 !important; }
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-badge-toujours  { background: rgba(0,61,82,.08) !important; color: #003D52 !important; }

/* ── MESSAGE VIDE DESKTOP ── */
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-vide {
  padding: 60px 24px !important;
  text-align: center !important;
  background: white !important;
  border: 1px solid #D4E4EB !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 16px !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-vide p { font-size: 14px !important; color: #4A6070 !important; font-family: 'Montserrat', sans-serif !important; font-style: italic !important; }
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-vide button, .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-mvide button {
  padding: 10px 20px !important;
  background: #003D52 !important;
  color: white !important;
  border: none !important;
  font-family: 'Montserrat', sans-serif !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  border-radius: 2px !important;
}

/* ════════════════════════════════════════════
   LÉGENDE
════════════════════════════════════════════ */
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-legende {
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
  flex-wrap: wrap !important;
  margin-bottom: 36px !important;
  padding: 14px 20px !important;
  background: white !important;
  border: 1px solid #D4E4EB !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-legende-label {
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  color: #4A6070 !important;
  font-family: 'Montserrat', sans-serif !important;
  flex-shrink: 0 !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-legende-item {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  color: #4A6070 !important;
  font-family: 'Montserrat', sans-serif !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-legende-dot { width: 10px !important; height: 10px !important; border-radius: 2px !important; flex-shrink: 0 !important; }
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-dot-natation { background: #0077A8 !important; }
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-dot-fitness  { background: #E85D04 !important; }
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-dot-bienetre { background: #7B5EA7 !important; }
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-dot-famille  { background: #2E8B57 !important; }
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-legende-sep { width: 1px !important; height: 20px !important; background: #D4E4EB !important; flex-shrink: 0 !important; }

/* ════════════════════════════════════════════
   CTA
════════════════════════════════════════════ */
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-cta {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  padding-top: 32px !important;
  border-top: 1px solid #D4E4EB !important;
  flex-wrap: wrap !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-btn-resa {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 13px 28px !important;
  background: #F2611A !important;
  color: white !important;
  font-family: 'Montserrat', sans-serif !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  transition: background .2s !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-btn-resa:hover { background: #D4510F !important; color: white !important; }
.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-btn-resa svg { stroke: white !important; fill: none !important; flex-shrink: 0 !important; }

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-btn-tarifs {
  display: inline-flex !important;
  align-items: center !important;
  padding: 12px 24px !important;
  background: transparent !important;
  color: #003D52 !important;
  font-family: 'Montserrat', sans-serif !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  border: 2px solid #003D52 !important;
  transition: all .2s !important;
}

.elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-btn-tarifs:hover { background: #003D52 !important; color: white !important; }

/* ════════════════════════════════════════════
   RESPONSIVE MOBILE
════════════════════════════════════════════ */
@media (max-width: 768px) {

  /* Cache desktop, affiche mobile */
  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-filtres-bar { display: none !important; }
  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-filtres-mobile {
    display: block !important;
    background: white !important;
    border-bottom: 2px solid #00AECC !important;
    box-shadow: 0 4px 20px rgba(0,0,0,.06) !important;
    padding: 12px 16px !important;
    position: sticky !important;
    top: 0 !important;
    z-index: 90 !important;
  }
  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-cal-wrap { display: none !important; }
  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-mobile-view { display: block !important; }

  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-dl-inner { padding: 10px 16px !important; flex-direction: column !important; align-items: flex-start !important; }
  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-dl-btns { flex-direction: column !important; width: 100% !important; }
  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-dl-btn { width: 100% !important; }
  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-content { padding: 16px 16px 48px !important; }

  /* Blocs jours mobile */
  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-jour-bloc { margin-bottom: 20px !important; }

  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-jour-header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    background: #003D52 !important;
    padding: 10px 14px !important;
    margin-bottom: 8px !important;
  }

  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-jour-nom {
    font-size: 12px !important;
    font-weight: 800 !important;
    color: white !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    font-family: 'Montserrat', sans-serif !important;
  }

  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-jour-cnt {
    font-size: 10px !important;
    color: rgba(255,255,255,.4) !important;
    font-family: 'Montserrat', sans-serif !important;
  }

  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-mcards {
    display: flex !important;
    flex-direction: column !important;
    gap: 6px !important;
  }

  /* Cards mobile */
  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-mcard {
    display: flex !important;
    align-items: stretch !important;
    background: white !important;
    border: 1px solid #D4E4EB !important;
    overflow: hidden !important;
    text-decoration: none !important;
  }

  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-mcard-band {
    width: 4px !important;
    flex-shrink: 0 !important;
  }

  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-mcard[data-cat="natation"] .ppl-mcard-band { background: #0077A8 !important; }
  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-mcard[data-cat="fitness"]  .ppl-mcard-band { background: #E85D04 !important; }
  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-mcard[data-cat="bienetre"] .ppl-mcard-band { background: #7B5EA7 !important; }
  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-mcard[data-cat="famille"]  .ppl-mcard-band { background: #2E8B57 !important; }
  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-mcard:not([data-cat]), .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-mcard[data-cat=""] { background: rgba(0,61,82,.03) !important; }
  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-mcard:not([data-cat]) .ppl-mcard-band,
  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-mcard[data-cat=""] .ppl-mcard-band { background: #00AECC !important; }

  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-mcard-body {
    flex: 1 !important;
    padding: 10px 12px !important;
  }

  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-mcard-titre {
    font-size: 12px !important;
    font-weight: 800 !important;
    color: #003D52 !important;
    text-transform: uppercase !important;
    letter-spacing: .2px !important;
    margin-bottom: 4px !important;
    line-height: 1.2 !important;
    font-family: 'Montserrat', sans-serif !important;
  }

  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-mcard[data-cat="natation"] .ppl-mcard-titre { color: #0077A8 !important; }
  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-mcard[data-cat="fitness"]  .ppl-mcard-titre { color: #C44D00 !important; }
  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-mcard[data-cat="bienetre"] .ppl-mcard-titre { color: #6B4E96 !important; }
  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-mcard[data-cat="famille"]  .ppl-mcard-titre { color: #206B40 !important; }

  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-mcard-heure {
    font-size: 15px !important;
    font-weight: 900 !important;
    color: #003D52 !important;
    letter-spacing: -.3px !important;
    line-height: 1 !important;
    margin-bottom: 6px !important;
    font-family: 'Montserrat', sans-serif !important;
  }

  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-mbadge {
    display: inline-block !important;
    font-size: 8px !important;
    font-weight: 700 !important;
    padding: 2px 7px !important;
    border-radius: 2px !important;
    text-transform: uppercase !important;
    letter-spacing: .5px !important;
    font-family: 'Montserrat', sans-serif !important;
  }

  .elementor-3030 .elementor-element.elementor-element-c450df6 .badge-scolaire { background: rgba(0,174,204,.15) !important; color: #007A9A !important; }
  .elementor-3030 .elementor-element.elementor-element-c450df6 .badge-vacances  { background: rgba(242,97,26,.12) !important; color: #C44D00 !important; }
  .elementor-3030 .elementor-element.elementor-element-c450df6 .badge-toujours  { background: rgba(0,61,82,.08) !important; color: #003D52 !important; }

  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-mcard-arrow {
    display: flex !important;
    align-items: center !important;
    padding: 0 12px !important;
    color: rgba(0,61,82,.2) !important;
    font-size: 18px !important;
    flex-shrink: 0 !important;
  }

  /* Message vide mobile */
  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-mvide {
    text-align: center !important;
    padding: 40px 24px !important;
  }

  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-mvide p {
    font-size: 13px !important;
    color: #4A6070 !important;
    font-style: italic !important;
    margin-bottom: 16px !important;
    font-family: 'Montserrat', sans-serif !important;
  }

  /* CTA mobile */
  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-cta {
    flex-direction: column !important;
    padding-top: 20px !important;
  }

  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-btn-resa,
  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-btn-tarifs {
    width: 100% !important;
    justify-content: center !important;
  }

  /* Légende mobile */
  .elementor-3030 .elementor-element.elementor-element-c450df6 .ppl-legende { gap: 10px !important; padding: 12px !important; }
}/* End custom CSS */