/* ============================= */
/*           catalogue           */
/* ============================= */

/* filtres : alignement et confort */
.shop-filters{
  align-items: center;
}

/* cartes : même rythme typographique */
.shop-item__body{
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* titre / desc / meta : éviter les écarts */
.shop-item__body h3{
  margin: 0;
  line-height: 1.25;
}

.shop-item__desc{
  margin: 0;
  line-height: 1.55;
}

/* meta : garder une base alignée */
.shop-item__meta{
  margin: 0;
}

.shop-item__meta div:first-child{
  border-top: 0;
  padding-top: 0;
}

/* CTA : toujours en bas de la carte */
.shop-item__body .btn,
.shop-item__body .btn-solid,
.shop-item__body .btn--ghost{
  margin-top: auto;
}

/* images : cohérence de hauteur en desktop */
@media (min-width: 901px){
  .shop-item__media{
    min-height: 220px;
  }
}

/* mobile : un peu plus d’air */
@media (max-width: 900px){
  .shop-item__body{
    padding: 16px;
  }
}
/* ============================= */
/*           shop grid           */
/* ============================= */

/* Grille du shop (2 colonnes desktop, 1 colonne mobile) */
.shop-grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  margin-top: 18px;
}

@media (min-width: 860px){
  .shop-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* ============================= */
/*            shop card          */
/* ============================= */

.shop-card{
  border: 1px solid rgba(0,0,0,0.12);
  border-radius: 16px;
  overflow: hidden;
  background: rgba(255,255,255,0.02);
}

.shop-card__img{
  aspect-ratio: 3 / 2;
}

.shop-card__img img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Assure que le bas du contenu respecte le radius */
.shop-card__body{
  padding: 14px 14px 16px;
  border-bottom-left-radius: 16px;
  border-bottom-right-radius: 16px;
}
/* Catalogue sections*/
#catalogue.section,
#Articles-Anciens.section,
#Ecrits-Livres.section,
#Editions-limitees.section{
  padding-left: 18px;
  padding-right: 18px;
}

/* ============================= */
/*         demande d'étude       */
/* ============================= */

.demande-etude .contact-section {
  max-width: 760px;
}

.demande-etude .form-group {
  margin-bottom: 18px;
}

/* libellés : harmonisation sur cette page uniquement */
.demande-etude .contact-form label,
.demande-etude .label-inline {
  font-size: 0.9rem;
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: 0.02em;
  text-transform: none;
  margin-bottom: 2px;
}

/* radios : une colonne, alignement propre */
.demande-etude .radio-group {
  display: grid;
  grid-template-columns: 1fr;
  margin-top: 12px;
  row-gap: 12px;
}

.demande-etude .radio-option {
  display: grid;
  grid-template-columns: 18px 1fr;
  column-gap: 8px;
  align-items: start;
  line-height: 1.35;
  margin: 0;
  cursor: pointer;
}

.demande-etude .radio-option input[type="radio"] {
  margin: 3px 0 0 0;
}

.demande-etude .radio-option span {
  display: block;
  text-transform: none;
  letter-spacing: normal;
}

/* optionnel : très légère atténuation des libellés */
.demande-etude .contact-form label {
  opacity: 0.95;
}

/* baseline du hero */
.hero__content .baseline {
  text-transform: none;
  font-style: italic;
  font-size: 1.05rem;
  letter-spacing: normal;
  margin-top: 0.6rem;
  opacity: 0.9;
  text-align: center;
}
/* espace sous les titres de groupes (@ Votre demande concerne, etc.) */
.demande-etude .form-group > label {
  display: block;
  margin-bottom: 10px;
}


/* alignement des cartes */

.domain{
  display: flex;
  flex-direction: column;
}

.domain h3{
  margin-bottom: 1rem;
}

.domain p{
  margin-top: auto;
}
.domain{
  display: flex;
  flex-direction: column;
  min-height: 220px; /* ajuste selon ton rendu */
}

/* ============================= */
/*        CONTACT        */
/* ============================= */
.contact-section label,
.contact-section .label-inline {
  text-transform: none;
  letter-spacing: normal;
}
/* =========================
   A PROPOS
========================= */

.genese-intro{
  font-size:1.35rem;
  line-height:1.7;
  max-width:60ch;
  margin:0 0 28px;
}

.genese-intro strong{
  font-weight:700;
  letter-spacing:.03em;
}

.genese-transition{
  font-style:italic;
  margin:8px 0 32px 28px;   /* léger décalage à droite */
  color:var(--muted);
}

#a-propos h2{
  color:#6f4a2c;
}

#a-propos h3{
  color:#7a5231;
  margin-top:34px;
}
/* =========================
   Titres de chapitre
========================= */

#a-propos h3{
  margin-top:46px;
  margin-bottom:12px;
  color:#7a5231;            /* cuivre chaud */
  font-weight:600;
  letter-spacing:.04em;
  font-size:1.1rem;
}

/* petit trait discret au-dessus */
#a-propos h3::before{
  content:"";
  display:block;
  width:36px;
  height:1px;
  background:rgba(122,82,49,.35);
  margin-bottom:10px;
}
/* =========================
   Signature Carnets d'Atelier
========================= */

.signature{
  margin-top:48px;
  font-size:1.05rem;
  color:#7a5231;
  letter-spacing:.08em;
}

.signature span{
  display:block;
  margin-top:4px;
  font-size:.85rem;
  color:var(--muted);
  letter-spacing:.06em;
}
/* amélioration visuelle du formulaire */

.demande-etude .contact-form input,
.demande-etude .contact-form textarea,
.demande-etude .contact-form select{
  padding: 2px 12px;
  border-radius: 4px;
}

.demande-etude .contact-form input:focus,
.demande-etude .contact-form textarea:focus,
.demande-etude .contact-form select:focus{
  outline: none;
  border-color: #8a8a8a;
  box-shadow: 0 0 0 1px rgba(0,0,0,0.08);
}

/* radios légèrement plus respirants */

.demande-etude .radio-option{
  padding: 2px 0;
}
/*CITATIONS*/
.transition .quote{
  font-style: italic;
  margin: 0 0 3rem 12%;
}

.transition .quote-author{
  font-size: .9em;
  opacity: .8;
  margin-left: .5rem;
}
/*PAGE PRO*/
.invitation-contact{
color:#774b31;
}

/*RGPD*/
.rgpd-consent{
  margin-top:22px;
  padding-top:12px;
  border-top:1px solid rgba(43,31,24,.12);
}

.rgpd-text{
  margin:0 0 10px 0;
  font-size:0.75rem;
  line-height:1.45;
  color:var(--muted);
}

.rgpd-checkbox{
  display:flex;
  align-items:flex-start;
  gap:8px;
  cursor:pointer;
}


.rgpd-checkbox input[type="checkbox"]{
  width:15px;
  height:15px;
  margin-top:2px;
  accent-color:#2b1f18;
}

.rgpd-checkbox span{
  font-size:0.75rem;
  line-height:1.4;
  letter-spacing:normal;
  text-transform:none;
}
/*anti-spam*/
.hp-field{
  position: absolute;
  left: -9999px;
}
/* ============================= */
/*        Librairie      */
/* ============================= */

.librairie-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:20px;
  margin-top:20px;
}

@media (min-width:860px){
  .librairie-grid{
    grid-template-columns:repeat(2,1fr);
  }
}

.librairie-item{
  border:1px solid rgba(0,0,0,0.12);
  border-radius:16px;
  padding:18px;
  background:rgba(255,255,255,0.04);
}

.librairie-item h3{
  margin-top:0;
}

.librairie-meta{
  font-size:0.85rem;
  color:var(--muted);
  margin-bottom:10px;
}

/* ============================= */
/*       offre pro detail        */
/* ============================= */

.offre-pro-detail-page .offer-detail{
  max-width: 800px;
}
.offre-pro-detail-page{
  padding:20px 20px;
}

.offre-pro-detail-page .paper{
  background:#ffffff;
  padding:42px 36px;
  border:1px solid rgba(43,31,24,.12);
  box-shadow:0 10px 30px rgba(0,0,0,.08);
  max-width:860px;
  margin:auto;
}

.offer-detail__header{
  text-align: center;
  border-bottom: 2px solid var(--walnut);
  padding-bottom: 20px;
  margin-bottom: 40px;
}

.offer-detail__header h1{
  margin: 0;
  font-size: clamp(2rem, 3vw, 2rem);
  letter-spacing: 0.14em;
  color: var(--walnut);
}

.offer-detail__subtitle{
  margin: 10px 0 6px;
  font-style: italic;
  font-size: 1.15rem;
  color: var(--copper);
}

.offer-detail__tagline{
  margin: 0;
  font-weight: 700;
  text-transform: uppercase;
  font-size: 0.9rem;
  letter-spacing: 0.04em;
}

.offer-detail__block + .offer-detail__block,
.offer-detail__box{
  margin-top: 40px;
}

.offre-pro-detail-page .offer-detail h2{
  color: var(--walnut);
  border-left: 4px solid var(--copper);
  padding-left: 15px;
  margin-top: 0;
  margin-bottom: 18px;
  font-size: 1.35rem;
}

.offer-detail__intro-quote{
  font-size: 1.1rem;
  color: #8a3d2f;
  font-weight: 700;
  margin-bottom: 20px;
}

.offer-detail__list{
  list-style: none;
  padding-left: 0;
  margin: 0 0 18px;
}

.offer-detail__list li{
  position: relative;
  padding-left: 22px;
  margin-bottom: 12px;
}

.offer-detail__list li::before{
  content: "•";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--copper);
  font-weight: 700;
}

.offer-detail__cards{
  list-style: none;
  padding-left: 0;
  margin: 0;
}

.offer-detail__cards li{
  background: rgba(255,255,255,0.35);
  padding: 15px 15px 15px 18px;
  border-radius: 6px;
  border-left: 3px solid var(--walnut);
  margin-bottom: 12px;
}

.offer-detail__cards strong{
  color: var(--walnut);
  display: block;
  margin-bottom: 5px;
}

.offer-detail__cards span{
  display: block;
}

.offer-detail__box{
  background: rgba(255,255,255,0.35);
  padding: 25px;
  border-radius: 8px;
  border: 1px solid rgba(43,31,24,.12);
}

.offer-detail__closing{
  margin-top: 48px;
  text-align: center;
  font-weight: 700;
  font-size: 1.08rem;
  color: var(--walnut);
}

.offer-detail__cta {
      margin-top: 34px;
      padding: 22px;
      border: 1px solid #cbb89b;
      background: #f5e7d3;
    }



@media (max-width: 600px){
  .offer-detail__header{
    margin-bottom: 30px;
  }

  .offer-detail__subtitle{
    font-size: 1.05rem;
  }

  .offer-detail__tagline{
    font-size: 0.82rem;
  }

  .offre-pro-detail-page .offer-detail h2{
    font-size: 1.2rem;
  }

  .offer-detail__box{
    padding: 18px;
  }
}
