/* ===========================================================================
   Components — nav, hero, cards, tape, torn dividers, app module, footer,
   forms, blog. Ported from the approved Home reference.
   =========================================================================== */

/* ---------- Layout helpers ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter)}
.wrap-content{max-width:var(--maxw-content);margin:0 auto;padding-inline:var(--gutter)}
.section{position:relative;padding-block:56px}
.section--paper{background:var(--paper)}
.section--forest{background:var(--forest);overflow:hidden}
.section--deep{background:var(--forest-deep);overflow:hidden}
.section--sage{background:var(--sage)}
.relative{position:relative}
.texture{position:absolute;inset:0;background-image:var(--emboss);background-size:600px;opacity:.9;pointer-events:none}
.texture--soft{opacity:.62}
.grain{position:absolute;inset:0;background-image:var(--grain);opacity:.1;mix-blend-mode:overlay;pointer-events:none}

/* ---------- Buttons / tape ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:800;font-size:15px;border-radius:var(--r-pill);text-decoration:none;cursor:pointer;border:0;line-height:1}
.btn--lime{background:var(--lime);color:var(--forest);padding:12px 22px}
.btn--forest{background:var(--forest);color:#fff;padding:14px 26px}
.btn--sm{padding:9px 16px;font-size:14px}
.link-underline{color:var(--forest);font-weight:800;font-size:15px;border-bottom:3px solid var(--lime);padding-bottom:2px}

.tape{
  position:relative;display:inline-block;color:var(--forest);font-weight:800;
  padding:9px 20px;white-space:nowrap;transform:rotate(-2.5deg);
  background:
    repeating-linear-gradient(90deg, rgba(6,60,45,.06) 0 1px, transparent 1px 6px),
    linear-gradient(180deg,#eaff66,#d3f400);
  -webkit-mask:var(--tape-edge);mask:var(--tape-edge);
  -webkit-mask-size:100% 100%;mask-size:100% 100%;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;
  filter:drop-shadow(0 5px 5px rgba(0,0,0,.28));
}
.tape::before{content:"";position:absolute;inset:0;background:linear-gradient(115deg,rgba(255,255,255,.55),transparent 42%);pointer-events:none}

/* ---------- Eyebrow / section header ---------- */
.eyebrow{font-weight:800;font-size:13px;letter-spacing:.08em;text-transform:uppercase}
.eyebrow--teal{color:var(--teal)}
.eyebrow--lime{color:var(--lime)}
.eyebrow--green{color:#3c6b53}
.eyebrow-dot{display:inline-flex;align-items:center;gap:8px;color:var(--lime);font-weight:700;font-size:13.5px;letter-spacing:.04em;text-transform:uppercase}
.eyebrow-dot i{width:8px;height:8px;border-radius:50%;background:var(--lime);animation:pulse 2s infinite}
.section-header h2{font-weight:900;font-size:clamp(28px,4.4vw,46px);margin-top:8px}
.section-header p{margin-top:12px;font-size:16px;line-height:1.55}
.pill-label{display:inline-block;background:var(--forest);color:#fff;font-weight:700;font-size:12px;letter-spacing:.08em;text-transform:uppercase;padding:6px 14px;border-radius:var(--r-pill)}

/* ---------- NAV ---------- */
.nav{position:fixed;top:0;inset-inline:0;z-index:60;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px var(--gutter);transition:background .3s ease,box-shadow .3s ease,padding .3s ease}
.nav.is-stuck{background:rgba(6,60,45,.96);box-shadow:0 6px 24px rgba(0,0,0,.22);padding-block:11px}
.nav__brand{display:flex;align-items:center;gap:10px}
.nav__brand span{font-weight:800;font-size:22px;color:#fff;letter-spacing:-.5px}
.nav__links{display:flex;gap:clamp(14px,1.8vw,26px);align-items:center}
.nav__links ul{display:flex;gap:clamp(14px,1.8vw,26px);align-items:center;list-style:none;margin:0;padding:0}
.nav__links a{color:rgba(255,255,255,.86);font-weight:600;font-size:14.5px;white-space:nowrap}
.nav__links a:hover{color:#fff}
.mobile-menu ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}
.nav__right{display:flex;align-items:center;gap:10px}
.nav__burger{display:none;align-items:center;justify-content:center;width:40px;height:40px;border-radius:11px;border:0;background:rgba(255,255,255,.12);cursor:pointer}
.lang-pill{display:flex;background:rgba(255,255,255,.12);border-radius:var(--r-pill);padding:3px}
.lang-pill a,.lang-pill span{border:0;cursor:pointer;background:transparent;color:#fff;font-weight:800;font-size:12.5px;padding:5px 12px;border-radius:var(--r-pill)}
.lang-pill .is-active{background:var(--lime);color:var(--forest)}

.mobile-menu{display:none;position:fixed;top:74px;inset-inline:12px;z-index:59;background:rgba(6,60,45,.98);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:12px;box-shadow:0 20px 50px rgba(0,0,0,.4);flex-direction:column}
.mobile-menu.is-open{display:flex}
.mobile-menu a{color:#fff;font-weight:600;font-size:16px;padding:13px 12px;border-radius:10px}

@media(max-width:920px){
  .nav__links{display:none}
  .nav__burger{display:inline-flex}
}

/* ---------- HERO ---------- */
.hero{position:relative;overflow:hidden;padding:118px var(--gutter) 70px}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:40px;position:relative;max-width:var(--maxw);margin:0 auto;z-index:3;padding-top:30px}
.hero h1{color:#fff;font-weight:900;font-size:clamp(38px,6.4vw,72px);line-height:1.02}
.hero h1 .hl{color:var(--forest);background:var(--lime);padding:0 12px;border-radius:4px;-webkit-box-decoration-break:clone;box-decoration-break:clone;white-space:nowrap}
.hero__sub{color:rgba(255,255,255,.8);font-size:clamp(16px,2vw,20px);line-height:1.55;margin-top:22px;max-width:480px}
.hero__rating{display:flex;align-items:center;gap:8px;margin-top:18px;color:rgba(255,255,255,.7);font-size:13px}
.hero__rating .stars{color:var(--lime);letter-spacing:1px}
.hero__radial{position:absolute;inset:0;background:radial-gradient(120% 70% at 12% 4%,rgba(255,255,255,.07),transparent 55%),radial-gradient(90% 90% at 95% 100%,rgba(0,0,0,.5),transparent 60%);pointer-events:none}

.sale-marquee{position:absolute;top:60px;inset-inline:-30px;transform:rotate(-2deg);z-index:2;pointer-events:none}
.sale-marquee__track{background:var(--lime);overflow:hidden;filter:var(--sh-tape-lg);clip-path:polygon(0 10%,100% 0,100% 90%,0 100%)}
.sale-marquee__track div{display:inline-flex;white-space:nowrap;padding:7px 0;animation:marq 18s linear infinite}
.sale-marquee__track span{color:var(--forest);font-weight:800;font-size:13.5px;letter-spacing:.05em}
/* RTL: scroll the tape the other way (rightward) so it reads right-to-left */
.rtl .sale-marquee{transform:rotate(2deg)}
.rtl .sale-marquee__track div{animation-direction:reverse}
/* RTL: Arabic glyphs are taller — loosen heading leading so stacked lines don't
   overlap the tape (which sits at z-index:-1 behind all heading text). */
.rtl .story__panel h1,.rtl .story__panel h2{line-height:1.4}

/* hero collage */
.collage{position:relative;display:flex;justify-content:center;min-height:430px}
.collage .sticker{position:absolute;z-index:4;background:#fff;border:4px solid #fff;box-shadow:var(--sh-float);display:flex;align-items:center;justify-content:center}
.collage .s-avocado{top:-14px;inset-inline-start:-22px;width:84px;height:84px;border-radius:18px;font-size:40px;transform:rotate(-9deg);animation:floaty 4s ease-in-out infinite}
.collage .s-lotion{top:40%;inset-inline-end:-10px;width:78px;height:78px;border-radius:50%;font-size:36px;transform:rotate(8deg);animation:floaty2 5s ease-in-out infinite}
.collage .s-choc{bottom:14px;inset-inline-start:8px;width:74px;height:74px;border-radius:16px;font-size:34px;transform:rotate(7deg);animation:floaty 4.6s ease-in-out infinite}
.collage .price-tape{position:absolute;top:24%;inset-inline-end:6px;z-index:5;font-size:13px;padding:7px 13px}

.phone{position:relative;z-index:3;width:clamp(228px,72vw,288px);aspect-ratio:9/18.6;background:#0b0b0b;border-radius:40px;padding:9px;box-shadow:var(--sh-phone);transform:rotate(-2deg)}
.phone__screen{position:relative;width:100%;height:100%;border-radius:31px;overflow:hidden;background:#fff}
.phone__top{position:relative;background:var(--forest);padding:18px 14px 8px}
.phone__brandrow{position:relative;display:flex;align-items:center;justify-content:space-between}
.phone__brandrow span:first-child{color:#fff;font-weight:800;font-size:15px}
.phone__badge{background:var(--lime);color:var(--forest);font-weight:800;font-size:10px;padding:3px 8px;border-radius:var(--r-pill)}
.phone__loc{position:relative;margin-top:11px;background:rgba(255,255,255,.16);border-radius:9px;padding:7px 10px;color:#dff0e7;font-size:11px}
.phone__cats{display:grid;grid-template-columns:repeat(4,1fr);gap:7px}
.phone__cats div{background:var(--sage);border-radius:12px;padding:9px 0;text-align:center;font-size:20px}
.phone__item{margin-top:11px;display:flex;align-items:center;gap:9px;border:1px solid #eee;border-radius:13px;padding:8px}
.phone__item .thumb{width:42px;height:42px;background:#F3F3F3;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:23px}
.phone__co{margin-top:10px;background:var(--forest);color:#fff;text-align:center;font-weight:800;font-size:13px;padding:11px;border-radius:13px}
.price-now{font-weight:900;font-size:16px;color:var(--forest)}
.price-was{font-size:11px;color:#bbb;text-decoration:line-through}

@media(max-width:920px){.hero__grid{grid-template-columns:1fr;gap:28px}}

/* ---------- Sticky phone story (super-app → grocery → food) ---------- */
/* overflow-x:clip contains the rotated marquee WITHOUT breaking position:sticky
   (plain overflow:hidden would disable the sticky phone). */
/* isolation:isolate makes .story its own stacking context so the sticky colour
   backdrop (z-index:2) can't paint past the section over the torn divider / next
   section below it (which caused a black overhang after the last slide). */
.story{position:relative;background:var(--forest);overflow-x:clip;isolation:isolate}
/* Native page scroll: each slide is a full-viewport block and the phone is
   pinned with position:sticky against the page (NOT a nested scroll container).
   Snapping is done at the PAGE level (html, below) instead of inside a nested
   scroll-snap deck — that nested deck used to trap the viewport when scrolling
   back up into the section. Page-level snap keeps the per-slide lock without
   the trap. */
.story__deck{position:relative;z-index:3}
/* Scrolling is fully native — CSS scroll-snap (set on the page, in base.css)
   makes each slide a snap point, so you can scroll freely and it settles on a
   slide. No wheel hijacking / lock (that needed a click between scrolls and
   could skip a slide). The phone screen + backdrop colour follow via the
   IntersectionObserver in phone-story.js. */
.story__panel{scroll-snap-align:start}
/* Pinned phone overlay — zero-height sticky so it never adds scroll length. */
.story__stage{position:sticky;top:0;height:0;z-index:5;pointer-events:none}
.story__phone{position:absolute;top:50vh;transform:translateY(-50%);width:clamp(240px,26vw,290px);inset-inline-end:max(var(--gutter),calc((100vw - var(--maxw-content)) / 2));pointer-events:auto}
/* Soft light behind the phone — only on a dark slide (.is-darkbg), so the dark
   phone edges read against e.g. the black Rabbit+ background. Off on green. */
.story__phone::before,.panel-phone::before{content:"";position:absolute;z-index:-1;inset:-48% -60%;background:radial-gradient(closest-side,rgba(255,255,255,.6),rgba(255,255,255,.26) 52%,rgba(255,255,255,.08) 72%,transparent 90%);filter:blur(26px);opacity:0;transition:opacity .55s var(--ease);pointer-events:none}
.story.is-darkbg .story__phone::before,.story.is-darkbg .panel-phone::before{opacity:1}
.story__progress{position:absolute;inset-inline-start:50%;transform:translateX(-50%);bottom:-34px;display:flex;gap:8px}
.story__dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.25);transition:background .3s var(--ease),width .3s var(--ease)}
.story__dot.is-active{background:var(--lime);width:22px;border-radius:6px}
.story__panel{height:100vh;display:flex;align-items:center;padding:88px max(var(--gutter), calc((100vw - var(--maxw-content)) / 2)) 24px;position:relative}
/* Panels are transparent; the colour comes from the .story__bg backdrop so it
   can cross-fade between slides. Keep panel content above that backdrop. */
.story__panel>*{position:relative;z-index:1}
/* Cross-fading colour backdrop. Pinned for the whole story; the JS sets its
   colour to the active slide's data-bg (empty = transparent, so the section's
   green crumpled texture shows). The transition makes green↔black smooth. */
/* Zero-height sticky (like .story__stage) so it adds NO scroll length; a pinned
   100vh pseudo carries the colour, cross-faded via the --story-bgc variable the
   JS sets per active slide (empty = transparent → green texture shows). */
.story__bg{position:sticky;top:0;height:0;z-index:2;pointer-events:none}
.story__bg::before{content:"";position:absolute;top:0;left:0;width:100%;height:100vh;background-color:var(--story-bgc,transparent);transition:background-color .55s var(--ease)}
.story__bg::after{content:"";position:absolute;top:0;left:0;width:100%;height:100vh;background-image:var(--grain);background-size:200px;opacity:0;mix-blend-mode:overlay;transition:opacity .55s var(--ease)}
/* Grain only over a custom solid colour (e.g. black slide); not over the green
   section, which already carries its own texture. */
.story__bg.is-colored::after{opacity:.5}
.story__copy{max-width:520px}
.story__panel h1{color:#fff;font-weight:900;font-size:clamp(38px,5.4vw,64px);line-height:1.03;letter-spacing:-.02em}
.story__panel h2{color:#fff;font-weight:900;font-size:clamp(30px,4.6vw,52px);line-height:1.04;letter-spacing:-.02em}
.story__chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:22px}
.story__chip{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);color:#dff0e7;font-size:13px;font-weight:600;padding:7px 14px;border-radius:var(--r-pill)}
.panel-phone{display:none;margin-top:28px;width:clamp(230px,78vw,280px);position:relative;isolation:isolate}

/* Tape-style highlight (matches the lime tape: gradient + adhesive lines + torn
   ends + sheen) painted BEHIND the text via ::before so glyphs are never clipped. */
.hl{position:relative;color:var(--forest);padding:0 14px;white-space:nowrap;-webkit-box-decoration-break:clone;box-decoration-break:clone}
.hl::before{content:"";position:absolute;inset:-3px -2px;z-index:-1;
  background:repeating-linear-gradient(90deg, rgba(6,60,45,.06) 0 1px, transparent 1px 6px), linear-gradient(180deg,#eaff66,#d3f400);
  -webkit-mask:var(--tape-edge);mask:var(--tape-edge);-webkit-mask-size:100% 100%;mask-size:100% 100%;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;
  filter:drop-shadow(0 3px 3px rgba(0,0,0,.18));transform:rotate(-1deg)}
.hl::after{content:"";position:absolute;inset:-3px -2px;z-index:-1;pointer-events:none;
  background:linear-gradient(115deg,rgba(255,255,255,.5),transparent 45%);
  -webkit-mask:var(--tape-edge);mask:var(--tape-edge);-webkit-mask-size:100% 100%;mask-size:100% 100%;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;transform:rotate(-1deg)}

/* swappable screens inside the phone */
.story__phone .phone__screen{height:100%}
/* Native-style screen push: the incoming screen slides in from the leading edge
   and sits on top; the outgoing one parallax-dims to the opposite edge — like
   navigating between sections in a real app. Scroll direction sets data-dir on
   .story__phone (fwd = next screen, back = previous). */
.scr{position:absolute;inset:0;opacity:0;overflow:hidden;background:#fff;
  transform:translateX(100%);
  transition:opacity .3s ease, transform .5s cubic-bezier(.22,.61,.36,1);
  will-change:transform,opacity;pointer-events:none;backface-visibility:hidden}
.scr.is-active{opacity:1;transform:none;z-index:3;pointer-events:auto}
.scr.is-leaving{opacity:0;z-index:2;transform:translateX(-26%) scale(.99)}
/* Directional idle/exit must NOT override .is-active (which stays at transform:none),
   so the incoming screen is always on-stage — scrolled up or down. */
.story__phone[data-dir="back"] .scr:not(.is-active):not(.is-leaving){transform:translateX(-100%)}
.story__phone[data-dir="back"] .scr.is-leaving{transform:translateX(26%) scale(.99)}

/* Each slide's copy pops in when it becomes the current slide. */
.story__copy{transition:opacity .6s var(--ease), transform .7s var(--pop)}
@media(min-width:921px){
  .story.is-ready .story__panel:not(.is-current) .story__copy{opacity:0;transform:translateY(34px)}
  .story.is-ready .story__panel.is-current .story__copy{opacity:1;transform:none}
}

/* ---------- Icons exploding from BEHIND the phone, in every direction ---------- */
.fly{position:absolute;inset:0;pointer-events:none;z-index:1;display:none;overflow:visible} /* z-index:1 = behind the phone */
.story__phone[data-active="1"] .fly--grocery,
.story__phone[data-active="2"] .fly--food{display:block}
.fly > span{position:absolute;left:50%;top:50%;margin:-34px 0 0 -34px;width:68px;height:68px;border-radius:16px;background:#fff;
  display:flex;align-items:center;justify-content:center;font-size:40px;line-height:1;opacity:0;
  box-shadow:0 6px 14px rgba(0,0,0,.18);
  animation-name:flyout;animation-timing-function:var(--ease);animation-iteration-count:infinite}
@keyframes flyout{
  0%{opacity:0;transform:translate(0,0) rotate(0) scale(.4)}
  9%{opacity:1}
  55%{opacity:1}                 /* hold, then a long gentle fade-out */
  100%{opacity:0;transform:translate(var(--fx),var(--fy)) rotate(var(--fr)) scale(1.12)}
}
/* image icons (when an icon value is an image URL instead of an emoji) */
.rb-ico{width:1.25em;height:1.25em;object-fit:contain;display:inline-block;vertical-align:-0.2em}
.fly > span .rb-ico{width:60px;height:60px}

/* ---------- Tape stuck on the phone ---------- */
.phone-tape{position:absolute;z-index:7;top:46px;inset-inline-end:-16px;font-size:13px}

@media (prefers-reduced-motion:reduce){
  .fly{display:none!important}
  .scr{transform:none!important;transition:opacity .25s linear}
  .story__copy{opacity:1!important;transform:none!important}
  .story__deck{scroll-behavior:auto}
  .story__bg::before,.story__bg::after{transition:none}
}
.scr__top{position:relative;background:var(--forest);padding:15px 12px 9px}
.scr__top .texture{opacity:.6;background-size:200px}
.scr__brandrow{position:relative;display:flex;align-items:center;justify-content:space-between}
.scr__brandrow b{color:#fff;font-weight:800;font-size:14px}
.scr__loc{position:relative;margin-top:9px;background:rgba(255,255,255,.16);border-radius:8px;padding:6px 9px;color:#dff0e7;font-size:10.5px}
.scr__search{position:relative;margin-top:8px;background:#fff;border-radius:9px;padding:7px 11px;color:#9bb0a4;font-size:10.5px}
.scr__body{padding:10px;display:flex;flex-direction:column;gap:8px}
.scr-tiles{display:grid;grid-template-columns:1fr 1fr;gap:7px}
.scr-tile{background:var(--sage);border-radius:13px;padding:11px}
.scr-tile .ic{font-size:22px}
.scr-tile .t{font-weight:800;color:var(--forest);font-size:11.5px;margin-top:4px}
.scr-tile .s{color:#5d7d6c;font-size:9px;font-weight:600;margin-top:1px}
.scr-row{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
.scr-row div{background:var(--sage);border-radius:10px;padding:8px 0;text-align:center;font-size:17px}
.scr-item{display:flex;align-items:center;gap:8px;border:1px solid #eee;border-radius:11px;padding:6px}
.scr-item .th{width:36px;height:36px;background:#F3F3F3;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:19px}
.scr-item .nm{font-weight:700;font-size:11px;color:#1a1a1a}
.scr-item .pr{display:flex;align-items:center;gap:5px;margin-top:1px}
.scr-item .add{width:24px;height:24px;background:var(--lime);border-radius:7px;display:flex;align-items:center;justify-content:center;font-weight:900;color:var(--forest);font-size:14px}
.scr-co{background:var(--forest);color:#fff;text-align:center;font-weight:800;font-size:12px;padding:10px;border-radius:11px}
.scr-rests{display:flex;gap:6px}
.scr-rest{flex:1;background:var(--sage);border-radius:11px;padding:10px 4px;text-align:center}
.scr-rest .ic{font-size:20px}
.scr-rest .n{font-weight:700;color:var(--forest);font-size:9px;margin-top:3px}
.scr-pill{background:#fff;color:var(--forest);font-weight:800;font-size:10px;border-radius:8px;padding:3px 8px}

/* Subscription (Rabbit+) screen */
.scr-sub{background:linear-gradient(135deg,var(--forest),#0a5740);border-radius:14px;padding:13px;color:#fff;text-align:center}
.scr-sub__badge{display:inline-block;background:var(--lime);color:var(--forest);font-weight:900;font-size:11px;padding:3px 11px;border-radius:var(--r-pill)}
.scr-sub__head{font-weight:800;font-size:12.5px;margin-top:8px;line-height:1.3}
.scr-sub__perks{margin-top:11px;display:flex;flex-direction:column;gap:7px}
.scr-perk{display:flex;align-items:center;gap:8px;background:var(--sage);border-radius:11px;padding:9px 11px;font-weight:700;color:var(--forest);font-size:11px;text-align:start}
.scr-perk .ic{font-size:16px;flex:0 0 auto}
/* Image (screenshot) screen — a slide can override the built-in layout */
.scr--img{background:#fff;padding:0}
.scr--img img{width:100%;height:100%;object-fit:cover;display:block}

@media(max-width:920px){
  .story{height:auto}
  .story__deck{height:auto;overflow:visible}
  .story__stage{display:none}
  .story__panel{height:auto;display:block;padding-block:46px}
  .story__copy{max-width:none;opacity:1!important;transform:none!important}
  .panel-phone{display:block;position:relative}
  .panel-phone .phone__screen{height:auto}
  .panel-phone .scr{position:relative;opacity:1;transform:none}
  .panel-phone .fly{display:block}
}

/* ---------- App download module ---------- */
.app-badges{display:flex;gap:10px;flex-wrap:wrap}
.app-badge{display:inline-flex;align-items:center;gap:9px;background:#000;color:#fff;border-radius:13px;padding:9px 15px;border:1px solid rgba(255,255,255,.18)}
.app-badge small{font-size:9px;opacity:.85}
.app-badge b{font-size:15px;font-weight:700}
.app-badge .col{display:flex;flex-direction:column;line-height:1.05;align-items:flex-start}
.app-row{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:30px}
.app-row--center{justify-content:center}
.qr-wrap{display:flex;align-items:center;gap:11px}
.qr-box{width:70px;height:70px;background:#fff;border-radius:12px;padding:6px;box-shadow:0 8px 20px rgba(0,0,0,.3)}
.qr-box img{width:100%;height:100%;display:block;object-fit:contain;border-radius:6px}
.qr-wrap span{color:rgba(255,255,255,.65);font-size:12.5px;max-width:80px;line-height:1.3}
.app-band{position:relative;text-align:center}
.app-band .app-badges{justify-content:center;margin-top:26px}
@media(max-width:920px){.qr-wrap{display:none}}

/* ---------- Trust / stats / press ---------- */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:14px}
.stat{background:#fff;border-radius:18px;padding:22px 16px;text-align:center;border:1px solid var(--card-border)}
.stat__num{font-weight:900;font-size:clamp(24px,3vw,32px);color:var(--forest);line-height:1}
.stat__label{color:var(--gray-500);font-size:13px;font-weight:600;margin-top:8px}
.press{display:flex;align-items:center;justify-content:center;gap:clamp(18px,4vw,46px);flex-wrap:wrap}
.press__lead{color:#9a968d;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}
.press span.logo{color:var(--forest);opacity:.55;font-weight:800;font-size:clamp(15px,2vw,20px)}
.factual{font-weight:600;font-size:clamp(20px,3vw,30px);line-height:1.42;color:var(--forest);max-width:880px;margin:0 auto;text-wrap:pretty}

/* ---------- Cards: steps / categories / pillars ---------- */
.grid-auto{display:grid;gap:16px}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.grid-4{grid-template-columns:repeat(auto-fit,minmax(230px,1fr))}
.grid-cats{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px}

.step{position:relative;background:#fff;border-radius:var(--r-card-lg);padding:26px;border:1px solid var(--card-border)}
.step__head{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.step__n{width:42px;height:42px;border-radius:13px;background:var(--forest);color:var(--lime);font-weight:900;font-size:18px;display:flex;align-items:center;justify-content:center}
.step__icon{font-size:34px}
.step h3{font-weight:800;font-size:20px}
.step p{color:var(--muted);font-size:15px;line-height:1.55;margin-top:8px}

.cat{background:var(--sage);border-radius:var(--r-card);padding:24px 16px;text-align:center;transition:transform .25s var(--ease)}
.cat:hover{transform:translateY(-6px)}
.cat__icon{font-size:46px;line-height:1}
.cat__label{font-weight:800;color:var(--forest);font-size:15px;margin-top:12px}

.pillar{background:#fff;border-radius:var(--r-card-lg);padding:26px;border:1px solid var(--card-border)}
.pillar__icon{width:54px;height:54px;border-radius:15px;background:var(--sage);display:flex;align-items:center;justify-content:center;font-size:28px;margin-bottom:16px}
.pillar h3{font-weight:800;font-size:19px}
.pillar p{color:var(--muted);font-size:14.5px;line-height:1.55;margin-top:8px}

/* ---------- Company teaser ---------- */
.co-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:36px;align-items:center;position:relative}
.co-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.co-stat{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:22px}
.co-stat__num{font-weight:900;font-size:30px;letter-spacing:-.02em;color:#fff}
.co-stat__num.lime{color:var(--lime)}
.co-stat__label{color:rgba(255,255,255,.66);font-size:13px;margin-top:6px}
.co-copy h2{color:#fff}
.co-copy p{color:rgba(255,255,255,.72);font-size:16px;line-height:1.6;margin-top:16px;max-width:480px}

/* ---------- Careers teaser ---------- */
.careers-teaser{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
.careers-teaser h2{color:var(--forest)}
.careers-teaser p{color:#3c6b53;font-size:16px;line-height:1.6;margin-top:14px}

/* ---------- FAQ ---------- */
.faq-list{display:flex;flex-direction:column;gap:12px}
.faq-item{background:#fff;border:1px solid var(--card-border);border-radius:16px;padding:20px 22px}
.faq-item__row{display:flex;align-items:flex-start;gap:12px}
.faq-item__q{color:var(--lime);background:var(--forest);width:26px;height:26px;border-radius:8px;flex:none;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:14px}
.faq-item h3{font-weight:800;font-size:17px}
.faq-item p{color:var(--muted);font-size:15px;line-height:1.55;margin-top:6px}
.faq-item--toggle .faq-item__a{display:none;padding-inline-start:38px}
.faq-item--toggle.is-open .faq-item__a{display:block}
.faq-item--toggle .faq-item__row{cursor:pointer}

/* ---------- Download band ---------- */
.dl-band h2{color:#fff;font-weight:900;font-size:clamp(28px,4.6vw,48px)}
.dl-band p{color:rgba(255,255,255,.72);font-size:16px;margin-top:14px}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:rgba(255,255,255,.66);padding:54px var(--gutter) 120px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:34px;max-width:var(--maxw-content);margin:0 auto}
.foot-brand{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.foot-brand span{font-weight:800;font-size:20px;color:#fff}
.site-footer p{font-size:14px;line-height:1.6;max-width:260px}
.foot-col h4{color:#fff;font-weight:800;font-size:14px;margin-bottom:14px}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:9px;font-size:14px}
.foot-col a:hover{color:#fff}
.foot-bottom{max-width:var(--maxw-content);margin:34px auto 0;padding-top:22px;border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:13px}
@media(max-width:920px){.foot-grid{grid-template-columns:1fr 1fr;gap:26px}}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}}

/* ---------- Mobile sticky download bar ---------- */
.mobile-dlbar{display:none;position:fixed;bottom:0;inset-inline:0;z-index:70;background:var(--lime);padding:10px 14px calc(10px + env(safe-area-inset-bottom));align-items:center;justify-content:space-between;gap:10px;box-shadow:0 -6px 22px rgba(0,0,0,.22)}
.mobile-dlbar span{color:var(--forest);font-weight:800;font-size:14px;line-height:1.15}
.mobile-dlbar .icons{display:flex;gap:7px}
.mobile-dlbar .icons a{width:38px;height:38px;border-radius:10px;background:#000;display:flex;align-items:center;justify-content:center}
@media(max-width:760px){.mobile-dlbar{display:flex}}

/* ---------- Torn divider ---------- */
.torn{line-height:0;position:relative;z-index:1;overflow:hidden}
.torn .texture{z-index:0}
/* Dividers are all authored upper-fill (torn sheet on top, torn BOTTOM edge) and
   never flipped, so the drop-shadow always casts DOWN onto the layer below =
   ripped-paper depth, correct for every divider. No SVG filter, so the shadow is
   clean (no speckles). */
.torn svg{display:block;position:relative;z-index:1;width:100%;height:74px;filter:drop-shadow(0 5px 5px rgba(0,0,0,.32))}
/* Green crumple texture laid over the divider's green region only (clipped to the
   exact torn edge) so its colour matches the textured green sections. */
.torn__tex{position:absolute;inset:0;z-index:2;background-image:var(--emboss);background-size:600px;opacity:.9;pointer-events:none}
.torn__tex--sheet{clip-path:url(#tornSheetClip)}
.torn__tex--below{clip-path:url(#tornBelowClip)}

/* ---------- Forms (Fluent Forms / native) ---------- */
.rb-form{max-width:620px;margin:0 auto}
.rb-form .ff-el-group,.rb-form p{margin-bottom:14px}
.rb-form label{font-weight:700;font-size:14px;color:var(--forest);display:block;margin-bottom:6px}
/* On dark (forest) sections — e.g. For Brands / For Restaurants — labels must be light */
.section--forest .rb-form label{color:#fff}
.rb-form input,.rb-form textarea,.rb-form select{
  width:100%;background:#fff;border:1px solid var(--card-border);border-radius:var(--r-input);
  padding:13px 15px;font-family:inherit;font-size:15px;color:var(--ink)
}
.rb-form input:focus,.rb-form textarea:focus,.rb-form select:focus{outline:2px solid var(--lime);border-color:var(--lime)}
.rb-form .ff-btn-submit,.rb-form button[type=submit]{background:var(--lime);color:var(--forest);font-weight:800;border:0;border-radius:var(--r-pill);padding:14px 26px;cursor:pointer}
.rb-form-msg{max-width:620px;margin:0 auto 18px;padding:14px 18px;border-radius:var(--r-card);font-weight:700;font-size:15px;line-height:1.45}
.rb-form-msg--ok{background:#e7f6ea;border:1px solid #9fd9ad;color:#0c5a2a}
.rb-form-msg--err{background:#fdeaea;border:1px solid #f1a9a9;color:#9a1f1f}
.contact-channels{display:flex;flex-wrap:wrap;gap:16px;margin-top:20px}
.contact-channels a{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--card-border);border-radius:var(--r-pill);padding:10px 18px;font-weight:700;color:var(--forest)}

/* ---------- Generic page / entry content ---------- */
.entry{max-width:760px;margin:0 auto;color:var(--gray-700);font-size:17px;line-height:1.7}
.entry h1{font-size:clamp(30px,5vw,46px);font-weight:900}
.entry h2{font-size:clamp(24px,3.5vw,32px);font-weight:800;margin-top:1.6em}
.entry h3{font-size:21px;font-weight:700;margin-top:1.4em}
.entry p{margin-top:1em}
.entry a{color:var(--forest);border-bottom:2px solid var(--lime)}
.entry ul,.entry ol{margin:1em 0;padding-inline-start:1.4em}
.entry li{margin-top:.4em}
.entry img{border-radius:var(--r-card);margin:1.4em 0}
.entry blockquote{border-inline-start:4px solid var(--lime);padding-inline-start:18px;margin:1.4em 0;font-style:italic;color:var(--forest)}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{position:relative;overflow:hidden;background:var(--forest);padding:140px var(--gutter) 70px;text-align:center}
.page-hero h1{color:#fff;font-weight:900;font-size:clamp(34px,6vw,64px)}
.page-hero p{color:rgba(255,255,255,.8);font-size:clamp(16px,2vw,20px);line-height:1.55;margin:18px auto 0;max-width:620px}
.breadcrumbs{font-size:13px;color:rgba(255,255,255,.6);margin-bottom:16px}
.breadcrumbs a{border-bottom:1px solid rgba(255,255,255,.3)}

/* ---------- Blog ---------- */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}
.post-card{background:#fff;border:1px solid var(--card-border);border-radius:var(--r-card);overflow:hidden;display:flex;flex-direction:column;transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.post-card:hover{transform:translateY(-4px);box-shadow:var(--sh-card)}
.post-card__thumb{aspect-ratio:16/9;background:var(--sage);overflow:hidden}
.post-card__thumb img{width:100%;height:100%;object-fit:cover}
.post-card__body{padding:20px;display:flex;flex-direction:column;gap:8px;flex:1}
.post-card__cat{align-self:flex-start;background:var(--forest);color:var(--lime);font-weight:700;font-size:11px;letter-spacing:.04em;text-transform:uppercase;padding:4px 10px;border-radius:var(--r-pill)}
.post-card h3{font-weight:800;font-size:18px;color:var(--forest);line-height:1.25}
.post-meta{color:var(--gray-500);font-size:13px;display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.blog-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:28px}
.cat-filter{display:flex;gap:8px;flex-wrap:wrap}
.cat-filter a{font-size:13px;font-weight:700;padding:7px 14px;border-radius:var(--r-pill);background:#fff;border:1px solid var(--card-border);color:var(--forest)}
.cat-filter a.is-active{background:var(--lime);border-color:var(--lime)}

.single-hero{max-width:820px;margin:0 auto;text-align:center}
.single-hero h1{font-size:clamp(30px,5vw,52px);font-weight:900;color:#fff;line-height:1.1}
.single-hero__subtitle{color:var(--lime);font-weight:600;font-size:clamp(17px,2.2vw,21px);line-height:1.45;margin:14px auto 0;max-width:640px}
.single-hero .post-meta{justify-content:center;color:rgba(255,255,255,.7);margin-top:18px}

/* About-the-author card (re-skins the imported Elementor author box) */
.entry .elementor-author-box{display:flex;align-items:center;gap:20px;background:var(--sage);border:1px solid var(--card-border);border-radius:var(--r-card);padding:24px 26px;margin-top:48px;text-align:start}
.entry .elementor-author-box__avatar{flex:none}
.entry .elementor-author-box__avatar img{width:76px;height:76px;border-radius:50%;object-fit:cover;margin:0;display:block;box-shadow:var(--sh-card)}
.entry .elementor-author-box__name{margin:0;font-size:19px;font-weight:800;color:var(--forest);line-height:1.2}
.entry .elementor-author-box__bio{margin-top:6px;color:var(--gray-700);font-size:14.5px;line-height:1.5}
.entry .elementor-author-box__bio p{margin:0}
@media(max-width:520px){
	.entry .elementor-author-box{flex-direction:column;align-items:flex-start;gap:14px}
}
/* Featured image lives inside the green hero and overflows its bottom half past
   the torn edge onto the paper below, so the green extends to ~the image middle.
   --rb-feat-lift = how much of the image hangs below the hero box (≈ bottom half). */
.single-hero-section{overflow:visible;--rb-feat-lift:36%}
.single-featured{max-width:980px;margin:40px auto 0;position:relative;z-index:5;line-height:0}
.single-featured img{display:block;width:100%;height:auto;border-radius:var(--r-card);box-shadow:var(--sh-card);margin-bottom:calc(-1 * var(--rb-feat-lift))}
.single-entry-section{padding-top:clamp(120px,30vw,300px)}
.share-row{display:flex;gap:10px;align-items:center;margin-top:32px}
.share-row a{width:40px;height:40px;border-radius:50%;background:var(--sage);display:flex;align-items:center;justify-content:center;color:var(--forest)}
.related{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-top:24px}

/* pagination */
.rb-pagination{display:flex;gap:8px;justify-content:center;margin-top:40px;flex-wrap:wrap}
.rb-pagination .page-numbers{display:inline-flex;min-width:40px;height:40px;align-items:center;justify-content:center;border-radius:10px;background:#fff;border:1px solid var(--card-border);color:var(--forest);font-weight:700;padding:0 12px}
.rb-pagination .current{background:var(--forest);color:#fff}
