/* ============================================================
   The Enjoyment Minister — landing page
   Forest-green signature · warm cream canvas · rounded & friendly.
   Structured after the usemitu.com pattern: eyebrow → headline with an
   italic accent → lead → bullet list, each paired with a rich product
   mockup card (status chip, progress bar, live rows, footer pot).
   ============================================================ */

:root{
  --canvas:#ffffff;
  --surface:#ffffff;
  --surface-soft:#f6f5f1;
  --hairline:#e8e4db;
  --hairline-soft:#f0ede6;

  --ink:#1a1812;
  --body:#4b4636;
  --muted:#736d5a;
  --muted-soft:#9c9580;
  --on-dark:#f3f7ee;

  --forest:#16523e;
  --forest-deep:#0e3a2c;
  --forest-hover:#1d6650;
  --leaf:#3f9e6f;
  --leaf-soft:#dcefe2;

  --clay:#e0623c;
  --ochre:#e6a83f;
  --peach:#ffb487;
  --lavender:#b9a8ee;
  --berry:#f2667f;
  --sage:#9ed0b1;
  --sky:#8fc6d8;
  --cream-card:#efe6d1;

  --clay-tint:#fbe3d9;
  --ochre-tint:#fbeecb;
  --forest-tint:#dcebe3;

  --wa:#25d366;

  --shadow-sm:0 1px 2px rgba(40,34,18,.06);
  --shadow-md:0 16px 44px -24px rgba(40,34,18,.36);
  --shadow-lg:0 30px 70px -30px rgba(20,60,46,.5);

  --font:'Uncut Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --display:'Fredoka','Uncut Sans',sans-serif;
  --maxw:1180px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{ margin:0; background:var(--canvas); color:var(--body); font-family:var(--font);
  font-size:17px; line-height:1.6; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; overflow-x:hidden; }
img{max-width:100%; display:block;}
a{color:inherit; text-decoration:none;}

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 24px; }
.display{ font-family:var(--display); font-weight:500; letter-spacing:-.02em; line-height:1.04; color:var(--ink); }
.accent{ color:var(--forest); font-style:italic; font-weight:500; }

/* eyebrow — uppercase tracked label */
.eyebrow{ display:inline-flex; align-items:center; gap:9px; font-size:12px; font-weight:600;
  letter-spacing:1.7px; text-transform:uppercase; color:var(--forest); }
.eyebrow--pill{ background:var(--forest-tint); border-radius:999px; padding:7px 14px; }
.eyebrow .leaf{ width:14px; height:14px; }
.eyebrow .sep{ opacity:.4; }

/* buttons */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:9px; height:52px; padding:0 24px;
  border-radius:14px; font-family:inherit; font-size:16px; font-weight:600; line-height:1; border:1.6px solid transparent;
  cursor:pointer; white-space:nowrap; transition:background .16s, color .16s, border-color .16s, transform .05s; }
.btn:active{ transform:translateY(1px); }
.btn--lg{ height:58px; padding:0 28px; font-size:17px; }
.btn--wa{ background:var(--forest); color:var(--on-dark); }
.btn--wa:hover{ background:var(--forest-hover); }
.btn--ghost{ background:transparent; color:var(--ink); border-color:#d9cfb6; }
.btn--ghost:hover{ background:var(--surface-soft); }
.btn--cream{ background:var(--surface); color:var(--ink); border-color:var(--hairline); }
.btn--cream:hover{ background:var(--surface-soft); }
.btn .wa-ico{ width:20px; height:20px; }
.btn .ig-ico{ width:19px; height:19px; }

/* ============ nav ============ */
.nav{ position:sticky; top:0; z-index:60; background:rgba(255,255,255,.88); backdrop-filter:blur(10px);
  border-bottom:1px solid transparent; transition:border-color .2s; }
.nav.scrolled{ border-color:var(--hairline); }
.nav__in{ display:flex; align-items:center; gap:28px; height:72px; }
.brand{ display:inline-flex; align-items:center; gap:11px; }
.brand__mark{ width:34px; height:34px; border-radius:11px; background:var(--forest); color:var(--leaf-soft);
  display:grid; place-items:center; flex:none; box-shadow:inset 0 -6px 0 rgba(0,0,0,.18), inset 6px 0 0 rgba(0,0,0,.07); }
.brand__mark svg{ width:19px; height:19px; }
.brand__name{ font-family:var(--display); font-weight:600; font-size:19px; color:var(--ink); letter-spacing:-.01em; line-height:1.05; }
.brand__name b{ color:var(--forest); font-weight:600; }
.nav__links{ display:flex; gap:2px; margin-left:6px; }
.nav__links a{ padding:9px 14px; font-size:15.5px; color:var(--muted); border-radius:9px; }
.nav__links a:hover{ color:var(--ink); background:var(--surface-soft); }
.nav__right{ margin-left:auto; display:flex; align-items:center; gap:14px; }
.nav__burger{ display:none; width:42px; height:42px; border:1px solid var(--hairline); border-radius:11px; background:var(--surface); cursor:pointer; align-items:center; justify-content:center; }

/* ============ hero ============ */
.hero{ position:relative; overflow:hidden; min-height:100vh; display:flex; flex-direction:column; justify-content:center; padding:48px 0 0;
  background:
    radial-gradient(130% 90% at 50% -8%, rgba(228,238,196,.92) 0%, rgba(238,243,222,.7) 30%, rgba(250,248,239,.45) 52%, rgba(255,255,255,0) 72%),
    linear-gradient(180deg, #faf8f0 0%, #f4f2e8 46%, #e7f0df 100%); }
.hero::before{ content:''; position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:radial-gradient(rgba(22,82,62,.06) 1px, transparent 1.5px);
  background-size:22px 22px; -webkit-mask-image:linear-gradient(180deg, #000 0%, #000 70%, transparent 100%);
  mask-image:linear-gradient(180deg, #000 0%, #000 70%, transparent 100%); }
.hero__blob{ position:absolute; z-index:0; border-radius:50%; filter:blur(12px); opacity:.5; pointer-events:none; }
.hero__in{ position:relative; z-index:2; display:flex; flex-direction:column; align-items:center; text-align:center; gap:0; width:100%; margin-top:7vh; }
.hero__brand{ display:inline-flex; align-items:center; gap:11px; margin-bottom:38px; }
.hero__brand .brand__mark{ width:42px; height:42px; border-radius:12px; background:var(--forest); color:#fff; display:grid; place-items:center; }
.hero__brand .brand__mark svg{ width:22px; height:22px; }
.hero__brand .brand__name{ font-family:var(--display); font-weight:500; font-size:21px; color:var(--ink); letter-spacing:-.01em; }
.hero__brand .brand__name b{ color:var(--forest); font-weight:600; }
.hero h1{ font-size:clamp(44px,7vw,86px); margin:22px 0 0; max-width:14em; }
.hero__lead{ font-size:clamp(16px,1.5vw,18.5px); color:var(--body); margin:24px auto 0; max-width:33em; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:12px; margin-top:34px; justify-content:center; }
.hero__note{ display:flex; align-items:center; gap:9px; margin-top:22px; font-size:14.5px; color:var(--muted); }
.hero__note .dot{ width:7px; height:7px; border-radius:999px; background:var(--leaf); box-shadow:0 0 0 4px var(--leaf-soft); }

/* ============ marquee ============ */
.marquee{ overflow:hidden; -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); }
.marquee--hero{ position:relative; z-index:2; margin-top:auto; padding-top:52px; padding-bottom:20px; }

/* hero footer */
.hfoot{ position:relative; z-index:2; padding-bottom:22px; }
.hfoot__in{ display:flex; align-items:center; justify-content:space-between; gap:18px; }
.hfoot__c{ font-size:13.5px; color:var(--muted); }
.hfoot__nav{ display:flex; gap:24px; }
.hfoot__right{ display:flex; align-items:center; gap:26px; }
.hfoot__nav a{ font-size:13.5px; color:var(--muted); text-decoration:none; transition:color .15s; }
.hfoot__nav a:hover{ color:var(--ink); }

/* language dropdown */
.lang{ position:relative; }
.lang__btn{ display:inline-flex; align-items:center; gap:7px; height:34px; padding:0 12px;
  background:var(--surface); border:1px solid var(--hairline); border-radius:999px;
  font-family:inherit; font-size:13px; font-weight:500; color:var(--ink); cursor:pointer; transition:border-color .15s, background .15s; }
.lang__btn:hover{ border-color:#d3cab2; }
.lang__btn svg{ width:15px; height:15px; color:var(--muted); }
.lang__chev{ transition:transform .18s; }
.lang.open .lang__chev{ transform:rotate(180deg); }
.lang__menu{ position:absolute; right:0; bottom:calc(100% + 8px); min-width:148px; margin:0; padding:6px;
  list-style:none; background:var(--surface); border:1px solid var(--hairline); border-radius:14px;
  box-shadow:0 10px 30px rgba(20,40,30,.12); opacity:0; visibility:hidden; transform:translateY(6px);
  transition:opacity .16s, transform .16s, visibility .16s; }
.lang.open .lang__menu{ opacity:1; visibility:visible; transform:translateY(0); }
.lang__menu li{ padding:9px 12px; border-radius:9px; font-size:14px; color:var(--body); cursor:pointer; transition:background .12s; }
.lang__menu li:hover{ background:var(--surface-soft); }
.lang__menu li.on{ color:var(--forest); font-weight:600; }
@media (max-width:520px){
  .hfoot__in{ flex-direction:column; gap:14px; text-align:center; }
  .hfoot__right{ flex-direction:column; gap:14px; }
}

/* ============ content pages (FAQ / About / Privacy) ============ */
.doc{ min-height:100vh;
  background:
    radial-gradient(130% 70% at 50% -10%, rgba(228,238,196,.85) 0%, rgba(238,243,222,.6) 32%, rgba(255,255,255,0) 66%),
    linear-gradient(180deg, #faf8f0 0%, #f6f4ea 60%, #eef3e7 100%); }
.doc__bar{ position:sticky; top:0; z-index:10; }
.doc__bar .wrap{ display:flex; align-items:center; justify-content:space-between; height:74px; }
.doc__back{ display:inline-flex; align-items:center; gap:8px; font-size:14.5px; font-weight:600; color:var(--ink); text-decoration:none; }
.doc__back svg{ width:18px; height:18px; }
.doc__brand{ font-family:var(--display); font-weight:500; font-size:18px; color:var(--ink); letter-spacing:-.01em; }
.doc__brand b{ color:var(--forest); font-weight:600; }
.doc__body{ max-width:760px; margin:0 auto; padding:40px 24px 100px; }
.doc__eyebrow{ font-size:12px; font-weight:600; letter-spacing:1.7px; text-transform:uppercase; color:var(--forest); }
.doc h1{ font-family:var(--display); font-weight:600; font-size:clamp(34px,5vw,52px); letter-spacing:-.02em; color:var(--ink); margin:14px 0 0; }
.doc__lead{ font-size:18px; color:var(--muted); margin:16px 0 0; max-width:40em; }
.doc h2{ font-family:var(--display); font-weight:500; font-size:23px; color:var(--ink); margin:42px 0 0; letter-spacing:-.01em; }
.doc p{ font-size:16.5px; color:var(--body); margin:12px 0 0; }
.doc .qa-block{ margin-top:30px; border-top:1px solid var(--hairline); }
.doc .qa-block > div{ padding:22px 0; border-bottom:1px solid var(--hairline); }
.doc .qa-block h3{ font-size:17px; font-weight:600; color:var(--ink); margin:0; }
.doc .qa-block p{ margin-top:8px; color:var(--muted); }

/* ============ scrolling city photo marquee ============ */
.citymq__track{ display:flex; gap:16px; width:max-content; padding:0 24px; animation:scrollx 60s linear infinite; }
.marquee:hover .citymq__track{ animation-play-state:paused; }
.citytile{ position:relative; flex:0 0 auto; width:236px; height:152px; margin:0;
  border-radius:18px; overflow:hidden; border:1px solid var(--hairline); background:var(--surface-soft); }
.citytile img{ width:100%; height:100%; object-fit:cover; display:block; }
.citytile figcaption{ position:absolute; left:0; right:0; bottom:0; padding:18px 14px 11px;
  display:flex; flex-direction:column; gap:1px; color:#fff;
  background:linear-gradient(to top, rgba(8,20,16,.78), rgba(8,20,16,.32) 55%, transparent); }
.citytile figcaption b{ font-size:15px; font-weight:600; letter-spacing:-.01em; }
.citytile figcaption span{ font-size:12px; opacity:.85; }
@media (max-width:520px){
  .citytile{ width:200px; height:130px; }
}
.marquee__track{ display:flex; gap:12px; width:max-content; animation:scrollx 32s linear infinite; }
.marquee:hover .marquee__track{ animation-play-state:paused; }
@keyframes scrollx{ to{ transform:translateX(-50%); } }
.mq-pill{ display:inline-flex; align-items:center; gap:9px; background:var(--surface); border:1px solid var(--hairline);
  border-radius:999px; padding:10px 17px; font-size:14.5px; font-weight:500; color:var(--ink); white-space:nowrap; }
.mq-pill .d{ width:8px; height:8px; border-radius:999px; flex:none; }

/* word marquee (closing) */
.wordmq{ background:var(--forest); color:#bfe7cf; padding:20px 0; overflow:hidden; }
.wordmq__track{ display:flex; gap:0; width:max-content; animation:scrollx 26s linear infinite; }
.wordmq span{ font-family:var(--display); font-weight:500; font-size:26px; letter-spacing:-.01em; padding:0 22px; display:inline-flex; align-items:center; gap:44px; }
.wordmq span::after{ content:'·'; color:var(--leaf); }

/* ============ section scaffolding ============ */
.section{ padding:90px 0; }
.section--soft{ background:var(--surface-soft); }
.sec-head{ max-width:36rem; }
.sec-head--center{ margin:0 auto; text-align:center; }
.sec-head h2{ font-size:clamp(30px,3.9vw,48px); margin:14px 0 0; }
.sec-head p{ font-size:18px; color:var(--muted); margin:16px 0 0; }

/* big statement band (usemitu "Made to move with you") */
.statement{ text-align:center; padding:96px 0; }
.statement h2{ font-size:clamp(32px,4.6vw,56px); margin:0 auto; max-width:16em; }
.statement p{ font-size:19px; color:var(--muted); margin:22px auto 0; max-width:40em; }

/* ============ feature blocks ============ */
.feat{ display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; }
.feat + .feat{ margin-top:104px; }
.feat--flip .feat__media{ order:-1; }
.feat h3{ font-size:clamp(27px,3.1vw,38px); margin:16px 0 0; }
.feat__lead{ font-size:18px; color:var(--body); margin:16px 0 0; max-width:30em; }
.feat__list{ list-style:none; padding:0; margin:24px 0 28px; display:flex; flex-direction:column; gap:13px; }
.feat__list li{ display:flex; gap:12px; font-size:16px; color:var(--body); }
.feat__list .ck{ width:24px; height:24px; border-radius:999px; background:var(--leaf-soft); color:var(--forest); display:grid; place-items:center; flex:none; margin-top:1px; }
.feat__list .ck svg{ width:14px; height:14px; }
.feat__media{ display:flex; align-items:center; justify-content:center; }

/* tinted stage behind a mock card */
.stage{ width:100%; border-radius:30px; padding:38px; display:flex; align-items:center; justify-content:center; }

/* ====== the signature mockup card (usemitu "pot" pattern) ====== */
.joycard{ width:100%; max-width:360px; background:var(--surface); border:1px solid var(--hairline);
  border-radius:24px; padding:22px; box-shadow:var(--shadow-lg); }
.joycard__chip{ display:inline-flex; align-items:center; gap:7px; font-size:10.5px; font-weight:700;
  letter-spacing:1px; text-transform:uppercase; color:var(--forest); background:var(--leaf-soft);
  border-radius:999px; padding:5px 11px; }
.joycard__chip .live{ width:6px; height:6px; border-radius:999px; background:var(--leaf); animation:pulse 1.6s infinite; }
@keyframes pulse{ 0%,100%{opacity:1;} 50%{opacity:.3;} }
.joycard__title{ font-family:var(--display); font-weight:600; font-size:22px; color:var(--ink); letter-spacing:-.01em; margin:15px 0 0; }
.joycard__sub{ font-size:13.5px; color:var(--muted); margin-top:3px; }
.joycard__sub b{ color:var(--ink); font-weight:600; }
.joybar{ margin:16px 0 4px; }
.joybar__top{ display:flex; align-items:baseline; justify-content:space-between; font-size:13.5px; color:var(--muted); margin-bottom:8px; }
.joybar__top b{ color:var(--ink); font-weight:600; font-size:15px; }
.joybar__top .pct{ color:var(--forest); font-weight:700; }
.joybar__track{ height:9px; border-radius:999px; background:var(--surface-soft); overflow:hidden; }
.joybar__fill{ height:100%; border-radius:999px; background:linear-gradient(90deg,var(--leaf),var(--forest)); }
.joyrows{ margin-top:16px; display:flex; flex-direction:column; }
.joyrow{ display:flex; align-items:center; gap:12px; padding:11px 0; border-top:1px solid var(--hairline-soft); }
.joyrow:first-child{ border-top:0; }
.joyrow__ico{ width:38px; height:38px; border-radius:11px; display:grid; place-items:center; flex:none; background:var(--forest-tint)!important; color:var(--forest)!important; }
.joyrow__ico svg{ width:19px; height:19px; }
.joyrow__mid{ flex:1; min-width:0; }
.joyrow__nm{ font-size:14.5px; font-weight:600; color:var(--ink); }
.joyrow__meta{ font-size:12.5px; color:var(--muted); margin-top:2px; }
.joyrow__val{ font-size:13.5px; font-weight:600; color:var(--forest); white-space:nowrap; }
.joycard__foot{ margin-top:18px; padding-top:16px; border-top:1px solid var(--hairline); display:flex; align-items:center; justify-content:space-between; }
.joycard__foot .lab{ font-size:12.5px; color:var(--muted); }
.joycard__foot .val{ font-family:var(--display); font-weight:600; font-size:19px; color:var(--ink); }
.joycard__foot .val small{ color:var(--muted-soft); font-weight:500; font-size:13px; }

/* refine chips */
.chips{ display:flex; flex-wrap:wrap; gap:10px; }
.chip{ background:var(--surface); border:1px solid var(--hairline); border-radius:999px; padding:10px 16px; font-size:14.5px; color:var(--ink); font-weight:500; cursor:pointer; transition:background .14s,color .14s,border-color .14s; }
.chip--on{ background:var(--forest); color:#fff; border-color:var(--forest); }

/* ====== whatsapp chat mock ====== */
.phone{ position:relative; justify-self:center; width:342px; max-width:100%; background:#0a0d0c; border-radius:46px; padding:11px; box-shadow:var(--shadow-lg), inset 0 0 0 2px rgba(255,255,255,.06); }
.phone__screen{ position:relative; background:#e7ddcf; border-radius:36px; overflow:hidden; display:flex; flex-direction:column; }

/* status bar */
.wa-bar{ background:var(--forest); color:#fff; display:flex; align-items:center; justify-content:space-between; padding:9px 22px 4px; font-size:12.5px; font-weight:600; letter-spacing:.2px; }
.wa-bar__ic{ display:flex; align-items:center; gap:6px; }
.wa-bar__ic svg{ width:16px; height:13px; }

/* chat header */
.wa-top{ background:var(--forest); color:#fff; display:flex; align-items:center; gap:10px; padding:7px 14px 11px; }
.wa-back{ background:none; border:0; color:#fff; cursor:pointer; padding:0; display:grid; place-items:center; }
.wa-back svg{ width:22px; height:22px; }
.wa-top__av{ width:38px; height:38px; border-radius:999px; background:var(--leaf); display:grid; place-items:center; flex:none; color:#08291f; }
.wa-top__av svg{ width:21px; height:21px; }
.wa-top__id{ flex:1; min-width:0; }
.wa-top__nm{ font-weight:600; font-size:15px; line-height:1.15; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.wa-top__st{ font-size:11.5px; color:#bfe6d2; margin-top:1px; }
.wa-top__acts{ display:flex; align-items:center; gap:18px; color:#eaf5ee; }
.wa-top__acts svg{ width:20px; height:20px; }

/* wallpaper body */
.wa-body{ flex:1; padding:14px 12px 12px; display:flex; flex-direction:column; gap:7px; background-color:#e7ddcf;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='92' height='92' viewBox='0 0 92 92'%3E%3Cg fill='none' stroke='%23123f30' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' opacity='0.06'%3E%3Cpath d='M18 17c-3-4-10-1.5-10 3 0 4.5 10 10 10 10s10-5.5 10-10c0-4.5-7-7-10-3z'/%3E%3Ccircle cx='68' cy='20' r='8'/%3E%3Cpath d='M64.5 18.5h0M71.5 18.5h0M64 23c2 2 6 2 8 0'/%3E%3Cpath d='M46 54l2.6 5.3 5.8.8-4.2 4.1 1 5.8-5.2-2.8-5.2 2.8 1-5.8-4.2-4.1 5.8-.8z'/%3E%3Cpath d='M12 66h13M12 73h9'/%3E%3Cpath d='M78 60c4 0 6 5 2 7'/%3E%3C/g%3E%3C/svg%3E"); background-size:92px 92px; }

/* date + encryption chips */
.wa-date{ align-self:center; background:#d3e7da; color:#3a5246; font-size:11px; font-weight:600; padding:4px 12px; border-radius:8px; box-shadow:0 1px 1px rgba(0,0,0,.05); margin:2px 0 4px; }
.wa-enc{ align-self:center; max-width:84%; text-align:center; background:#fdf4d3; color:#6b5b2e; font-size:10.5px; line-height:1.4; padding:6px 12px; border-radius:8px; box-shadow:0 1px 1px rgba(0,0,0,.05); margin-bottom:4px; display:flex; align-items:center; gap:5px; }
.wa-enc svg{ width:11px; height:11px; flex:none; }

.msg{ position:relative; max-width:82%; padding:7px 10px 6px; border-radius:9px; font-size:13.5px; line-height:1.42; box-shadow:0 1px .5px rgba(0,0,0,.13); }
.msg .t{ display:inline-flex; align-items:center; gap:3px; float:right; font-size:10px; color:rgba(0,0,0,.4); margin:5px 0 -1px 10px; }
.msg .t .tick{ width:15px; height:10px; color:#53bdeb; }
.msg--in{ align-self:flex-start; background:#fff; color:#11231b; border-top-left-radius:1px; }
.msg--in::before{ content:''; position:absolute; top:0; left:-7px; width:9px; height:13px; background:#fff; clip-path:polygon(100% 0,100% 100%,0 0); }
.msg--out{ align-self:flex-end; background:#d6f8c8; color:#10301c; border-top-right-radius:1px; }
.msg--out::before{ content:''; position:absolute; top:0; right:-7px; width:9px; height:13px; background:#d6f8c8; clip-path:polygon(0 0,0 100%,100% 0); }
.msg b{ font-weight:600; }
.msg--loc{ align-self:flex-end; padding:4px; overflow:hidden; width:198px; background:#d6f8c8; }
.msg--loc::before{ content:''; position:absolute; top:0; right:-7px; width:9px; height:13px; background:#d6f8c8; clip-path:polygon(0 0,0 100%,100% 0); }
.msg--loc .pin{ background:#bfe6c2; border-radius:6px; height:78px; display:grid; place-items:center; color:var(--forest); position:relative; }
.msg--loc .pin svg{ width:28px; height:28px; }
.msg--loc .lab{ padding:7px 8px 4px; color:#10301c; font-size:12px; display:flex; align-items:center; gap:5px; }

/* message input bar */
.wa-input{ display:flex; align-items:center; gap:8px; padding:8px 10px 12px; background:#e7ddcf; }
.wa-field{ flex:1; display:flex; align-items:center; gap:9px; background:#fff; border-radius:22px; padding:10px 12px; box-shadow:0 1px 1px rgba(0,0,0,.06); }
.wa-field__ph{ flex:1; font-size:13.5px; color:#8a8f88; }
.wa-field svg{ width:19px; height:19px; color:#5a6b62; flex:none; }
.wa-field .emoji{ color:#7a857d; }
.wa-send{ width:44px; height:44px; border-radius:999px; background:var(--forest); border:0; color:#fff; display:grid; place-items:center; flex:none; cursor:pointer; box-shadow:var(--shadow-sm); }
.wa-send svg{ width:21px; height:21px; }

/* ============ testimonials ============ */
.tcols{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:48px; }
.tcard{ background:var(--surface); border:1px solid var(--hairline); border-radius:20px; padding:26px 24px; display:flex; flex-direction:column; }
.tcard__loc{ display:inline-flex; align-items:center; gap:7px; font-size:12.5px; font-weight:600; color:var(--forest); margin-bottom:14px; }
.tcard__loc .d{ width:7px; height:7px; border-radius:999px; background:var(--leaf); }
.tcard p{ font-size:16.5px; color:var(--ink); margin:0; line-height:1.55; }
.tcard__by{ display:flex; align-items:center; gap:11px; margin-top:22px; }
.tcard__av{ width:40px; height:40px; border-radius:999px; display:grid; place-items:center; color:#fff; font-weight:600; font-size:14px; flex:none; }
.tcard__nm{ font-weight:600; color:var(--ink); font-size:14.5px; }
.tcard__role{ font-size:13px; color:var(--muted); }

/* ============ faq ============ */
.faq{ max-width:760px; margin:46px auto 0; border-top:1px solid var(--hairline); }
.qa{ border-bottom:1px solid var(--hairline); }
.qa__q{ width:100%; background:none; border:0; cursor:pointer; font-family:inherit; text-align:left; display:flex; align-items:center; gap:16px; padding:22px 4px; font-size:18px; font-weight:600; color:var(--ink); }
.qa__q .pl{ margin-left:auto; width:24px; height:24px; flex:none; color:var(--forest); transition:transform .2s; }
.qa.open .qa__q .pl{ transform:rotate(45deg); }
.qa__a{ max-height:0; overflow:hidden; transition:max-height .26s ease; }
.qa__a div{ padding:0 4px 22px; font-size:16px; color:var(--muted); max-width:64ch; }

/* ============ closing cta ============ */
.cta{ text-align:center; }
.cta__card{ background:var(--surface); border:1px solid var(--hairline); border-radius:34px; padding:64px 40px; box-shadow:var(--shadow-md); position:relative; overflow:hidden; }
.cta h2{ font-size:clamp(32px,4.4vw,52px); margin:0 auto; max-width:15em; }
.cta p{ font-size:19px; color:var(--muted); margin:18px auto 0; max-width:30em; }
.cta__btns{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-top:30px; }

/* ============ footer ============ */
.footer{ background:var(--forest-deep); color:#bcd6c8; padding:64px 0 40px; }
.footer__top{ display:flex; gap:40px; justify-content:space-between; flex-wrap:wrap; }
.footer .brand__name{ color:#fff; } .footer .brand__name b{ color:var(--leaf); }
.footer__tag{ margin:16px 0 0; max-width:24em; font-size:15.5px; color:#9cbcab; }
.footer__cols{ display:flex; gap:64px; flex-wrap:wrap; }
.footer__col h4{ font-size:13px; text-transform:uppercase; letter-spacing:1px; color:#7fa392; margin:0 0 14px; font-weight:600; }
.footer__col a{ display:block; font-size:15px; color:#c8ddd1; padding:5px 0; }
.footer__col a:hover{ color:#fff; }
.footer__bot{ margin-top:48px; padding-top:24px; border-top:1px solid rgba(255,255,255,.1); display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; font-size:14px; color:#88a899; }

/* ============ responsive ============ */
@media (max-width:980px){
  .hero__in{ grid-template-columns:1fr; gap:40px; }
  .phone{ order:-1; }
  .feat{ grid-template-columns:1fr; gap:32px; }
  .feat--flip .feat__media{ order:0; }
  .tcols{ grid-template-columns:1fr; }
  .nav__links{ display:none; }
  .statement{ padding:70px 0; }
}
@media (max-width:560px){
  .nav__right .btn--ghost{ display:none; }
  .footer__top{ flex-direction:column; }
  .section{ padding:62px 0; }
  .stage{ padding:22px; }
}
