/* ================================================================
   YOOZI — LUXURY POLISH
   Typographie éditoriale, spacing palace, micro-interactions,
   bandeaux éthiques, manifeste, rituels, testimonials, FAQ.
   ================================================================ */

/* === TYPOGRAPHIE ÉDITORIALE === */

/* Typographie éditoriale "serif signature" — baseline sans !important.
   Spécificité abaissée via :where() pour que Blocksy Customizer (H1..H6) ET
   tout widget Elementor Heading posé dans ces zones gagnent sans effort. */
:where(.single-product .product_title,
       .yoozi-editorial h1,
       .yoozi-editorial h2,
       .yoozi-manifeste-title,
       .yoozi-rituels-title,
       .yoozi-why-title,
       .yoozi-compare-title,
       .yoozi-faq-title) {
  font-family: 'Nunito', sans-serif;
  font-weight: 500;
  letter-spacing: -0.015em;
  line-height: 1.1;
}

.single-product .product_title {
  font-size: clamp(2.25rem, 4.5vw, 3.75rem);
  margin-bottom: 0.4em;
}

.yoozi-editorial .eyebrow,
.yoozi-eyebrow {
  display: inline-block;
  font-family: 'Nunito', sans-serif;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--yoozi-gold);
  margin-bottom: 1em;
}

/* === SPACING LUXURY === */

.yoozi-section {
  padding: 80px 24px;
  max-width: 1200px;
  margin: 0 auto;
}

@media (max-width: 767px) {
  .yoozi-section { padding: 48px 20px; }
}

/* === BANDEAU ÉTHIQUE (4 piliers) ===
   En Elementor, les .yoozi-ethics-item sont rendues dans un widget HTML sans wrapper
   → on cible le parent direct des items via :has() pour appliquer le grid */

.yoozi-ethics-band {
  background: var(--yoozi-cream);
  border-top: 1px solid #E8E4DE;
  border-bottom: 1px solid #E8E4DE;
  padding: 56px 0;
}

.yoozi-ethics-band .elementor-container {
  max-width: 1200px !important;
  padding: 0 24px;
}

/* La règle de grid est appliquée plus bas via .yoozi-ethics-inner > .elementor-container */

.yoozi-ethics-item {
  text-align: center;
}

.yoozi-ethics-item svg {
  width: 36px;
  height: 36px;
  margin: 0 auto 14px;
  display: block;
  stroke: var(--yoozi-gold);
  fill: none;
  stroke-width: 1.5;
}

.yoozi-ethics-item h4 {
  font-family: 'Nunito', sans-serif;
  font-weight: 700;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--yoozi-dark);
  margin: 0 0 6px;
}

.yoozi-ethics-item p {
  font-size: 13px;
  color: var(--yoozi-grey);
  line-height: 1.6;
  margin: 0;
}

@media (max-width: 767px) {
  .yoozi-ethics-band { padding: 36px 0; }
  .yoozi-ethics-band .elementor-container { padding: 0 16px; }
}

/* === BANDE "NOTRE PRINCIPE POUR PROPOSER UNE BOISSON AVEC 0° D'ALCOOL" ===
   Section 1ecced2.
   IMPORTANT : seul le H2 garde une max-width pour la lisibilité du titre.
   Les widgets text-editor sont LIBRES (full width de la colonne) pour que
   l'alignement (left/center/right) défini dans Elementor s'applique
   visuellement sur toute la largeur sans espace résiduel. */
.elementor-element-1ecced2 .elementor-widget-heading {
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

/* Text-editor : largeur libre, alignement éditable depuis Elementor */
.elementor-element-1ecced2 .elementor-widget-text-editor {
  max-width: 100%;
  margin-left: 0;
  margin-right: 0;
}

/* === MANIFESTE 0,0% === */

.yoozi-manifeste {
  position: relative;
  background: var(--yoozi-cream);
  padding: 96px 24px;
  text-align: center;
  overflow: hidden;
  isolation: isolate;
}

/* Fond Provence vineyard en filigrane — ambiance chaleureuse, éditoriale */
.yoozi-manifeste::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url('http://localhost:8088/wp-content/uploads/2026/03/Vignes-Bouches-du-Rhone.jpg');
  background-size: cover;
  background-position: center;
  opacity: 0.12;
  filter: saturate(0.85) contrast(1.05);
  z-index: -2;
  transition: opacity 1.2s ease;
}

.yoozi-manifeste::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at center, transparent 30%, var(--yoozi-cream) 85%);
  z-index: -1;
  pointer-events: none;
}

.yoozi-manifeste > * {
  position: relative;
  z-index: 1;
}

.yoozi-manifeste-title {
  font-size: clamp(2rem, 3.8vw, 3.25rem);
  color: var(--yoozi-dark);
  max-width: 820px;
  margin: 0 auto 24px;
}

.yoozi-manifeste-body {
  max-width: 640px;
  margin: 0 auto;
  font-size: 17px;
  line-height: 1.85;
  color: var(--yoozi-dark);
}

.yoozi-manifeste-signature {
  display: inline-block;
  margin-top: 28px;
  font-family: 'Nunito', sans-serif;
  font-style: italic;
  font-size: 18px;
  color: var(--yoozi-gold);
}

/* === RITUELS DE SERVICE === */

.yoozi-rituels {
  padding: 80px 24px;
}

.yoozi-rituels-title {
  text-align: center;
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  margin-bottom: 48px;
}

.yoozi-rituels-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  max-width: 1200px;
  margin: 0 auto;
}

.yoozi-rituel-card {
  background: #fff;
  border: 1px solid #EFE8DA;
  overflow: hidden;
  text-align: center;
  transition: transform 400ms ease, box-shadow 400ms ease, border-color 400ms ease;
  display: flex;
  flex-direction: column;
}

/* === NOUVELLE STRUCTURE RITUELS — Elementor natif (éditable par widget) ===
   4 colonnes Elementor avec image + heading + text-editor chacune.
   La classe yoozi-rituel-col est sur la column, les widgets ont leurs
   classes yoozi-rituel-img / yoozi-rituel-title / yoozi-rituel-desc. */
.yoozi-rituels-inner .elementor-column {
  background: #fff;
  border: 1px solid #EFE8DA;
  overflow: hidden;
  transition: transform 400ms ease, box-shadow 400ms ease, border-color 400ms ease;
}

.yoozi-rituels-inner .elementor-column:hover {
  transform: translateY(-6px);
  box-shadow: 0 28px 56px -24px rgba(31, 31, 31, 0.22);
  border-color: var(--yoozi-gold);
}

.yoozi-rituels-inner .yoozi-rituel-img {
  margin: 0 !important;
}

.yoozi-rituels-inner .yoozi-rituel-img .elementor-widget-container {
  overflow: hidden;
  aspect-ratio: 4 / 3;
  background: var(--yoozi-cream, #faf7ef);
}

.yoozi-rituels-inner .yoozi-rituel-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 900ms cubic-bezier(0.2, 0.8, 0.2, 1), filter 600ms ease;
  filter: saturate(0.92);
}

.yoozi-rituels-inner .elementor-column:hover .yoozi-rituel-img img {
  transform: scale(1.06);
  filter: saturate(1.05);
}

.yoozi-rituels-inner .yoozi-rituel-title .elementor-heading-title {
  font-family: 'Nunito', sans-serif;
  font-style: normal;
}

.yoozi-rituels-inner .yoozi-rituel-desc p {
  margin: 0;
}

.yoozi-rituel-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 28px 56px -24px rgba(31, 31, 31, 0.22);
  border-color: var(--yoozi-gold);
}

.yoozi-rituel-media {
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--yoozi-cream, #faf7ef);
}

.yoozi-rituel-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 900ms cubic-bezier(0.2, 0.8, 0.2, 1), filter 600ms ease;
  filter: saturate(0.92);
}

.yoozi-rituel-card:hover .yoozi-rituel-media img {
  transform: scale(1.06);
  filter: saturate(1.05);
}

.yoozi-rituel-body {
  padding: 28px 24px 32px;
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.yoozi-rituel-card .yoozi-rituel-ic {
  width: 36px;
  height: 36px;
  margin: 0 auto 12px;
  color: var(--yoozi-gold);
  transition: transform 500ms ease;
}

.yoozi-rituel-card:hover .yoozi-rituel-ic {
  transform: translateY(-2px) scale(1.08);
}

.yoozi-rituel-card h3 {
  font-family: 'Nunito', sans-serif;
  font-size: 24px;
  font-weight: 500;
  margin: 0 0 8px;
}

.yoozi-rituel-card p {
  font-size: 14px;
  line-height: 1.65;
  color: var(--yoozi-grey);
  margin: 0;
}

@media (max-width: 767px) {
  .yoozi-rituels-grid { grid-template-columns: 1fr 1fr; }
}

/* === TESTIMONIALS === */

.yoozi-testimonials {
  background: var(--yoozi-cream);
  padding: 96px 24px;
}

/* Le grid est appliqué à .yoozi-testimonials-grid > .elementor-container plus bas
   (l'ancienne règle qui mettait grid sur la section a été retirée car elle
   forçait le container interne à occuper 1/3 de la largeur seule) */

.yoozi-testimonial {
  background: #fff;
  padding: 40px 32px;
  border-top: 3px solid var(--yoozi-gold);
}

.yoozi-testimonial-quote {
  font-family: 'Nunito', sans-serif;
  font-style: italic;
  font-size: 20px;
  line-height: 1.55;
  color: var(--yoozi-dark);
  margin: 0 0 20px;
}

.yoozi-testimonial-quote::before {
  content: '«\00a0';
  font-family: 'Nunito', sans-serif;
  font-style: italic;
  font-weight: 500;
  font-size: 1em;
  color: var(--yoozi-gold);
  margin-right: 2px;
}

.yoozi-testimonial-quote::after {
  content: '\00a0»';
  font-family: 'Nunito', sans-serif;
  font-style: italic;
  font-weight: 500;
  color: var(--yoozi-gold);
  margin-left: 2px;
}

.yoozi-testimonial-author {
  font-family: 'Nunito', sans-serif;
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--yoozi-gold);
}

.yoozi-testimonial-context {
  display: block;
  margin-top: 4px;
  font-weight: 400;
  letter-spacing: 0.04em;
  text-transform: none;
  color: var(--yoozi-grey);
  font-size: 13px;
}

/* Mobile testimonials override est géré dans le bloc principal plus bas */

/* === WHY 0,0% (3 raisons chiffrées) === */

.yoozi-why {
  padding: 96px 24px;
  max-width: 1100px;
  margin: 0 auto;
  text-align: center;
}

.yoozi-why-title {
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  margin-bottom: 48px;
}

.yoozi-why-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 48px;
}

.yoozi-why-stat {
  font-family: 'Nunito', sans-serif;
  font-size: clamp(3rem, 6vw, 4.5rem);
  font-weight: 500;
  color: var(--yoozi-gold);
  line-height: 1;
  margin-bottom: 12px;
}

.yoozi-why-label {
  font-family: 'Nunito', sans-serif;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--yoozi-dark);
  font-weight: 700;
  margin-bottom: 8px;
}

.yoozi-why-desc {
  font-size: 14px;
  color: var(--yoozi-grey);
  line-height: 1.65;
}

@media (max-width: 767px) {
  .yoozi-why-grid { grid-template-columns: 1fr; gap: 36px; }
}

/* === TABLEAU COMPARATIF YOOZI VS AUTRES === */

.yoozi-compare {
  max-width: 1000px;
  margin: 0 auto;
  padding: 72px 24px;
}

.yoozi-compare-title {
  text-align: center;
  font-size: clamp(1.75rem, 3vw, 2.25rem);
  margin-bottom: 32px;
}

.yoozi-compare-table {
  width: 100%;
  border-collapse: collapse;
  font-family: 'Nunito', sans-serif;
  font-size: 14px;
}

.yoozi-compare-table thead th {
  padding: 16px 12px;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--yoozi-grey);
  border-bottom: 2px solid #EFE8DA;
  text-align: center;
}

.yoozi-compare-table thead th.is-yoozi {
  color: var(--yoozi-gold);
  background: var(--yoozi-cream);
}

.yoozi-compare-table tbody td {
  padding: 14px 12px;
  border-bottom: 1px solid #EFE8DA;
  color: var(--yoozi-dark);
  text-align: center;
}

.yoozi-compare-table tbody td:first-child {
  text-align: left;
  color: var(--yoozi-grey);
  font-weight: 600;
}

.yoozi-compare-table tbody td.is-yoozi {
  background: var(--yoozi-cream);
  color: var(--yoozi-dark);
  font-weight: 700;
}

/* === FAQ === */

.yoozi-faq {
  max-width: 820px;
  margin: 0 auto;
  padding: 80px 24px;
}

.yoozi-faq-title {
  text-align: center;
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  margin-bottom: 32px;
}

/* Style legacy <details> (si le shortcode PHP est utilisé) */
.yoozi-faq details {
  border-bottom: 1px solid #EFE8DA;
  padding: 18px 0;
}

.yoozi-faq summary {
  cursor: pointer;
  list-style: none;
  font-family: 'Nunito', sans-serif;
  font-weight: 700;
  font-size: 17px;
  color: var(--yoozi-dark);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
}

.yoozi-faq summary::-webkit-details-marker { display: none; }

.yoozi-faq summary::after {
  content: '+';
  color: var(--yoozi-gold);
  font-size: 22px;
  font-weight: 400;
  transition: transform 300ms ease;
}

.yoozi-faq details[open] summary::after {
  content: '–';
}

.yoozi-faq details p {
  margin: 12px 0 0;
  font-size: 15px;
  line-height: 1.7;
  color: var(--yoozi-grey);
}

/* Style widget Elementor toggle (version migrée Elementor native) */
.yoozi-faq .elementor-toggle {
  border: none;
  max-width: 820px;
  margin: 0 auto;
}

.yoozi-faq .elementor-toggle-item {
  border-bottom: 1px solid #EFE8DA !important;
  border-top: none !important;
  border-left: none !important;
  border-right: none !important;
  background: transparent !important;
  padding: 0 !important;
}

/* FAQ : on garde !important uniquement sur les propriétés STRUCTURELLES nécessaires
   pour contrer les défauts d'Elementor Toggle (padding/bg/border/display). La typo
   reste éditable via Elementor (Style > Typography) ou Blocksy Customizer. */
.yoozi-faq .elementor-tab-title {
  font-weight: 700;
  font-size: 17px;
  color: var(--yoozi-dark);
  padding: 18px 0 !important;
  background: transparent !important;
  border: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
}

.yoozi-faq .elementor-tab-title .elementor-toggle-title {
  color: var(--yoozi-dark);
  text-decoration: none;
  flex: 1;
}

.yoozi-faq .elementor-tab-title .elementor-toggle-icon {
  color: var(--yoozi-gold);
  margin-left: auto !important;
  margin-right: 0 !important;
  order: 2;
}

.yoozi-faq .elementor-tab-title .elementor-toggle-icon svg {
  fill: var(--yoozi-gold);
  width: 16px;
  height: 16px;
}

.yoozi-faq .elementor-tab-content {
  padding: 0 0 18px !important;
  font-size: 15px;
  line-height: 1.7;
  color: var(--yoozi-grey);
  background: transparent !important;
  border: none !important;
}

.yoozi-faq .elementor-tab-content p {
  margin: 0;
  color: inherit;
}

/* === BADGES RÉASSURANCE ENRICHIS (6 items avec SVG line-art) === */

.yoozi-reassurance {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  padding: 28px 20px;
  border-top: 1px solid #EFE8DA;
  border-bottom: 1px solid #EFE8DA;
  margin: 32px 0;
  background: #fff;
}

/* Sur la fiche produit : 50% gauche, 2 rangées de 3 */
body.single-product .yoozi-reassurance {
  grid-template-columns: repeat(3, 1fr);
  max-width: 50%;
  margin-right: auto;
  margin-left: 0;
}

.yoozi-reassurance-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  text-align: center;
  font-family: 'Nunito', sans-serif;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--yoozi-dark);
}

.yoozi-reassurance-ic svg {
  width: 26px;
  height: 26px;
  color: var(--yoozi-gold);
  display: block;
  stroke-linecap: round;
  stroke-linejoin: round;
}

body[class*="product-"] .yoozi-reassurance-ic svg {
  color: var(--product-color);
}

@media (max-width: 1024px) {
  body.single-product .yoozi-reassurance {
    max-width: 70%;
  }
}
@media (max-width: 767px) {
  body.single-product .yoozi-reassurance {
    max-width: 100%;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
    padding: 22px 12px;
  }
}
@media (max-width: 480px) {
  body.single-product .yoozi-reassurance {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* === Suffixe prix "l'unité" / "le pack x6" === */
.yoozi-price-unit {
  color: #999;
  font-size: 0.7em;
  font-weight: 400;
  letter-spacing: 0.02em;
  margin-left: 6px;
  vertical-align: middle;
}

/* === FICHE TECHNIQUE — colonne Rituel de service === */

.yoozi-data-rituel p {
  font-size: 13px;
  line-height: 1.55;
  margin-bottom: 12px;
}

.yoozi-data-rituel p strong {
  display: inline-block;
  font-family: 'Nunito', sans-serif;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--yoozi-gold);
  font-weight: 700;
  margin-bottom: 2px;
}

body[class*="product-"] .yoozi-data-rituel p strong {
  color: var(--product-color-dark);
}

/* === FICHE TECHNIQUE LAYOUT 4 colonnes === */

@media (min-width: 1000px) {
  .yoozi-product-data {
    gap: 32px;
    padding: 48px;
    box-shadow: 0 24px 60px -30px rgba(31, 31, 31, 0.15);
  }
  .yoozi-data-col { flex: 1 1 22%; }
}

/* === HOMEPAGE — Gamme 4 bouteilles full-width
   (Elementor gère le stretching via la classe .elementor-section-full_width ;
   on ne force que le container interne pour qu'il n'y ait aucun cap) */

.yoozi-bottles-row.elementor-section-full_width > .elementor-container,
.yoozi-bottles-row > .elementor-container {
  max-width: 100% !important;
  width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.yoozi-bottles-row .elementor-column.yoozi-product-card {
  padding: 40px 24px !important;
}

.yoozi-bottles-row .elementor-column.yoozi-product-card {
  padding: 32px 16px;
  cursor: default;
}

.yoozi-bottles-row .yoozi-bottle-wrap {
  max-width: 280px !important;
  margin: 0 auto 18px !important;
  position: relative;
}

/* Image bouteille simplement masquée en cercle — pas de fond, pas de halo.
   Les coins transparents du PNG rendent l'effet invisible au repos ; seule l'image conserve sa forme naturelle. */
.yoozi-bottles-row .yoozi-bottle-wrap img {
  border-radius: 50% !important;
  background: transparent !important;
}

.yoozi-bottles-row .yoozi-product-card h3,
.yoozi-bottles-row .yoozi-product-card h3 a {
  font-family: 'Nunito', sans-serif;
  font-size: clamp(1.4rem, 1.6vw, 1.9rem);
  font-weight: 500;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  margin: 6px 0 4px;
  color: var(--yoozi-ink);
}

.yoozi-bottles-row .yoozi-product-card .elementor-heading-title {
  font-size: clamp(0.95rem, 1.1vw, 1.125rem);
}

.yoozi-bottles-row .yoozi-product-card:hover .yoozi-bottle-wrap {
  transform: translateY(-6px);
}

.yoozi-bottles-row .yoozi-bottle-wrap {
  transition: transform 500ms cubic-bezier(0.2, 0.9, 0.3, 1);
}

/* Séparateur vertical subtil entre les bouteilles (désactivé sur la dernière) */
.yoozi-bottles-row .elementor-column.yoozi-product-card + .yoozi-product-card::before {
  content: '';
  position: absolute;
  left: 0;
  top: 20%;
  bottom: 20%;
  width: 1px;
  background: linear-gradient(to bottom, transparent, #E8E4DE 50%, transparent);
  pointer-events: none;
}

.yoozi-bottles-row .elementor-column.yoozi-product-card {
  position: relative;
}

@media (max-width: 1023px) {
  .yoozi-bottles-row .elementor-container {
    flex-wrap: wrap !important;
  }
  .yoozi-bottles-row .elementor-column.yoozi-product-card {
    width: 50% !important;
    flex: 0 0 50% !important;
  }
  .yoozi-bottles-row .elementor-column.yoozi-product-card + .yoozi-product-card::before {
    display: none;
  }
}

@media (max-width: 600px) {
  .yoozi-bottles-row .elementor-column.yoozi-product-card {
    width: 100% !important;
    flex: 0 0 100% !important;
  }
}

/* === LONG DESCRIPTION FICHE PRODUIT === */

.yoozi-long-desc {
  max-width: 1100px;
  margin: 48px auto;
  padding: 0 24px;
  font-family: 'Nunito', sans-serif;
}

.yoozi-long-desc h2 {
  font-family: 'Nunito', sans-serif;
  font-weight: 500;
  font-size: clamp(1.75rem, 3.2vw, 2.5rem);
  line-height: 1.15;
  letter-spacing: -0.015em;
  color: var(--yoozi-ink);
  margin: 56px 0 20px;
}

.yoozi-long-desc h3 {
  font-family: 'Nunito', sans-serif;
  font-weight: 700;
  font-size: 18px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--product-color, var(--yoozi-gold));
  margin: 40px 0 12px;
}

.yoozi-long-desc p {
  font-size: 17px;
  line-height: 1.75;
  color: var(--yoozi-ink);
  margin: 0 0 18px;
}

.yoozi-long-desc ul {
  list-style: none;
  padding: 0;
  margin: 0 0 24px;
}

.yoozi-long-desc ul li {
  font-size: 16px;
  line-height: 1.65;
  padding: 6px 0;
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.yoozi-long-desc ul li::before {
  content: '';
  width: 7px;
  height: 7px;
  min-width: 7px;
  border-radius: 50%;
  background: var(--product-color, var(--yoozi-gold));
  flex-shrink: 0;
  margin-top: 0.6em;
}

.yoozi-long-desc .yoozi-cta-block {
  background: var(--yoozi-cream);
  padding: 32px 36px;
  margin: 48px 0;
  border-left: 4px solid var(--product-color, var(--yoozi-gold));
}

.yoozi-long-desc .yoozi-cta-block p {
  margin: 0 0 12px;
}

.yoozi-long-desc .yoozi-ps {
  font-style: italic;
  color: var(--yoozi-grey);
  font-size: 14px;
}

/* ================================================================
   PAGE /yousee/ — hommage au chat
   ================================================================ */

.yousee-hero {
  text-align: center;
  padding: 96px 24px 48px;
  max-width: 820px;
  margin: 0 auto;
}

.yousee-title {
  font-family: 'Nunito', sans-serif;
  font-weight: 500;
  font-size: clamp(3.5rem, 8vw, 6rem);
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--yoozi-ink);
  margin: 12px 0 16px;
}

.yousee-tagline {
  font-family: 'Nunito', sans-serif;
  font-style: italic;
  font-size: clamp(1.25rem, 2vw, 1.75rem);
  color: var(--yoozi-gold);
  margin: 0;
}

.yousee-story {
  padding: 72px 24px;
  max-width: 1200px;
  margin: 0 auto;
  background: var(--yoozi-cream);
}

.yousee-story-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 72px;
  align-items: center;
}

.yousee-story-text h2,
.yousee-values-title,
.yousee-provenance h2 {
  font-family: 'Nunito', sans-serif;
  font-weight: 500;
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1.1;
  letter-spacing: -0.015em;
  margin: 12px 0 20px;
  color: var(--yoozi-ink);
}

.yousee-story-text p {
  font-size: 17px;
  line-height: 1.8;
  color: var(--yoozi-ink);
  margin: 0 0 16px;
  max-width: 58ch;
}

.yousee-quote-author {
  display: inline-block;
  margin-top: 8px;
  font-family: 'Nunito', sans-serif;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--yoozi-grey);
  font-style: normal;
}

.yousee-portrait-placeholder {
  width: 100%;
  max-width: 400px;
  aspect-ratio: 1 / 1;
  margin: 0 auto;
  background: #fff;
  border: 1px solid #E8E4DE;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--yoozi-gold);
  padding: 48px;
}

.yousee-portrait-placeholder svg {
  width: 70%;
  height: auto;
}

.yousee-caption {
  text-align: center;
  font-size: 12px;
  font-style: italic;
  color: var(--yoozi-grey);
  margin: 16px 0 0;
}

/* Cadre portrait Yousee — cohérent avec le frame Enzo, adapté format carré */
.yousee-story-image .yousee-portrait-frame {
  margin: 0 auto;
  width: 100%;
  max-width: 420px;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: var(--yoozi-cream, #faf7ef);
  box-shadow: 0 28px 56px -28px rgba(31, 31, 31, 0.22);
  transition: transform 700ms cubic-bezier(0.2, 0.8, 0.2, 1);
  position: relative;
}

.yousee-story-image .yousee-portrait-frame::after {
  content: '';
  position: absolute;
  inset: 14px;
  border: 1px solid rgba(198, 165, 106, 0.5);
  pointer-events: none;
  transition: inset 600ms ease, border-color 600ms ease;
}

.yousee-story-image .yousee-portrait-frame:hover {
  transform: translateY(-4px);
}

.yousee-story-image .yousee-portrait-frame:hover::after {
  inset: 10px;
  border-color: var(--yoozi-gold);
}

.yousee-story-image .yousee-portrait-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 30%;
  display: block;
  transition: transform 900ms cubic-bezier(0.2, 0.8, 0.2, 1);
}

.yousee-story-image .yousee-portrait-frame:hover img {
  transform: scale(1.04);
}

.yousee-values {
  padding: 96px 24px;
  max-width: 1200px;
  margin: 0 auto;
  text-align: center;
}

.yousee-values-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 48px;
  margin-top: 48px;
  text-align: left;
}

.yousee-value {
  position: relative;
  padding-top: 16px;
  border-top: 1px solid #E8E4DE;
}

.yousee-value-num {
  font-family: 'Nunito', sans-serif;
  font-size: 56px;
  line-height: 1;
  font-weight: 500;
  color: var(--yoozi-gold);
  margin-bottom: 16px;
  letter-spacing: -0.02em;
}

.yousee-value h3 {
  font-family: 'Nunito', sans-serif;
  font-weight: 500;
  font-size: 28px;
  margin: 0 0 12px;
  color: var(--yoozi-ink);
}

.yousee-value p {
  font-size: 15px;
  line-height: 1.7;
  color: var(--yoozi-ink);
  margin: 0;
}

.yousee-provenance {
  background: var(--yoozi-cream);
  padding: 96px 24px;
  text-align: center;
}

.yousee-provenance-body {
  max-width: 680px;
  margin: 0 auto 24px;
  font-size: 17px;
  line-height: 1.8;
  color: var(--yoozi-ink);
}

.yousee-cta {
  display: inline-block;
  font-family: 'Nunito', sans-serif;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--yoozi-gold);
  text-decoration: none;
  padding: 14px 0;
  border-bottom: 1px solid var(--yoozi-gold);
  transition: letter-spacing 300ms ease, color 300ms ease;
}

.yousee-cta:hover {
  letter-spacing: 0.2em;
  color: var(--yoozi-gold-dark);
}

@media (max-width: 900px) {
  .yousee-story-grid { grid-template-columns: 1fr; gap: 40px; }
  .yousee-values-grid { grid-template-columns: 1fr; gap: 36px; }
}

/* === FOOTER — picto chat discret lié à /yousee/ === */

.yoozi-yousee-pawprint {
  display: block;
  margin: 32px auto 12px;
  width: 24px;
  height: 24px;
  opacity: 0.5;
  color: var(--yoozi-gold);
  transition: opacity 300ms ease, transform 300ms ease;
}

.yoozi-yousee-pawprint:hover {
  opacity: 1;
  transform: translateY(-2px);
}

.yoozi-yousee-pawprint svg {
  width: 100%;
  height: 100%;
}

/* ================================================================
   PAGE /enzo/ — Mixologue signataire
   ================================================================ */

.enzo-hero {
  padding: 96px 24px 64px;
  max-width: 1200px;
  margin: 0 auto;
}

.enzo-hero-grid {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 64px;
  align-items: center;
}

.enzo-portrait-placeholder {
  width: 100%;
  max-width: 420px;
  aspect-ratio: 3 / 4;
  margin: 0 auto;
  background: var(--yoozi-cream);
  border: 1px solid #E8E4DE;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--yoozi-gold);
  padding: 32px;
}

.enzo-portrait-placeholder svg {
  width: 60%;
  height: auto;
}

.enzo-portrait-caption {
  text-align: center;
  font-size: 12px;
  font-style: italic;
  color: var(--yoozi-grey);
  margin: 14px 0 0;
}

.enzo-name {
  font-family: 'Nunito', sans-serif;
  font-weight: 500;
  font-size: clamp(3rem, 6vw, 4.5rem);
  line-height: 1;
  margin: 14px 0 12px;
  letter-spacing: -0.02em;
  color: var(--yoozi-ink);
}

.enzo-role {
  font-family: 'Nunito', sans-serif;
  font-size: 15px;
  letter-spacing: 0.04em;
  color: var(--yoozi-grey);
  line-height: 1.55;
  margin-bottom: 24px;
}

.enzo-quote {
  font-family: 'Nunito', sans-serif;
  font-style: italic;
  font-size: clamp(1.25rem, 2vw, 1.625rem);
  line-height: 1.45;
  color: var(--yoozi-gold-dark);
  border-left: 3px solid var(--yoozi-gold);
  padding: 8px 0 8px 20px;
  margin: 0 0 24px;
}

.enzo-bio {
  font-size: 17px;
  line-height: 1.8;
  color: var(--yoozi-ink);
  margin: 0;
}

.enzo-signatures {
  padding: 96px 24px;
  max-width: 1000px;
  margin: 0 auto;
  background: var(--yoozi-cream);
}

.enzo-signatures-title {
  font-family: 'Nunito', sans-serif;
  font-weight: 500;
  font-size: clamp(2.25rem, 4.5vw, 3.25rem);
  line-height: 1.1;
  margin: 12px 0 16px;
  color: var(--yoozi-ink);
}

.enzo-signatures-intro {
  font-size: 17px;
  line-height: 1.8;
  color: var(--yoozi-grey);
  max-width: 680px;
  margin: 0 auto 48px;
  text-align: center;
}

.enzo-recipe {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 32px;
  padding: 40px 0;
  border-top: 1px solid #E8E4DE;
}

.enzo-recipe:last-child {
  border-bottom: 1px solid #E8E4DE;
}

.enzo-recipe-num {
  font-family: 'Nunito', sans-serif;
  font-size: 72px;
  line-height: 0.9;
  font-weight: 500;
  color: var(--yoozi-gold);
  letter-spacing: -0.04em;
}

.enzo-recipe h3 {
  font-family: 'Nunito', sans-serif;
  font-weight: 500;
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  line-height: 1.1;
  margin: 0 0 14px;
  color: var(--yoozi-ink);
}

.enzo-recipe-base {
  font-family: 'Nunito', sans-serif;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--yoozi-gold-dark);
  margin: 0 0 18px;
}

.enzo-recipe-ings {
  font-size: 15px;
  line-height: 1.75;
  color: var(--yoozi-ink);
  margin: 0 0 14px;
}

.enzo-recipe-method {
  font-size: 15px;
  line-height: 1.75;
  color: var(--yoozi-ink);
  margin: 0 0 14px;
}

.enzo-recipe-moment {
  font-family: 'Nunito', sans-serif;
  font-style: italic;
  font-size: 17px;
  color: var(--yoozi-gold);
  margin: 0 0 10px;
}

.enzo-recipe-playlist {
  font-family: 'Nunito', sans-serif;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--yoozi-grey);
  margin: 12px 0 0;
}

.enzo-recipe-playlist span {
  display: inline-block;
  padding: 6px 12px;
  border: 1px dashed #D8D1C3;
  border-radius: 999px;
}

.enzo-ethics {
  padding: 96px 24px;
  max-width: 1100px;
  margin: 0 auto;
  text-align: center;
}

.enzo-ethics h2 {
  font-family: 'Nunito', sans-serif;
  font-weight: 500;
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1.1;
  color: var(--yoozi-ink);
  margin: 12px 0 48px;
}

.enzo-ethics-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
  text-align: left;
  margin-bottom: 48px;
}

.enzo-ethics-grid > div {
  padding-top: 24px;
  border-top: 1px solid var(--yoozi-gold);
}

.enzo-ethics-grid h3 {
  font-family: 'Nunito', sans-serif;
  font-weight: 500;
  font-size: 26px;
  margin: 0 0 12px;
  color: var(--yoozi-ink);
}

.enzo-ethics-grid p {
  font-size: 15px;
  line-height: 1.7;
  color: var(--yoozi-grey);
  margin: 0;
}

.enzo-ethics-signature {
  font-family: 'Nunito', sans-serif;
  font-style: italic;
  font-size: 18px;
  color: var(--yoozi-gold);
}

@media (max-width: 900px) {
  .enzo-hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .enzo-recipe { grid-template-columns: 60px 1fr; gap: 20px; padding: 32px 0; }
  .enzo-recipe-num { font-size: 56px; }
  .enzo-ethics-grid { grid-template-columns: 1fr; gap: 28px; }
}

/* === Homepage teaser Enzo === */

.yoozi-enzo-teaser {
  background: linear-gradient(180deg, #fff 0%, var(--yoozi-cream) 100%);
  padding: 96px 0;
}

.yoozi-enzo-teaser .elementor-container {
  max-width: 1200px !important;
  padding: 0 24px;
}

.yoozi-enzo-teaser-grid {
  /* La section elle-même n'a pas besoin du grid — c'est son container qui compte */
}
.yoozi-enzo-teaser-grid > .elementor-container {
  display: grid !important;
  grid-template-columns: 0.8fr 1.3fr !important;
  gap: 64px !important;
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
}
.yoozi-enzo-teaser-grid .elementor-column.yoozi-enzo-portrait,
.yoozi-enzo-teaser-grid .elementor-column.yoozi-enzo-text {
  width: auto !important;
  max-width: none !important;
}

.yoozi-enzo-portrait .enzo-portrait-placeholder {
  max-width: 320px;
  aspect-ratio: 3 / 4;
  background: #fff;
}

/* Nouveau cadre photo Enzo — éditorial, filet or discret, caption tagline */
.yoozi-enzo-portrait .enzo-portrait-frame,
.enzo-hero-portrait .enzo-portrait-frame {
  position: relative;
  margin: 0;
  max-width: 360px;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  background: var(--yoozi-cream, #faf7ef);
  box-shadow: 0 30px 60px -30px rgba(31, 31, 31, 0.25);
  transition: transform 700ms cubic-bezier(0.2, 0.8, 0.2, 1), box-shadow 700ms ease;
}

.yoozi-enzo-portrait .enzo-portrait-frame,
.enzo-hero-portrait .enzo-portrait-frame::after {
  content: '';
  position: absolute;
  inset: 14px;
  border: 1px solid rgba(198, 165, 106, 0.55);
  pointer-events: none;
  transition: inset 600ms ease, border-color 600ms ease;
}

.yoozi-enzo-portrait .enzo-portrait-frame,
.enzo-hero-portrait .enzo-portrait-frame:hover {
  transform: translateY(-4px);
  box-shadow: 0 40px 80px -32px rgba(31, 31, 31, 0.32);
}

.yoozi-enzo-portrait .enzo-portrait-frame,
.enzo-hero-portrait .enzo-portrait-frame:hover::after {
  inset: 10px;
  border-color: var(--yoozi-gold);
}

.yoozi-enzo-portrait .enzo-portrait-frame,
.enzo-hero-portrait .enzo-portrait-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: grayscale(0.15) contrast(1.03);
  transition: transform 900ms cubic-bezier(0.2, 0.8, 0.2, 1), filter 700ms ease;
}

.yoozi-enzo-portrait .enzo-portrait-frame,
.enzo-hero-portrait .enzo-portrait-frame:hover img {
  transform: scale(1.05);
  filter: grayscale(0) contrast(1.05);
}

.yoozi-enzo-portrait .enzo-portrait-frame .enzo-portrait-caption,
.enzo-hero-portrait .enzo-portrait-frame .enzo-portrait-caption {
  position: absolute;
  left: 24px;
  bottom: 20px;
  margin: 0;
  font-family: 'Nunito', sans-serif;
  font-size: 11px;
  letter-spacing: 0.22em;
  color: #fff;
  font-style: normal;
  text-shadow: 0 2px 16px rgba(0, 0, 0, 0.6);
  z-index: 2;
}

.yoozi-enzo-text h2 {
  font-family: 'Nunito', sans-serif;
  font-style: italic;
  font-weight: 500;
  font-size: clamp(1.5rem, 2.5vw, 2.25rem);
  line-height: 1.35;
  color: var(--yoozi-ink);
  margin: 12px 0 16px;
  max-width: 30ch;
}

.yoozi-enzo-byline {
  font-family: 'Nunito', sans-serif;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--yoozi-gold);
  margin: 0 0 20px;
}

.yoozi-enzo-body {
  font-size: 17px;
  line-height: 1.75;
  color: var(--yoozi-ink);
  margin: 0 0 28px;
  max-width: 58ch;
}

@media (max-width: 900px) {
  .yoozi-enzo-teaser-grid { grid-template-columns: 1fr; gap: 32px; text-align: center; }
  .yoozi-enzo-body { max-width: none; }
}

/* ================================================================
   HOMEPAGE — Timeline Maison Yoozi (Provence)
   ================================================================ */

.yoozi-timeline {
  padding: 96px 24px;
  max-width: 1200px;
  margin: 0 auto;
  text-align: center;
}

.yoozi-timeline-title {
  font-family: 'Nunito', sans-serif;
  font-weight: 500;
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1.1;
  letter-spacing: -0.015em;
  color: var(--yoozi-ink);
  margin: 12px 0 56px;
}

.yoozi-timeline-rail {
  position: relative;
  /* Le grid est appliqué à .yoozi-timeline-rail > .elementor-container (cf. home-fix.css)
     pour que le container Elementor interne récupère bien 100% de largeur */
  padding-top: 40px;
}

.yoozi-timeline-rail::before {
  content: '';
  position: absolute;
  top: 44px;
  left: 5%;
  right: 5%;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--yoozi-gold) 15%, var(--yoozi-gold) 85%, transparent);
}

.yoozi-timeline-step {
  text-align: center;
  position: relative;
}

.yoozi-timeline-dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--yoozi-gold);
  margin: 0 auto 24px;
  position: relative;
  z-index: 1;
  box-shadow: 0 0 0 6px var(--yoozi-cream);
}

.yoozi-timeline-year {
  font-family: 'Nunito', sans-serif;
  font-size: clamp(2.25rem, 3.5vw, 3rem);
  font-weight: 500;
  color: var(--yoozi-gold);
  line-height: 1;
  margin: 0 0 12px;
  letter-spacing: -0.02em;
}

.yoozi-timeline-step h3 {
  font-family: 'Nunito', sans-serif;
  font-weight: 700;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--yoozi-ink);
  margin: 0 0 10px;
}

.yoozi-timeline-step p {
  font-size: 14px;
  line-height: 1.6;
  color: var(--yoozi-grey);
  max-width: 22ch;
  margin: 0 auto;
}

@media (max-width: 767px) {
  .yoozi-timeline-rail {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .yoozi-timeline-rail::before {
    left: 50%;
    right: auto;
    top: 0;
    bottom: 0;
    width: 1px;
    height: auto;
    background: linear-gradient(to bottom, transparent, var(--yoozi-gold) 15%, var(--yoozi-gold) 85%, transparent);
  }
}

/* ================================================================
   PAGE /presse/ — Dossier de presse (print-friendly)
   ================================================================ */

.presse-hero {
  text-align: center;
  padding: 96px 24px 48px;
  max-width: 820px;
  margin: 0 auto;
}

.presse-title {
  font-family: 'Nunito', sans-serif;
  font-weight: 500;
  font-size: clamp(3rem, 7vw, 5rem);
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--yoozi-ink);
  margin: 12px 0 16px;
}

.presse-tagline {
  font-family: 'Nunito', sans-serif;
  font-style: italic;
  font-size: clamp(1.125rem, 1.8vw, 1.5rem);
  color: var(--yoozi-gold);
  margin: 0;
}

.presse-intro,
.presse-downloads,
.presse-quotes,
.presse-facts,
.presse-contact {
  max-width: 1000px;
  margin: 0 auto;
  padding: 48px 24px;
}

.presse-intro-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
}

.presse-intro-block h3 {
  font-family: 'Nunito', sans-serif;
  font-weight: 700;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--yoozi-gold);
  margin: 0 0 14px;
}

.presse-intro-block p,
.presse-list {
  font-size: 16px;
  line-height: 1.7;
  color: var(--yoozi-ink);
}

.presse-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.presse-list li {
  padding: 6px 0;
  border-bottom: 1px solid #EFE8DA;
}

.presse-list li:last-child { border-bottom: none; }

.presse-downloads h2,
.presse-quotes h2,
.presse-facts h2,
.presse-contact h2 {
  font-family: 'Nunito', sans-serif;
  font-weight: 500;
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  line-height: 1.1;
  margin: 0 0 32px;
  color: var(--yoozi-ink);
}

.presse-downloads-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.presse-dl-card {
  display: block;
  background: var(--yoozi-cream);
  padding: 32px 24px;
  text-decoration: none;
  border: 1px solid #E8E4DE;
  transition: border-color 300ms ease, transform 300ms ease;
}

.presse-dl-card:hover {
  border-color: var(--yoozi-gold);
  transform: translateY(-3px);
}

.presse-dl-ic {
  display: inline-block;
  padding: 4px 10px;
  background: var(--yoozi-gold);
  color: #fff;
  font-family: 'Nunito', sans-serif;
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.12em;
  margin-bottom: 12px;
}

.presse-dl-title {
  display: block;
  font-family: 'Nunito', sans-serif;
  font-size: 20px;
  color: var(--yoozi-ink);
  font-weight: 500;
  margin-bottom: 6px;
}

.presse-dl-meta {
  display: block;
  font-size: 13px;
  color: var(--yoozi-grey);
  line-height: 1.5;
}

.presse-quotes {
  background: var(--yoozi-cream);
  max-width: none;
}

.presse-quotes > * { max-width: 1000px; margin-left: auto; margin-right: auto; }

.presse-quotes-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}

.presse-quote {
  margin: 0;
  padding: 28px;
  background: #fff;
  border-top: 3px solid var(--yoozi-gold);
}

.presse-quote p {
  font-family: 'Nunito', sans-serif;
  font-style: italic;
  font-size: 18px;
  line-height: 1.5;
  margin: 0 0 16px;
  color: var(--yoozi-ink);
}

.presse-quote cite {
  font-family: 'Nunito', sans-serif;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--yoozi-gold);
  font-style: normal;
}

.presse-facts-table {
  width: 100%;
  border-collapse: collapse;
  font-family: 'Nunito', sans-serif;
  font-size: 15px;
}

.presse-facts-table tr { border-bottom: 1px solid #EFE8DA; }

.presse-facts-table th {
  text-align: left;
  padding: 14px 0;
  color: var(--yoozi-gold-dark);
  font-weight: 700;
  letter-spacing: 0.04em;
  width: 30%;
}

.presse-facts-table td {
  padding: 14px 0;
  color: var(--yoozi-ink);
  line-height: 1.6;
}

.presse-contact {
  text-align: center;
  background: var(--yoozi-cream);
  max-width: none;
}

.presse-contact > * { max-width: 640px; margin-left: auto; margin-right: auto; }

.presse-contact-text {
  font-size: 16px;
  color: var(--yoozi-ink);
  line-height: 1.6;
  margin-bottom: 16px;
}

.presse-contact-email {
  font-family: 'Nunito', sans-serif;
  font-size: clamp(1.5rem, 3vw, 2.25rem);
  margin: 0 0 8px;
}

.presse-contact-email a {
  color: var(--yoozi-gold);
  text-decoration: none;
  border-bottom: 1px solid var(--yoozi-gold);
}

.presse-contact-sub { font-size: 13px; color: var(--yoozi-grey); font-style: italic; }

@media (max-width: 900px) {
  .presse-intro-grid { grid-template-columns: 1fr; gap: 32px; }
  .presse-downloads-grid { grid-template-columns: 1fr; }
  .presse-quotes-grid { grid-template-columns: 1fr; }
}

@media print {
  header, footer, .yoozi-yousee-pawprint, .yoozi-nl-popup-backdrop, .presse-dl-card { display: none !important; }
  body { background: #fff !important; color: #000 !important; }
  .presse-hero, .presse-intro, .presse-quotes, .presse-facts, .presse-contact { break-inside: avoid; padding: 24px 0; max-width: none; }
}

/* ================================================================
   PAGE /hotels-restaurants/ — Partenaires B2B + carte Leaflet
   ================================================================ */

.partners-hero {
  text-align: center;
  padding: 96px 24px 48px;
  max-width: 820px;
  margin: 0 auto;
}

.partners-title {
  font-family: 'Nunito', sans-serif;
  font-weight: 500;
  font-size: clamp(3rem, 6vw, 4.5rem);
  line-height: 1;
  letter-spacing: -0.02em;
  margin: 12px 0 16px;
  color: var(--yoozi-ink);
}

.partners-tagline {
  font-family: 'Nunito', sans-serif;
  font-style: italic;
  font-size: clamp(1.125rem, 1.8vw, 1.5rem);
  color: var(--yoozi-gold);
  margin: 0;
}

.partners-map-section {
  max-width: 1200px;
  margin: 0 auto;
  padding: 48px 24px;
}

.yoozi-partners-empty {
  text-align: center;
  padding: 72px 24px;
  background: var(--yoozi-cream);
  border: 1px dashed var(--yoozi-gold);
  max-width: 820px;
  margin: 0 auto;
}

.yoozi-partners-empty h3 {
  font-family: 'Nunito', sans-serif;
  font-weight: 500;
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  margin: 12px 0;
}

.yoozi-partners-empty p {
  font-size: 16px;
  line-height: 1.7;
  color: var(--yoozi-grey);
  max-width: 560px;
  margin: 0 auto;
}

.yoozi-partners-map {
  width: 100%;
  height: 480px;
  border: 1px solid #E8E4DE;
}

.yoozi-partners-list {
  list-style: none;
  padding: 0;
  margin: 32px 0 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 16px;
}

.yoozi-partner-item {
  background: #fff;
  border: 1px solid #E8E4DE;
  padding: 20px;
  transition: border-color 300ms ease;
}

.yoozi-partner-item:hover { border-color: var(--yoozi-gold); }

.yoozi-partner-type {
  font-family: 'Nunito', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--yoozi-gold);
  margin-bottom: 6px;
}

.yoozi-partner-item h4 {
  font-family: 'Nunito', sans-serif;
  font-size: 22px;
  font-weight: 500;
  margin: 0 0 4px;
}

.yoozi-partner-city { font-weight: 700; font-size: 13px; margin: 0 0 4px; color: var(--yoozi-ink); }
.yoozi-partner-address { font-size: 13px; color: var(--yoozi-grey); line-height: 1.5; margin: 0 0 10px; }
.yoozi-partner-link { font-size: 12px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--yoozi-gold); text-decoration: none; }

.partners-apply {
  background: var(--yoozi-cream);
  padding: 80px 24px;
}

.partners-apply-grid {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}

.partners-apply-text h2 {
  font-family: 'Nunito', sans-serif;
  font-weight: 500;
  font-size: clamp(1.75rem, 3.5vw, 2.75rem);
  line-height: 1.15;
  margin: 12px 0 20px;
}

.partners-apply-text p,
.partners-apply-list { font-size: 16px; line-height: 1.7; color: var(--yoozi-ink); }

.partners-apply-list {
  list-style: none;
  padding: 0;
  margin: 16px 0 0;
}

.partners-apply-list li {
  padding: 10px 0 10px 28px;
  position: relative;
  border-bottom: 1px solid #E8E4DE;
}

.partners-apply-list li::before {
  content: '→';
  position: absolute;
  left: 0;
  color: var(--yoozi-gold);
  font-weight: 700;
}

.partners-apply-form {
  background: #fff;
  padding: 32px;
  border: 1px solid #E8E4DE;
}

.partners-apply-fallback {
  font-size: 13px;
  color: var(--yoozi-grey);
  margin-top: 16px;
  text-align: center;
}

.partners-apply-fallback a { color: var(--yoozi-gold); }

.partners-pitch {
  max-width: 1200px;
  margin: 0 auto;
  padding: 80px 24px;
}

.partners-pitch h2 {
  text-align: center;
  font-family: 'Nunito', sans-serif;
  font-weight: 500;
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  margin: 0 0 48px;
}

.partners-pitch-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
}

.partners-pitch-grid > div {
  padding-top: 24px;
  border-top: 1px solid var(--yoozi-gold);
}

.partners-pitch-grid h3 {
  font-family: 'Nunito', sans-serif;
  font-weight: 500;
  font-size: 26px;
  margin: 0 0 12px;
  color: var(--yoozi-ink);
}

.partners-pitch-grid p { font-size: 15px; line-height: 1.7; color: var(--yoozi-grey); margin: 0; }

@media (max-width: 900px) {
  .partners-apply-grid { grid-template-columns: 1fr; gap: 40px; }
  .partners-pitch-grid { grid-template-columns: 1fr; gap: 28px; }
}

/* ================================================================
   MON COMPTE — Panneau Parrainage
   ================================================================ */

.yoozi-referral-panel {
  font-family: 'Nunito', sans-serif;
  max-width: 620px;
}

.yoozi-referral-panel h2 {
  font-family: 'Nunito', sans-serif;
  font-weight: 500;
  font-size: 2rem;
  margin: 8px 0 16px;
}

.yoozi-referral-code-box {
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--yoozi-cream);
  padding: 18px 20px;
  border: 1px solid var(--yoozi-gold);
  margin: 20px 0 12px;
}

.yoozi-referral-code {
  font-family: 'Nunito', sans-serif;
  font-size: 28px;
  font-weight: 500;
  letter-spacing: 0.08em;
  color: var(--yoozi-ink);
  flex: 1;
}

.yoozi-referral-copy {
  background: var(--yoozi-gold);
  color: #fff;
  border: none;
  padding: 10px 18px;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 250ms ease;
}

.yoozi-referral-copy:hover { background: var(--yoozi-gold-dark); }

.yoozi-referral-url {
  font-size: 13px;
  color: var(--yoozi-grey);
  margin: 4px 0 24px;
}
.yoozi-referral-url code { background: var(--yoozi-cream); padding: 4px 8px; }

.yoozi-referral-balance {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 20px;
  background: #fff;
  border-left: 3px solid var(--yoozi-gold);
  margin-bottom: 16px;
}

.yoozi-referral-balance-label {
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--yoozi-grey);
}

.yoozi-referral-balance-amount {
  font-family: 'Nunito', sans-serif;
  font-size: 28px;
  font-weight: 500;
  color: var(--yoozi-gold-dark);
}

.yoozi-referral-use-form button { cursor: pointer; }

/* === HEADER SIGNATURE — accolade orpheline style.css l.351 neutralisée === */

.yoozi-divider {
  display: block;
  width: 80px;
  height: 1px;
  background: var(--yoozi-gold);
  margin: 24px auto;
  opacity: 0.6;
}

/* === SCROLL REVEAL fallback quand animation-timeline absent === */

@supports not (animation-timeline: view()) {
  .yoozi-reveal {
    opacity: 0;
    transform: translateY(16px);
    transition: opacity 700ms ease, transform 700ms ease;
  }
  .yoozi-reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ==============================================================
   === BONUS WOW EFFECT — animations signature Yoozi            ===
   ============================================================== */

/* Stagger reveal progressif sur les cartes rituels (entry animation).
   Couvre l'ancienne structure .yoozi-rituels-grid + la nouvelle Elementor. */
@media (prefers-reduced-motion: no-preference) {
  .yoozi-rituels-grid .yoozi-rituel-card,
    .yoozi-rituels-inner .elementor-column {
    opacity: 0;
    transform: translateY(24px);
    animation: yoozi-rituel-reveal 800ms cubic-bezier(0.2, 0.8, 0.2, 1) forwards;
  }
  .yoozi-rituels-grid .yoozi-rituel-card:nth-child(1),
  .yoozi-rituels-inner .elementor-column:nth-child(1) { animation-delay: 0.0s; }
  .yoozi-rituels-grid .yoozi-rituel-card:nth-child(2),
  .yoozi-rituels-inner .elementor-column:nth-child(2) { animation-delay: 0.12s; }
  .yoozi-rituels-grid .yoozi-rituel-card:nth-child(3),
  .yoozi-rituels-inner .elementor-column:nth-child(3) { animation-delay: 0.24s; }
  .yoozi-rituels-grid .yoozi-rituel-card:nth-child(4),
  .yoozi-rituels-inner .elementor-column:nth-child(4) { animation-delay: 0.36s; }
}

@keyframes yoozi-rituel-reveal {
  to { opacity: 1; transform: translateY(0); }
}

/* Shimmer or sur l'eyebrow du mixologue — passage lumineux discret */
@media (prefers-reduced-motion: no-preference) {
  .yoozi-enzo-text .yoozi-eyebrow {
    position: relative;
    display: inline-block;
    background: linear-gradient(
      90deg,
      var(--yoozi-gold) 0%,
      var(--yoozi-gold) 40%,
      #efd8a5 50%,
      var(--yoozi-gold) 60%,
      var(--yoozi-gold) 100%
    );
    background-size: 200% 100%;
    background-clip: text;
    -webkit-background-clip: text;
    color: transparent;
    animation: yoozi-shimmer 6s ease-in-out infinite;
  }
}

@keyframes yoozi-shimmer {
  0%, 100% { background-position: 200% 0; }
  50%      { background-position: -100% 0; }
}

/* Fine ligne or animée au survol du bouton "Découvrir les 5 signatures" */
.yousee-cta {
  position: relative;
  display: inline-block;
  color: var(--yoozi-gold);
  font-family: 'Nunito', sans-serif;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  text-decoration: none;
  padding-bottom: 6px;
  transition: color 300ms ease;
}

.yousee-cta::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 1px;
  background: var(--yoozi-gold);
  transform: scaleX(0.3);
  transform-origin: left;
  transition: transform 500ms cubic-bezier(0.2, 0.8, 0.2, 1);
}

.yousee-cta:hover::after {
  transform: scaleX(1);
}

.yousee-cta:hover {
  color: var(--yoozi-dark);
}

/* ============================================================
   PATCH 2026-05-01 — NOTRE PRINCIPE en 50/50 propre
   La section 1ecced2 utilise désormais ses 2 colonnes natives :
   - col gauche 0d3e8dc : H2 "Notre principe..." centré verticalement
   - col droite 98d724e : 2 paragraphes centrés
   On cale juste les 2 colonnes en flex/center et on harmonise le H2.
   ============================================================ */
.elementor-element-1ecced2 .elementor-widget-heading h2.elementor-heading-title {
  font-family: 'Nunito', sans-serif;
  font-weight: 700;
  font-size: clamp(20px, 1.6vw, 26px);
  line-height: 1.3;
  letter-spacing: 0;
  color: #1F2A44;
  margin: 0;
  max-width: 480px;
  margin-left: auto;
  margin-right: auto;
}
.elementor-element-1ecced2 .elementor-element-b516213 .elementor-widget-container,
.elementor-element-1ecced2 .elementor-element-2a65dd7 .elementor-widget-container {
  max-width: 460px;
  margin-left: auto;
  margin-right: auto;
  padding: 0;
}
.elementor-element-1ecced2 .elementor-element-b516213 p,
.elementor-element-1ecced2 .elementor-element-2a65dd7 p {
  margin: 0 0 14px;
}
.elementor-element-1ecced2 .elementor-element-2a65dd7 p {
  margin-bottom: 0;
}

/* === Phase 2 — Témoignages en Elementor natif ===
   L'ancien widget HTML 1134dac est remplacé par une inner-section
   yoozi-testimonials-grid contenant 3 colonnes .yoozi-testimonial,
   chacune avec 1 text-editor dont le HTML porte les classes
   .yoozi-testimonial-quote / .yoozi-testimonial-author /
   .yoozi-testimonial-context. Styles existants (::before guillemet,
   border-top gold, grid 3 cols) continuent à matcher. */

.yoozi-testimonials-grid > .elementor-container {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 32px !important;
  max-width: 1200px;
  margin: 0 auto;
}

.yoozi-testimonial.elementor-column {
  background: #fff;
  padding: 40px 32px !important;
  border-top: 3px solid var(--yoozi-gold);
  width: auto !important;
  max-width: none !important;
}

@media (max-width: 900px) {
  .yoozi-testimonials-grid > .elementor-container {
    grid-template-columns: 1fr !important;
  }
}

.yoozi-testimonial .elementor-widget-container {
  background: transparent;
}

.yoozi-testimonial .elementor-widget-text-editor {
  margin: 0;
}

/* === Phase 3 — Bandeau éthique en Elementor natif ===
   Widget HTML 33348fc remplacé par inner-section yoozi-ethics-inner
   contenant 4 colonnes .yoozi-ethics-item (SVG + heading + text-editor).
   Les règles historiques lignes 59-119 continuent de matcher (svg/h4/p
   sont descendants via wrappers Elementor). Ici juste les overrides
   nécessaires pour le grid Elementor + spacing. */

.yoozi-ethics-inner > .elementor-container {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 32px !important;
  max-width: 1200px;
  margin: 0 auto;
}

.yoozi-ethics-inner .yoozi-ethics-item.elementor-column {
  text-align: center;
  padding: 0 8px;
  width: auto !important;
  max-width: none !important;
}

@media (max-width: 900px) {
  .yoozi-ethics-inner > .elementor-container {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

.yoozi-ethics-inner .yoozi-ethics-icon {
  margin: 0 auto 14px;
}

.yoozi-ethics-inner .yoozi-ethics-icon .elementor-widget-container {
  display: flex;
  justify-content: center;
}

.yoozi-ethics-inner .yoozi-ethics-title .elementor-heading-title {
  font-family: 'Nunito', sans-serif;
  font-weight: 700;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--yoozi-dark);
  margin: 0 0 6px;
}

.yoozi-ethics-inner .yoozi-ethics-desc p {
  font-size: 13px;
  color: var(--yoozi-grey);
  line-height: 1.6;
  margin: 0;
}

/* Responsive handled by Elementor natively via structure=44 */

/* === Phase 4 — Timeline en Elementor natif ===
   Widget HTML b23a26f remplacé par inner-section yoozi-timeline-rail
   contenant 4 colonnes .yoozi-timeline-step. Chaque step : heading année +
   heading titre + text-editor desc. Le dot gold est un ::before sur la col.
   La ligne gradient horizontale est un ::before sur l'inner-container. */

.yoozi-timeline-rail > .elementor-container {
  padding-top: 40px;
  position: relative;
  max-width: 1200px;
  margin: 0 auto;
  gap: 24px;
}

.yoozi-timeline-rail > .elementor-container::before {
  content: '';
  position: absolute;
  top: 44px;
  left: 5%;
  right: 5%;
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    var(--yoozi-gold) 20%,
    var(--yoozi-gold) 80%,
    transparent 100%
  );
  z-index: 0;
}

.yoozi-timeline-rail .yoozi-timeline-step.elementor-column {
  position: relative;
  padding: 0 12px !important;
  text-align: center;
}

.yoozi-timeline-rail .yoozi-timeline-step::before {
  content: '';
  position: absolute;
  top: -3px;
  left: 50%;
  transform: translateX(-50%);
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--yoozi-gold);
  box-shadow: 0 0 0 6px var(--yoozi-cream);
  z-index: 1;
}

.yoozi-timeline-rail > .elementor-container {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 24px !important;
  max-width: 1200px;
  margin: 0 auto;
}
.yoozi-timeline-rail .yoozi-timeline-step.elementor-column {
  width: auto !important;
  max-width: none !important;
}
.yoozi-timeline-rail .yoozi-timeline-year .elementor-heading-title {
  font-family: 'Nunito', sans-serif;
  font-weight: 500;
  font-size: clamp(1.5rem, 2.4vw, 2.2rem);
  color: var(--yoozi-gold);
  line-height: 1.1;
  margin: 16px 0 12px;
  letter-spacing: -0.01em;
  word-break: normal;
  hyphens: none;
}
@media (max-width: 900px) {
  .yoozi-timeline-rail > .elementor-container {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 540px) {
  .yoozi-timeline-rail > .elementor-container {
    grid-template-columns: 1fr !important;
  }
}

.yoozi-timeline-rail .yoozi-timeline-title-item .elementor-heading-title {
  font-family: 'Nunito', sans-serif;
  font-weight: 700;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--yoozi-ink, var(--yoozi-dark));
  margin: 0 0 10px;
}

.yoozi-timeline-rail .yoozi-timeline-desc p {
  font-size: 14px;
  line-height: 1.6;
  color: var(--yoozi-grey);
  max-width: 22ch;
  margin: 0 auto;
}

@media (max-width: 767px) {
  .yoozi-timeline-rail > .elementor-container {
    grid-template-columns: 1fr !important;
    gap: 40px !important;
    padding-top: 20px;
  }
  .yoozi-timeline-rail > .elementor-container::before {
    left: 50%;
    right: auto;
    top: 0;
    bottom: 0;
    width: 1px;
    height: auto;
    background: linear-gradient(
      180deg,
      transparent 0%,
      var(--yoozi-gold) 20%,
      var(--yoozi-gold) 80%,
      transparent 100%
    );
  }
  .yoozi-timeline-rail .yoozi-timeline-step::before {
    top: 10px;
  }
}

/* === Phase 5 — Teaser Enzo en Elementor natif (hybride) ===
   Widget HTML 9c7c2a2 remplacé par inner-section yoozi-enzo-teaser-grid :
   - Col gauche .yoozi-enzo-portrait : 1 widget html figure portrait (hover
     complexe scale + grayscale→color + border ::after préservé intact).
   - Col droite .yoozi-enzo-text : 5 widgets Elementor (eyebrow, quote,
     byline, body, button CTA) — TOUS éditables par Lorène.
   Forcer le grid 0.8fr/1.3fr sur l'inner-container Elementor. */

.yoozi-enzo-teaser-grid > .elementor-container {
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
  gap: 64px;
}

.yoozi-enzo-teaser-grid .yoozi-enzo-portrait.elementor-column {
  padding: 0 !important;
}

.yoozi-enzo-teaser-grid .yoozi-enzo-text.elementor-column {
  padding: 0 !important;
}

.yoozi-enzo-teaser-grid .yoozi-enzo-portrait-html,
.yoozi-enzo-teaser-grid .yoozi-enzo-portrait-html .elementor-widget-container {
  margin: 0;
}

.yoozi-enzo-teaser-grid .yoozi-enzo-eyebrow .elementor-heading-title {
  font-family: 'Nunito', sans-serif;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--yoozi-gold);
  margin: 0 0 12px;
}

.yoozi-enzo-teaser-grid .yoozi-enzo-quote .elementor-heading-title {
  font-family: 'Nunito', sans-serif;
  font-style: italic;
  font-weight: 500;
  font-size: clamp(1.5rem, 2.5vw, 2.25rem);
  line-height: 1.35;
  color: var(--yoozi-ink, var(--yoozi-dark));
  margin: 12px 0 16px;
  max-width: 30ch;
}

.yoozi-enzo-teaser-grid .yoozi-enzo-byline p {
  font-family: 'Nunito', sans-serif;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--yoozi-gold);
  margin: 0 0 20px;
}

.yoozi-enzo-teaser-grid .yoozi-enzo-body p {
  font-size: 17px;
  line-height: 1.75;
  color: var(--yoozi-ink, var(--yoozi-dark));
  margin: 0 0 28px;
  max-width: 58ch;
}

/* CTA Elementor button styled comme l'ancien <a class="yousee-cta"> */
.yoozi-enzo-teaser-grid .yousee-cta-widget .elementor-button {
  position: relative;
  display: inline-block;
  background: transparent !important;
  color: var(--yoozi-gold) !important;
  font-family: 'Nunito', sans-serif;
  font-size: 14px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  padding: 6px 0 !important;
  border: none;
  border-radius: 0;
  transition: color 300ms ease;
}

.yoozi-enzo-teaser-grid .yousee-cta-widget .elementor-button::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 1px;
  background: var(--yoozi-gold);
  transform: scaleX(0.3);
  transform-origin: left;
  transition: transform 500ms cubic-bezier(0.2, 0.8, 0.2, 1);
}

.yoozi-enzo-teaser-grid .yousee-cta-widget .elementor-button:hover::after {
  transform: scaleX(1);
}

.yoozi-enzo-teaser-grid .yousee-cta-widget .elementor-button:hover {
  color: var(--yoozi-dark) !important;
  background: transparent !important;
}

@media (max-width: 900px) {
  .yoozi-enzo-teaser-grid > .elementor-container {
    gap: 32px;
    text-align: center;
  }
  .yoozi-enzo-teaser-grid .yoozi-enzo-body p {
    max-width: none;
    margin-left: auto;
    margin-right: auto;
  }
  .yoozi-enzo-teaser-grid .yoozi-enzo-quote .elementor-heading-title {
    max-width: none;
    margin-left: auto;
    margin-right: auto;
  }
}

/* ============================================================
   PATCH 2026-05-01 — Section ENZO en widgets Elementor natifs
   Le widget HTML a été remplacé par : image widget + headings + button.
   On retarget le frame photo sur la <figure.wp-caption> générée par
   Elementor et on style le caption en bas.
   ============================================================ */
.yoozi-enzo-portrait .elementor-widget-image {
  margin: 0;
}
.yoozi-enzo-portrait .elementor-widget-image .elementor-widget-container,
.yoozi-enzo-portrait .elementor-widget-image figure.wp-caption {
  position: relative;
  margin: 0;
  width: 100%;
  max-width: 380px;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: var(--yoozi-cream, #faf7ef);
  box-shadow: 0 30px 60px -30px rgba(31, 31, 31, 0.25);
  transition: transform 700ms cubic-bezier(0.2, 0.8, 0.2, 1), box-shadow 700ms ease;
}
.yoozi-enzo-portrait .elementor-widget-image figure.wp-caption {
  background: transparent;
  box-shadow: none;
}
.yoozi-enzo-portrait .elementor-widget-image .elementor-widget-container::after {
  content: '';
  position: absolute;
  inset: 14px;
  border: 1px solid rgba(198, 165, 106, 0.55);
  pointer-events: none;
  transition: inset 600ms ease, border-color 600ms ease;
  z-index: 2;
}
.yoozi-enzo-portrait .elementor-widget-image:hover .elementor-widget-container {
  transform: translateY(-4px);
  box-shadow: 0 40px 80px -32px rgba(31, 31, 31, 0.32);
}
.yoozi-enzo-portrait .elementor-widget-image:hover .elementor-widget-container::after {
  inset: 10px;
  border-color: var(--yoozi-gold);
}
.yoozi-enzo-portrait .elementor-widget-image img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
  display: block;
  filter: grayscale(0.15) contrast(1.03);
  transition: transform 900ms cubic-bezier(0.2, 0.8, 0.2, 1), filter 700ms ease;
}
.yoozi-enzo-portrait .elementor-widget-image:hover img {
  transform: scale(1.05);
  filter: grayscale(0) contrast(1.05);
}
.yoozi-enzo-portrait .elementor-widget-image figcaption.wp-caption-text {
  position: absolute;
  left: 24px;
  bottom: 20px;
  margin: 0;
  padding: 0;
  font-family: 'Nunito', sans-serif;
  font-size: 11px;
  letter-spacing: 0.22em;
  color: #fff;
  font-style: normal;
  text-shadow: 0 2px 16px rgba(0, 0, 0, 0.6);
  z-index: 3;
  text-transform: uppercase;
  background: transparent;
}

/* Eyebrow + quote + byline + body — alignés gauche, espacement éditorial */
.yoozi-enzo-text .yoozi-eyebrow .elementor-heading-title {
  font-family: 'Nunito', sans-serif !important;
  font-size: 12px !important;
  letter-spacing: 0.22em !important;
  text-transform: uppercase !important;
  color: var(--yoozi-gold, #C8A96E) !important;
  margin: 0 0 18px !important;
  font-weight: 700 !important;
}
.yoozi-enzo-text .yoozi-enzo-quote .elementor-heading-title {
  font-family: 'Nunito', sans-serif !important;
  font-style: italic !important;
  font-weight: 500 !important;
  font-size: clamp(1.5rem, 2.5vw, 2.25rem) !important;
  line-height: 1.35 !important;
  color: var(--yoozi-ink, #1F1F1F) !important;
  margin: 0 0 20px !important;
  max-width: 30ch !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
}
.yoozi-enzo-text .elementor-widget-text-editor p.yoozi-enzo-byline {
  font-family: 'Nunito', sans-serif;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--yoozi-gold, #C8A96E);
  margin: 0 0 20px;
}
.yoozi-enzo-text .elementor-widget-text-editor p.yoozi-enzo-body {
  font-size: 17px;
  line-height: 1.75;
  color: var(--yoozi-ink, #1F1F1F);
  margin: 0 0 28px;
  max-width: 58ch;
}
.yoozi-enzo-text .elementor-widget-button .elementor-button.yousee-cta,
.yoozi-enzo-text .elementor-widget-button .elementor-button-link {
  background: transparent !important;
  color: var(--yoozi-ink, #1F1F1F) !important;
  font-family: 'Nunito', sans-serif !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  padding: 8px 0 !important;
  border-radius: 0 !important;
  border-bottom: 1px solid var(--yoozi-gold, #C8A96E) !important;
  box-shadow: none !important;
  transition: color 0.3s ease, border-color 0.3s ease;
}
.yoozi-enzo-text .elementor-widget-button .elementor-button:hover {
  color: var(--yoozi-gold, #C8A96E) !important;
}
.yoozi-enzo-text .elementor-widget-button .elementor-button .elementor-button-icon {
  margin-left: 8px;
}

@media (max-width: 900px) {
  .yoozi-enzo-teaser-grid > .elementor-container {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
    text-align: center !important;
  }
  .yoozi-enzo-portrait .elementor-widget-image .elementor-widget-container {
    margin: 0 auto;
  }
  .yoozi-enzo-text .yoozi-enzo-quote .elementor-heading-title {
    max-width: none !important;
  }
  .yoozi-enzo-text .elementor-widget-text-editor p.yoozi-enzo-body { max-width: none; }
}
