@import url('https://fonts.googleapis.com/css2?family=Fraunces:wght@500;700&family=Source+Sans+3:wght@400;500;600;700&display=swap');

:root{
  --ink:#1f2d2a;
  --ink-strong:#16201d;
  --muted:#4d5b57;
  --bg:#f6f1e8;
  --bg-2:#fff9f2;
  --card:#ffffff;
  --accent:#d77b62;
  --accent-deep:#b35f4a;
  --teal:#2f6f69;
  --teal-deep:#1f4e48;
  --sage:#8aa39b;
  --gold:#c7a05d;
  --line:rgba(31,45,42,.14);
  --shadow:0 22px 50px rgba(24,35,33,.12);
  --shadow-strong:0 30px 70px rgba(24,35,33,.18);
  --radius-xl:58px;
  --radius-lg:40px;
  --radius-md:28px;
  --radius-sm:20px;
  --transition:all .28s ease;
}

*,*::before,*::after{box-sizing:border-box}
html{
  font-family:'Source Sans 3','Segoe UI',Tahoma,sans-serif;
  scroll-behavior:smooth;
  font-size:17px;
}
body{
  margin:0;
  min-height:100vh;
  background:var(--bg);
  color:var(--ink);
  line-height:1.7;
  display:flex;
  flex-direction:column;
}
body::before,
body::after{
  content:'';
  position:fixed;
  width:420px;
  height:420px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(215,123,98,.18),transparent 70%);
  z-index:-1;
  filter:blur(2px);
  pointer-events:none;
}
body::before{top:-120px;left:-120px}
body::after{
  bottom:-140px;
  right:-140px;
  background:radial-gradient(circle,rgba(47,111,105,.2),transparent 70%);
}
a{color:inherit;text-decoration:none}
a:hover{color:var(--teal-deep)}
img{max-width:100%;display:block}

.wrap{width:min(1200px,100%);margin:0 auto;padding:0 28px}

header.site-header{
  position:sticky;
  top:0;
  z-index:90;
  background:rgba(255,251,245,.92);
  backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(31,45,42,.08);
  box-shadow:0 12px 30px rgba(24,35,33,.08);
}

.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  height:84px;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  font-family:'Fraunces',serif;
  font-weight:700;
  letter-spacing:.02em;
}
.logo-dot{
  width:12px;
  height:12px;
  border-radius:999px;
  background:linear-gradient(135deg,var(--accent),var(--gold));
  box-shadow:0 0 0 8px rgba(215,123,98,.18);
}

.scroll-progress{
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:4px;
  background:rgba(31,45,42,.06);
  overflow:hidden;
}
.scroll-progress span{
  display:block;
  height:100%;
  width:0;
  background:linear-gradient(90deg,var(--accent),var(--gold));
  border-radius:999px;
  transition:width .2s ease;
}

.navlinks{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:.95rem;
  color:var(--muted);
}
.navlinks a{
  position:relative;
  padding:8px 14px;
  border-radius:999px;
  transition:var(--transition);
}
.navlinks a:focus-visible{outline:2px solid rgba(215,123,98,.5);outline-offset:3px}
.navlinks a:hover{
  background:rgba(215,123,98,.14);
  color:var(--ink-strong);
}

.nav-toggle{
  display:none;
  align-items:center;
  justify-content:center;
  width:46px;
  height:46px;
  border-radius:16px;
  border:1px solid rgba(47,111,105,.24);
  background:#fff;
  color:var(--teal-deep);
  box-shadow:0 10px 22px rgba(24,35,33,.1);
  transition:transform .16s ease,box-shadow .26s ease,border-color .22s ease;
}
.nav-toggle:hover{
  transform:translateY(-1px);
  box-shadow:0 16px 30px rgba(24,35,33,.14);
  border-color:rgba(47,111,105,.5);
}
.nav-toggle:focus-visible{outline:2px solid rgba(47,111,105,.4);outline-offset:4px}
.nav-toggle-bar{
  position:relative;
  width:20px;
  height:2px;
  border-radius:999px;
  background:currentColor;
  transition:transform .2s ease,background .2s ease;
}
.nav-toggle-bar::before,
.nav-toggle-bar::after{
  content:'';
  position:absolute;
  left:0;
  width:20px;
  height:2px;
  border-radius:999px;
  background:currentColor;
  transition:transform .2s ease,top .2s ease,opacity .2s ease;
}
.nav-toggle-bar::before{top:-6px}
.nav-toggle-bar::after{top:6px}
.site-header.nav-open .nav-toggle-bar{background:transparent}
.site-header.nav-open .nav-toggle-bar::before{top:0;transform:rotate(45deg)}
.site-header.nav-open .nav-toggle-bar::after{top:0;transform:rotate(-45deg)}

.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:14px 24px;
  border-radius:999px;
  font-weight:700;
  letter-spacing:.02em;
  border:0;
  background:linear-gradient(135deg,var(--accent),#e4a07e);
  color:#fff;
  box-shadow:0 16px 34px rgba(215,123,98,.3);
  transition:transform .18s ease,box-shadow .28s ease;
}
.cta:hover{
  transform:translateY(-2px);
  box-shadow:0 22px 46px rgba(215,123,98,.36);
}
.cta.secondary{
  background:var(--bg-2);
  color:var(--teal-deep);
  border:1px solid rgba(47,111,105,.24);
  box-shadow:none;
}
.cta.secondary:hover{border-color:rgba(47,111,105,.5)}

.legal-note{
  margin:16px 0;
  padding:12px 16px;
  border:1px solid rgba(199,160,93,.4);
  border-radius:18px 26px 18px 28px;
  background:rgba(255,244,219,.9);
  color:#6a4c1f;
  font-size:.74rem;
  position:relative;
}

main{flex:1;padding:70px 0 120px}

.hero{
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);
  gap:48px;
  padding:56px;
  border-radius:56px 78px 50px 86px;
  background:linear-gradient(135deg,rgba(255,252,246,.96),rgba(255,255,255,.92));
  border:1px solid rgba(31,45,42,.08);
  box-shadow:var(--shadow-strong);
  position:relative;
  overflow:hidden;
}
.hero::before{
  content:'';
  position:absolute;
  inset:-20%;
  background:
    radial-gradient(60% 60% at 18% 16%,rgba(215,123,98,.18),transparent 70%),
    radial-gradient(50% 50% at 90% 80%,rgba(47,111,105,.16),transparent 70%);
  pointer-events:none;
}
.hero::after{
  content:'';
  position:absolute;
  width:360px;
  height:360px;
  border-radius:40% 60% 55% 45%;
  background:radial-gradient(circle,rgba(199,160,93,.2),transparent 70%);
  top:-120px;
  right:-140px;
  pointer-events:none;
}
.hero-content{position:relative;z-index:1;display:flex;flex-direction:column;gap:18px}
.badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 16px;
  border-radius:999px;
  background:rgba(47,111,105,.12);
  color:var(--teal-deep);
  font-size:.78rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
}

h1{
  margin:0;
  font-family:'Fraunces',serif;
  font-size:2.7rem;
  line-height:1.15;
  color:var(--ink-strong);
}
p.lead{margin:0;font-size:1.08rem;color:var(--muted)}

.price{display:flex;align-items:baseline;gap:16px;margin:4px 0 0}
.old{text-decoration:line-through;color:#7b8c88;font-weight:500;font-size:1.05rem}
.new{font-size:2.2rem;font-weight:800;color:var(--teal-deep)}

.chip{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 12px;
  border-radius:999px;
  background:rgba(215,123,98,.16);
  color:#7a3f31;
  font-weight:600;
  font-size:.85rem;
}

.cta-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:12px}
.subtrust{display:flex;flex-wrap:wrap;gap:10px;font-size:.92rem;color:var(--muted)}
.subtrust .chip{
  background:rgba(47,111,105,.12);
  color:var(--teal-deep);
  font-weight:600;
}

.plan-chooser{
  margin-top:8px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.pill{
  border:1px solid rgba(47,111,105,.22);
  background:rgba(255,255,255,.7);
  color:var(--teal-deep);
  padding:8px 14px;
  border-radius:999px;
  font-weight:600;
  font-size:.88rem;
  cursor:pointer;
  transition:var(--transition);
}
.pill:hover{
  transform:translateY(-1px);
  box-shadow:0 10px 20px rgba(24,35,33,.12);
}
.pill.is-active{
  background:linear-gradient(135deg,var(--teal),#3d857e);
  color:#fff;
  border-color:transparent;
  box-shadow:0 14px 26px rgba(47,111,105,.28);
}

.hero-media{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  justify-content:center;
}
.hero-media .frame{
  border-radius:58% 42% 50% 50% / 48% 60% 40% 52%;
  background:linear-gradient(145deg,#fff,rgba(47,111,105,.12));
  border:1px solid rgba(47,111,105,.18);
  padding:42px 30px;
  box-shadow:0 28px 60px rgba(47,111,105,.22);
  max-width:420px;
  width:100%;
  position:relative;
  overflow:hidden;
}
.hero-media .frame::before{
  content:'';
  position:absolute;
  inset:10px;
  border-radius:inherit;
  background:radial-gradient(circle at 30% 30%,rgba(215,123,98,.18),transparent 60%);
  z-index:0;
}
.hero-media img{width:100%;height:auto;position:relative;z-index:1}

.section{margin:90px 0;position:relative}

.grid{display:grid;gap:24px}
.cols-3{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.cols-2{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}

.section-title{
  margin:0 0 32px;
  font-family:'Fraunces',serif;
  font-size:2.1rem;
  font-weight:700;
  color:var(--ink-strong);
  text-align:center;
  line-height:1.3;
}

.tile{
  background:rgba(255,255,255,.9);
  border:1px solid rgba(31,45,42,.1);
  border-radius:26px 40px 28px 46px;
  padding:28px;
  box-shadow:var(--shadow);
  display:flex;
  flex-direction:column;
  gap:12px;
  position:relative;
  overflow:hidden;
}
.tile::before{
  content:'';
  position:absolute;
  top:-40px;
  right:-30px;
  width:140px;
  height:140px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(215,123,98,.2),transparent 70%);
  pointer-events:none;
}
.tile h2,.tile h3{margin:0;font-size:1.12rem;color:var(--ink-strong)}

.ingredients{
  position:relative;
  padding:12px 0;
  isolation:isolate;
  overflow:hidden;
}
.ingredients::before,
.ingredients::after{
  content:'';
  position:absolute;
  width:320px;
  height:320px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(47,111,105,.16),transparent 70%);
  z-index:-1;
  filter:blur(2px);
}
.ingredients::before{top:-80px;left:-80px}
.ingredients::after{
  bottom:-90px;
  right:-80px;
  background:radial-gradient(circle,rgba(215,123,98,.18),transparent 70%);
}

.ingredients-header{
  text-align:center;
  margin-bottom:36px;
  display:flex;
  flex-direction:column;
  gap:10px;
  align-items:center;
}
.ingredients-header h2{
  margin:0;
  font-family:'Fraunces',serif;
  font-size:2.1rem;
  color:var(--ink-strong);
}
.ingredients-kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 16px;
  border-radius:999px;
  background:rgba(199,160,93,.16);
  color:#7a5730;
  font-weight:700;
  letter-spacing:.04em;
  font-size:.8rem;
  text-transform:uppercase;
}

.ingredients-grid{
  display:grid;
  gap:22px;
  grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
}
.ingredient-card{
  position:relative;
  overflow:hidden;
  background:rgba(255,255,255,.95);
  border-radius:30px 44px 28px 54px;
  padding:26px;
  border:1px solid rgba(47,111,105,.16);
  box-shadow:0 20px 48px rgba(24,35,33,.12);
  transition:transform .25s ease,box-shadow .25s ease,opacity .6s ease;
}
.ingredient-card::before{
  content:'';
  position:absolute;
  top:-40px;
  right:-40px;
  width:130px;
  height:130px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(215,123,98,.18),transparent 65%);
}
.ingredient-card:hover{
  transform:translateY(-4px);
  box-shadow:0 26px 58px rgba(24,35,33,.16);
}
.ingredient-card.wide{
  grid-column:auto;
  background:linear-gradient(160deg,#fff,rgba(47,111,105,.08));
}
@media (min-width:1050px){
  .ingredient-card.wide{grid-column:span 3}
}
.ingredient-title{
  display:flex;
  gap:14px;
  align-items:center;
}
.ingredient-title h3{margin:0;font-size:1.12rem;color:var(--ink-strong)}
.ingredient-sub{
  margin:2px 0 0;
  font-size:.82rem;
  color:var(--muted);
}
.ingredient-index{
  width:46px;
  height:46px;
  border-radius:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,var(--teal),#3d857e);
  color:#fff;
  font-weight:800;
  box-shadow:0 10px 22px rgba(47,111,105,.24);
}
.ingredient-card p{
  margin:12px 0 0;
  color:var(--muted);
  font-size:.98rem;
}
.ingredient-tags{
  margin-top:14px;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.ingredient-tag{
  padding:4px 10px;
  border-radius:999px;
  background:rgba(47,111,105,.12);
  color:var(--teal-deep);
  font-weight:600;
  font-size:.78rem;
}
.ingredient-points{
  list-style:none;
  margin:12px 0 0;
  padding:0;
  display:grid;
  gap:10px;
  color:var(--muted);
  font-size:.96rem;
}
.ingredient-points li{
  display:flex;
  gap:10px;
  align-items:flex-start;
}
.ingredient-points li strong{
  color:var(--ink-strong);
  min-width:40px;
}
.ingredient-footnote{
  margin-top:12px;
  font-size:.92rem;
  color:var(--muted);
}

.ingredients-band{
  margin-top:26px;
  display:grid;
  gap:16px;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
}
.band-card{
  border-radius:22px 30px 24px 32px;
  padding:16px 18px;
  background:linear-gradient(135deg,rgba(47,111,105,.12),rgba(215,123,98,.12));
  border:1px solid rgba(47,111,105,.18);
  text-align:center;
  display:flex;
  flex-direction:column;
  gap:6px;
  transition:transform .25s ease,opacity .6s ease;
}
.band-title{
  font-weight:700;
  color:var(--ink-strong);
}
.band-sub{
  color:var(--muted);
  font-size:.88rem;
}

.ingredients.is-ready .ingredient-card,
.ingredients.is-ready .band-card{
  opacity:0;
  transform:translateY(16px);
}
.ingredients.is-ready .ingredient-card.is-visible,
.ingredients.is-ready .band-card.is-visible{
  opacity:1;
  transform:translateY(0);
}

.kpi{
  display:flex;
  flex-direction:column;
  gap:6px;
  align-items:center;
  text-align:center;
  font-size:1.08rem;
  font-weight:600;
  color:var(--ink-strong);
}
.kpi h2{
  margin:0;
  font-family:'Fraunces',serif;
  font-size:1.35rem;
  font-weight:700;
  color:var(--ink-strong);
}
.kpi .sm{font-weight:500}

.sm{margin:0;color:var(--muted);font-size:.98rem}

.list{margin:0;padding:0;list-style:none;display:grid;gap:11px}
.list li{
  position:relative;
  padding-left:34px;
  color:var(--ink);
}
.list li::before{
  content:'+';
  position:absolute;
  left:0;
  top:.2em;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:20px;
  height:20px;
  border-radius:50%;
  background:rgba(47,111,105,.16);
  color:var(--teal-deep);
  font-weight:700;
}

.plans{
  margin-top:32px;
  display:grid;
  gap:22px;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
}

.plan{
  position:relative;
  background:#fff;
  border-radius:32px 50px 30px 54px;
  border:1px solid rgba(31,45,42,.08);
  padding:30px;
  box-shadow:0 20px 50px rgba(24,35,33,.12);
  display:flex;
  flex-direction:column;
  gap:18px;
  transition:var(--transition);
}
.plan.has-tag{
  padding-top:62px;
  border:2px solid rgba(47,111,105,.4);
  box-shadow:0 36px 80px rgba(47,111,105,.2);
  transform:translateY(-6px);
  background:linear-gradient(185deg,#fff,rgba(255,249,242,.9));
}
.plan:hover{
  transform:translateY(-4px);
  box-shadow:0 26px 60px rgba(24,35,33,.18);
}
.plan.is-selected{
  transform:translateY(-8px) scale(1.01);
  border-color:rgba(215,123,98,.6);
  box-shadow:0 34px 70px rgba(215,123,98,.22);
}

.plan .tag{
  position:absolute;
  top:18px;
  left:50%;
  transform:translateX(-50%);
  padding:6px 16px;
  border-radius:999px;
  background:linear-gradient(135deg,var(--teal),#3d857e);
  color:#fff;
  font-size:.78rem;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
  white-space:nowrap;
  box-shadow:0 10px 20px rgba(47,111,105,.24);
}
.plan img{
  width:220px;
  height:180px;
  max-width:100%;
  margin:12px auto 4px;
  object-fit:contain;
}
.plan h3{
  margin:0;
  font-family:'Fraunces',serif;
  font-size:1.28rem;
  text-align:center;
  color:var(--ink-strong);
}
.plan .sup{margin:0;text-align:center;color:var(--muted);font-size:.95rem}

.plan .money{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
}
.plan .money .old{text-decoration:line-through;color:#909f9c;font-size:1rem}
.plan .money .new{font-size:1.9rem;color:var(--accent-deep);font-weight:800}

.plan .detail{margin:0;text-align:center;color:var(--muted);font-size:.95rem}

.plan .cta{
  width:100%;
  justify-content:center;
  margin-top:8px;
  padding:15px 20px;
  background:linear-gradient(135deg,var(--accent),#e4a07e);
}
.plan .cta:hover{box-shadow:0 24px 48px rgba(215,123,98,.32)}

.plan .extra{
  margin:0;
  text-align:center;
  font-size:.88rem;
  color:var(--teal-deep);
  font-weight:600;
}
.plan .extra.upsell{color:#8b4d3d}

.rich-content{
  background:rgba(255,255,255,.96);
  border:1px solid rgba(31,45,42,.1);
  border-radius:44px 60px 40px 66px;
  padding:48px;
  box-shadow:0 30px 64px rgba(24,35,33,.14);
  display:flex;
  flex-direction:column;
  gap:18px;
}
.rich-content p{margin:0;color:var(--muted);font-size:1.02rem}
.rich-content h3{
  margin:28px 0 12px;
  font-family:'Fraunces',serif;
  font-size:1.45rem;
  font-weight:700;
  color:var(--ink-strong);
}
.rich-content ul{margin:0 0 18px 20px;color:var(--muted);font-size:1rem;line-height:1.7}
.rich-content ul li{margin-bottom:8px}

.rich-content table{
  display:block;
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  background:linear-gradient(140deg,#fff,rgba(47,111,105,.06));
  border:1px solid rgba(31,45,42,.12);
  border-radius:28px;
  overflow:auto;
  box-shadow:0 22px 54px rgba(24,35,33,.14);
  mask-image:linear-gradient(90deg,transparent 0,#000 18px,#000 calc(100% - 18px),transparent 100%);
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 18px,#000 calc(100% - 18px),transparent 100%);
}
.rich-content table::-webkit-scrollbar{height:10px}
.rich-content table::-webkit-scrollbar-track{background:rgba(24,35,33,.08);border-radius:999px}
.rich-content table::-webkit-scrollbar-thumb{
  background:linear-gradient(135deg,var(--teal),var(--accent));
  border-radius:999px;
}
.rich-content thead,
.rich-content tbody{display:table;width:100%;table-layout:fixed}
.rich-content thead{
  position:sticky;
  top:0;
  z-index:2;
  background:linear-gradient(135deg,rgba(47,111,105,.12),rgba(215,123,98,.1));
  backdrop-filter:blur(6px);
}
.rich-content th,
.rich-content td{
  padding:16px 18px;
  text-align:left;
  color:var(--ink);
  border-bottom:1px solid rgba(31,45,42,.12);
}
.rich-content th{
  font-size:.95rem;
  letter-spacing:.01em;
  color:var(--ink-strong);
  font-weight:700;
}
.rich-content tbody tr:nth-child(odd){background:rgba(47,111,105,.03)}
.rich-content tbody tr:hover{background:rgba(215,123,98,.08)}

.note{margin-top:18px;font-size:.86rem;color:#4f615e}

body.legal-page{display:block}
body.legal-page a{color:inherit}
body.legal-page a:hover{color:var(--teal-deep)}
body.legal-page main{padding:0}

body.legal-page.legal-simple{
  line-height:1.7;
  margin:0;
  padding:0;
  background:#fff;
}
body.legal-page.legal-simple main{
  font-family:'Source Sans 3','Segoe UI',Tahoma,sans-serif;
  max-width:900px;
  margin:40px auto;
  padding:0 20px;
}
body.legal-page.legal-simple main h1{font-size:1.8rem;margin:0 0 12px}
body.legal-page.legal-simple main h2{font-size:1.2rem;margin-top:22px}
body.legal-page.legal-simple main p{margin:10px 0}
body.legal-page.legal-simple main ul{margin:10px 0 0 18px}
body.legal-page.legal-simple main li{margin:6px 0}
body.legal-page.legal-simple main code{background:#f4f6f8;padding:2px 6px;border-radius:6px}
body.legal-page.legal-impressum p{margin:1em 0}
body.legal-page.legal-impressum ul{margin:1em 0 1em 18px}

body.legal-page.legal-about{
  min-height:100vh;
  background:var(--bg);
  line-height:1.7;
}
body.legal-page.legal-about .wrap{width:min(960px,100%);margin:0 auto;padding:38px 26px}
body.legal-page.legal-about .hero{
  background:linear-gradient(135deg,rgba(255,252,246,.96),rgba(255,255,255,.92));
  border:1px solid rgba(31,45,42,.08);
  box-shadow:var(--shadow-strong);
  border-radius:var(--radius-xl);
  padding:42px;
}
body.legal-page.legal-about h1{
  margin:0 0 10px;
  font-family:'Fraunces',serif;
  font-size:2.1rem;
  color:var(--ink-strong);
}
body.legal-page.legal-about p.lead{margin:0;color:var(--muted);font-size:1.05rem}
body.legal-page.legal-about .note{
  margin:20px 0;
  padding:14px 16px;
  border:1px solid rgba(47,111,105,.16);
  border-radius:18px;
  background:rgba(255,249,242,.7);
}
body.legal-page.legal-about .card{
  background:var(--card);
  border:1px solid rgba(31,45,42,.12);
  border-radius:var(--radius-md);
  padding:26px;
  margin-top:22px;
  box-shadow:0 16px 36px rgba(24,35,33,.08);
}
body.legal-page.legal-about h2{
  margin:0 0 12px;
  font-family:'Fraunces',serif;
  font-size:1.38rem;
  color:var(--ink-strong);
}
body.legal-page.legal-about .card h3{margin:14px 0 8px;color:var(--ink-strong);font-size:1.08rem}
body.legal-page.legal-about .footer{margin-top:28px;color:#5a6b69;font-size:.92rem;text-align:center}
body.legal-page.legal-about .cta-row{margin-top:18px;display:flex;gap:12px;flex-wrap:wrap}
body.legal-page.legal-about .cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 18px;
  border-radius:999px;
  font-weight:700;
  background:linear-gradient(135deg,var(--accent),#e4a07e);
  color:#fff;
  box-shadow:0 16px 32px rgba(215,123,98,.24);
}
body.legal-page.legal-about .cta.secondary{
  background:#fff;
  color:var(--teal-deep);
  border:1px solid rgba(47,111,105,.24);
  box-shadow:none;
}
body.legal-page.legal-about ul{margin:10px 0 0 18px}
body.legal-page.legal-about li{margin:6px 0}

#faq{
  background:rgba(255,255,255,.96);
  border-radius:46px 60px 44px 68px;
  padding:40px;
  box-shadow:0 26px 58px rgba(24,35,33,.14);
  border:1px solid rgba(31,45,42,.08);
}
#faq details{
  border:1px solid rgba(47,111,105,.18);
  border-radius:22px 30px 24px 32px;
  padding:18px 22px;
  background:rgba(255,249,242,.8);
  transition:var(--transition);
}
#faq details+details{margin-top:16px}
#faq summary{
  cursor:pointer;
  font-weight:600;
  color:var(--ink-strong);
  list-style:none;
}
#faq summary::-webkit-details-marker{display:none}
#faq details[open]{background:#fff;box-shadow:0 18px 36px rgba(24,35,33,.12)}
#faq details[open] summary{color:var(--teal-deep)}

.stick{
  position:fixed;
  left:0;
  right:0;
  bottom:20px;
  display:flex;
  justify-content:center;
  padding:0 18px;
  z-index:90;
  pointer-events:none;
}
.stick .bar{
  pointer-events:auto;
  width:min(460px,100%);
  border-radius:999px 999px 999px 48px;
  background:rgba(25,35,33,.92);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 16px;
  gap:14px;
  box-shadow:0 18px 44px rgba(18,24,23,.32);
  backdrop-filter:blur(10px);
  position:relative;
}
.stick .bar .kpi{
  display:flex;
  flex-direction:column;
  font-size:.92rem;
  font-weight:600;
  text-align:left;
}
.stick .bar .kpi span{font-weight:500;color:rgba(255,255,255,.78)}
.stick .bar .kpi strong{color:#fff}
.stick .bar .cta{
  padding:12px 20px;
  border-radius:999px;
  background:linear-gradient(135deg,var(--accent),#e4a07e);
  box-shadow:0 18px 38px rgba(215,123,98,.32);
}

footer{
  margin-top:96px;
  font-size:.8rem;
  color:#5a6b69;
  text-align:center;
  padding-bottom:26px;
}
footer p{margin:0}
.footer-legal{margin-top:10px}

@media (max-width:980px){
  .hero{grid-template-columns:1fr;padding:44px}
  .hero-media{order:-1}
  .header-inner{
    flex-wrap:wrap;
    height:auto;
    padding:12px 0;
    gap:16px;
    position:relative;
  }
  .nav-toggle{display:inline-flex}
  .navlinks{
    position:absolute;
    left:0;
    right:0;
    top:100%;
    margin-top:12px;
    padding:16px 18px;
    background:rgba(255,251,245,.98);
    border:1px solid rgba(47,111,105,.2);
    border-radius:22px;
    box-shadow:0 18px 36px rgba(24,35,33,.12);
    flex-direction:column;
    align-items:flex-start;
    gap:12px;
    display:none;
  }
  .site-header.nav-open .navlinks{display:flex}
  .navlinks a{width:100%}
}

@media (max-width:720px){
  .wrap{padding:0 20px}
  .hero{padding:34px}
  h1{font-size:2.2rem}
  .cta-row{width:100%}
  .cta-row .cta{flex:1 1 100%}
  .cta-row .cta.secondary{order:2}
  .section-title{font-size:1.8rem}
  .ingredients-header h2{font-size:1.8rem}
  .ingredients-kicker{font-size:.74rem}
  .ingredient-card{padding:22px}
  .ingredient-card.wide{grid-column:auto}
  .rich-content{padding:36px}
  .plans{grid-template-columns:1fr}
  .stick .bar{
    flex-direction:column;
    align-items:stretch;
    text-align:center;
    gap:10px;
    padding:14px 16px;
  }
  .stick .bar .cta{width:100%}
}

@media (max-width:520px){
  html{font-size:16px}
  .hero{padding:28px}
  .tile{padding:22px}
  #faq{padding:28px}
  .rich-content table{
    font-size:.95rem;
    mask-image:none;
    -webkit-mask-image:none;
  }
  .rich-content th,
  .rich-content td{padding:14px 14px}
  .rich-content td:last-child{white-space:normal}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
    scroll-behavior:auto!important;
  }
}
