/** Shopify CDN: Minification failed

Line 177:34 Expected identifier but found whitespace
Line 177:36 Unexpected "{"
Line 177:45 Expected ":"

**/


/* CSS from section stylesheet tags */
/* ----- Base / variables ----- */
.ingr-sec{
  --ingr-bg:#F5FAF7;
  background: var(--ingr-bg);
  overflow-x: clip; /* empêche les débordements horizontaux */
}
.ingr-wrap{ max-width: 1280px; margin: 0 auto; padding: 8px 0 0; text-align: center; }

/* Titles */
.ingr-title{ font-size: clamp(1.8rem, 3vw, 2.4rem); font-weight: 800; margin: 0 0 .25rem; color:#0f172a; }
.ingr-subtitle{ max-width: 800px; margin: 0 auto 28px; color:#334155; font-size: 1rem; }

/* Grid / cards */
.ingr-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px,1fr));
  gap: 20px;
}
.ingr-card{
  position: relative; height: var(--ingr-card-h, 450px);
  border-radius: 16px; overflow: hidden;
  box-shadow: 0 2px 6px rgba(0,0,0,.05);
  background:#e9eef0; /* fallback */
}

/* image + overlay (compat Sense) */
.ingr-imgwrap{
  position: absolute; inset: 0; overflow: hidden;
  isolation: isolate; /* crée un contexte propre pour z-index */
}
.ingr-imgwrap img{
  position: absolute; inset: 0;
  width:100%; height:100%;
  object-fit:cover; display:block;
  z-index: 0 !important; /* image derrière */
}
.ingr-placeholder{
  position: absolute; inset: 0;
  background: linear-gradient(120deg, #e5e7eb 25%, #f1f5f9 50%, #e5e7eb 75%);
  background-size: 200% 100%;
  animation: ingr-skel 1.5s infinite;
  z-index: 0 !important;
}
@keyframes ingr-skel{ to { background-position: -200% 0; } }

.ingr-overlay{
  position:absolute; inset:0;
  z-index:1 !important;
  pointer-events:none;
  /* gradient renforcé pour garantir la lisibilité */
  background: linear-gradient(
    to bottom,
    rgba(0,0,0, calc((var(--ingr-ov, .6)) * 0.3)) 0%,
    rgba(0,0,0, var(--ingr-ov, .6)) 75%,
    rgba(0,0,0, var(--ingr-ov, .8)) 100%
  ) !important;
  opacity: 1 !important;
  mix-blend-mode: normal !important;
}

/* content (texte par-dessus l'image) */
.ingr-content{
  position:absolute; left:0; right:0; bottom:0;
  z-index:2 !important;
  padding: 24px 18px;
  color:#fff !important; text-align:left;
  text-shadow: 0 1px 2px rgba(0,0,0,.35);
}

/* Force toutes les sous-éléments (y compris liens) en blanc
   (Sense applique ses variables de couleur aux titres/liens) */
.ingr-content *,
.ingr-content a,
.ingr-content a:visited,
.ingr-content a:hover{
  color:#fff !important;
}

/* Titres/paragraphe */
.ingr-h3{ margin:0 0 8px !important; font-size: clamp(1.2rem, 2.2vw, 1.6rem); font-weight:700; }
.ingr-text{ margin:0 !important; font-size:.98rem; line-height:1.5; }

/* Responsive */
@media (max-width: 992px){
  .ingr-sec{ --ingr-card-h: 400px; }
}
@media (max-width: 768px){
  .ingr-wrap{ padding: 8px 15px 0; }

  .ingr-grid{
    display:flex;
    overflow-x:auto;
    gap:16px;
    padding: 10px 0 18px;
    margin: 0;
    width: 100%;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain; /* évite le scroll du body */
    box-sizing: border-box;
  }
  .ingr-grid::-webkit-scrollbar{ display:none; }

  .ingr-card{
    flex: 0 0 85%;
    min-width: 280px;
    height: var(--ingr-card-h, 380px);
    margin: 0;
    scroll-snap-align:center;
  }

  .ingr-title{ padding: 0 15px; }
  .ingr-subtitle{ padding: 0 15px; margin-bottom: 22px; }
}
/* --- PATCH: dégradé noir ancré en bas, compatible Sense --- */

/* Contexte d'empilement propre */
.ingr-sec .ingr-imgwrap{
  position: absolute; /* déjà absolute dans ta section, on garde */
  inset: 0;
  overflow: hidden;
  isolation: isolate; /* z-index fiable */
}

/* On désactive l'ancien overlay pour éviter les conflits */
.ingr-sec .ingr-overlay{ display: none !important; }

/* Nouveau dégradé via pseudo-élément (plus robuste) */
.ingr-sec .ingr-imgwrap::after{
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 60%;                    /* zone couverte depuis le bas */
  pointer-events: none;
  z-index: 2;                     /* au-dessus de l'image */
  background: linear-gradient(
    to top,
    rgba(0,0,0, var(--ingr-ov, .6)) 0%,
    rgba(0,0,0, calc(var(--ingr-ov, .6) * .85)) 35%,
    rgba(0,0,0, 0) 100%
  );
  opacity: 1 !important;
}

/* S’assure que le texte passe bien au-dessus du dégradé */
.ingr-sec .ingr-content{
  position: absolute;
  left: 0; right: 0; bottom: 0;
  z-index: 3 !important;
  color: #fff !important;
  text-align: left;
  text-shadow: 0 1px 2px rgba(0,0,0,.35);
}
.ingr-sec .ingr-content *,
.ingr-sec .ingr-content a,
.ingr-sec .ingr-content a:hover,
.ingr-sec .ingr-content a:visited{
  color:#fff !important;
}

/* Au cas où Sense aurait posé un transform sur la carte */
.ingr-sec .ingr-card{
  will-change: transform;
  transform: translateZ(0); /* crée un nouveau contexte GPU, stabilise z-index */
}
/* Layout & reset */
.doctor-testimonial { --dt-border: {{ section.settings.border_color }}; }
.doctor-testimonial .dt-card{
  display: grid;
  grid-template-columns: auto 1fr;        /* avatar | content */
  align-items: var(--dt-align, start);    /* 'start' or 'center' */
  gap: 14px;
  border: 1px solid var(--dt-border, #e1e1e1);
  background: #fff;
  padding: 16px;
  border-radius: 12px;
  box-shadow: 0 2px 4px rgba(0,0,0,.05);
}
.doctor-testimonial[data-valign="center"] .dt-card { --dt-align: center; }

.dt-avatar img{ width:60px; height:60px; border-radius:50%; object-fit:cover; display:block; }
.dt-content{ min-width:0; }

/* Stars row */
.dt-stars{ margin: 2px 0 8px; line-height: 0; }
.dt-stars-img{ width: 90px; height: auto; display: inline-block; vertical-align: middle; }

/* Quote text – remove theme indents/margins and insert quotes via CSS */
.dt-quote{
  margin: 0 0 8px;
  font-style: italic;
  font-size: 14px;
  color: #333;
  line-height: 1.55;
  text-indent: 0;         /* kill any theme blockquote style */
}
.dt-quote[data-quotes="true"]::before { content: "“"; margin-right: .25em; }
.dt-quote[data-quotes="true"]::after  { content: "”"; margin-left: .25em; }

/* Verified line */
.dt-verify{ display:flex; align-items:center; gap:6px; }
.dt-check{ width:18px; height:18px; flex:0 0 18px; }
.dt-name{ font-weight:600; font-size:14px; color:#333; }

/* Mobile tweaks */
@media (max-width:480px){
  .doctor-testimonial .dt-card{ padding:14px; gap:12px; }
  .dt-stars-img{ width:80px; }
  .dt-quote{ font-size:13.5px; }
}
.rating-reviews { background:#fff; }
.rating-reviews .container { max-width: 1200px; margin: 0 auto; padding: 20px; text-align: center; }

.rr-title { font-size: 26px; font-weight: 800; color:#222; margin: 0 0 6px; }
.rr-rating { font-size: 18px; color:#333; }
.rr-number { font-weight: 800; font-size: 22px; margin: 0 2px; }
.rr-stars { display:flex; justify-content:center; gap:6px; margin-top: 10px; }
.rr-star { width:22px; height:22px; display:block; }

/* Carousel container */
.rr-track-wrap{
  position: relative;
  margin-top: 18px;

  /* padding latéral réglable */
  padding: 0 var(--rr-side-pad, 20px) 12px var(--rr-side-pad, 20px);
  /* petit coussin à droite pour ne pas couper la dernière carte */
  padding-right: calc(var(--rr-side-pad, 20px) + 1px);

  overflow-x: auto;
  overflow-y: hidden;
  -ms-overflow-style: none;  /* IE/Edge */
  scrollbar-width: none;     /* Firefox */

  /* ✅ on redonne le scroll vertical à la page */
  touch-action: auto;
  overscroll-behavior-x: contain;
  -webkit-overflow-scrolling: touch;
}
.rr-track-wrap::-webkit-scrollbar{ display:none; }

/* Track : colonnes horizontales */
.rr-track{
  display: grid;
  grid-auto-flow: column;
  gap: var(--rr-gap, 20px);
  scroll-snap-type: x mandatory;
}

/* MOBILE : largeur carte = 100vw - (2×marge latérale) - aperçu */
@media (max-width: 740px){
  .rr-track{
    grid-auto-columns: calc(100vw - (var(--rr-side-pad, 20px) * 2) - var(--rr-peek, 24px));
  }
}

/* DESKTOP : largeur fixe en px */
@media (min-width: 741px){
  .rr-track{ grid-auto-columns: var(--rr-card-d, 440px); }
}

.rr-card{
  position: relative;
  scroll-snap-align: start;
  border: 1px solid #eee;
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 8px 26px rgba(0,0,0,.08);
  overflow: hidden;
  text-align: left;
  margin-right: calc(var(--rr-overlap, 0px) * -1);
  z-index: 0;
}
.rr-card:hover,
.rr-card:focus-within{ z-index: 1; }

.rr-photo{ width:100%; display:block; aspect-ratio: 4 / 3; object-fit: cover; }
.rr-caption{ padding: 14px 16px 18px; }
.rr-name{ font-weight:700; color:#111; margin-bottom: 6px; }
.rr-quote{ color:#333; margin: 0; line-height: 1.55; }

/* Fade edges */
.rr-fade{
  position: sticky;
  top: 0; bottom: 0;
  width: 28px; pointer-events: none;
  background: linear-gradient(to right, rgba(255,255,255,1), rgba(255,255,255,0));
}
.rr-fade--left{ left: 0; transform: translateX(-20px); }
.rr-fade--right{
  left: calc(100% - 28px);
  background: linear-gradient(to left, rgba(255,255,255,1), rgba(255,255,255,0));
  transform: translateX(20px);
}

/* Swipe hint */
.rr-hint{
  position: absolute;
  left: 50%; transform: translateX(-50%);
  bottom: -2px;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px; border-radius: 999px;
  background: rgba(0,0,0,.06); color:#111;
  font-size: 13px; font-weight: 600;
  backdrop-filter: blur(4px);
  transition: opacity .2s ease, transform .2s ease;
}
.rr-hint[hidden]{ opacity:0; transform: translateX(-50%) translateY(6px); }

.rr-hint-arrow{ animation: rr-nudge 1.2s ease-in-out infinite; }
@keyframes rr-nudge{ 0%,100%{ transform: translateX(0); } 50%{ transform: translateX(4px); } }

@media (max-width: 740px){
  .rr-title { font-size: 22px; }
  .rr-number { font-size: 20px; }
}
/* Wrapper & variables */
.sb-how{ background: var(--sb-bg, #FDF7E6); }
.sb-wrap{ max-width: 1200px; margin: 0 auto; padding: clamp(28px, 4vw, 60px) 16px; }

/* Grid */
.sb-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sb-gap, 60px);
  align-items: center;
}
@media (max-width: 900px){
  .sb-grid{ grid-template-columns: 1fr; }
  .sb-grid.sb-grid--img-first .sb-media{ order: 1; }
  .sb-grid.sb-grid--img-first .sb-content{ order: 2; }
}

/* Media */
.sb-media{ display:flex; justify-content:center; }
.sb-img{
  width: min(100%, 520px);
  aspect-ratio: 4/5;
  object-fit: cover;
  border-radius: var(--sb-radius, 20px);
  box-shadow: 0 22px 60px rgba(0,0,0, var(--sb-shadow, .1));
  background: #ececec;
}
.sb-img--ph{ background: linear-gradient(120deg,#e5e7eb 25%,#f1f5f9 50%,#e5e7eb 75%); background-size:200% 100%; animation: sb-skel 1.5s infinite; }
@keyframes sb-skel{ to{ background-position:-200% 0; } }

/* Content */
.sb-content{ color: var(--sb-text, #3f3f46); }
.sb-title{
  color: var(--sb-title, #1f2937);
  font-weight: 800;
  line-height: 1.1;
  font-size: clamp(28px, 4.2vw, 52px);
  letter-spacing: -0.02em;
  margin: 0 0 clamp(16px, 2.5vw, 28px);
}
.sb-highlight{ color: var(--sb-accent, #ef4444); }

.sb-steps{ display:flex; flex-direction:column; gap: clamp(14px, 2vw, 22px); }
.sb-step{ display:flex; gap: 12px; align-items:flex-start; }
.sb-step-icon{ flex:0 0 auto; display:inline-flex; margin-top: 4px; }
.sb-step-title{ font-weight: 700; color: var(--sb-title, #111827); font-size: clamp(16px, 2.2vw, 20px); }
.sb-step-desc{ color: var(--sb-text, #374151); font-size: clamp(14px, 2vw, 18px); line-height: 1.55; }

/* CTA */
.sb-cta-wrap{ margin-top: clamp(16px, 3vw, 28px); }
.sb-cta{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  background: var(--sb-accent, #ef4444); color:#fff; text-decoration:none;
  padding: 14px 26px; border-radius: 999px; font-weight: 700; box-shadow: 0 10px 28px rgba(239,68,68,.28);
  transition: transform .15s ease, box-shadow .15s ease, filter .15s ease;
}
.sb-cta:hover{ transform: translateY(-2px); box-shadow: 0 14px 36px rgba(239,68,68,.38); filter: brightness(.98); }
.sb-cta-arrow{ margin-left: 2px; }

/* Fine-tuning on small screens */
@media (max-width: 480px){
  .sb-img{ width: min(100%, 320px); }
}
/* Wrapper / variables */
.itg{ background: var(--itg-bg, #fff7ea); }
.itg__wrap{ max-width: 1200px; margin: 0 auto; padding: clamp(24px, 4vw, 56px) 16px; }

/* Grid */
.itg__grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--itg-gap, 48px);
  align-items: center;
}
@media (min-width: 900px){
  .itg__grid{ grid-template-columns: 1fr 1fr; }
  .itg__grid--image-right{ grid-auto-flow: dense; }
  .itg__grid--image-right .itg__media{ order: 2; }
}
/* Mobile order */
.itg__grid--m-below .itg__media{ order: 2; }
.itg__grid--m-below .itg__content{ order: 1; }

/* Media */
.itg__media{ display:flex; justify-content:center; }
.itg__img{
  width: min(100%, 560px);
  aspect-ratio: var(--itg-ar, 4 / 5);
  object-fit: cover;
  border-radius: var(--itg-radius, 20px);
  box-shadow: 0 22px 60px rgba(0,0,0,var(--itg-shadow,.1));
  background:#ececec;
}
.itg__img--ph{
  background: linear-gradient(120deg,#e5e7eb 25%,#f3f4f6 50%,#e5e7eb 75%);
  background-size: 200% 100%;
  animation: itg-skel 1.4s infinite;
}
@keyframes itg-skel{ to{ background-position:-200% 0; } }

/* Content */
.itg__content{ color: var(--itg-text,#374151); }
.itg__kicker{
  color: var(--itg-accent,#fb923c);
  font-weight: 700;
  letter-spacing: .02em;
  text-transform: uppercase;
  font-size: .9rem;
  margin: 0 0 6px;
}
.itg__title{
  color: var(--itg-title,#111827);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.1;
  font-size: clamp(28px, 4.2vw, 48px);
  margin: 0 0 clamp(14px, 2.2vw, 20px);
}
.itg__grad{
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  font-weight: 800;
}
.itg__grad--g1{
  background-image: linear-gradient(90deg, var(--itg-g1-from,#ff7a18), var(--itg-g1-to,#ffb86b));
}
.itg__grad--g2{
  background-image: linear-gradient(90deg, var(--itg-g2-from,#ff7a18), var(--itg-g2-to,#ffb86b));
}
.itg__body{
  font-size: clamp(15px, 2.1vw, 18px);
  line-height: 1.6;
  color: var(--itg-text,#374151);
}
.itg__cta-wrap{ margin-top: clamp(14px, 2.4vw, 22px); }
.itg__cta{
  display:inline-flex; align-items:center; gap:8px;
  background: var(--itg-accent,#fb923c); color:#fff; text-decoration:none;
  padding: 14px 22px; border-radius: 999px; font-weight: 700;
  box-shadow: 0 10px 28px rgba(251,146,60,.28);
  transition: transform .15s ease, box-shadow .15s ease, filter .15s ease;
}
.itg__cta:hover{ transform: translateY(-2px); box-shadow: 0 14px 36px rgba(251,146,60,.38); filter: brightness(.98); }
/* --- PATCH Sense : respecter l'aspect-ratio et afficher le média en entier --- */

/* Conteneur média : centré, sans étirement vertical */
.itg .itg__media{
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Cadre du média : taille contrôlée par aspect-ratio (pas par la hauteur du parent) */
.itg .itg__img,
.itg .itg__video{
  width: min(100%, 560px) !important;  /* même logique que ton CSS */
  height: auto !important;             /* annule les height:100% globaux */
  aspect-ratio: var(--itg-ar, 4 / 5) !important;
  object-fit: contain !important;      /* ✅ on voit 100% de l'image/vidéo */
  border-radius: var(--itg-radius, 20px) !important;
  box-shadow: 0 22px 60px rgba(0,0,0,var(--itg-shadow,.1)) !important;
  background: #ececec !important;      /* bandes latérales si besoin */
  display: block !important;
  max-width: 100% !important;          /* évite tout dépassement */
}

/* Si Sense colle height:100% via un sélecteur plus fort */
.itg .itg__media img.itg__img,
.itg .itg__media video.itg__video{
  height: auto !important;
  max-height: none !important;
}

/* Neutralise d’éventuels wrappers Flex qui étirent l’enfant */
.itg .itg__media > *{
  flex: 0 0 auto !important;
}
.video-row {
  padding: 20px;
  overflow-x: auto;
  -ms-overflow-style: none;  /* IE/Edge */
  scrollbar-width: none;     /* Firefox */
  background: var(--video-bg, #ffffff);
}
.video-row::-webkit-scrollbar { display: none; } /* Chrome/Safari */

/* Header / title */
.video-header{
  text-align: var(--title-align, center);
  margin-bottom: var(--title-mb, 16px);
}
.video-title{
  margin: 0;
  font-size: var(--title-size, 24px);
  font-weight: var(--title-weight, 800);
  line-height: 1.2;
  color: var(--title-color, #111111);
}
.video-subtitle{
  margin: 6px 0 0;
  color: rgba(17,17,17,.72);
  font-size: clamp(14px, 2.5vw, 16px);
}

/* Track */
.video-track { display: flex; gap: 16px; }

.video-item {
  flex: 0 0 auto;
  width: 280px;                /* each column width */
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 4px 16px rgba(0,0,0,.08);
  background: #000;            /* avoids white flash */
}

.video-embed {
  width: 100%;
  height: 100%;
  display: block;
  border-radius: 20px;
  object-fit: cover;
  aspect-ratio: 9 / 16;
}