/* =============================================================
   ZAHI CARE — Custom Homepage Styles  (RTL / Arabic)
   Brand palette: Olive Green · Gold · Cream · Charcoal
   Scoped under #zahi-home so it never collides with Salla theme
   ============================================================= */

#zahi-home {
  /* ---- Brand tokens ---- */
  --z-green-900: #1c2714;   /* deepest olive (logo bg)  */
  --z-green-700: #2d4a2b;
  --z-green-600: #2d5a3d;   /* brand green */
  --z-green-400: #5e7c54;
  --z-gold:      #c8a04d;   /* signature accent */
  --z-gold-soft: #e3c98a;
  --z-cream:     #fff8ed;   /* warm background */
  --z-beige:     #f5f0e6;
  --z-tan:       #e0d5c0;   /* borders */
  --z-ink:       #1a1a1a;
  --z-ink-soft:  #4a4639;

  --z-radius:    18px;
  --z-radius-sm: 12px;
  --z-shadow:    0 18px 50px -22px rgba(28,39,20,.45);
  --z-shadow-sm: 0 8px 24px -14px rgba(28,39,20,.4);
  --z-maxw:      1240px;

  --z-serif: "Playfair Display", "Georgia", serif;
  --z-sans:  "Tajawal", "Cairo", system-ui, sans-serif;

  direction: rtl;
  text-align: right;
  font-family: var(--z-sans);
  color: var(--z-ink);
  background: var(--z-cream);
  line-height: 1.75;
  -webkit-font-smoothing: antialiased;
  font-size: 16px;
  overflow-x: hidden;
  margin: 0;           /* sit flush under the Salla header — no top gap */
  display: block;
}
/* kill any default spacing on the first visible element of the block */
#zahi-home > .z-announce:first-child,
#zahi-home > .z-hero:first-child { margin-top: 0; }

#zahi-home *,
#zahi-home *::before,
#zahi-home *::after { box-sizing: border-box; margin: 0; padding: 0; }

#zahi-home img { max-width: 100%; display: block; }
#zahi-home a { text-decoration: none; color: inherit; }
#zahi-home .z-wrap { max-width: var(--z-maxw); margin-inline: auto; padding-inline: 22px; }

/* ---- Buttons ---- */
#zahi-home .z-btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--z-sans); font-weight: 800; font-size: 1.02rem;
  padding: 15px 34px; border-radius: 100px; cursor: pointer;
  border: none; transition: transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s, background .25s;
  will-change: transform;
}
#zahi-home .z-btn--gold {
  background: linear-gradient(135deg, var(--z-gold) 0%, #b88a36 100%);
  color: #2a210c; box-shadow: 0 14px 30px -12px rgba(200,160,77,.7);
}
#zahi-home .z-btn--gold:hover { transform: translateY(-3px); box-shadow: 0 20px 38px -12px rgba(200,160,77,.85); }
#zahi-home .z-btn--ghost {
  background: transparent; color: var(--z-cream);
  border: 1.5px solid rgba(255,248,237,.45);
}
#zahi-home .z-btn--ghost:hover { background: rgba(255,248,237,.1); transform: translateY(-2px); }
#zahi-home .z-btn--dark { background: var(--z-green-900); color: var(--z-cream); }
#zahi-home .z-btn--dark:hover { transform: translateY(-3px); box-shadow: var(--z-shadow-sm); }

/* ---- Section heading ---- */
#zahi-home .z-eyebrow {
  display: inline-flex; align-items: center; gap: 9px;
  font-weight: 700; font-size: .82rem; letter-spacing: .12em;
  color: var(--z-gold); text-transform: uppercase;
}
#zahi-home .z-eyebrow::before { content:""; width: 26px; height: 1.5px; background: var(--z-gold); }
#zahi-home .z-h2 {
  font-family: var(--z-sans); font-weight: 900;
  font-size: clamp(1.7rem, 3.6vw, 2.7rem); line-height: 1.25;
  color: var(--z-green-900); margin: 14px 0 10px;
}
#zahi-home .z-sub { color: var(--z-ink-soft); max-width: 560px; font-size: 1.02rem; }
#zahi-home .z-center { text-align: center; }
#zahi-home .z-center .z-sub { margin-inline: auto; }

/* ============================ TOP BAR ============================ */
#zahi-home .z-announce {
  background: var(--z-green-900); color: var(--z-gold-soft);
  text-align: center; font-size: .9rem; font-weight: 600;
  padding: 9px 16px; letter-spacing: .01em;
}
#zahi-home .z-announce b { color: #fff; }

#zahi-home .z-nav {
  position: sticky; top: 0; z-index: 40;
  background: rgba(255,248,237,.86); backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--z-tan);
}
#zahi-home .z-nav__in {
  max-width: var(--z-maxw); margin-inline: auto; padding: 14px 22px;
  display: flex; align-items: center; justify-content: space-between; gap: 20px;
}
#zahi-home .z-logo { display: flex; align-items: center; gap: 11px; }
#zahi-home .z-logo__mark { width: 38px; height: 38px; flex: none; }
#zahi-home .z-logo__txt { font-family: var(--z-serif); font-weight: 700; font-size: 1.32rem; letter-spacing: .14em; color: var(--z-green-900); }
#zahi-home .z-navlinks { display: flex; gap: 30px; font-weight: 700; font-size: .98rem; }
#zahi-home .z-navlinks a { color: var(--z-ink-soft); transition: color .2s; }
#zahi-home .z-navlinks a:hover { color: var(--z-green-600); }
#zahi-home .z-nav__cta { display: flex; align-items: center; gap: 14px; }

/* ============================ HERO ============================ */
#zahi-home .z-hero {
  position: relative; overflow: hidden;
  background:
    radial-gradient(120% 90% at 85% 0%, #33502f 0%, transparent 55%),
    radial-gradient(90% 80% at 0% 100%, #243218 0%, transparent 60%),
    linear-gradient(160deg, var(--z-green-900) 0%, #243017 100%);
  color: var(--z-cream);
}
#zahi-home .z-hero::after {        /* botanical grain glow */
  content:""; position: absolute; inset: 0;
  background-image: radial-gradient(rgba(200,160,77,.16) 1px, transparent 1px);
  background-size: 26px 26px; opacity: .5; pointer-events: none;
}
#zahi-home .z-hero__in {
  max-width: var(--z-maxw); margin-inline: auto; padding: 70px 22px 80px;
  display: grid; grid-template-columns: 1.05fr .95fr; gap: 50px; align-items: center;
  position: relative; z-index: 2;
}
#zahi-home .z-hero__badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(200,160,77,.16); border: 1px solid rgba(200,160,77,.4);
  color: var(--z-gold-soft); font-weight: 700; font-size: .85rem;
  padding: 7px 16px; border-radius: 100px;
}
#zahi-home .z-hero h1 {
  font-family: var(--z-sans); font-weight: 900;
  font-size: clamp(2.1rem, 5.4vw, 3.6rem); line-height: 1.18;
  margin: 20px 0 18px; letter-spacing: -.01em;
}
#zahi-home .z-hero h1 .g { color: var(--z-gold); }
#zahi-home .z-hero p.lead { font-size: 1.12rem; color: rgba(255,248,237,.82); max-width: 480px; margin-bottom: 28px; }
#zahi-home .z-hero__actions { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; }
#zahi-home .z-hero__stats { display: flex; gap: 26px; margin-top: 34px; flex-wrap: wrap; }
#zahi-home .z-stat .n { font-weight: 900; font-size: 1.6rem; color: var(--z-gold); font-family: var(--z-serif); }
#zahi-home .z-stat .l { font-size: .82rem; color: rgba(255,248,237,.7); }

/* hero product card */
#zahi-home .z-hero__card {
  position: relative; justify-self: center;
  background: linear-gradient(180deg, #fffdf8, var(--z-beige));
  border-radius: 28px; padding: 22px; width: 100%; max-width: 420px;
  box-shadow: 0 40px 80px -30px rgba(0,0,0,.6); color: var(--z-ink);
  transform: rotate(-1.4deg);
}
#zahi-home .z-hero__card .pic {
  border-radius: 18px; overflow: hidden; background: #fff;
  aspect-ratio: 1/1; display: grid; place-items: center;
}
#zahi-home .z-hero__card .pic img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s; }
#zahi-home .z-hero__card:hover .pic img { transform: scale(1.05); }
#zahi-home .z-hero__card .save {
  position: absolute; top: 14px; inset-inline-start: 14px;
  background: #b23b2e; color: #fff; font-weight: 800; font-size: .82rem;
  padding: 6px 13px; border-radius: 100px; z-index: 3; box-shadow: var(--z-shadow-sm);
}
#zahi-home .z-hero__card h3 { font-size: 1.25rem; font-weight: 900; color: var(--z-green-900); margin: 16px 0 4px; }
#zahi-home .z-hero__card .rate { color: var(--z-gold); font-size: .92rem; font-weight: 700; }
#zahi-home .z-hero__card .rate span { color: var(--z-ink-soft); font-weight: 600; }
#zahi-home .z-hero__price { display: flex; align-items: baseline; gap: 10px; margin: 12px 0 16px; }
#zahi-home .z-hero__price .now { font-size: 1.7rem; font-weight: 900; color: var(--z-green-700); }
#zahi-home .z-hero__price .now small { font-size: .9rem; font-weight: 700; }
#zahi-home .z-hero__price .old { color: #a99; text-decoration: line-through; font-weight: 700; }
#zahi-home .z-hero__card .z-btn { width: 100%; justify-content: center; }

/* ============================ TRUST STRIP ============================ */
#zahi-home .z-trust { background: var(--z-green-900); }
#zahi-home .z-trust__in {
  max-width: var(--z-maxw); margin-inline: auto; padding: 22px;
  display: grid; grid-template-columns: repeat(5,1fr); gap: 12px;
}
#zahi-home .z-trust__i {
  display: flex; align-items: center; gap: 11px; justify-content: center;
  color: var(--z-cream); font-weight: 700; font-size: .96rem;
}
#zahi-home .z-trust__i svg { width: 26px; height: 26px; color: var(--z-gold); flex: none; }

/* ============================ SECTION SHELL ============================ */
#zahi-home section.z-sec { padding: 78px 0; }
#zahi-home .z-sec--cream { background: var(--z-cream); }
#zahi-home .z-sec--beige { background: var(--z-beige); }
#zahi-home .z-sechead { margin-bottom: 42px; }

/* ============================ PRODUCT GRID ============================ */
#zahi-home .z-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 22px; }
#zahi-home .z-card {
  background: #fff; border: 1px solid var(--z-tan); border-radius: var(--z-radius);
  overflow: hidden; display: flex; flex-direction: column;
  transition: transform .3s cubic-bezier(.2,.8,.2,1), box-shadow .3s, border-color .3s;
}
#zahi-home .z-card:hover { transform: translateY(-7px); box-shadow: var(--z-shadow); border-color: var(--z-gold-soft); }
#zahi-home .z-card__img { position: relative; aspect-ratio: 1/1; background: var(--z-beige); overflow: hidden; }
#zahi-home .z-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform .55s; }
#zahi-home .z-card:hover .z-card__img img { transform: scale(1.07); }
#zahi-home .z-tag {
  position: absolute; top: 12px; inset-inline-start: 12px;
  background: var(--z-green-600); color: #fff; font-weight: 800; font-size: .74rem;
  padding: 5px 11px; border-radius: 100px;
}
#zahi-home .z-tag--save { background: #b23b2e; }
#zahi-home .z-card__body { padding: 16px 16px 18px; display: flex; flex-direction: column; flex: 1; }
#zahi-home .z-card__body h3 { font-size: 1.06rem; font-weight: 800; color: var(--z-green-900); margin-bottom: 6px; }
#zahi-home .z-card__body p { font-size: .86rem; color: var(--z-ink-soft); margin-bottom: 14px; flex: 1; }
#zahi-home .z-card__price { display: flex; align-items: baseline; gap: 8px; margin-bottom: 14px; }
#zahi-home .z-card__price .now { font-weight: 900; font-size: 1.22rem; color: var(--z-green-700); }
#zahi-home .z-card__price .now small { font-size: .78rem; font-weight: 700; }
#zahi-home .z-card__price .old { font-size: .9rem; color: #b3ab9a; text-decoration: line-through; font-weight: 700; }
#zahi-home .z-card .z-btn { width: 100%; justify-content: center; padding: 12px; font-size: .95rem; }

/* ============================ HERO BUNDLE BANNER ============================ */
#zahi-home .z-bundle {
  background: linear-gradient(135deg, var(--z-green-700), var(--z-green-900));
  border-radius: 26px; overflow: hidden; color: var(--z-cream);
  display: grid; grid-template-columns: 1fr 1fr; align-items: center;
  position: relative; box-shadow: var(--z-shadow);
}
#zahi-home .z-bundle::before {
  content:""; position: absolute; inset: 0;
  background: radial-gradient(60% 120% at 90% 50%, rgba(200,160,77,.22), transparent 60%);
}
#zahi-home .z-bundle__txt { padding: 48px 44px; position: relative; z-index: 2; }
#zahi-home .z-bundle__txt h2 { font-weight: 900; font-size: clamp(1.6rem,3vw,2.3rem); line-height: 1.3; margin: 14px 0 12px; }
#zahi-home .z-bundle__txt .g { color: var(--z-gold); }
#zahi-home .z-bundle__txt p { color: rgba(255,248,237,.82); margin-bottom: 24px; }
#zahi-home .z-bundle__pic { position: relative; z-index: 2; height: 100%; min-height: 320px; }
#zahi-home .z-bundle__pic img { width: 100%; height: 100%; object-fit: cover; }

/* ============================ INGREDIENTS / 7 OILS ============================ */
#zahi-home .z-oils { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; }
#zahi-home .z-oil {
  background: #fff; border: 1px solid var(--z-tan); border-radius: 14px;
  padding: 22px 18px; text-align: center; transition: transform .3s, box-shadow .3s;
}
#zahi-home .z-oil:hover { transform: translateY(-5px); box-shadow: var(--z-shadow-sm); }
#zahi-home .z-oil .ic {
  width: 54px; height: 54px; margin: 0 auto 12px; border-radius: 50%;
  display: grid; place-items: center;
  background: var(--z-beige); color: var(--z-green-600); border: 1px solid var(--z-tan);
}
#zahi-home .z-oil .ic svg { width: 26px; height: 26px; }
#zahi-home .z-oil:hover .ic { background: var(--z-green-600); color: #fff; border-color: var(--z-green-600); }
#zahi-home .z-oil h4 { font-size: 1rem; font-weight: 800; color: var(--z-green-900); margin-bottom: 4px; }
#zahi-home .z-oil p { font-size: .82rem; color: var(--z-ink-soft); }

/* ============================ HOW TO USE ============================ */
#zahi-home .z-steps { display: grid; grid-template-columns: repeat(3,1fr); gap: 26px; }
#zahi-home .z-step { text-align: center; position: relative; padding: 8px; }
#zahi-home .z-step .num {
  width: 64px; height: 64px; margin: 0 auto 16px; border-radius: 50%;
  display: grid; place-items: center; font-family: var(--z-serif); font-weight: 700;
  font-size: 1.7rem; color: var(--z-green-900);
  background: linear-gradient(135deg, var(--z-gold-soft), var(--z-gold));
  box-shadow: 0 10px 24px -10px rgba(200,160,77,.7);
}
#zahi-home .z-step h4 { font-size: 1.15rem; font-weight: 800; color: var(--z-green-900); margin-bottom: 8px; }
#zahi-home .z-step p { color: var(--z-ink-soft); font-size: .95rem; max-width: 280px; margin-inline: auto; }

/* ============================ REVIEWS ============================ */
#zahi-home .z-reviews { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
#zahi-home .z-rev {
  background: #fff; border: 1px solid var(--z-tan); border-radius: var(--z-radius);
  padding: 26px 24px; position: relative;
}
#zahi-home .z-rev .stars { color: var(--z-gold); letter-spacing: 3px; margin-bottom: 12px; }
#zahi-home .z-rev p { font-size: 1rem; color: var(--z-ink); margin-bottom: 16px; line-height: 1.85; }
#zahi-home .z-rev .who { display: flex; align-items: center; gap: 11px; }
#zahi-home .z-rev .av {
  width: 42px; height: 42px; border-radius: 50%; flex: none;
  background: linear-gradient(135deg, var(--z-green-400), var(--z-green-700));
  color: #fff; display: grid; place-items: center; font-weight: 800;
}
#zahi-home .z-rev .who b { display: block; font-size: .95rem; color: var(--z-green-900); }
#zahi-home .z-rev .who span { font-size: .8rem; color: var(--z-ink-soft); }

/* ---- Native Salla add-to-cart button, styled to match the design ----
   <salla-add-product-button> renders into light DOM as
   salla-add-product-button > div > salla-button > button.s-button-element */
#zahi-home salla-add-product-button { display: block; width: 100%; margin-top: auto; }
#zahi-home salla-add-product-button .w-full,
#zahi-home salla-add-product-button .s-button-wrap,
#zahi-home salla-add-product-button salla-button { width: 100%; display: block; }
#zahi-home salla-add-product-button button,
#zahi-home salla-add-product-button .s-button-element {
  width: 100% !important;
  display: inline-flex !important; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--z-sans) !important; font-weight: 800 !important; font-size: .98rem !important;
  border: none !important; cursor: pointer; line-height: 1.4;
  padding: 13px 18px !important; border-radius: 100px !important;
  transition: transform .25s, box-shadow .25s, filter .25s; box-shadow: none;
}
#zahi-home salla-add-product-button button:hover { transform: translateY(-2px); }
/* gold variant (hero card + bestsellers) */
#zahi-home salla-add-product-button.z-host-gold button,
#zahi-home salla-add-product-button.z-host-gold .s-button-element {
  background: linear-gradient(135deg, var(--z-gold), #b88a36) !important; color: #2a210c !important;
  box-shadow: 0 12px 26px -12px rgba(200,160,77,.7) !important;
}
/* dark variant (single oils) */
#zahi-home salla-add-product-button.z-host-dark button,
#zahi-home salla-add-product-button.z-host-dark .s-button-element {
  background: var(--z-green-900) !important; color: var(--z-cream) !important;
}
/* baseline before Salla hydrates (and in local preview) so it still looks like a button */
#zahi-home salla-add-product-button:not(.hydrated) {
  text-align: center; padding: 13px 18px; border-radius: 100px;
  font-weight: 800; color: #2a210c; visibility: visible;
  background: linear-gradient(135deg, var(--z-gold), #b88a36);
}
#zahi-home salla-add-product-button.z-host-dark:not(.hydrated) { background: var(--z-green-900); color: var(--z-cream); }

/* ============================ FAQ ============================ */
#zahi-home .z-faq { display: flex; flex-direction: column; gap: 12px; }
#zahi-home .z-faqi {
  background: #fff; border: 1px solid var(--z-tan); border-radius: var(--z-radius-sm);
  overflow: hidden; transition: border-color .25s, box-shadow .25s;
}
#zahi-home .z-faqi[open] { border-color: var(--z-gold-soft); box-shadow: var(--z-shadow-sm); }
#zahi-home .z-faqi summary {
  list-style: none; cursor: pointer; padding: 18px 22px;
  font-weight: 800; color: var(--z-green-900); font-size: 1.05rem;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
}
#zahi-home .z-faqi summary::-webkit-details-marker { display: none; }
#zahi-home .z-faqi summary::after {
  content: "+"; font-size: 1.5rem; font-weight: 400; color: var(--z-gold);
  transition: transform .3s; line-height: 1;
}
#zahi-home .z-faqi[open] summary::after { transform: rotate(45deg); }
#zahi-home .z-faqi > div { padding: 0 22px 20px; color: var(--z-ink-soft); line-height: 1.85; }

/* ============================ FINAL CTA ============================ */
#zahi-home .z-final {
  position: relative; overflow: hidden; text-align: center; color: var(--z-cream);
  background:
    radial-gradient(100% 120% at 50% 0%, #33502f 0%, transparent 55%),
    linear-gradient(160deg, var(--z-green-900), #1a2410);
  padding: 90px 22px;
}
#zahi-home .z-final::after {
  content:""; position: absolute; inset: 0;
  background-image: radial-gradient(rgba(200,160,77,.14) 1px, transparent 1px);
  background-size: 24px 24px; opacity: .55;
}
#zahi-home .z-final__in { position: relative; z-index: 2; max-width: 640px; margin-inline: auto; }
#zahi-home .z-final h2 { font-weight: 900; font-size: clamp(1.8rem,4vw,2.8rem); margin-bottom: 16px; line-height: 1.3; }
#zahi-home .z-final h2 .g { color: var(--z-gold); }
#zahi-home .z-final p { color: rgba(255,248,237,.82); font-size: 1.1rem; margin-bottom: 30px; }

/* ============================ FOOTER ============================ */
#zahi-home .z-foot { background: var(--z-green-900); color: rgba(255,248,237,.8); padding: 56px 0 26px; }
#zahi-home .z-foot__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 34px; }
#zahi-home .z-foot__grid h5 { color: var(--z-gold); font-size: .95rem; font-weight: 800; margin-bottom: 16px; letter-spacing: .04em; }
#zahi-home .z-foot__grid a { display: block; padding: 5px 0; color: rgba(255,248,237,.78); transition: color .2s; font-size: .93rem; }
#zahi-home .z-foot__grid a:hover { color: var(--z-gold-soft); }
#zahi-home .z-foot__brand p { font-size: .92rem; line-height: 1.85; margin: 14px 0 18px; max-width: 280px; }
#zahi-home .z-foot__social { display: flex; gap: 12px; }
#zahi-home .z-foot__social a {
  width: 40px; height: 40px; border-radius: 50%; display: grid; place-items: center;
  background: rgba(255,248,237,.08); border: 1px solid rgba(255,248,237,.16); padding: 0;
}
#zahi-home .z-foot__social a:hover { background: var(--z-gold); color: var(--z-green-900); border-color: var(--z-gold); }
#zahi-home .z-foot__social svg { width: 19px; height: 19px; }
#zahi-home .z-foot__bottom {
  margin-top: 40px; padding-top: 22px; border-top: 1px solid rgba(255,248,237,.14);
  display: flex; justify-content: space-between; gap: 14px; flex-wrap: wrap;
  font-size: .85rem; color: rgba(255,248,237,.6);
}

/* ============================ REVEAL ANIM ============================ */
/* Visible by DEFAULT — content can never get stuck hidden if JS is stripped,
   delayed, or the scroll observer misbehaves inside Salla. The hidden/animated
   state only applies once JS opts in by adding .zr-on to #zahi-home. */
#zahi-home .z-rise { opacity: 1; transform: none; }
#zahi-home.zr-on .z-rise { opacity: 0; transform: translateY(24px); transition: opacity .7s ease, transform .7s cubic-bezier(.2,.8,.2,1); }
#zahi-home.zr-on .z-rise.in { opacity: 1; transform: none; }

/* ============================ RESPONSIVE ============================ */
@media (max-width: 1000px) {
  #zahi-home .z-grid { grid-template-columns: repeat(3,1fr); }
  #zahi-home .z-oils { grid-template-columns: repeat(4,1fr); }
  #zahi-home .z-trust__in { grid-template-columns: repeat(3,1fr); gap: 16px; }
}

/* ---- tablet / large phone ---- */
@media (max-width: 820px) {
  #zahi-home .z-hero__in { grid-template-columns: 1fr; gap: 32px; text-align: center; padding: 40px 22px 56px; }
  #zahi-home .z-hero__actions, #zahi-home .z-hero__stats { justify-content: center; }
  #zahi-home .z-hero p.lead { margin-inline: auto; }
  #zahi-home .z-hero__card { transform: none; }      /* drop the tilt so it never clips screen edges */
  #zahi-home .z-grid { grid-template-columns: repeat(2,1fr); }
  #zahi-home .z-oils { grid-template-columns: repeat(3,1fr); }
  #zahi-home .z-bundle { grid-template-columns: 1fr; }
  #zahi-home .z-bundle__pic { min-height: 240px; order: -1; }
  #zahi-home .z-bundle__txt { padding: 34px 28px; }
  #zahi-home .z-steps { grid-template-columns: 1fr; gap: 22px; }
  #zahi-home .z-reviews { grid-template-columns: 1fr; }
}

/* ---- phone ---- */
@media (max-width: 560px) {
  #zahi-home { font-size: 15px; }
  #zahi-home section.z-sec { padding: 46px 0; }
  #zahi-home .z-wrap { padding-inline: 16px; }
  #zahi-home .z-announce { font-size: .78rem; padding: 9px 12px; line-height: 1.6; }

  #zahi-home .z-hero__in { padding: 30px 18px 46px; gap: 28px; }
  #zahi-home .z-hero__badge { font-size: .78rem; padding: 6px 13px; }
  #zahi-home .z-hero h1 { font-size: clamp(1.85rem, 8.5vw, 2.4rem); margin: 14px 0 14px; }
  #zahi-home .z-hero p.lead { font-size: 1rem; margin-bottom: 22px; }
  #zahi-home .z-hero__actions { flex-direction: column; gap: 11px; width: 100%; }
  #zahi-home .z-hero__actions .z-btn { width: 100%; justify-content: center; }
  #zahi-home .z-hero__stats { gap: 14px; margin-top: 26px; }
  #zahi-home .z-stat .n { font-size: 1.32rem; }
  #zahi-home .z-stat .l { font-size: .74rem; }
  #zahi-home .z-hero__card { max-width: 340px; }

  #zahi-home .z-trust__in { grid-template-columns: repeat(2,1fr); gap: 13px 14px; padding: 18px 16px; }
  #zahi-home .z-trust__i { font-size: .85rem; justify-content: flex-start; }
  #zahi-home .z-trust__i svg { width: 22px; height: 22px; }

  #zahi-home .z-h2 { font-size: clamp(1.5rem, 6.6vw, 2rem); }
  #zahi-home .z-sub { font-size: .95rem; }
  #zahi-home .z-sechead { margin-bottom: 30px; }

  #zahi-home .z-grid { grid-template-columns: repeat(2,1fr); gap: 12px; }
  #zahi-home .z-oils { grid-template-columns: repeat(2,1fr); gap: 12px; }
  #zahi-home .z-card__body { padding: 13px 13px 15px; }
  #zahi-home .z-card__body h3 { font-size: .94rem; }
  #zahi-home .z-card__body p { font-size: .8rem; margin-bottom: 12px; }
  #zahi-home .z-card__price .now { font-size: 1.1rem; }
  #zahi-home .z-card .z-btn { font-size: .86rem; padding: 11px 10px; }
  /* native Salla add-to-cart buttons: match the smaller card buttons on phones */
  #zahi-home salla-add-product-button button,
  #zahi-home salla-add-product-button .s-button-element { padding: 11px 12px !important; font-size: .85rem !important; }
  #zahi-home salla-add-product-button:not(.hydrated) { padding: 11px 12px; font-size: .85rem; }
  #zahi-home .z-oil { padding: 18px 12px; }
  #zahi-home .z-oil .ic { width: 48px; height: 48px; }

  #zahi-home .z-bundle__txt { padding: 30px 22px; }
  #zahi-home .z-step .num { width: 56px; height: 56px; font-size: 1.5rem; }
  #zahi-home .z-rev { padding: 22px 20px; }
  #zahi-home .z-faqi summary { padding: 15px 18px; font-size: .98rem; }
  #zahi-home .z-final { padding: 64px 18px; }
}

/* ---- very small phone ---- */
@media (max-width: 360px) {
  #zahi-home .z-trust__in { grid-template-columns: 1fr; }
}