/* ============================================================
   Clew Digital — site stylesheet
   Brand palette sampled from official brand board.
   Type: Georgia (display, per brand "Georgia Pro") + Public Sans (body)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Public+Sans:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,400;1,600;1,700&display=swap');

/* Temporary live contact-page recovery: keeps the polished nested layout visible
   while hiding broken wrapper markup left by the remote editor. */
body > main.contact-page-polished > .contact-hero-panel {
  padding: 0 !important;
}

body > main.contact-page-polished > .contact-hero-panel > .wrap.contact-hero-layout {
  display: block !important;
  max-width: none !important;
  padding: 0 !important;
}

body > main.contact-page-polished > .contact-hero-panel > .wrap.contact-hero-layout > .reveal:first-child,
body > main.contact-page-polished > .contact-hero-panel > .wrap.contact-hero-layout > .response-card > :not(main) {
  display: none !important;
}

body > main.contact-page-polished > .contact-hero-panel > .wrap.contact-hero-layout > .response-card {
  display: block !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  font-size: 0 !important;
}

body > main.contact-page-polished > .contact-hero-panel > .wrap.contact-hero-layout > .response-card > main.contact-page-polished {
  display: block !important;
  font-size: 17px !important;
}

:root{
  /* brand — greens + warm */
  --olive:#637d24;
  --olive-deep:#465713;
  --olive-ink:#2c360f;
  --logo-green:#617f0c;
  --leaf:#8ab33d;
  --leaf-bright:#a6cc4e;
  --tomato:#ea682c;
  --tomato-deep:#cf5320;
  --marigold:#f4b146;
  --lemon:#efdf54;
  /* neutrals */
  --ink:#0c080c;
  --ink-soft:#1c1a14;
  --gray:#7c7c76;
  --gray-line:#e4e2d7;
  --cloud:#fbfafb;
  --cream:#f4f2e9;
  --cream-2:#efece0;

  --font-display:Georgia,'Times New Roman',serif;
  --font-body:'Public Sans', system-ui, sans-serif;

  --maxw:1240px;
  --r-lg:28px;
  --r-md:20px;
  --r-sm:14px;
  --shadow:0 24px 60px -28px rgba(44,54,15,.45);
  --shadow-sm:0 14px 34px -18px rgba(44,54,15,.4);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0; font-family:var(--font-body); color:var(--ink);
  background:var(--cream); font-size:17px; line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;}
h1,h2,h3,h4,p{margin:0;}
.serif{font-family:var(--font-display);}
.italic{font-style:italic;}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px;}
.section{padding:104px 0;}
.section.tight{padding:72px 0;}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-weight:700;font-size:13px;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--olive);
}
.eyebrow::before{content:"";width:26px;height:2px;background:currentColor;border-radius:2px;}
.eyebrow.on-dark{color:var(--lemon);}
.h-sec{font-family:var(--font-display);font-weight:700;font-size:clamp(34px,4.4vw,56px);line-height:1.05;letter-spacing:-1px;}
.h-sec .it{font-style:italic;color:var(--tomato);}
.lead{font-size:clamp(17px,1.4vw,20px);color:#54583f;line-height:1.6;}
.center{text-align:center;}
.center .eyebrow{justify-content:center;}

/* ---------- buttons ---------- */
.btn{
  font-family:var(--font-body);font-weight:700;font-size:16px;
  border:none;cursor:pointer;border-radius:999px;padding:15px 26px;
  display:inline-flex;align-items:center;gap:10px;text-decoration:none;
  transition:transform .16s ease, box-shadow .2s ease, background .2s;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px);}
.btn:active{transform:translateY(0);}
.btn .arr{width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:15px;transition:transform .2s;}
.btn:hover .arr{transform:translate(2px,-2px);}
.btn-tomato{background:var(--tomato);color:var(--cloud);box-shadow:0 12px 30px -12px var(--tomato);}
.btn-tomato:hover{background:var(--tomato-deep);}
.btn-olive{background:var(--olive);color:var(--cloud);box-shadow:0 12px 30px -12px var(--olive);}
.btn-ink{background:var(--ink);color:var(--cloud);}
.btn-leaf{background:var(--leaf);color:var(--ink);}
.btn-cream{background:var(--cloud);color:var(--ink);box-shadow:var(--shadow-sm);}
.btn-ghost{background:transparent;border:2px solid var(--gray-line);color:var(--ink);}
.btn-ghost.on-dark{border-color:rgba(255,255,255,.3);color:var(--cloud);}
.btn-ghost:hover{border-color:var(--olive);}
.btn-leaf .arr,.btn-cream .arr{background:rgba(12,8,12,.1);}
.btn-lg{padding:18px 32px;font-size:17px;}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(244,242,233,.82);backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;transition:border-color .3s, background .3s;
}
.site-header.scrolled{border-color:var(--gray-line);background:rgba(244,242,233,.95);}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;height:78px;}
.brand{display:flex;align-items:baseline;gap:0;line-height:1;text-decoration:none;user-select:none;}
.brand .lc{font-family:var(--font-display);font-style:italic;font-weight:700;font-size:28px;letter-spacing:-.5px;color:var(--ink);}
.brand .ld{font-family:var(--font-body);font-weight:800;font-size:25px;letter-spacing:-1px;color:var(--logo-green);margin-left:3px;}
.brand .dot{font-family:var(--font-body);font-weight:800;font-size:25px;color:var(--tomato);}
.nav{display:flex;align-items:center;gap:4px;}
.nav a{
  font-weight:600;font-size:15.5px;text-decoration:none;color:var(--ink-soft);
  padding:10px 16px;border-radius:999px;transition:.2s;
}
.nav a:hover{background:rgba(99,125,36,.1);color:var(--olive);}
.nav a.active{background:var(--olive);color:var(--cloud);}
.nav > .btn{display:none;}
.header-cta{display:flex;align-items:center;gap:12px;}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;width:46px;height:46px;border-radius:12px;align-items:center;justify-content:center;}
.menu-toggle span{display:block;width:22px;height:2.4px;background:var(--ink);border-radius:2px;position:relative;transition:.25s;}
.menu-toggle span::before,.menu-toggle span::after{content:"";position:absolute;left:0;width:22px;height:2.4px;background:var(--ink);border-radius:2px;transition:.25s;}
.menu-toggle span::before{top:-7px;} .menu-toggle span::after{top:7px;}
body.menu-open .menu-toggle span{background:transparent;}
body.menu-open .menu-toggle span::before{top:0;transform:rotate(45deg);}
body.menu-open .menu-toggle span::after{top:0;transform:rotate(-45deg);}

/* ---------- footer ---------- */
.site-footer{background:var(--olive-deep);color:#dfe3cf;padding:80px 0 36px;position:relative;overflow:hidden;}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;}
.site-footer .brand .lc{color:var(--cloud);} .site-footer .brand .ld{color:var(--leaf-bright);}
.foot-col h4{font-weight:800;font-size:13px;letter-spacing:2px;text-transform:uppercase;color:var(--leaf-bright);margin-bottom:18px;}
.foot-col a{display:block;text-decoration:none;color:#cfd4bd;padding:6px 0;font-size:15.5px;transition:.2s;}
.foot-col a:hover{color:var(--cloud);}
.foot-blurb{max-width:300px;color:#c4cab1;margin:18px 0 22px;font-size:15.5px;}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;margin-top:56px;padding-top:26px;border-top:1px solid rgba(255,255,255,.12);font-size:14px;color:#aeb497;flex-wrap:wrap;}
.foot-social{display:flex;gap:10px;}
.foot-social a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;transition:.2s;text-decoration:none;color:var(--cloud);}
.foot-social a:hover{background:var(--tomato);transform:translateY(-2px);}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.08s;} .reveal.d2{transition-delay:.16s;} .reveal.d3{transition-delay:.24s;} .reveal.d4{transition-delay:.32s;}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none;}}

/* ---------- image slots ---------- */
image-slot{display:block;width:100%;height:100%;background:linear-gradient(150deg,var(--olive),var(--leaf));}
image-slot::part(frame){background:transparent;}
image-slot::part(empty){color:rgba(255,255,255,.85);font-family:var(--font-body);}

/* ====================================================================
   HERO (Home)
   ==================================================================== */
.hero{position:relative;overflow:hidden;padding:48px 0 90px;}
.hero-blobs{position:absolute;inset:0;pointer-events:none;z-index:0;}
.hero-blobs i{position:absolute;border-radius:50%;display:block;}
.hero-blobs .b1{width:min(38vw,460px);aspect-ratio:1;background:var(--leaf);top:-12%;right:-6%;opacity:.42;}
.hero-blobs .b2{width:120px;height:120px;background:var(--marigold);top:30%;left:42%;opacity:.85;}
.hero-blobs .b3{width:74px;height:74px;background:var(--tomato);top:46%;left:51%;opacity:.8;}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.08fr .92fr;gap:48px;align-items:center;}
.pill-tag{display:inline-flex;align-items:center;gap:9px;background:var(--olive);color:var(--cloud);font-weight:600;border-radius:999px;padding:10px 18px;font-size:14px;margin-bottom:26px;}
.pill-tag .spark{color:var(--lemon);}
.hero h1{font-family:var(--font-display);font-weight:700;font-size:clamp(44px,6vw,82px);line-height:1.02;letter-spacing:-2px;margin-bottom:26px;}
.hero h1 .pop{color:var(--tomato);font-style:italic;}
.hero h1 .uline{display:inline-block;position:relative;}
.hero h1 .uline svg{position:absolute;left:0;bottom:-10px;width:100%;height:18px;}
.hero .sub{font-size:clamp(18px,1.5vw,21px);line-height:1.55;color:#4d5340;max-width:480px;margin-bottom:34px;}
.hero .cta-row{display:flex;align-items:center;gap:16px;margin-bottom:44px;flex-wrap:wrap;}
.hero .chips{display:flex;gap:34px;flex-wrap:wrap;}
.chip{display:flex;align-items:center;gap:14px;}
.chip .n{font-family:var(--font-display);font-weight:700;font-size:38px;color:var(--olive);line-height:1;}
.chip .n em{color:var(--tomato);font-style:italic;}
.chip .t{font-size:13.5px;font-weight:700;color:var(--gray);line-height:1.2;max-width:96px;}
.hero-visual{position:relative;display:flex;align-items:center;justify-content:center;}
.hero-frame{position:relative;width:min(100%,430px);}
.hero-frame .ph{width:100%;height:100%;border-radius:48% 48% 46% 46%/40% 40% 42% 42%;overflow:hidden;border:11px solid var(--ink);}
.float-badge{position:absolute;background:var(--cloud);border-radius:18px;padding:14px 17px;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:12px;font-weight:800;font-size:14px;line-height:1.2;}
.float-badge .ic{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:19px;color:var(--cloud);flex:0 0 auto;}
.float-badge.fb1{top:18px;left:-34px;animation:floaty 5s ease-in-out infinite;}
.float-badge.fb2{bottom:36px;right:-38px;animation:floaty 5.6s ease-in-out infinite .5s;}
/* hero dashboard graphic — clean, self-contained */
.hero-visual{display:flex;align-items:center;justify-content:center;}
.dash{width:min(100%,430px);background:var(--cloud);border:1px solid var(--gray-line);border-radius:28px;box-shadow:var(--shadow);padding:30px;position:relative;z-index:2;}
.dash .dhead{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px;}
.dash .dlabel{font-size:13.5px;font-weight:700;color:var(--gray);}
.dash .dbig{font-family:var(--font-display);font-weight:700;font-size:44px;letter-spacing:-1px;line-height:1.1;}
.dash .dlive{display:inline-flex;align-items:center;gap:7px;background:rgba(99,125,36,.12);color:var(--olive);font-weight:700;font-size:12.5px;padding:6px 12px;border-radius:999px;}
.dash .dlive .ldot{width:8px;height:8px;border-radius:50%;background:var(--olive);animation:pulse 1.6s ease-in-out infinite;}
@keyframes pulse{50%{opacity:.3;}}
.dash .dtrend{font-size:13.5px;color:#54583f;font-weight:600;margin-bottom:22px;}
.dash .dtrend .up{color:var(--olive);font-weight:800;}
.dash .chart{display:flex;align-items:flex-end;gap:11px;height:150px;}
.dash .chart .bar{flex:1;height:var(--h);background:var(--c);border-radius:8px 8px 4px 4px;transform-origin:bottom;transform:scaleY(0);animation:barGrow .8s cubic-bezier(.2,.8,.2,1) forwards;}
.dash .chart .bar:nth-child(1){animation-delay:.15s;} .dash .chart .bar:nth-child(2){animation-delay:.24s;}
.dash .chart .bar:nth-child(3){animation-delay:.33s;} .dash .chart .bar:nth-child(4){animation-delay:.42s;}
.dash .chart .bar:nth-child(5){animation-delay:.51s;} .dash .chart .bar:nth-child(6){animation-delay:.6s;}
.dash .chart .bar:nth-child(7){animation-delay:.69s;}
@keyframes barGrow{to{transform:scaleY(1);}}
.dash .chart-x{display:flex;gap:11px;margin-top:10px;}
.dash .chart-x span{flex:1;text-align:center;font-size:11px;font-weight:700;color:var(--gray);}
.dash .dfoot{display:flex;gap:14px;margin-top:24px;padding-top:22px;border-top:1px solid var(--gray-line);}
.dash .dstat{flex:1;}
.dash .dstat b{display:block;font-family:var(--font-display);font-weight:700;font-size:24px;letter-spacing:-.5px;line-height:1;}
.dash .dstat span{font-size:12px;font-weight:700;color:var(--gray);}
.dash .dstat:not(:last-child){border-right:1px solid var(--gray-line);}
@media (prefers-reduced-motion:reduce){.dash .chart .bar{transform:scaleY(1);animation:none;}.dash .dlive .ldot{animation:none;}}
@keyframes floaty{50%{transform:translateY(-12px);}}
@keyframes spin{to{transform:rotate(360deg);}}
@media (prefers-reduced-motion:reduce){.float-badge,.hero-frame .star{animation:none;}}

/* marquee strip */
.marquee{background:var(--ink);color:var(--cloud);overflow:hidden;white-space:nowrap;padding:18px 0;}
.marquee .track{display:inline-flex;gap:30px;animation:marq 26s linear infinite;}
.marquee .track span{display:inline-flex;align-items:center;gap:30px;font-family:var(--font-display);font-style:italic;font-size:24px;}
.marquee .track .dotsep{color:var(--marigold);font-style:normal;}
@keyframes marq{to{transform:translateX(-50%);}}
@media (prefers-reduced-motion:reduce){.marquee .track{animation:none;}}

/* ====================================================================
   SERVICE CARDS
   ==================================================================== */
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:54px;}
.svc-card{
  background:var(--cloud);border-radius:var(--r-lg);padding:38px;
  border:1px solid var(--gray-line);position:relative;overflow:hidden;
  transition:transform .25s ease, box-shadow .25s ease;
  display:flex;flex-direction:column;gap:18px;min-height:280px;
}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);}
.svc-card .num{position:absolute;top:26px;right:32px;font-family:var(--font-display);font-style:italic;font-size:30px;color:var(--gray-line);}
.svc-ic{width:62px;height:62px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:28px;color:var(--cloud);}
.svc-card h3{font-family:var(--font-display);font-weight:700;font-size:26px;letter-spacing:-.5px;}
.svc-card p{color:#54583f;font-size:16px;}
.svc-card .tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:auto;}
.svc-card .tags span{font-size:13px;font-weight:600;color:var(--olive);background:rgba(99,125,36,.1);padding:6px 12px;border-radius:999px;}
.svc-card .more{font-weight:700;color:var(--tomato);text-decoration:none;display:inline-flex;align-items:center;gap:7px;font-size:15px;}
.svc-card .more .arr{transition:transform .2s;}
.svc-card:hover .more .arr{transform:translateX(4px);}

/* ====================================================================
   STATS BAND
   ==================================================================== */
.stats-band{background:var(--olive);color:var(--cloud);border-radius:36px;padding:56px;position:relative;overflow:hidden;}
.stats-band .gridlines{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px);background-size:54px 54px;}
.stats-grid{position:relative;z-index:2;display:grid;grid-template-columns:repeat(4,1fr);gap:30px;}
.stat-item .big{font-family:var(--font-display);font-weight:700;font-size:clamp(40px,4.5vw,58px);line-height:1;}
.stat-item .big .u{color:var(--lemon);}
.stat-item .lbl{margin-top:10px;color:#dfe3cf;font-weight:600;font-size:15px;}
.stat-item{position:relative;}
.stat-item:not(:last-child)::after{content:"";position:absolute;right:-15px;top:8px;bottom:8px;width:1px;background:rgba(255,255,255,.16);}

/* ====================================================================
   PROCESS
   ==================================================================== */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:54px;}
.step{background:var(--cloud);border:1px solid var(--gray-line);border-radius:var(--r-md);padding:30px;position:relative;}
.step .k{font-family:var(--font-display);font-style:italic;font-weight:700;font-size:20px;width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--cloud);margin-bottom:20px;}
.step h4{font-family:var(--font-display);font-size:21px;font-weight:700;margin-bottom:9px;letter-spacing:-.3px;}
.step p{font-size:15px;color:#54583f;}

/* ====================================================================
   CASE STUDY
   ==================================================================== */
.case-feature{display:grid;grid-template-columns:.95fr 1.05fr;gap:48px;align-items:center;background:var(--cloud);border-radius:var(--r-lg);border:1px solid var(--gray-line);overflow:hidden;}
.case-feature .media{position:relative;min-height:440px;}
.case-feature .media image-slot{position:absolute;inset:0;}
.case-feature .media .tag{position:absolute;top:22px;left:22px;z-index:3;background:var(--cloud);border-radius:999px;padding:9px 16px;font-weight:700;font-size:13px;display:flex;align-items:center;gap:8px;}
.case-feature .body{padding:50px 50px 50px 8px;}
.case-feature .quote{font-family:var(--font-display);font-size:26px;line-height:1.35;letter-spacing:-.4px;margin:22px 0 28px;}
.case-metrics{display:flex;gap:34px;flex-wrap:wrap;margin-bottom:30px;}
.case-metrics .m .n{font-family:var(--font-display);font-weight:700;font-size:40px;color:var(--tomato);line-height:1;}
.case-metrics .m .l{font-size:13.5px;font-weight:700;color:var(--gray);margin-top:6px;}

/* case study cards grid (case studies page) */
.cs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:54px;}
.cs-card{background:var(--cloud);border:1px solid var(--gray-line);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;transition:transform .25s, box-shadow .25s;text-decoration:none;color:inherit;}
.cs-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);}
.cs-card .media{position:relative;aspect-ratio:16/11;}
.cs-card .media image-slot{position:absolute;inset:0;}
.cs-card .media .cat{position:absolute;top:16px;left:16px;background:var(--cloud);border-radius:999px;padding:7px 14px;font-size:12.5px;font-weight:700;color:var(--olive);}
.cs-card .pad{padding:26px 26px 30px;display:flex;flex-direction:column;gap:14px;flex:1;}
.cs-card h3{font-family:var(--font-display);font-size:23px;font-weight:700;letter-spacing:-.4px;line-height:1.15;}
.cs-card .res{display:flex;gap:22px;margin-top:auto;}
.cs-card .res .n{font-family:var(--font-display);font-weight:700;font-size:28px;color:var(--tomato);line-height:1;}
.cs-card .res .l{font-size:12px;font-weight:700;color:var(--gray);margin-top:4px;}

/* ====================================================================
   TESTIMONIAL
   ==================================================================== */
.testi{background:var(--marigold);border-radius:36px;padding:64px;position:relative;overflow:hidden;}
.testi .mark{font-family:var(--font-display);font-size:160px;line-height:.6;color:var(--tomato);opacity:.5;position:absolute;top:40px;left:48px;}
.testi blockquote{font-family:var(--font-display);font-size:clamp(24px,2.6vw,34px);line-height:1.32;letter-spacing:-.5px;max-width:880px;position:relative;z-index:2;}
.testi .by{display:flex;align-items:center;gap:14px;margin-top:32px;position:relative;z-index:2;}
.testi .by .av{width:54px;height:54px;border-radius:50%;overflow:hidden;background:var(--olive);flex:0 0 auto;}
.testi .by .who b{display:block;font-weight:800;font-size:16px;}
.testi .by .who span{font-size:14px;color:var(--olive-ink);}

/* ====================================================================
   CTA BAND
   ==================================================================== */
.cta-band{background:var(--ink);color:var(--cloud);border-radius:36px;padding:72px;text-align:center;position:relative;overflow:hidden;}
.cta-band .glow{position:absolute;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,var(--olive),transparent 65%);top:-40%;left:50%;transform:translateX(-50%);opacity:.6;}
.cta-band h2{font-family:var(--font-display);font-weight:700;font-size:clamp(34px,4.6vw,58px);line-height:1.04;letter-spacing:-1.2px;position:relative;z-index:2;}
.cta-band h2 .it{font-style:italic;color:var(--marigold);}
.cta-band p{position:relative;z-index:2;color:#cfd4bd;font-size:19px;margin:20px auto 36px;max-width:520px;}
.cta-band .cta-row{position:relative;z-index:2;display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

/* ====================================================================
   PAGE HERO (inner pages)
   ==================================================================== */
.page-hero{position:relative;overflow:hidden;padding:72px 0 64px;text-align:center;}
.page-hero .blob{position:absolute;border-radius:50%;pointer-events:none;}
.page-hero .pb1{width:300px;height:300px;background:var(--leaf);opacity:.32;top:-120px;left:-60px;}
.page-hero .pb2{width:140px;height:140px;background:var(--marigold);opacity:.7;bottom:-30px;right:8%;}
.page-hero h1{font-family:var(--font-display);font-weight:700;font-size:clamp(42px,6vw,76px);line-height:1.02;letter-spacing:-2px;position:relative;z-index:2;}
.page-hero h1 .it{font-style:italic;color:var(--tomato);}
.page-hero .sub{position:relative;z-index:2;max-width:620px;margin:22px auto 0;color:#54583f;font-size:clamp(17px,1.5vw,20px);}
.crumbs{position:relative;z-index:2;display:inline-flex;gap:8px;align-items:center;font-size:13px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--gray);margin-bottom:22px;}
.crumbs a{text-decoration:none;color:var(--olive);}

/* ---------- forms ---------- */
.form-card{background:var(--cloud);border:1px solid var(--gray-line);border-radius:var(--r-lg);padding:44px;box-shadow:var(--shadow-sm);}
.field{margin-bottom:22px;}
.field label{display:block;font-weight:700;font-size:14px;margin-bottom:9px;}
.field label .req{color:var(--tomato);}
.field input,.field select,.field textarea{
  width:100%;font-family:var(--font-body);font-size:16px;color:var(--ink);
  background:var(--cream);border:1.6px solid var(--gray-line);border-radius:13px;
  padding:14px 16px;transition:border-color .2s, box-shadow .2s, background .2s;
}
.field textarea{resize:vertical;min-height:130px;}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--olive);background:var(--cloud);
  box-shadow:0 0 0 4px rgba(99,125,36,.12);
}
.field.invalid input,.field.invalid select,.field.invalid textarea{border-color:var(--tomato);box-shadow:0 0 0 4px rgba(234,104,44,.1);}
.field .err{display:none;color:var(--tomato);font-size:13px;font-weight:600;margin-top:7px;}
.field.invalid .err{display:block;}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.chip-select{display:flex;flex-wrap:wrap;gap:10px;}
.chip-select label{cursor:pointer;margin:0;}
.chip-select input{position:absolute;opacity:0;pointer-events:none;width:0;}
.chip-select .opt{display:inline-block;padding:11px 18px;border-radius:999px;border:1.6px solid var(--gray-line);font-weight:600;font-size:14.5px;background:var(--cream);transition:.18s;}
.chip-select input:checked + .opt{background:var(--olive);color:var(--cloud);border-color:var(--olive);}
.chip-select .opt:hover{border-color:var(--olive);}
.form-success{display:none;text-align:center;padding:30px 10px;}
.form-success.show{display:block;}
.form-success .tick{width:84px;height:84px;border-radius:50%;background:var(--leaf);color:var(--cloud);display:flex;align-items:center;justify-content:center;font-size:42px;margin:0 auto 22px;}
.form-success h3{font-family:var(--font-display);font-size:30px;font-weight:700;margin-bottom:12px;}

/* contact aside */
.contact-grid{display:grid;grid-template-columns:1fr 1.25fr;gap:48px;align-items:start;}
.contact-info .info-item{display:flex;gap:16px;padding:20px 0;border-bottom:1px solid var(--gray-line);}
.contact-info .info-item:last-child{border-bottom:none;}
.contact-info .ic{width:50px;height:50px;border-radius:14px;background:rgba(99,125,36,.12);color:var(--olive);display:flex;align-items:center;justify-content:center;font-size:22px;flex:0 0 auto;}
.contact-info .info-item b{display:block;font-size:13px;letter-spacing:1px;text-transform:uppercase;color:var(--gray);margin-bottom:4px;}
.contact-info .info-item .v{font-family:var(--font-display);font-size:20px;font-weight:700;}

/* ---------- about ---------- */
.value-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:54px;}
.value-card{background:var(--cloud);border:1px solid var(--gray-line);border-radius:var(--r-md);padding:34px;}
.value-card .vic{font-size:32px;margin-bottom:16px;}
.value-card h3{font-family:var(--font-display);font-size:23px;font-weight:700;margin-bottom:10px;letter-spacing:-.4px;}
.value-card p{color:#54583f;font-size:15.5px;}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:54px;}
.team-card .ph{aspect-ratio:1/1.12;border-radius:var(--r-md);overflow:hidden;position:relative;margin-bottom:16px;}
.team-card .ph image-slot{position:absolute;inset:0;}
.team-card h4{font-family:var(--font-display);font-size:21px;font-weight:700;letter-spacing:-.3px;}
.team-card span{color:var(--olive);font-weight:600;font-size:14.5px;}
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;}
.split .media{aspect-ratio:1/1;border-radius:var(--r-lg);overflow:hidden;position:relative;}
.split .media image-slot{position:absolute;inset:0;}

/* fun number badge for about story */
.story-stats{display:flex;gap:40px;margin-top:30px;flex-wrap:wrap;}
.story-stats .s .n{font-family:var(--font-display);font-weight:700;font-size:46px;color:var(--olive);line-height:1;}
.story-stats .s .l{font-size:14px;font-weight:700;color:var(--gray);margin-top:6px;}

/* services detail rows */
.svc-detail{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;padding:64px 0;border-bottom:1px solid var(--gray-line);}
.svc-detail:nth-child(even) .media{order:2;}
.svc-detail .media{aspect-ratio:5/4;border-radius:var(--r-lg);overflow:hidden;position:relative;}
.svc-detail .media image-slot{position:absolute;inset:0;}
.svc-detail .ic-lg{width:64px;height:64px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:30px;color:var(--cloud);margin-bottom:22px;}
.svc-detail h2{font-family:var(--font-display);font-weight:700;font-size:clamp(30px,3.4vw,42px);letter-spacing:-.8px;margin-bottom:16px;}
.svc-detail .feat{list-style:none;padding:0;margin:24px 0 0;display:grid;gap:12px;}
.svc-detail .feat li{display:flex;gap:12px;align-items:flex-start;font-size:16px;color:#3f4330;}
.svc-detail .feat li::before{content:"✓";color:var(--cloud);background:var(--leaf);width:24px;height:24px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;flex:0 0 auto;margin-top:2px;}

/* faq */
.faq{max-width:820px;margin:54px auto 0;}
.faq-item{border-bottom:1px solid var(--gray-line);}
.faq-q{width:100%;background:none;border:none;cursor:pointer;text-align:left;padding:26px 0;font-family:var(--font-display);font-weight:700;font-size:21px;letter-spacing:-.3px;display:flex;justify-content:space-between;align-items:center;gap:20px;color:var(--ink);}
.faq-q .pm{flex:0 0 auto;width:34px;height:34px;border-radius:50%;border:1.6px solid var(--gray-line);display:flex;align-items:center;justify-content:center;font-size:20px;transition:.25s;}
.faq-item.open .faq-q .pm{background:var(--olive);color:var(--cloud);border-color:var(--olive);transform:rotate(45deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;}
.faq-a p{padding:0 0 26px;color:#54583f;font-size:16px;max-width:680px;}

/* ---------- service illustrated mockups ---------- */
.svc-detail .media{background:radial-gradient(120% 120% at 80% 0%, var(--cream-2), #e7e4d6);display:flex;align-items:center;justify-content:center;padding:38px;}
.mock{width:100%;max-width:362px;font-family:var(--font-body);position:relative;}
.mock-card{background:var(--cloud);border:1px solid var(--gray-line);border-radius:20px;box-shadow:var(--shadow-sm);overflow:hidden;}
.mock .float-tag{position:absolute;z-index:4;background:var(--cloud);border-radius:13px;box-shadow:var(--shadow-sm);padding:10px 13px;display:flex;align-items:center;gap:9px;font-weight:800;font-size:13px;line-height:1.15;}
.mock .float-tag .fic{width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:15px;color:var(--cloud);flex:0 0 auto;}

/* social post */
.m-social .top{display:flex;align-items:center;gap:10px;padding:14px 15px;}
.m-social .av{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--leaf),var(--olive));flex:0 0 auto;}
.m-social .nm{font-weight:800;font-size:14px;line-height:1.2;}
.m-social .nm small{display:block;font-weight:600;color:var(--gray);font-size:11.5px;}
.m-social .pic{height:172px;background:linear-gradient(150deg,var(--marigold),var(--tomato));display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.92);font-family:var(--font-display);font-style:italic;font-size:30px;font-weight:700;}
.m-social .acts{display:flex;gap:16px;padding:13px 15px 6px;font-weight:800;font-size:15px;color:var(--ink);}
.m-social .acts .sp{margin-left:auto;}
.m-social .cap{padding:0 15px 16px;font-size:13px;color:#54583f;line-height:1.45;}
.m-social .cap b{color:var(--ink);}
.m-social .float-tag{top:-14px;right:-16px;}

/* ads dashboard */
.m-ads{padding:20px;}
.m-ads .arow{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;}
.m-ads .alabel{font-size:12.5px;font-weight:700;color:var(--gray);}
.m-ads .abig{font-family:var(--font-display);font-weight:700;font-size:34px;letter-spacing:-.5px;line-height:1;}
.m-ads .pill{background:rgba(99,125,36,.12);color:var(--olive);font-weight:800;font-size:12px;padding:5px 11px;border-radius:999px;}
.m-ads .spark{height:96px;position:relative;margin:6px 0 14px;}
.m-ads .spark svg{width:100%;height:100%;display:block;}
.m-ads .mrow{display:flex;gap:10px;}
.m-ads .mtile{flex:1;background:var(--cream);border-radius:13px;padding:12px 13px;}
.m-ads .mtile b{font-family:var(--font-display);font-weight:700;font-size:20px;display:block;line-height:1;}
.m-ads .mtile span{font-size:11.5px;font-weight:700;color:var(--gray);}
.m-ads .float-tag{bottom:-16px;left:-16px;}

/* landing page A/B */
.m-pages{background:none;border:none;box-shadow:none;display:flex;gap:14px;}
.m-pages .win{flex:1;background:var(--cloud);border:1px solid var(--gray-line);border-radius:16px;box-shadow:var(--shadow-sm);overflow:hidden;position:relative;}
.m-pages .win.b{transform:translateY(16px);}
.m-pages .bbar{height:26px;background:var(--cream-2);display:flex;align-items:center;gap:5px;padding:0 10px;}
.m-pages .bbar i{width:7px;height:7px;border-radius:50%;background:var(--gray-line);display:block;}
.m-pages .pbody{padding:14px;}
.m-pages .ph-line{height:9px;border-radius:5px;background:var(--gray-line);margin-bottom:8px;}
.m-pages .ph-line.t{width:70%;height:12px;background:var(--olive);}
.m-pages .ph-line.s{width:90%;}
.m-pages .ph-btn{height:24px;width:62%;border-radius:8px;margin-top:12px;}
.m-pages .win.a .ph-btn{background:var(--leaf);}
.m-pages .win.b .ph-btn{background:var(--tomato);}
.m-pages .ph-img{height:46px;border-radius:8px;background:linear-gradient(150deg,var(--marigold),var(--tomato));margin-bottom:12px;}
.m-pages .win.a .ph-img{background:linear-gradient(150deg,var(--leaf),var(--olive));}
.m-pages .vs{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:5;width:40px;height:40px;border-radius:50%;background:var(--ink);color:var(--cloud);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-style:italic;font-weight:700;font-size:15px;}
.m-pages .win.b .badge{position:absolute;top:8px;right:8px;background:var(--olive);color:var(--cloud);font-weight:800;font-size:10.5px;padding:4px 8px;border-radius:999px;}

/* email + sms */
.m-email{background:none;border:none;box-shadow:none;position:relative;height:300px;}
.m-email .mailcard{position:absolute;top:0;left:0;width:74%;background:var(--cloud);border:1px solid var(--gray-line);border-radius:16px;box-shadow:var(--shadow-sm);padding:16px;}
.m-email .mailcard .eh{display:flex;align-items:center;gap:9px;margin-bottom:12px;}
.m-email .mailcard .eh .eav{width:30px;height:30px;border-radius:8px;background:var(--marigold);color:var(--ink);display:flex;align-items:center;justify-content:center;font-size:15px;}
.m-email .mailcard .eh b{font-size:13px;font-weight:800;}
.m-email .mailcard .eh small{display:block;font-size:11px;color:var(--gray);font-weight:600;}
.m-email .mailcard .el{height:8px;border-radius:5px;background:var(--gray-line);margin-bottom:7px;}
.m-email .mailcard .el.t{width:80%;height:11px;background:var(--ink-soft);}
.m-email .mailcard .el.s{width:95%;} .m-email .mailcard .el.u{width:60%;}
.m-email .phone{position:absolute;bottom:0;right:0;width:150px;background:var(--ink);border-radius:24px;padding:10px;box-shadow:var(--shadow);}
.m-email .phone .screen{background:var(--cream);border-radius:16px;padding:12px 10px;min-height:150px;display:flex;flex-direction:column;gap:8px;}
.m-email .bubble{max-width:80%;padding:9px 12px;border-radius:14px;font-size:12px;font-weight:600;line-height:1.3;}
.m-email .bubble.them{background:var(--cloud);border:1px solid var(--gray-line);align-self:flex-start;border-bottom-left-radius:5px;}
.m-email .bubble.you{background:var(--olive);color:var(--cloud);align-self:flex-end;border-bottom-right-radius:5px;}
.m-email .float-tag{top:-6px;right:-6px;z-index:6;}

/* ---------- about: funnel thread graphic ---------- */
.split .media.flow-media{aspect-ratio:auto;background:radial-gradient(120% 120% at 80% 0%, var(--cream-2), #e7e4d6);border:1px solid var(--gray-line);display:flex;align-items:center;justify-content:center;padding:38px;}
.story-flow{width:100%;max-width:380px;display:flex;flex-direction:column;gap:14px;position:relative;}
.story-flow::before{content:"";position:absolute;left:35px;top:38px;bottom:38px;width:3px;background:repeating-linear-gradient(var(--leaf) 0 8px,transparent 8px 16px);border-radius:2px;z-index:0;}
.sf-step{display:flex;align-items:center;gap:16px;background:var(--cloud);border:1px solid var(--gray-line);border-radius:16px;padding:16px 18px;box-shadow:var(--shadow-sm);position:relative;z-index:1;}
.sf-step .sf-ic{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--cloud);flex:0 0 auto;}
.sf-step b{display:block;font-family:var(--font-display);font-weight:700;font-size:17px;letter-spacing:-.3px;line-height:1.1;}
.sf-step span{font-size:13px;color:var(--gray);font-weight:600;}
.sf-step.win{background:var(--olive);border-color:var(--olive);}
.sf-step.win b{color:var(--cloud);} .sf-step.win span{color:#dfe3cf;}

/* case study media images */
.case-feature .media .media-cover{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.case-feature .media .logo-fill{position:absolute;inset:0;background:linear-gradient(150deg,var(--leaf),var(--olive));display:flex;align-items:center;justify-content:center;}
.case-feature .media .logo-fill img{width:60%;max-width:260px;border-radius:20px;box-shadow:var(--shadow);}
.case-feature .media .logo-fill.tl{background:linear-gradient(150deg,var(--marigold),var(--tomato));}
.case-feature .media .logo-fill.tl img{width:74%;max-width:300px;}

/* ---------- reviews ---------- */
.reviews-grid{columns:3;column-gap:24px;margin-top:54px;}
.review-card{break-inside:avoid;background:var(--cloud);border:1px solid var(--gray-line);border-radius:var(--r-md);padding:28px;margin-bottom:24px;display:inline-block;width:100%;transition:transform .25s, box-shadow .25s;}
.review-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm);}
.review-card .stars{display:flex;gap:3px;color:var(--tomato);font-size:16px;margin-bottom:14px;letter-spacing:1px;}
.review-card .rating{font-weight:800;color:var(--ink);margin-left:6px;font-size:14px;letter-spacing:0;}
.review-card p{font-size:16px;line-height:1.55;color:#3f4330;margin-bottom:18px;}
.review-card .meta{display:flex;align-items:center;gap:12px;border-top:1px solid var(--gray-line);padding-top:16px;}
.review-card .meta .role{font-family:var(--font-display);font-weight:700;font-size:15px;letter-spacing:-.2px;}
.review-card .meta .when{font-size:12.5px;color:var(--gray);font-weight:600;}
.review-card .tag-pill{display:inline-block;margin-bottom:14px;font-size:12px;font-weight:700;color:var(--olive);background:rgba(99,125,36,.1);padding:5px 11px;border-radius:999px;}

/* case study services list */
.cs-services{display:flex;flex-wrap:wrap;gap:8px;margin:22px 0 26px;}
.cs-services span{font-size:13px;font-weight:600;color:var(--olive);background:rgba(99,125,36,.1);padding:7px 13px;border-radius:999px;}
.cs-note{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;font-weight:700;color:var(--gray);margin-bottom:8px;}
/* ---------- responsive ---------- */
@media (max-width:1024px){
  .hero-grid{grid-template-columns:1fr;gap:40px;}
  .hero-copy{order:1;}
  .hero-visual{order:2;}
  .case-feature{grid-template-columns:1fr;}
  .case-feature .media{min-height:320px;}
  .case-feature .body{padding:40px;}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:36px 30px;}
  .stat-item:nth-child(2)::after{display:none;}
  .steps{grid-template-columns:repeat(2,1fr);}
  .cs-grid{grid-template-columns:repeat(2,1fr);}
  .team-grid{grid-template-columns:repeat(2,1fr);}
  .reviews-grid{columns:2;}
  .value-grid{grid-template-columns:1fr;}
  .split,.svc-detail{grid-template-columns:1fr;gap:36px;}
  .svc-detail:nth-child(even) .media{order:0;}
  .contact-grid{grid-template-columns:1fr;}
}

@media (max-width:760px){
  .nav,
  .header-cta .btn{
    display:none;
  }

  .menu-toggle{
    display:flex;
  }

  body.menu-open{
    overflow:hidden !important;
  }

  body.menu-open .site-header{
    position:fixed !important;
    top:0 !important;
    left:0 !important;
    right:0 !important;
    z-index:10000 !important;
    background:#f4f2e9 !important;
    border-color:var(--gray-line);
    box-shadow:0 18px 44px -28px rgba(44,54,15,.45);
  }

  body.menu-open .nav{
    display:flex !important;
    position:fixed !important;
    top:78px !important;
    left:0 !important;
    right:0 !important;
    bottom:0 !important;
    width:100vw !important;
    height:calc(100vh - 78px) !important;
    z-index:9999 !important;
    flex-direction:column !important;
    align-items:stretch !important;
    gap:6px !important;
    margin:0 !important;
    padding:24px 32px 32px !important;
    background:#f4f2e9 !important;
    border-top:1px solid var(--gray-line) !important;
    overflow-y:auto !important;
  }

  body.menu-open .nav a{
    font-size:20px;
    padding:16px;
    border-radius:14px;
  }

  body.menu-open .nav .btn{
    display:inline-flex !important;
    justify-content:center;
    margin-top:10px;
  }

  .nav > .btn{
    display:none;
  }

  .section{padding:72px 0;}
  .svc-grid{grid-template-columns:1fr;}
  .stats-grid{grid-template-columns:1fr 1fr;}
  .steps{grid-template-columns:1fr;}
  .cs-grid{grid-template-columns:1fr;}
  .team-grid{grid-template-columns:1fr 1fr;}
  .reviews-grid{columns:1;}
  .field-row{grid-template-columns:1fr;}
  .stats-band,.testi,.cta-band{padding:44px 28px;}
  .wrap{padding:0 22px;}
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px;}
  .hero h1{letter-spacing:-1px;}
}

@media (max-width:460px){
  .team-grid{grid-template-columns:1fr;}
  .foot-grid{grid-template-columns:1fr;}
  .hero .chips{gap:22px;}
}