@font-face {

  font-family: 'Tangent';

  src: url('//nutridome.de/cdn/shop/t/4/assets/Tangent-Light.woff?v=109283039714296229231744886298') format('woff');

  font-weight: 400;

  font-style: normal;

  font-display: swap;

}
@font-face {

  font-family: 'Tangent';

  src: url('//nutridome.de/cdn/shop/t/4/assets/Tangent-Medium.woff?v=101815703280399425621744886298') format('woff');

  font-weight: 700;

  font-style: normal;

  font-display: swap;

}
@font-face {

  font-family: 'Harmonia Sans';

  src: url(../fonts/harmoniasans-regular.woff2) format('woff2');

  font-weight: 400;

  font-style: normal;

  font-display: swap;

}
@font-face {

  font-family: 'Tenor Sans';

  src: url(../fonts/tenorsans-regular.woff2) format('woff2');

  font-weight: 400;

  font-style: normal;

  font-display: swap;

}
:root{

  --brand: #2f3f6b;

  --brand-deep: #151e40;

  --black: #0d1524;

  --bg-soft: #f2f4f8;

  --maxw: 1000px;

  --pad: 24px;

  --ratio-portrait: 126.4814814815%;

  --star: #f1c15a;

  --muted: rgba(13,21,36,0.74);

  --outline: #24335a;

  --outline-soft: rgba(36,51,90,0.18);

  --success: #3c9f88;

  --tint: #e6e9f3;

  --card-shadow: 0 10px 24px rgba(0,0,0,0.06);

  --radius: 16px;

  --space-s: 10px;

  --space-m: 16px;

  --space-l: 24px;

  --space-xl: 32px;

  --space-xxl: 48px;

  --subhead-size: 14px;

  --subhead-line: 1.5;

}
*{ box-sizing: border-box; }
html, body { min-height: 100%; }
html { font-size: 16px; scroll-behavior: smooth; }
  body{

  margin: 0;

  background: #fff;

  color: var(--black);

  font-family: "Tangent", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

  line-height: 1.4;

  text-align: center;

}
h1, h2, h3, h4{

  font-family: 'Tangent', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

}
.sr-only{

  position:absolute !important;

  width:1px;

  height:1px;

  padding:0;

  margin:-1px;

  overflow:hidden;

  clip:rect(0,0,0,0);

  white-space:nowrap;

  border:0;

}
.frame{

  width: 100%;

  max-width: var(--maxw);

  margin: 0 auto;

  background: #fff;

}
.section{

  padding-left: var(--pad);

  padding-right: var(--pad);

}
.section.nopad{ padding-left: 0; padding-right: 0; }
.site-topbar{

  background: #000;

  color: #fff;

}
.site-topbar__inner{

  max-width: var(--maxw);

  margin: 0 auto;

  display: flex;

  align-items: center;

  justify-content: center;

  gap: 8px;

  padding: 6px var(--pad);

  font-size: 0.6875rem;

  letter-spacing: 0.02em;

  text-transform: uppercase;

}
.site-topbar__text{

  line-height: 1;

}
.site-topbar__icon{

  width: 16px;

  height: 16px;

  display: block;

  color: #fff;

}
.site-header{

  position: -webkit-sticky;

  position: sticky;

  top: 0;

  left: 0;

  right: 0;

  z-index: 150;

  background: #fff;

  border-bottom: 1px solid rgba(0,0,0,0.08);

  color: #000;

}
.site-header__inner{

  max-width: var(--maxw);

  margin: 0 auto;

  display: flex;

  align-items: center;

  justify-content: space-between;

  padding: var(--space-s) var(--pad);

}
.site-header__brand{

  display: flex;

  flex-direction: column;

  align-items: flex-start;

  gap: 5px;

  text-decoration: none;

  color: inherit;

}
.site-header__brand img{

  height: 22px;

  width: auto;

  display: block;

}
.site-header__tagline{

  font-size: 0.625rem;

  letter-spacing: 0.08em;

  text-transform: uppercase;

  color: rgba(0,0,0,0.6);

}
.site-header__cart{

  position: relative;

  display: inline-flex;

  align-items: center;

  justify-content: center;

  padding: 6px;

  border: none;

  border-radius: 999px;

  background: transparent;

  color: inherit;

  cursor: pointer;

  transition: background-color 0.2s ease;

}
.site-header__cart:hover{

  background: rgba(0,0,0,0.06);

}
.site-header__cart:focus-visible{

  outline: 2px solid var(--outline);

  outline-offset: 2px;

}
.site-header__cart img{

  width: 22px;

  height: 22px;

  display: block;

}
.site-header__count{

  position: absolute;

  top: -2px;

  right: -2px;

  min-width: 16px;

  height: 16px;

  border-radius: 999px;

  background: var(--brand);

  color: #fff;

  font-size: 0.55rem;

  font-weight: 700;

  line-height: 1;

  display: flex;

  align-items: center;

  justify-content: center;

  transform: translate(50%,-50%);

}
.intro-breadcrumb{

  text-align: left;

  padding: var(--space-s) var(--pad) var(--space-m);

}
.hero{ padding: 0; }
.hero img{ display:block; width:100%; height:auto; }


/* ===== Mobile: Intro-Slider full-bleed bis an den Bildschirmrand ===== */

@media (max-width: 979px){

  .intro .intro-media .carousel{

margin-left: -24px;

    margin-right: -24px;

  }
}


.eyebrow{

  font-size: 12px;

  line-height: 1.2;

  text-transform: uppercase;

  color: var(--black);

  font-weight: 700;

  letter-spacing: 0.06em;

  margin: 16px 0 11px 0;

  text-align: left;

}


/* 3er Slider (mobile) */

.carousel{

  position: relative;

  margin-top: 8px;

}
.carousel-track{

  display: flex;

  gap: 12px;

  overflow-x: auto;

  -webkit-overflow-scrolling: touch;

  scroll-snap-type: x mandatory;

  padding-bottom: 6px;

}
.carousel-track::-webkit-scrollbar{ display: none; }
.slide{ flex: 0 0 86%; scroll-snap-align: center; }
.media{

  position: relative;

  border-radius: 0px;

  overflow: hidden;

  background: var(--bg-soft);

}
.ratio{position: relative; padding-top: var(--ratio-portrait); width: 100%; }
.vidbox { border-top: 1px solid var(--outline); border-bottom: 1px solid var(--outline)}
.ratio > img, .ratio > iframe{

  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block;

}
.carousel-badge{

  position: absolute;

  top: 8px;

  right: 8px;

  background: #fff;

  color: var(--black);

  font-weight: 700;

  font-size: 12px;

  line-height: 1;

  text-transform: uppercase;

  letter-spacing: 0.04em;

  padding: 8px 10px;

  border-radius: 4px;

  box-shadow: 0 2px 8px rgba(0,0,0,0.08);

  z-index: 2;

  pointer-events: none;

}


/* Bewertung und Headlines */

.rating{ margin-top: 18px; text-align: left; }
.rating-row{ display: inline-flex; align-items: center; gap: 8px; }
.stars{ display: inline-flex; gap: 0px; }
.star{ width: 18px; height: 18px; color: var(--star); display: inline-block; }
.reviews{ font-size: 14px; color: var(--black); }
.headline-eyebrow{

  margin: 10px 0 6px 0;

  font-size: 14px;

  line-height: 1.2;

  text-transform: uppercase;

  letter-spacing: 0.072em;

  color: var(--brand);

  font-weight: 700;

  text-align: left;

}
.headline{

  margin: 8px 0 16px 0;

  font-size: 28px;

  line-height: 1.18;

  font-weight: 700;

  color: var(--black);

  text-align: left;

  letter-spacing: 0.01em;

}
.subhead{

  margin: 0 0 28px 0;

  color: var(--muted);

  font-size: var(--subhead-size);

  line-height: var(--subhead-line);

  text-align: left;

}
.subhead--compact{ margin: 0 0 12px 0 !important; }
.brandmark{ margin: 20px 0; text-align: left; }
.brandmark img{ height: 20px; width: auto; display: block; }


/* Kaufblock */

.buy{ text-align: left; margin-bottom: 40px; }
.price-row{

  display: flex;

  align-items: baseline;

  gap: 12px;

  flex-wrap: wrap;

  margin: 0 0 10px 0;

}
.price-now{ font-size: 23px; font-weight: 700; color: var(--black); }
.price-old{ font-size: 14px; color: rgba(0,0,0,0.36); text-decoration: line-through; }
.save{ font-size: 14px; color: var(--brand); font-weight: 700; }
.buy-row{ display: flex; gap: 8px; align-items: stretch; margin: 24px 0 12px 0; }
.qty{

  flex: 0 0 118px;

  display: inline-flex;

  align-items: center;

  justify-content: center;

  border: 1px solid var(--outline);

  border-radius: 10px;

  overflow: hidden;

  height: 48px;

  background: #fff;

}
.qty-btn{

  width: 44px;

  height: 48px;

  border: 0;

  background: #fff;

  color: var(--black);

  font-size: 18px;

  cursor: pointer;

}
.qty-input{

  width: 48px;

  height: 48px;

  border: 0;

  text-align: center;

  font-size: 16px;

  background: #fff;

  color: var(--black);

}
.cta-primary{

  flex: 1 1 auto;

  display: flex;

  align-items: center;

  justify-content: center;

  background: var(--brand);

  color: #fff;

  border: 0;

  height: 48px;

  border-radius: 8px;

  font-weight: 600;

  font-size: 13px;

  letter-spacing: 0.02em;

  text-transform: uppercase;

  cursor: pointer;

  text-align: center;

  text-decoration: none;

}


/* Features */

.features{ display: grid; gap: 10px; margin-top: 10px; }
.feature-item{

  display: grid;

  grid-template-columns: 18px 1fr;

  gap: 10px;

  align-items: start;

}
.feature-icon{ width: 18px; height: 18px; color: var(--brand); flex: 0 0 18px; }
.feature-text{ font-size: 13px; color: var(--black); line-height: 1.45; }


/* Payments + Hinweis Versandkosten */

.payments{ margin-top: 12px; }
.pay-icons{

  display: flex;

  gap: 8px;

  flex-wrap: wrap;

  align-items: center;

}
.pay-badge{

  display: inline-flex;

  align-items: center;

  justify-content: center;

  height: 30px;

  width: 48px;

  border-radius: 8px;

  border: 0;

  background: #fff;

  color: #fff;

  font-weight: 700;

  font-size: 12px;

  border: solid 1px var(--outline);

}
.pay-badge .pay-logo{ display: block; height: 30px; width: auto; }
.free-shipping{ margin-top: 6px; font-size: 12px; color: var(--muted); }
.shipping{

  display: flex;

  align-items: center;

  gap: 8px;

  color: var(--brand);

  font-size: 14px;

  margin: 12px 0 12px 0;

}
.shipping .dot{

  width: 10px;

  height: 10px;

  border-radius: 50%;

  background: #22a254;

  box-shadow: 0 0 0 2px rgba(34,162,84,0.15);

}
.divider{ height: 1px; background: var(--outline); border: 0; margin: 8px 0 0 0; }


/* INFO-TOGGLES */

.info{

  background: #fff;

  padding-top: var(--space-xl);

  padding-bottom: var(--space-xl);

  margin-top: var(--space-xl);

  margin-bottom: var(--space-xxl);

  text-align: left;

}
.info-list{

  display: grid;

  grid-template-columns: 1fr;

  gap: 0;

  margin-top: 0;

  border-top: 1px solid var(--outline-soft);

}
.info-acc, .info-link{

  background: transparent;

  border: 0;

  border-radius: 0;

  box-shadow: none;

  border-bottom: 1px solid var(--outline-soft);

}
.info-acc summary, .info-link a{

  list-style: none;

  cursor: pointer;

  padding: 18px 0;

  display: grid;

  grid-template-columns: 1fr auto;

  align-items: center;

  gap: 10px;

  text-decoration: none;

  color: inherit;

}
.info-acc summary::-webkit-details-marker{ display:none; }
.info-title{

  margin: 0;

  font-weight: 700;

  font-size: 14px;

  line-height: 1.2;

  text-transform: uppercase;

  letter-spacing: .04em;

  color: var(--black);

}
.info-chevron{ width: 14px; height: 14px; color: rgba(0,0,0,0.85); transition: transform .18s ease; }
.info-acc[open] .info-chevron{ transform: rotate(180deg); }
.info-panel{ padding: 0 0 18px 0; font-size: 12.5px; color: var(--muted); line-height: 1.5; }
.info-arrow{ width: 14px; height: 14px; color: rgba(0,0,0,0.85); }
.info + .bridge{ margin-top: var(--space-xl); }


/* Warum Smilebite */

.why{

  margin: 0;

  text-align: left;

  background: #f2f4f8;

  padding-top: var(--space-xxl);

  padding-bottom: var(--space-xxl);

}
.section-intro{

  margin: 10px 0 28px 0;

  color: var(--muted);

  font-size: var(--subhead-size);

  line-height: var(--subhead-line);

  text-align: left;

}
.benefits{

  display: grid;

  grid-template-columns: 1fr;

  gap: 28px;

  margin-top: 16px;

}
.benefit{

  background: #fff;

  border: 1px solid var(--brand);

  border-radius: var(--radius);

  box-shadow: var(--card-shadow);

  padding: 18px;

  display: grid;

  gap: 10px;

}
.benefit .kicker-row{ display: inline-flex; align-items: center; gap: 8px; margin-bottom: 0; }
.kicker{ font-size: 11px; text-transform: uppercase; letter-spacing: .08em; font-weight: 700; color: var(--brand); opacity: 1; }
.check{ width: 16px; height: 16px; color: var(--brand); flex: 0 0 16px; }
.benefit-lead{ font-size: 18px; font-weight: 700; color: var(--black); line-height: 1.28; margin: 0; }
.benefit-copy{ font-size: 13px; color: var(--muted); line-height: 1.5; margin: 0; }
.footnote{ margin-top: 12px; font-size: 11px; color: rgba(0,0,0,0.5); }
.why-closer{
  margin-top: 28px;
  font-size: var(--subhead-size);
  line-height: var(--subhead-line);
  color: var(--muted);
}


/* ÃƒÅ“bergangsbild */

.bridge img{

  display:block; width:100%; height:auto; border-bottom: solid 1px var(--outline); border-top: solid 1px var(--outline);

}


/* Inhaltsstoffe */

.ingredients{

  background: #f2f4f8;

  padding-top: var(--space-xxl);

  padding-bottom: var(--space-xxl);

  text-align: left;

}
.ingredients .subhead{ margin-bottom: 28px; }
.ingr-acc{

  border: 1px solid var(--brand);

  border-radius: var(--radius);

  background: #fff;

  overflow: hidden;

  box-shadow: var(--card-shadow);

}
.ingr-acc + .ingr-acc{ margin-top: 28px; }
.ingr-acc summary{

  list-style: none;

  cursor: pointer;

  padding: 18px;

  display: grid;

  grid-template-columns: 1fr auto;

  align-items: center;

  gap: 10px;

}
.ingr-acc summary::-webkit-details-marker{ display:none; }
.ingr-head{ display: grid; gap: 10px; }
.ingr-icon line{ stroke: var(--brand); stroke-width: 2.2; stroke-linecap: round; }
.ingr-icon-line--vert{

  transition: opacity .2s ease;

  opacity: 1;

}




.ingr-acc[open] .ingr-icon-line--vert,

.ingr-toggle[open] .ingr-icon-line--vert{

  transition: opacity .2s ease;

  opacity: 1;

}








.ingr-kicker{ font-size: 11px; text-transform: uppercase; letter-spacing: .08em; font-weight: 700; color: var(--brand); opacity: 1; }
.ingr-title{ font-size: 18px; font-weight: 700; color: var(--black); line-height: 1.25; }
.ingr-sub{ font-size: 13px; color: var(--muted); }
.ingr-icon{ width: 20px; height: 20px; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.ingr-panel{ padding: 18px; padding-top: 18px; font-size: 11px; color: var(--muted); line-height: 1.5; border-top: 1px solid #f2f4f8; margin-top: 18px; }
.ingr-panel p{ margin: 0; }
.ingr-toggle{

  margin-top: 28px;

  background: #fff;

  border: 0;

  border-radius: 0;

  overflow: hidden;

  box-shadow: none;

}
.ingr-toggle summary{

  list-style: none;

  cursor: pointer;

  padding: 12px 14px;

  display: flex;

  align-items: center;

  justify-content: space-between;

  font-weight: 400;

  font-size: 13px;

  color: var(--muted);

}
.ingr-toggle summary::-webkit-details-marker{ display:none; }
.ingr-toggle .ingr-icon{ width: 20px; height: 20px; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.ingr-toggle .ingr-list{ padding: 0 14px 14px 14px; font-size: 13px; color: var(--muted); line-height: 1.5; }
.ingr-closer{ margin-top: 28px; font-size: var(--subhead-size); color: var(--muted); line-height: var(--subhead-line); }


/* Vergleich */
.compare-note{ margin-top: 16px; }
.compare-note--desktop{ display: block; }
.compare-note--mobile{ display: none; }

.compare{
  border-top: solid 1px var(--outline);
  background: #fff;
  padding-top: var(--space-xxl);
  padding-bottom: var(--space-xxl);
  padding-left: clamp(16px, 5vw, var(--pad));
  padding-right: clamp(16px, 5vw, var(--pad));
  text-align: left;
}
.cmp-card{
  position: relative;
  overflow: hidden;
  background: #fff;
  border-radius: 24px;
  border: 1px solid rgba(0,0,0,0.08);
  box-shadow: 0 20px 44px rgba(0,0,0,0.05);
  padding: clamp(12px, 4vw, 20px);
}
.cmp-table-wrap{
  overflow-x: auto;
}
.cmp-table{
  width: 100%;
  min-width: 0;
  table-layout: fixed;
  border-collapse: separate;
  border-spacing: 0;
}
\.cmp-table thead th{
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  text-align: center;
  padding: 0;
  border-bottom: 1px solid rgba(0,0,0,0.08);
}
.cmp-table thead th:first-child{
  width: 40%;
  border-bottom: none;
}
.cmp-head-label{
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  border: 0;
}
.cmp-head--brand{
  background: var(--brand);
  color: #fff;
  padding: 28px 0;
  font-size: 13px;
  letter-spacing: .12em;
  border-bottom: none;
  border-radius: 18px 18px 0 0;
  text-align: center;
}
.cmp-head--other{
  color: rgba(0,0,0,0.55);
  padding: 28px 0;
  font-size: 12px;
  letter-spacing: .08em;
  border-bottom: none;
  text-align: center;
}
.cmp-table tbody tr + tr th,
.cmp-table tbody tr + tr td{
  border-top: 1px solid rgba(0,0,0,0.08);
}
.cmp-table tbody tr + tr td.cmp-col--brand{
  border-top: 1px solid rgba(255,255,255,0.18);
}
.cmp-table tbody th{
  font-size: 15px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--black);
  padding: 20px clamp(12px,4vw,24px);
}
.cmp-table tbody td{
  padding: 18px 10px;
  text-align: center;
  vertical-align: middle;
}
.cmp-table tbody th{ width: 48%; }
.cmp-table thead th:nth-child(2),
.cmp-table tbody td.cmp-col--brand{
  background: var(--brand);
  color: #fff;
  position: relative;
  overflow: hidden;
  border-top: 1px solid rgba(255,255,255,0.18);
}
.cmp-table thead th:nth-child(3){ width: 26%; }
.cmp-table tbody td:last-child{
  width: 26%;
  color: rgba(0,0,0,0.65);
  position: relative;
}
.cmp-table tbody td.cmp-col--brand{
  background: var(--brand);
  color: #fff;
  position: relative;
  overflow: hidden;
  border-top: 1px solid rgba(255,255,255,0.18);
}
.cmp-table tbody tr:first-child td.cmp-col--brand{
  border-top: none;
}
.cmp-table tbody tr:last-child td.cmp-col--brand{
  border-bottom: none;
  border-bottom-left-radius: 18px;
  border-bottom-right-radius: 18px;
}
.cmp-table tbody td.cmp-col--brand::before,
.cmp-table tbody td.cmp-col--brand::after{
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 1px;
  background: rgba(255,255,255,0.16);
}
.cmp-table tbody td.cmp-col--brand::before{ left: 0; }
.cmp-table tbody td.cmp-col--brand::after{ right: 0; }
.cmp-table tbody td:last-child{
  color: rgba(0,0,0,0.65);
  position: relative;
}
.cmp-table tbody td:last-child::before{
  content: "";
  position: absolute;
  left: 0;
  top: 10px;
  bottom: 10px;
  width: 1px;
  background: rgba(0,0,0,0.08);
}
.cmp-table tbody tr:first-child th,
.cmp-table tbody tr:first-child td{ border-top: none; }
.cmp-table tbody tr:last-child th,
.cmp-table tbody tr:last-child td{ border-bottom: none; }
.cmp-icon{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 2px solid currentColor;
  background: rgba(255,255,255,0.04);
  transition: transform .2s ease;
}
.cmp-icon svg{
  width: 18px;
  height: 18px;
  stroke: currentColor;
  stroke-width: 2.4;
  stroke-linecap: round;
  stroke-linejoin: round;
  fill: none;
}
.cmp-icon--brand{
  background: #fff;
  color: var(--brand);
  border: 0;
  box-shadow: 0 10px 24px rgba(36,51,90,0.18);
}
.cmp-icon--other-check{
  background: transparent;
  color: var(--brand);
  border-color: rgba(47,63,107,0.28);
  opacity: 0.45;
}
.cmp-icon--cross{
  color: rgba(0,0,0,0.45);
  background: transparent;
  border-color: rgba(0,0,0,0.3);
}
.cmp-icon--cross svg{ stroke-width: 2.2; }
.cmp-table tbody td:last-child .cmp-icon--cross{
  border-color: rgba(0,0,0,0.25);
}
.cmp-disclaimer{
  margin-top: 20px;
  font-size: 11px;
  color: rgba(0,0,0,0.5);
  font-style: italic;
  text-align: center;
}
.cmp-card + .subhead{ margin-top: 28px; margin-bottom: 10px; }
@media (max-width: 640px){
  .compare{ padding-left: 16px; padding-right: 16px; }
  .cmp-card{ padding: 14px; border-radius: 20px; }
  .cmp-table{ min-width: 100%; }
  .cmp-table tbody th{ font-size: 14px; padding: 18px 12px; }
  .cmp-table tbody td{ padding: 16px 8px; }
  .cmp-icon{ width: 32px; height: 32px; }
  .cmp-icon svg{ width: 16px; height: 16px; }
}


/* So funktioniert's */

.how{

  background: #fff;

  padding-top: var(--space-xxl);

  padding-bottom: var(--space-xxl);

  text-align: left;

}
.steps{

  display: grid;

  grid-template-columns: 1fr;

  gap: 28px;

  margin-top: 16px;

}
.step{

  background: #f2f4f8;

  border: 1px solid var(--brand);

  border-radius: var(--radius);

  box-shadow: var(--card-shadow);

  padding: 18px;

  display: grid;

  gap: 10px;

}
.step-tag{ font-size: 11px; text-transform: uppercase; letter-spacing: .08em; font-weight: 700; color: var(--brand); opacity: 1; }
.step-title{ font-size: 18px; font-weight: 700; color: var(--black); margin: 0; line-height: 1.28; }
.step-copy{
  font-size: var(--subhead-size);
  line-height: var(--subhead-line);
  color: var(--muted);
  margin: 0;
}
.how-callout{ margin-top: 28px; background: none; border: 0; border-radius: 0; padding: 0; box-shadow: none; display: grid; gap: 6px; }
.how-callout .emph{
  font-weight: 700;
  color: var(--brand);
  font-size: var(--subhead-size);
  line-height: var(--subhead-line);
}
.how-closer{
  margin-top: 16px;
  font-size: var(--subhead-size);
  line-height: var(--subhead-line);
  color: var(--muted);
}


/* Testimonials */

.testimonials{

  background: #f2f4f8;

  padding-top: var(--space-xxl);

  padding-bottom: calc(var(--space-xxl) + 8px);

  text-align: left;

}
.testimonials .star{ color: var(--brand); }
.review-stars{ display: inline-flex; align-items: center; gap: 2px; }
.review-score{ font-size: 14px; font-weight: 700; letter-spacing: 0.02em; color: var(--black); margin-left: 6px; }
.review-text{

  font-size: 16px;

  line-height: 1.5;

  color: var(--black);

  margin: 2px 0 4px 0;

}
.review-author{ margin: 2px 0 0 0; font-size: 13px; color: var(--muted); }
.ba-grid{ display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 4px; }
.ba-box{

  position: relative;

  width: 100%;

  aspect-ratio: 5 / 4;

  border-radius: 16px;

  border: 0;

  overflow: hidden;

  background: #f2f5f4;

  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.6);

}
.ba-box img{

  position: absolute;

  inset: 0;

  width: 100%;

  height: 100%;

  object-fit: cover;

  object-position: center;

  display: block;

}
@media (min-width: 980px){

  .ba-box{

    aspect-ratio: 3 / 2;

  }
}
.ba-label{

  position: absolute; top: 8px; left: 8px; background: #fff; color: var(--brand); border-radius: 999px; padding: 6px 10px; font-size: 12px; font-weight: 700; line-height: 1;

}
.review-card{

  background: #fff;

  border: 1px solid var(--outline);

  border-radius: 16px;

  padding: 16px;

  display: grid;

  gap: 10px;

  box-shadow: var(--card-shadow);

}


/* Testimonials Slider (mobile) */

.t-carousel{ position: relative; margin-top: 16px; }
.t-track{

  display: flex;

  gap: 12px;

  overflow-x: auto;

  -webkit-overflow-scrolling: touch;

  scroll-snap-type: x mandatory;

  scroll-snap-stop: always;

  padding-bottom: 25px;

  scroll-behavior: smooth;

}


.t-slide{ flex: 0 0 86%; scroll-snap-align: center; display: flex; }
.t-controls{
  display: none;
  align-items: center;
  justify-content: space-between;
  margin-top: 18px;
  gap: 16px;
  flex-wrap: wrap;
}
.t-arrows{
  display: flex;
  gap: 12px;
}
.t-arrow{
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1px solid var(--brand);
  background: #fff;
  color: var(--brand);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  box-shadow: 0 14px 30px rgba(38,91,80,0.16);
  cursor: pointer;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
}
.t-arrow svg{
  width: 22px;
  height: 22px;
}
.t-arrow:hover{
  background: var(--brand);
  color: #fff;
  transform: translateY(-1px);
}
.t-arrow:focus-visible{
  outline: 2px solid var(--brand);
  outline-offset: 3px;
}
.t-arrow[disabled]{
  opacity: 0.4;
  cursor: not-allowed;
  background: rgba(255,255,255,0.85);
  color: var(--brand);
  box-shadow: none;
  transform: none;
}
.t-dots{
  display: none;
  gap: 8px;
}
.t-dot{
  width: 24px;
  height: 4px;
  border-radius: 999px;
  background: rgba(38,91,80,0.25);
  border: 0;
  padding: 0;
  transition: background .2s ease;
}
.t-dot[aria-current="true"]{ background: var(--brand); }
.cta-final .cta-primary {margin-top: 10px;}
.t-cta{ margin-top: 12px; display: grid; gap: 10px; }
.t-cta .cta-primary{ width: 100%; color: #fff !important; }
.t-cta .subhead{ margin-top: 28px; margin-bottom: 8px}

/* Social Proof Slider */
.social-proof{
  background: #f2f4f8;
  padding-top: var(--space-xxl);
  padding-bottom: var(--space-xxl);
  text-align: left;
}
.proof-carousel{
  margin-top: 24px;
  display: grid;
  gap: 10px;
  overflow: hidden;
}
.proof-track{
  display: flex;
  gap: 14px;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  scroll-snap-stop: always;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.proof-track::-webkit-scrollbar{
  display: none;
  width: 0;
  height: 0;
}
.proof-slide{
  position: relative;
  flex: 0 0 78% !important;
  display: flex;
  scroll-snap-align: start;
}
.proof-media{
  width: 100%;
  display: block;
  border-radius: var(--radius);
  box-shadow: var(--card-shadow);
  object-fit: cover;
}
.proof-slide + .proof-slide{ margin-left: 0; }
.proof-hint{
  font-size: var(--subhead-size);
  color: var(--muted);
  line-height: var(--subhead-line);
  margin: 16px 0 0 0;
}
.proof-controls{
  display: flex;
  justify-content: flex-end;
  margin-top: 12px;
}
@media (max-width: 767px){
  .proof-controls{
    justify-content: center;
  }
}
@media (min-width: 980px){
  .proof-controls{
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }
  .proof-track{
    gap: 12px;
    overflow-x: auto;
    scrollbar-width: thin;
    -ms-overflow-style: auto;
  }
  .proof-track::-webkit-scrollbar{
    display: block;
    height: 6px;
    background: rgba(0,0,0,0.08);
  }
  .proof-track::-webkit-scrollbar-thumb{
    background: rgba(0,0,0,0.4);
    border-radius: 999px;
  }
  .proof-slide{
    flex: 0 0 calc((100% - (5 * 12px)) / 6) !important;
  }
  .proof-controls .t-arrows{
    display: none;
  }
}

/* Backed by Science */
.science{
  background: #fff;

  padding-top: var(--space-xxl);

  padding-bottom: var(--space-xxl);

  text-align: left;

}
.science-metrics{

  display: grid;

  grid-template-columns: repeat(3, minmax(0, 1fr));

  gap: 16px;

  margin-top: 28px;

  margin-bottom: 28px;

  align-items: stretch;

}
.metric{

  background: #f2f4f8;

  border: 1px solid var(--brand);

  border-radius: 14px;

  padding: 14px;

  box-shadow: var(--card-shadow);

  display: flex;

  flex-direction: column;

  align-items: center;

  text-align: center;

  gap: 10px;

}
.metric .val{ font-size: 30px; font-weight: 700; color: var(--brand); }
.metric .label{ font-size: 13px; color: var(--muted); }


/* FAQ */

.faq{

  background: var(--brand);

  padding-top: var(--space-xxl);

  padding-bottom: 26px;

  text-align: left;

}
.faq .headline-eyebrow, .faq .headline, .faq .subhead{ color: #ffffff; }
.qa-list{

  display: grid;

  grid-template-columns: 1fr;

  gap: 18px;

  margin-top: 16px;

}
.qa{

  border: 0px solid rgba(255,255,255,0.28);

  border-radius: 12px;

  background: #fff;

  overflow: hidden;

}
.qa summary{

  list-style: none;

  cursor: pointer;

  padding: 18px 14px;

  display: grid;

  grid-template-columns: 1fr auto;

  align-items: center;

  gap: 12px;

}
.qa summary::-webkit-details-marker{ display:none; }
.qa .q{

  font-weight: 700;

  font-size: 15px;

  color: var(--black);

  line-height: 1.35;

  margin: 0;

}
.qa .icon{ width: 18px; height: 18px; position: relative; }
.qa .plus, .qa .minus{

  position: absolute; inset: 0; color: rgba(0,0,0,0.85); transition: opacity .18s ease, transform .18s ease;

}
.qa .minus{ opacity: 0; transform: rotate(-90deg); }
.qa[open] .plus{ opacity: 0; transform: rotate(90deg); }
.qa[open] .minus{ opacity: 1; transform: rotate(0deg); }
.qa .a{

  padding: 16px 14px;

  font-size: 13px;

  color: var(--muted);

  line-height: 1.55;

  border-top: 1px solid var(--outline);

  background: linear-gradient(180deg, #ffffff 0%, #fbfbfb 100%);

}
.faq .subhead:not(:first-of-type){ margin-top: 28px; }


/* CTA + Bundle (final) */

.cta-final{

  margin-top: 32px;

  background: #fff;

  border: 1px solid var(--outline);

  border-radius: 18px;

  padding: 18px;

  margin-bottom: 40px;

}
.cta-title{

  font-size: 20px;

  font-weight: 700;

  color: var(--black);

  margin: 0 0 6px 0;

}
.cta-copy{ font-size: 14px; color: var(--muted); margin: 0 0 12px 0; }
.cta-subline{
  margin-top: 16px;
  font-size: 18px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--brand);
  font-weight: 700;
}
.cta-price-row{ display: flex; align-items: baseline; gap: 12px; }
.cta-badge{

  background: var(--brand);

  color: #fff;

  font-weight: 700;

  font-size: 12px;

  padding: 7px 8px;

  border-radius: 10px;

  min-width: 44px;

  text-align: center;

}
.cta-price{ font-size: 26px; font-weight: 700; color: var(--brand); }
.cta-old{ font-size: 14px; color: rgba(0,0,0,0.36); text-decoration: line-through; }


.bundle{

  background: var(--bg-soft);

  border-radius: 14px;

  padding: 12px;

  margin-top: 14px;

}
.bundle h4{ margin: 2px 0 8px 0; font-size: 15px; color: var(--black); }
.b-item{

  background: #fff;

  border: 1px solid var(--outline);

  border-radius: 12px;

  padding: 14px;

  display: grid;

  grid-template-columns: auto 1fr auto;

  gap: 12px;

  align-items: center;

}
.b-item + .b-item{ margin-top: 10px; }
.b-thumb{

  width: 46px;

  height: 46px;

  object-fit: cover;

  border-radius: 8px;

  border: 1px solid var(--outline);

  background: #fff;

}
.b-name{ font-size: 13px; font-weight: 700; color: var(--black); }
.b-sub{ font-size: 11px; color: var(--muted); margin-top: 4px; }
.b-right{

  display: grid;

  grid-template-columns: auto 1fr;

  align-items: center;

  gap: 10px;

}
.b-price{

  background: #f1f5f3;

  color: var(--black);

  font-weight: 700;

  font-size: 12px;

  padding: 6px 10px;

  border-radius: 999px;

}
.b-pricing{ display: grid; gap: 4px; justify-items: end; }
.b-save{ display: inline-flex; align-items: center; gap: 8px; }
.b-old{ font-size: 9px; color: rgba(0,0,0,0.55); text-decoration: line-through; }
.b-off{ font-size: 9px; font-weight: 700; color: var(--brand); background: none; border-radius: 999px; padding: 2px 6px; }
.b-check{ width: 18px; height: 18px; accent-color: var(--brand); }
.bundle-cta{ width: 100%; }


.trust-row{

  margin-top: 14px;

  display: flex;

  gap: 12px;

  flex-wrap: wrap;

}
.trust{

  background: #fff;

  color: var(--black);

  border: 1px solid var(--outline);

  border-radius: 999px;

  padding: 8px 10px;

  font-size: 12px;

  font-weight: 700;

  display: inline-flex;

  align-items: center;

  gap: 6px;

}
.trust .tick{ width: 14px; height: 14px; color: var(--brand); }


/* Kontaktkarte (not used here but kept) */

.contact-card{

  background: #fff;

  border: 1px solid var(--outline);

  border-radius: 16px;

  padding: 14px;

  box-shadow: var(--card-shadow);

  display: grid;

  gap: 8px;

}
.contact .cta-primary, .faq .cta-primary{

  width: 100%;

  height: 48px;

  border-radius: 8px;

  font-size: 13px;

}
.contact .info, .faq .info{ font-size: 13px; color: var(--muted); }


/* Desktop layout enhancements */

@media (min-width: 980px){
  :root{
    --maxw: 1400px;

    --pad: 32px;

    --subhead-size: 18px;

    --subhead-line: 1.55;

  }
  .compare{ border-top: 0; }

  body{ text-align: left; }
  .frame{ max-width: var(--maxw); }


  /* ===== Headlines: grÃƒÂ¶ÃƒÅ¸er & markanter (leicht zApple-likeÃƒÅ“) ===== */

  .headline{

    font-size: clamp(36px, 3.2vw, 56px);

    line-height: 1.08;

    letter-spacing: -0.015em;

    margin: 12px 0 18px 0;

  }
  .intro .headline{

    font-size: clamp(28px, 2.4vw, 32px);

    line-height: 1.04;

    letter-spacing: -0.02em;

  }
  /* Intro: media left, details right */

  .intro-grid{

    display: grid;

    grid-template-columns: 1.26fr 0.74fr;

    gap: 48px;

    align-items: start;

  }
  .intro-details{ position: relative; top: 0; }


  /* Turn the mobile carousel into a 2x2 masonry-like grid on desktop */

  .carousel-track{

    display: grid;

    grid-template-columns: 1fr 1fr;

    gap: 16px;

    overflow: visible;

    scroll-snap-type: none;

    padding-bottom: 0;

  }
  .slide{ flex: initial; scroll-snap-align: unset; }
  .slide.placeholder{ display: block; }
  .slide:nth-child(1){ grid-column: 1; grid-row: 1; }
  .slide:nth-child(2){ grid-column: 2; grid-row: 1; }
  .slide:nth-child(3){ grid-column: 1; grid-row: 2; }
  .slide.placeholder{

    grid-column: 2; grid-row: 2;

    background: #f2f5f4;

    border: 1px dashed rgba(36,51,90,0.18);

    border-radius: 12px;

    display: flex;

    align-items: center; justify-content: center;

    min-height: 280px;

  }
  .slide.placeholder .ph{

    font-size: 12px;

    color: rgba(0,0,0,0.45);

    text-transform: uppercase;

    letter-spacing: .08em;

    font-weight: 700;

  }


  /* Info toggles when placed in the right column: remove outer margins */

  .intro-details .info{

    margin-top: var(--space-l);

    margin-bottom: 0;

    padding-top: var(--space-l);

    padding-bottom: 0;

  }


  /* Generic two-column row wrapper */

  .row{

    display: grid;

    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);

    gap: 32px;

    align-items: center;

    padding-left: var(--pad);

    padding-right: var(--pad);

  }
  .row .content{ order: 1; }
  .row .row-media{ order: 2; }
  .row.media-left .row-media{ order: 1; }
  .row.media-left .content{ order: 2; }

  .row .content,

  .row .row-media{

    min-width: 0;

  }


  /* Keep section backgrounds on rows */

  .row.bg-soft{ background: transparent; }
  .row .row-media.bridge img{

    border-top: 1px solid var(--outline);

    border-bottom: 1px solid var(--outline);

  }


  /* Why section inside row: remove double paddings, keep spacing */

  .why{ padding-top: var(--space-xl); padding-bottom: var(--space-xl); background: transparent; }
  .why .benefits{ grid-template-columns: 1fr 1fr; gap: 16px; }


  /* Science row */

  .science{ padding-top: var(--space-xl); padding-bottom: var(--space-xl); }
  .science-metrics{ grid-template-columns: repeat(3,1fr); }


  /* Ingredients row */

  .ingredients{ padding-top: var(--space-xl); padding-bottom: var(--space-xl); }
  .ingredients .ingr-acc + .ingr-acc{ margin-top: 18px; }


  /* How section inside row */

  .how{ padding-top: var(--space-xl); padding-bottom: var(--space-xl); }


  /* Testimonials: Slider auch auf Desktop UND Bild links / Slider rechts */

  .testimonials{ padding-top: var(--space-xl); padding-bottom: var(--space-xl); background: transparent; }
  .t-track{
  display: flex;
  gap: 12px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x mandatory;
  scroll-snap-stop: always;
  padding-bottom: 25px;
  scroll-behavior: smooth;
}

  .t-slide{ flex: 0 0 86% !important; scroll-snap-align: center !important; display: flex !important; }

  .proof-track .t-slide{
    flex: 0 0 78% !important;
    scroll-snap-align: start !important;
  }

  @media (min-width: 980px){
    .proof-track .t-slide{
      flex: 0 0 calc((100% - (5 * 12px)) / 6) !important;
    }
  }


  /* Compare: media next to text */

  .compare-grid{

    display: grid;

    grid-template-columns: 1fr 1fr;

    gap: 32px;

    align-items: center;

  }
  .compare-grid .compare-text{ order: 1; }
  .compare-grid .compare-media{ order: 2; }


  /* FAQ: 2 columns */

  .qa-list{ grid-template-columns: 1fr 1fr; gap: 16px; }


  /* CTA final: 2 columns (left description, right bundle) */

  .cta-final-grid{

    display: grid;

    grid-template-columns: 1fr 1fr;

    gap: 24px;

    align-items: start;

  }
  .cta-left .cta-price-row{ margin-top: 8px; }
  .cta-right .bundle{ margin-top: 0; }


  /* ==== FULL-WIDTH BACKGROUNDS (Desktop) ==== */

  .row, .section{ position: relative; z-index: 0; }
  .row.bg-soft::before,
  .section.faq::before,
  .section.social-proof::before{
    content: "";
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: 0;
    bottom: 0;

    width: 100vw;

    z-index: -1;

    pointer-events: none;

  }
  .row.bg-soft::before{ background: var(--bg-soft); }
  .section.faq::before{ background: var(--brand); }
  .section.social-proof::before{ background: #f2f4f8; }


  /* ==== MORE SPACE BETWEEN SECTIONS (Desktop) ==== */

  main > * + *{ margin-top: 72px; }


  /* ==== REMOVE TOP/BOTTOM BORDERS ON MEDIA (Desktop) ==== */

  .bridge img,

  .row .row-media.bridge img,

  .vidbox{

    border-top: none !important;

    border-bottom: none !important;

  }


  /* ==== ROUNDED CORNERS FOR IMAGES & VIDEOS (Desktop) ==== */

  .bridge img,

  .row .row-media img,

  .ratio > img,

  .ratio > iframe,

  .media,

  .vidbox,

  .cmp-card img{

    border-radius: var(--radius);

  }
  .media, .vidbox{ overflow: hidden; }
}


/* Utility: hide desktop placeholder on mobile to keep slider UX identical */

.slide.placeholder{ display: none; }


/* === Cart Modal Styles === */

/* Body Scroll Lock, wenn Modal offen ist */

body.modal-open { overflow: hidden; }


/* Backdrop */

.cart-backdrop{

  position: fixed; inset: 0;

  background: rgba(0,0,0,.42);

  z-index: 9990;

  opacity: 0; pointer-events: none;

  transition: opacity .18s ease;

}
.cart-backdrop.is-open{ opacity: 1; pointer-events: auto; }


/* Modal Container (full-screen) */

.cart-modal{

  position: fixed; inset: 0;

  background: #fff;

  z-index: 10000;

  display: grid;

  grid-template-rows: auto 1fr auto; /* Header / Scroll / Sticky CTA */

  width: 100%;

  max-width: none;

  margin-left: auto;

  transform: translateY(8px);

  opacity: 0; pointer-events: none;

  transition: transform .18s ease, opacity .18s ease;

}
.cart-modal.is-open{ transform: translateY(0); opacity: 1; pointer-events: auto; }


@media (min-width: 1200px){

  .cart-modal{

    left: auto;

    right: 0;

    width: 33.333vw;

    min-width: 600px;

    border-top-left-radius: var(--radius);

    border-bottom-left-radius: var(--radius);

    box-shadow: -24px 0 48px rgba(0,0,0,0.16);

    transform: translateX(16px);

  }
  .cart-modal.is-open{ transform: translateX(0); }
}


/* Header */

.cart-head{

  display:flex; align-items:center; justify-content:space-between;

  padding: 14px 16px; border-bottom: 1px solid var(--outline, #d9d9d9);

}
.cart-title{

  display:flex; align-items: center; gap: 10px; font-weight: 700; letter-spacing: .02em;

}
.cart-close{

  appearance:none; border:0; background:transparent; cursor:pointer;

  width: 36px; height: 36px; border-radius: 8px;

  display:grid; place-items:center;

}
.cart-close:hover{ background: rgba(0,0,0,0.06); }


/* Info Bar (Free Shipping / Delivery) */

.cart-infobar{

  display:flex;

  align-items:center;

  gap:8px;

  padding: 14px 18px 12px;

  background:transparent;

  border-bottom: 1px solid var(--outline, #e6e6e6);

  font-size: 11px;

  line-height: 1.4;

  color: rgba(0,0,0,0.6);

}
.cart-info-icon{

  width:18px;

  height:18px;

  display:block;

  flex-shrink:0;

}


/* Content scroll area */

.cart-body{ overflow:auto; -webkit-overflow-scrolling: touch; }
.cart-section{ padding: 14px 16px; }


/* Line Items */

.cart-items{ display:grid; gap: 12px; }
.ci{

  display:grid; grid-template-columns: 64px 1fr auto; gap: 12px;

  border: 1px solid var(--outline, rgba(0,0,0,.12));

  border-radius: 12px; padding: 10px; background:#fff;

}
.ci-thumb{ width:64px; height:64px; border-radius:10px; object-fit:cover; border:1px solid var(--outline,#e6e6e6); }
.ci-title{ font-weight:700; font-size: 14px; }
.ci-meta{ font-size:12px; color: rgba(0,0,0,.6); margin-top: 2px; }
.ci-actions{ display:grid; gap:8px; align-content:start; }
.ci-remove{

  appearance:none; border:0; background:transparent; cursor:pointer; width:32px; height:32px; border-radius:8px; display:grid; place-items:center;

}
.ci-remove:hover{ background: rgba(0,0,0,.06); }


/* Quantity stepper */

.qtybox{ display:inline-flex; border:1px solid var(--outline,#cfd6d3); border-radius:10px; overflow:hidden; height:36px; }
.qtybox button{

  width:36px; height:36px; border:0; background:#fff; cursor:pointer; font-size:18px;

}
.qtybox input{

  width:44px; height:36px; border:0; text-align:center; font-size:14px;

}


/* Price row (line total) */

.ci-price{ font-weight:700; font-size: 14px; margin-top: 6px; }


/* Upsells */

.cart-upsells{ display:grid; gap:10px; }
.ups-card{

  display:grid; grid-template-columns: 52px 1fr auto; align-items:center; gap: 12px;

  border: 1px dashed var(--outline,#d9d9d9); border-radius: 12px; padding: 10px; background: #fff;

}
.ups-thumb{ width:52px; height:52px; border-radius:8px; object-fit:cover; border:1px solid var(--outline,#e6e6e6); }
.ups-title{ font-weight:700; font-size: 13px; }
.ups-sub{ font-size:12px; color: rgba(0,0,0,.6); margin-top: 2px; }
 .ups-add{

  appearance:none; border:0; background: var(--brand,#2f3f6b); color:#fff; cursor:pointer;

  padding: 10px 12px; border-radius: 8px; font-weight: 700; font-size: 12px; text-transform: uppercase;

}
.ups-add[disabled]{

  background: rgba(0,0,0,0.15);

  color: rgba(0,0,0,0.5);

  cursor: not-allowed;

}


/* Badges / Benefits */

.benefit-row{

  display:flex;

  gap:10px;

  flex-wrap:wrap;

  margin: 18px 0 20px;

  padding-bottom: 8px;

}
.badge{

  background:#fff; border: 1px solid var(--outline,#d9d9d9); border-radius:999px;

  padding: 8px 10px; font-size: 12px; font-weight:700; display:inline-flex; gap:6px; align-items:center;

}


/* Terms */

.cart-terms{

  display:flex;

  gap:10px;

  align-items:flex-start;

  font-size:12px;

  color: rgba(0,0,0,.75);

}
.cart-terms input{

  margin-top:2px;

  outline:2px solid transparent;

  outline-offset:2px;

}
.cart-terms input:not(:checked){

  outline-color:#d32f2f;

}
.cart-terms label{

  margin-left:6px;

}
.cart-terms a{

  color: var(--brand,#2f3f6b);

  text-decoration: underline;

}
.cart-terms--sticky{ margin-bottom:8px; }


/* Sticky Checkout */

.cart-sticky{

  position: sticky; bottom: 0; background: #fff;

  border-top: 1px solid var(--outline, #d9d9d9);

  padding: 12px 16px;

  display:grid; gap:8px;

}
.cart-summary{ display:flex; align-items:center; justify-content:space-between; }
.cart-total{ font-weight:700; font-size: 16px; }
.cart-checkout{

  appearance:none; border:0; background: var(--brand,#2f3f6b); color:#fff; cursor:pointer;

  width:100%; height:48px; border-radius:8px; font-weight:700; letter-spacing:.02em; text-transform:uppercase;

}
.cart-checkout[disabled]{ opacity:.5; cursor:not-allowed; }


/* Small helpers */

.hr{

  height:1px;

  background: var(--outline,#e0e0e0);

  border:0;

  width: calc(100% + 32px);

  margin: 20px -16px;

}


.sr-only{ position:absolute !important; width:1px; height:1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }


















/* ===== Footer ===== */

.site-footer{

  background:#000;

  color:#fff;

  padding: 48px clamp(24px, 8vw, 96px) 32px;

}
.site-footer a{ color:#fff; text-decoration:none; }
.site-footer a:hover{ text-decoration:underline; }
.footer-inner{

  width: 100%;

  max-width: none;

  margin: 0;

  display:grid;

  gap:32px;

}
.footer-columns{

  display:grid;

  gap:16px;

}
.footer-accordion{

  background:transparent;

  border:1px solid rgba(255,255,255,0.1);

  border-radius:12px;

  padding: 16px;

}
.footer-accordion summary{

  list-style:none;

  display:flex;

  align-items:center;

  justify-content:space-between;

  gap:12px;

  cursor:pointer;

  font-weight:700;

  letter-spacing:0.08em;

  text-transform:uppercase;

  font-size:12px;

}
.footer-accordion summary::-webkit-details-marker{ display:none; }
.footer-toggle-icon{

  display:inline-flex;

  width:20px;

  height:20px;

  border-radius:50%;

  border:1px solid rgba(255,255,255,0.4);

  align-items:center;

  justify-content:center;

  font-size:12px;

}
.footer-toggle-icon::before{ content:'+'; }
.footer-accordion[open] .footer-toggle-icon::before{ content:'Ã¢â‚¬â€œ'; }
.footer-panel{

  margin-top:16px;

  font-size:13px;

  color:rgba(255,255,255,0.75);

}
.footer-panel ul{ list-style:none; margin:0; padding:0; display:grid; gap:10px; }
.footer-panel p{ margin:0; }
.footer-payments{

  display:flex; flex-wrap:wrap; gap:10px; margin-top:12px;

}
.footer-payments img{ height:24px; width:auto; filter:none; }
.footer-contact{

  font-size:13px;

  color:rgba(255,255,255,0.75);

  line-height:1.6;

}
.footer-social{

  display:flex; gap:12px;

}
.footer-social-icon{

  width:36px; height:36px; border-radius:50%; background:rgba(255,255,255,0.12);

  display:inline-flex; align-items:center; justify-content:center;

  font-weight:700; letter-spacing:0.04em;

}
.footer-bottom{

  display:flex; flex-direction:column; gap:16px;

}
.locale-btn{

  appearance:none; border:1px solid rgba(255,255,255,0.3); background:transparent;

  color:#fff; padding:10px 16px; border-radius:999px;

  display:inline-flex; align-items:center; gap:10px; cursor:pointer;

}
.locale-btn .flag{ font-size:18px; }
.footer-meta{ font-size:12px; color:rgba(255,255,255,0.6); }


@media (min-width: 768px){




  .footer-columns{ grid-template-columns: repeat(3, minmax(0,1fr)); gap:24px; }
  .footer-accordion{ border:0; padding:0; }
  .footer-accordion summary{ cursor:default; padding-bottom:12px; border-bottom:1px solid rgba(255,255,255,0.12); font-size:13px; }
  .footer-toggle-icon{ display:none; }
  .footer-accordion[open] .footer-panel{ display:block; margin-top:18px; }
  .footer-bottom{ flex-direction:row; align-items:center; justify-content:space-between; }
  .footer-social{ justify-content:flex-end; }
  .locale-btn{ order:0; }
  .footer-meta{ order:1; }
}


@media (max-width: 767px){

  .compare-note--desktop{ display: none; }\r\n  .compare-note--mobile{ display: block; }\r\n  .t-carousel{ overflow: hidden; }

  .t-track{ margin-bottom: -20px; padding-bottom: 25px; }



  .t-track{ scrollbar-width: none; -ms-overflow-style: none; }
  .t-track::-webkit-scrollbar{
    display: none;
    width: 0;
    height: 0;
    background: transparent;
  }
  .t-controls{ display: flex; margin-top: 12px; }
  .t-dots{ display: flex; align-items: center; justify-content: center; flex: 1 1 auto; }






  .ingr-track .ingr-acc summary{ pointer-events: none; cursor: default; }
  .ingr-track .ingr-acc summary:focus{ outline: none; }
  .footer-panel{ margin-top:12px; }
}






















































/* Mobile sticky CTA */

.mobile-sticky-cta{

  position: fixed;

  left: 0;

  right: 0;

  bottom: 0;

  background: #fff;

  border-top: 1px solid rgba(0,0,0,0.08);

  padding: 12px 16px calc(12px + env(safe-area-inset-bottom));

  box-shadow: 0 -8px 24px rgba(0,0,0,0.08);

  display: none;

  z-index: 140;

}
.mobile-sticky-cta .mobile-sticky-inner{

  display: flex;

  align-items: center;

  justify-content: space-between;

  gap: 16px;

}
.mobile-pricing{ display: flex; align-items: baseline; gap: 10px; line-height: 1.2; }
.mobile-sticky-copy{ display: flex; flex-direction: column; gap: 6px; align-items: flex-start; flex: 1; }
.mobile-sticky-label{ font-size: 11px; letter-spacing: 0.04em; text-transform: uppercase; color: rgba(0,0,0,0.6); }
.mobile-old-price{

  font-size: 12px;

  color: var(--muted);

  text-decoration: line-through;

}
.mobile-current-price{

  font-size: 18px;

  font-weight: 700;

  color: var(--black);

}
.mobile-sticky-button{

  background: var(--brand);

  color: #fff;

  border: 0;

  padding: 10px 20px;

  border-radius: 999px;

  font-weight: 700;

  letter-spacing: 0.02em;

  cursor: pointer;

  flex-shrink: 0;

}
.mobile-sticky-button:focus-visible{

  outline: 2px solid var(--outline);

  outline-offset: 2px;

}
.mobile-sticky-cta.is-visible{

  display: block;

}
@media (max-width: 767px){

  .compare-note--desktop{ display: none; }\r\n  .compare-note--mobile{ display: block; }\r\n







  body.mobile-cta-visible{ padding-bottom: 96px; }
}
@media (min-width: 768px){




  .mobile-sticky-cta{ display: none !important; }
}
/* Ingredients slider (beta) */

.ingr-carousel{

  margin-top: 28px;

}
.ingr-track{

  display: grid;

  gap: 24px;

}
.ingr-track:focus{ outline: none; }
.ingr-controls{
  display: none;
  align-items: center;
  justify-content: space-between;
  margin-top: 18px;
  gap: 16px;
  flex-wrap: wrap;
}
.ingr-arrows{

  display: flex;

  gap: 12px;

}
.ingr-arrow{

  width: 44px;

  height: 44px;

  border-radius: 50%;

  border: 1px solid var(--brand);

  background: #fff;

  color: var(--brand);

  display: inline-flex;

  align-items: center;

  justify-content: center;

  padding: 0;

  box-shadow: 0 14px 30px rgba(38,91,80,0.16);

  cursor: pointer;

  transition: transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease;

}
.ingr-arrow svg{

  width: 22px;

  height: 22px;

}
.ingr-arrow:hover{

  background: var(--brand);

  color: #fff;

  transform: translateY(-1px);

}
.ingr-arrow:focus-visible{

  outline: 2px solid var(--brand);

  outline-offset: 3px;

}
.ingr-arrow[disabled]{

  opacity: 0.4;

  cursor: not-allowed;

  background: rgba(255,255,255,0.85);

  color: var(--brand);

  box-shadow: none;

  transform: none;

}
.ingr-dots{
  display: none;
  gap: 8px;
}
.ingr-dot{
  width: 24px;
  height: 4px;
  border-radius: 999px;
  background: rgba(38,91,80,0.25);
  border: 0;
  padding: 0;
  transition: background .2s ease;
}
.ingr-dot[aria-current="true"]{ background: var(--brand); }
@media (max-width: 767px){

  .compare-note--desktop{ display: none; }\r\n  .compare-note--mobile{ display: block; }\r\n







  .ingredients .subhead{ margin-bottom: 18px; }
  .ingr-carousel{ margin-top: 22px; }
  .ingr-track{

    display: flex;

    overflow-x: auto;

    -webkit-overflow-scrolling: touch;

    scroll-snap-type: x mandatory;

    scroll-snap-stop: always;

    gap: 18px;

    padding: 6px 16px 36px;

    scrollbar-width: none;

  }
  .ingr-track::-webkit-scrollbar{
    display: none;
    width: 0;
    height: 0;
    background: transparent;
  }
  .ingr-track .ingr-acc{

    flex: 0 0 calc(100% - 48px);

    scroll-snap-align: center;

    border: 1px solid var(--brand);

    border-radius: 28px;

    background: #fff;

    box-shadow: var(--card-shadow);

  }
  .ingr-track .ingr-acc summary{

    pointer-events: none;

    cursor: default;

    padding: 24px 24px 0;

    display: block;

  }
  .ingr-track .ingr-acc summary::-webkit-details-marker{ display: none; }
  .ingr-track .ingr-acc summary svg{ display: none; }
  .ingr-track .ingr-head{

    display: flex;

    flex-direction: column;

    gap: 12px;

  }
  .ingr-track .ingr-kicker{

    font-size: 13px;

    letter-spacing: .08em;

    text-transform: uppercase;

    color: var(--brand);

  }
  .ingr-track .ingr-title{

    font-size: 28px;

    font-weight: 700;

    color: var(--black);

    line-height: 1.15;

  }
  .ingr-track .ingr-sub{

    font-size: 17px;

    font-style: italic;

    color: var(--muted);

  }
  .ingr-track .ingr-panel{

    padding: 18px 24px 24px;

    font-size: 14px;

    color: var(--muted);

    line-height: 1.6;

    border: 0;

    margin-top: 0;

  }
  .ingr-track .ingr-panel p{ margin: 0; }
  .ingr-track .ingr-panel p + p{ margin-top: 12px; }
  .ingr-controls{ display: flex; margin-top: 6px; }


  .ingr-dots{

    display: flex;

    align-items: center;

    justify-content: center;

    flex: 1 1 auto;

  }
}
@media (min-width: 768px){




  .ingr-controls{ display: none !important; }
  .ingr-dots{ display: none !important; }
}


/* Support Section */

.support{

  margin-top: var(--space-xl);

  padding: var(--space-xl) var(--pad);

  background: var(--bg-soft);

}
.support-inner{

  max-width: 640px;

  margin: 0 auto;

  display: grid;

  gap: 16px;

  text-align: center;

}
.support-title{

  margin: 0;

  font-size: 22px;

  font-weight: 700;

  color: var(--black);

}
.support-copy{

  margin: 0;

  color: var(--muted);

  font-size: 14px;

  line-height: 1.6;

}
.support-actions{

  display: flex;

  flex-direction: column;

  gap: 10px;

  justify-content: center;

  align-items: center;

}
.support-btn{

  display: inline-flex;

  justify-content: center;

  align-items: center;

  padding: 12px 24px;

  border-radius: 999px;

  border: 1px solid var(--brand);

  font-weight: 700;

  font-size: 13px;

  color: var(--brand);

  text-decoration: none;

  transition: background-color .2s ease, color .2s ease;

}
.support-btn:hover{

  background: rgba(38,91,80,0.1);

}
.support-btn--primary{

  background: var(--brand);

  color: #fff;

}
.support-btn--primary:hover{

  background: var(--brand-deep);

  color: #fff;

}
.support-divider{

  height: 1px;

  background: rgba(0,0,0,0.08);

  margin: 8px auto;

  width: 100%;

}
@media (min-width: 600px){

  .support-actions{ flex-direction: row; }
}
.support-btn:focus-visible{ outline: 2px solid var(--outline); outline-offset: 2px; }


























@media (max-width: 767px){

  .compare-note--desktop{ display: none; }\r\n  .compare-note--mobile{ display: block; }\r\n






}
@media (min-width: 768px){



}









































































