:root {
  --cream: #f7f2e8;
  --paper: #fffdf8;
  --ink: #17231d;
  --muted: #657168;
  --green: #246b4f;
  --green-deep: #123d2c;
  --green-soft: #dfece1;
  --orange: #f3a324;
  --red: #d3212d;
  --lime: #84c743;
  --line: rgba(23, 35, 29, .14);
  --shadow: 0 25px 70px rgba(24, 49, 35, .13);
  --radius: 28px;
}

* { box-sizing: border-box; }
[hidden] { display: none !important; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: "DM Sans", sans-serif; font-size: 16px; line-height: 1.55; overflow-x: hidden; }
body.no-scroll { overflow: hidden; }
button, input, select, textarea { font: inherit; }
button, a { -webkit-tap-highlight-color: transparent; }
button { color: inherit; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
.section-shell { width: min(1180px, calc(100% - 48px)); margin-inline: auto; }
.section-pad { padding-block: 120px; }
.skip-link { position: fixed; z-index: 1000; left: 16px; top: -60px; padding: 10px 16px; background: var(--ink); color: white; border-radius: 8px; transition: top .2s; }
.skip-link:focus { top: 16px; }

.announcement { min-height: 36px; display: flex; justify-content: center; align-items: center; gap: 28px; padding: 7px 24px; color: #fff; background: var(--green-deep); font-size: 12px; letter-spacing: .03em; }
.announcement p { margin: 0; }
.announcement p span { display: inline-block; margin-right: 8px; padding: 2px 7px; color: var(--green-deep); background: var(--orange); border-radius: 99px; font-size: 9px; font-weight: 800; text-transform: uppercase; }
.announcement a { color: #f7cc75; font-weight: 700; }

.site-header { position: sticky; z-index: 100; top: 0; display: flex; align-items: center; justify-content: space-between; height: 92px; padding: 0 max(32px, calc((100vw - 1180px) / 2)); background: rgba(255, 253, 248, .9); border-bottom: 1px solid transparent; backdrop-filter: blur(18px); transition: height .25s, box-shadow .25s, border .25s; }
.site-header.scrolled { height: 80px; border-color: var(--line); box-shadow: 0 8px 30px rgba(32, 48, 39, .05); }
.brand { display: flex; width: 205px; height: 100%; padding-block: 8px; align-items: center; overflow: hidden; }
.brand img { width: auto; height: 100%; max-width: 100%; object-fit: contain; }
.site-nav { display: flex; margin-left: auto; align-items: center; gap: 30px; font-family: "Manrope", sans-serif; font-size: 13px; font-weight: 700; }
.site-nav > a { position: relative; }
.site-nav > a::after { content: ""; position: absolute; left: 0; right: 100%; bottom: -7px; height: 2px; background: var(--green); transition: right .25s; }
.site-nav > a:hover::after { right: 0; }
.cart-button { display: none; border: 0; background: transparent; font-weight: 700; cursor: pointer; }
.cart-count { display: inline-grid; min-width: 23px; height: 23px; margin-left: 5px; place-items: center; color: white; background: var(--red); border-radius: 99px; font-size: 10px; }
.header-tools { order: 3; display: flex; margin-left: 18px; align-items: center; gap: 10px; flex-shrink: 0; }
.header-cart-button, .header-whatsapp-button { position: relative; width: 44px; height: 44px; padding: 0; place-items: center; border-radius: 50%; cursor: pointer; }
.header-cart-button { display: grid; color: var(--ink); background: transparent; border: 1px solid var(--line); }
.header-whatsapp-button { display: none; color: var(--ink); background: transparent; border: 1px solid var(--line); }
.header-cart-button svg, .header-whatsapp-button svg { width: 20px; height: 20px; fill: none; stroke: currentColor; stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; }
.header-whatsapp-button svg { fill: currentColor; stroke: none; }
.header-cart-button .cart-count { position: absolute; top: -4px; right: -4px; min-width: 18px; height: 18px; margin: 0; padding-inline: 4px; font-size: 9px; }
.menu-toggle { display: none; }

.button { display: inline-flex; min-height: 54px; padding: 0 24px; align-items: center; justify-content: center; gap: 26px; color: white; background: var(--green); border: 1px solid var(--green); border-radius: 99px; font-family: "Manrope", sans-serif; font-weight: 700; cursor: pointer; transition: transform .2s, background .2s, box-shadow .2s; }
.button:hover { transform: translateY(-2px); background: #185a41; box-shadow: 0 12px 25px rgba(36, 107, 79, .2); }
.button-small { min-height: 43px; padding-inline: 19px; font-size: 12px; }
.button-dark { background: var(--ink); border-color: var(--ink); }
.button-light { color: var(--green-deep); background: #fff; border-color: #fff; }
.button-light:hover { color: var(--green-deep); background: var(--cream); }
.text-link { display: inline-flex; align-items: center; gap: 18px; padding: 8px 0; border: 0; border-bottom: 1px solid var(--ink); background: transparent; font-weight: 700; cursor: pointer; }
.eyebrow, .kicker { display: inline-flex; align-items: center; gap: 10px; color: var(--green); font-family: "Manrope", sans-serif; font-size: 11px; font-weight: 800; letter-spacing: .16em; text-transform: uppercase; }
.eyebrow span { width: 18px; height: 2px; background: var(--orange); }

.hero { display: grid; min-height: 700px; padding-block: 86px 110px; grid-template-columns: 1.02fr .98fr; align-items: center; gap: 75px; }
.hero h1 { max-width: 650px; margin: 24px 0; font-family: "Manrope", sans-serif; font-size: clamp(58px, 6.2vw, 91px); font-weight: 700; letter-spacing: -.065em; line-height: .97; }
.hero h1 em, .section-heading h2 em, .shop-heading h2 em, .faq h2 em, .final-cta h2 em { color: var(--green); font-family: Georgia, serif; font-weight: 400; }
.hero-lead { max-width: 590px; margin: 0 0 34px; color: var(--muted); font-size: 18px; line-height: 1.7; }
.hero-actions { display: flex; align-items: center; gap: 30px; }
.hero-proof { display: flex; margin-top: 48px; align-items: center; gap: 14px; }
.hero-proof p { margin: 0; color: var(--muted); font-size: 12px; line-height: 1.55; }
.hero-proof strong { color: var(--ink); font-size: 13px; }
.avatar-stack { display: flex; padding-left: 14px; }
.avatar { width: 38px; height: 38px; margin-left: -14px; background-size: cover; border: 3px solid var(--paper); border-radius: 50%; }
.avatar-one { background: #d7ac8f url("https://images.unsplash.com/photo-1494790108377-be9c29b29330?auto=format&fit=crop&w=100&q=80") center/cover; }
.avatar-two { background: #c9aa9b url("https://images.unsplash.com/photo-1531123897727-8f129e1688ce?auto=format&fit=crop&w=100&q=80") center/cover; }
.avatar-three { background: #9a6d52 url("https://images.unsplash.com/photo-1534528741775-53994a69daeb?auto=format&fit=crop&w=100&q=80") center/cover; }

.hero-visual { position: relative; min-height: 520px; }
.hero-image-wrap { position: absolute; inset: 5px 5px 5px 30px; overflow: hidden; background: #c7d6c5; border-radius: 46% 46% 22px 22px; }
.hero-image-wrap::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 55%, rgba(13, 47, 32, .2)); }
.hero-image-wrap img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 45%; }
.hero-shape { position: absolute; border-radius: 50%; mix-blend-mode: screen; opacity: .75; }
.hero-shape-one { width: 210px; height: 210px; top: -45px; right: -60px; background: var(--orange); }
.hero-shape-two { width: 140px; height: 140px; left: -35px; bottom: -45px; background: var(--lime); }
.floating-card { position: absolute; z-index: 2; display: flex; padding: 15px 18px; align-items: center; gap: 12px; background: rgba(255, 253, 248, .92); border: 1px solid rgba(255,255,255,.7); border-radius: 16px; box-shadow: var(--shadow); backdrop-filter: blur(14px); }
.floating-card strong, .floating-card small { display: block; }
.floating-card strong { font-family: "Manrope", sans-serif; font-size: 12px; }
.floating-card small { margin-top: 2px; color: var(--muted); font-size: 10px; }
.floating-card-top { top: 56px; right: -28px; }
.floating-card-bottom { bottom: 48px; left: -24px; }
.floating-icon { display: grid; width: 36px; height: 36px; place-items: center; color: white; background: var(--red); border-radius: 50%; }
.mini-mark { width: 11px; height: 36px; background: var(--orange); border-radius: 70% 30% 60% 40%; transform: rotate(22deg); }

.trust-strip { display: grid; padding: 25px max(32px, calc((100vw - 1180px) / 2)); grid-template-columns: repeat(4, 1fr); color: #fff; background: var(--green-deep); }
.trust-strip > div { display: flex; min-height: 42px; align-items: center; justify-content: center; gap: 12px; border-right: 1px solid rgba(255,255,255,.16); font-size: 12px; font-weight: 600; }
.trust-strip > div:last-child { border-right: 0; }
.trust-strip svg { width: 22px; fill: none; stroke: var(--orange); stroke-width: 1.6; }

.section-heading { display: grid; margin-bottom: 55px; grid-template-columns: 1.2fr .7fr; align-items: end; gap: 80px; }
.section-heading h2, .shop-heading h2, .faq h2 { max-width: 690px; margin: 16px 0 0; font-family: "Manrope", sans-serif; font-size: clamp(38px, 4vw, 58px); letter-spacing: -.055em; line-height: 1.08; }
.section-heading > p, .shop-heading > p { max-width: 430px; margin: 0; color: var(--muted); line-height: 1.75; }
.service-grid { display: grid; grid-template-columns: 1.2fr repeat(2, .9fr); gap: 18px; }
.service-card { position: relative; display: flex; min-height: 425px; padding: 32px; flex-direction: column; justify-content: space-between; overflow: hidden; background: var(--cream); border: 1px solid transparent; border-radius: var(--radius); transition: transform .3s, box-shadow .3s, border .3s; }
.service-card:hover { transform: translateY(-6px); border-color: rgba(36, 107, 79, .15); box-shadow: 0 24px 50px rgba(26, 61, 42, .1); }
.service-featured { grid-row: span 2; min-height: 868px; color: #fff; background: var(--green); }
.service-card:nth-child(4) { grid-column: 2 / 4; min-height: 425px; }
.service-number { position: absolute; top: 29px; right: 32px; color: rgba(23,35,29,.45); font-family: "Manrope", sans-serif; font-size: 11px; font-weight: 800; }
.service-featured .service-number { color: rgba(255,255,255,.55); }
.service-icon { display: grid; width: 95px; height: 95px; margin: 20px 0 55px; place-items: center; border-radius: 48% 52% 45% 55%; }
.service-icon svg { width: 58px; fill: none; stroke: currentColor; stroke-linecap: round; stroke-linejoin: round; stroke-width: 2; }
.icon-water { width: 180px; height: 180px; color: var(--green-deep); background: #b8d9c4; }
.icon-water svg { width: 100px; }
.icon-leaf { color: #205b42; background: #c7e5cf; }
.icon-drip { color: #9c5a00; background: #f5dfad; }
.icon-sparkle { margin-bottom: 25px; color: #9e1e28; background: #f0c5c7; }
.service-tag { display: inline-block; margin-bottom: 16px; padding: 5px 9px; color: var(--green-deep); background: #d9e9dd; border-radius: 99px; font-size: 9px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.service-content h3 { margin: 0 0 12px; font-family: "Manrope", sans-serif; font-size: 28px; letter-spacing: -.03em; }
.service-content p { margin: 0 0 20px; color: var(--muted); font-size: 14px; line-height: 1.7; }
.service-featured .service-content p { max-width: 420px; color: rgba(255,255,255,.75); font-size: 15px; }
.service-content ul { display: grid; margin: 24px 0 36px; padding: 0; gap: 10px; list-style: none; color: rgba(255,255,255,.82); font-size: 12px; }
.service-content li::before { content: "✓"; margin-right: 9px; color: #a8dcaf; }
.card-link { display: flex; width: 100%; padding: 13px 0 2px; align-items: center; justify-content: space-between; border: 0; border-top: 1px solid rgba(23,35,29,.16); background: none; font-size: 12px; font-weight: 800; cursor: pointer; }
.service-featured .card-link { color: white; border-color: rgba(255,255,255,.25); }
.card-link span { font-size: 18px; transition: transform .2s; }
.card-link:hover span { transform: translate(3px, -3px); }

.packages { color: white; background: var(--green-deep); }
.section-heading.light .kicker { color: #f3be58; }
.section-heading.light h2 em { color: #a5cfac; }
.section-heading.light > p { color: rgba(255,255,255,.65); }
.package-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.package-card { position: relative; display: flex; min-height: 550px; padding: 34px; flex-direction: column; overflow: hidden; color: var(--ink); background: var(--paper); border-radius: var(--radius); transition: transform .3s; }
.package-card:hover { transform: translateY(-7px); }
.package-card::after { content: ""; position: absolute; z-index: 0; width: 170px; height: 170px; right: -90px; top: 70px; background: rgba(132,199,67,.12); border-radius: 50%; }
.package-popular { background: #f3b536; }
.package-popular::after { background: rgba(255,255,255,.2); }
.popular-ribbon { position: absolute; z-index: 2; top: 24px; right: -38px; width: 150px; padding: 6px; color: white; background: var(--red); text-align: center; font-size: 9px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; transform: rotate(42deg); }
.package-top { position: relative; z-index: 1; display: flex; justify-content: space-between; }
.package-label { font-size: 10px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.package-spot { display: grid; width: 28px; height: 28px; place-items: center; color: white; background: var(--green); border-radius: 50%; font-size: 9px; font-weight: 800; }
.package-card h3 { position: relative; z-index: 1; margin: 44px 0 16px; font-family: "Manrope", sans-serif; font-size: 34px; letter-spacing: -.045em; line-height: 1.05; }
.package-card > p { margin: 0 0 26px; color: var(--muted); font-size: 13px; line-height: 1.65; }
.package-popular > p { color: rgba(23,35,29,.75); }
.package-card ul { display: grid; margin: 0; padding: 0; gap: 11px; list-style: none; font-size: 12px; }
.package-card li::before { content: "✓"; display: inline-grid; width: 20px; height: 20px; margin-right: 8px; place-items: center; color: white; background: var(--green); border-radius: 50%; font-size: 9px; }
.price-row { display: flex; margin-top: auto; padding-top: 28px; align-items: end; justify-content: space-between; border-top: 1px solid var(--line); }
.price-row small, .price-row strong { display: block; }
.price-row small { color: var(--muted); font-size: 9px; font-weight: 800; letter-spacing: .09em; text-transform: uppercase; }
.price-row strong { margin-top: 2px; font-family: "Manrope", sans-serif; font-size: 26px; }
.round-add { width: 48px; height: 48px; color: #fff; background: var(--green); border: 0; border-radius: 50%; font-size: 25px; cursor: pointer; transition: transform .2s, background .2s; }
.round-add:hover { transform: rotate(90deg); background: var(--red); }
.round-book { min-width: 64px; height: 42px; padding: 0 16px; color: #fff; background: var(--green); border: 0; border-radius: 99px; font-size: 10px; font-weight: 800; letter-spacing: .04em; cursor: pointer; transition: transform .2s, background .2s; }
.round-book:hover { transform: translateY(-2px); background: var(--red); }
.package-note { margin: 22px 0 0; color: rgba(255,255,255,.5); font-size: 10px; text-align: center; }
.package-addons { display: grid; margin-top: 18px; padding: 24px 28px; grid-template-columns: 1.1fr 1fr 1fr; align-items: center; gap: 22px; color: var(--ink); background: #dfece1; border-radius: 22px; }
.addon-intro .kicker { color: var(--green); }
.addon-intro h3 { margin: 5px 0 0; font-family: "Manrope", sans-serif; font-size: 18px; letter-spacing: -.03em; }
.addon-item { display: grid; padding-left: 22px; grid-template-columns: 1fr auto 38px; align-items: center; gap: 14px; border-left: 1px solid rgba(23,35,29,.14); }
.addon-item span, .addon-item strong { display: block; }
.addon-item span { color: var(--muted); font-size: 8px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.addon-item strong { margin-top: 3px; font-size: 12px; }
.addon-item b { font-family: "Manrope", sans-serif; font-size: 16px; }
.addon-item button { width: 38px; height: 38px; padding: 0; color: white; background: var(--green); border: 0; border-radius: 50%; font-size: 20px; cursor: pointer; transition: transform .2s, background .2s; }
.addon-item button:hover { transform: rotate(90deg); background: var(--red); }

.online-booking { position: relative; overflow: hidden; background: #edf2eb; scroll-margin-top: 74px; }
.online-booking::before { content: ""; position: absolute; width: 520px; height: 520px; left: -250px; bottom: -280px; border: 1px solid rgba(36,107,79,.12); border-radius: 50%; box-shadow: 0 0 0 70px rgba(36,107,79,.025), 0 0 0 140px rgba(36,107,79,.025); }
.booking-heading { position: relative; display: grid; margin-bottom: 46px; grid-template-columns: 1.2fr .65fr; align-items: end; gap: 70px; }
.booking-heading h2 { margin: 14px 0 0; font-family: "Manrope", sans-serif; font-size: clamp(40px, 4.5vw, 62px); letter-spacing: -.055em; line-height: 1.04; }
.booking-heading h2 em { color: var(--green); font-family: Georgia, serif; font-weight: 400; }
.booking-heading > p { max-width: 420px; margin: 0; color: var(--muted); line-height: 1.75; }
.booking-layout { position: relative; display: grid; grid-template-columns: 300px minmax(0, 1fr); align-items: start; gap: 22px; }
.booking-guide { position: sticky; top: 100px; padding: 30px; color: #fff; background: var(--green-deep); border-radius: 24px; box-shadow: var(--shadow); }
.booking-live { display: inline-flex; padding: 6px 10px; align-items: center; gap: 7px; color: #b8dfc0; background: rgba(255,255,255,.08); border-radius: 99px; font-size: 9px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.booking-live i { width: 7px; height: 7px; background: #7cd58d; border-radius: 50%; box-shadow: 0 0 0 4px rgba(124,213,141,.12); }
.booking-guide h3 { margin: 24px 0 20px; font-family: "Manrope", sans-serif; font-size: 22px; letter-spacing: -.035em; line-height: 1.2; }
.booking-guide ol { display: grid; margin: 0 0 28px; padding: 0; gap: 20px; list-style: none; }
.booking-guide li { display: grid; grid-template-columns: 30px 1fr; gap: 12px; }
.booking-guide li > span { display: grid; width: 28px; height: 28px; place-items: center; color: var(--green-deep); background: var(--orange); border-radius: 50%; font-size: 10px; font-weight: 800; }
.booking-guide li strong { font-size: 12px; }
.booking-guide li p { margin: 3px 0 0; color: rgba(255,255,255,.6); font-size: 10px; line-height: 1.55; }
.booking-guide .text-link { color: white; border-color: rgba(255,255,255,.35); font-size: 10px; }
.booking-guide > small { display: block; margin-top: 18px; color: rgba(255,255,255,.4); font-size: 8px; }
.booking-frame-shell { overflow: hidden; background: white; border: 1px solid rgba(23,35,29,.11); border-radius: 24px; box-shadow: 0 24px 55px rgba(27,57,41,.1); }
.booking-frame-top { display: grid; min-height: 56px; padding: 0 20px; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 20px; background: #fbfaf6; border-bottom: 1px solid var(--line); }
.booking-frame-top > span { display: flex; gap: 5px; }
.booking-frame-top i { width: 8px; height: 8px; background: #df655f; border-radius: 50%; }
.booking-frame-top i:nth-child(2) { background: #e8b84e; }
.booking-frame-top i:nth-child(3) { background: #6db27d; }
.booking-frame-top strong { font-family: "Manrope", sans-serif; font-size: 11px; text-align: center; }
.booking-frame-top b { justify-self: end; color: var(--green); font-size: 8px; letter-spacing: .08em; text-transform: uppercase; }
#salonbridge_iframe { display: block; width: 100%; height: 760px; color-scheme: light; background: #fff; border: 0; }

.approach { display: grid; grid-template-columns: .95fr 1.05fr; align-items: center; gap: 95px; }
.approach-visual { position: relative; min-height: 620px; }
.approach-image { position: absolute; inset: 0 55px 65px 0; overflow: hidden; border-radius: 180px 180px 24px 24px; }
.approach-image img { width: 100%; height: 100%; object-fit: cover; }
.approach-quote { position: absolute; right: 0; bottom: 0; width: 270px; padding: 26px; color: white; background: var(--red); border-radius: 22px; box-shadow: var(--shadow); }
.approach-quote span { position: absolute; color: rgba(255,255,255,.25); font-family: Georgia, serif; font-size: 80px; line-height: 1; }
.approach-quote p { position: relative; margin: 28px 0 0; font-family: "Manrope", sans-serif; font-size: 16px; font-weight: 700; line-height: 1.45; }
.approach-copy h2 { margin: 14px 0 22px; font-family: "Manrope", sans-serif; font-size: clamp(40px, 4vw, 58px); letter-spacing: -.055em; line-height: 1.05; }
.approach-copy > p { max-width: 570px; color: var(--muted); line-height: 1.75; }
.principles { display: grid; margin: 38px 0; gap: 0; }
.principles > div { display: grid; padding: 20px 0; grid-template-columns: 42px 110px 1fr; align-items: center; border-top: 1px solid var(--line); }
.principles > div:last-child { border-bottom: 1px solid var(--line); }
.principles span { color: var(--green); font-family: "Manrope", sans-serif; font-size: 10px; font-weight: 800; }
.principles h3, .principles p { margin: 0; }
.principles h3 { font-family: "Manrope", sans-serif; font-size: 14px; }
.principles p { color: var(--muted); font-size: 12px; }

.nutrition-program { overflow: hidden; background: #fffdf8; border-top: 1px solid var(--line); scroll-margin-top: 74px; }
.nutrition-heading { display: grid; margin-bottom: 52px; grid-template-columns: 1.25fr .7fr; align-items: end; gap: 80px; }
.nutrition-heading h2 { margin: 14px 0 0; font-family: "Manrope", sans-serif; font-size: clamp(40px, 4.5vw, 62px); letter-spacing: -.055em; line-height: 1.05; }
.nutrition-heading h2 em { color: var(--green); font-family: Georgia, serif; font-weight: 400; }
.nutrition-heading > p { max-width: 430px; margin: 0; color: var(--muted); line-height: 1.75; }
.nutrition-feature { display: grid; grid-template-columns: .88fr 1.12fr; gap: 18px; }
.nutrition-visual { position: relative; min-height: 610px; overflow: hidden; background: var(--green-deep); border-radius: var(--radius); }
.juice-orb { position: absolute; border-radius: 50%; }
.juice-orb-one { width: 380px; height: 380px; left: -190px; top: -100px; background: rgba(132,199,67,.15); box-shadow: 0 0 0 55px rgba(255,255,255,.025); }
.juice-orb-two { width: 260px; height: 260px; right: -110px; bottom: -70px; background: rgba(243,163,36,.15); }
.juice-bottles { position: absolute; display: flex; left: 50%; bottom: 95px; align-items: end; gap: 12px; transform: translateX(-50%); }
.juice-bottle { position: relative; width: 105px; height: 300px; padding: 28px 10px 12px; overflow: visible; background: rgba(255,255,255,.16); border: 1px solid rgba(255,255,255,.3); border-radius: 22px 22px 30px 30px; box-shadow: inset 10px 0 16px rgba(255,255,255,.12), 0 32px 35px rgba(0,0,0,.2); backdrop-filter: blur(5px); }
.juice-bottle::before { content: ""; position: absolute; z-index: 0; inset: 62px 6px 6px; border-radius: 7px 7px 24px 24px; opacity: .9; }
.juice-green::before { background: linear-gradient(180deg, #84c743, #2b7c4c); }
.juice-gold::before { background: linear-gradient(180deg, #f5c646, #ea8f1e); }
.juice-red::before { background: linear-gradient(180deg, #d94a54, #8f2033); }
.juice-green { height: 330px; transform: rotate(-4deg); }
.juice-gold { height: 365px; }
.juice-red { height: 315px; transform: rotate(4deg); }
.juice-bottle > i { position: absolute; width: 65px; height: 34px; left: 20px; top: -22px; background: #f4efe4; border-radius: 7px 7px 3px 3px; box-shadow: inset 0 7px rgba(23,35,29,.08); }
.juice-bottle > span { position: absolute; z-index: 2; display: flex; left: 10px; right: 10px; top: 125px; min-height: 105px; padding: 12px 8px; flex-direction: column; justify-content: space-between; color: var(--green-deep); background: rgba(255,253,248,.9); border-radius: 7px 7px 18px 18px; text-align: center; }
.juice-bottle b { font-family: Georgia, serif; font-size: 13px; font-style: italic; }
.juice-bottle small { font-family: "Manrope", sans-serif; font-size: 12px; font-weight: 800; line-height: 1.05; }
.juice-note { position: absolute; z-index: 3; display: flex; padding: 13px 15px; align-items: center; gap: 10px; color: var(--ink); background: rgba(255,253,248,.94); border-radius: 14px; box-shadow: var(--shadow); }
.juice-note strong { color: var(--red); font-family: "Manrope", sans-serif; font-size: 24px; }
.juice-note span { font-size: 9px; font-weight: 700; line-height: 1.35; }
.juice-note i { display: grid; width: 28px; height: 28px; place-items: center; color: white; background: var(--green); border-radius: 50%; font-size: 11px; font-style: normal; }
.juice-note-top { top: 48px; right: 24px; }
.juice-note-bottom { left: 22px; bottom: 28px; }
.nutrition-overview { display: flex; min-height: 610px; padding: 48px; flex-direction: column; background: var(--cream); border-radius: var(--radius); }
.programme-badge { align-self: flex-start; padding: 6px 10px; color: var(--green); background: var(--green-soft); border-radius: 99px; font-size: 9px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.nutrition-overview h3 { margin: 28px 0 16px; font-family: "Manrope", sans-serif; font-size: clamp(38px, 4vw, 56px); letter-spacing: -.055em; line-height: 1.02; }
.nutrition-overview > p { max-width: 590px; margin: 0; color: var(--muted); line-height: 1.7; }
.programme-includes { display: grid; margin: 34px 0; grid-template-columns: 1fr 1fr; gap: 0 24px; border-top: 1px solid var(--line); }
.programme-includes > div { display: grid; padding: 14px 0; grid-template-columns: 30px 1fr; align-items: center; border-bottom: 1px solid var(--line); }
.programme-includes span { color: var(--green); font-size: 9px; font-weight: 800; }
.programme-includes p { margin: 0; font-size: 11px; font-weight: 600; }
.programme-action { display: flex; margin-top: auto; align-items: center; justify-content: space-between; gap: 20px; }
.programme-action small, .programme-action strong { display: block; }
.programme-action small { color: var(--muted); font-size: 8px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.programme-action strong { margin-top: 3px; font-family: "Manrope", sans-serif; font-size: 14px; }
.combined-programmes { margin-top: 18px; padding: 42px; color: white; background: var(--ink); border-radius: 26px; }
.combo-heading { display: grid; margin-bottom: 28px; grid-template-columns: 1.1fr .9fr; align-items: end; gap: 50px; }
.combo-heading .kicker { color: #f3c361; }
.combo-heading h3 { margin: 6px 0 0; font-family: "Manrope", sans-serif; font-size: 32px; letter-spacing: -.04em; }
.combo-heading p { margin: 0; color: rgba(255,255,255,.58); font-size: 11px; line-height: 1.7; }
.combo-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.combo-card { display: flex; min-height: 430px; padding: 28px; flex-direction: column; color: var(--ink); background: var(--paper); border-radius: 20px; }
.combo-card-featured { background: #f3d697; }
.combo-top { display: flex; align-items: center; justify-content: space-between; }
.combo-top span { color: var(--green); font-size: 8px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.combo-top strong { padding: 6px 9px; color: white; background: var(--green); border-radius: 99px; font-size: 9px; }
.combo-card h4 { margin: 28px 0 9px; font-family: "Manrope", sans-serif; font-size: 25px; letter-spacing: -.04em; }
.combo-card > p { margin: 0; color: var(--muted); font-size: 11px; line-height: 1.6; }
.combo-card ul { display: grid; margin: 24px 0 28px; padding: 0; gap: 9px; list-style: none; font-size: 10px; }
.combo-card li::before { content: "✓"; display: inline-grid; width: 18px; height: 18px; margin-right: 8px; place-items: center; color: white; background: var(--green); border-radius: 50%; font-size: 8px; }
.combo-action { display: flex; margin-top: auto; padding-top: 20px; align-items: end; justify-content: space-between; gap: 12px; border-top: 1px solid var(--line); }
.combo-action small, .combo-action b { display: block; }
.combo-action small { color: var(--muted); font-size: 7px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.combo-action b { max-width: 120px; margin-top: 3px; font-size: 10px; line-height: 1.25; }
.combo-action button { display: inline-flex; min-height: 38px; padding: 0 14px; align-items: center; gap: 9px; color: white; background: var(--green); border: 0; border-radius: 99px; font-size: 9px; font-weight: 800; cursor: pointer; }
.combo-action button:hover { background: var(--red); }
.combo-action i { font-size: 13px; font-style: normal; }
.combo-note { margin: 24px 0 0; color: rgba(255,255,255,.55); font-size: 9px; line-height: 1.6; text-align: center; }
.combo-note strong { color: rgba(255,255,255,.85); }
.nutrition-disclaimer { max-width: 930px; margin: 20px auto 0; color: var(--muted); font-size: 9px; line-height: 1.6; text-align: center; }

.shop { background: var(--cream); }
.shop-heading { display: grid; margin-bottom: 50px; grid-template-columns: 1.2fr .7fr; align-items: end; gap: 80px; }
.product-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 34px 16px; }
.product-visual { position: relative; display: grid; height: 310px; place-items: center; overflow: hidden; background: #fff; border: 1px solid rgba(23,35,29,.07); border-radius: 22px; }
.product-visual::before { content: ""; position: absolute; width: 260px; height: 260px; right: -85px; bottom: -100px; background: rgba(255,255,255,.33); border-radius: 50%; }
.product-green { background: #c7dec8; }
.product-orange { background: #f2d39d; }
.product-red { background: #ecc4c1; }
.product-yellow { background: #e7e1ad; }
.product-blue { background: #d9e8ee; }
.product-pink { background: #efd6e3; }
.product-teal { background: #d2e6e1; }
.product-purple { background: #e1dced; }
.product-mint { background: #d7ebe4; }
.product-pill { position: absolute; z-index: 2; top: 18px; left: 18px; padding: 5px 9px; background: rgba(255,255,255,.78); border-radius: 99px; font-size: 9px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; backdrop-filter: blur(5px); }
.product-photo { position: absolute; z-index: 1; inset: 0; width: 100%; height: 100%; object-fit: contain; mix-blend-mode: multiply; transition: transform .35s ease; }
.product-card:hover .product-photo { transform: scale(1.035); }
.quick-add { position: absolute; z-index: 3; left: 14px; right: 14px; bottom: -52px; min-height: 42px; color: white; background: var(--ink); border: 0; border-radius: 99px; font-size: 11px; font-weight: 800; cursor: pointer; opacity: 0; transition: bottom .25s, opacity .25s; }
.product-card:hover .quick-add, .quick-add:focus { bottom: 14px; opacity: 1; }
.product-info { display: flex; padding: 18px 4px 0; justify-content: space-between; align-items: end; }
.product-info span { color: var(--muted); font-size: 9px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.product-info h3 { margin: 3px 0 0; font-family: "Manrope", sans-serif; font-size: 16px; }
.product-info > strong { max-width: 72px; color: var(--green); font-family: "Manrope", sans-serif; font-size: 10px; line-height: 1.25; text-align: right; }
.shop-foot { display: flex; margin-top: 44px; padding-top: 18px; justify-content: space-between; border-top: 1px solid var(--line); color: var(--muted); font-size: 12px; }
.shop-foot p { margin: 0; }
.shop-foot button { padding: 0; border: 0; border-bottom: 1px solid; background: transparent; font-weight: 700; cursor: pointer; }

.testimonial { position: relative; display: grid; padding-top: 105px; padding-bottom: 105px; grid-template-columns: .22fr 1.2fr .45fr; align-items: start; gap: 25px; }
.quote-mark { color: var(--orange); font-family: Georgia, serif; font-size: 145px; line-height: .8; }
.testimonial blockquote { margin: 0; }
.testimonial blockquote > p { max-width: 800px; margin: 0; font-family: "Manrope", sans-serif; font-size: clamp(24px, 3vw, 39px); font-weight: 500; letter-spacing: -.035em; line-height: 1.35; }
.testimonial blockquote footer { display: flex; margin-top: 32px; align-items: center; gap: 12px; }
.testimonial-avatar { display: grid; width: 44px; height: 44px; place-items: center; color: white; background: var(--green); border-radius: 50%; font-size: 11px; font-weight: 800; }
.testimonial blockquote footer strong, .testimonial blockquote footer span { display: block; }
.testimonial blockquote footer strong { font-size: 12px; }
.testimonial blockquote footer span { color: var(--muted); font-size: 10px; }
.rating { justify-self: end; padding: 14px 0; }
.rating span { display: block; color: var(--orange); letter-spacing: .08em; }
.rating small { color: var(--muted); font-size: 9px; }

.faq { display: grid; grid-template-columns: .7fr 1.3fr; gap: 100px; border-top: 1px solid var(--line); }
.faq-intro > p { max-width: 390px; color: var(--muted); }
.faq-intro .text-link { margin-top: 20px; }
.accordion details { border-bottom: 1px solid var(--line); }
.accordion details:first-child { border-top: 1px solid var(--line); }
.accordion summary { position: relative; padding: 27px 54px 27px 0; font-family: "Manrope", sans-serif; font-size: 16px; font-weight: 700; cursor: pointer; list-style: none; }
.accordion summary::-webkit-details-marker { display: none; }
.accordion summary span::before, .accordion summary span::after { content: ""; position: absolute; width: 15px; height: 1.5px; right: 9px; top: 38px; background: var(--ink); transition: transform .2s; }
.accordion summary span::after { transform: rotate(90deg); }
.accordion details[open] summary span::after { transform: rotate(0); }
.accordion details p { max-width: 650px; margin: -7px 0 28px; color: var(--muted); font-size: 13px; line-height: 1.75; }

.final-cta { position: relative; padding: 105px 0; overflow: hidden; color: white; background: var(--green); text-align: center; }
.final-cta .section-shell { position: relative; z-index: 2; }
.final-cta .kicker { color: #ffd373; }
.final-cta h2 { margin: 15px 0 20px; font-family: "Manrope", sans-serif; font-size: clamp(49px, 6vw, 78px); letter-spacing: -.06em; line-height: .98; }
.final-cta h2 em { color: #b7dfa8; }
.final-cta p { max-width: 540px; margin: 0 auto 30px; color: rgba(255,255,255,.72); }
.cta-orb { position: absolute; border: 1px solid rgba(255,255,255,.15); border-radius: 50%; }
.orb-one { width: 440px; height: 440px; left: -160px; top: -110px; box-shadow: 0 0 0 60px rgba(255,255,255,.02), 0 0 0 120px rgba(255,255,255,.02); }
.orb-two { width: 360px; height: 360px; right: -100px; bottom: -170px; background: rgba(243,163,36,.12); }

.footer { padding-top: 70px; background: #fffdf8; }
.footer-main { display: grid; padding-bottom: 60px; grid-template-columns: 1.6fr repeat(3, 1fr); gap: 55px; }
.footer-brand img { width: 200px; }
.footer-brand p, .footer-column p { color: var(--muted); font-size: 12px; }
.footer-column { display: flex; flex-direction: column; gap: 10px; font-size: 12px; }
.footer-column h3 { margin: 0 0 10px; font-family: "Manrope", sans-serif; font-size: 11px; letter-spacing: .1em; text-transform: uppercase; }
.footer-column a:hover { color: var(--green); }
.footer-column button { padding: 0; color: var(--green); background: none; border: 0; text-align: left; font-size: 12px; font-weight: 700; cursor: pointer; }
.footer-bottom { display: flex; padding: 20px 0 30px; justify-content: space-between; border-top: 1px solid var(--line); color: var(--muted); font-size: 9px; }
.footer-bottom p { margin: 0; }

.overlay { position: fixed; z-index: 180; inset: 0; background: rgba(7, 20, 14, .56); backdrop-filter: blur(4px); }
.cart-drawer { position: fixed; z-index: 200; display: flex; width: min(460px, 100%); height: 100%; top: 0; right: 0; padding: 34px; flex-direction: column; background: var(--paper); box-shadow: -20px 0 60px rgba(0,0,0,.2); transform: translateX(105%); transition: transform .35s cubic-bezier(.7,0,.2,1); }
.cart-drawer.open { transform: translateX(0); }
.drawer-head { display: flex; padding-bottom: 22px; align-items: start; justify-content: space-between; border-bottom: 1px solid var(--line); }
.drawer-head h2 { margin: 4px 0 0; font-family: "Manrope", sans-serif; font-size: 28px; }
.icon-close { display: grid; width: 40px; height: 40px; padding: 0; place-items: center; background: transparent; border: 1px solid var(--line); border-radius: 50%; font-size: 25px; cursor: pointer; }
.cart-items { display: grid; overflow: auto; }
.cart-item { display: grid; padding: 18px 0; grid-template-columns: 48px 1fr auto; align-items: center; gap: 14px; border-bottom: 1px solid var(--line); }
.cart-item-icon { display: grid; width: 48px; height: 48px; place-items: center; color: white; background: var(--green); border-radius: 14px; font-weight: 800; }
.cart-item h3, .cart-item p { margin: 0; }
.cart-item h3 { font-size: 13px; }
.cart-item p { color: var(--muted); font-size: 11px; }
.cart-item button { border: 0; color: var(--muted); background: none; font-size: 18px; cursor: pointer; }
.empty-cart { margin: auto; text-align: center; }
.empty-cart > span { display: grid; width: 68px; height: 68px; margin: 0 auto 18px; place-items: center; color: var(--green); background: var(--green-soft); border-radius: 50%; font-size: 38px; }
.empty-cart h3 { margin: 0 0 8px; font-family: "Manrope", sans-serif; }
.empty-cart p { max-width: 270px; color: var(--muted); font-size: 12px; }
.empty-cart button { padding: 0 0 4px; border: 0; border-bottom: 1px solid; background: none; font-size: 11px; font-weight: 800; cursor: pointer; }
.cart-summary { margin-top: auto; padding-top: 22px; border-top: 1px solid var(--line); }
.cart-summary > div { display: flex; justify-content: space-between; font-size: 14px; }
.cart-summary > div strong { font-size: 22px; }
.cart-summary p { color: var(--muted); font-size: 10px; }
.cart-summary .button { width: 100%; margin-top: 10px; }

.modal { position: fixed; z-index: 210; display: grid; inset: 0; padding: 22px; place-items: center; }
.modal-panel { position: relative; width: min(650px, 100%); max-height: calc(100vh - 44px); padding: 42px; overflow: auto; background: var(--paper); border-radius: 26px; box-shadow: var(--shadow); }
.modal-panel > .icon-close { position: absolute; top: 20px; right: 20px; }
.modal-panel h2 { margin: 9px 0 6px; font-family: "Manrope", sans-serif; font-size: 34px; letter-spacing: -.04em; }
.modal-panel > p { margin: 0 0 24px; color: var(--muted); font-size: 13px; }
#booking-form { display: grid; gap: 14px; }
#booking-form label { display: grid; gap: 6px; font-size: 10px; font-weight: 800; letter-spacing: .07em; text-transform: uppercase; }
#booking-form input, #booking-form select, #booking-form textarea { width: 100%; padding: 13px 14px; color: var(--ink); background: white; border: 1px solid var(--line); border-radius: 10px; outline: 0; font-size: 13px; font-weight: 400; letter-spacing: 0; text-transform: none; transition: border .2s, box-shadow .2s; }
#booking-form input:focus, #booking-form select:focus, #booking-form textarea:focus { border-color: var(--green); box-shadow: 0 0 0 3px rgba(36,107,79,.1); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
#booking-form .consent { display: flex; grid-template-columns: none; align-items: flex-start; gap: 9px; color: var(--muted); font-size: 10px; font-weight: 400; letter-spacing: 0; line-height: 1.5; text-transform: none; }
#booking-form .consent input { width: auto; margin-top: 2px; }
#booking-form .button { justify-self: start; }
.form-note { color: var(--muted); font-size: 9px; }
.toast { position: fixed; z-index: 300; left: 50%; bottom: 28px; padding: 12px 18px; color: white; background: var(--ink); border-radius: 99px; box-shadow: var(--shadow); font-size: 12px; opacity: 0; pointer-events: none; transform: translate(-50%, 20px); transition: opacity .25s, transform .25s; }
.toast.show { opacity: 1; transform: translate(-50%, 0); }

.reveal { opacity: 0; transform: translateY(24px); transition: opacity .75s ease, transform .75s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }
.delay-one { transition-delay: .1s; }
.delay-two { transition-delay: .2s; }
.delay-three { transition-delay: .3s; }

@media (max-width: 1050px) {
  .site-nav { gap: 17px; }
  .site-nav > a:nth-child(4) { display: none; }
  .hero { gap: 40px; }
  .service-grid { grid-template-columns: 1fr 1fr; }
  .service-featured { grid-row: span 2; min-height: 800px; }
  .service-card:nth-child(4) { grid-column: auto; min-height: 390px; }
  .product-grid { grid-template-columns: repeat(3, 1fr); gap: 36px 18px; }
  .approach { gap: 55px; }
  .package-grid { grid-template-columns: repeat(2, 1fr); }
  .package-addons { grid-template-columns: 1fr 1fr; }
  .addon-intro { grid-column: span 2; }
  .booking-layout { grid-template-columns: 260px minmax(0, 1fr); }
  .nutrition-feature { grid-template-columns: 1fr; }
  .nutrition-visual { min-height: 560px; }
  .nutrition-overview { min-height: 560px; }
}

@media (max-width: 820px) {
  .section-pad { padding-block: 85px; }
  .site-header { height: 82px; padding-inline: 24px; }
  .brand { position: relative; z-index: 102; width: 175px; }
  .header-tools { position: relative; z-index: 102; }
  .header-whatsapp-button { display: grid; }
  .menu-toggle { position: relative; z-index: 102; display: grid; width: 44px; height: 44px; padding: 0; place-content: center; gap: 6px; background: transparent; border: 1px solid var(--line); border-radius: 50%; }
  .menu-toggle span { width: 18px; height: 1.5px; background: var(--ink); transition: transform .2s; }
  .menu-toggle.active span:first-child { transform: translateY(4px) rotate(45deg); }
  .menu-toggle.active span:last-child { transform: translateY(-4px) rotate(-45deg); }
  .site-nav { position: fixed; z-index: 101; display: flex; inset: 0 0 auto; width: 100%; height: 100vh; height: 100dvh; padding: 120px 30px 40px; flex-direction: column; align-items: stretch; gap: 0; overflow-y: auto; background: var(--paper); opacity: 0; pointer-events: none; transform: translateY(-20px); overscroll-behavior: contain; transition: opacity .25s, transform .25s; }
  .site-nav.open { opacity: 1; pointer-events: auto; transform: translateY(0); }
  .site-nav > a { padding: 16px 0; border-bottom: 1px solid var(--line); font-size: 24px; }
  .site-nav > a:nth-child(4) { display: block; }
  .site-nav .cart-button { display: none; }
  .site-nav .button { width: 100%; margin-top: 20px; align-self: stretch; }
  .hero { padding-top: 58px; grid-template-columns: 1fr; }
  .hero-copy { max-width: 670px; }
  .hero h1 { font-size: clamp(57px, 13vw, 84px); }
  .hero-visual { min-height: 600px; }
  .hero-image-wrap { inset: 20px 50px 20px 50px; }
  .floating-card-top { right: 20px; }
  .floating-card-bottom { left: 20px; }
  .trust-strip { grid-template-columns: 1fr 1fr; }
  .trust-strip > div:nth-child(2) { border-right: 0; }
  .trust-strip > div { border-bottom: 1px solid rgba(255,255,255,.15); }
  .section-heading, .shop-heading { grid-template-columns: 1fr; gap: 24px; }
  .service-grid { grid-template-columns: 1fr 1fr; }
  .service-featured { grid-row: auto; grid-column: span 2; min-height: 690px; }
  .product-grid { grid-template-columns: repeat(2, 1fr); }
  .package-grid { grid-template-columns: 1fr; }
  .package-card { min-height: 480px; }
  .package-addons { grid-template-columns: 1fr; }
  .addon-intro { grid-column: auto; }
  .addon-item { padding: 16px 0 0; border-top: 1px solid rgba(23,35,29,.14); border-left: 0; }
  .booking-heading { grid-template-columns: 1fr; gap: 20px; }
  .booking-layout { grid-template-columns: 1fr; }
  .booking-guide { position: relative; top: 0; }
  .nutrition-heading { grid-template-columns: 1fr; gap: 22px; }
  .combo-heading { grid-template-columns: 1fr; gap: 14px; }
  .combo-grid { grid-template-columns: 1fr; }
  .combo-card { min-height: 390px; }
  .approach { grid-template-columns: 1fr; }
  .approach-visual { min-height: 610px; }
  .approach-copy { max-width: 660px; }
  .testimonial { grid-template-columns: 80px 1fr; }
  .rating { display: none; }
  .faq { grid-template-columns: 1fr; gap: 55px; }
  .footer-main { grid-template-columns: 1.4fr 1fr 1fr; }
  .footer-brand { grid-column: span 3; }
}

@media (max-width: 560px) {
  .section-shell { width: min(100% - 30px, 1180px); }
  .section-pad { padding-block: 70px; }
  .announcement { min-height: 34px; justify-content: space-between; gap: 10px; font-size: 9px; }
  .announcement p span { display: none; }
  .site-header { padding-inline: 15px; }
  .brand { width: 165px; }
  .hero { min-height: auto; padding-top: 18px; padding-bottom: 70px; gap: 40px; }
  .hero h1 { margin: 19px 0; font-size: clamp(50px, 15.7vw, 70px); }
  .hero-lead { font-size: 15px; }
  .hero-actions { align-items: flex-start; flex-direction: column; gap: 14px; }
  .hero-proof { margin-top: 35px; }
  .hero-visual { min-height: 440px; order: -1; }
  .hero-image-wrap { inset: 0 12px 20px; border-radius: 150px 150px 20px 20px; }
  .floating-card { padding: 11px 13px; }
  .floating-card-top { top: 35px; right: 0; }
  .floating-card-bottom { bottom: 0; left: 0; }
  .floating-card strong { font-size: 10px; }
  .floating-card small { font-size: 8px; }
  .trust-strip { padding-inline: 12px; }
  .trust-strip > div { justify-content: flex-start; padding: 10px; font-size: 10px; }
  .section-heading { margin-bottom: 35px; }
  .section-heading h2, .shop-heading h2, .faq h2 { font-size: 39px; }
  .service-grid { grid-template-columns: 1fr; }
  .service-featured { grid-column: auto; min-height: 660px; }
  .service-card, .service-card:nth-child(4) { min-height: 390px; padding: 26px; }
  .icon-water { width: 140px; height: 140px; }
  .package-card { min-height: 520px; padding: 28px; }
  .booking-heading h2 { font-size: 41px; }
  .booking-guide { padding: 25px; }
  .booking-frame-shell { height: 458px; margin-inline: -2px; border-radius: 18px; }
  .booking-frame-top { padding-inline: 13px; grid-template-columns: 1fr auto; }
  .booking-frame-top > span { display: none; }
  .booking-frame-top b { font-size: 7px; }
  #salonbridge_iframe { width: 153.846%; height: 600px; margin-top: 12px; transform: scale(.65); transform-origin: left top; }
  .nutrition-heading h2 { font-size: 40px; }
  .nutrition-visual { min-height: 510px; }
  .juice-bottles { bottom: 80px; gap: 5px; transform: translateX(-50%) scale(.82); }
  .juice-note-top { top: 25px; right: 16px; }
  .juice-note-bottom { left: 15px; bottom: 18px; }
  .nutrition-overview { min-height: auto; padding: 30px 24px; }
  .nutrition-overview h3 { font-size: 38px; }
  .programme-includes { grid-template-columns: 1fr; }
  .programme-action { align-items: flex-start; flex-direction: column; }
  .combined-programmes { padding: 26px 18px; }
  .combo-heading h3 { font-size: 27px; }
  .combo-card { min-height: 410px; padding: 25px; }
  .approach-visual { min-height: 500px; }
  .approach-image { inset: 0 20px 55px 0; border-radius: 130px 130px 20px 20px; }
  .approach-quote { width: 240px; padding: 20px; }
  .principles > div { grid-template-columns: 32px 1fr; }
  .principles p { grid-column: 2; margin-top: 3px; }
  .product-grid { grid-template-columns: 1fr; gap: 36px; }
  .product-visual { height: 390px; }
  .quick-add { bottom: 14px; opacity: 1; }
  .shop-foot { align-items: flex-start; flex-direction: column; gap: 10px; }
  .testimonial { padding-top: 70px; padding-bottom: 70px; grid-template-columns: 1fr; }
  .quote-mark { height: 50px; font-size: 100px; }
  .testimonial blockquote > p { font-size: 25px; }
  .faq { gap: 35px; }
  .final-cta { padding-block: 80px; }
  .final-cta h2 { font-size: 51px; }
  .footer { padding-top: 55px; }
  .footer-main { grid-template-columns: 1fr 1fr; gap: 38px 28px; }
  .footer-brand { grid-column: span 2; }
  .footer-column:last-child { grid-column: span 2; }
  .footer-bottom { align-items: flex-start; flex-direction: column; gap: 8px; }
  .cart-drawer { padding: 24px 20px; }
  .modal { padding: 10px; }
  .modal-panel { max-height: calc(100vh - 20px); padding: 34px 22px 24px; }
  .modal-panel h2 { padding-right: 35px; font-size: 29px; }
  .form-row { grid-template-columns: 1fr; }
}

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