/*
Theme Name:     Kadence-Child-gourmandisesludiques
Theme URI:      n/a
Template:       kadence
Author:         Studio Orizon
Author URI:     https://www.studio-orizon.fr
Description:    Child Theme Description
Version:        1.0
License:        GNU General Public License v3.0 (or later)
License URI:    https://www.gnu.org/licenses/gpl-3.0.html
*/
.so-ateliers-grid {
  display: grid;
  gap: 20px;
  grid-template-columns: repeat(3, 1fr); /* toujours 3 colonnes */
}
@media (max-width: 1024px) {
  .so-ateliers-grid {
    grid-template-columns: repeat(2, 1fr); /* tablette */
  }
}
@media (max-width: 640px) {
  .so-ateliers-grid {
    grid-template-columns: 1fr; /* mobile */
  }
}


.so-atelier-card {
	border: 1px solid #e5e7eb;
	border-radius: 12px;
	overflow: hidden;
	background: #fff;
	display: flex;
	flex-direction: column;
	transition: transform .15s ease, box-shadow .15s ease;
}
.so-atelier-card:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 20px rgba(0,0,0,.08);
}
.so-atelier-thumb {
	aspect-ratio: 16/9;
	width: 100%;
	object-fit: cover;
	display: block;
	background: #f3f4f6;
}
.so-atelier-body {
	padding: 16px;
	display: flex;
	flex-direction: column;
	gap: 8px;
	flex: 1;
}
.so-atelier-title {
	font-weight: 700;
	font-size: 1.05rem;
	line-height: 1.3;
	margin: 0;
}
.so-atelier-meta { 
	color: #6b7280; 
	font-size: .92rem; 
}
.so-atelier-price { 
	font-weight: 600; 
}
.so-atelier-spots { 
	font-size: .92rem; 
}
.so-atelier-footer { 
	padding: 0 16px 16px; 
}
.so-atelier-btn {
	display: inline-block;
	text-align: center;
	width: 100%;
	padding: 12px 16px;
	border-radius: 10px;
	background: #111827;
	color: #fff;
	text-decoration: none;
	font-weight: 600;
}
.so-atelier-btn:hover { 
	opacity: .92; 
}
.so-atelier-card img{
	width:100%;
	object-fit: cover;
	height: 230px;
	border-radius:8px;
}
.so-atelier-card{
	border: 1px solid #e5e7eb;
    border-radius: 10px;
    background: #f1f1f1;
}
.so-atelier-card h3{  
	color: #b24e93;
	font-size: 18px;
}
.formulairecontact label {
  display: block;          /* chaque champ sur une ligne */
  margin-bottom: 15px;     /* espacement entre les champs */
  font-weight: 600;        /* optionnel : met le label en gras */
}

.formulairecontact input[type="text"],
.formulairecontact input[type="email"],
.formulairecontact input[type="url"],
.formulairecontact input[type="tel"],
.formulairecontact input[type="number"],
.formulairecontact input[type="date"],
.formulairecontact input[type="file"],
.formulairecontact textarea,
.formulairecontact select {
  width: 100%;             /* largeur max */
  box-sizing: border-box;  /* évite le débordement avec padding/border */
  padding: 10px;           /* un peu de confort pour l’écriture */
  border: 1px solid #ddd;  /* style léger */
  border-radius: 5px;      /* arrondi optionnel */
  font-size: 16px;
}

.formulairecontact input[type="submit"] {
  width: 100%;             /* bouton sur toute la largeur */
  padding: 12px;
  background: #2B6CB0;     /* couleur de ton thème */
  color: #fff;
  border: none;
  border-radius: 6px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.2s ease;
}

.formulairecontact input[type="submit"]:hover {
  background: #215387;     /* foncé au survol */
}
