.u-section-1 .u-sheet-1 {
  min-height: 358px;
}

.u-section-1 .u-text-1 {
  margin: 18px 32px 0 16px;
}

.u-section-1 .u-text-2 {
  margin: 22px 16px 0;
}

.u-section-1 .u-text-3 {
  margin: 0 32px 0 16px;
}

.u-section-1 .u-text-4 {
  margin: 0 48px 9px 16px;
}

@media (max-width: 1199px) {
  .u-section-1 .u-text-1 {
    margin-right: 0;
    margin-left: 0;
  }

  .u-section-1 .u-text-2 {
    margin-right: 0;
    margin-left: 0;
  }

  .u-section-1 .u-text-3 {
    margin-right: 0;
    margin-left: 0;
  }

  .u-section-1 .u-text-4 {
    margin-right: 0;
    margin-left: 0;
  }
}

@media (max-width: 991px) {
  .u-section-1 .u-sheet-1 {
    min-height: 462px;
  }

  .u-section-1 .u-text-1 {
    width: auto;
    margin-top: 17px;
    margin-left: 16px;
    margin-right: 16px;
  }

  .u-section-1 .u-text-2 {
    width: auto;
    margin-top: 23px;
    margin-left: 16px;
    margin-right: 16px;
  }

  .u-section-1 .u-text-3 {
    width: auto;
    margin-left: 16px;
    margin-right: 16px;
  }

  .u-section-1 .u-text-4 {
    width: auto;
    margin-left: 16px;
    margin-right: 16px;
  }
}

@media (max-width: 767px) {
  .u-section-1 .u-text-1 {
    margin-right: 0;
    margin-left: 0;
  }

  .u-section-1 .u-text-2 {
    margin-right: 0;
    margin-left: 0;
  }

  .u-section-1 .u-text-3 {
    margin-right: 0;
    margin-left: 0;
  }

  .u-section-1 .u-text-4 {
    margin-right: 0;
    margin-left: 0;
  }
}

@media (max-width: 575px) {
  .u-section-1 .u-sheet-1 {
    min-height: 704px;
  }

  .u-section-1 .u-text-1 {
    margin-left: 17px;
  }

  .u-section-1 .u-text-2 {
    margin-left: 17px;
  }

  .u-section-1 .u-text-3 {
    margin-left: 17px;
    margin-right: 17px;
  }

  .u-section-1 .u-text-4 {
    margin-left: 17px;
    margin-right: 17px;
  }
}.u-section-2 .u-sheet-1 {
  min-height: 400px;
}

.u-section-2 .u-custom-php-1 {
  min-height: 400px;
  margin-top: 0;
  margin-bottom: 0;
  height: auto;
}.stages-search { max-width: 1200px; margin: 0 auto 40px; padding: 20px; }
.stages-search h2 { color: #333; margin-bottom: 20px; }
.select-section { margin: 20px 0; }
.select-section label { font-weight: bold; display: block; margin-bottom: 8px; font-size: 1.1em; }
.stages-search select { 
    padding: 12px 15px; margin: 0; width: 280px; font-size: 16px; 
    border: 2px solid #ddd; border-radius: 8px; background: white;
    transition: border-color 0.3s;
}
.stages-search select:focus { border-color: #007cba; outline: none; box-shadow: 0 0 0 3px rgba(0,124,186,0.1); }
.stages-list { margin-top: 30px; }
.stage-item { 
    padding: 25px; margin: 20px 0; border-radius: 16px; border-left: 8px solid #007cba; 
    display: flex; flex-wrap: wrap; gap: 20px; align-items: center; position: relative; 
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}
.stage-libelle { font-size: 1.5em; font-weight: bold; flex: 1; min-width: 220px; }
.stage-header {
    display: flex;
    flex-direction: column;  /* Prix sous le nom */
    gap: 5px;
    flex: 1;
    min-width: 220px;
}
.stage-link {
    text-decoration: none;
    color: inherit;
    display: block;
}
.stage-link:hover .stage-libelle {
    text-decoration: underline;
    opacity: 0.9;
    transition: all 0.2s;
	color: black;
}
.stage-prix {
    font-size: 1.5em; 
    color: #d32f2f; 
    font-weight: bold;
    position: relative;
    top: 0;  
}
/* SURCHARGE SPÉCIFIQUE pour bg-AquaFun sinon prix écrit en rouge sur fond rouge*/
.stage-item.bg-AquaFun .stage-prix {
    color: white !important;
}
.stage-places-maj { 
    background: #e8f5e8; padding: 12px 18px; border-radius: 25px; font-weight: bold; 
    font-size: 1.1em; min-width: 140px; text-align: center;
	color: black;
}
.alert-places { 
    position: absolute; top: 15px; right: 15px; background: #d32f2f; color: white; 
    padding: 10px 15px; border-radius: 25px; font-weight: bold; font-size: 0.95em;
    box-shadow: 0 3px 8px rgba(0,0,0,0.2);
}
.alert-complet { background: #b71c1c !important; animation: pulse 2s infinite; }
@keyframes pulse { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.05); } }
/* Seulement sur écrans smartphones */
@media (max-width: 575px) {
  .alert-places {
    top: 60px;
	left: 70px;
	width: 230px;
  	word-wrap: break-word;
  }
}