.promotion-content {
  max-width: 900px;
  margin: auto;
  display: grid;
  gap: 2rem;
}

.recap-grid {
  display: grid;
  grid-template-columns: 2fr 1fr; /* infos à gauche, prix à droite */
  gap: 2rem;
  padding: 1.5rem;
  border: 1px solid #e0e0e0;
  border-radius: 12px;
  background: #fafafa;
}

.recap-infos h2 {
  margin-bottom: 1rem;
  font-size: 1.3rem;
  color: #333;
}

.recap-infos div,
.recap-prix div {
  margin: 0.5rem 0;
  font-size: 1rem;
}

.recap-prix {
  background: #fff;
  border: 1px solid #ddd;
  border-radius: 10px;
  padding: 1rem 1.5rem;
  display: grid;
  gap: 0.8rem;
  align-self: start; /* bloque la boîte en haut */
}

.recap-prix span {
  float: right;
  font-weight: bold;
}

.recap-prix .total {
  font-size: 1.2rem;
  color: #0077cc;
}

.cgv-checkbox {
  font-size: 0.9rem;
  color: #555;
}

.recap-actions {
  text-align: center;
}

.recap-actions .btn {
  padding: 12px 20px;
  font-size: 1rem;
  border-radius: 8px;
  background: #0077cc;
  color: #fff;
  border: none;
  cursor: pointer;
}

.cgv-erreur{
  outline: solid 1px red;
}


@media (max-width: 750px){
  .recap-grid{
    display: block;
  }

}
